var __defProp3 = Object.defineProperty;
var __defNormalProp3 = (obj, key, value) => key in obj ? __defProp3(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __publicField3 = (obj, key, value) => {
__defNormalProp3(obj, typeof key !== "symbol" ? key + "" : key, value);
return value;
};
(function(global2, factory) {
typeof exports === "object" && typeof module !== "undefined" ? factory(exports, require("vue")) : typeof define === "function" && define.amd ? define(["exports", "vue"], factory) : (global2 = typeof globalThis !== "undefined" ? globalThis : global2 || self, factory(global2["ddei-editor"] = {}, global2.Vue));
})(this, function(exports, vue) {
var _a2;
"use strict";
var __vite_style__ = document.createElement("style");
__vite_style__.textContent = `/**以下为菜单的样式 */
.ddei-editor-menu-dialog[data-v-1cde0d47] {
width: 200px;
background-color: var(--panel-background);
font-size: 13px;
color: var(--panel-title);
display: none;
position: absolute;
font-weight: bolder;
z-index: 999;
border-radius: 4px;
border: 0.3px solid var(--panel-border);
box-shadow: -3px 3px 3px hsla(0, 0%, 0%, 0.25);
}
.ddei-editor-menu-dialog-item[data-v-1cde0d47] {
height: 34px;
width: 100%;
display: flex;
}
.ddei-editor-menu-dialog-item[data-v-1cde0d47]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-editor-menu-dialog-item-icon[data-v-1cde0d47] {
flex: 0 0 34px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-editor-menu-dialog-item-icon .icon[data-v-1cde0d47] {
width: 22px;
height: 22px;
margin: 0px 3px 0px 3px;
}
.ddei-editor-menu-dialog-item-content[data-v-1cde0d47] {
flex: 1;
display: flex;
justify-content: start;
align-items: center;
}
.ddei-editor-menu-dialog-item-desc[data-v-1cde0d47] {
flex: 0 0 34px;
}
.ddei-editor-menu-dialog-item-hr[data-v-1cde0d47] {
border: 0.5px solid var(--panel-border);
width: 93%;
margin: 1px auto;
}
.ddei-core-panel-topmenu[data-v-fefbc1f9] {
background: var(--topmenu-background);
}
.ddei-core-panel-topmenu-quickbox[data-v-fefbc1f9] {
background-color: var(--topmenu-header);
width: 100%;
height: 103px;
display: flex;
}
.icon[data-v-ea668126] {
color: var(--icon);
}
.ddei-core-panel-toolbox[data-v-ea668126] {
user-select: none;
text-align: center;
display: flex;
flex-flow: column;
height: 100%;
/**以下为收折框 */
}
.ddei-core-panel-toolbox-header[data-v-ea668126] {
background: var(--toolbox-header);
border-bottom: 1px solid var(--toolbox-header);
flex: 0 0 30px;
display: flex;
justify-content: center;
align-items: center;
padding: 0px 8px;
}
.ddei-core-panel-toolbox-header-morecontrol[data-v-ea668126] {
display: flex;
justify-content: center;
align-items: center;
flex: 0 1 100px;
}
.ddei-core-panel-toolbox-header-morecontrol .header-3[data-v-ea668126] {
flex: 0 1 8px;
}
.ddei-core-panel-toolbox-header-morecontrol .header-4[data-v-ea668126] {
font-size: 16px;
flex: 0 1 70px;
font-weight: bold;
color: var(--toolbox-title);
}
.ddei-core-panel-toolbox-header-morecontrol[data-v-ea668126]:hover {
background-color: var(--toolbox-hover);
cursor: pointer;
}
.ddei-core-panel-toolbox-header .header-1[data-v-ea668126] {
flex: 0 1 17px;
}
.ddei-core-panel-toolbox-header .header-2[data-v-ea668126] {
font-size: 14px;
}
.ddei-core-panel-toolbox-header .header-7[data-v-ea668126] {
font-size: 18px;
}
.ddei-core-panel-toolbox-header .header-7[data-v-ea668126]:hover {
background-color: var(--toolbox-hover);
cursor: pointer;
}
.ddei-core-panel-toolbox-header .icon1[data-v-ea668126] {
font-size: 23px;
}
.ddei-core-panel-toolbox-header .icon2[data-v-ea668126] {
font-size: 16px;
}
.ddei-core-panel-toolbox-searchbox[data-v-ea668126] {
flex: 0 0 52px;
display: flex;
justify-content: center;
align-items: center;
background: var(--toolbox-background);
}
.ddei-core-panel-toolbox-searchbox-group[data-v-ea668126] {
flex: 1;
margin: 0 25px;
height: 32px;
background: var(--toolbox-header);
border: 1px solid var(--toolbox-header);
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-panel-toolbox-searchbox-group .icon[data-v-ea668126] {
font-size: 24px;
margin: 0 6px;
}
.ddei-core-panel-toolbox-searchbox-group .input[data-v-ea668126] {
flex: 1 1 140px;
height: 28px;
width: 100%;
border: transparent;
outline: none;
background: transparent;
font-size: 16px;
font-weight: 400;
color: var(--toolbox-title);
}
.ddei-core-panel-toolbox-searchbox-group .input[data-v-ea668126]::placeholder {
/* Chrome, Firefox, Opera, Safari 10.1+ */
color: var(--placeholder);
}
.ddei-core-panel-toolbox-searchbox-group .input[data-v-ea668126]::-webkit-input-placeholder {
/* WebKit browsers,webkit内核浏览器 */
color: var(--placeholder);
}
.ddei-core-panel-toolbox-searchbox-group .input[data-v-ea668126]:-moz-placeholder {
/* Mozilla Firefox 4 to 18 */
color: var(--placeholder);
}
.ddei-core-panel-toolbox-searchbox-group .input[data-v-ea668126]::-moz-placeholder {
/* Mozilla Firefox 19+ */
color: var(--placeholder);
}
.ddei-core-panel-toolbox-searchbox-group .input[data-v-ea668126]:-ms-input-placeholder {
/* Internet Explorer 10-11 */
color: var(--placeholder);
}
.ddei-core-panel-toolbox-searchbox-group .input[data-v-ea668126]::-ms-input-placeholder {
/* Microsoft Edge */
color: var(--placeholder);
}
.ddei-core-panel-toolbox-groups[data-v-ea668126] {
text-align: center;
background: var(--toolbox-background, --panel-background);
overflow-y: auto;
display: flex;
flex-flow: column;
flex: 1 1 auto;
}
.ddei-core-panel-toolbox-groups-group[data-v-ea668126] {
text-align: center;
margin-bottom: 1px;
}
.ddei-core-panel-toolbox-groups-group-box[data-v-ea668126] {
display: flex;
height: 35px;
background: var(--toolbox-header);
user-select: none;
justify-content: center;
align-items: center;
}
.ddei-core-panel-toolbox-groups-group-box[data-v-ea668126]:hover {
background-color: var(--toolbox-header);
}
.ddei-core-panel-toolbox-groups-group-box[data-v-ea668126]:active {
background-color: var(--toolbox-header);
}
.ddei-core-panel-toolbox-groups-group-box .title[data-v-ea668126] {
flex: 1;
color: var(--toolbox-title);
text-align: left;
margin-left: 25px;
font-size: 16px;
font-weight: bold;
}
.ddei-core-panel-toolbox-groups-group-box .close[data-v-ea668126] {
margin-right: 10px;
font-size: 18px;
}
.ddei-core-panel-toolbox-groups-group-box .close[data-v-ea668126]:hover {
color: var(--toolbox-title) hover;
cursor: pointer;
}
.ddei-core-panel-toolbox-groups-group-itempanel[data-v-ea668126] {
display: flex;
flex-flow: row wrap;
background: var(--toolbox-background);
padding: 15px 15px 15px 15px;
}
.ddei-core-panel-toolbox-groups-group-itempanel-item[data-v-ea668126] {
flex: 0 0 62px !important;
height: 60px;
margin: 15px 0px;
display: flex;
overflow: hidden;
justify-content: center;
align-items: center;
flex-flow: column;
}
.ddei-core-panel-toolbox-groups-group-itempanel-item[data-v-ea668126]:hover {
background: var(--toolbox-control-hover);
outline: var(--toolbox-control-hover-outline);
cursor: all-scroll;
}
.ddei-core-panel-toolbox-groups-group-itempanel-item .text[data-v-ea668126] {
white-space: nowrap;
text-align: center;
font-size: 13px;
font-weight: 400;
color: var(--toolbox-control-title);
}
.ddei-core-panel-toolbox-groups-group-itempanel-item .icon[data-v-ea668126] {
width: 90%;
height: 90%;
object-fit: contain;
}
.ddei-core-panel-toolbox-groups-group--expanded[data-v-ea668126] {
background-color: var(--toolbox-header);
}
.ddei-editor-qcview[data-v-f305cac8] {
height: 16px;
background: var(--panel-header);
border: 0.5pt solid var(--panel-border);
display: flex;
position: relative;
}
.ddei-editor-qcview-type[data-v-f305cac8] {
flex: 0 0 30px;
height: 14px;
width: 20px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-editor-qcview-type[data-v-f305cac8]:hover {
background: var(--panel-hover);
cursor: pointer;
}
.ddei-editor-qcview-type img[data-v-f305cac8] {
display: block;
float: left;
}
.ddei-editor-qcview-color[data-v-f305cac8] {
flex: 1 1 15px;
height: 13px;
margin-left: 2px;
margin-top: 1px;
}
.ddei-editor-qcview-color[data-v-f305cac8]:hover {
outline: 0.5px solid var(--dot);
box-sizing: border-box;
outline-offset: 0.5px;
}
.ddei-editor-qcview-color--disabled[data-v-f305cac8] {
background-color: var(--panel-disabled) !important;
}
.propertyview[data-v-156d5ed6] {
flex-direction: column;
background: var(--panel-background);
display: flex;
user-select: none;
height: 100%;
}
.propertyview-header[data-v-156d5ed6] {
background: var(--panel-header);
border-bottom: 1px solid #D5D5DF;
flex: 0 0 30px;
display: flex;
justify-content: center;
align-items: center;
}
.propertyview-header .header-7[data-v-156d5ed6] {
font-size: 18px;
margin-left: 8px;
margin-right: 4px;
}
.propertyview-header .header-7-expand[data-v-156d5ed6] {
font-size: 18px;
margin-left: 4px;
margin-right: 4px;
}
.propertyview-header .ding[data-v-156d5ed6] {
font-size: 20px;
margin-right: 4px;
}
.propertyview .content[data-v-156d5ed6] {
flex: 1;
display: flex;
}
.propertyview-subgroup[data-v-156d5ed6] {
flex: 1;
display: flex;
flex-flow: column;
}
.propertyview-subgroup-tabtitle[data-v-156d5ed6] {
flex: 0 0 46px;
display: flex;
border-bottom: 1pt solid #ebebef;
color: grey;
}
.propertyview-subgroup-tabtitle-item[data-v-156d5ed6] {
flex: 1;
text-align: center;
font-size: 16px;
font-weight: 400;
color: var(--panel-title);
display: flex;
justify-content: center;
align-items: center;
}
.propertyview-subgroup-tabtitle-item--selected[data-v-156d5ed6] {
flex: 1;
text-align: center;
font-size: 16px;
background-color: var(--background);
font-weight: 400;
color: var(--dot);
border-bottom: 4px solid var(--dot);
display: flex;
justify-content: center;
align-items: center;
}
.propertyview-subgroup-tabtitle-item[data-v-156d5ed6]:hover {
color: var(--dot);
cursor: pointer;
}
.propertyview-subgroup-tabpanel[data-v-156d5ed6] {
text-align: center;
background: var(--panel-background);
overflow-y: auto;
display: flex;
flex-flow: column;
flex: 1 1 auto;
color: var(--panel-title);
font-size: 15px;
height: 100px;
}
.propertyview-subgroup-tabpanel span[data-v-156d5ed6] {
color: red;
}
.propertyview-subgroup-tabpanel-editors-column[data-v-156d5ed6] {
display: flex;
flex-flow: column;
margin-top: 10px;
margin-bottom: 10px;
}
.propertyview-subgroup-tabpanel-editors-column .title[data-v-156d5ed6] {
background: var(--panel-background);
color: var(--panel-title);
text-align: left;
padding-left: 10px;
margin: auto 0;
margin-bottom: 5px;
font-size: 15px;
}
.propertyview-subgroup-tabpanel-editors-column .editor[data-v-156d5ed6] {
text-align: left;
padding-left: 10px;
}
.propertyview-subgroup-tabpanel-editors-row[data-v-156d5ed6] {
display: flex;
margin-top: 10px;
margin-bottom: 10px;
}
.propertyview-subgroup-tabpanel-editors-row .title[data-v-156d5ed6] {
text-align: left;
padding-left: 10px;
flex: 0 0 100px;
white-space: nowrap;
/*文字不换行*/
overflow: hidden;
/*超出部分隐藏*/
text-overflow: ellipsis;
/*溢出部分用省略号表示*/
margin: auto 0;
font-size: 15px;
}
.propertyview-subgroup-tabpanel-editors-row .editor[data-v-156d5ed6] {
text-align: center;
flex: 1;
}
.propertyview .empty-value[data-v-156d5ed6] {
filter: opacity(50%);
}
.propertyview-groupview[data-v-156d5ed6] {
flex: 0 0 28px;
display: flex;
flex-flow: column;
border-left: 1px solid #E0E3E9;
}
.propertyview-groupview-items[data-v-156d5ed6] {
flex: 1;
display: flex;
flex-flow: column;
}
.propertyview-groupview-items-item[data-v-156d5ed6] {
flex: 0 0 16px;
margin-top: 8px;
margin-bottom: 8px;
display: flex;
flex-flow: column;
justify-content: center;
align-items: center;
}
.propertyview-groupview-items-item--selected[data-v-156d5ed6] {
flex: 0 0 16px;
margin-top: 8px;
margin-bottom: 8px;
display: flex;
flex-flow: column;
justify-content: center;
align-items: center;
}
.propertyview-groupview-items-item--selected > svg[data-v-156d5ed6] {
color: #1F72FF;
}
.propertyview--disabled[data-v-156d5ed6] {
pointer-events: none !important;
user-select: none !important;
filter: opacity(70%);
}
.propertyview--disabled .propertyview-subgroup-tabpanel[data-v-156d5ed6] {
pointer-events: none !important;
user-select: none !important;
filter: opacity(70%) !important;
}
.icon[data-v-cf0859cc] {
color: var(--icon);
}
.ddei-core-panel-openfilesview[data-v-cf0859cc] {
flex: 0 0 30.5px;
background: var(--panel-background);
border-top: 1px solid var(--panel-border);
border-bottom: 1px solid var(--panel-border);
display: flex;
user-select: none;
align-items: center;
}
.ddei-core-panel-openfilesview-expandbox[data-v-cf0859cc] {
flex: 0 0 28px;
display: flex;
justify-content: center;
align-items: center;
height: 100%;
}
.ddei-core-panel-openfilesview-expandbox[data-v-cf0859cc]:hover {
background: var(--panel-hover);
cursor: pointer;
}
.ddei-core-panel-openfilesview-expandbox .icon[data-v-cf0859cc] {
font-size: 18px;
}
.ddei-core-panel-openfilesview .addfile[data-v-cf0859cc] {
margin: 0px 10px;
font-size: 24px;
}
.ddei-core-panel-openfilesview-movebox[data-v-cf0859cc] {
flex: 0 0 25px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-panel-openfilesview-movebox[data-v-cf0859cc]:hover {
background: var(--panel-hover);
cursor: pointer;
}
.ddei-core-panel-openfilesview-movebox img[data-v-cf0859cc] {
filter: brightness(60%);
margin-top: 4px;
}
.ddei-core-panel-openfilesview-item[data-v-cf0859cc] {
height: 100%;
flex: 0 0 195px;
display: flex;
justify-content: center;
align-items: center;
background-color: var(--panel-background);
border-right: 1px solid var(--panel-hover);
}
.ddei-core-panel-openfilesview-item .icon[data-v-cf0859cc] {
font-size: 16px;
flex: 0 0 42px;
text-align: center;
}
.ddei-core-panel-openfilesview-item .close[data-v-cf0859cc] {
font-size: 18px;
flex: 0 0 24px;
margin-left: -5px;
}
.ddei-core-panel-openfilesview-item .textcontent[data-v-cf0859cc] {
font-size: 15px;
flex: 0 0 130px;
width: 130px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-panel-openfilesview-item .textcontent .text[data-v-cf0859cc] {
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
color: var(--panel-title);
flex: 1;
font-size: 16px;
font-weight: 400;
}
.ddei-core-panel-openfilesview-item span .dirty[data-v-cf0859cc] {
color: red;
width: 10px;
flex: 0 0 10px;
font-size: 18px;
text-align: right;
}
.ddei-core-panel-openfilesview-item[data-v-cf0859cc]:hover {
background: var(--panel-hover);
}
.ddei-core-panel-openfilesview-item--selected[data-v-cf0859cc] {
background: var(--panel-selected);
}
.ddei-core-panel-openfilesview-item--selected .textcontent .text[data-v-cf0859cc] {
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
flex: 1;
color: var(--panel-title);
}
.ddei-editor-canvasview {
flex: 1;
overflow: hidden;
position: relative;
background-color: var(--panel-header);
}
.ddei-editor-canvasview-contentlayer {
overflow: hidden;
width: 100%;
height: 100%;
z-index: 50;
position: absolute;
pointer-events: none;
}
.ddei-core-panel-bottommenu[data-v-5ec138cc] {
height: 30px;
display: flex;
color: var(--text);
background: var(--background);
justify-content: center;
align-items: center;
font-size: 16px;
}
.ddei-core-panel-eimport[data-v-9c97ea48] {
height: 103px;
width: 260px;
flex: 0 1 260px;
display: grid;
grid-template-rows: 20px 57px 26px;
grid-template-columns: 1fr;
text-align: center;
}
.ddei-core-panel-eimport .content[data-v-9c97ea48] {
display: flex;
justify-content: center;
align-items: center;
padding: 0px 4px;
}
.ddei-core-panel-eimport .content .part[data-v-9c97ea48] {
flex: 1;
padding: 0px 2px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-panel-eimport .content .part .button-v[data-v-9c97ea48] {
flex: 1;
height: 50px;
border-radius: 4px;
display: flex;
flex-direction: column;
align-items: center;
}
.ddei-core-panel-eimport .content .part .button-v[data-v-9c97ea48]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-core-panel-eimport .content .part .button-v-selected[data-v-9c97ea48] {
flex: 1;
height: 50px;
background-color: var(--panel-selected);
border-radius: 4px;
display: flex;
flex-direction: column;
align-items: center;
}
.ddei-core-panel-eimport .content .part .button-v-selected .text[data-v-9c97ea48] {
color: var(--panel-title-selected);
}
.ddei-core-panel-eimport .content .part .button-v-disabled[data-v-9c97ea48] {
flex: 1;
height: 50px;
cursor: not-allowed;
display: flex;
flex-direction: column;
align-items: center;
background-color: var(--panel-disabled);
}
.ddei-core-panel-eimport .content .part .button-v-disabled > span[data-v-9c97ea48] {
color: var(--panel-title-disabled);
}
.ddei-core-panel-eimport .content .part .button-v-disabled .text[data-v-9c97ea48] {
color: var(--panel-title-disabled);
}
.ddei-core-panel-eimport .content .part .text[data-v-9c97ea48] {
flex: 0 0 20px;
white-space: nowrap;
font-size: 14px;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-panel-eimport .tail[data-v-9c97ea48] {
display: flex;
justify-content: center;
align-items: center;
font-size: 14px;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-panel-fileinfo[data-v-b1753b91] {
height: 103px;
width: 230px;
flex: 0 1 230px;
display: grid;
grid-template-rows: 20px 57px 26px;
grid-template-columns: 1fr;
text-align: center;
}
.ddei-core-panel-fileinfo .content[data-v-b1753b91] {
display: flex;
justify-content: center;
align-items: center;
border-right: 1px solid var(--panel-border);
padding: 0px 4px;
}
.ddei-core-panel-fileinfo .content .part[data-v-b1753b91] {
padding: 0px 2px;
flex: 1;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-panel-fileinfo .content .part .button-v[data-v-b1753b91] {
flex: 1;
height: 50px;
display: flex;
flex-direction: column;
align-items: center;
}
.ddei-core-panel-fileinfo .content .part .button-v .text[data-v-b1753b91] {
white-space: nowrap;
flex: 0 0 13px;
font-size: 14px;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-panel-fileinfo .content .part .button-v[data-v-b1753b91]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-core-panel-fileinfo .content .part .button-h[data-v-b1753b91] {
flex: 1;
display: flex;
flex-direction: column;
margin-top: -2px;
}
.ddei-core-panel-fileinfo .content .part .button-h .button[data-v-b1753b91] {
flex: 1;
display: flex;
justify-content: center;
align-items: center;
border-radius: 4px;
}
.ddei-core-panel-fileinfo .content .part .button-h .button .icon[data-v-b1753b91] {
font-size: 28px;
flex: 1;
}
.ddei-core-panel-fileinfo .content .part .button-h .button .text[data-v-b1753b91] {
white-space: nowrap;
flex: 0 0 25px;
font-size: 14px;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-panel-fileinfo .content .part .button-h .button[data-v-b1753b91]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-core-panel-fileinfo .tail[data-v-b1753b91] {
display: flex;
justify-content: center;
align-items: center;
font-size: 14px;
font-weight: 400;
color: var(--panel-title);
border-right: 1px solid var(--panel-border);
}
.ddei-core-panel-fileoperate[data-v-891d9231] {
width: 150px;
height: 90px;
border-right: 1px solid #e0e0e0;
grid-template-rows: 30px 30px 20px;
grid-template-columns: 1fr;
display: grid;
gap: 4px;
padding-right: 4px;
}
.ddei-core-panel-fileoperate-item[data-v-891d9231] {
margin: auto;
display: grid;
grid-template-columns: 1fr 1fr 1fr 1fr;
gap: 4px;
}
.ddei-core-panel-fileoperate-item-text[data-v-891d9231] {
text-align: center;
font-size: 12px;
grid-column: 1/5;
color: var(--panel-title);
}
.ddei-core-panel-fileoperate-item-box[data-v-891d9231] {
width: 30px;
height: 50px;
color: var(--panel-title);
border-radius: 4px;
font-size: 12px;
display: grid;
grid-template-rows: 25px 25px 10px;
grid-template-columns: 1fr;
}
.ddei-core-panel-fileoperate-item-box div[data-v-891d9231] {
margin: auto;
}
.ddei-core-panel-fileoperate-item-box img[data-v-891d9231] {
filter: brightness(45%) drop-shadow(0.2px 0px 0.2px var(--panel-title));
width: 16px;
height: 16px;
margin: auto;
}
.ddei-core-panel-fileoperate-item-box[data-v-891d9231]:hover {
background-color: var(--panel-hover);
border-radius: 4px;
}
.ddei-core-panel-fontandtext[data-v-84f4d012] {
height: 103px;
display: grid;
grid-template-rows: 20px 57px 26px;
grid-template-columns: 1fr;
text-align: center;
}
.ddei-core-panel-fontandtext .content[data-v-84f4d012] {
display: flex;
flex-direction: column;
padding-left: 16px;
border-right: 1px solid var(--panel-border);
}
.ddei-core-panel-fontandtext .content .buttons[data-v-84f4d012] {
flex: 1;
}
.ddei-core-panel-fontandtext .content .buttons > div[data-v-84f4d012] {
float: left;
margin-right: 10px;
}
.ddei-core-panel-fontandtext .content .buttons .mg16[data-v-84f4d012] {
margin-right: 3px;
}
.ddei-core-panel-fontandtext .content .buttons .mg165[data-v-84f4d012] {
margin-right: 5px;
}
.ddei-core-panel-fontandtext .content .buttons .mg14[data-v-84f4d012] {
margin-right: 3px;
margin-left: -3px;
}
.ddei-core-panel-fontandtext .content .buttons .mg17[data-v-84f4d012] {
margin-right: 8px;
}
.ddei-core-panel-fontandtext .content .buttons .b1[data-v-84f4d012] {
width: 152px;
margin-right: 0px;
}
.ddei-core-panel-fontandtext .content .buttons .b2[data-v-84f4d012] {
width: 64px;
}
.ddei-core-panel-fontandtext .content .buttons .b4[data-v-84f4d012] {
margin-right: 33px;
}
.ddei-core-panel-fontandtext .content .buttons .b5[data-v-84f4d012] {
margin-top: 1px;
margin-right: 17px;
}
.ddei-core-panel-fontandtext .content .buttons .b6[data-v-84f4d012] {
margin-top: 1px;
margin-right: 15px;
}
.ddei-core-panel-fontandtext .tail[data-v-84f4d012] {
display: flex;
justify-content: center;
align-items: center;
font-size: 14px;
font-weight: 400;
color: var(--panel-title);
border-right: 1px solid var(--panel-border);
}
.ddei-core-panel-operate[data-v-fc2f1000] {
height: 103px;
width: 230px;
flex: 0 1 230px;
display: grid;
grid-template-rows: 20px 57px 26px;
grid-template-columns: 1fr;
text-align: center;
}
.ddei-core-panel-operate .content[data-v-fc2f1000] {
display: flex;
justify-content: center;
align-items: center;
border-right: 1px solid var(--panel-border);
padding: 0px 4px;
}
.ddei-core-panel-operate .content .part[data-v-fc2f1000] {
padding: 0px 2px;
flex: 1;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-panel-operate .content .part .button-v[data-v-fc2f1000] {
display: flex;
flex-direction: column;
flex: 1;
height: 50px;
border-radius: 4px;
align-items: center;
}
.ddei-core-panel-operate .content .part .button-v[data-v-fc2f1000]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-core-panel-operate .content .part .button-v--selected[data-v-fc2f1000] {
flex: 1;
height: 50px;
display: flex;
flex-direction: column;
background-color: var(--panel-selected);
border-radius: 4px;
}
.ddei-core-panel-operate .content .part .button-v--selected .text[data-v-fc2f1000] {
color: var(--panel-title-selected);
}
.ddei-core-panel-operate .content .part .button-v--disabled[data-v-fc2f1000] {
flex: 1;
height: 50px;
display: flex;
flex-direction: column;
cursor: not-allowed;
align-items: center;
background-color: var(--panel-disabled);
}
.ddei-core-panel-operate .content .part .button-v--disabled .icon[data-v-fc2f1000] {
filter: grayscale(1);
opacity: 40%;
}
.ddei-core-panel-operate .content .part .button-v--disabled .text[data-v-fc2f1000] {
color: var(--panel-title-disabled);
}
.ddei-core-panel-operate .content .part .text[data-v-fc2f1000] {
font-size: 14px;
white-space: nowrap;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-panel-operate .tail[data-v-fc2f1000] {
display: flex;
justify-content: center;
align-items: center;
font-size: 14px;
font-weight: 400;
color: var(--panel-title);
border-right: 1px solid var(--panel-border);
}
.ddei-core-panel-sort[data-v-9f739241] {
height: 103px;
width: 230px;
flex: 0 1 230px;
display: grid;
grid-template-rows: 20px 57px 26px;
grid-template-columns: 1fr;
text-align: center;
}
.ddei-core-panel-sort .content[data-v-9f739241] {
display: flex;
justify-content: center;
align-items: center;
padding: 0px 4px;
border-right: 1px solid var(--panel-border);
}
.ddei-core-panel-sort .content .part[data-v-9f739241] {
flex: 1;
padding: 0px 2px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-panel-sort .content .part .button-v[data-v-9f739241] {
flex: 1;
height: 50px;
border-radius: 4px;
}
.ddei-core-panel-sort .content .part .button-v[data-v-9f739241]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-core-panel-sort .content .part .button-v--selected[data-v-9f739241] {
flex: 1;
height: 50px;
background-color: var(--panel-selected);
border-radius: 4px;
}
.ddei-core-panel-sort .content .part .button-v--selected .text[data-v-9f739241] {
color: var(--panel-title-selected);
}
.ddei-core-panel-sort .content .part .button-v--disabled[data-v-9f739241] {
flex: 1;
height: 50px;
cursor: not-allowed;
background-color: var(--panel-disabled);
}
.ddei-core-panel-sort .content .part .button-v--disabled > span[data-v-9f739241] {
color: var(--panel-title-disabled);
}
.ddei-core-panel-sort .content .part .button-v--disabled .icon[data-v-9f739241] {
filter: grayscale(1);
opacity: 40%;
}
.ddei-core-panel-sort .content .part .button-v--disabled .text[data-v-9f739241] {
color: var(--panel-title-disabled);
}
.ddei-core-panel-sort .content .part .text[data-v-9f739241] {
height: 20px;
font-size: 14px;
white-space: nowrap;
font-weight: 400;
color: var(--panel-title);
margin-top: -3px;
}
.ddei-core-panel-sort .content .part .extbtn[data-v-9f739241] {
font-size: 12px;
vertical-align: top;
}
.ddei-core-panel-sort .tail[data-v-9f739241] {
display: flex;
justify-content: center;
align-items: center;
font-size: 14px;
font-weight: 400;
color: var(--panel-title);
border-right: 1px solid var(--panel-border);
}
.ddei-core-panel-quickstyle[data-v-109430c5] {
width: 430px;
height: 90px;
border-right: 1px solid #e0e0e0;
grid-template-rows: 20px 20px 20px 20px;
grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
display: grid;
padding-right: 10px;
}
.ddei-core-panel-quickstyle-item[data-v-109430c5] {
margin: auto;
}
.ddei-core-panel-quickstyle-item-box[data-v-109430c5] {
width: 60px;
height: 20px;
color: black;
text-align: center;
border-radius: 4px;
font-size: 14px;
margin-top: 2px;
}
.ddei-core-panel-quickstyle-item-box img[data-v-109430c5] {
margin-top: 3px;
filter: brightness(45%) drop-shadow(0.2px 0px 0.2px #000);
float: left;
margin-left: 2px;
}
.ddei-core-panel-quickstyle-item-box div[data-v-109430c5] {
float: left;
margin-left: 3px;
}
.ddei-core-panel-quickstyle-item-box-selected[data-v-109430c5] {
width: 25px;
height: 25px;
text-align: center;
background-color: #e4e4e8;
border-radius: 4px;
}
.ddei-core-panel-quickstyle-item-box-selected img[data-v-109430c5] {
margin-top: 4px;
filter: brightness(45%) drop-shadow(0.2px 0px 0.2px #000);
}
.ddei-core-panel-quickstyle-item-box[data-v-109430c5]:hover {
background-color: #e9e9ee;
border-radius: 4px;
}
.ddei-core-panel-quickstyle-item-box-template[data-v-109430c5] {
width: 350px;
height: 55px;
margin-top: 4px;
border-radius: 4px;
padding-left: 5px;
background: white;
display: flex;
}
.ddei-core-panel-quickstyle-item-box-template-item[data-v-109430c5] {
height: 34px;
margin: auto;
flex: 0 0 34px;
color: black;
border-radius: 4px;
border: 1px solid black;
text-align: center;
padding-top: 3px;
}
.ddei-core-panel-quickstyle-item-box-template-item[data-v-109430c5]:hover {
outline: 0.5px solid #017fff;
box-sizing: border-box;
outline-offset: 3px;
}
.ddei-core-panel-quickstyle-item-box-template-icon[data-v-109430c5] {
width: 20px;
grid-template-rows: 17px 17px 17px;
grid-template-columns: 1fr;
margin: auto;
display: grid;
margin-top: -2px;
margin-right: 5px;
}
.ddei-core-panel-quickstyle-item-box-template-icon img[data-v-109430c5] {
margin-top: 5px;
margin-left: 8px;
filter: brightness(80%) drop-shadow(0.1px 0px 0.1px #000);
}
.ddei-core-panel-quickstyle-item-text[data-v-109430c5] {
text-align: center;
font-family: "Microsoft YaHei";
font-size: 12px;
color: #787878;
margin-top: 8px;
}
.ddei-core-panel-tool[data-v-d02823f2] {
height: 103px;
width: 200px;
flex: 0 1 200px;
display: grid;
grid-template-rows: 20px 57px 26px;
grid-template-columns: 1fr;
text-align: center;
}
.ddei-core-panel-tool .content[data-v-d02823f2] {
display: flex;
justify-content: center;
align-items: center;
border-right: 1px solid var(--panel-border);
padding: 0px 4px;
}
.ddei-core-panel-tool .content .part[data-v-d02823f2] {
flex: 1;
display: flex;
justify-content: center;
align-items: center;
padding: 0px 2px;
}
.ddei-core-panel-tool .content .part .button-v[data-v-d02823f2] {
display: flex;
flex-direction: column;
flex: 1;
height: 50px;
border-radius: 4px;
align-items: center;
}
.ddei-core-panel-tool .content .part .button-v[data-v-d02823f2]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-core-panel-tool .content .part .button-v--selected[data-v-d02823f2] {
flex: 1;
display: flex;
flex-direction: column;
height: 50px;
background-color: var(--panel-selected);
border-radius: 4px;
align-items: center;
}
.ddei-core-panel-tool .content .part .button-v--selected .text[data-v-d02823f2] {
color: var(--panel-title-selected);
}
.ddei-core-panel-tool .content .part .button-v--disabled[data-v-d02823f2] {
flex: 1;
height: 50px;
display: flex;
flex-direction: column;
cursor: not-allowed;
align-items: center;
background-color: var(--panel-disabled);
}
.ddei-core-panel-tool .content .part .button-v--disabled .icon[data-v-d02823f2] {
filter: grayscale(1);
opacity: 40%;
}
.ddei-core-panel-tool .content .part .button-v--disabled .text[data-v-d02823f2] {
color: var(--panel-title-disabled);
}
.ddei-core-panel-tool .content .part .text[data-v-d02823f2] {
flex: 0 0 13px;
font-size: 14px;
white-space: nowrap;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-panel-tool .tail[data-v-d02823f2] {
display: flex;
justify-content: center;
align-items: center;
font-size: 14px;
font-weight: 400;
color: var(--panel-title);
border-right: 1px solid var(--panel-border);
}
.ddei-core-panel-bottom-shapecount[data-v-91252de3] {
flex: 0 0 100px;
display: block;
font-size: 15px;
text-align: center;
}
.ddei-core-panel-bottom-managelayers[data-v-e3adc5da] {
flex: 0 0 30px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-panel-bottom-managelayers .icon[data-v-e3adc5da] {
font-size: 20px;
}
.ddei-core-panel-bottom-managelayers[data-v-e3adc5da]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-panel-bottom-play[data-v-7e2fc5b7] {
flex: 0 0 35px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-panel-bottom-suitratio[data-v-4eeb5012] {
flex: 0 0 30px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-panel-bottom-suitratio .icon[data-v-4eeb5012] {
font-size: 20px;
}
.ddei-core-panel-bottom-suitratio[data-v-4eeb5012]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.expbtn[data-v-f8d489b0] {
width: 14px;
font-size: 14px;
}
.icon[data-v-f8d489b0] {
font-size: 20px;
width: 20px;
height: 20px;
}
.ddei-core-panel-bottom-changeratio[data-v-f8d489b0] {
flex: 0 0 157px;
display: flex;
justify-content: center;
align-items: center;
font-size: 15px;
}
.ddei-core-panel-bottom-changeratio span[data-v-f8d489b0] {
float: left;
width: 36px;
text-align: center;
margin-left: 5px;
margin-right: 5px;
}
.ddei-core-panel-bottom-changeratio div[data-v-f8d489b0] {
float: left;
padding-left: 5px;
padding-right: 5px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-panel-bottom-changeratio input[data-v-f8d489b0] {
float: left;
width: 100px;
border-radius: 4px;
}
.ddei-core-panel-bottom-changeratio__combox[data-v-f8d489b0] {
float: left;
padding-left: 5px;
padding-right: 5px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-panel-bottom-changeratio__combox__dialog[data-v-f8d489b0]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-panel-bottom-addpage[data-v-d059d47d] {
flex: 0 0 40px;
display: flex;
justify-content: center;
align-items: center;
margin-left: 10px;
}
.ddei-core-panel-bottom-addpage .icon[data-v-d059d47d] {
font-size: 20px;
}
.ddei-core-panel-bottom-pages[data-v-d059d47d] {
font-size: 15px;
flex: 1;
display: block;
text-align: center;
}
.ddei-core-panel-bottom-pages-movebox[data-v-d059d47d] {
width: 25px;
height: 27px;
float: left;
text-align: center;
}
.ddei-core-panel-bottom-pages-movebox .icon[data-v-d059d47d] {
font-size: 20px;
}
.ddei-core-panel-bottom-pages-movebox[data-v-d059d47d]:hover {
background: #ebebef;
cursor: pointer;
}
.ddei-core-panel-bottom-pages-movebox .icon[data-v-d059d47d] {
height: 27px;
}
.ddei-core-panel-bottom-pages-page[data-v-d059d47d] {
float: left;
height: 27px;
border-right: 1px solid var(--panel-border);
padding: 0 10px;
text-align: center;
}
.ddei-core-panel-bottom-pages-page span[data-v-d059d47d] {
height: 27px;
width: 80px;
padding-left: 3px;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
display: inline-flex;
align-items: center;
background: var(--panel-background);
}
.ddei-core-panel-bottom-pages-page span[data-v-d059d47d]:hover {
color: var(--dot);
cursor: pointer;
background: var(--background);
}
.ddei-core-panel-bottom-pages-page--selected[data-v-d059d47d] {
float: left;
height: 27px;
border-right: 1px solid var(--panel-border);
padding: 0 10px;
text-align: center;
}
.ddei-core-panel-bottom-pages-page--selected span[data-v-d059d47d] {
height: 27px;
width: 80px;
padding-left: 3px;
background: var(--panel-selected);
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
color: var(--dot);
font-weight: bold;
display: inline-flex;
align-items: center;
}
.ddei-core-panel-toolbox-simple[data-v-bd214554] {
text-align: center;
position: absolute;
z-index: 99999;
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 5px;
overflow: hidden;
background-color: var(--panel-background);
display: flex;
justify-content: start;
align-items: center;
}
.ddei-core-panel-toolbox-simple .item[data-v-bd214554] {
width: 30px;
height: 30px;
border-radius: 3px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-panel-toolbox-simple .item > img[data-v-bd214554] {
margin-top: 2px;
margin-left: 2px;
}
.ddei-core-panel-toolbox-simple .item[data-v-bd214554]:hover {
background-color: #e2dede;
cursor: pointer;
}
.ddei-core-panel-toolbox-simple .item-icon-html[data-v-bd214554] {
width: 30px;
height: 30px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-panel-toolbox-simple .item-icon-html[data-v-bd214554] > * {
width: 28px !important;
height: 28px !important;
}
.ddei-core-panel-toolbox-simple .item-selected[data-v-bd214554] {
background-color: #e2dede;
}
.ddei-core-panel-toolbox-simple .item-block[data-v-bd214554] {
width: 10px;
height: 10px;
}
.ddei-core-panel-toolbox-simple .item-drag[data-v-bd214554] {
width: 100%;
height: 10px;
background-color: #efefef;
}
.ddei-core-panel-toolbox-simple .item-drag[data-v-bd214554]:hover {
background-color: var(--dot);
cursor: grab;
}
.ddei-core-panel-toolbox-simple .item-drag-2[data-v-bd214554] {
height: 100%;
width: 10px;
background-color: #efefef;
}
.ddei-core-panel-toolbox-simple .item-drag-2[data-v-bd214554]:hover {
background-color: var(--dot);
cursor: grab;
}
.ddei-core-panel-topmenu-simple[data-v-52f75ccc] {
text-align: center;
position: absolute;
color: var(--text);
z-index: 99999;
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 5px;
overflow: hidden;
background-color: var(--panel-background);
display: flex;
font-size: 14px;
justify-content: start;
align-items: center;
}
.ddei-core-panel-topmenu-simple .item[data-v-52f75ccc] {
min-width: 60px;
padding: 0 10px;
height: 24px;
border-radius: 3px;
display: flex;
justify-content: center;
align-items: center;
border-right: 0.5px solid #e2dede;
border-top-right-radius: 0px;
border-bottom-right-radius: 0px;
}
.ddei-core-panel-topmenu-simple .item > div[data-v-52f75ccc] {
width: 100%;
}
.ddei-core-panel-topmenu-simple .item[data-v-52f75ccc]:hover {
background-color: #e2dede;
cursor: pointer;
border-top-right-radius: 3px;
border-bottom-right-radius: 3px;
}
.ddei-core-panel-topmenu-simple .item-selected[data-v-52f75ccc] {
background-color: #e2dede;
}
.ddei-core-panel-topmenu-simple .item-block[data-v-52f75ccc] {
width: 10px;
height: 10px;
}
.ddei-core-panel-topmenu-simple .item-drag[data-v-52f75ccc] {
width: 100%;
height: 10px;
background-color: #efefef;
}
.ddei-core-panel-topmenu-simple .item-drag[data-v-52f75ccc]:hover {
background-color: var(--dot);
cursor: grab;
}
.ddei-core-panel-topmenu-simple .item-drag-2[data-v-52f75ccc] {
height: 100%;
width: 10px;
background-color: #efefef;
}
.ddei-core-panel-topmenu-simple .item-drag-2[data-v-52f75ccc]:hover {
background-color: var(--dot);
cursor: grab;
}
.ddei-editor-quickifat-item-box[data-v-4ef00c85] {
width: 22px;
display: flex;
text-align: center;
}
.ddei-editor-quickifat-item-box--disabled[data-v-4ef00c85] {
pointer-events: none;
filter: grayscale(1);
opacity: 40%;
background: var(--panel-disabled);
cursor: not-allowed;
}
.ddei-editor-quickifat-item-box[data-v-4ef00c85]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-editor-quickifat-item-box .magtop-1[data-v-4ef00c85] {
margin-top: -1px;
}
.ddei-editor-quickifat-item-box .magtop-2[data-v-4ef00c85] {
margin-top: -2px;
}
.ddei-editor-quickifat-item-box .magtop-3[data-v-4ef00c85] {
margin-top: -3px;
}
.ddei-pv-border-dash-combox[data-v-8ff63c75] {
height: 28px;
}
.ddei-pv-border-dash-combox--disabled .textinput[data-v-8ff63c75] {
background-color: var(--panel-background);
height: 28px;
justify-content: center;
align-items: center;
}
.ddei-pv-border-dash-combox .textinput[data-v-8ff63c75] {
width: 100%;
padding-right: 5px;
border: 0.5px solid var(--panel-border);
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
padding-left: 5px;
height: 28px;
}
.ddei-pv-border-dash-combox .textinput[data-v-8ff63c75]:hover {
border: 1px solid var(--dot);
box-sizing: border-box;
}
.ddei-pv-border-dash-combox .textinput .div_input[data-v-8ff63c75] {
flex: 1 1 calc(100% - 10px);
width: calc(100% - 10px);
height: 3px;
}
.ddei-pv-border-dash-combox .textinput div[data-v-8ff63c75] {
flex: 0 0 20px;
}
.icon[data-v-8ff63c75] {
font-size: 16px;
}
.ddei_pv_border_weight_combox[data-v-e7c6034b] {
height: 28px;
}
.ddei_pv_border_weight_combox_disabled .textinput[data-v-e7c6034b] {
background-color: #d2d2d2;
height: 28px;
justify-content: center;
align-items: center;
}
.ddei_pv_border_weight_combox .textinput[data-v-e7c6034b] {
width: 100%;
padding-right: 5px;
border: 0.5px solid #d2d2d2;
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
padding-left: 5px;
height: 28px;
}
.ddei_pv_border_weight_combox .textinput[data-v-e7c6034b]:hover {
border: 1px solid #017fff;
box-sizing: border-box;
}
.ddei_pv_border_weight_combox .textinput .div_input[data-v-e7c6034b] {
flex: 1 1 calc(100% - 10px);
width: calc(100% - 10px);
height: 3px;
}
.ddei_pv_border_weight_combox .textinput div[data-v-e7c6034b] {
flex: 0 0 20px;
}
.icon[data-v-e7c6034b] {
font-size: 16px;
}
.ddei-editor-quick-fat-item-box[data-v-b43b0371] {
width: 24px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-editor-quick-fat-item-box[data-v-b43b0371]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-editor-quick-fat-item-box--selected[data-v-b43b0371] {
background-color: var(--panel-selected);
}
.ddei-editor-quick-fat-item-box--disabled[data-v-b43b0371] {
background-color: var(--panel-disabled);
pointer-events: none;
cursor: not-allowed;
filter: grayscale(1);
opacity: 40%;
}
.ddei-editor-quick-fat-item-box .rotate-90[data-v-b43b0371] {
transform: rotate(90deg);
}
.ddei-editor-quick-fat-item-box .ext-underline[data-v-b43b0371] {
margin-top: 5.5px;
font-size: 16px;
}
.ddei-editor-quick-fat-item-box .magtop-1[data-v-b43b0371] {
margin-top: -1px;
}
.ddei-editor-quick-fat-item-box .magtop-2[data-v-b43b0371] {
margin-top: -2px;
}
.ddei-editor-quick-fat-item-box .magtop-3[data-v-b43b0371] {
margin-top: -3px;
}
.ddei-editor-quick-fat-item-box[data-v-019ae087] {
width: 15px;
height: 24px;
overflow: hidden;
display: flex;
align-items: center;
flex-direction: column;
}
.ddei-editor-quick-fat-item-box .icon[data-v-019ae087] {
flex: 0 0 16px;
}
.ddei-editor-quick-fat-item-box .colorbar[data-v-019ae087] {
width: 100%;
flex: 0 0 3px;
}
.ddei-editor-quick-fat-item-box .colinput[data-v-019ae087] {
border: none;
outline: none;
display: block;
margin-top: 5px;
}
.ddei-editor-quick-fat-item-box .magtop-1[data-v-019ae087] {
margin-top: -1px;
}
.ddei-editor-quick-fat-item-box[data-v-019ae087]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-editor-quick-fat-item-box--disabled[data-v-019ae087] {
background-color: var(--panel-disabled);
pointer-events: none;
cursor: not-allowed;
filter: grayscale(1);
opacity: 40%;
}
/*字体选择框*/
.ddei-editor-quick-fat-item-fontfamily[data-v-ec936992] {
background-color: var(--panel-background);
height: 24px;
display: flex;
border-top-left-radius: 4px;
border-bottom-left-radius: 4px;
justify-content: center;
align-items: center;
border: 1px solid var(--panel-border);
border-right: none;
box-sizing: border-box;
}
.ddei-editor-quick-fat-item-fontfamily[data-v-ec936992]:hover {
border: 0.5px solid var(--dot);
box-sizing: border-box;
}
.ddei-editor-quick-fat-item-fontfamily--disabled[data-v-ec936992]:hover {
background-color: var(--panel-disabled);
cursor: not-allowed !important;
}
.ddei-editor-quick-fat-item-fontfamily_input[data-v-ec936992] {
width: calc(100% - 20px);
border: transparent;
outline: none;
font-size: 15px;
color: var(--panel-title);
background: transparent;
}
.ddei-editor-quick-fat-item-fontfamily_combox[data-v-ec936992] {
height: 24px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-editor-quick-fat-item-fontfamily_combox .iconfont-45[data-v-ec936992] {
font-size: 13px;
}
/*字体大小设置框 */
.ddei-editor-quick-fat-item-fontsize[data-v-4fcf2a95] {
background-color: var(--panel-background);
height: 24px;
display: flex;
justify-content: center;
align-items: center;
border-top-right-radius: 4px;
border-bottom-right-radius: 4px;
border: 1px solid var(--panel-border);
}
.ddei-editor-quick-fat-item-fontsize[data-v-4fcf2a95]:hover {
border: 0.5px solid var(--dot);
}
.ddei-editor-quick-fat-item-fontsize--disabled[data-v-4fcf2a95]:hover {
background-color: var(--panel-disabled);
cursor: not-allowed !important;
}
.ddei-editor-quick-fat-item-fontsize_input[data-v-4fcf2a95] {
width: calc(100% - 20px);
border: transparent;
outline: none;
color: var(--panel-title);
font-size: 15px;
background: transparent;
}
.ddei-editor-quick-fat-item-fontsize_combox[data-v-4fcf2a95] {
height: 24px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-editor-quick-fat-item-fontsize_combox .iconfont-45[data-v-4fcf2a95] {
font-size: 13px;
}
.ddei-editor-quick-fat-item-box[data-v-4fcf2a95] {
width: 25px;
height: 25px;
text-align: center;
}
.ddei-editor-quick-fat-item-box--disabled[data-v-4fcf2a95] {
color: var(--panel-title-disabled);
filter: brightness(200%) !important;
}
.ddei-editor-quick-fat-item-box--disabled[data-v-4fcf2a95]:hover {
background-color: var(--panel-disabled);
cursor: not-allowed;
}
.ddei-editor-quick-fat-item-box[data-v-4fcf2a95]:hover {
background-color: var(--panel-hover);
border-radius: 4px;
}
.ddei_pv_line_point_combox[data-v-5b25a083] {
height: 28px;
}
.ddei_pv_line_point_combox_disabled .textinput[data-v-5b25a083] {
background-color: var(--panel-background);
height: 28px;
justify-content: center;
align-items: center;
}
.ddei_pv_line_point_combox .textinput[data-v-5b25a083] {
width: 100%;
padding-right: 5px;
border: 0.5px solid var(--panel-border);
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
padding-left: 5px;
height: 28px;
}
.ddei_pv_line_point_combox .textinput[data-v-5b25a083]:hover {
border: 1px solid var(--dot);
box-sizing: border-box;
}
.ddei_pv_line_point_combox .textinput .div_input[data-v-5b25a083] {
flex: 1 1 calc(100% - 10px);
width: calc(100% - 10px);
text-overflow: ellipsis;
overflow: hidden;
}
.ddei_pv_line_point_combox .textinput div[data-v-5b25a083] {
flex: 0 0 20px;
}
.icon[data-v-5b25a083] {
font-size: 16px;
}
.ddei-pv-line-type-combox[data-v-739c83c3] {
width: 24px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-pv-line-type-combox[data-v-739c83c3]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-pv-line-type-combox--disabled[data-v-739c83c3] {
pointer-events: none;
background-color: var(--panel-disabled);
color: var(--panel-title-disabled);
cursor: not-allowed;
}
.ddei-editor-quick-fat-item-box[data-v-781d8566] {
width: 24px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-editor-quick-fat-item-box[data-v-781d8566]:hover {
cursor: pointer;
background-color: var(--panel-hover);
}
.ddei-editor-quick-fat-item-box--selected[data-v-781d8566] {
background-color: var(--panel-selected);
}
.ddei-editor-quick-fat-item-box--disabled[data-v-781d8566] {
pointer-events: none;
color: var(--panel-title-selected);
cursor: not-allowed;
background-color: var(--panel-selected);
}
.ddei-editor-quick-fat-item-box .rotate-90[data-v-781d8566] {
transform: rotate(90deg);
}
.ddei-editor-quick-fat-item-box .ext-underline[data-v-781d8566] {
margin-top: 5.5px;
font-size: 16px;
}
.ddei-editor-quick-fat-item-box .magtop-1[data-v-781d8566] {
margin-top: -1px;
}
.ddei-editor-quick-fat-item-box .magtop-2[data-v-781d8566] {
margin-top: -2px;
}
.ddei-editor-quick-fat-item-box .magtop-3[data-v-781d8566] {
margin-top: -3px;
}
.ddei-editor-layout-standrad[data-v-43088579] {
width: 100%;
height: 100%;
display: flex;
flex-direction: column;
}
.ddei-editor-layout-standrad .top[data-v-43088579] {
border: 0.5px solid var(--border);
border-bottom: none;
}
.ddei-editor-layout-standrad .bottom[data-v-43088579] {
border: 0.5px solid var(--border);
border-top: none;
}
.ddei-editor-layout-standrad .body[data-v-43088579] {
display: flex;
overflow: hidden;
flex: 1 1 calc(100vh - 134px);
}
.ddei-editor-layout-standrad .body .left[data-v-43088579] {
flex: 0 1 292px;
border: 1px solid var(--border);
overflow: hidden;
}
.ddei-editor-layout-standrad .body .middle[data-v-43088579] {
flex: 1 1 auto;
display: flex;
flex-direction: column;
}
.ddei-editor-layout-standrad .body .right[data-v-43088579] {
flex: 0 1 292px;
border: 1px solid var(--border);
overflow: hidden;
}
.ddei-editor-layout-standrad > img {
-webkit-user-drag: none;
user-drag: none;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
.ddei-editor-layout-standrad > div {
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
.ddei-editor-layout-simple[data-v-4920d2e1] {
width: 100%;
height: 100vh;
display: flex;
flex-direction: column;
}
.ddei-editor-layout-simple .top[data-v-4920d2e1] {
flex: 0 1 auto;
}
.ddei-editor-layout-simple .middle[data-v-4920d2e1] {
flex: 1 1 auto;
display: flex;
}
.ddei-editor-layout-simple .bottom[data-v-4920d2e1] {
flex: 0 1 auto;
}
.ddei-editor-layout-simple .bottom[data-v-4920d2e1] > * {
height: 30px;
border-top: 0.5px solid var(--border);
}
.ddei-editor-layout-simple > img {
-webkit-user-drag: none;
user-drag: none;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
.ddei-editor-layout-simple > div {
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
.ddei-core-dialog-align[data-v-6574182d] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 180px;
position: absolute;
background-color: var(--panel-background);
height: 180px;
z-index: 999;
}
.ddei-core-dialog-align .content[data-v-6574182d] {
width: 100%;
max-height: 180px;
overflow-y: auto;
user-select: none;
}
.ddei-core-dialog-align .content .title[data-v-6574182d] {
color: var(--panel-title);
font-weight: bold;
flex: 0 0 30px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
font-size: 17px;
}
.ddei-core-dialog-align .content .group[data-v-6574182d] {
color: black;
flex: 1 1 40px;
width: 100%;
border-top: 1px solid var(--panel-border);
}
.ddei-core-dialog-align .content .group .title[data-v-6574182d] {
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;
}
.ddei-core-dialog-align .content .group .group_content[data-v-6574182d] {
width: 100%;
display: grid;
gap: 10px;
grid-template-columns: 1fr 1fr 1fr;
padding: 3px 0px;
}
.ddei-core-dialog-align .content .group .group_content .item[data-v-6574182d] {
outline: none;
width: 30px;
height: 25px;
margin: auto;
background: transparent;
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
cursor: pointer;
}
.ddei-core-dialog-align .content .group .group_content .itembox_disabled[data-v-6574182d] {
color: var(--panel-title-disabled);
text-decoration: line-through;
}
.ddei-core-dialog-align .content .group .group_content .itembox_disabled[data-v-6574182d]:hover {
cursor: not-allowed !important;
}
.ddei-core-dialog-align .content .group .group_content .item[data-v-6574182d]:hover {
background-color: var(--panel-hover);
}
.ddei-core-dialog-align .content .group .group_content .text[data-v-6574182d] {
flex: 1;
text-align: center;
white-space: nowrap;
width: 100%;
}
.ddei-core-dialog-align .content .group .group_content .icon[data-v-6574182d] {
font-size: 28px;
}
/**以下是设置缩放比例的弹出框 */
.ddei-core-dialog-changeratio[data-v-561a0908] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 180px;
position: absolute;
background-color: var(--panel-background);
z-index: 999;
}
.ddei-core-dialog-changeratio .content[data-v-561a0908] {
width: 180px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.ddei-core-dialog-changeratio .content .title[data-v-561a0908] {
color: var(--panel-title);
font-weight: bold;
flex: 0 0 30px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
font-size: 16px;
border-bottom: 1px solid var(--panel-border);
}
.ddei-core-dialog-changeratio .content .group[data-v-561a0908] {
color: var(--panel-title);
flex: 1 1 40px;
width: 100%;
}
.ddei-core-dialog-changeratio .content .group .group_content[data-v-561a0908] {
width: 100%;
display: flex;
flex-direction: column;
}
.ddei-core-dialog-changeratio .content .group .group_content .item[data-v-561a0908] {
flex: 0 0 30px;
padding: 0 10px;
display: flex;
justify-content: start;
align-items: center;
cursor: pointer;
}
.ddei-core-dialog-changeratio .content .group .group_content .item > input[data-v-561a0908] {
border: none;
outline: none;
background: var(--panel-background);
color: var(--panel-title);
}
.ddei-core-dialog-changeratio .content .group .group_content .item_selected[data-v-561a0908] {
font-weight: bold;
}
.ddei-core-dialog-changeratio .content .group .group_content .item[data-v-561a0908]:hover {
background-color: var(--panel-hover);
}
.ddei-core-dialog-choosecontrolgroup[data-v-d0e0cfd9] {
display: none;
overflow: hidden;
width: 420px;
position: absolute;
height: 400px;
z-index: 999;
}
.ddei-core-dialog-choosecontrolgroup .content[data-v-d0e0cfd9] {
width: 210px;
border: 1px solid var(--panel-border);
background-color: var(--panel-background);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
height: 400px;
overflow-y: auto;
overflow-x: hidden;
user-select: none;
}
.ddei-core-dialog-choosecontrolgroup .content .title[data-v-d0e0cfd9] {
color: var(--panel-title);
height: 36px;
width: 100%;
display: flex;
justify-content: start;
align-items: center;
font-size: 16px;
padding-left: 10px;
border-bottom: 1px solid var(--panel-border);
}
.ddei-core-dialog-choosecontrolgroup .content .group[data-v-d0e0cfd9] {
color: var(--panel-title);
flex: 1;
width: 100%;
display: flex;
flex-direction: column;
justify-content: start;
align-items: center;
}
.ddei-core-dialog-choosecontrolgroup .content .group .item[data-v-d0e0cfd9] {
flex: 0 0 36px;
width: 210px;
padding: 0 20px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-dialog-choosecontrolgroup .content .group .item .groupicon[data-v-d0e0cfd9] {
width: 34px;
font-size: 26px;
}
.ddei-core-dialog-choosecontrolgroup .content .group .item .groupname[data-v-d0e0cfd9] {
white-space: nowrap;
flex: 0 1 160px;
margin: 0 10px;
font-size: 16px;
}
.ddei-core-dialog-choosecontrolgroup .content .group .item .expand[data-v-d0e0cfd9] {
font-size: 22px;
}
.ddei-core-dialog-choosecontrolgroup .content .group .item[data-v-d0e0cfd9]:hover {
background-color: var(--panel-hover);
}
.ddei-core-dialog-choosecontrolgroup .subcontent[data-v-d0e0cfd9] {
display: none;
position: absolute;
width: 160px;
border: 1px solid var(--panel-border);
background-color: var(--panel-background);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
max-height: 400px;
overflow-y: auto;
overflow-x: hidden;
user-select: none;
}
.ddei-core-dialog-choosecontrolgroup .subcontent .title[data-v-d0e0cfd9] {
color: var(--panel-title);
height: 36px;
width: 100%;
display: flex;
justify-content: start;
align-items: center;
font-size: 16px;
padding-left: 10px;
}
.ddei-core-dialog-choosecontrolgroup .subcontent .group[data-v-d0e0cfd9] {
color: var(--panel-title);
flex: 1;
width: 100%;
display: flex;
flex-direction: column;
justify-content: start;
align-items: center;
}
.ddei-core-dialog-choosecontrolgroup .subcontent .group .item[data-v-d0e0cfd9] {
flex: 0 0 36px;
width: 160px;
padding: 0 10px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-dialog-choosecontrolgroup .subcontent .group .item > input[data-v-d0e0cfd9] {
flex: 0 0 20px;
width: 14px;
height: 14px;
}
.ddei-core-dialog-choosecontrolgroup .subcontent .group .item .groupname[data-v-d0e0cfd9] {
white-space: nowrap;
flex: 0 1 120px;
margin-left: 10px;
font-size: 16px;
}
.ddei-core-dialog-choosecontrolgroup .subcontent .group .item[data-v-d0e0cfd9]:hover {
background-color: var(--panel-hover);
}
/**以下为询问框的样式 */
.ddei-core-dialog-closefile[data-v-929ef917] {
width: 420px;
height: 165px;
background: var(--panel-background);
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 12px;
display: none;
position: absolute;
overflow: hidden;
z-index: 999;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.ddei-core-dialog-closefile .content[data-v-929ef917] {
width: 420px;
height: 165px;
display: flex;
flex-direction: column;
padding: 0 24px;
}
.ddei-core-dialog-closefile .content .header[data-v-929ef917] {
flex: 0 0 55px;
display: flex;
align-items: center;
font-size: 18px;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-dialog-closefile .content .header > span[data-v-929ef917] {
margin: 0 2px;
}
.ddei-core-dialog-closefile .content .header .close[data-v-929ef917] {
font-size: 22px;
}
.ddei-core-dialog-closefile .content .header .warn[data-v-929ef917] {
font-size: 20px !important;
color: #F05B13;
}
.ddei-core-dialog-closefile .content .msg[data-v-929ef917] {
flex: 0 0 55px;
display: flex;
justify-content: center;
align-items: center;
font-size: 16px;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-dialog-closefile .content .tail[data-v-929ef917] {
flex: 0 0 55px;
display: flex;
align-items: center;
text-align: center;
justify-content: end;
}
.ddei-core-dialog-closefile .content .button[data-v-929ef917] {
flex: 0 0 70px;
height: 32px;
background: var(--panel-header);
border: 1px solid var(--panel-border);
border-radius: 6px;
font-size: 16px;
font-weight: 400;
color: var(--panel-title);
margin-left: 13px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-dialog-closefile .content .button[data-v-929ef917]:hover {
color: white;
background: var(--dot);
cursor: pointer;
}
.ddei-core-dialog-closefile .content .button-main[data-v-929ef917] {
color: white;
background: var(--dot);
}
/**以下为询问框的样式 */
.ddei-core-dialog-collfile[data-v-068f2102] {
width: 420px;
height: 165px;
background: var(--panel-background);
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 12px;
display: none;
position: absolute;
overflow: hidden;
z-index: 999;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.ddei-core-dialog-collfile .content[data-v-068f2102] {
width: 420px;
height: 165px;
display: flex;
flex-direction: column;
padding: 0 24px;
}
.ddei-core-dialog-collfile .content .header[data-v-068f2102] {
flex: 0 0 55px;
display: flex;
align-items: center;
font-size: 18px;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-dialog-collfile .content .header > span[data-v-068f2102] {
margin: 0 2px;
}
.ddei-core-dialog-collfile .content .header .close[data-v-068f2102] {
font-size: 22px;
}
.ddei-core-dialog-collfile .content .header .warn[data-v-068f2102] {
font-size: 20px !important;
}
.ddei-core-dialog-collfile .content .msg[data-v-068f2102] {
flex: 0 0 55px;
display: flex;
justify-content: center;
align-items: center;
font-size: 16px;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-dialog-collfile .content .tail[data-v-068f2102] {
flex: 0 0 55px;
display: flex;
align-items: center;
text-align: center;
justify-content: end;
}
.ddei-core-dialog-collfile .content .button[data-v-068f2102] {
flex: 0 0 70px;
height: 32px;
white-space: nowrap;
background: var(--panel-header);
border: 1px solid var(--panel-border);
border-radius: 6px;
font-size: 16px;
font-weight: 400;
color: var(--panel-title);
margin-left: 13px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-dialog-collfile .content .button[data-v-068f2102]:hover {
color: white;
background: var(--dot);
cursor: pointer;
}
.ddei-core-dialog-collfile .content .button-main[data-v-068f2102] {
color: white;
background: var(--dot);
}
/**以下是选择颜色的弹出框 */
.ddei-core-dialog-linepointtype[data-v-ec516138] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 240px;
position: absolute;
background-color: var(--panel-background);
height: 250px;
z-index: 999;
user-select: none;
}
.ddei-core-dialog-linepointtype .content[data-v-ec516138] {
width: 100%;
max-height: 250px;
overflow-y: auto;
}
.ddei-core-dialog-linepointtype .content .group[data-v-ec516138] {
color: var(--panel-title);
width: 100%;
}
.ddei-core-dialog-linepointtype .content .group .title[data-v-ec516138] {
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;
}
.ddei-core-dialog-linepointtype .content .group .group_content[data-v-ec516138] {
width: 100%;
padding: 0px 15px;
display: grid;
gap: 5px;
grid-template-columns: 1fr 1fr;
}
.ddei-core-dialog-linepointtype .content .group .item[data-v-ec516138] {
height: 30px;
background: transparent;
display: flex;
justify-content: center;
align-items: center;
cursor: pointer;
border: 0.5px solid var(--panel-border);
}
.ddei-core-dialog-linepointtype .content .group .item .div_input[data-v-ec516138] {
width: calc(100% - 10px);
height: 3px;
}
.ddei-core-dialog-linepointtype .content .group .item[data-v-ec516138]:hover {
outline: 1px solid var(--dot);
}
.ddei-core-dialog-linepointtype .content .group .item-selected[data-v-ec516138] {
outline: 1px solid var(--dot);
}
.ddei-core-dialog-linepointtype .tail[data-v-ec516138] {
margin-top: 5px;
flex: 0 0 55px;
display: flex;
align-items: center;
text-align: center;
padding: 0 15px;
justify-content: end;
}
.ddei-core-dialog-linepointtype .button[data-v-ec516138] {
flex: 0 0 70px;
height: 32px;
background: var(--panel-header);
border: 1px solid var(--panel-border);
border-radius: 6px;
font-size: 16px;
font-weight: 400;
color: var(--panel-title);
margin-left: 13px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-dialog-linepointtype .button[data-v-ec516138]:hover {
color: white;
background: var(--dot);
cursor: pointer;
}
.ddei-core-dialog-linepointtype .button-main[data-v-ec516138] {
color: white;
background: var(--dot);
}
.ddei-core-dialog-linetype[data-v-5fc9eaad] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 240px;
position: absolute;
background-color: var(--panel-background);
height: 90px;
z-index: 999;
}
.ddei-core-dialog-linetype .content[data-v-5fc9eaad] {
width: 100%;
max-height: 90px;
overflow-y: auto;
user-select: none;
}
.ddei-core-dialog-linetype .content .title[data-v-5fc9eaad] {
color: var(--panel-title);
font-weight: bold;
flex: 0 0 30px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
font-size: 17px;
}
.ddei-core-dialog-linetype .content .group[data-v-5fc9eaad] {
color: var(--panel-title);
flex: 1 1 40px;
width: 100%;
padding: 10px;
border-top: 1px solid var(--panel-border);
}
.ddei-core-dialog-linetype .content .group .group_content[data-v-5fc9eaad] {
width: 96%;
display: grid;
gap: 5px;
grid-template-columns: 1fr 1fr 1fr;
}
.ddei-core-dialog-linetype .content .group .group_content .item[data-v-5fc9eaad] {
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);
}
.ddei-core-dialog-linetype .content .group .group_content .selected[data-v-5fc9eaad] {
background-color: var(--panel-selected);
}
.ddei-core-dialog-linetype .content .group .group_content .item[data-v-5fc9eaad]:hover {
background-color: var(--panel-hover);
}
.ddei-core-dialog-linetype .content .group .group_content .icon[data-v-5fc9eaad] {
font-size: 28px;
}
/**以下是编辑图层的弹出框 */
.ddei-core-dialog-managerlayers[data-v-f8156347] {
width: 240px;
position: absolute;
background-color: var(--panel-background);
height: 320px;
z-index: 999;
display: none;
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
user-select: none;
}
.ddei-core-dialog-managerlayers .content[data-v-f8156347] {
width: 240px;
height: 320px;
display: flex;
flex-direction: column;
justify-content: center;
}
.ddei-core-dialog-managerlayers .content .title[data-v-f8156347] {
color: var(--panel-title);
font-weight: bold;
flex: 0 0 30px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
font-size: 16px;
border-bottom: 1px solid var(--panel-border);
}
.ddei-core-dialog-managerlayers .content .group[data-v-f8156347] {
color: var(--panel-title);
flex: 1 1 40px;
}
.ddei-core-dialog-managerlayers .content .group .group_content[data-v-f8156347] {
width: 100%;
height: 280px;
display: flex;
flex-direction: column;
overflow-y: auto;
}
.ddei-core-dialog-managerlayers .content .group .group_content .item[data-v-f8156347] {
width: 100%;
flex: 0 0 30px;
display: grid;
gap: 2px;
grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
padding: 3px 10px;
}
.ddei-core-dialog-managerlayers .content .group .group_content .item > span[data-v-f8156347] {
font-size: 14px;
font-weight: bold;
}
.ddei-core-dialog-managerlayers .content .group .group_content .item .icon[data-v-f8156347] {
font-size: 22px;
}
.ddei-core-dialog-managerlayers .content .group .group_content .item > input[data-v-f8156347] {
height: 16px;
margin-top: 4px;
}
.ddei-core-dialog-managerlayers .content .group .group_content .current[data-v-f8156347] {
background-color: var(--panel-header);
}
.ddei-core-dialog-managerlayers .content .group .group_content .item_selected[data-v-f8156347] {
font-weight: bold;
}
.ddei-core-dialog-managerlayers .content .group .group_content .item[data-v-f8156347]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-dialog-mergecompose[data-v-eb54102e] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 140px;
position: absolute;
background-color: var(--panel-background);
height: 110px;
z-index: 999;
}
.ddei-core-dialog-mergecompose .content[data-v-eb54102e] {
width: 100%;
max-height: 110px;
overflow-y: auto;
user-select: none;
}
.ddei-core-dialog-mergecompose .content .title[data-v-eb54102e] {
color: var(--panel-title);
font-weight: bold;
flex: 0 0 30px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
font-size: 17px;
border-bottom: 1px solid var(--panel-border);
}
.ddei-core-dialog-mergecompose .content .group[data-v-eb54102e] {
color: var(--panel-title);
flex: 1 1 40px;
width: 100%;
}
.ddei-core-dialog-mergecompose .content .group .group_content[data-v-eb54102e] {
width: 100%;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.ddei-core-dialog-mergecompose .content .group .group_content .item[data-v-eb54102e] {
outline: none;
font-size: 16px;
background: transparent;
border-radius: 4px;
width: 100%;
flex: 0 0 36px;
display: flex;
justify-content: start;
align-items: center;
padding: 0px 10px;
cursor: pointer;
}
.ddei-core-dialog-mergecompose .content .group .group_content .item_disabled[data-v-eb54102e] {
outline: none;
font-size: 16px;
background: transparent;
border-radius: 4px;
width: 100%;
flex: 0 0 36px;
display: flex;
justify-content: start;
align-items: center;
padding: 0px 10px;
color: var(--panel-title-disabled);
text-decoration: line-through;
}
.ddei-core-dialog-mergecompose .content .group .group_content .item_disabled[data-v-eb54102e]:hover {
cursor: not-allowed !important;
}
.ddei-core-dialog-mergecompose .content .group .group_content .item[data-v-eb54102e]:hover {
background-color: var(--panel-hover);
}
.ddei-core-dialog-mergecompose .content .group .group_content .text[data-v-eb54102e] {
flex: 1;
text-align: left;
padding-left: 15px;
white-space: nowrap;
width: 100%;
}
.ddei-core-dialog-mergecompose .content .group .group_content .icon[data-v-eb54102e] {
font-size: 22px;
}
.ddei-core-dialog-changeposition[data-v-70a473a4] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 140px;
position: absolute;
background-color: var(--panel-background);
height: 180px;
z-index: 999;
}
.ddei-core-dialog-changeposition .content[data-v-70a473a4] {
width: 100%;
max-height: 180px;
overflow-y: auto;
user-select: none;
}
.ddei-core-dialog-changeposition .content .title[data-v-70a473a4] {
color: var(--panel-title);
font-weight: bold;
flex: 0 0 30px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
font-size: 17px;
border-bottom: 1px solid var(--panel-border);
}
.ddei-core-dialog-changeposition .content .group[data-v-70a473a4] {
color: var(--panel-title);
flex: 1 1 40px;
width: 100%;
}
.ddei-core-dialog-changeposition .content .group .group_content[data-v-70a473a4] {
width: 100%;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.ddei-core-dialog-changeposition .content .group .group_content .item[data-v-70a473a4] {
outline: none;
font-size: 16px;
margin: auto;
background: transparent;
border-radius: 4px;
width: 100%;
flex: 0 0 36px;
display: flex;
justify-content: start;
align-items: center;
padding: 0px 10px;
cursor: pointer;
}
.ddei-core-dialog-changeposition .content .group .group_content .item_disabled[data-v-70a473a4] {
color: var(--panel-title-disabled);
text-decoration: line-through;
}
.ddei-core-dialog-changeposition .content .group .group_content .item_disabled[data-v-70a473a4]:hover {
cursor: not-allowed !important;
}
.ddei-core-dialog-changeposition .content .group .group_content .item[data-v-70a473a4]:hover {
background-color: var(--panel-hover);
}
.ddei-core-dialog-changeposition .content .group .group_content .text[data-v-70a473a4] {
flex: 1;
text-align: center;
white-space: nowrap;
width: 100%;
}
.ddei-core-dialog-changeposition .content .group .group_content .icon[data-v-70a473a4] {
font-size: 22px;
}
/**以下为询问框的样式 */
.ddei-core-dialog-publishfile[data-v-251feafa] {
width: 420px;
height: 165px;
background: var(--panel-background);
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 12px;
display: none;
position: absolute;
overflow: hidden;
z-index: 999;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.ddei-core-dialog-publishfile .content[data-v-251feafa] {
width: 420px;
height: 165px;
display: flex;
flex-direction: column;
padding: 0 24px;
}
.ddei-core-dialog-publishfile .content .header[data-v-251feafa] {
flex: 0 0 55px;
display: flex;
align-items: center;
font-size: 18px;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-dialog-publishfile .content .header > span[data-v-251feafa] {
margin: 0 2px;
}
.ddei-core-dialog-publishfile .content .header .close[data-v-251feafa] {
font-size: 22px;
}
.ddei-core-dialog-publishfile .content .header .warn[data-v-251feafa] {
font-size: 20px !important;
}
.ddei-core-dialog-publishfile .content .msg[data-v-251feafa] {
flex: 0 0 55px;
display: flex;
justify-content: center;
align-items: center;
font-size: 16px;
font-weight: 400;
color: var(--panel-title);
}
.ddei-core-dialog-publishfile .content .tail[data-v-251feafa] {
flex: 0 0 55px;
display: flex;
align-items: center;
text-align: center;
justify-content: end;
}
.ddei-core-dialog-publishfile .content .button[data-v-251feafa] {
flex: 0 0 70px;
height: 32px;
background: var(--panel-header);
border: 1px solid var(--panel-border);
border-radius: 6px;
font-size: 16px;
font-weight: 400;
color: var(--panel-title);
margin-left: 13px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-dialog-publishfile .content .button[data-v-251feafa]:hover {
color: white;
background: var(--dot);
cursor: pointer;
}
.ddei-core-dialog-publishfile .content .button-main[data-v-251feafa] {
color: white;
background: var(--dot);
}
.ddei-core-dialog-qcview[data-v-6bab58c9] {
width: 80px;
position: absolute;
background-color: var(--panel-background);
left: 0px;
display: none;
bottom: 16px;
height: 48px;
}
.ddei-core-dialog-qcview .icon[data-v-6bab58c9] {
font-size: 18px;
width: 18px;
height: 18px;
}
.ddei-core-dialog-qcview .items .item[data-v-6bab58c9] {
height: 24px;
width: 80px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-dialog-qcview .items .item > div[data-v-6bab58c9] {
color: var(--panel-title);
font-size: 13px;
flex: 1;
}
.ddei-core-dialog-qcview .items .item[data-v-6bab58c9]:hover {
background: var(--panel-hover);
cursor: pointer;
}
.ddei-core-dialog-setstyle[data-v-a2a1cbf5] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 440px;
position: absolute;
background-color: var(--panel-background);
height: 230px;
z-index: 999;
}
.ddei-core-dialog-setstyle .content[data-v-a2a1cbf5] {
width: 100%;
max-height: 230px;
overflow-y: auto;
user-select: none;
}
.ddei-core-dialog-setstyle .content .title[data-v-a2a1cbf5] {
color: var(--panel-title);
font-weight: bold;
flex: 0 0 30px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
font-size: 17px;
}
.ddei-core-dialog-setstyle .content .group[data-v-a2a1cbf5] {
color: var(--panel-title);
flex: 1 1 40px;
width: 100%;
padding: 10px;
border-top: 1px solid var(--panel-border);
}
.ddei-core-dialog-setstyle .content .group .group_content[data-v-a2a1cbf5] {
width: 95%;
display: grid;
gap: 5px;
grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
}
.ddei-core-dialog-setstyle .content .group .group_content .item[data-v-a2a1cbf5] {
outline: none;
width: 80px;
height: 40px;
margin: auto;
background: transparent;
display: flex;
justify-content: center;
align-items: center;
cursor: pointer;
border: 1px solid var(--panel-border);
}
.ddei-core-dialog-setstyle .content .group .group_content .item[data-v-a2a1cbf5]:hover {
filter: brightness(150%);
}
.ddei-core-dialog-setstyle .content .group .group_content .text[data-v-a2a1cbf5] {
flex: 1;
text-align: center;
white-space: nowrap;
width: 100%;
}
.ddei-core-dialog-setstyle .content .group .group_content .icon[data-v-a2a1cbf5] {
font-size: 28px;
}
.ddei-core-dialog-changerotate[data-v-2fcc5441] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 180px;
position: absolute;
background-color: var(--panel-background);
height: 150px;
z-index: 999;
}
.ddei-core-dialog-changerotate .content[data-v-2fcc5441] {
width: 100%;
max-height: 150px;
overflow-y: auto;
user-select: none;
}
.ddei-core-dialog-changerotate .content .title[data-v-2fcc5441] {
color: var(--panel-title);
font-weight: bold;
flex: 0 0 30px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
font-size: 17px;
}
.ddei-core-dialog-changerotate .content .group[data-v-2fcc5441] {
color: var(--panel-title);
flex: 1 1 40px;
width: 100%;
border-top: 1px solid var(--panel-border);
}
.ddei-core-dialog-changerotate .content .group .title[data-v-2fcc5441] {
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;
}
.ddei-core-dialog-changerotate .content .group .group_content[data-v-2fcc5441] {
width: 100%;
display: grid;
gap: 10px;
grid-template-columns: 1fr 1fr 1fr;
padding: 3px 0px;
}
.ddei-core-dialog-changerotate .content .group .group_content .item[data-v-2fcc5441] {
outline: none;
width: 30px;
height: 25px;
margin: auto;
background: transparent;
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
cursor: pointer;
}
.ddei-core-dialog-changerotate .content .group .group_content .item_disabled[data-v-2fcc5441] {
color: var(--panel-title-disabled);
outline: none;
width: 30px;
height: 25px;
margin: auto;
background: transparent;
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
cursor: pointer;
text-decoration: line-through;
}
.ddei-core-dialog-changerotate .content .group .group_content .item_disabled .icon[data-v-2fcc5441] {
color: var(--panel-title-disabled);
}
.ddei-core-dialog-changerotate .content .group .group_content .item_disabled[data-v-2fcc5441]:hover {
cursor: not-allowed !important;
}
.ddei-core-dialog-changerotate .content .group .group_content .item[data-v-2fcc5441]:hover {
background-color: var(--panel-hover);
}
.ddei-core-dialog-changerotate .content .group .group_content .text[data-v-2fcc5441] {
flex: 1;
text-align: center;
white-space: nowrap;
width: 100%;
}
.ddei-core-dialog-changerotate .content .group .group_content .icon[data-v-2fcc5441] {
font-size: 28px;
}
/**以下是选择颜色的弹出框 */
.ddei-core-dialog-selectborderdash[data-v-143dc703] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 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;
}
.ddei-core-dialog-selectborderdash .content[data-v-143dc703] {
width: 100%;
max-height: 250px;
overflow-y: auto;
}
.ddei-core-dialog-selectborderdash .content .group[data-v-143dc703] {
color: var(--panel-title);
width: 100%;
}
.ddei-core-dialog-selectborderdash .content .group .title[data-v-143dc703] {
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;
box-sizing: border-box;
}
.ddei-core-dialog-selectborderdash .content .group .group_content[data-v-143dc703] {
width: 100%;
padding: 0px 15px;
display: grid;
gap: 5px;
grid-template-columns: 1fr 1fr;
box-sizing: border-box;
}
.ddei-core-dialog-selectborderdash .content .group .item[data-v-143dc703] {
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);
}
.ddei-core-dialog-selectborderdash .content .group .item .div_input[data-v-143dc703] {
width: calc(100% - 10px);
height: 3px;
}
.ddei-core-dialog-selectborderdash .content .group .item .div_input[data-v-143dc703] > * {
stroke: var(--panel-title);
fill: var(--panel-background);
}
.ddei-core-dialog-selectborderdash .content .group .item[data-v-143dc703]:hover {
outline: 1px solid var(--dot);
}
.ddei-core-dialog-selectborderdash .content .group .item-selected[data-v-143dc703] {
outline: 1px solid var(--dot);
}
.ddei-core-dialog-selectborderdash .tail[data-v-143dc703] {
margin-top: 5px;
flex: 0 0 55px;
display: flex;
align-items: center;
text-align: center;
padding: 0 15px;
justify-content: end;
}
.ddei-core-dialog-selectborderdash .button[data-v-143dc703] {
flex: 0 0 70px;
height: 32px;
white-space: nowrap;
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;
}
.ddei-core-dialog-selectborderdash .button[data-v-143dc703]:hover {
color: white;
background: var(--dot);
cursor: pointer;
}
.ddei-core-dialog-selectborderdash .button-main[data-v-143dc703] {
color: white;
border: 1px solid var(--panel-background);
background: var(--dot);
}
/**以下是选择颜色的弹出框 */
.ddei-core-dialog-selectboderweight[data-v-b939438e] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 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;
}
.ddei-core-dialog-selectboderweight .content[data-v-b939438e] {
width: 100%;
max-height: 250px;
overflow-y: auto;
}
.ddei-core-dialog-selectboderweight .content .group[data-v-b939438e] {
color: var(--panel-title);
width: 100%;
}
.ddei-core-dialog-selectboderweight .content .group .title[data-v-b939438e] {
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;
}
.ddei-core-dialog-selectboderweight .content .group .group_content[data-v-b939438e] {
width: 100%;
padding: 0px 15px;
display: grid;
gap: 5px;
grid-template-columns: 1fr 1fr;
}
.ddei-core-dialog-selectboderweight .content .group .item[data-v-b939438e] {
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-border);
}
.ddei-core-dialog-selectboderweight .content .group .item .div_input[data-v-b939438e] {
width: calc(100% - 10px);
height: 100%;
}
.ddei-core-dialog-selectboderweight .content .group .item .div_input[data-v-b939438e] > * {
stroke: var(--panel-title);
fill: var(--panel-background);
}
.ddei-core-dialog-selectboderweight .content .group .item[data-v-b939438e]:hover {
outline: 1px solid var(--dot);
}
.ddei-core-dialog-selectboderweight .content .group .item-selected[data-v-b939438e] {
outline: 1px solid var(--dot);
}
.ddei-core-dialog-selectboderweight .tail[data-v-b939438e] {
margin-top: 5px;
flex: 0 0 55px;
display: flex;
align-items: center;
text-align: center;
padding: 0 15px;
justify-content: end;
}
.ddei-core-dialog-selectboderweight .button[data-v-b939438e] {
flex: 0 0 70px;
height: 32px;
white-space: nowrap;
background: #FFFFFF;
border: 1px solid var(--panel-border);
border-radius: 6px;
font-size: 16px;
font-family: "Microsoft YaHei";
font-weight: 400;
color: #040404;
margin-left: 13px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-core-dialog-selectboderweight .button[data-v-b939438e]:hover {
color: white;
background: #176EFF;
cursor: pointer;
}
.ddei-core-dialog-selectboderweight .button-main[data-v-b939438e] {
color: white;
background: #176EFF;
}
/**以下是选择颜色的弹出框 */
.ddei-core-dialog-selectcolor[data-v-cd291105] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 290px;
position: absolute;
background-color: var(--panel-background);
height: 380px;
z-index: 999;
user-select: none;
}
.ddei-core-dialog-selectcolor .content[data-v-cd291105] {
width: 100%;
max-height: 380px;
overflow-y: auto;
}
.ddei-core-dialog-selectcolor .content .group[data-v-cd291105] {
color: var(--panel-title);
width: 100%;
}
.ddei-core-dialog-selectcolor .content .group .title[data-v-cd291105] {
color: var(--panel-title);
flex: 0 0 30px;
width: 100%;
box-sizing: border-box;
display: flex;
justify-content: start;
align-items: center;
padding-left: 10px;
font-size: 15px;
border: none;
margin-top: 5px;
margin-bottom: 5px;
}
.ddei-core-dialog-selectcolor .content .group .color1[data-v-cd291105] {
display: grid;
gap: 1px;
grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
}
.ddei-core-dialog-selectcolor .content .group .color2[data-v-cd291105] {
display: grid;
grid-template-rows: 20px 20px 20px 20px 20px 20px 20px;
gap: 1px;
grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
margin: 10px 0px;
}
.ddei-core-dialog-selectcolor .content .group .color3[data-v-cd291105] {
display: flex;
justify-content: start;
align-items: center;
margin-top: -5px;
margin-left: 10px;
}
.ddei-core-dialog-selectcolor .content .group .color3 > input[data-v-cd291105] {
width: 80px;
height: 24px;
background: var(--panel-background);
border: 1px solid var(--panel-title);
color: var(--panel-title);
}
.ddei-core-dialog-selectcolor .content .group .color3 .colorinput[data-v-cd291105] {
outline: none;
border: none;
width: 60px;
height: 34px;
margin-right: 5px;
background: none;
}
.ddei-core-dialog-selectcolor .content .group .group_content[data-v-cd291105] {
width: 100%;
padding: 0px 15px;
box-sizing: border-box;
}
.ddei-core-dialog-selectcolor .content .group .item[data-v-cd291105] {
width: 25px;
height: 20px;
margin: 0px 2px;
margin: auto;
background: transparent;
display: flex;
justify-content: center;
align-items: center;
cursor: pointer;
border: 0.5px solid var(--panel-title);
}
.ddei-core-dialog-selectcolor .content .group .item[data-v-cd291105]:hover {
outline: 1px solid var(--panel-hover);
}
.ddei-core-dialog-selectcolor .content .group .item-selected[data-v-cd291105] {
outline: 1px solid var(--panel-selected);
}
.ddei-core-dialog-selectcolor .tail[data-v-cd291105] {
margin-top: 5px;
flex: 0 0 55px;
display: flex;
align-items: center;
text-align: center;
padding: 0 15px;
justify-content: end;
}
.ddei-core-dialog-selectcolor .button[data-v-cd291105] {
flex: 0 0 70px;
white-space: nowrap;
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;
}
.ddei-core-dialog-selectcolor .button[data-v-cd291105]:hover {
color: white;
background: var(--dot);
cursor: pointer;
}
.ddei-core-dialog-selectcolor .button-main[data-v-cd291105] {
color: white;
border: 1px solid var(--panel-background);
background: var(--dot);
}
.ddei-core-dialog-selectcolor .button-small[data-v-cd291105] {
height: 26px;
flex: 0 0 55px;
font-size: 15px;
border: 1px solid var(--panel-title);
color: var(--panel-title);
}
.ddei-core-dialog-selectcolor .button-small[data-v-cd291105]:hover {
color: var(--panel-title);
font-weight: bold;
background: var(--panel-background);
cursor: pointer;
}
/**以下是选择字体的弹出框 */
.ddei-core-dialog-selectfont[data-v-64fcb708] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 170px;
position: absolute;
background-color: var(--panel-background);
height: 310px;
z-index: 999;
user-select: none;
}
.ddei-core-dialog-selectfont .content[data-v-64fcb708] {
width: 100%;
max-height: 310px;
overflow-y: auto;
}
.ddei-core-dialog-selectfont .content .group[data-v-64fcb708] {
color: var(--panel-title);
flex: 1 1 40px;
width: 100%;
}
.ddei-core-dialog-selectfont .content .group .group_content[data-v-64fcb708] {
font-size: 14px;
width: 100%;
grid-template-columns: 1fr 1fr;
grid-template-rows: 30px 30px 30px 30px 30px;
display: grid;
}
.ddei-core-dialog-selectfont .content .group .group_content .item[data-v-64fcb708] {
outline: none;
font-size: 15px;
margin: auto;
background: transparent;
border-radius: 4px;
width: 80px;
height: 30px;
display: flex;
justify-content: start;
align-items: center;
cursor: pointer;
}
.ddei-core-dialog-selectfont .content .group .group_content .item .text[data-v-64fcb708] {
text-align: center;
white-space: nowrap;
display: table-cell;
width: 100%;
vertical-align: middle;
}
.ddei-core-dialog-selectfont .content .group .group_content .itembox_deleted[data-v-64fcb708] {
text-decoration: line-through;
}
.ddei-core-dialog-selectfont .content .group .group_content .itembox_disabled[data-v-64fcb708] {
color: var(--panel-title-disabled);
text-decoration: line-through;
}
.ddei-core-dialog-selectfont .content .group .group_content .itembox_disabled[data-v-64fcb708]:hover {
cursor: not-allowed !important;
}
.ddei-core-dialog-selectfont .content .group .group_content .itembox_underline[data-v-64fcb708] {
text-decoration: underline;
}
.ddei-core-dialog-selectfont .content .group .group_content .item_selected[data-v-64fcb708] {
font-weight: bold;
background-color: var(--panel-selected);
}
.ddei-core-dialog-selectfont .content .group .group_content .item[data-v-64fcb708]:hover {
background-color: var(--panel-hover);
}
/**以下是选择字号的弹出框 */
.ddei-core-dialog-selectfontsize[data-v-9fc02a16] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
width: 170px;
position: absolute;
background-color: var(--panel-background);
height: 310px;
z-index: 999;
user-select: none;
}
.ddei-core-dialog-selectfontsize .content[data-v-9fc02a16] {
width: 100%;
max-height: 310px;
overflow-y: auto;
}
.ddei-core-dialog-selectfontsize .content .group[data-v-9fc02a16] {
color: var(--panel-title);
flex: 1 1 40px;
width: 100%;
}
.ddei-core-dialog-selectfontsize .content .group .group_content[data-v-9fc02a16] {
font-size: 14px;
width: 100%;
grid-template-columns: 1fr 1fr;
grid-template-rows: 30px 30px 30px 30px 30px;
display: grid;
}
.ddei-core-dialog-selectfontsize .content .group .group_content .itembox[data-v-9fc02a16] {
outline: none;
font-size: 15px;
margin: auto;
background: transparent;
border-radius: 4px;
width: 80px;
height: 30px;
display: flex;
justify-content: start;
align-items: center;
cursor: pointer;
}
.ddei-core-dialog-selectfontsize .content .group .group_content .itembox .itembox_text[data-v-9fc02a16] {
text-align: center;
white-space: nowrap;
display: table-cell;
width: 100%;
vertical-align: middle;
}
.ddei-core-dialog-selectfontsize .content .group .group_content .itembox_deleted[data-v-9fc02a16] {
text-decoration: line-through;
}
.ddei-core-dialog-selectfontsize .content .group .group_content .itembox_disabled[data-v-9fc02a16] {
color: var(--panel-title-disabled);
text-decoration: line-through;
}
.ddei-core-dialog-selectfontsize .content .group .group_content .itembox_disabled[data-v-9fc02a16]:hover {
cursor: not-allowed !important;
}
.ddei-core-dialog-selectfontsize .content .group .group_content .itembox_underline[data-v-9fc02a16] {
text-decoration: underline;
}
.ddei-core-dialog-selectfontsize .content .group .group_content .itembox_selected[data-v-9fc02a16] {
font-weight: bold;
background-color: var(--panel-selected);
}
.ddei-core-dialog-selectfontsize .content .group .group_content .itembox[data-v-9fc02a16]:hover {
background-color: var(--panel-hover);
}
.ddei-core-dialog-textalign[data-v-fe33bdea] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 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;
}
.ddei-core-dialog-textalign .content[data-v-fe33bdea] {
width: 100%;
max-height: 240px;
overflow-y: auto;
user-select: none;
}
.ddei-core-dialog-textalign .content .title[data-v-fe33bdea] {
color: var(--panel-title);
font-weight: bold;
flex: 0 0 30px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
font-size: 17px;
}
.ddei-core-dialog-textalign .content .group[data-v-fe33bdea] {
color: var(--panel-title);
flex: 1 1 40px;
width: 100%;
padding: 10px;
border-top: 1px solid var(--panel-border);
}
.ddei-core-dialog-textalign .content .group .group_content[data-v-fe33bdea] {
width: 96%;
display: grid;
gap: 5px;
grid-template-columns: 1fr 1fr 1fr;
}
.ddei-core-dialog-textalign .content .group .group_content .item[data-v-fe33bdea] {
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);
}
.ddei-core-dialog-textalign .content .group .group_content .selected[data-v-fe33bdea] {
background-color: var(--panel-selected);
}
.ddei-core-dialog-textalign .content .group .group_content .item[data-v-fe33bdea]:hover {
background-color: var(--panel-hover);
}
.ddei-core-dialog-textalign .content .group .group_content .icon[data-v-fe33bdea] {
font-size: 28px;
}
.ddei-core-dialog-choosecontrol[data-v-5962d4b2] {
display: none;
overflow: hidden;
max-width: 220px;
position: absolute;
max-height: 220px;
z-index: 999999;
}
.ddei-core-dialog-choosecontrol-content[data-v-5962d4b2] {
max-width: 220px;
border: 1px solid var(--panel-border);
background-color: var(--panel-background);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
max-height: 220px;
overflow-y: auto;
overflow-x: hidden;
user-select: none;
}
.ddei-core-dialog-choosecontrol-content-itempanel[data-v-5962d4b2] {
display: flex;
flex-flow: row wrap;
background: var(--toolbox-background);
padding: 5px 5px 5px 5px;
}
.ddei-core-dialog-choosecontrol-content-itempanel-item[data-v-5962d4b2] {
flex: 0 0 50px !important;
height: 45px;
margin: 5px 0px;
display: flex;
overflow: hidden;
justify-content: center;
align-items: center;
flex-flow: column;
}
.ddei-core-dialog-choosecontrol-content-itempanel-item[data-v-5962d4b2]:hover {
background: var(--toolbox-control-hover);
outline: var(--toolbox-control-hover-outline);
cursor: all-scroll;
}
.ddei-core-dialog-choosecontrol-content-itempanel-item .text[data-v-5962d4b2] {
white-space: nowrap;
text-align: center;
font-size: 0.7vw;
font-weight: 400;
color: var(--toolbox-control-title);
}
.ddei-core-dialog-choosecontrol-content-itempanel-item .icon[data-v-5962d4b2] {
width: 90%;
height: 90%;
object-fit: contain;
}
.ddei-core-dialog-choosecontrol-content-itempanel-item .icon-html[data-v-5962d4b2] {
width: 50px;
height: 45px;
object-fit: contain;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-core-dialog-choosecontrol-content-itempanel-item .icon-html[data-v-5962d4b2] > * {
width: 28px !important;
height: 28px !important;
object-fit: contain;
}
/**以下为text属性编辑器 */
.ddei-pv-editor-text[data-v-48447048] {
border-radius: 4px;
border: 0.5px solid var(--panel-title);
height: 28px;
margin-right: 10px;
padding: 0 5px;
box-sizing: border-box;
}
.ddei-pv-editor-text--disabled[data-v-48447048] {
background-color: var(--panel-disabled) !important;
}
.ddei-pv-editor-text--disabled[data-v-48447048]:hover {
border: 1px solid var(--panel-disabled) !important;
}
.ddei-pv-editor-text[data-v-48447048]:hover {
border: 1px solid var(--dot);
box-sizing: border-box;
}
.ddei-pv-editor-text input[data-v-48447048] {
height: 24px;
width: 100%;
border: transparent;
outline: none;
color:var(--panel-title);
font-size: 15px;
background: transparent;
}
.ddei-pv-base-combox[data-v-b36dc5e7] {
height: 28px;
padding-right: 10px;
}
.ddei-pv-base-combox--disabled .textinput[data-v-b36dc5e7] {
background-color: var(--panel-disabled);
height: 28px;
}
.ddei-pv-base-combox .textinput[data-v-b36dc5e7] {
width: 100%;
padding-right: 5px;
box-sizing: border-box;
border: 0.5px solid var(--panel-title);
border-radius: 4px;
display: flex;
padding-left: 5px;
height: 28px;
}
.ddei-pv-base-combox .textinput[data-v-b36dc5e7]:hover {
border: 1px solid var(--dot);
box-sizing: border-box;
}
.ddei-pv-base-combox .textinput input[data-v-b36dc5e7] {
flex: 1 1 calc(100% - 10px);
width: calc(100% - 10px);
border: transparent;
outline: none;
font-size: 15px;
background: transparent;
margin-top: 1px;
}
.ddei-pv-base-combox .textinput div[data-v-b36dc5e7] {
flex: 0 0 20px;
}
.ddei-pv-base-combox .display_img input[data-v-b36dc5e7] {
display: none;
}
.ddei-pv-base-combox .display_img img[data-v-b36dc5e7] {
width: 20px;
height: 20px;
}
.ddei-pv-base-combox .display_img_text input[data-v-b36dc5e7] {
width: calc(100% - 30px);
}
.ddei-pv-base-combox .display_img_text img[data-v-b36dc5e7] {
float: left;
width: 20px;
height: 20px;
}
.ddei-combox-show-dialog[data-v-b36dc5e7] {
font-size: 13px;
background: var(--panel-background);
display: none;
position: absolute;
z-index: 999;
border-radius: 4px;
}
.ddei-combox-show-dialog-content[data-v-b36dc5e7] {
width: 100%;
height: 100%;
background: var(--panel-background);
padding: 10px;
box-shadow: 4px 4px 4px hsl(0deg 0% 0% /0.25);
display:flex;
justify-content: center;
align-items: center;
}
.icon[data-v-b36dc5e7] {
font-size: 16px
}
/**以下为aligntype属性编辑器 */
.ddei-pv-editor-aligntype-items[data-v-135fda87] {
width: 200px;
height: 150px;
display: grid;
padding: 2%;
grid-template-rows: 30% 30% 30%;
grid-template-columns: 1fr 1fr 1fr;
gap: 4px;
}
.ddei-pv-editor-aligntype-item[data-v-135fda87] {
text-align: center;
font-size: 16px;
display: table;
color: var(--panel-title);
border: 0.5px solid var(--panel-title);
background-color: var(--panel-background);
padding: 5px;
}
.ddei-pv-editor-aligntype-item div[data-v-135fda87] {
display: table-cell;
}
.ddei-pv-editor-aligntype-item[data-v-135fda87]:hover {
border: 1px solid var(--dot);
background: var(--panel-hover);
cursor: pointer;
}
.ddei-pv-editor-aligntype-item--selected[data-v-135fda87] {
border: 1px solid var(--dot);
}
.ddei-pv-border-dash-combox[data-v-2e01e102] {
height: 28px;
padding-right: 10px;
}
.ddei-pv-border-dash-combox .textinput[data-v-2e01e102] {
width: 100%;
padding-right: 5px;
border: 0.5px solid var(--panel-title);
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
padding-left: 5px;
height: 28px;
box-sizing: border-box;
}
.ddei-pv-border-dash-combox .textinput[data-v-2e01e102]:hover {
border: 1px solid var(--dot);
box-sizing: border-box;
}
.ddei-pv-border-dash-combox .textinput .div_input[data-v-2e01e102] {
flex: 1 1 calc(100% - 10px);
width: calc(100% - 10px);
height: 3px;
}
.ddei-pv-border-dash-combox .textinput .div_input div[data-v-2e01e102] {
flex: 0 0 20px;
}
.ddei-pv-border-dash-combox .textinput .div_input[data-v-2e01e102] > * {
stroke: var(--panel-title);
fill: var(--panel-background);
}
.ddei-pv-border-dash-combox--disabled .textinput[data-v-2e01e102] {
background-color: var(--panel-disabled);
height: 28px;
justify-content: center;
align-items: center;
}
.icon[data-v-2e01e102] {
font-size: 16px;
}
/**以下为radio属性编辑器 */
.ddei_pv_editor_bordertype[data-v-ea9f8fdd] {
border-radius: 4px;
margin-right: 10px;
}
.ddei_pv_editor_bordertype_disabled[data-v-ea9f8fdd] {
background-color: rgb(210, 210, 210) !important;
}
.ddei_pv_editor_bordertype .itembox[data-v-ea9f8fdd] {
display: flex;
justify-content: start;
align-items: center;
height: 24px;
outline: none;
font-size: 15px;
margin: 0;
padding-top: 2px;
box-sizing: border-box;
background: transparent;
}
.ddei_pv_editor_bordertype .itembox input[data-v-ea9f8fdd] {
width: 16px;
height: 16px;
}
.ddei_pv_editor_bordertype .itembox div[data-v-ea9f8fdd] {
margin-left: 15px;
}
.ddei-editor-pv-subgroup-view-tab-panel-editors-row .itembox[data-v-ea9f8fdd] {
float: left;
margin-right: 10px;
}
.ddei-editor-pv-subgroup-view-tab-panel-editors-column .itembox[data-v-ea9f8fdd] {
margin-top: 10px;
}
.ddei-editor-pv-subgroup-view-tab-panel-editors-row .itembox div[data-v-ea9f8fdd] {
float: left;
margin-left: 5px;
}
.ddei-pv-color-combox[data-v-22680f1e] {
height: 28px;
padding-right: 10px;
}
.ddei-pv-color-combox .textinput[data-v-22680f1e] {
width: 100%;
padding-right: 5px;
box-sizing: border-box;
border: 0.5px solid var(--panel-title);
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
padding-left: 5px;
height: 28px;
}
.ddei-pv-color-combox .textinput[data-v-22680f1e]:hover {
border: 1px solid var(--dot);
box-sizing: border-box;
}
.ddei-pv-color-combox .textinput input[data-v-22680f1e] {
flex: 1 1 calc(100% - 10px);
width: calc(100% - 10px);
border: transparent;
outline: none;
font-size: 15px;
background: transparent;
user-select: none;
pointer-events: none;
}
.ddei-pv-color-combox .textinput div[data-v-22680f1e] {
flex: 0 0 20px;
}
.ddei-pv-color-combox--disabled .textinput[data-v-22680f1e] {
background-color: #d2d2d2;
height: 28px;
justify-content: center;
align-items: center;
}
.icon[data-v-22680f1e] {
font-size: 16px;
}
/**以下为color属性编辑器 */
.ddei-pv-editor-color[data-v-ec0fa5a7] {
border-radius: 4px;
height: 28px;
margin-right: 10px;
display: flex;
}
.ddei-pv-editor-color .color[data-v-ec0fa5a7] {
height: 36px;
width: 60%;
border: transparent;
outline: none;
background: transparent;
flex: 1;
margin: -4px -4px 0px -4px;
}
.ddei-pv-editor-color--disabled .textinput[data-v-ec0fa5a7] {
flex: 0 0 80px;
margin-left: 10px;
padding-left: 5px;
padding-right: 5px;
background-color: var(--panel-disabled);
border: 0.5px solid var(--panel-disabled);
border-radius: 4px;
}
.ddei-pv-editor-color--disabled .textinput[data-v-ec0fa5a7]:hover {
border: 1px solid var(--panel-disabled) !important;
box-sizing: border-box;
}
.ddei-pv-editor-color--disabled .color[data-v-ec0fa5a7] {
height: 32px;
width: 60%;
border: transparent;
outline: none;
background-color: var(--panel-title) !important;
flex: 1;
margin: -4px -4px 0px -4px;
}
.ddei-pv-editor-color .textinput[data-v-ec0fa5a7] {
flex: 0 0 80px;
margin-left: 10px;
padding-left: 5px;
padding-right: 5px;
border: 0.5px solid var(--panel-title);
border-radius: 4px;
}
.ddei-pv-editor-color .textinput[data-v-ec0fa5a7]:hover {
border: 1px solid var(--dot);
box-sizing: border-box;
}
.ddei-pv-editor-color .textinput input[data-v-ec0fa5a7] {
width: 100%;
border: transparent;
outline: none;
font-size: 15px;
margin: 0px 2%;
background: transparent;
}
/**以下为combox属性编辑器 */
.ddei-combox-show-dialog-content .itemboxs[data-v-e318138d] {
border-radius: 4px;
margin-top: 4px;
display: grid;
gap: 4px;
overflow: auto;
color: var(--panel-title);
font-size: 13px;
}
.ddei-combox-show-dialog-content .itemboxs .itembox[data-v-e318138d] {
outline: none;
font-size: 13px;
margin: auto;
background: transparent;
border:1px solid var(--panel-title);
display: flex;
border-radius: 4px;
}
.ddei-combox-show-dialog-content .itemboxs .itembox[data-v-e318138d]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-combox-show-dialog-content .itemboxs .itembox .itembox_img[data-v-e318138d] {
display: table-cell;
padding-left: 5px;
vertical-align: middle;
}
.ddei-combox-show-dialog-content .itemboxs .itembox .itembox_img img[data-v-e318138d] {
text-align: center;
vertical-align: middle;
}
.ddei-combox-show-dialog-content .itemboxs .itembox .itembox_text[data-v-e318138d] {
text-align: center;
display: table-cell;
flex: 1;
vertical-align: middle;
}
.ddei-combox-show-dialog-content .itemboxs .itembox .itembox_desc[data-v-e318138d] {
text-align: left;
display: table-cell;
font-size: 11px;
filter: brightness(60%);
padding-top: 2px;
flex: 1;
white-space: nowrap;
text-overflow: ellipsis;
vertical-align: middle;
}
.ddei-combox-show-dialog-content .itembox--selected[data-v-e318138d] {
background-color: var(panel-title) !important;
}
.ddei-combox-show-dialog-content .itembox--deleted[data-v-e318138d] {
text-decoration: line-through;
}
.ddei-combox-show-dialog-content .itembox--disabled[data-v-e318138d] {
color: rgb(210, 210, 210);
text-decoration: line-through;
}
.ddei-combox-show-dialog-content .itembox--disabled[data-v-e318138d]:hover {
cursor: not-allowed !important;
}
.ddei-combox-show-dialog-content .itembox--underline[data-v-e318138d] {
text-decoration: underline;
}
.ddei-combox-show-dialog-content .itembox--bold .itembox_text[data-v-e318138d] {
font-weight: bold;
}
/**以下为combox属性编辑器 */
.ddei-pv-editor-excheckbox[data-v-4960d25a] {
margin-top: 4px;
}
.ddei-pv-editor-excheckbox--disabled[data-v-4960d25a] {}
.ddei-combox-show-dialog-content .itemboxs[data-v-4960d25a] {
border-radius: 4px;
margin-top: 4px;
display: grid;
gap: 4px;
overflow: auto;
color: var(--panel-title);
font-size: 13px;
}
.ddei-combox-show-dialog-content .itemboxs .itembox[data-v-4960d25a] {
outline: none;
font-size: 13px;
margin: auto;
background: transparent;
border: 1px solid var(--panel-title);
display: table;
border-radius: 4px;
}
.ddei-combox-show-dialog-content .itemboxs .itembox[data-v-4960d25a]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-combox-show-dialog-content .itemboxs .itembox .itembox_img[data-v-4960d25a] {
display: table-cell;
padding-left: 5px;
vertical-align: middle;
}
.ddei-combox-show-dialog-content .itemboxs .itembox .itembox_img img[data-v-4960d25a] {
text-align: center;
vertical-align: middle;
}
.ddei-combox-show-dialog-content .itemboxs .itembox .itembox_text[data-v-4960d25a] {
text-align: center;
display: table-cell;
width: 100%;
vertical-align: middle;
}
.ddei-combox-show-dialog-content .itembox--selected[data-v-4960d25a] {
border: 1px solid var(--dot);
overflow: hidden;
position: relative;
}
.ddei-combox-show-dialog-content .itembox--selected[data-v-4960d25a]::before {
position: absolute;
content: "";
-webkit-font-smoothing: antialiased;
background-color: var(--dot);
-webkit-transform: rotate(45deg);
-ms-transform: rotate(45deg);
transform: rotate(45deg);
right: -8px;
bottom: -8px;
width: 15px;
height: 15px;
}
.ddei-combox-show-dialog-content .itembox--selected[data-v-4960d25a]::after {
font-size: 12px;
line-height: 12px;
right: -3px;
bottom: -2px;
position: absolute;
-webkit-font-smoothing: antialiased;
content: "✓";
-webkit-transform: scale(0.5);
-ms-transform: scale(0.5);
transform: scale(0.5);
color: #fff;
}
.ddei-combox-show-dialog-content .itembox--deleted[data-v-4960d25a] {
text-decoration: line-through;
}
.ddei-combox-show-dialog-content .itembox--disabled[data-v-4960d25a] {
color: rgb(210, 210, 210);
}
.ddei-combox-show-dialog-content .itembox--disabled[data-v-4960d25a]:hover {
cursor: not-allowed !important;
}
.ddei-combox-show-dialog-content .itembox--underline[data-v-4960d25a] {
text-decoration: underline;
}
.ddei-combox-show-dialog-content .itembox--bold .itembox_text[data-v-4960d25a] {
font-weight: bold;
}
/**以下为radio属性编辑器 */
.ddei-pv-editor-filltype[data-v-64114ba5] {
border-radius: 4px;
margin-right: 10px;
}
.ddei-pv-editor-filltype--disabled[data-v-64114ba5] {
background-color: var(--panel-disabled) !important;
}
.ddei-pv-editor-filltype .itembox[data-v-64114ba5] {
display: flex;
justify-content: start;
align-items: center;
height: 24px;
outline: none;
font-size: 15px;
margin: 0;
padding-top: 2px;
background: transparent;
}
.ddei-pv-editor-filltype .itembox input[data-v-64114ba5] {
width: 16px;
height: 16px;
}
.ddei-pv-editor-filltype .itembox div[data-v-64114ba5] {
margin-left: 15px;
}
.ddei-editor-pv-subgroup-view-tab-panel-editors-row .itembox[data-v-64114ba5] {
float: left;
margin-right: 10px;
}
.ddei-editor-pv-subgroup-view-tab-panel-editors-column .itembox[data-v-64114ba5] {
margin-top: 10px;
}
.ddei-editor-pv-subgroup-view-tab-panel-editors-row .itembox div[data-v-64114ba5] {
float: left;
margin-left: 5px;
}
/**以下为range属性编辑器 */
.ddei-pv-editor-fontsize[data-v-b2ded6b2] {
border-radius: 4px;
height: 28px;
margin-right: 10px;
display: flex;
}
.ddei-pv-editor-fontsize .range[data-v-b2ded6b2] {
height: 7px;
width: 60%;
border: transparent;
outline: none;
background: transparent;
flex: 1;
margin: auto;
}
.ddei-pv-editor-fontsize--disabled .range[data-v-b2ded6b2] {
height: 7px;
width: 60%;
border: transparent;
outline: none;
background-color: var(--panel-disabled) !important;
flex: 1;
margin: auto;
}
.ddei-pv-editor-fontsize .textinput[data-v-b2ded6b2] {
flex: 0 0 80px;
margin-left: 10px;
padding-left: 5px;
padding-right: 5px;
color:var(--panel-title);
border: 0.5px solid var(--panel-title);
border-radius: 4px;
box-sizing: border-box;
display: flex;
}
.ddei-pv-editor-fontsize .textinput[data-v-b2ded6b2]:hover {
border: 1px solid var(--dot);
box-sizing: border-box;
}
.ddei-pv-editor-fontsize--disabled .textinput[data-v-b2ded6b2] {
flex: 0 0 80px;
margin-left: 10px;
padding-left: 5px;
padding-right: 5px;
background-color: var(--panel-disabled);
border: 0.5px solid var(--panel-disabled);
border-radius: 4px;
display: flex;
}
.ddei-pv-editor-fontsize--disabled .textinput[data-v-b2ded6b2]:hover {
border: 1px solid var(--panel-disabled) !important;
}
.ddei-pv-editor-fontsize .textinput input[data-v-b2ded6b2] {
flex: 1 1 50px;
border: transparent;
outline: none;
font-size: 15px;
color:var(--panel-title);
margin: 0px 2%;
background: transparent;
}
/**以下为range属性编辑器 */
.ddei-pv-editor-image[data-v-d7cc496a] {
border-radius: 4px;
height: 28px;
margin-right: 10px;
}
.ddei-pv-editor-image .textinput[data-v-d7cc496a] {
width: 100%;
height: 28px;
padding-left: 5px;
padding-right: 5px;
border: 0.5px solid var(--panel-title);
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-pv-editor-image .textinput[data-v-d7cc496a]:hover {
border: 1px solid var(--dot);
}
.ddei-pv-editor-image--disabled .textinput[data-v-d7cc496a] {
width: 100%;
height: 28px;
padding-left: 5px;
padding-right: 5px;
border: 0.5px solid var(--panel-disabled);
border-radius: 4px;
display: flex;
background-color: var(--panel-disabled);
justify-content: center;
align-items: center;
}
.ddei-pv-editor-image--disabled .textinput[data-v-d7cc496a]:hover {
border: 1px solid var(--panel-disabled) !important;
box-sizing: border-box;
}
.ddei-pv-editor-image .textinput input[data-v-d7cc496a] {
flex: 1 1 calc(100% - 20px);
width: calc(100% - 20px);
border: transparent;
outline: none;
color:var(--panel-title);
font-size: 16px;
margin: 0px 2%;
background: transparent;
}
.ddei-pv-editor-image .textinput .icon[data-v-d7cc496a] {
flex: 0 0 20px;
font-size: 16px
}
.ddei-pv-editor-image .textinput .icon[data-v-d7cc496a]:hover {
cursor: pointer;
background: var(--panel-hover);
}
.textinput .fileinput[data-v-d7cc496a] {
display: none;
}
/**以下为radio属性编辑器 */
.ddei-pv-editor-radio[data-v-d06209f3] {
border-radius: 4px;
margin-right: 10px;
}
.ddei-pv-editor-radio--disabled[data-v-d06209f3] {
background-color: #d2d2d2 !important;
}
.ddei-pv-editor-radio .itembox[data-v-d06209f3] {
display: flex;
justify-content: start;
align-items: center;
height: 24px;
outline: none;
font-size: 15px;
margin: 0;
padding-top: 2px;
background: transparent;
}
.ddei-pv-editor-radio .itembox input[data-v-d06209f3] {
width: 16px;
height: 16px;
}
.ddei-pv-editor-radio .itembox div[data-v-d06209f3] {
margin-left: 15px;
}
.ddei-editor-pv-subgroup-view-tab-panel-editors-row .itembox[data-v-d06209f3] {
float: left;
margin-right: 10px;
}
.ddei-editor-pv-subgroup-view-tab-panel-editors-row .itembox div[data-v-d06209f3] {
float: left;
margin-left: 5px;
}
.ddei-editor-pv-subgroup-view-tab-panel-editors-column .itembox[data-v-d06209f3] {
margin-top: 10px;
}
/**以下为range属性编辑器 */
.ddei-pv-editor-range[data-v-713ecc9b] {
border-radius: 4px;
height: 28px;
margin-right: 10px;
display: flex;
}
.ddei-pv-editor-range .range[data-v-713ecc9b] {
height: 7px;
width: 60%;
border: transparent;
outline: none;
background: transparent;
flex: 1;
margin: auto;
}
.ddei-pv-editor-range .textinput[data-v-713ecc9b] {
flex: 0 0 80px;
margin-left: 10px;
padding: 2px 5px 0px 5px;
border: 0.5px solid var(--panel-title);
border-radius: 4px;
}
.ddei-pv-editor-range .textinput input[data-v-713ecc9b] {
width: 100%;
border: transparent;
outline: none;
font-size: 15px;
margin: 0px 2%;
color: var(--panel-title);
background: transparent;
}
.ddei-pv-editor-range .textinput[data-v-713ecc9b]:hover {
border: 1px solid var(--dot);
box-sizing: border-box;
}
.ddei-pv-editor-range--disabled .range[data-v-713ecc9b] {
height: 7px;
width: 60%;
border: transparent;
outline: none;
background-color: var(--panel-disabled) !important;
flex: 1;
margin: auto;
}
.ddei-pv-editor-range--disabled .textinput[data-v-713ecc9b] {
flex: 0 0 80px;
margin-left: 10px;
padding-left: 5px;
padding-right: 5px;
background-color: var(--panel-disabled);
border: 0.5px solid var(--panel-disabled);
border-radius: 4px;
}
.ddei-pv-editor-range--disabled .textinput[data-v-713ecc9b]:hover {
border: 1px solid var(--panel-disabled) !important;
box-sizing: border-box;
}
.ddei-pv-editor-range--disabled .textinput input[data-v-713ecc9b] {
width: 100%;
border: transparent;
outline: none;
font-size: 15px;
margin: 0px 2%;
color: var(--panel-title);
background: transparent;
}
/**以下为checkbox属性编辑器 */
.ddei-pv-editor-switch-excheckbox[data-v-5a394c0d] {
border-radius: 4px;
margin-right: 10px;
box-sizing: border-box;
}
.ddei-pv-editor-switch-excheckbox--disabled[data-v-5a394c0d] {
background-color: var(--panel-disabled) !important;
}
.ddei-pv-editor-switch-excheckbox .title[data-v-5a394c0d] {
float: left;
color:var(--panel-title);
}
.ddei-pv-editor-switch-excheckbox .chk_state[data-v-5a394c0d] {
border: 1px solid var(--panel-title);
width: 14px;
height: 14px;
margin-right: 10px;
margin-top: 4px;
float: left;
box-sizing: border-box;
}
.ddei-pv-editor-switch-excheckbox:hover .chk_state[data-v-5a394c0d] {
background: var(--dot);
}
.ddei-pv-editor-switch-excheckbox .chk_state_checked[data-v-5a394c0d] {
border: 1px solid var(--panel-title);
width: 14px;
height: 14px;
margin-right: 10px;
margin-top: 4px;
float: left;
background-color: var(--dot);
box-sizing: border-box;
color: #fff;
}
.ddei-pv-editor-switch-excheckbox .chk_state_checked span[data-v-5a394c0d] {
margin-top: -4.5px;
margin-left: 0.5px;
display: block;
}
/**以下为text属性编辑器 */
.ddei-pv-editor-textarea[data-v-ac742ab1] {
border-radius: 4px;
border: 0.5px solid var(--panel-title);
height: 80px;
margin-right: 10px;
padding: 0 5px;
display: flex;
box-sizing: border-box;
}
.ddei-pv-editor-textarea--disabled[data-v-ac742ab1] {
background-color: var(--panel-disabled) !important;
}
.ddei-pv-editor-textarea--disabled[data-v-ac742ab1]:hover {
border: 1px solid var(--panel-disabled) !important;
}
.ddei-pv-editor-textarea[data-v-ac742ab1]:hover {
border: 1px solid var(--dot);
box-sizing: border-box;
}
.ddei-pv-editor-textarea textarea[data-v-ac742ab1] {
flex: 1;
border: transparent;
outline: none;
font-size: 15px;
margin: 1px 0;
color:var(--panel-title);
width: 100%;
background: transparent;
}
.ddei-editor[theme='ddei-core-theme-default'] {
--background: white;
--theme: #F5F5F5;
--text: black;
--dot: #176eff;
--hover: #e7e7e7;
--icon: #424242;
--border:#D5D5DF;
--placeholder: #AdAdAd;
--scroll-background: var(--theme);
--scroll-hover: var(--hover);
--scroll-border: var(--border);
--panel-header:var(--theme);
--panel-background: var(--background);
--panel-title: var(--text);
--panel-border: var(--border);
--panel-hover: var(--hover);
--panel-disabled: var(--theme);
--panel-selected: var(--hover);
--panel-title-disabled: #AdAdAd;
--panel-title-selected: var(--text);
--toolbox-header:var(--theme);
--toolbox-background:var(--background);
--toolbox-title:var(--text);
--toolbox-hover:var(--hover);
--toolbox-control-hover: #EDEFFF;
--toolbox-control-hover-outline: 2px solid #BED0EF;
--toolbox-control-title: var(--text);
--topmenu-background: var(--background);
--topmenu-header: var(--theme);
--canvas-rule-background: var(--background);
--canvas-rule-border: #E0E3E9;
--canvas-scroll-background: var(--background);
--canvas-scroll-border: #E0E3E9;
--canvas-grid-line: rgb(220, 220, 220);
--canvas-grid-dot: rgb(121, 121, 121);
--canvas-control-border: black;
--canvas-control-background: white;
--canvas-control-title: #252525;
--canvas-mark-title: #252525;
--canvas-text-selection: #97bdf2;
--canvas-text-cursor: black;
}.ddei-editor[theme='ddei-core-theme-black'] {
--background: #212121;
--theme: #2c2c2c;
--text: white;
--dot: #176eff;
--hover: rgb(60,60,60);
--icon: white;
--border: #DFDFDF;
--placeholder: #A1A1A1;
--scroll-background: var(--theme);
--scroll-hover: var(--hover);
--scroll-border: white;
--panel-header: var(--theme);
--panel-background: var(--background);
--panel-title: var(--text);
--panel-border: var(--border);
--panel-hover: var(--hover);
--panel-disabled: var(--theme);
--panel-selected: var(--hover);
--panel-title-disabled: #A1A1A1;
--panel-title-selected: var(--text);
--toolbox-header: var(--theme);
--toolbox-background: var(--background);
--toolbox-title: var(--text);
--toolbox-hover: var(--hover);
--toolbox-control-hover: var(--dot);
--toolbox-control-hover-outline: 2px solid #BED0EF;
--toolbox-control-title: var(--text);
--canvas-rule-background: var(--theme);
--canvas-rule-border: white;
--canvas-scroll-background: var(--theme);
--canvas-scroll-border: white;
--canvas-grid-line: rgb(121, 121, 121);
--canvas-grid-dot: rgb(121, 121, 121);
--canvas-control-border: white;
--canvas-control-background: var(--theme);
--canvas-control-title: white;
--canvas-mark-title: white;
--canvas-text-selection: #97bdf2;
--canvas-text-cursor: white;
}.iconfont {
font-family: 'iconfont' !important;
font-size: 24px;
color: #424242;
font-style: normal;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
.iconfont-small {
font-size: 6px !important;
}@font-face {
font-family: "iconfont"; /* Project id 4428875 */
src: url('data:font/woff2;base64,d09GMgABAAAAADlAAAsAAAAAhBgAADjtAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHFQGYACSWgqB2ViBrDUBNgIkA4QoC4IWAAQgBYRnB4xNG5hrZYaYxwFAtReGKMriqkRRJyinYbL//5rcGFNcOMu6jXqFBssTTMfFsmWzB5xcTiEFNmTZQcSbX5Lry7MwMZlF7XVMj02GB+HPl0VrFYVkHEAmxKssHTj/uODGvww9fUc2kx2SFE0IbI2cvQcALAAnzMKIJlMjywPfGO6fzL0tiiZvC0UR09e54Wur4CXgpdOIYp16EMA1b4kVHxHrMizwGY1ogLPpQIC5DTzRPERKuxl6zCRSI77MX55wAj8JDwknKu0wdds7PM3t39022Ma97W7UirEd1QMkerCNqtHCqIFgYAImJRwooI2NUWBgFBgYhei3Ciu/GAUW8z/O9laTXKLBk5X8t/OiqiatJK9xXLr60Ync7nf+84dISGQNESwIOuO4/xYAAegmEm3nCu73/dZycltMZm9eja8zx1RGFftjFwqKwJLQjYCh37Qe3vOZ5BSGyp23fuLWXaSylqRNVq+nMvwOvyOQtB4h0DVP23VBOmAAQP7fq1q2hKiNd5nnGOQUi0bay92NuwrvfQDU/yBIARR3BULcE8hNkFZrQTzdiORqDEjaNUBqA+Uk7YUQSkdSvEBtmCNXDuKFkKorHXPRualcuXNVuCpz3bt00fbmeexErvkDoN9Lk+u/izfLACc+wakPYvZ7Y9Ck/SuvpavB3HUY9/7/Ytv5umd7Zh1nQhKhJETZ/31+f2N7/yLDaHISSj+53R8CJJuzU1z/ZrtErsFxTUrZbn7gdP5wLUx6hF/iMuGkoDnaSHvYLOxrINqL/fAH/ujDPwuhS6Qh2X1HmxeUIX8A64JUaiHmm93qHOCOI4iDGGgVrDf6Qs6Ed1JIW6HcisvN4SkUarzcl+afi8AXKFR6HzyDN9ADX+C/C6mVFRe4ztFT74xgeB/QzxKG/+/yQK6qbk0tdX1qTtv7eeSxJ/ZcMDH1cPf08vbxteu+Bx66bG5hKe1mbWNr5+Do5Ozi6qato6tvYGgkqqdvQCCSyBQqjc5gstgcLo8vEIrEEqlMbmhkbGJqZm4hsrSytrG1s3cgEElkCpVGZzBZbI6MrJy8giJXSVlFVU1dQ1NLWItWbdp16NIgS6KgidAIjE0F4t+6238izB+DXIiAeMRAJsRCFsRBNsRDBhIgB5IhHSlwAVLhIaTBV6TDJ2TAZ2TCF2TBN2TDVciBa5AL1yEPXkA+PIcCeAmF8AqK4DUUwxsogbcohXcog/cohw+ogI+ohBtQBTehGm5BDdyGWmiGOrgD9XAXGuAeNMJ9aIIH0AyPoAUeQys8gTZ4Cu3wDDpumltOcAOWC8BZ6IZz0APnoRcuQh9cgn64DANwBQYhD4YgH4ahAEagEEahCMagGMahBCagFCahDKagHKahAmagEmahCuagGuahBhagFhahDpagHpahAVagEVahCdbOYV51AC2wAa2wCW2wBe2wDR2wA52wD7pgP3TDAeiBg9ALh6APDkM/HIEBOAqDcOwUcY0DGIITMAwnYQROwSichjE4A+NwFibgHEzCeZiCCzANF2EGLsEsXIY5uALzcBUW4BoswnVYghuwDDdhBW7BKtyGNbgD63AXNuAebMJ92IIHsA0PYQcewS48hj14AvvwFA7gGRzCcziCF3AML+EEXsEpvIYz8AYS8RaS8A6S8R5S8AFS8RHS8Aky8Bni8A1isQcx+AUR/kPgH+QfEgC+A6Ef0SRqR9B83O4de+zm+1ej6HyypPlM/0pYsGGws1/qIOQWqd5mu0HLZ4d6LpjlzdnX1X07rIKUixNQVZFE9gcDF+KGcnhjXzU7hN29vdyUeK7yDzVlG0G2ZLloW/sLcciNRI/yI5Vmr9t9rnuXBwzVtSRWeKHFb9/slj+wKcJnq7bk0PFHdOGWCAS0ET3qJEo94OMTUv2jkzpAx8Cm8dIroKo0d455DWSF5Yiuo4VboKuv+z7mEnUggB/CBRp6F2luWCjOY136w/o/BUvj4XpVrLvpwI9OMFx+J98/lrpUVHFFXvppDdplmD2Oc1koucGTk5JmYMJ7mICRCCf2g/kwCxXJFEF65LpMu60QUww9R60IvrfReIpogLX1ibKTFJUY5gkKhWqSsm05Vc51N8tBRlQNzQQ/PiolxySqTMmjc2ie6/46N6qBN1BZ4XVh5nacMyOq9kLgdah4LQryFiXXYYLxG770iFaerf17JcHLUS0tmKkTi2km5llhG2fGDKUtPaxuruEObQLCQGxm0sHC0zCsAxQ9lMVORi19Dtj3RMwr54j6ZA2IL2XcdEKZPmJoaWonyTC5ldjpbedmjKMbRYArJyTiiboKxy1LDnRVAXLR56on5tqn+5ehaembjEFAo5KVR5beO3Opo7y/t9ErnHquX/TapkqwljJHExU0yutVZZh6tYZmWQY4/Not675LgOFLETeh2OX9su4yoTWxD7jGFI7Ic4Q4p1uO1kxe9T21v9pz6FbyoB3UfWUujt+vdSvUVZkQjViaLYQm7wKZOq3zsmaZqlZEQ5Zo1FRDhAHPVfQucCkyHdUwM5GOdqUs1qZbAp7ftg3wuu+qBjM+3uhomtAtUeZ6nFLuWEiS96gtihnTDsc37x8/kNx6oNzZX+84USkjEyFyvAlAUQydevwcSvPa5+MYSh7agVLMdlF/AHx7hy3owI6TAvFZOiDpBFVha23Ex6pxR7C6uYPImKsazAltZN4Jmg3AscexXbOdY5XjztH2EW966Qhoo4Mpq4oKZbf0C0CSyKT7Vy9DsTiW4CgaJS0JXl7R1XR9BczISTtNs2ANgE8rvhmnad/UWLn0610ksEO4Mgx9xEy8qhxp6DSliOPYySEifbEe6T38zkIk54ECMl+VMuH7aVODBSTHYoCgJ5qGMy1WKJo7Kov7hwTkEeT+bU74daW2llZhbMsS7KND0Y3oPuz5JnxKUyjkN+XQH+Hy2xho3WfjeGPdh9Xp+I238ybJC/Xf7wALLtgibn1H6BEQKjCDHEzRM2poo5uh51ltxGjVgj7ilpZoFwBcFtP+qYDnTRV5W9ZBSdyQ3HeWhIFHMlIe03nLMLbVzg0ZZQOJiugdMAmUdWVcAhy8qXcIIAnXHfsllDcJ+onzihBM/ZFh/3fQ9YrwNaYI5R8pnB6TtCCuZ1AjhHHP/DytooTVbC5TwyOQSV16PktMLA8q3aRmHaWZqGrh+GnmVutoVxKdkNBlotsqdgoZSeSDNdnkvp5aXD1/de+erpdek88FUwibK5S7xd3mbiZufKfV7WHZYDh+Nld4+vs13NYGhaMOMaz0UfKWEGgNp4oeh5Ao06BpBQDlMcrkDRAI6A1kyvFBm8FtkXVlGKb6qRxUS5wRLHBOq9Xfz5qWTRtylNV14IDMJCQOSsWsg3JWB+QlNDVI3D72l9rc+XaAelDuiUXFeqHVmp6EgCr8NiNghyY0K8dSltWGFenQc2cM52J/cyfe0+cfIZcGgl32/sHwuBylsDlgUk6oBBCKGRSHWQdkhLYzs2lXDdbQxoShqWbU9rYNuxd6zPq+mb/pcrcONUDSiBkYTEgNl6oGjykEBYoW0CWSgTwK7EGtEDr9ObWJ+5RNfjFnDO+yIFAecaIom+hEHrCtSca84YupOWRzBIPJFYsqJQ3MF2MMUwpYsDnYz+m2SSpEBmC0li5B+Hxj4tYocSACn7ODCR6ZhMcKBRtoicgyTCNOF5wT4dGsjYUWuZAPc4Y2DCegKxL/PdOQ8OGYBJLApKuKFbtu0hlTvs/lCR+yVYOLyVWB/ZF2lR6TBJVcIAfH7KLDYkn2wvEuCtPvtkxpVc0aaDq0HtSpCRszMqHo6VJjG3yzu5x9IDANC0F+zcOt0qBG+VC7WUn2appKSwMl5j49c/pFp8DRtc8/7U11dREsfTWYNlg53H3x/Rqbhab8A2CLE1+NDed+QQtlUpR8QghYdc/0JCYqL/b2CrTPJNphaZp+CBeHN0mllZd6doQmCaij4CwhLIW5o+TKnng5vnx6PeHS7wSZV6Ikq0ocvWUwz6Vbz51hyEIIJcF2p01eCRcOHGA4h2zTfhaC2RBVfqA5dGJJOE2sjNPiFgnUddi3S9KK+UDmfmrPyvyodphqspDPAHYZuu/dd4lc2OM21gESYL1CWFVRL6ZgNr01SHbPduioQ5Zwmp6i0wIJbGkyWaBiFptYtjx3sBbPPCKY5Tuw2KqMkbYeDY+WTU3sF5oABRolUWOrTuYrautUNs8FDOkQVnOOzKEaDpO2cWuMcJkYZTteo9km4ao5TjhXtMa8woME1YOOi72D13fZu3snGweb023r3COjhqqKQ2gbBeLKdkJVRzWsGpX8pKUodVDxycAaOwcUvHvAyKdaAg0gXTtxVJUhDt3WqPolTiimuIqq8wxcIkIMcPQrpli1TGfh+trOKZS+3334YFltrWh668zs8d5Z1PN6bEIt1O4wZJF14NCuDllnX4+7NIDSIspXFBfcMT11pAvYj56XoxNcihdd5LiFwwWdXDtln77uXD0plT2tCyZp4WVn1V4ZMhyC9pBY6ZjNZCzENIMx3JNpZMGnYlz/ydYYOKBOfzd2xYVRmqVVtGMx33CJ5uyqNLGfswzmhBH0WbVGzZMy9k0YzWKmPJ9XrvTV9QyMaTehA7LvahMxaZFopAE7LDeGqw7INbtPcIKps/Mu49LKvk9oac7MbHj8cLesc7tKN1NlndUa54/2F/9AA6QJTZ+gquG2qSjvXV4bxzs1QXOrVMJ8EqATq8vQ6wMORASxJ+ecU3oJBrcggWoTFkH1lYX91+OrcXTFJAqdunMaHc4EnxgE3dug3KBqat2woTH6tYieoybxXU9lh8MZxEfSLhg0vjdsfL6ly0I07i/mu1WLPSvMnKbQhvJseLh7B3zZOdXq0nW3r2puVbnx9lPcgrlAX3NKpeXS1TNe/dR5eCYmzlXOm7cf3qzLNo0Kwk8kL+7hiDImcbuQM/aCRxM1ewzj2Mn4tGw6beNzQFbvPhmcFfAuFCp1r/FCVdheVOwbOLe0TvJMzNOerZd8ZYOIKixGM9PF21Mdt8uydd60rtzBZdJQ3cE8t/p1dtwliMeSMKS3YneynVpSIQ8dsHx3TZPPa414WelH/86Tgp1w07u4mIl+2iM4wNJ4KaKoc5dsTqmmvfFPhkfJZHaKE7Nisj1cJp8lX4t3w6nUcI0uulKbSaVGHHW6/kzMH8XaS28WMDnasM6a5Ze1bUI4TN0y8l0jc3rE7ZzbQjhdRlxq8d0RKVUQx9fIPLXv/a1lEA7SQ+17oOqAGdiDpdDpN9zhuKLr+cLfGczRLFOnqmVYEU6Zsi1U8BaIcvkyvrEakWFeC8d7Nskcdzev1WOgNGRrlnDcTFZNYvlGBvVu7M4KTpnMV7johKMWnJT8NvTWEtnsh+CrwtWlPZdO9uHqb9M6kJUtL1VQjxacQuI3CUudE4/OhkvuPBk3m/pNdT2VJHOM+CrkXf+5JKF5p3IyTm+nyTW6wWEvwFE0OSYq5UAcjNcFjDCHEgEdRXNSkT8M3igWjirDp17rwGcgW+qO+YGjL4pXjrylP6UgRw4hM1hYFB1uYqdxemCDTrF6LEQHnAMrm2XoPhn4uggM5hk6nWo2nTC0K0sQ3F2S5duO3G4bzT8ygvbzyE8GFv2bWNHGhCOKZg4g8RmVVMPtJyKTXMFXv/Rfl4l92bsuAf690taDsT99H3IEBLUSDXUmk1XJxZfcRg8iyU8lxr9BkjHeCN8wth/JBFJykUjh+9BkJor/BKXqC/nsy/Hd9q5jXRm5Cv5MzMO/0/apF8C+RJzOiq2UY7VG5QzB4E/YRPHvBBXHu7kxIXVMPdW+z7tt0BCT3BsLwkY0ZuMkF1KofbaVOnMiVYbTptoG8sTwV+YUMrvaHCacT7ReCKzmj0mWSGifDannHuSCRqVJiki+KKQCVwQ82pK2VDYSgAByy0k8y5uZvikao8RPRG4COcKZEtyZMvqrF0IEsN8etJgAZYkD5kK5H1bXhhTDvry/S8A4ZcCllNOo7O0mtjjnxG8Jhpykskl0rkit8ZKA2diO05V6oulq2sE+GNE7MsUuBaO0+GyAAuiKIAMzKIyS8GZfkpbMJMAnMJjD+DYDOg1tvzV7HcrLxb3SKx1adGErij4XmfqVedAS5djTFmipWQ5eP8BXoqfcK8nCv27Ud9Xx3hMzptp/nascYZni65CL0zMRbyQpgXPUPC/YeMpLEqh07h4MB0WnCIhC2z+oVLTw+cP9Tam0uYrb5VNlEuDaA8kzvI6AC5IQ9zhTcxjWwwaTSp5jYX54yN1z4Rkn7ExNXoU5E92cudb4jj/6h9jV9r2G14Qy9nbCQAThTPhFQD76HRSR3At0lnaYUs1LEFNP+dR3F84SIa5SGWDPvWD0DpM1D31DjrbBFfxCei5l02ktrFBiY2CaBO1tRf07I2nBgRJSEWX+OJpi4+ITcua5LaSoytceBlmaRXejt8HI6ALwIM75GhSM45Rm4ag1hPJv2bnCbOWFFKVnFEsnW0uM0HVB2B/jtW8E2VO7Y11ipQDovSBJB60wfX7mGTa9Rkd9uh+9ML1nXjCbTkF6seM1OoT+Zv3MuYX7S7Xz+3pyK/nyI5prHxQ15inG756vXP25KmfgqNS+txmr7nvTWhORvMMrYU1dzlrhetzzELXCOudaap220kSnGul3abAGbuGRSuJ/mYy59CRpVIN4vbtG2bMW7DdRJ0EHFzWPJWYYL65GCZezSsOpeUpdBtGRPhPQ8INUidYaqEVQA7eFwzB9gFDMHGHzQpQk6VprNY1fxzUvek33z5wbQP4IGgqSdSVwlOpovKy1MID4oQNHFL0VmRdxphZoRSViXjN3PYFi5EN47Tv7l1++CM26/m7YaW0m0L6l1258FOW1STBAvjtjLdClcrADWuCRM+b+fBq7gk1kxV51ljEjT/ZYrT0YJZjKao2jwYD4UtnDelHpUnLf4VKRcjGq8j34wwINXSrVG8aOXeGKt2RcS5eS+1MtR74xV82lFiuBkM4R+fxIapUn0y9TaMZVY+fjKlOUpceiz6L8zv6TH8eOdfnd8MldA6c+SYh+4a2+1Gv7gGTt4sm1d6JJfNx0QjsAkaFfUe3NlgmNgBhYuuNUNRtS4GWdgsSdBynKFwpF20c4BEsw6SJ0hrS4FWhjotGS1jz92/C/ztZ9jaFu7srfrzloYCVfE/xbN0ATmUy7uW0iRvqQXJ/5fZ5kZqObIUKUiecH7jcYoNk7YDaAaSN30kHC2q9OGaY0n+34fVNK82OOSLV/Zkom2Ld44tIpzCdBU9gIkP99waDMU7WFvHVo0f4SHDfWpO7Z4oIXrV25wV3RlRTXc7IkTlolQmMOUKhIDyPNnvpKR8xAFlU7U0cqvY3DYOi49unoRFfV9O5FehuLHTMv1A/MtatM3VS35qnkwcpqb+Ngd619TK1yN7utrqpFlOpWKja9BTorCz3cKoYdiCm3vVyHREmm78Es8XqLB13cVzZTr1nT7maN0EZFezkU4NoF5BpWZlado9MtlxOsh2hydkxNNw8eNkC9/oWj84YLK+f6dPohWpkymhdarx5Aencc+PQaMStgYszhdmozCfLIUkKKxXB4y+3UsIKHGnH0FS1O7E4f4T75RnQu8kyEgH15iasdz0ZNnngDSSEJNRyZUMZhnlCTNl5ZIaPK5po14Diiw/qJVWI+iSfRMPvEykyLDUKL/C87kUaYKRskZeHPpWYyw5vcnYoTzdXbDsUYtocxttr+NoAkxG2sFSHW2LgDB+j3m1NdI2a4n/SRfbY190sG0e9QmzSvYTxxf1vmSk1keUPkevSjqEoqyiY15aj3zEkPp+J+Aum3HGkHhwc1kMfpkGZ/lwr83q9sMvnnOGLS1Li9qeTH+heqQND904bIAIJnRC5fRLdbPrkrufIFGcmEvAUyjOlUkKwa57Fg6pbIyjU4e4pWUQh4NggG3jGZeQ8mS8OTZfe0TPtve3boXEMeLPhuMe5RRFF5xPhH17aqB/EhKb9eBnbf+Nrf7e+7mfldWdIz0u7WeefEX2an7UvdNwc5K26d1y2VndmTlc8En101Bl6VG1ztKiMy3AkkTwETJwPEPUT7bCF28fRUPdXZ8OQC57KyN7OJ5jdVVZGyuOXyf0c1aHmZBlZxWcNlMlVkBmmBgMX6DLCfKpoQ7fSILVPZ+JqCv8czyqRcFy/9Xp5Q3muyEkAS+n2OI732BZtPYI4O0Me39RL3b42y8ujY3ijiiajJkxv7T3u2xAtse6N7Rwe1WtjYRj2NEAxMOWqqS4X7HubuTXZM3jCQuw+mTjN92I0SD/MQQ1oPaogM5CEGSV1t9io7W6V9m3lRR4N5m93g7Lrtq5rS7uQM805Jm6TT3EdYSbJnRuCYgIAxswKKzxNnFQc8XEHOZFJQcDLpNMMpSk4mEWkjIyGJdItykuhW6IBPV9Uo46N2PcbnMnvsjnZdzk10ind0iXKNzewy6rftN+oKUY4tD54/LRgaklhtd7RJkOEa6xwV75jkBNyf8XsJjMKIXgqmrF2tQ3QAmS6+97ILScA5T33TSqKNbvPVr1EHGgw+FezteVAm4x/hv9IJ/gdu7vWiGN5TmVof8zF66X+YG1RaGhQCz+/bvNGv0DN0dKU5ERw0blxQiKBudXqU4zhsmkKr8/Zb55rg4hzPxUSZclWMdSqIsndV66dJ4xTe2yyAW2+xt1gn7liJMD/pM0qiHQyG9xqcepaEqdnKGcttvy5qWDVDJpNHYknSNb3yVdMlYMotjICSAAkk7lviomQRrT+YhuI0ug6mNaJu12yunTtgZ9c/FxIO371pNDzMT6MHAjKa44o0Iq4ghB9UgIuUQnp/CEIguJsbHhAuVJbcD1Az+gBcYFTd72VxabTbiezrYp8fDoRh1M6dmjjXnq/fNLsCJSCAGzhcBAlJwKLi1LxxA6XpkkzHAvy4uRCq6xsaUkVcNloy1vyCSifXTzQpLqV9kmxP6DpRWB4+oeDmYH+TcGaPIrhp3iHWsAtFOrGdg39E9lRhqXxzRkVJeSaqlEYRf2wcwsQ6USFbc7ajlMIOQ/iM3BRDArLPy6JWHcD5RWsJSBgviD9QAksOxFcdJY4Ct/hGS0ueRbYlYWlhKbPMtuCpr1Nvy8YIaIGKZZ+aMH7udaLNbLftvjawYdBCZ6jr8XW5zsipb6TWuYQOenzRvXysYwYxe6qoN83OYxNb90kzmnmZPcDG5JNAOp3ghnHbeTgPnnHBEa365bBcfwWKviiGJpLUa8gvxa1jeOkeTigsHEuLwMnlGDVlpEXYoAeeeVUZmBvkYdyuqi5zLI/N1bxOS/RLTPdKD6qlec1m54kkIgMuRnwtYWoDvF0iknDSgesiYkaaiqx/z9me99eQZb3SssgCXwr7Jr7hMF3MPoI7Za5kOf8Uxr5kI52hAO1pvOkkAmiDw1iWWGQC5IHeCTj5wtsYIWO9cwH5rXgZs5vbyfL10+8kOph+vo8BvIfp22/sxLtZh0bA8ck3mp0zkpzunB4MvD4rIOx5kfs68VDv9BGl4q2fA7ZSOT15nujgLI8fYsosxyzj381gte3f0vRXcFfop6Ux14PM1FRmG9JAqv4Kzkp9DQAbd00J0yt83FSPhPOvmBKS/87yEdOjpgh/VRGM3B1zMzuvcPd1V+j+bqNO40NYZmfdZXoyd3osLPNu5KQeKTc7Z2H3IHdDpVHJyI81YHb+mAgLC8k5OaEnk2uPoeGcOLkFWfOD0IyNYtRSCIgJwAhsr1gj3su8MwuffYe5FyXRvRghbz5QQTq6A8xZr/EPZeYp+NRyS6wT3xL5VHTa8VHMYNz6LZGnwigiCvWTqKj3lm+CPdKCz/huu6lnK4sWp4hvo8dET7Db7hYX1n7aTZNbgPLQ3Zb+j6Ihve0XHngPCew2RggD36oIGKcTZfkieag4HSqo5PtiYkCsE+Wje4nF3wBCYrFIHZWX7RUDA1js7gSHzBjOrW6GiIIRfaPlR3+2T2IpQQ0OFSAIfhS6iXxa2yABW0O5xKWllLZWKHNp6MxPP/uQFhDSkkw0tbTTlVsSVVoNCsmWfEhgBXau+V3yUSRBjrLYtbMiwd9n0yYLEpGTmzZLPnSKCksUy7VAJelT/m3RpQFsBIelAgmNRkv6TozyJNT5P873cIYkz61uvykWa8R+ca/OfAW98NLXziOmRk+OCJ8cNQ2fpxqZ6OpX8V1t/JYt/Rh1DKUhTqGhTgSB7f9Xkr6xhiaoNrrREWTYF8+4ZiLhzgotCSkuUpSEzeLq2aSHtRrFlfR/CIrIvtlmR3l4RFuefzr2BEA+0pUIAobEX0Q6kY9Xdo5X2e2y4vdiPiLd7Ju2CmubUFuURL/43bY3P1++tiXLPFN8bLSGuohInaHWxjfF08U5NtbZWUxOXYMpRt6mt2rS/LoTkMf7Y9S6tc3zTRqccsdK5lk36XRN1vMkY3OdGkzm3127rlCW+7Y0syvf1zcfTPUt+PZNK/DRvnKf/PPZ8h4HqRkzKSaoombOoIQEuGHDfqeVaTLHJ3/72hMUpMkY26ivxxrOlRWm5FICXFCp0a7wNIuZuhRtCnliXHBySm5jrJn3kiv6atKcXxHvZRcd93lnnItTXKxTdpxT21wc7MQpIsxsZzuXmx9NqP8jB8kNJ3+nG5LxdWeehfW3ZDm1nTozQ5/VD6LzvCYqYNvZrc2NK9i8nUEvWJ9YgMr0gEduKuN5PK6bK2ogpVJTQlzQQJRXNAgQJtXcXAmYYyAhpD58oITH/Z/CiCycxNhGnMgJ+uLLjd779Bmru3RYeu35CApbINWPg0xxy5RUW+D7wwC2roLU/fsVArys7cyZKVPaynBBRVMTBf6G/kX4pAD5W8vkj+C/f+EjdAbyh+76F6EzRiqu6QgG/gpI5lpsvCbrarEnpv8MWgw7aM0YR7QOM2bezZYmC/nTTD4yikSmRSBBwsw1bAtJfYlKX6ZqNjrt1cgv2tYPFNdckGv8ptimPqOjwTI66PNGEEM3/36aaTCKv0jNzKSqcAE1NQ5YkOHiaWJTulTqJhtw97aQk6kPkuhZqkW6qbhQHC4uEhszaIghOejuLXeXe8kHSTeplE4vgIVONKKFfCI5aOHtbuHu5Z5tiPJcjcS69Qeb0FGUtBh4K13uTVbWY+uWttmUGZvq6UUwslnaxJzyD4NyOUkw8EeDRa9Mgk1pJE29shsFm/wof/wB14oHYIB/HxpyJtKN9BgRenp0eu74+sEBgkG4EeyDjyq+m7qaUNNwl5mUWPNosAESYRCDj5YlJLyRWX/Pic75Hr1qWIsV5Zaie9KB4P0QeNYtV2fAiJMNDF2ESYImo1JQb8S4gSqQ+siSmoSL2m+839qFG1RUUAJCSEVH5xfRx6elfg0KqKbG+ZritF/TslL7v803V5PmFM3dHsqt2LIvmD/EBbEPqu19k54Y1EDiWMCizuI3DyEBa9hXkxx8fvbFCvr/LmlhhyToZODJgwsCFhzUBmqBJx6yoT4S1NTOOQkJ7BRGwJMYHLfTv7audu3JJ671/ovTZz5mA3w57/Kv3VQLNul/N1OWJ5tZMDwC0k5Mq29177Xtxx/NfQveiqfxnlxy0T+9XcCkE1/XSfm5WsJ+61VeufHCIbVrzeOvQkvyI/ldOL/B0FKvgv2/7BhrhwEhkGIm8jIl/7JNIYHRMAKWsY7J/mdPgoRQhkn0mp5s1zdmn7CyUvPHTJuZMQOc1RpseDnw38qCMCTdMMQ4uFzWxtl6t2rgw7AoZO76ODF76rLw6XVHS2pjfMacf5rNm7oc79M1XiEaZqgHluyqalvPWs6tnrH60C913OR3B483O7yjZR0Nu407cX7n4WFV3JThrfDS3PZ3jE2A1QZPXMhe3uC81ed/qYPyf22ROHNWZo7TuOX08X6q9p+PVPKdJwFm/uaijNEbM+qzikuyNq4Bb+z0gtH1s4dtayr6622sh1Efn5kg75S19elorZN5iEVZAd3hLr+/+o4DqnVMshrC3WjI1cMQ8ORN2qCTJNgfaxjmMgyP+BryeHEA2uGN94xfB/Y7JPA+fV+duSSOoehlUIyAbuVJWu68OeuU0uyLX76r9h9Xpa0EY76ZQ6iq1qleohdjceWc9pVCTrOOQClWx4NV+2Ekv93MrmJOe2VN0LHaPC53XlV7sSBoUWXyQLZbp1Zu7GjIs8kk+NIXU9jJ1BCqPOC5xhObmUHki70BlLKGs+qdePYR9GUD7RV2ZgYGEtvKOetU379czJYqd/F5/Rc8SYJyjMIGc9edO1nxLh+63OgS09X9jR5EW80S4UN84YvqBxs2enLGBXR2LJQI2FMv4AZmWzv03Lv4/4EQwYNF79/nLEngycCK3oAFAeWtgdpA4EnkMtK1c45tKfBEWK/Dv+pM1drakxDB9DAESpqAetC4zNZXI/bu6O49ujlCRqp+IPdzXDWoTU/0Mq9dI825iP5QjZK9IDGHpXst4ZgRDiTgRl7n8iYtlA/hHX4IOFN1tuCvHiRgL0CG1reAvpq+Bn3+PemNiGh/L1Aq4SVYuFJOqsPqvDUiplYEnxQkcpIl2+Voz54gkacJhDvvDKjdWAvkOJdLLDmM8ZqbT8omehN2BdTV1q0HTysSQZ3L/htrNwI34Mp+6/XFwitGVUyvj+Lmeb3lvfXq7KiG/QlFfUk8kwCoVtmevbIhK7H0UjLz7q2cmox5ycWeS44ytoaLWh9Xhb7UyP49nzsB4eeO8sfqMPCIg7UmA3keCztAcCPQGa6pOznytBgBTRogVwI21WwCA2IRpNrlFy66j3KfMOHwHFzoI73ID/8jRFbWE0gICDbedwH8ExQXXf2vuJjHW7Li6pX7d0mLC31yEgSyMALG24qseEhMiav5IYEx9lOvKATMTWqHNLQfiWNfpAU3G+wnWMM2X1X0rjHLMzm5lz9sw81VZtZGfYyAlxiCuyGt8IdHBxPrNiOo5uZGYWORi0tavsumqoIgAa80knUFEu+9v+QnQV0wcgJSQQpNYFDP168aO0c3KSEhSCxAAZ4UoxRBlPBgCgghhad2m014V0MoZrTm27eeoDjNS4FOpn0HvoxDqg8gGSGRJDvKMN7caxnj1E1RjkwUu/iFWCsTQhC9G4pIrpDkCv40wETjGASykNfku5LPQIbBZuBK5JpLBIfmeGcG2OuMx8bGjjUqtAvI8lZobavmMJGa485Ri0MvWE2fsa54kqtrspzwsaFiNQzlhI+ESLybc2Ju8F0XmN38I6uwrvPDfmF+ddYV40octQTt0ttB/QdITZr0whe5Y6BZO7NNSLz0WNuJdJ81aVKbsI3CKJx0VwIS5GQNQQR+gcgHj0EcgRtZGE+B/S69vzP/AU9/LaqCeS/rzitjjevxh/M63Thn8P0791u33Nks3A13sEPcEDZ7cIJRwZ+/5cbT3r2fZqz7+3f8bKLn3tbBTZEe6UoNXnP9c3oGBshRZLWi0bLobK19kn3ELMSgV9ZrQDbbRXhywYPr2HCABLxCG+P6jXrEo8qb34OCYQERNgTXGExPjNeNN8rnq7uIc0yYja+mRs26kFXzFzCzH4porHJuI10TvsSes+1S2sTo8572ast10etUlg57IAHHWocvTPYdm7HB42w8bcZJY8zuYwS0F9wzlZgQS674lVYc8JOn+8abOsfaOint7aEMzL+/4J2WLBxgmEZyFbg1qrAAUpMmosIgW1QvJLBXTpjG8P9LepTDh3Ahge04yjC+GfwvhTp0fk1cUM+3b5qxpdqxbrplnbeFiQga0p4lkF+eaZNVpra2DUuwVaqtyiT+5mXLKlwqlpaZP+Db8LXBtlYhsVaKYBvE74H0qfKp7AF49Hr12FNqoz4bcfAMqrq5t2TYc/NGD2F9lpOcK/vTkBe+r6MH9oXnNYzuSwx6gF5IGQNV8/U5gBqo8VQhdbgBAQE61uSNZUtF1CF9VgYj0pwEl1hn51iXhOOBjy8OnOByPGHPnhOnsA62dnTFWusQ4OzWa936rZf17zSzxKxZP4mCm833pPeq3hQjpGN2Mlj9AFIqFSUQWT0bvyFcpFCeOzy1+5mEcbkejONCEJwUah+aFGy/HWmfoLCwCo4OvlsED8KS1LZKa7swB6XeZqsIC5XCKdRpM4yUhctcgh9wPlOJom81cVhlkDbPfyqr1C4umSwjJoXk6Lyn6JU4ljZWSfmNp6aPuhukl9Clqj4qm3APmbzEz2+pfT/kskjVHtth0Fdl28UNk4Rxg9zqekOny7dvd8dZ4kZHzAiXO3Id+fIBJzJWZ6h79fLnz1evdsXCilruytu3OiTJZh1dYaUkLHH7xT7wNF7/61GOZt4pi7GJtlaMlbxdK1k7LJlprbDi9EBW7BVIQImeQ7ChuuWHpx4YsVVVeeTmelbP86jKy+P7aALVnrl5nnNUOdU3k7ZQq9gg65wxY4dsvUK7MC3WOpSpaaWwiZ42/+1A+iXWuLvEnWYmvR9DIddlQUF87oYHLcfwXz8TZbdncWfdLms2XMlrMRgZryVs2j+ZlgtNlTe/dLjEJgn45WC6dFnQJtvf7BZIwE6MgPBVhDFEMNbPlxcz5YS13lXxU4kRqlCJ3+0SYw4+r99khV8NWGZ9fIn3a0FoUQ9RBA0xRjASQus3ZhBLggyTItcqZSK35efB0LiE2z5OHNzj3XO7LyaEu73+T7fy7//Ig6lr54s1s7ffIaJ/abAkYM+d4XSqilaWVcRg1tkdVTSRx+vlCajBDw25n0wq/v9APYMRYhIBPFcCxHGny16H2zW/863XAE6Y2fadiCV4dGkDkC0tNCfiJ574LJl6zAuESfWsT0zhxfj4xfaKGLDDNNgJX2j2b9tNQcv8ssLf+Lx2wMTH34tUVgS86thvdImOBDNCMEOOjujRJdt5v6o7br0scLlcJFPu8jNKkC4hGIW3PhXv59PxCXbXJAm7R25kAq4/rUFpBixliL9igpM7wY456w1+t5lJxcEARDn7hzaUPvd2PFofEOk2lKZH9ACeENUqFZDNqodgQQ3OGta6pSxcqPlGu0bit0nNhVQUrL5K+wauWoqbdrgTT4ttpWUF5rycvCufuVP7RTsx2GEgkdzKM21dp1sNkMkp8JnfwrzTgjffZbZmpjH8/mWq9pZeBiP/udtAS7Hww/uhJozq67vqwaONLAeQEPxYDQKCX5EwFq3DtkkV7ats1sU+6jl85xmK66R9TSllAj0pU5VK1iPScVnM5rt4/tu5PiH/0yVmft8k66ey57fum5wHmv24RRdkUVNE4ffpUt/CfD2LmPWamT4oSnlYD2FU91RVwKub6uVqF5E4ZmiS9TxZFQJC0LDNCIlmKA20oU3Qu3U/ipeygTjwlJ8uLs6EukEQZmveoBkwijOKH0hLG0wynHfYMGnwUgfi40pP2us+JBktW9OQl9Yd152aplnVN9AoJIVtlzu3h6WldsZ1erB2HNFo7ioQo4kBR1LTiTn99bkjqFhnfra9tmwYEtDPexVwtOdo59AvJGlAYBg65PTdC+ix9dqWaGQ4S3vpn3P9z18Y2pXbwgjsnr/z9wNYhIXN8DpVwZIurCwtdZjM0PmE5BATybLY5LF2U1j5fkG5Y/RXv0IujmeyE1wVIx8tosjNMNRJ4WShsorQ2+KgtAtV2oTbJomCWMO2qj2j8NU/vtyz8V2y1HcS6MvGd0zao0q4Ho2fepxbYfLHkdAHJonMO+NdOr6+bGayB1l1vDPBXscNgy+Mh/kj210/8xDnUCmkIKXPeb/OfPcDjlwfSTLsMVJih8aKss5jSsOjhnX6K/TChNbDVu5D6ceLDP6Z/jMZNB1sp7kz9g2DPmkkmJno02S2OPTFCyTNNM0YJwmTdHkm8MGP8gA/OY+8cdri168UBu2SW/yU4eFL5CWkW9b98ZNy+JdSNtLaVTXy/Ls7P5ufo1YdNvEt5s97YvuIzCczLMGIW77G86c8eL0cySwvKV/6om5w+88rIZpIedKR2Usy4tUzfRz73PFVKnIvnfX2D0wazC5uKDM3HZNT3NjNacwp0gTHXUK/p3wehhSZ9i0LVuon7m/I9K2KrMio9/Wt9nobySKao8vT06KnjOm/7RL1linXGUPTIgSkfF+dn8a6N0Haj/5Yw8LAHyAc7asE48x9B4y9+eRjtgcG+ADToyCll3e8wIPlnmU8YBye3Q6rR23CE9PC7GGqWT14D0vN7EkwY93Nkfagr9YwMe4GhreulukORpzgc3N0yqzkD9LZcTPltqK3S1QKCZftGwpN64Y40UdaSNDD7Sa5ruQ73SaUrZ2w/EWu9AD3ewYj8wpSRr12D17PA+PG9e2XK4bSfIrifYC3/qj4OmVU1dfEE12OCqtFcWnHrv8UX7YTepS525iJUmuZobl41ztRC1FO7hsBH1weCjXCboxqoCrgNKFGJM1FtP5qGs2cThszBhKwf9VqTmnpToRA1DsxAuKQwLg7rrdcl0W3RLUA+VOfrET3LnR4p/VAy4Daegfk7sKIiADzCXcxlHpg62N3yYPWHEszCxabgz3BOOxdxcwS938i7O+Y8TNLLlUFBL7NkQXA0DZIPXv+7JnmD+xGuiYPDVFCqiDp/Waz9CiMwKqYyapqbW+EBNyx8RAU/vDEOyDhWtwhTjH4bJCykdu5o18z93OeFlbWKfbU02HFq41E32ermNRoAHpYnLKBwQ7/oiGoWQkYVaMbEQ7jW4K83rK+5CkWLQ20+/XR/6oG3QcmS5tkr0yE9VLWRN56WertY4o6VlP7tG3TFsxbUD5+DiTg5zpWDzK0p9Hoz5DAwE0p3pz3Ef6g6ETNrdthpq2ilDOznXtEXy0+2Cn/oP/ycWPHgvAikaHPbtECp77SlHzKUG++VQkf2RsGB4swqjCiNGxY/7OUkJj1jZGwr4+Yw0o12XUQ+dueg/nDhhgB5wz2lzEc9EuNTDpWdNjY/razMW9++eme9dW+X0e9F3p1Ux1fUDX/cmSCrq/HVD/9yOVeqBd0tSSLpOUV8SOPMVHV9U6qQ73e+9ivq5ciK8Y0RKG+HY0d1ugtVs2H/451R+jr/zlxuc9nshMReBqw/8g/eTarEU7o6sd9AfKupUR87pUvnKmXRwGV1HN0ZhjKGYxDdsRt9Ir2pshBPce+VzOmUdm9yOfe7DnLU4Ti2ZNYC3Mwcs2THs6dWeJZdziY8SPHR8bu500BB7hwOQTwCrAPczKP5iY8nDx5BeZ79MDWLf1jxgyG3xhgZ02WW0b7wUL7KIOOkwWTJh9zwpErVDw1z523VNWKblkmAxgB1VwPhBsrm9UokwPV4daRLPyUFBJPU8PhkkqrHDFKpargg7L6Y5ASIlE/ZSSuUkEe8EM/NgS/wL+1rG76N6W6MkcGNP6QqqyUj6qyegcle/p0SkBdvvyZvxpiKR3qCSptWWTkkEnBBpfOCRPWr0979xf7ApOQrf5gRl64dm2yC54PBOaM3B5zQtW0Ab0LpPounaaZkIDv+tE6msHSvlZJ4wBAakEvAanOab6iVa2My7RqnDEaHQChKej7UA7aFqpEP4cS0GshPvqu1lh0CQDEN2jxyviDrgEGglYAwwudC0Kf0bWhXvRfqgj9XnXwseLvnJ6clBo9TyuIFksBwacxgRt8Md8EXVY2lIgWhALQnpQOfQmCj0KJyDrFRUapTGgU+qxWGdoLpDqUB429CnWim+dnoPdoX1eGdhXbg+4C7nV56MFiG51g7+ss0E/+M2BFMHMT+cPqMdoY9IKiBBIpolVJIj4Z0lQj+nEolaOiK4ohlp86xlV0L1QKSSEpejdkg/ooJ2WNTa0Kmx7+VQaNNUT+NlQssyF90iFBB5S4pub8Qyl3DPEIutXxBaPhJifVjR9WLnoKSPVOmkWzI/lfu9LQz0RbhTJfVx0k5YlIykHQNTDGb9r/dA5JIJSPng7J0Vdz6lC1qEQnles6Jqh4fgE6VQeVWJIirFpqKlagwwIaMxXBvxJKZRR/HZZEJ6KNqX86RKOjAkiFomf+F4BaYL/15cUcrv93pkH2tYLgL0ZwGmb+3zPsxvZEEWryL/xHjlEWjfU2wfe4v277OxHgu///tr6NCJL3++H/bjg320+3lBxqC4JmRNh2RJqMdcRoNs7FrpjoiNNmoSNes7WOZJOuR07R58kn5Bao91p1BN3eHVGnzx1Jtw+XV3w7Ggz6dzTqNuv/DsAM3BjUE6wkCIqu7Z/aYDkOEVV4e3/gWAgkbdsflBzY0nan+/iO7xhRWCySr+NZdWgH4an9tvnOkIjbJPwXrZ68avp0dzfgmj5Znm4+Ewgo5LR6T8GnBxaLhuKK/uT9gEYFAULJ/RkSWQC3v9U5uafgvsuRalJBqmdXozOlBvfOBoJNWt88OyKEPTnha/2FLHXiS1jJJ3f7YgOtfGpemYyabNxNuTs0VYDSCHMYLvnXLbOXx8f/Z+ertNqdbu/PPr/SBFGSFVXTDdOyHdfzgzCKkzTLh6PxZDqbL5ar9Wa72z/y/c8rSrKiarphWraTyebyhaJbKleqtXqj2Wp3ur3+YDgaT6az+WK5Wm+2u/3heDpfrrf74/l6f74cnFzcPLx8/AKCQpO7AJGZQK2fCSYCi/PsuViI4ypGTfZ9nT374AvEJntImLeKj2pKdCgUIu4xurG+xHkwh2fc5bnvxoIC8fg0w8cE0XXbJCGqcSFDT+jqaBNNicT20uAEgbpNz8Jym0kYLYdbWk5PZgiE3RacC5mZM/LO0Zjo8CO6ySJrVoUDDcET9ry2EC1K+E6UEZtKE19xBeY5PBXJvLn/baXe0xZdUJOEE0rAnHnfX3/8tJLniFXJKE1GEOuXPdjLKFyiq8TGA8hS2xJnXFuOKkxcNP+CL3X2IDhLpaeQ/Syjaojj6hCuWJw7fojE4JrXZrtqoJBqoDDGykN0CwrxYlwYkqNGQqss88Q5aODYQLSeZdaajClpAbEqtjQNsmEgz1MyymnfX+T91o2E0evu9TCEg86nIMJi/GYgBWzcrwrfVs+qPB2BEHfnVK6jIIn/yvBeRs11l3UZ5XRACQ+sElPg9notE0vxs/k9cpnXoEBGqUSPrDVAi6pxm1+WdNYyCcZfrypVgxbVbK2WeLfbZDkkVFSp0WtUGFt8I3Ot2zR8Bz2rNzk43A1SuA7UK43qXNq5/tG6phCoHkfAKGMh46psvKQKRS6y31Q9k2vau/48byQyKyV39RJ8bBnKHUW1RPDUCF5R9IijhC2bE9TEFpKTEX4nc2EFRXNPnBLM992EKbFoNTI7bfe+TpH3NP5Oc+n1KaHpmj24uQXC6EBWswb1bxKagdcuF+oYAQ1cTSCXFRBJF7KorKJlzdRIpbzkqtb5594GVbB+MUGGDT7hAn/rH+9NcG5d06jznBNGctUqwxXrXkr2L7o3bAoizbSvUSfIivOID5tIPZ6wW1nV8Zfz0hbl2nuW+zZ+zANIbDKvq1yI4w0AAA==') format('woff2'),
url('data:font/woff;base64,d09GRgABAAAAAEYIAAsAAAAAhBgAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAADsAAABUIIslek9TLzIAAAFEAAAARAAAAGA8TknQY21hcAAAAYgAAAO3AAAJWmRNCVNnbHlmAAAFQAAAOjoAAGzYSz7JJmhlYWQAAD98AAAALwAAADYpnBa/aGhlYQAAP6wAAAAcAAAAJAfeBAtobXR4AAA/yAAAABIAAAIoKAAAAGxvY2EAAD/cAAABFgAAARaU1XmKbWF4cAAAQPQAAAAfAAAAIAGgAQJuYW1lAABBFAAAAUAAAAJnEKM8sHBvc3QAAEJUAAADsgAABk1R4DGKeJxjYGRgYOBiMGCwY2BycfMJYeDLSSzJY5BiYGGAAJA8MpsxJzM9kYEDxgPKsYBpDiBmg4gCACY7BUgAeJxjYGFhYJzAwMrAwNTJdIaBgaEfQjO+ZjBi5ACKMrAyM2AFAWmuKQwHnlk8Z2Bu+N/AwMB8h6ERKMyIoogJAGk6DJp4nOXWZY9dVRjF8f/UgeJerLi7lQKVgeLuNnV3d9cpFHcv7l6suLt7XzVpstr0TT9CWc8sEhICn4CZ/CYz9yR33zn72WsdoC3Q2g6xNtBqJQ3+jYYVfrWh5fXWbNryepuGZv+9E1v5lQ7qoq5qVC+t0mqt0Tqt14a1bNwILVe6+UrTP6/861eD37G+O9O5odPf376yHe281tZsw5Zsyxb0YzzNLGIxS1jKYIYwlBlMZyazmM0c5jKP+SxgIcMYzghGchCjGM0YxjKOCUxkEpOZwlSm0Zs+9KU/AxjIILZnB3b0Z9iZTuzCruzG7uzhT7Qne7E3+7Av+7E/B3Cg3/Fg35FDOYzDOYIjOYqjOYZjOY7j6eJrJ9CVEzmJk+lGd3rQk0ZO4VR6cRqncwZnchZncw7nch7ncwEXchEXcwmXchmXcwVXchVXcw1NdGAT3/fN6Mjm/v/bem9a08p3q71vWbv/uJf/p6+O9aPd8r/+WlZzF54b1DU8QahbeJZQ9/BUoR7h+UI9w3caNYZnDvUKTx9qCs8h6h2eSNQnPJuob3hKUb/wvKL+4clFA8IzjAaGpxkNCs81GhyecDQkPOtoaHjq0bDw/KPh4ZOARoTPBBoZPh1oVPicoNHhE4PGhM8OGhs+RWhc+Dyh8UGtOSGoNScGteakoNacHD4vaEpQ608Nav1pQa0/Paj1ZwS1/syg1pwV1Jqzg1pzTlBrzg1qzXlBrTk/qDUXBLWHC4Paw0VB7eHioPZtSVD71hzUvi0Nat+uDScJui6cKWhZOF3Q9eGcQTeEEwfdGM4edFM4hdDN4TxCt4STCd0azih0Wzit0O3h3EJ3hBMM3RnOMnRXONXQ3eF8Q/eEkw7dG848dF84/dD94RxED4QTET0YLXu9PJyE6KGoZtHD4eREj4QzFD0aTlP0WDhX0ePhhEVPhLMWPRlOXfRUOH/R0+EkRs+EMxk9G05n9FxQOfF8tHzOF8LZjV4MKj9eCuc5ejmc7OiVcMajFUFlzKtBZcxrQWXM60FlzBtBZcyb4X5AK8NNgd4KKnveDrcHeifcI+jdcKOg98Ldgt4Ptwz6INw36MNw86CPwh2EPg63Efok3Evo03BDoc/CXYU+D7cW+iLcX+jLcJOhr8Kdhr4Otxv6Jtxz6Ntw46Hvwt2Hvg+3IPoh3Ifox3Azop+CyuOfw22Jfgn3Jvo16slFv4W7FP0e1R76I9yvaFW05P/qqCcjrYl6MtK6qKclrQ83MtoQ9bS0lqD9n2e1Fh0AeJzNfQl4HMWZaFf19Dl991yaS5oZzYwuS5ZG0tjWYfmUARtfYGzAGGPAnIEEk8BCiLkSIMTO84YsG8IVILvhyMHLstmFJCYnwSEbNoshgTjcIYFwJeSFbNS8/6/uGc3IcoDs977viXF3dXVVddVf/11/FVyIgz/+C/QJroUrccdwZ3AcyYvS0GApL0btSGxgeIxkSWVgnAz2Ej7fSwbHyUCWRAxCCnmDRLHE0ODwCBmIZYgoiYW8JEoGjcfiscpAdbiKdYeHbKjswttSuTQMmcP4JiaJ9PHyirSbdOGXXlGubq7Cr7SwVFq4Ei/exHGFkTy8KyWPy/UVW91MzsnmUkVNUVI9q9zwsm7eCutuebGeHu0fV8RINBHR57ttBRoSqVtoe0l3XX3qLsNxDLmtsPiDV35wsXd0//pt6/vZhdxQGClgkVSpL59TQiQkWEZlIptv6SBih6K5OrHKS8renpIopLKJflULUUqVtnQRQSZy3Du/5b/Lx7gol+D6uCq3kPsgwK4Sz5KB6jgp870ADl7MkuGFNF4g42QIYNBNfKgCuDCjVK4MxCJiN4kXhliqWOojvbTcD7eSQWKtRCz30uogNgUtAVAlgyBgF9K546Q6RFbRjpBliZoq3iAkWoQbBAWuHcfM/xD9pRNpG267Ewd/JyQir1wTa2uLXQN/cPceIOyPJ/Q4NWnzaiId61hYIE7SJaT36GokKYcFWbVUeatEeUJe3iSrvNCikQ1hWQ57d2otqqJt/OZHvWvsnpa2oTZX9+7S3dbhtpaeG1p72u48o7WndQnl4T/4I0fIfDQpR4igDh3RqbvE0eefMmkIMKaUaghLRF6mGkcBnn/kb+bDXIFbwHFCvo9IYi9dSMq9ALuFdBygQbNUNGH8BukjA62kXIK3JSyHmSapDlfoy7L01FOya0ik+14pJBjqHz8gxBPCOX9UDFEQ7+2ikhV+RZa+luO1T//QkjdtlO0ffFrj8/dKssLv2BGiqq28dY9kOxpp/5Uqy+qv2olmO9I9bym2Ru4Pbf6+Hb42w5tf/7pFM9eG7e9vDvm48Hv+Qt7gerjN3NmAB5dyVwIuxCTovEFaaawSjw0sREwYhqk0SQlmFYgkkoU+w7QSsRcGUsWJHSelPh7GXsibJG9SkZHRQhKLZ+kIwGGwJJEco6dSIeejkluJFoQgXQne8YBO9E2RRORUhJcPD1EiCbooExJaLAswFyIR9MNOmSebsmIqnUcMqd4jnUcMqlBBNRVL5oUjeJh1VRKIRogIdcKIDFhr+UlVSXciuvcbwiHtvIPXOXv30l0spZPac38snVB5O6keF6I8z4cIDW1Vk2YoLMfjw0f3EaKYtqEQkp/o8NgVymsqQPo4KBsigB1bw0lJNKD40FFziYuYeUPQPvsq4fbuDb7Pct/h9iJdUsbPdtF9XITr4jg3x4gR6SkvRloJACoSA3AxOmolwLwG+xCiAM/r6H5R1MICH7pLSTnKjqmPQNP0uamuplx6Ffvg07yQ0EThTtVNKTugc9cheYhQxk2q+Mxw4mP8i/xOzuFauUFuKbee2wo4kQMWOlx1gYnG4m4WsKPA54FNsKkr8zBz8H4MmCxMN7DZDDJaPi/CHXkG8GLoKKlz4WjEoDxw4Sxl7IXSA97SeDlGtF9qpZ5S+IBGYh3xX1L6SwJUfD+Q4gHyL9d3TXbGu+e3Xt852dW1/Dut3d2t12e7u7Pk3vEzxsfP+Ojp44WJo3vnrCw4E8ceNRDvqpLz4x29EXKSG4263k2R3o44NOXdSEOAVtvoX9Z0Le+6vnVedwLv8I9c3JO9PtvDLt4VrMHx0xf2HrWoQC6uHLVpwimsnJOtdsX9uQIYPcJfyoWBcjiYltLgMAACGWG+DLICcHl4IAaYnWX8MngCwSGJ/A1/eTiaTkf5Ybh6q7euXzu3P9ORWX7BtR9ZnulMk/6+tUfthES6M/MTGM3q48hXI5lMxFuz6OxF8Ks9Hbd65ZzegJ8D3mymvwROvhrm6hjuOG4L0vBweWi4JBVKYjyaq6fEWLVi11NYJldPYRmbFOyGbLtenR+qRO1oYUgI7vy47hDgiFfBzftpkIBbqTSdT+Y25HsD/qu5tUJY6yMrV5I/rFxJE7M3cOiG4U1TQ37qzJUrvY0r8Y9OrFzJcb6OsIO+DJIuB7i8nOOKhV42HzhbgJxiuWRQKRITyxXE3KEc4ijMH6BpZQB4l4+mUgSS4zy+If/7yUShkCD/lsjHjfKRC/Mk5Lz4DTJx1iLdW0W+OHLqUplOfGBRS8uCY+foS7aPzl3XR6hYOXLjyn45t6TbfYDkWeV84nemw8vuwIoOLRkdmzhr4odTxw+fsMCyJz4wIegrP/CRrfPJLXPXztW0nsky6V6xac18BcfDszFtoddzJpflBmBEgH21EQHGib6krnFUIDqQzMCBgWcAI88iFxf59NRD6XI5TefBdepuygt0HjA76j0Zd25QeSupfJ7nP6+CvJI/75xWTpM7sbS3IV0mb0KpDQJPyZ2U9141LpZbgFFfTOnFQsiJyxeZnMz6dyF9A1IZ0MxGuTXAP07jPgI9RY0B9QViYwp0iKo92M24Q2U4JhXilWgcdAspGgEZAXnlwrR0qPI55CbwPpi6CpQk0YI/9mq8kMdBA2PBhkm+jGOmsTgBkiTnO3o2C+jxZCnFj03wJHSq7kymSl+8crxzzOnhvdf5zeNjulNKEbOlSCe811PFMUqIRehY0bsOSuZbxqogWB53tDfGyQFNmVonCiEN9Bf6ZcXZrzljDimyWjyxePgYKV0BTV+pO3+cx/Ovjzu69wY2Qk8pJUNjiwjwsxUrkiWvOFZMEQs+ORby3uDJeujj2NT9Cv2yaNlaSBCn1iktDoJTYDBdSx/lOrn53CJuLdA4YDJyHWSugVSVbGS1TC1rxghpJoZEI/EcAL0K+cCY67RQzA0F4pm3tuuOo2/Hrk49AyKVPxWfT02VSinamiyVvoDDBV3jKM0pev+Jw2717oY0jAfyvW+TGCXe64R+w2lxfFAimOHBL1FMYf2rEOLYLoKH9L+O33n9TvwMFIAPjq3A73M1Ok7Q3wIV93OLuSN9rC/bOH6k1RjqViWmtGQIGyWo+c2qBYgrGCxiBdAAoBhSPkFFBpUT+hggd4mU052Hf/islCjHE6K9fOVcshQwvuQtQNpAhOfpY7qTKQhdowNOPOnERE2SNFHRtDYYySmpcvfollRlONwSlrVCzhkrd5dT3g0wtLuAaG5gjZwCcHjO0VV5YLRHzM2fZ9q687+IGNbDIiG6rdfo+yz6GaDvVq54KPqeHpdQrArFOB+deqp9YKCdFtorA1PfQKjSAoPtb72HkmAJdSavrhTICVjG+0KhQn4Gr76gOTCHJ+jO83vnf/Xr8/1v05foafDtHDcXpEi5NAhcA3TWWAT4Rl4aBw22hCxEYvJhoFpEhU+sy3h6W0WS0pIrDeItUpR4YWHIkl6UCNGUhbJMum5XpTZRlB9RDYO8Nggl05JUkSJwmydZoYUCLz0tKQsVjUhDUk40DFVTDeyWxvr2F3oj9M3i0lwH8PMhbhnw9HXcCWD9nXkwpAp8jUSAKKRDpAvN1BF7j7XoE95rZjRqEtuMRMxFuyVZlnZLkizOlroqKGuZURLFwvAHbxVxttRFUPAWLO6dCMUPl3UZfhuabidDkZuDIhFyGGZqyoaGmy4HPIPQCwBeKYBXH5vPQN+u5mKAPL1EKoAoB50bhHolSnLRylAvqenn1cpQgafPeTvDDlgQOzWH2Bs2jmzaNLLRu5SclCW25t0EFkY4mzXpPCsMDxYQukZOClsvrVtXhR8Jp1LAJTXv38I2SZFjAzqu0ith7g7jTuW2Q49AuoKxANojHWLkPABYlaUZki9IeUQ0MCOGFxIhywOOREuSGAf9E8x4sNWBywHFA/MfJ3FUhLsJM/4zYIOIqHVGfSdAZYj2OwlR4JWXjVTc6mrfXnCu0zMJsy/zuumGClTXVJ3PkSXhmCPzpG9u/+bUgB2JxBy3b96A7Ubjtjv3dFkLKwvCdniBrGnygrClLSB/7/S0xCtx1c26RIGvh50WQyaOfYHiavLFYCi4KdD9eVPVM9CE31a90X8Im9qIpIXlEWyLtU58XY6+QW9itN8GM7aSWwUwKqFBjlo/KODDYBIAACQejcleghp5XKr4CF9j/PHZAcGsBYl822jhj+MN/TUjEcL7C6+lM/Jx0kDqzVRGPlYZSF/yx3RnZ+atTGfnnaqpbpRVVT4GEsdIqiptoDtChundDXUX8kDCR0HipIVyf8q7G1oZhwQ5Op2Whjoz3q3QQIZsyXS+tRFrbsQmZAUTRpgE9s5e6rGxcp0zZNZMWqZrvY54Ph8nT8CVtHojiVwuQb4PV8j7CT54A/H8T+HhASwG5kS+xku307fApiqBbsyBdl5kLK04PBAX4sjUBLAOmZFbHMZ3eZYTFAPrhFnuYrxWpM/XK8AyZlUpl4p4zwqRiECykeEIyWLSezbifYtkQ7wIFmGW571nWdJ7liddteJnibalElk6A9SK1hDFkq2UniErRLUc8Wy/mejPnYf4yIII/5BTTxD1ByFKQz8ICT8A65T/YchrD96tFMA0t83Q4aHQD3lK4RUkTceQqLgyqDxtL2yhv+JiYLuMciu4jaCdccRXBUYCHxn6e1AlEOpKxlhgumEucsKgNFMc+Dxc4QHyCsWD3s0wAo/UnFL6XtmQ4Xcv5R1SuRfFECRl0zLk0huPobL5WKpcfl0QHhMEsg3TKcx9g4lgJkjHoUa6JBuWKfMUGtgFugUkgmbTpd1+E1iNZLCZx4RJvxHMJ+mgHbjU9atRgEkraFgVbgKpzsfAYPx1T2Hg90I5XBfCRdRFmYfM9cfuj7zQ+EDv9T6fKneiRD63lN6fKp+DyY6ydzEM5mQKqvcBSvdTeh9kJx3nBv+WA937KzCyldjvlZDw1oKa8oa3lsHgK2MrmdYecbT9CMKmC9dgK/yKK8ColvhjqveprkIg2/DHx/SLd9E3+LR3Y6rMwA1mNHz/TziSP0EPvYe857GjJA2Q937E+pjGKwzDL8SyoBLUBtXoRpybcoqkmXXxPEzLNhjN87V6jbjqgryfx3D1VF/znR6FL5CrLKthKAh0911wcXZc9RG5VKDtgEc+WgFML9ODBOKdc8IsOOndOI25YFI9BlbSVwHTA+SGhnbVEizXe64RRafxcSaaAuo2wyICkDgcuNk27uwa3c4YNx9MYd0cqM9gDWwGKftjb9DuypUq8LeSWXtVb65cx296L0LhDJzLM9Nld653NPaUPZ/Bpu0uGF/SgRa26Y7y5ciwO+C6X5HXzb+D5/tD/B2t+5H4dwH6fPd6nu6iPPmSo+8O8GG37ngXAPa8kS5DGwBPE5vchY3vBoJ2tJM15SsutDgc+bIydkeIH+D5L74KXw764FMDV7cXEFZt3FLuKO7kaZypg6Q+0QGBkkZOV6rxv2ZAHGRIzSAN8m+PTcMDWQ6Oi6yYhs9jwVCx2J1ALKUSEAtcvYeaiOUxRl/ItfyqgCAnM0RkOFLLY+UeC1pIY2sz6ceXsZP0h9wc7mgm/Ur+f8PVARwTLnaAeMtHopBYSMbRUe/77miBFNDTyP6rMJhAvS5SALWLOSVBJxuGnHyBviBJ1354x2ErbWFuWZZ2Jtr5UFI1o2nau5RSW5sbHx5pyRmpdtcbEgyHWksXn3bmJaIZocsnCCWuVYmtHOJ1M54mpFUgZB5xVh2+4yPXlifEXGK0GpurGTxZ2ktpJmqGkyG+veXSSHvKomtp3LzkzNOXLLOi5qWUCK35qGIOrRISAzpYmxPLp/FglL7MdIwesJ19rg6SrFrJ0ii669hSEJvBQdB9y3nfQowy92XdQUno256RKs87cd5++Ff2Lu1Y0gFAfpPykDhz6JiOyOHbt470re7Lz0vqcxcvLGYrwNjmb5kH49kyH2apvLQDp6VjafkfFmzdfkSk45ghKE0ypfElc/XkvHxrJVvn1xsAb6NcHjR2mLE+INVeOo4rCFIc3a6kZFDmVYReoW+nNE6RfkW+qCm3zP/UVSe1lrd/8tqze+O9N0u8ZHqfGT15hIyc/OFTRhacTObrysUKsVuUjyrOqHIzFDr72k9uL7eedNWn5t8iOo5Kj6+V/cjJI1N7oFyLTaBOssEPsYU+A/DMAE6NgX7KVZljmDBVSSKi4D8CVUXgiTS/nF221Onnv1QTFF16vAhGQygkTt2hEFmxYBjkGKXFkb07Ve/h4BmLCILofUmhq2d3ZnWEbUek5wi+p2bq71VJdRyRnKTYLap3s0qy8CiRrRK+twXvJtV7NmiEecfoTp5OPQQ8HFurj70Fxt7CdISl3JqZXgimHVVmZw2oI/QSxDZ3ph+ijmYNboje1Ses6e1Ml8qNzgfvgQPZymgle06TE0IKi7yq67Jec0L0rentXdPn+x7K5O5G38NYd3YwCz/vopk+CEk3FF7QJEWv000LfR7G2sENwFjrtvVsIz3kQAE7B1G8VIehAkgYNr5y8/CEmaNboiuTitOiDFzAcG+XjCrCyalyvz+ufhgXaFLkzpD3eTYsUJ7G+4F+spVW76PKCiVpywMXytDALnV6XSVGP8tpMBqgqNJgHTtz+TLroe8mVEBkkVcB1RUPEs/oeHOSmOWcEdyTmDddCKliWsdqAYodaYZUzVcZQKrQhO7djHzLje6GmmM25PtcQ4jRP22vo/QuXRmj5PhdqFKgXET1cFuq/PdY5RcAF9C+mK/pRsGXAMoYId5zIDkc349IWF/X0ZM52+ctpUF0DKNbmBHrP+vKk7KTUL9PzlcTQG/nK59XnmSzADmMb0BWHT/G6P3AVfsBPyY4bg7ab64/DhSvUT4SFwLxGpVAFUOsr4+U4T2pcQqwZgE3PI8mCrSQeMeCv3dCNES8kB23SEHRrMs10wrvclPETnu/lw2RF0lKjplE8p6XltJCC/EShXRK8HC5TngnjD6HlgK52QpfYcfNVORTmnmL91vFtAXSIlkx2XtJDubtVPoCF2djQOnYi94tNPEGh6vF4SxFI5tvJVngX2B4l0uSkBfjDJ8RYEW6TpacpLCR8C/GUukYrbidWUn5kdh+/kZCBJ6QfYTQ0NR3eSpQ+sLxwMIU75pWGmpxXuTJRrF9TkF8WJGyne7UI7E06XwOqlCB0Plg39FHZEI2Hs9gvibgPafSA9y53FPcL7lXuLfqGg3T2EQ2l75IZrpgoLVATvBiwPf/T2szop9RU/7gBnKeaTlQ38+IBA3DjWmMTDVgShOawKz6oL+4UK3U1KZeOuxnoyUNoouUhwaZtmXQkp+Jq5koyMCIDLRx38aO4KomKiFFqWmdsIxODHRd0PYV6Q6eD/FGZJ476Lomj6EAoThifxQ0B8qbkchgpBoxoQzfkYbSMAsh3nTnRSoRyKUwGxEsHQsRwkMzkX5oiZUm5c+6CfEwgSRKHaYZClUoNUzJzEfjaGVHonlLNkxKB4lALLOzlCDCYSKJlztNA+Z2kFLTkK18JIaFY7XCFSJAfhdZ95vSRKk0sXKiFO2opNt6eyd6ewvldBw6AV+JRCrQPxM5WaiEfQbMh4EEI6QwQOQC6UiIzhggiAkGDz6E8BiqlRZT5X+Uc9G4KIoR1hGerwBWmWZHOQ6DnoSK8XKHBf0mQ4SwfgMxiqFoHsZrUDrACuMQeX6FX9g0IQ8gYprSujwbCAwoXemI/gKHMtFb4yvkZi7MfIz11VC+MvU55orG5QOyFU1a5Jk+T+6jj3IpbojxZMASpof7az1DdSMlV2U0yaRIsIpaReYN+EIiyRLF5QWB/Az+Yaor5c15RXPIhcipV8GnNiHNfVKZ2568BrvxceCLH8fENakC+Wdiaxfi+1VkG3OU79mIYucavdF+KHDLuQ2z2pzDB5tdZIbdVDfNAqsSACK8q3H9WGBbN6v6Xqym8NdeMtOAVA5tRMxqdZCTA+uy4S1aKX/VjOAkBo9h+iyncxaX5XJcEXSgOT5U0AMJlGqjnWgTtiCHK28urqmGSSVaGAr+kR89ZTnCU3wkZjrf2kNOf0p3iBFzQ08JziN79rQ++OCnP33iiW1Jk14WDofs8NQlujNO7vLigD6Xhe2Qpk5dYiYxZ+/4fWP3jdd9WefSvYB3KZBF6OWo+hK4hoHlwrQpHPSxIEF/4gfbuAV+7dQJDFu/ANetD2LyQRC1X7788psffBBTGuZ95fLLF/kidaejke9gtjeuOWPkiu88/fQ7jvYs5sBl7HYWJ/AnfpBXAcsvAhUSvdyMZQPP5OOgSGG42RDzYCNvHWbG1zBIFwpdBUurWEc24KmIH7i8FROZztlLxAaXb/CEb4b9tOFLMjDi6B1vZYY6YqFxTVZa2ue4RkurLYim7vbPSdlOW5ckOYWUoVorvI9affm3kp0KMBpXA4pySdi1HI3XHM01WYyVYoY11xUcKZEQZTnWMQSKqLDJKpfbIkT5sdUaUzE6y8lplhzpapEFGprblgDOFU7kHO/qqNPZ/3Qk2Z6fm0mEBJFcoOrUUO7WHFsnMUXnDdX7DUKdnKsYVFc9ZvuTrBQmquS9rFqiKLeokp7SautB/F30DkjFuQRXAik+xq0AO/dE7iyA9tVomZR7mQsXGAkGzqAcB4EUR0GPgobppGi+YFKUmCYO9u44KGUld/bsQlWcNT9YZWdi0SDVpi/8IBxu7dWT1WXDkdi8vBE2FKO1zRFaRtaosirIV0ot0ZB0pXJHz7gwb8NSvb8rrJotsqpZxahsat/uXhgKssNmQgmzbCus/7h7oQj5Rn+XivmqbhUjkhX2njHU48WQqDuWcLxM3fNkKSyJJ4gtMUnarG7lxd6JkSLtWryo4x9lJZc11HQ+5mREqSX8zXDISKrfNL42smGxMnT0pEKvd9IZOSy3tYcl70P13H90MmlFldqKqvxxArnqQWUfDX9AdKwwL0sfUFtMEEmJ8O1hSW8J327UeP+x9Ocwa12B1lXmwYqNCxVUC0yKoM0CvgNVLCSVcVIuAt5HyW9EwU7Jf1bkTKdLyzQSkXPx75aFuNsGH+qhuvIE6Gvi1C9AcewCFDRpp9uZkeQ/q11zcnz5exnbWBwiQujnik57iB56G5QBUrcPaj7Sv8lD+h49ou/VC1qzNc+lXwW+Fod+MbuiUa5KjTK2kdsdIr+Js+nvM00/5Mvtq3yu573m36/yc+ExkOo1OXEu/VrQ77nMQ3B8M0cuNtg7uYa0kJ8OmxILjQ9uE3GxQLSFpLY00zQ0T/g6pvFCnqknvdt9b7ru384zlZ0CL+qWJeyUecf7g2zKVLhUADtYoMJOdY0/oPv8m/+7ztEoZXDxkL1Pp8lW7RbRNlVelG4BZFcsR7pFAoPctMVbw40w+WoDTA7nNjbPp3AImJBDwqSAIaYBgykwNxBG3cYwwOx9A0QPO7y8k0Xy7FRMU7lUopEkZPBhuTb3TcDwPgOtU4TDlMe+VE8TI6ncygKIbtW0W5Wkxau3qi2yyL1PnI6/h/ymcd7j3cRiGU6C62feQ/4MnL56ticuiGWaxuc+bpQ7DOZu+wyMPgQFNqbd94Hdh0Luj3v7mEAcYjrH7On/akZ1Q90pUFGzTR/V32IzLViWLvLCTqUZ05tvU++8B5SHKTbMFrWG8bdo73Oe30u6mXd5C9lQH5zJr7ybWf7Wv867DjHPfzNuCodIN/X51YY+/1fjfN7b0Gky+L57XeMtJ9H7mF6e49q5Dq4niPNgUiwuoEgt5op8vhyEeqEjVhCr0TmomleDf/wi1LZrqvfUHlCyj25VZb1B9RaSkHnZ+PiFY2MXjI+T6x29rs2P75l6UVSsuj5Pn6qp8w10f1ugo/ehlG2C7UEa+hALwSnb46RRa2/Wzr+JSbzctXPnzQ/qNiG27mvnl9XszJ0OxldDsXfgOvY972KoKzL8+DM8k4en6furB9M3OcTMHgpLK+/KqRlBS03E/j8lbz0gZ9sAjY+x7p0iCDbbF2wzeHfz7a9ycEmiYQsFGNFuxUAFXpKAjZv1udzbOJfvZm3x79PSenc7y1vYZGXVcKxAXwdbIM3iZgaZV6GByc4IdcROkNxB4Y85ygWM8x2GOQx/Xv3e98kpiDMB/nhh8rA3bMLTbQG3cckeHxnxMr7To46+NxjT+GV1f+m59HsMz8pcdzPUmjS12SB4KO3NY1/By1euuGLUn1h6eCCkq9D9FYw1fgPRXWugxb2HokUyy9eFd5s/79TGOSPPNU4nvcyfwqlvwxw+6DNwNofPOPoz+AiX8dum15YmDjmHMQammfM10+XCOpfT8ZPE2YXfCr7rrQW8uZh8ofZR5ye33dY8hbv8TuM4xi9H6Vcbx9jl0+sI/fRRLgqclvmswszBiatbAxhpjHZL40xaqhn6/e+FREIRiBUyHTNELEHRxNO8exhurYfrXFWm7VNPaUo4rtFtGGk1daOWEOi+OpPnOe6db/Kn04fguwV/TfAQX2ZO00DbeC/9OMu72w+XwShe0I7OYmL+M3DtqPVKTTT2iv+xgvE2iFwP1/vn4/YyNm8tgVeokfJyjQ/FWaaQL/okN/Ul/04e8Fj4KkNe70dE8/7QNFGN6TcDQoPL2BWHwKFqYwdmo/nmKBGDIA79SkMUcuhQTXZrNRT6Tg2DiP0ft99+EBfwkQZQ6DKPa+IC/nrDifR5LglyuodxgLKIvs3qtBfe9OOLCIs2K0tivBpnMRkSPeC9oCupyI8iEXJuZDjyI9d9ldDNT0P7U2/tIzw5/dHTKb3u0Sd5/kchPqMQ92GMRzs3EtnnVt3fUboZKcL+ESGn/fR0nv/cf/ycD+3j6+ua9Gl6PcAsAT3r58br0WA1GDWzp5px0hTsxDdBeaEPPnK+dwmjwMvgenadWR3F6NN5xJ9vqjr6Giy1RnfWBCam6d/JrdOvvC3QzptMChgY3eTj3dX0NUaPvbj37t1psqnL1Yax0H9RLP4PQCRxVSQmEInFH0yst/uj2sTEMV6cRjo5idHJTQ3US2S/GF5Ora3C+XiQoA9wNpdFDwi6FmoLMRjTKTXbCo2kTD6kO8ouJanswlW6Cy5QLvVB+IpnsE6+iYrklWzpU93F1u2gjLcX3vyEAW5Ad+j8oCMk8Hss5lzmhQk2TCi1tVGQhFBVDLHVc9JFutia515lr0KWiCZbn/d+Ruagy9z7plLjj2vpMzCukt9ifaVVwfXVXMnP8WMBFLYGRF0Na0OTbHGMtUcsyHsA81gYgMA+g6EMOYVMwNjhguuw+739CoI4yBMFATuK2ZJjhwM405/Se5nMLTZL3Cb+WPCjaP2YWrrGe4ehLEFE9d5hcCWQ85KgG/REGgUleSu1A8uJ5gNj6QAf1WheM0NRfepA2KjFctBTpue52LAcnqXMbG+Y5kargqzSYZYBsBcGS+CK5s/zyx7bLkHegOtXIRtgBhOMa4RQXCM/YfJ1QHPODObYx7U2+gTAoMwta5b1uXqoi4ghMb0E40oY++F7KVuBiUayUKLXX7atZCnGxJCawojM+c15x3fHVp996jh8rHPZikEzM4bMXB84qh9zlq4YquX0r+3rW1tTzMe3n7062rV5HsK5OJ42B1cs7USh8h+k/+gBPzNjDB7GMunA+q3rB+pr12U6nzMBli56cgs55oF1YwM0OyXzSkTzRC2i8PKU1v4YySvxqKZF44p3QK/Vpw/SX/lr3zOxk956MCbOhnCBjDkf+KVdtxiCuV1I/DiHuG8PDOIu38E6b6822pCHlJDkE7pyngI/nPjNm1XnBd1RN29GbDhPVc9TTvU6GAo8AdfNum2j4JxE7LDtV6FWUjkPQx+gAkLav/vZynk+Urwd8Am9gWewdA1ngac+GlhDNY5KgyCe2VgqOZiLUsOxVSIQ4xB8lKh1DhroP4rGy6YrzaIBkQ8EuAxwf+fP/LG8AvwqAxp0FfFZyLNFDhZFgEEcEvAUXqotJZd9v9iAv94cl9hiNut2nK0GYBAVrkmTn0VL5isRw4iQsNPvkB7b9t4yy9EpWX5ZjkreObb2cpjE2rSXlZASOfGAO+weAA5GQ6rU3S0TO5PL2EpXyBQs8+XIMIhdFRrYDy1BKxY9xYM2XpEk72PaK+G2uPqKnIjpDxxwoQ3bPupwI5+27XTeOFyswX+U4VZmmmc04lUjF2vymBIQQ41sH9cGGTExtjB1vy9zf9YkPpIsbHomUjDZ2gTr+e8P0u77gu65ViN097wbQE16MgOoLNcBqsRjuvfHJkjO4BfE37Ec7GEenoVf0G7vQI1hkLxe0yVfD/T9AW6MO/a9aBi4xod6eGCQ4MqTWFsvjgdLdd24oYM1Mk7ilQF/8ZSuZrQjxqIq36SBnNVIOScMda3o6prs/prudE1uKVer5aFyNas52YFsLL9AD8UTWihy7HC8d3WvG9CWKirR8CyU9VBxYuVE0dHPKk0Un5gz0dvbtupJ+ExXS1eCFls1TYlplRHSubzL26/XfWQJ+hbnMC1xDPkeHgAwPFN5qYUV1Rbqy9NoClR4CLuXfApj/6RGDnaq3sDMgIH5Tg/i/G4m56ppPk+SsO2KDdxT8W5QPlRLIwdVCNDDE6xeh26fiVwTRMw9yEWTdk2HWQ06jOvrMCAjlOmdpCxiDDFIYcgeZJHfYdzYHO9nwZ5QkCAoSbzHFRwQvmASOsjOYSQZaFO1+MW9MGC4hG1HYkoWhjkGeYGOSz16FadyEdAisE85OzfMtmiUi7kYiwKVchXIZOK5WMHdjOUC0Mgd5PiOFZ2dKzq8Z0hroisBP++ZJ72XSKK8qFRa5HlPFvr6Ck9eQMqkvGzt8hIB/Ozs64wRyOhcfOSSjlEysGyAzsaTfMnGyP2vSzbark9rKMibLkMVNFBHT/C16Z8BQC64AMPNGGdSZudINfn9b/SfGD0LuJbrr3tLghghRzeJe3KST97kzzXy5ur67kSg7yossLbOz0R+QmcyPog9rUv+vf7coh5s1uYW9fjm/hRxpZ3t98fIsUF6VxM3ITfNZDcH6SMM02qxiIhVWwKsQrydgTuBJu4jyXSsSgSs7wVAl0Gc9yA7rwYDuCPs3AE830aM4DMeYjOM8dwlPBcHoDg9lW60Srkt61b3zZ3bt3rdt2qJLauXLCrD36IlN9USn5YMRbZs6THDeEyOfizXVJ4l6M6mCizhDciGQtKKIQu71DZ1l0DonUc3jMHh8sBbVh0k+ZB9zx47Mx06E2BhQBSBWuLTCrkRg0rhh7ygv18KSRb58Oxhwz95h2NSk4uWovDrQhzsKi0plZY8hfWVFciS5g6IrqPef8h4Ye9CtF4j7V3tERaY1L5o5aL2Gn/ZSr8DMzUezBNIAbaDkYXas03MPCjivB8TAlKCLQ9RDPKu+st9MJqn1q9Y3tUjldqXLP3iEYfNHVCp1RIl8sS2D5+1puAs3n7+mWWlxaXKnIt+LopfA+VKMmz5ulG0boVJ3lrWWV62/IuHT/b2Gvn8osXrtShv6Qu2jqldR3/wvBPnS3N6VKBYtVIlE3QSFH1LpaHRz4KVGw/fq2BQLZ4R8jj/Ub4T7Ios18ENcYu41TPPwSjVJjDOUAsYVuDUiMSnTSHkGHW9LIs6WmRac+A3Tq3BXa70q3D1LnEL+uPp9B+sORaxLOv3RqEgudKv//RrSSIXmurj4Vgm/LgaXf+w3e88LIgyeVwWOsqSmcwmLbnMGx3RbBR+nzCMx1OroRnLe93qhWaM1ZL0IrTiileE94ezUXa5c59t7xMNYqxaomeTJjSiLxFn0Nowt/j90VoDZ2xkme+R4Fb7NuBl3rOMhWbh+l6Jrj8or2Pd3dPrR7XY5V8D3eHOehhNLx0c53FrhD+OWmg6DkCCAZSDuMw4boHmll960vDQtks/edlJw6zTG/csyV98zxe24pdXaY4AaGcogq13Dp102Scv3TZEhrftXL7F7+bW2+6+OL9kz8Yjly4qdfzc1n+sAD8x5Ec0tzGmGuE89H6g7L5/wE78DRDdO8P/6cdCV7hB3GX3brHQ/kbCQIoHzsc4GfaVal8mHToa2vu1Zl3u+20/5SatDHHCluy9IBhWmBdEkpQPHQ/9khW+AliKaUgk5ewKWzeTDmLHZe8lUeDDlhkiLTJX91P+ipsDfHgti/Ersw2h9ZUBDGgfZlwLY3ejMYnpsD6Ns93aw0EUcnW47B8dhkerQcKGonaBXvTZhSO8pbLoLrik9Ggo4sqjJTE70Er55em+FL/A3PzoZ0uj6nwqSJq9XXeISEkmKtjJUCSqDuVSCx5auzYXVTSYt7uQXwumNnJkcS7JDGSLS1J9aU17af5h433Fl9SIrEX0RYsjmah11EhryfuPBCFn/417I8vvvjfy+VokEIvD/BqO8Wu4TRDjfPxw/ZJ3aS0CiAVq+mVq4ZZ+UNDz6fL+copsYzFBN6ZL5E4M669Va6Tdev9razc117YffVrbzR/Ek7zbBrbrvlYLV2KD8KNAsYPk7zDGqZRmXWocABmvxS5NjwOroRv3ORxwuhQEOd3VNAS//9fSm9i6AWgtVZF5ZLK0vjEDpCLbmBEtsLP38L8S0Hy8PA4yMz4cj/lcClBLwu2G5DUlblHZcxXyLOhyNgpq8jvFJnPu5Y2WtrirEhLNhMOkQgw9lSsk46KsWQ5YTC5xoeirMrXjtQ0eqChAEqT4l/vS8UI6EjdsM6oajmC3ai6hsVirbTuWY8YMuYlmjuTW+XGxTLaXC9Hpbflsyx27guCLsl3WMcmgZSSmcomdfTDONvVDBcmusP15WaCxIhLNMrE0KruRUFRPMaqBi2rxIws/O7LZXMADzSwHwGYrmUiGUJE4xqm2BixyvjJa+uz4glRuKByJ8klb8D4HdDO3eOQCzSQCY3t36Y6mRA+b/5KmpfvSoG/1Z8bS0UWL9YgmRdVfF/sS3k9KraPr7Oj+Rrp5Gvhdx8ydQcPByTzDjbteajoaO16mm22tY2eFFaI+kuKumNrGl3OAqR6Af+egUvZPTCWb+hZdzNNzcHO4wl5RPufvEu1Ewu/0r0AmJuDYVd79uPdl2RiU6gRVExTNTrbpuhN3htb2ed8HNkCZnW12lE839Y2fwdJAbpYdxk2WDd8chFaZXtZnbu23z8RvnulTs3fCmQE5YW7gst+gWFJI3BOc9LNHuVJX9qABaVuQierpbfWdx9q9uEu4YR/xJKinGebQf05zvNfw8Lk9gfG5R4FmfLf5HsmxVa5OZ+PvSmfF/3d0JumWndD/Kp11zkpm8WirY7mmY8V0uRavcSLTC7q5hdx67kTubO5i7pMc587Y3st2rOTqEfgNPhl2AOj07AbnuRQPwgLD92rV1NRisEzj7z1gD7XZLzQEdUTEvbpTTu/G+d9NeWLT83DL9C4fF3cDijpecRfb4SywQuRLu4KybOO0oin70N28T3GnrgJg70OPwD6F/L0GacFmM/uw8pyu7BMFIQzYAqXJa8AMgk3TuzXkDP5ZCgr2w/YGymn/EwJzn2Cp2qbqMGsfLy7YKco+2UnAA7kF05K/9LNPgU8xm1jCsoENk2B7VNuZxkgaJIpB2PmXVbZdIxA+1WEiydgZ3NKmGJb0299Kb8jSPjxJjPL7pBwAhh7P7KjboVzo4x8P/Th0Hi2hqJj6xQ6+Nu9b6TPsbMSmeS/Ouv992gnXQNSzoMj0EQGNlO42znvuvc472aXXILsrXXLm7pJNGX67/B3/v0Ss8DfuQcYdtenCnFYdAd+C8z51XsOU/zOmAz/RPuX/+FPuT4kzyiaZ6QrwRfIJGTRtufb1VBnsT7wxFsLes2K1Ot4JtW+wRYLg4+RfMF3/RMOnG/RcPGewDSyfw7kjfG9owAbjpWluiJaeWDf4xtHkY2Bj50ZFgNWghthLsUQcl8KkOFnWOj+G1tmm1qM6tUjrpuzaNaMNj7H529Kr0xtjqt6rJF11TmokuimVIkOp0dimJBk+kr3KIFeStncmYtk1a6FqROs8ClqKRkfxMRtlj7EEVNwUG031qm5S6dXU6EZomai6GtuYPnKYJI+FdxmJWnGlrYZ3qGOZIDHa2RkUo3Wt+KDAE/9YlLrvVyxgZnGW6ILp81P881RYQX7ibZwivPz6gQfu/jNMm6OxrF/cfz/dWntJnBf9t/CE6AQvc34tvIzf/7afr/8JH3azO8sZu/9P7AEbxSccmsLGt41+l+sBDXI1dxx3Cfcp7nPcbdzd/uxiVDGoION8LzXw4Nde6osH/+QAFAoFwgx9XEj0FzYNjEiOi8HaYqxxe7OELUIRf7Mg2ySMm1mGSsymlKBwBeFSe8St0eygyuEynksXRwpnQWbTGwKXXjxHJm5SLp+1Y/tip7D67PNPnpCIatq6RML9cw9b+cWlS9pLUk/X8sPWe88rFj8ZoqplGfzIZ2VbF2lYvlf8mZMxpES+zSW5uGxIaAkppupkQKA6gi6rpqgZmkQUXSFmsjUF4iO33k0TLZ6K6SQdkVRCcUlLWgtmVsw0w3woJIRCy+ZVlKRN1Z4eccGJH/rg0V3q6EkLZF2iqqmsWzKRLxi9vZOH/9PypR2dZEJV7pWgy7wqXzfCkzB0n5+kq4jblm+R9IydyK0Hdh4OiQb05sqoLZshW7HUiqTJsgZyRTLTlpU2BxL5dGSZntDht8zNXKlKS8Pwt0xS02bchF8OOyaEar7QAfoirqEVxYCGmfLCCNdf6plmdPWtmcGWIiyTZRs9B3zXDtl3xEcXZIdeyG3alOfz8Xj+tcjgYIS6hu7+t2jbekiU/6zrRMtpr0ctK8pbnT2d1vPtLS0rtpxY+BTbpFc4LkfWf/Izgy/kE7Ecnz/22NzrrqG5vAsN/bckwmTYwp+1vEbD4TdiC0Zi1LKIbb3QvuXEyZaW9mvRTfqpQrGm411BJ7ki26Xvn17L/AdsjSobuNrYId+Bl030/yvWlTrE4VyzTlcQGjf1GKTYFHRPuW0bJiqpCMGzA1WzpbV77tiio48Y7kmoYiIuiyE30z6wYNJbhYsC4hYl4VDpRIX+u6GcCBxXBzm+ReQlU5l6UxI1RRwREjElNBIyyRG2skoUowlplSSEZZBnHYvyBaolwnIsWmztSrRW2he0RsNyOKGpme72/nRBAH1QPF0mVkI9XVVPE0Fn4EXpdNQG/w4P/700rITj4ctkVTUuUFt0Qb0gnJCEgBfUfJOTALcd3KXcLuAGt/7tnkphmmabuUDAV/DEYDyv3Q9B8HeA+kygJrTL/iZhf7tlfDpkAfJjwAL+p65Q7+qWQmGgUGhRgPJhGlRbc1tFKmoaDTmuYSdsoHsoQNqPj2az3dlsTNY0S9PWKYbIa7ap2mEhJCmh/5lL9XDswkBhk2oB5UuGotm7446ohURRUXhLHdRsW4OkCH1tGUy2Z6MroDPRyVh2tyZPKpqmTMpaVgFTAiqDSVtQpJCM8trX1dbR/2SxXc1xeaTJURaE3pUatuv2Bncd80ilOVZ+mD4AuhiewbgIT+Oc/RSiWQwrt2n5ukHNKuSnvf0i+bbeYPs4cxtsn/IaNHoCAwgsWGUPUv4e1b0JtKU9zJzYo6BCHBhfKbC5vA1160s/E09V8sdyGJRMOuwCms8e1IL21NZTTqbnc1k2usNr3kforC/8KswFCb3GeG5kG7G6C7LKTtdhfkmh4SSZaYnFnXzMwsGUQyRJT1cmNm2vPxInNbjwGO9jsXRPZcmeJZWeTLSeTBOpdTCu9YwuyKf60nYikU8krq0iIyCGkSou6VxQewDLZlFH9Q+Ftv5MqZTpbyvUU1fnF4z2aPHB1nRfajc2kE/UdDrch22zWMl5dWsepqLmIypXBobwmN7AkTFGJOZOCg63iAqgurjwj77qtSdLylWyTj6cLJW2TvL86Y7+Y905i5JJMHMsmIfX//M/87t2zS0lyb9rytVKKTX1dLI0xtPW0Ok4N1vO8tYTeg9O7z27yKojgv29RwL+toC9XuVG2P7O+u6G5mPZgnBOplr5Xhcsh5FdLOLDjcHbci7eyFyaOA3fO4XbovTHHf1c3Xkcgybuo61PaM6goz1BC1O/MFzaTmyNPK3ZpJ26U6+Rp1Pehot90rkjoKD5jvZl3fHNP0f/suaMnwMpPNrqsKhB1DAoCN4fjejYI39ytDNxpE2XOs0mma2TQ8rqQ97qH6sQxFc07Qqjb+vKc88Fq5ZvK0nlbSkk2d7bQQTml5TnnxP9I27eVpS3cdnK+4ij0Z2Msnf658TVztf1zxZbwTxY7Bsz3J9SbnpbxqHOFZsl3L92eNjb9cPDzgDzp5+ddUNKjceH3elbwaWP79fQspk+J+wawKC72cty2jtKd04/5Dlh5M2DTwTjA5q+P9DgazHBI2zd86Dt+kDpwdhEPJayhkIYHljMubnvYd92p90NhH4jOCDuG+wJbXgamnrFdqXdIVMhb1qOcBbIGIv8dIO3ahnw00iqDAWnd9+7YADTqVd0J22SCVlNmt6DaniM8HX/7qnM9kjhnp6ZJ2IWAfCxql2SciWJYQSa26WG02/pDu/Dub6+HLkm39vrLVYUck1YllXvfFWm5wC3VLxlzAFxf67P0XLMPMcDADaky0sEIpF/lgiRPdxE84bgw93U6/GrcXYmXxHgGZyBxJCiglwxPtOvzBAiXikHpxvBjP+FUlncL9CSN1Kb9vtgts4+O+evqFLxcUH2Ppgq04/hoiorc5qj33f92dNrqJ+D77fWoxHqZviMcAR6GAz0uUYKUH6DWB9QwGnA+JuJR3kriDc76Dv+cmagEs8MxSL/qinYeuChee45xSGXTDEio/i50xTWehBOC6+TTu1DTTSP536xbwUDqtZU8HITzXN6Q1v17js+zbc1dKM+8BB05GNsk89O3Z6m+VH6LJfhetnJisFe7BLbjQ1qssu0vSz7/5ZIYhlkHPs/UuC52TjNqA/TKroIUf75AbTsNN8qk39YHB2J5RJ9JOKkusI8/xeeKiYYX49a6UhXJN0Ztvh8JrpOTzt2TNP1nN1uSCJPvBsT0XSON8KdqWh3JG09CsqaInhT8OzyitKqa1rUttugRkTOSeGulKzQLtkyRDwlYCilK1SGooUV843w9hSYSOqCbM6QrP6UzodOCxvzJwvwaZkqRor8OIyh21Pfh+5J+3mjLTuiyrKOt9D0Gsv//77TZ/tS8ULGTeiOGWG+07awS/h4tM22HdM1Y4bUuF6U5wbYyvVsh0Q28nJfW/try0V00l/Vqm1rF2q72v8dl8GCdaEZx5LgCpi/toSnVNV2yv/1c0BxD8xf+H/lQ0CLORaDBPQhlfBEuSytsoiPcu3EIHYKxhBaCqhMivw93tVixrYyordTpE5C5hU1Zqteq5FIJ4xsT3YwniM5YJL5Y+nVpk2pbU6dJqUyJk+tDBgtDxgJA37eH6KtrdGHoGBbXz6wlbaA/ZwGrQRPgjueO537MHc5t8f3iDaYxs12sq/lovNLbHIlFhs1kcaDxht3hktNuxfqcXYNzmmmPZeb3ZLzupa1WdkdaGTvMMLhTLlsnscC6iIVsgpQckeEdI/F/azk5IpB103uULzf+LzkBowt1vFCe+rJZ/1Y0s+j3WEnlEnF9r4ODfnRNZPKt3Rl0l/KEFYo7njvqnWZHaik7zA6yhlVha/jgxslo3iPj3bT6A50ee9Iuu7g5CR8/QB8B3nVCt0OwsH2+yr7Y34H8DIHvpSwiTQJHf8T1J7EmNZJYLOTogVGmSBOKsnpmOYl9HtcjGsPzvnC2O9xdD4GYU9owSvoqSyxAJVyqba+4wfq0w1Aqh9XlMonll+ktCg/UZSL1J4BxfsnckRbPMyHz/3CuZpVOWUxLulINzMo3KyMKeTvgOUP9IQvUqBKUrlo+ScGFPIP3r90nlKxNKgDNePeRtV2xZtZhNzNiFb/FyamPVkAAHicY2BkYGAA4gX9T0/G89t8ZeBmYQCBx3aZiQj6fz0LA3MjkMvBwAQSBQA/ZAp0AHicY2BkYGBu+N/AEMPCAAJAkpEBFXQBAEeQAvN4nGNhYGBgGcWjmAAGAFm2AikAAAAAAAAAnAFEAaICaAKsAz4DhAQSBHwEzAV2BfYGbAaqBvgHkAfaCGoI4AkSCZwKJgqSCvILeAwODJINEg1qDboOOA6uDxQPRA+aD74QIBB2EcYR3hIuErYTAhNSFAAU3BUkFW4VyhZUFtgXMhfMGCYYghjUGSIZuhoGGlYamhroGzgbdBvEHAocWBykHQAdXB2gHcgeEB5QHpIe+B8YHzwfqh/4IGogriEQITAhuCIqInIitCL4IxgjQCNgI4Qj5iRaJL4lOiWiJe4mRCasJyAngCfgKEYovCkaKZQp+iq8KvYruCwyLKItni4MLqgvki+8MCwwojDyMWwxpjIWMnAyvDL8MzAzZjOgNDI0mDT2NT42FDZsAAB4nGNgZGBg6GL4xsDDAAJMQMwFhAwM/8F8BgAv8gKjAHichZE9bsJAEIWfwZAElChKpDRpVikoEsn8lEipUKCnoAez5ke211ovSNQ5TY6QE+QI6Whzikh52EMDRbza2W/evpkdyQDusIeH8rvnLtnDJbOSK7jAo3CV+pOwT34WrqGJnnCd+qtwAy94E26yY8YOnn/FrIV3YQ+3+BCu4AafwlXqX8I++Vu4hgf8CNep/wo3MPGuhZtoeeHA6qnTczXbqVVo0sik7niO9WITT+2pPNE2X5lUdYPOURrpVNtjm3y76DkXqciaRA15q+PYqMyatQ5dsHQu67fbkehBaBIMYKExhWOcQ2GGHeMKIQxSREV0Z/mY7gU2iFlp/3VP6LbIqR9yhS4CdM5cI7rSwnk6TY4tX+tRdXQrbsuahDSUWs1JYrLiDzzcramE1AMsi6oMfbS5ohN/UMyQ/AHYk29XeJxtVGd34zYQ1NgkRRVbvkvvvYeJKfvic3rvvfcEJNciIojgAaBsOb0nlz8dAJT95LzwAwnsLnZnB7PsrHXap9/5/+cy1rCOACEidBGjhz4GGGIDmxhhC+dwHlfgSlyFq3ENrsV1uB434EbchJtxC27Fbbgdd+BO3IW7cQ/uxX24Hw/gQSR4CA9jGynG2MEuLuAR7OEi9vEoHsPjeAJP4ik8jWfwLJ7D83gBL+IlvIxX8Cpew+t4A2/iLbyNd/Au3sP7+AAf4iN8jE/wKT7D5/gCX+IrfA2GDDkKEA4wQQmObzCFwAwVJGpcgoKGQYM5DnGEBY7xLb7D9/gBP+In/Ixf8Ct+w+/4A3/iL/yNy/in02NCJDNm8rKrqBYsp1iXsslZNRksDYkN6R6XvGxYFemS1aQ3DR2ZpKkKUoJXtOWtSV7aU6T5MY3asCRnhgk5WXTpqGZVkW7WilcmKbhmmaAi9NuoqYTMpxHNGBfpRiaVTZvUVOVc9HNZL5IDLijdZEXRrhKey2rkt1K4WLffOHH7XeBWkWALUnpom8nJdklqQpGimZzTgCXHfGEb2t2+GHrHJhXcJLWSNSlO+jRgZ/9CWJeyoqDRpCJNTOVlP2P5dKKkZSDw2N3L9pMLqWlo6xslhQeyJqehJUNRt24ywXXZ1WQMryYWSNFYtgt5aNtnReRRpMGB4HXIBJ9UgaWz6Fl+p4kjOdYkKDdSxbXU3HBZRbavUqquayhp6p7/unz9A4sg8UlibzSy3vJX5m2J4pPSjFYMgg5MPONKSZWUG+1ttp5y4BNk0hg5O7/qaU1ngudLIdClxt2xSeajVbdFcW5172EEDmsLOJdCqv+mKLdWjzigESlmryJw+IetCirjVLfe1OOl0k6+OwOfmVsZ8jx03KQjbyksmYY8r5mpPGs9t3AF0g1X3fZXJpoXNGpv6rSM05YIXeA4dMs0cgct/04EVvKaBu58U/usSyC7QWa1GvmWx/FJpW57MvWlva9/ukp9lJ3AhZXKnJSxHyeUvqvZctVz3XuRx0oaZijZHi7BemvEZ7VUJphIWawofmdlvduOsm4ys7Asp+sZK+KcCaoKpgbLyXEaPBu309eNHRfFrA6DGVPTgfuP2AtzeAMXH7nxqHV/CWy8tx0xY1he9vyQJLSg3tK3v71uGxmuFBvHdgwrFxNoNqcwU40u1yzFp7+DqB39sGbaUFzRobeGraQctYEjfz1vzFng45Xe94JDpqrVumlQ2NHsdP4FNNf0ewAA') format('woff'),
url('data:font/ttf;base64,AAEAAAALAIAAAwAwR1NVQiCLJXoAAAE4AAAAVE9TLzI8TknQAAABjAAAAGBjbWFwZE0JUwAABBQAAAlaZ2x5Zks+ySYAAA6IAABs2GhlYWQpnBa/AAAA4AAAADZoaGVhB94ECwAAALwAAAAkaG10eCgAAAAAAAHsAAACKGxvY2GU1XmKAAANcAAAARZtYXhwAaABAgAAARgAAAAgbmFtZRCjPLAAAHtgAAACZ3Bvc3RR4DGKAAB9yAAABk0AAQAAA4D/gABcBAAAAAAABAAAAQAAAAAAAAAAAAAAAAAAAIoAAQAAAAEAAKCP5clfDzz1AAsEAAAAAADjPmlhAAAAAOM+aWEAAP9/BAADgQAAAAgAAgAAAAAAAAABAAAAigD2AAwAAAAAAAIAAAAKAAoAAAD/AAAAAAAAAAEAAAAKADAAPgACREZMVAAObGF0bgAaAAQAAAAAAAAAAQAAAAQAAAAAAAAAAQAAAAFsaWdhAAgAAAABAAAAAQAEAAQAAAABAAgAAQAGAAAAAQAAAAQEAAGQAAUAAAKJAswAAACPAokCzAAAAesAMgEIAAACAAUDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFBmRWQAwOY45wADgP+AAAAD3ACBAAAAAQAAAAAAAAAAAAAAAAACBAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAAAAAABQAAAAMAAAAsAAAABAAAAroAAQAAAAABtAADAAEAAAAsAAMACgAAAroABAGIAAAAGAAQAAMACOY45jrmQuZF5trm4Obj5ujm6ubv5wD//wAA5jjmOuY+5kXmXebg5uPm6Obq5u/nAP//AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABABgAGAAYACAAIAEaARoBGgEaARoBGgAAABQABgAQABEAEgAPABMADgBhAHIAiACFAIYAhwCJAGYAZwBoAHsAegB8AH0AfgB/AIAAgQCCAIMAhABpAGoAawBsACoAbQBuAG8AcABxAHMAdAB1AHYAdwB4AHkAXgBfAGAAYgBjAGQAZQAVABYAFwAYABkAGgAbABwAHQAeAB8AIAAhACIAIwAkACUAJgAnACgAKQAqACsALAAtAC4ALwAwADEAMgAzADQANQA2ADcAOAArADkAOgA7ADwAPQA+AD8AQABBAEIAQwBEAEUARgBHAEgASQBKAEsATABNAE4ATwBQAFEAUgBTAFQAVQBWAFcAWABZAFoAWwBcAF0ACAAJAAoACwAMAA0ADwAFAAQAAwACAAEABwAAAQYAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADAAAAAAGoAAAAAAAAACMAADmOAAA5jgAAAAUAADmOgAA5joAAAAGAADmPgAA5j4AAAAQAADmPwAA5j8AAAARAADmQAAA5kAAAAASAADmQQAA5kEAAAAPAADmQgAA5kIAAAATAADmRQAA5kUAAAAOAADmXQAA5l0AAABhAADmXgAA5l4AAAByAADmXwAA5l8AAACIAADmYAAA5mAAAACFAADmYQAA5mEAAACGAADmYgAA5mIAAACHAADmYwAA5mMAAACJAADmZAAA5mQAAABmAADmZQAA5mUAAABnAADmZgAA5mYAAABoAADmZwAA5mcAAAB7AADmaAAA5mgAAAB6AADmaQAA5mkAAAB8AADmagAA5moAAAB9AADmawAA5msAAAB+AADmbAAA5mwAAAB/AADmbQAA5m0AAACAAADmbgAA5m4AAACBAADmbwAA5m8AAACCAADmcAAA5nAAAACDAADmcQAA5nEAAACEAADmcgAA5nIAAABpAADmcwAA5nMAAABqAADmdAAA5nQAAABrAADmdQAA5nUAAABsAADmdgAA5nYAAAAqAADmdwAA5ncAAABtAADmeAAA5ngAAABuAADmeQAA5nkAAABvAADmegAA5noAAABwAADmewAA5nsAAABxAADmfAAA5nwAAABzAADmfQAA5n0AAAB0AADmfgAA5n4AAAB1AADmfwAA5n8AAAB2AADmgAAA5oAAAAB3AADmgQAA5oEAAAB4AADmggAA5oIAAAB5AADmgwAA5oMAAABeAADmhAAA5oQAAABfAADmhQAA5oUAAABgAADmhgAA5oYAAABiAADmhwAA5ocAAABjAADmiAAA5ogAAABkAADmiQAA5okAAABlAADmigAA5ooAAAAVAADmiwAA5osAAAAWAADmjAAA5owAAAAXAADmjQAA5o0AAAAYAADmjgAA5o4AAAAZAADmjwAA5o8AAAAaAADmkAAA5pAAAAAbAADmkQAA5pEAAAAcAADmkgAA5pIAAAAdAADmkwAA5pMAAAAeAADmlAAA5pQAAAAfAADmlQAA5pUAAAAgAADmlgAA5pYAAAAhAADmlwAA5pcAAAAiAADmmAAA5pgAAAAjAADmmQAA5pkAAAAkAADmmgAA5poAAAAlAADmmwAA5psAAAAmAADmnAAA5pwAAAAnAADmnQAA5p0AAAAoAADmngAA5p4AAAApAADmnwAA5p8AAAAqAADmoAAA5qAAAAArAADmoQAA5qEAAAAsAADmogAA5qIAAAAtAADmowAA5qMAAAAuAADmpAAA5qQAAAAvAADmpQAA5qUAAAAwAADmpgAA5qYAAAAxAADmpwAA5qcAAAAyAADmqAAA5qgAAAAzAADmqQAA5qkAAAA0AADmqgAA5qoAAAA1AADmqwAA5qsAAAA2AADmrAAA5qwAAAA3AADmrQAA5q0AAAA4AADmrgAA5q4AAAArAADmrwAA5q8AAAA5AADmsAAA5rAAAAA6AADmsQAA5rEAAAA7AADmsgAA5rIAAAA8AADmswAA5rMAAAA9AADmtAAA5rQAAAA+AADmtQAA5rUAAAA/AADmtgAA5rYAAABAAADmtwAA5rcAAABBAADmuAAA5rgAAABCAADmuQAA5rkAAABDAADmugAA5roAAABEAADmuwAA5rsAAABFAADmvAAA5rwAAABGAADmvQAA5r0AAABHAADmvgAA5r4AAABIAADmvwAA5r8AAABJAADmwAAA5sAAAABKAADmwQAA5sEAAABLAADmwgAA5sIAAABMAADmwwAA5sMAAABNAADmxAAA5sQAAABOAADmxQAA5sUAAABPAADmxgAA5sYAAABQAADmxwAA5scAAABRAADmyAAA5sgAAABSAADmyQAA5skAAABTAADmygAA5soAAABUAADmywAA5ssAAABVAADmzAAA5swAAABWAADmzQAA5s0AAABXAADmzgAA5s4AAABYAADmzwAA5s8AAABZAADm0AAA5tAAAABaAADm0QAA5tEAAABbAADm0gAA5tIAAABcAADm0wAA5tMAAABdAADm1AAA5tQAAAAIAADm1QAA5tUAAAAJAADm1gAA5tYAAAAKAADm1wAA5tcAAAALAADm2AAA5tgAAAAMAADm2QAA5tkAAAANAADm2gAA5toAAAAPAADm4AAA5uAAAAAFAADm4wAA5uMAAAAEAADm6AAA5ugAAAADAADm6gAA5uoAAAACAADm7wAA5u8AAAABAADnAAAA5wAAAAAHAAAAAAAAAJwBRAGiAmgCrAM+A4QEEgR8BMwFdgX2BmwGqgb4B5AH2ghqCOAJEgmcCiYKkgryC3gMDgySDRINag26DjgOrg8UD0QPmg++ECAQdhHGEd4SLhK2EwITUhQAFNwVJBVuFcoWVBbYFzIXzBgmGIIY1BkiGboaBhpWGpoa6Bs4G3QbxBwKHFgcpB0AHVwdoB3IHhAeUB6SHvgfGB88H6of+CBqIK4hECEwIbgiKiJyIrQi+CMYI0AjYCOEI+YkWiS+JToloiXuJkQmrCcgJ4An4ChGKLwpGimUKfoqvCr2K7gsMiyiLZ4uDC6oL5IvvDAsMKIw8jFsMaYyFjJwMrwy/DMwM2YzoDQyNJg09jU+NhQ2bAAAAAQAAAAAA6IC2AAZACYAVwBqAAABIgYHNTQmIgYVERQWMjY9AR4BMzI+ATQuAQMiLgE0PgEyHgEUDgEBIyIOARUUFjI2NTQ2OwEyFh0BBgcGIyIHBgcOAhcWFxYzMjc2Nx4BMzI2NRE0LgETBgcGJicmNjc2NzYyNzY3FgcGAtcnSBwTGhMTGhMcSCc3XTc3XTcmPyYmP0w/JiY//kBbIzsiExoTJhpbIS8lHxMdIRIeIRslDAkJGyxNEwtFKwMQCw0TJ0INHDwxPgkGFBUYFA05EyAjAgQGAhMjIOgNExMN/asOEhIOCCAjQnGFcUL+VTFTY1MxMVNjUzEBmyM7Iw0TEw0bJi8iIQkEAQQFEA4zQB4iGSgBBigJDBMNARAnQyf+kiYGBRseGDEKDAQCAgIJIBwlAAAAAAYAAP/qA8MDFgAVABgALwA3AD8AcQAAATMXHgEyNz4BJwMuAQYHAwYeATY/AhcjAT4BNTQuASsBIgYVERQWOwEyPgE1NCYnMzIWFAYrARcjNTMyFhQGJSYvAS4CJzEmLwEmDgEWHwEGJy4CNzQuAQYHBh4BFxYXBw4BFxYzMj8CMD4BNzUBTQIoBBAQBgwKBpsFGBkFmwUJGBkFKFc5cgLdEhQgNiCqDhISDqogNiAU7IoWICAWioqKihYgIP68AQEBAQEBAwECWwoaEQMKGBwWKD8jARIaEwEBLlU3FBoICwUIChAKCGEHAgMBAetZCAoDBRkMAVYLCAgL/qoMGQoJDFi9ff6KESwZIDUgEw3+qw0THzYgGSybHywgqmofLB9DAgMCAwICAgIBSwgDFRoIFAEFCjVLKQ0TARINOWVHDgUBBgcbCg4FQwYDCAIMAAIAAP/2A58DCwAjADoAAAUiLwEHBi4CPwEnLgE+AT8CPgEWHwIeAgYPARcWDgEvATIfAScmPwEnJi8BBwYPARcWDwE3NjMC6wgH3NwIEw4HASuyBwQFDgr2bgUXGAVv9gkOBgUGsioCBxAL7AgHsSEDDJDHEAhZWAgRxpAMAyKyBwgJA3R0BAIKEQn1rQcREgwBJN8KCAgK3yQBDBESB631CREMAbsEXcURC4wdAw+0tBACHYwLEcVdBAAABgAA//MDeQMOACwAXQBtAHEAgQCFAAABFgcnLgEOAR8CFjMXFjI/ATY/AjYuAQYPASYnLgIHDgIUHgE3Nh4BFwEGLgEnJjcXFjMyPgEmLwMiLwEjIg8BIg8CBhYXFjMyPwEWFx4COwE+ATQmBwEhMjY1ETQmIyEiBhURFBYTMxUjBSEiBhURFBYzITI2NRE0JgMjNTMC8gYBFAgbFAMISgQCAQcFDQYIAQEEQggFFRoIBgEFDUllOAgPCAkPCSlLNQr+zSlLNAoGARQKDwkQCAMFSwMDAQEKBwUBDAEBBkIIBQsIChAKBgEFDUZiNwcNEhQN/ukBAA0TEw3/AA0TEy3AwAKO/wANExMNAQANExMtwMACMRYcGAoDERoKWwQCAwMDBAECBGEKGg8ECwgXFzZVLwEBCQ8RDgkBASJAKP4BASJAKBYcGAwKERIHWwMEAQQBBQEGYQsaBwYOCBcXNVQwARMaEwEBmxMNAQANExMN/wANEwEAwMATDf8ADRMTDQEADRP/AMAAAAAAAgAAAAADjgLLABQAKgAAEyEyNz4BJyYvASYiBhQfASEiBhQWBSEiBw4BFxYfARYyNjQvASEyNjQmI5UC1gYGDAsFAwSrCRsSCXT9dw0TEwLj/SoGBgwLBQMEqwkbEgl0AogNExMNAeADBRgMBgWqChMbCXQTGhOVAwUZDAYEqwkTGgp0ExoTAAYAAP9/A+YDgAASAB8ANABEAFMAYQAAASEiLgE2NxM+ATIWFxMeAQ4BIwMiBwMGFjMhMjYnAyYDIyIuAT0BND4COwEyHgEdARQOAQMiBh0BFBY7ATI2PQE0JiMBIi4BND4BMh4BFRQOAgMiDgEeAj4BNTQuAgLe/kQXJxYBDN0MJiwmC94MARYoF90CAt0BAgMBuwICAd4BtZgqRykXKzkfmClHKipGwh8rKx+YHisrHgGyPmo+Pmp9aT4jQFUuLUwjEkBaVDIXKjcBdRcoLhQBYhMVFRP+nhQuKBcBuwL+nQIEBAIBYwL8UCpGKpgfOCsYKkYqmCpGKgF8LB6YHiwsHpgeLP6EPmp9aT4+aT8uVEEjAXwzVFlAEiNMLR43KhcAAAACAAD/fwPNA4EACwAsAAAFISImNDYzITIWFAYlIicmJyY1ETQ2MhYVERQeATI+ATURNDYyFhURFgcGBwYDm/zKFRwcFQM2FRwc/k9hU1EwMR0oHUZ4jHdGHSkcATEvUVSAHSkcHCkdzi4tTE9bAbAUHR0U/lBBbUFBbUEBsBQdHRT+UFtPTC0uAAAAAAYAAAAAA10C3QA3AE8AUwBXAFsAXwAAARY2JzU2JgcjJgYXFSE1NiYHIyYGFxUGFjczESMmBhcVBhY3MxY2JzUhFQYWNzMWNic1NiYHIxEBIxEzFjYnNSEVBhY3MxEjJgYXFSE1NiYDNTMVERUjNQU1MxURFSM1Az4NEgEBEg2IDRIB/tABEg2IDRIBARINJiYNEgEBEg2IDRIBATABEg2IDRIBARINJv4yJiYNEgEBMAESDSYmDRIB/tABEndMTAH0TEwCGAESDYgNEgEBEg0mJg0SAQESDYgNEgH+0AESDYgNEgEBEg0mJg0SAQESDYgNEgEBMP7QATABEg0mJg0SAf7QARINJiYNEgFrTEz+WExMTExMAkBMTAAABAAAAAADdALrABgAIQA0AEYAACUjLgE1ETQ2MyEyFh0BFAYnJg4CBxQWBiczPgI7ATUhASIuAScmNTQ+ATMyFx4CDgIDIg4BBxQXHgI+Ay4BJyYBs9sYIyMYAbkYIhcOJ04/IgEEEua4AUBsQQ3+TQGmO2ZECAJAbkEZGTpaLQ1DZzwwUi8BAgYzTlhMMQghQysTvAEiGAG5GCIiGO0PEgMIEzJIKAwaFT1AbEDH/Vw2XjoQEUBuQAUNTG53YTkBoDBRMAwMLEcnAStIWVA5CQQAAAADAAAAAANfApgADwAeADIAACUhIiY1ETQ2MyEyFhURFAYBIgYVERQzITI2NRE0JiMBIi8BLgE+AR8BFj8BNh4BBg8BBgMc/cgcJyccAjgcJyf9rAIDBQI4AgMDAv7bFxKbCgMQGgmcAwOcChYOAQicEmgnHAGqHCcnHP5WHCcB8gMC/lYFAwIBqgID/u4OfAgZFAMIfAICfAUEEhcIew8ACAAAAAADeQLxAAgAHQAmADwAUABhAGgAdwAAJRQGKwE1MzIWAREUBisBJzMyNxE0KwEyNj0BMzYWByMXMxUXNTQmBxUUIyEiPQEzJyMiBhURFBYzITI2NwMhIgYdARc1NDYzITIWHQEzNTQmARUjIiY1ETQ2NxcjIhURFDMBFRQGKwEnASInAS4BPgIWFwEWFAYBdRINHh4NEgHbJhsDPUADAQRmDRJHGyamhT4pPRIsA/7wA10+PQ0SJhsBDxklAkD+8BslPQIBARABAj0l/pVHGyYiGT03AwMB1xIM8T4B3gwJ/VIGBQQMEBAGAq4JEtYMEj0SASX+8BslPQMBEAMSDR4BJoQ+KT2FDRL2OAMD8D4SDf7xGyYiGQJlJhoEPUEBAgIBSEgaJv4lPSUbARAZJQI9BP7xAwFTHg0SPf27CQKuBhARDAQFBv1SCRkSAAAAAAUAAAAAA1EC0QApADkAQQBRAFsAACUjIiY0NjsBMjY1ETQmIyEiBxEWOwEyFhQGKwEiJjURNDYzITIWFREUBgchIiY1ETQ2MyEyFhURFAYBFRQXITY9ATchIiY9ATQ2MyEyFh0BFAYlITU0JiMhIgYVAxBnDRISDWcBAgIB/eEDAQEDZg0SEg1mGyYmGwIfGiYmov7wGyUSDAFUDBIl/tIDARADH/6sDBIlGwEQGyUS/r8BFgIB/vABArgSGRICAQEQAQID/vADEhkSJRsBEBslJRv+8BsliCYbAQ8NEhIN/vEbJgEx8AMBAQPwqhINZhslJRtmDRI9SAECAgEAAAAEAAAAAAMYAuoAIQAxAEIATgAAJSEiJicRNDY7ATU0PgEWFxYOASYnLgEOAR0BITIWFREOAQEiBhURFBYzITI2NRE0JiMDIiY9AS4BPgIeAQYHFRQGJyYOARQeATc+ATQmAtX+VhwmASccKUp2bBsGCBcYBhFGTDABRBwnASb+OgIDAwIBqgIDAwLVDRIdIwUqPDISFxoSFgYMBwcMBgkMDCAmGwFlGycrPF8bMzYLGQsIDCMhEj0nKycb/psbJgGrAwL+mwIDAwIBZQID/uMSDQoIMjwsBiE5OA8RDRKRAQYLDQsGAQENEQ0AAAMAAAAAA2wClAAPAB8AJQAAJSEiJjURNDYzITIWFREUBgEiBhURFBYzITI2NRE0JiMFJTcFJRcDFf3cJDIyJAIjJDMy/bgNEhINAiMNEhIN/ur+yBoBHgEpGokzIwFeJDIyJP6iIzMB0xIN/qIMEhIMAV4NEuTAObC0OQADAAAAAALoAmgADwAhADAAAAEnJjQ/ATYyHwEWFA8BBiIHPgEvASYGDwEGBxUGFjczMjclIyIPAQYWOwEyNj0BNCYCozMHBxwHEwc0BwccBxQlBwMFPwQQB+YHAQEMCT8ICAEqpAoHIAYGCM0KDg4B7zQHEwccBwczBxQHHAc4BxAEPwUDB+AHCT8JDAEHNQchBg4OCgwKDgAAAAAMAAAAAAL8Ap0ADwAQABwAKAA0ADUARQBGAFIAXgBqAGsAACUhIiY1ETQ2MyEyFhURFAYjAyMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGIwchIiY1ETQ2MyEyFhURFgYjAyMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGIwLY/u8PFRUPAREPFBQPQY8HCAgHjwcHCAaPBwgIB48HBwgGjwcICAePBwcIBoj+7w8VFQ8BEA8VARUPQY8HBwcHjwcICQaPBwcHB48HCAkGjwcHBwePBwgJBnsVDwGgDxUVD/5gDxUBSggNCAgNCFYIDQgIDQhWCA0ICA0IZBUPAZ8PFRUP/mAPFAFJCA0ICAwJVggNCAgMCVYIDQgIDQgABQAAAAADAQJ4AA8AGwAcAC8AMAAAASEiBhURFBY3IRY2NREuAQcjFSM1IzUzNTMVMxUBIRUzNS4BIyEiBhURFBY3MzUjAwLj/oALEhEMAYAMEgERVlg7WVk7WP6BAWIeAREM/p4MERILHh4PAjgQC/6eDBABARAMAWILEOhSUjdSUjcBCxsbDBAQDP65CxEBGwFaAAQAAAAAAzcChQA0AEkAZgBnAAABDgEHBhYXIyIuAjURNDY7ATI3MzIeAh0BIiMHIgYPAQYWMzI2PwEFHgMHFAcVJgcGFzIWFx4BFAYHDgEiJicuATQ2Nz4BFzI2NCYrATU0JiIGHQEjIgYUFjsBFRQWMjY9ATM1AjESGAYFAwnrDhsXECokZyMSlQ0dGA8vHfAPEwQjAg0MCg0DIQFDCxYSCAMBLzAxXRsyERQUFhITLzgyERMVFxETMGkIDAsJOgsRCzoIDAwIOgsQDDoBkxIsGRczFwoTHhMBCSYrAQsSGQ4IARIReAkTDAh8AQEJExsTAQEDDwoNHRcREy84MhETFRYSEy84MhETFZcLDww7BwwLCDsLEAw6CAwLCToBAAYAAAAAAvECngAPAB8AIAAwAEwATQAAASYGBwMGFh8BFjY3EzYmLwEXHgEHAw4BLwEuATcTPgEXBzMyFhURFAYrASImNRE0Nhc1NCYiBh0BIyIGFBY7ARUUFjI2PQEzMjY0JiMHAb8OGQNbAw4N7w4YBFsDDg3l7xwdCFsHMhvyGx0IWgkyHH72HCkpHfUdKSmqCg8KWAgKCghXCg8KVwcKCgdWAnQEDg/+rA4YBD8DDg4BVA4YBGI/CDEb/qwcHQg+CDEbAVUcHAc1KR3+oR0pKR0BXx0p9VgHCgoHWAoPClcICQoHWAoOCwEAAgAAAAADwAL+AA8AHwAAKQEiJjURNDYzITIWFREUBiUhIiY1ETQ2MyEyFhURFAYCUf4oFyIiFwHYFyIiAR/+OxghIRgBxRghISIXAc4YISEY/jIXItAiFwG8FyIiF/5EFyIAAAMAAAAAA2cC9QAUACYAUwAAJSInJScmND8BJTYyFwUXFhQPAQUGAQUXFjI/ASU2JyUnJiIPAQUGASInJScmND8CPgEeAgYPAQYXBRcWMj8BJTYvAS4BPgIWHwIWFA8BBQYCABsU/uIFFBQFAR4UNhQBHgUUFAX+4hT+vgEeBAMGAwQBHgMD/uIEAwYDBP7iAwEqGxT+4gUUFAVsBhEQCgEIB2oDAwEfBAIGAwQBHwICaggJAQoQEgZtBRQUBf7iFdkSyAMUOhQDyBISyAMUOhQDyBIBCsYEAgIExgQFxgMDAwPHBP4kEsgDFDoUA0wFAgcOEQ8ESgQExwMCAgPHBARKBA8SDgcCBkwDFDoUA8gSAAAAAAYAAAAAA18C3wAWACwAPABIAFgAaAAAASImPQE0NjsBMh4BFA4BKwEiBh0BFAYFIyImNDY7ATI2PQE0PgEyHgEdARQGByMiJj0BNDY7ATIWHQEUBgMiHQEUOwEyPQE0IyUjIiY9ATQ2OwEyFh0BFAYDIgYdARQWOwEyNj0BNCYjAU4MEiYcsggOCAgOCLICAxIBM7IMEhIMsgIDCA8QDggm8dUcJycc1RsnJ/AFBdUFBQFj1RsnJxvVHCcn8QIDAwLVAgMDAgE+EgyyHCYIDhAPCAMCsgwSjhIZEgMCsggOCAgOCLIcJo8nHNUbJycb1RwnAR0F1QUF1QVHJxvVHCcnHNUbJwEcAwLVAgMDAtUCAwAAAAUAAAAAAzwC3wAfACkAMwBAAE0AACUhIiY1ESMiJjQ2OwE1NDY7ATIWHQEzMhYUBisBERQGAREUFjMhMjY1ESUzNTQmKwEiBhUTIiY9ATQ2MhYdARQGIyImPQE0NjIWHQEUBgKy/pwbJykNEhINcCYc1hsnbw0SEg0oJ/58AwIBZAIC/tveAgLWAgK2DRISGhISmw0SEhoSEiEnHAGvEhkSTBwnJxxMEhkS/lEcJgHx/lECAwMCAa89TAIDAwL+FBIM1gwSEgzWDBISDNYMEhIM1gwSAAAAAAMAAAAAA18C3wAjADMAQwAAJSEiJj0BNDYyFh0BFBYzITI2NRE0JisBIiY0NjsBMhYVERQGASEiJjURNDYzITIWFREUBgEiBhURFBYzITI2NRE0JiMDHP6dGycSGRIDAgFjAgMDAvgNEhIN+BwnJ/7I/uQcJyccARwbJyf+yQIDAwIBHAIDAwIhJxz4DRISDfgCAwMCAWMCAxIZEicb/p0cJwEdJxsBHBwnJxz+5BsnAWMDAv7kAgMDAgEcAgMAAAYAAAAAA18C3wATACgAOABIAFgAZgAAJSMiJj0BNDYyFh0BFBY7ATIWFAY3IiY9ATQmKwEiJjQ2OwEyFh0BFAYTIyImPQE0NjsBMhYdARQGAyIGHQEUFjsBMjY9ATQmIyUjIiY9ATQ2OwEyFh0BFAYDIgYdARQ7ATI9ATQmIwIkshwmEhkSAwKyDBISgg0SAwKyDBISDLIcJhJe1RsnJxvVHCcn8QIDAwLVAgMDAv6d1RwnJxzVGycn8AIDBdUFAwKwJhyyDBISDLICAxIZEo4SDLICAxIZEiYcsgwS/uMnHNUbJycb1RwnAR0DAtUCAwMC1QIDRycb1RwnJxzVGycBHAMC1QUF1QIDAAAGAAAAAANfAt8AFAA4AEoAUwBjAG0AAAEiJj0BNCYrASImNDY7ATIWHQEUBgMhIiY1ETQ2OwEyFhQGKwEiBhURFBYzITI2PQE0NjIWHQEOAScjIiY9ATQ/ATYyHwEWFA8BBiczNzYvASYPAScjIiY9ATQ2OwEyFh0BFAYnMzU0JisBIgYVArINEgMCag0SEg1rHCcTMP5VHCcnHGoNEhINagIDAwIBqwIDEhoSAScjYw0SCa4UNhMyExOvCFI5pQMDMQQDpR/WDBImHI4bJxLDmAMCjgIDAakSDY8CAxIZEicbjw0S/ngnHAHxHCcSGhIDAv4PAgMDAo4NEhINjxwmjxIMZAwJrxMTMhM2FK4JPaUEAzIDA6buEg1qHCcnHGoNEj1MAgMDAgAAAAAEAAAAAANfAt8AIABEAFQAZAAAJSMiJj0BNDY7ATIWFAYrASIdARQ7ATI9ATQ2MhYdARQGASMiJjQ2OwEyNj0BNCYrASIGHQEUBiImPQE0NjsBMhYdARQGByEiJjURNDYzITIWFREUBgEiBhURFBYzITI2NRE0JiMBudUcJyccag0SEg1qBQXVBRIZEicBSGoNEhINagIDAwLVAgMSGRInG9UcJyeq/uQcJiYcARwcJib+yAIDAwIBHAIDAwIhJxzVGycSGRIF1QUFag0SEg1qHCcBZBIZEgMC1QIDAwJqDRISDWocJycc1Rsn1SYcARwcJiYc/uQcJgFjAwL+5AIDAwIBHAIDAAACAAAAAANHAscALQBVAAAlIicmJyYnJicmNjcyOwEyFhcWFxYGDwEiFBUWFxY/AT4BFxYXHgEdARQOAiMBIw4BFxYXFhcWFzMyNj0BNCcmJyoBIwcOAScmLwEmNj8BNicmJyIjAuUHB4x2dElMEQUwJwgHgBgkAwQaCg8VHAIuRAICEQwwFzY7GSEOGyQT/jUFDhICEERCaGt+Bg8UAkZAAQIBExAzFkw1Aw0PFxwBAR8FAQE4ARJNSnR3jCdABiEYPDcWMAwOAwFELgICHRUPCxoEAyQZgRQkGxACUQIXD35raUNFEBUPgQIBBR8iFQkPNU0FGDINEAECQEYAAAAABAAAAAADPALrAA8AHwAsADkAACUhIiY1ND4BNzMeAhUUBiUiDgEVFBYzITI2NTQuASMnIi4BPgIeARUUDgEDIg4BHgI+ATU0LgEC+f4OGyc4YDjWOGA4J/6BKEMoAwIB8gIDKEMoazVXKBRKZ2E7L08vIjgaDTBCPyUeMx0nGzlfOAEBOF85GyfVJ0QoAgMDAihEJ5c6YWdLFChXNS9PLwEdJj5DMA0aOCIfMx4AAAADAAAAAANWAt8AFQAiAC8AACUiLwEOAS4CPgIeAgYHFx4BDgEBJg4CHgEyPgE0LgEBIi8BJj4CHwEWFAYDJQwJoDmNiGIfJ2eLjG0uFy6fBwMHD/6UPGQ7ATtkdmU7OmQBOQ0JfAkBERkJfQkSPAmfLhcubYyLZycfYoiNOaAGEhIKAlwBO2R2ZTs6ZHdkO/2SCX0JGREBCXwJGhIAAAAABQAAAAADXwLhAA8AHQAtAD0ATAAANyIuATY3AT4BHgIGBwEGBSIuATY3ATYyFhQHAQYBIi4BNjcBPgEeAgYHAQYBISImNRE0NjMhMhYVERQGASIGFREUMyEyNjURNCYj1AoPBwMGAlwGEBAMBAQG/aUJAQgJEAcDBwFXCRkSCP6qCv7KCRAHAwcBVwYQEAwFBQb+qQkCT/3IHCcnHAI4HCcn/awCAwUCOAIDAwIoCxESBgJvBQUEDBAQBv2TCgcKEhIGAWIJERkK/p8KAR4KEhIHAWEHBQQMEBEF/p4K/uInHAI4HCcnHP3IHCcCgAMC/cgFAwICOAIDAAAABQAAAAADGQLhABkAKQAzAEQAUAAAJSEiJicRNDY7ATU0PgEyHgEdATMyFhURFAYBIgYVERQWMyEyNjURNCYjJTM1NC4BIg4BFRMiJj0BLgE+Ah4BBgcVFAYnIg4BHgI+ATU0JgLV/lYcJgEnHCkuT15QLikcJif+OgIDAwIBqgIDAwL+vN4eMzwzHm8NEh0jBSo8MhIXGhIWBwsGAwoNDQgNICYbAWUbJysvUC4uUC8rJxv+mxsnAawDAv6bAgMDAgFlAgM9Kx40Hh40Hv57Eg0KCDI8LAYhOTgPEQ0SkQcNDgkDBQwHCQ0AAAAEAAAAAAMZAuQAGQAoADIARAAAJSEiJjURNDY7ATU0PgEyHgEdATMyFhURFAYBIhURFBYzITI2NRE0JiMlMzU0LgEiDgEVEyIvASY0NjIfATc2Mh4BDwEGAtX+VhwnJxwpLk9eUC4pHCYn/joFAwIBqgIDAwL+vN4eMzwzHkMNCUcJEhkJMngJGREBCY4IHScbAWQbJzEvUC4uUC8xJxv+nBsnAaoE/pwCAwMCAWQCAj4xHzMeHjMf/n0JSAkaEQgyeQgSGQmOCgAAAAACAAAAAAMWApYADAAZAAAlIiY0NwE2MhYUBwEGISInASY0NjIXARYUBgEJDRIJAe4JGhIJ/hIJAeENCf4SCRIaCQHuCRJqEhoJAe4JEhoJ/hIJCQHuCRoSCf4SCRoSAAADAAAAAANfAt8AGQAvADsAACUhIiY1ETQ2OwE1NDYzITIWHQEzMhYVERQGASMiBhURFDMhMjY1ETQmKwEiLwEmJwMjIiY0NjsBMhYUBgMc/cgcJyccBCccAaocJwQcJyf90CQCAwUCOAIDAwKODQk9AgFcjgwSEgyODRISISccAWMbJ5McJycc2icb/uQcJwGrAwL+nQUDAgEcAgMJPQEB/uMSGRISGRIAAAAAAQAAAAADUgJkABEAACUiLwEmND4BHwEBNh4BFAcBBgGoDQnbCBIYCsUBdQoYEgj+dQmcCdsJGREBCcUBdQkBERkJ/nUJAAAABAAAAAADPQK7AB8AMQAyAEAAAC0BIiY1EzQ2OwEyFgYrASIVAxQXBTI9ATQ2MhYVBxQGEyImPQEjIiY0NjsBMhYHFRQGJwEiLgE2NwE2Mh4BBwEGAv7+AhgjAiMY/xAQEBD/BAIEAf4EERcQASMJDBCDDA8QC44TGwERHP7zCA4GAwYBGwgWDwEH/uQHRAIjGQH+GCMcGwX+AwQBAgX/CxAQDP4ZIwGfEAuEERcPGxSNDA+g/uoJDxEFARkHEBYI/ugIAAMAAAAAA2YC5QAXADEAMgAAJSInLgEvASYvAS4BNDY3JTYeAgcDDgEDHwEeAT4BNxM2JyYHBSIGFzIfATc2HgEUByUCUggHEhoFWAED5hYbHBYCMxMpHgcJyQYkdVgBAQUDAQHLAQECBP3DAwIFAgLlXAkZEgn+ih8CBBkS5gMBWAYkLSMGygkHHikT/c0WHAEp4wUDAQIFAQI5AgIEAs0IAQFYXAkBERkJUAAFAAAAAANmAt4AcADcAN0A7AD1AAAlIyImPQE0LwEmDwEGIi8BJjQ/ATYnJicmKwEiJj0BNDY7ATI/ATYvASY0PwE2Mh8BFj8BNj0BNDY7ATIWHQEGHwEWPwE2Mh8BFhQPAQYfARYXMzIWHQEUBisBIg8BBh8BFhQPAQYiLwEmDwEGHQEOASceAR0BFDsBMj0BPgIWHwEWPwE2NC8BLgE+ATczMjY9ATQmKwEuAjY/ATY0LwEmIg8BDgEuASc1NCsBIh0BDgImLwEmIg8BBhQfAR4BDgEHIyIGHQEUFjsBHgIGDwEGFB8BFjI/AT4BJQciLgE0PgEyHgEVFA4CJyIGFBYyNjQmAiRIHCgDAwQDDhQ4EzQTEw8DAQEBAQQXHCcnHBUFAQECAw8UFDQUNxQPAwQDAygcSBwoAQUDBAMPEzgUMxQUDwMCAQIEFBwnJxwWBAEBAwMOFBQxFDgTDwMEAwMBJ5YTGAZJBQEYJigPDwQEMwICDg8HDyIVFwMDAwMUFSIQCA4PAgI0AQUBEA8pJhgBBUkGARcnKQ8OAgUCNAICDw4IECIUFgMDAwMWFSIQCA4PAgIzAQUCDw4qAVLpJkAmJkBMQCYVKDMcIC4uQC4uIyccFwQBAQICDhQUMxM4FA8DAwIBBCYcSBwoBAIEAw8UOBM0ExMPAwIBAQQEHCcnHBQEAgECAw8UFDQUNxQPAwQDAwEnHEgcKAMDAwQOFDgTNRMTDwMCAQEEBhsnmQghFRcGBgYUIhAIDg8DAzMCBQEPDygnFwEDA0cDAwEXJygQDgIFATUBAQ8OCBAiFRQGBgQVIg8HDw4CAjICBQEPDykmGAEDA0gDAwEXJygPDwIFATMCAg8PB1IiJkBMQCYmQCYcMygV2i5ALi5ALgABAAAAAANSAZ8ACwAAASEiJjQ2MyEyFhQGAzP9mg0SEg0CZg0SEgFhEhoSEhoSAAACAAAAAAMvAtEAGwA1AAAlIiYnNTQ2MhYdARYzITI2NzU0NjIWHQEOASchNy4BLwEmNDYyHwERNDYyFhURNzYyFhQPAQYBFBomAhIZEgIFAdMCBQESGRICKhv+LewMEgF5CRIaCU0SGhJZCRkSCYsJMCQaig0SEg2GBQMChg0SEg2KGyMBqAERDHkJGRIJTQFjDRISDf6SWAkSGQmKDQAABAAAAAADXwLfACMARgBWAGYAACUjIiY9ATQ2MhYdARQWOwEyNj0BNCYrASImNDY7ATIWHQEUBgEjIiY9ATQ2OwEyFh0BFAYiJj0BNCYrASIGHQEUOwEyFhQGBSEiJjURNDYzITIWFREUBgEiBhURFBYzITI2NRE0JiMDHNUbJxIZEgMC1QIDAwJqDRISDWocJyf+FmocJycc1RsnEhkSAwLVAgMFag0SEgEz/uQcJiYcARwcJib+yAIDAwIBHAIDAwIhJxxqDRISDWoCAwMC1QIDEhkSJxvVHCcBZCcb1RwnJxxqDRISDWoCAwMC1QUSGRLVJhwBHBwmJhz+5BwmAWMDAv7kAgMDAgEcAgMAAAAHAAAAAAM2AuIADQAQAB4AIQAlACkALQAAJSMiJjcTPgEeARURFAYnMxEBIyImNRE+AhYXExYGJzMLATMVIzUzFSM1MxUjAcncEBIF3AMUFg8SvpIBadwNEgEOFhME3AUSzZKSH8HBkJBgYCAaDwKCCwsEEQv9fg0SPgGr/hcSDQKCCxEEDAr9fg8aPgGr/sA+tj22PgAAAAYAAAAAA3ACwAALABsAHwAjADMANwAAJSEiJjQ2MyEyFhQGJyMiJjURNDY7ATIWFREUBiczESMHFSM1FyMiJj0BNDY7ATIWHQEUBiczNSMDUf1eDRISDQKiDRISYcENEhINwQwSEq6Dg5/BwcEMEhIMwQ0SEq+Dg0ESGRISGRKAEgwBwgwSEgz+PgwSPQGEwuDg/xIM4gwSEgziDBI9pAACAAD/+AM0AwoANQB7AAAFIyIuAj0BNC8BLgE+Axc1ND4CFxYXNTQ2Nz4BHgEdATYXHgEdATY3Nh4CFREUBw4BJRYdARQWOwEyNj8BNjURNCYOAR0BFgYiJicRNC4BBhURFAYrASImNRE0LgEGFREUBiImJxE2LgEGFREUDgEmLwEuAQ4BFwKl9R01KBYEPgwICRkkLRMOGR8RBQYPDRMxLRsREiAqBwcSIxsOChBI/n0QLyL1GikJAgMPEwwBEhkTAQsTEBIMAwwSDBMPEhoTAQEJDwsMExMFEgcYGAYICBYoNR0jBQVZECcnIBQBCcwQHxYKAQEBAxIhDBAIFCoZCAUCBDAgGAIBAgsYIRL+iRUSKTHgFBokIjAdGAQFBgF4Cg0CDgmsDBIRDQEWCQ0DDgr+6Q0SEg0BcAkOAg0K/o4NEhINAR4HCwEKB/7rChAGBggZCgcNGwwAAAAMAAAAAAOrAqUADAAXABgAJgAxAD0ASABVAGAAbAB7AIkAADciJy4CPgEeAg4BJyIHDgEeAT4BLgEnFyInLgE/AT4BHgEPAQY3Ii4BPgEeAQYHBiciDgEWFxY+ASYnJhMiLgE+AR4BBgcGJyIOARYXFj4BJicmIzcGLgE+AR4BBgcGJyIOARYXFj4BJicmASIvAS4BPgIWHwEWDgE3IicuAT8BPgEeAQ8BBsYLCx8uDRo3RTYUFjgiDgsOCQ4fIBIFGTtQCggKBQiFBxkVBAeFCaUsPgU4VkQNMSoLCg8ZCAoMECUVCA8Mvys/BDhWRA0xKgsLDxgJCwwQJRUIEAsNzCs/BjhWRA4xKgoLDxgJCg0QJRQHEAv+4Q4KXAYEBg0SEAVcCAITcwgHCwcGXgYZFgcHXQphAwYuQDslAipCQSiZCAkhHg4KHCIWEh0GBxkLvQsEDhoKvQ6xO1ZCCTVVRwkCmBIcHQgLCCAkCwf+cjtWQgk1VUcJApkSHRwJCgcgJQoIhgE7VkIKNVVHCQKYEhwdCAsIICQLB/7RC24GEhALAwgHbgoZDwEEBhgLpAsHDRkLpA4AAAIAAAAAA1oC2QAXACoAACUiJy4BJwMmPgIXBTMeAQ4BDwIGBwYnHgE2NTc+AT8BMz4BJyUmDgEVAekGBREbCPoJCB0pEwInAhQUCCEXwycFFxMgAwgHLAINCdgCBwMG/doCBAEqAQMSDwIpEykdBwj6CiotIQMnxB0RDkIEAQUE2QkNAiwBDQT5AQIEAQAAAAIAAAAAA18C3wAjADMAACUhIiY9ATQ2MhYdARQWMyEyNjURNCYrASImNDY7ATIWFREUBgEhIiY1ETQ2MyEyFhURFAYDHP6dGycSGRIDAgFjAgMDAvgNEhIN+BwnJ/7I/uQcJyccARwbJychJxz4DRISDfgCAwMCAWMCAxIZEicb/p0cJwEdJxsBHBwnJxz+5BsnAAAFAAAAAANwArAACwAXACMALwA7AAABISImNDYzITIWFAYHISImNDYzITIWFAYDISImNDYzITIWFAYnISImNDYzITIWFAYDISImNDYzITIWFAYDUf1eDRISDQKiDRISDf1eDRISDQKiDRISDf1eDRISDQKiDRISDf1eDRISDQKiDRISDf1eDRISDQKiDRISAnISGhISGhKIEhkSEhkS/u8SGRISGRKIEhoSEhoS/u8SGhISGhIAAAAABwAAAAADcAKxAAsAFwAjADAAPQBMAFwAACUhIiY0NjMhMhYUBiUjIiY0NjsBMhYUBiEjIiY0NjsBMhYUBgUiJjURNDYyFhURFAYjIiY1ETQ2MhYVERQGEyIvAS4BPgIWHwEWDgEhIi4BNj8BPgEeAgYPAQYDUf1eDRISDQKiDRIS/gW0DRISDbQNEhIB4bQNEhINtA0SEv6kDRISGhISDQ0SEhoSEnMPCYAFAwYNEBAFgAgDEv70CA8IAgWBBQ8RDQUCBYAKUBIaEhIaErYSGhISGhISGhISGhKVEgwCAg0SEg39/gwSEgwCAg0SEg39/gwSAWEMoAYRDwoDBgegChkPCRASB6AHBgMKDxEGoQsAAAAABwAAAAADcAKwAAsAFwAjADAAPQBKAFgAAAEhIiY0NjMhMhYUBgUjIiY0NjsBMhYUBiEjIiY0NjsBMhYUBgEiJjURNDYyFhURFAYjIiY1ETQ2MhYVERQGIy4CPwE+AR4BDwEGIyIvASY+ARYfARYGBwYDUf1eDRISDQKiDRIS/gW0DRISDbQNEhIB4bQNEhINtA0SEv6kDRISGhISDQ0SEhoSEg0LEgMIgAgZFAMIgAkPDwmBBwIUGgiACAMLCAJyEhoSEhoSthIaEhIaEhIaEhIaEv6UEg0CAgwSEgz9/g0SEg0CAgwSEgz9/g0SAQ4aCaEKAxAaCaEMDKEJGhADCqEKGQgGAAAABQAAAAADcAKwAAsAFwAjAC8AOwAAASEiJjQ2MyEyFhQGByEiJjQ2MyEyFhQGFyEiJjQ2MyEyFhQGByEiJjQ2MyEyFhQGFyEiJjQ2MyEyFhQGA1H9Xg0SEg0Cog0SEq3+ngwSEgwBYgwSEpT9Xg0SEg0Cog0SEq3+ngwSEgwBYgwSEpT9Xg0SEg0Cog0SEgJyEhoSEhoSiBIZEhIZEokSGhISGhKIEhkSEhkSiRIaEhIaEgAACAAAAAADcAKxAAsAFwAjAC8APABJAFgAZwAAJSEiJjQ2MyEyFhQGJSEiJjQ2MyEyFhQGJyEiJjQ2MyEyFhQGJyEiJjQ2MyEyFhQGEyImNRE0NjIWFREUBiMiJjURNDYyFhURFAYTIi8BLgE+AhYfARYOASEiLgE/AT4BHgIGDwEGA1H9Xg0SEg0Cog0SEv6G/ssNEhINATUMEhIM/ssNEhINATUMEhIM/ssNEhINATUMEhLUDRISGhISDQ0SEhoSEnMOCoAFAgYMEQ8FgAgDEv71CxIDCIAFEBANBgMFgAlQEhoSEhoSthIaEhIaErYSGhISGhK2EhoSEhoS/f8SDAICDRISDf3+DBISDAICDRISDf3+DBIBYQygBhEPCgMGB6EJGg4PGQqgBwYDCg8RBqAMAAAFAAAAAANwArAACwAXACMALwA7AAABISImNDYzITIWFAYHISImNDYzITIWFAYHISImNDYzITIWFAYHISImNDYzITIWFAYHISImNDYzITIWFAYDUf1eDRISDQKiDRISDf4/DRISDQHBDRISDf1eDRISDQKiDRISDf6fDRISDQFhDRISDf1eDRISDQKiDRISAnISGhISGhKIEhkSEhkSiRIaEhIaEogSGRISGRKJEhoSEhoSAAAFAAAAAANwArAACwAXACMALwA7AAABISImNDYzITIWFAYHISImNDYzITIWFAYXISImNDYzITIWFAYFISImNDYzITIWFAYFISImNDYzITIWFAYDUf1eDRISDQKiDRIS7v4/DRISDQHBDRIS1P1eDRISDQKiDRIS/rL+nw0SEg0BYQ0SEgE0/V4NEhINAqINEhICchIaEhIaEogSGRISGRKJEhoSEhoSiBIZEhIZEokSGhISGhIAAAAABwAAAAADYgK2AA0AEAAhACQAKAAsADAAAAEhIiY9ATQ2FwUeAQ4BJSElAyInJj0BNDYzIR4CBgcFBjcVLQEzFSM3MxUjNzMVIwNB/X4NEhoPAoILCwQR/ZIBq/5VHwoIDRINAoILEQQMCv1+BRoBq/6CPj55PT14Pj4BmBIN3BASBdwDFBYPPpL95gYJENwNEgEOFhME3ALckpIfwcGQkGAAAAAFAAAAAANwAqMACwAbAB8ALwAzAAABISImNDYzITIWFAYHIyImNRE0NjsBMhYVERQGJzM1IwMjIiYnET4BOwEyFhURFAYnMxEjA1H9Xg0SEg0Cog0SEmG9DRISDb0NEhKrgICfwQ0RAQERDcENEhKvg4IBYRIaEhIaEoASDQEADRISDf8ADRI9xP58Eg0CBg0SEg39+g0SPQHKAAAIAAAAAANwArAACwAXACMALwA8AEkAWABnAAABISImNDYzITIWFAYFISImNDYzITIWFAYHISImNDYzITIWFAYHISImNDYzITIWFAYzIiY1ETQ2MhYVERQGIyImNRE0NjIWFREUBiMuAj8BPgEeAgYPAQYHIi8BLgE+AhYfARYOAQNR/V4NEhINAqINEhL+hv7LDRISDQE1DBISDP7LDRISDQE1DBISDP7LDRISDQE1DBIS1A0SEhoSEg0NEhIaEhINCxIDCIAFEBEOBgQGgAkPDwmABgMGDREQBYAIAxICchIaEhIaErYSGhISGhK2EhoSEhoSthIaEhIaEhINAgIMEhIM/f4NEhINAgIMEhIM/f4NEgEOGgmhBwcCCxARBqELAQyhBhEQCgMHB6EKGQ8ABQAAAAADcALAAAsAGwAfAC8AMwAAJSEiJjQ2MyEyFhQGJyMiJjURNDY7ATIWFREUBiczESMDIyImPQE0NjsBMhYdARQGJzM1IwNR/V4NEhINAqINEhJhwQ0SEg3BDBISroODn8EMEhIMwQ0SEq+Dg0ESGRISGRKAEgwBwgwSEgz+PgwSPQGE/j8SDOIMEhIM4gwSPaQAAAAFAAAAAAMjAvAADAAcACAAMAA0AAAlIiY1ETQ2MhYVERQGEyEiJj0BNDYzITIWHQEUBiczNSMBISImPQE0NjMhMhYdARQGJSE1IQIADRISGhISc/8ADRISDQEADRIS7sTFAWX9+g0SEg0CBg0SEv4LAcr+Ng8SDQKjDRISDf1eDRMBkhINvQ0SEg29DRI+gP4CEg3ADRISDcEMEj6CAAAABAAAAAADcALEAAsAFwAnACsAACUhIiY0NjMhMhYUBgMhIiY0NjMhMhYUBgMjIiY1ETQ2OwEyFhURFAYnMxEjA1H9Xg0SEg0Cog0SEg39Xg0SEg0Cog0SEv7ADRISDcANEhKvhIQ8EhoSEhoSAkoSGhISGhL+NxINAUgNEhIN/rgNEj0BDAAAAAUAAAAAA3ACwAALABsAHwAvADMAAAEhIiY0NjMhMhYUBgEjIiY1ETQ2OwEyFhURFAYnMxEjBSMiJj0BNDY7ATIWHQEUBiczNSMDUf1eDRISDQKiDRIS/mbBDBISDMENEhKvg4MB48ENEhINwQwSEq6DgwKCEhkSEhkS/b8SDAHBDRISDf4/DBI9AYThEg3hDRISDeENEj6jAAAAAAUAAAAAA0AC8AAMABwAIAAwADQAACUiJjURNDYyFhURFgYDISImPQE0NjMhMhYdARQGJSE1IQEjIiY9ATQ2OwEyFh0BFAYnMzUjAyENEhIZEgESjv4/DBISDAHBDRIS/lEBhP58AaLhDRISDeENEhLOo6MPEg0Cow0SEg39Xg0TAY4SDcEMEhIMwQ0SPoP9/xIMwQ0SEg3BDBI9gwAAAAACAAAAAAMxAtEAFQAhAAAlIiYnCwEOAS4BNwE+ATIWFwEWBgcGJyEiJjQ2MyEyFhQGAxAKDwTz8wUYGAkFARAEDxIPBAEQBQkMBmj+rQ0SEg0BUw0SEjAKCAIk/dwMCQsXDAJjCAoKCP2dDBgFAssSGhISGhIAAAADAAD/vQNpAsgAFQAjAC8AACUiJicLAQ4BLgE3AT4BMhYXARYGBwYnISIuATQ+ATMhMhYUBhMhIiY0NjMhMhYUBgMQCg8E8/MFGBgJBQEQBA8SDwQBEAUJDAZs/qwIDggIDggBVAwSEpT9bAwSEgwClAwSEigKCAIk/dwMCQoYDAJjCAoKCP2dDBgFA8wJDhAPCBIaEv7KEhoSEhoSAAAABAAAAAADRQLwAAwAGQApAC0AACUiJjURNDYyFhURFAYhIiY1ETQ2MhYVERQGJSEiJj0BNDYzITIWHQEUBiUhNSEDJQ0SEhoSEv2pDRISGhISAbz+uA0SEg0BSA0SEv7JAQz+9A8SDQKjDRISDf1eDRMSDQKjDRISDf1eDRPyEg3ADRISDcANEj2EAAAFAAAAAANAAvAADAAcACAAMAA0AAA3IiY1ETQ2MhYVERQGASEiJj0BNDYzITIWHQEUBiUhNSETIyImPQE0NjsBMhYdAQ4BJzM1I98MEhIZEhICNf4/DRISDQHBDBIS/lEBhP58wuENEhIN4Q0SARHPpKQPEg0Cow0SEg39Xg0TAZISDcENEhINwQ0SPoL+ABINwA0SEg3BDBI+ggADAAAAAANgAuQAGgAkACwAACUhIicGLwEmNDcBNjIfARYUDwEGDwEzMhYUBgEXFjI/AScHBhc3Fzc2LwEmBwLe/uUNCRsUyRQUAXAUNhTJExPuAQJd4A0SEv31ywEDAWnRaQICldHbAwPJBAMdCQETyhQ2FAFwFBTLEzcT7QICXRIZEgERyQEBaNBpAwOaz9kDBMsDAwAAAAUAAAAAAuACmAAMABgAJAAxAD4AAAEiJj0BNDYyFh0BFAYlISImNDYzITIWFAYDIyImNDY7ATIWFAYTIiY9ATQ2MhYdARQGAyImNRE0NjIWFREUBgE/DBISGRISAXX+fgwSEgwBggwSEm3ADRISDcANEhJUDRISGRISzQ0SEhoSEgIKEg1QDBISDFANElASGRISGRL+DxIZEhIZEgGhEg1QDBISDFANEv5fEgwB8gwSEgz+DgwSAAAEAAAAAAOJAu8AFQAhAC4AOgAAJSImJwsBDgEuATcBPgEyFhcBFgYHBichIiY0NjMhMhYUBhMiJj0BNDYyFh0BFAY3IyImNDY7ATIWFAYCtQkQA/TzBRgXCgYBDwQPEhADARAFCQwGaP6tDRISDQFTDRISpAwSEhkSElnLDRISDcsNEhISCggCJP3cDAkKGAwCYggKCgj9ngwYBQLLEhoSEhoSAQgSDcsNEhINyw0SZhIZEhIZEgAAAwAAAAADGAK8ABEAHgAqAAABIiY0PwE2Mh8BFhQOAS8BBwYTIiY1ETQ2MhYVERQGEyEiJjQ2MyEyFhQGAXINEgmOCRoJjggSGAp4eAmBDRISGhIS7P4ODRISDQHyDRISAYUSGQmOCgqOCRkRAQl4eAn+wBINAc4MEhIM/jINEgI5EhkSEhkSAAEAAAAAA18CQgATAAAlIicBLgE+AhYXCQE2MhYUBwEGAgANCf7ABgQEDBAQBgEqASoJGhIJ/sAJwAkBQwYPEAwEBAb+0wEtCRIZCf69CQAAAgAAAAADUQLhABEAJgAAJSInASY0NwE2MhYUBwkBFhQGISYnASY0NwE+AR4CBgcJAR4BDgECEwwJ/r0JCQFDCRkSCf7TAS0JEgEQDAn+vAkJAUMGEBAMBAUG/tMBLQcDBw8hCQFACRoJAUAJEhoJ/tb+1gkaEgEIAUAJGgkBQAYFBQwQEAb+1v7WBxIRCwAAAwAAAAAC0AKyAAsAFwAlAAAlISImNDYzITIWFAYTISImNDYzITIWFAYDIy4BNxM+AR4BBwMOAQJQ/v8MEhIMAQENEhJU/v8NEhINAQEMEhLoBQ0OAmACFRoPAmECEVASGhISGhICIhIaEhIaEv3eAxUMAiIMDwQVDf3eCw4AAAADAAAAAAJlArwAEQAeACoAACUiLwEmNDYyHwE3Nh4CDwEGIyImNRE0NjIWFREUBhchIiY0NjMhMhYUBgFNDQmOCRIZCXl4CRkRAQmOCQwNEhIaEhLr/g8NEhINAfENEhKwCY4JGRIJeHgJAREZCY4JEgwBzg0SEg3+MgwSaxIZEhIZEgADAAAAAAMgAtgACwAnAEUAAAEhIiY0NjMhMhYUBiEiLgE+Ah4BFRQGIiY1NC4BDgIeATMyFhQGAy4CNTQ2MhYVFB4BPgIuASMiJjQ2Mx4CFA4BAwH9/g0SEg0CAg0SEv7yOFwrFk9tZj4SGRIpRUg0Dx09JQ0SEg0yVDESGRIpREg1Dx09JQ0SEg0xUS8vUQFhEhoSEhoSPmdtTxUqXTgMEhIMJT4cDzRIRCkSGhL+zwExVTIMEhIMJT4dDjRJRCkSGhICMlNhUzIAAAABAAAAAAMnAjkADwAAJRM+AS4BIyEiDgEWFxMWMgIe/QgDCRQM/gYMFAkDCP0MJNUBIgkXFQwMFRcJ/t4NAAAAAQAAAAACwQLfABEAACUiJwEmNDcBNjIWFAcJARYUBgKhDAn+vQkJAUMJGRIJ/tMBLQkSIQkBQAkaCQFACRIaCf7W/tYJGhIABQAAAAADdQKYABEAIwAvADwASQAAJSIvASY0PwE2Mh4BDwEXFhQGMyImND8BJyY0NjIfARYUDwEGNyEiJjQ2MyEyFhQGFyImNRE0NjIWFREUBiEiJjURNDYyFhURFAYBhw0JcwkJcwkZEQEJXV0KEuUNEgpdXQkSGQlzCgpzCWb+KA0SEg0B2A0SEl0NEREaEhL9Rw0SEhoREe4JcwkaCXMIEhkJXV0JGhISGgldXQkaEglzCRoJcwlzEhkSEhkS+RINAfINEhIN/g4NEhINAfINEhIN/g4NEgAAAAMAAAAAA4kC0QAXACMALwAAJSImJwsBDgIuATY3AT4BMhYXARYGBwYnISImNDYzITIWFAYBIyImNDY7ATIWFAYCtQkQA/TzAg4SEQoBBQEOBA8SEAMBEAUJDAZo/q0NEhINAVMNEhIBCssNEhINyw0SEjAKCAIk/dwJDAMIDxMHAmMICgoI/Z0MGAUCyxIaEhIaEgFuEhkSEhkSAAUAAP/6A1oDCQATAB0AKwA3AEUAAAUiJi8BLgE2NwE2MhcBFhQHAQ4BAwcGFB8BFjI/ASciLwEmPgEyHwEeAQ4BFwcGIi8BJjYzITIWFwcOAR4BMj4BNC8BJiIB0xUmD+wUDg4UAQsSMRIBLBER/vUPJxX9CAjrCBUH/m8RDOsLARYgDOsJBAkUYN4TNhPeBgcJAgQKBysrCAERHSEdEQkqBA8FEA/rFDY2FAEKERH+1hIxEv71DxACZf4IFQfsBwf+fwzsCyAXCuwIGBYNvN4TE94GERFUSg4iHBERHCIOSgYAAAMAAAAAAzwCmAARAB0AKgAAJSIvASY0PwE2Mh4BDwEXFhQGJSEiJjQ2MyEyFhQGBSImNRE0NjIWFREUBgHcDAmOCgqOCRkRAQl4eAkSATP+MgwSEgwBzg0SEv27DRISGRIS0wmOCRoJjggSGAp4eAkaEo4SGRISGRL5Eg0B8g0SEg3+Dg0SAAAEAAD/+gNaAwkAEwAdACsAOQAABSImLwEuATY3ATYyFwEWFAcBDgEDBwYUHwEWMj8BJyIvASY+ATIfAR4BDgETBw4BHgEyPgE0LwEmIgHTFSYP7BQODhQBCxIxEgEsERH+9Q8nFf0ICOsIFQf+cBAM6wsBFiAM6wkECRSSKwgBER0hHREJKgQPBRAP6xQ2NhQBChER/tYSMRL+9Q8PAmT+CBUH7AgI/n8M7AsgFwrsCRcWDf72Sg4iHBERHCIOSgYAAAAAAQAAAAADJwI5AA8AAAETHgEOASMhIi4BNjcTNjICHv0IAwkUDP4GDBQJAwj9DCQCK/7eCRcVDAwVFwkBIg0AAAUAAAAAA/AC0QAVACEAMgA9AFoAACUiJicLAQ4BLgE3AT4BMhYXARYGBwYnISImNDYzITIWFAYFIyIuATQ+ATsBMhYdARQOASciBhQWOwEyNj0BFyImNRE0LgErASYGBw4BLgE3PgEXMzIeARURFAYCTwkQA/TzBhYVCgMBDwQPEhADARAFCQwGbP6tDRISDQFTDRISAV41KkgqKkcrsQ0SKkdfJzc3JzUnNx4MEh4yHhYiOg0EFxgMBBRaNhcuTy4TMAoIAiT93AoGCRULAmMICgoI/Z0MGAUCyxIaEhIaEsglQExAJRINbCZAJdgtQC4uIE3bEg0BKhkqGAIlHwwMCRYMMzsBKUYq/tYNEgAABQAAAAADGAL1ABIAJAAxAD0ASQAAAQYuATY/ATYyHwEWFA4BLwEHBhMiLwEmND4BHwE3NjIWFA8BBiciJjURNDYyFhURDgEXISImNDYzITIWFAYDISImNDYzITIWFAYBjQoPBwMHcwkaCXMIEhkJXV0JZg0JcwgSGQldXQkaEglzCQ0NEhIaEgES7f4ODRISDQHyDRISDf4ODRISDQHyDRISAdsBCxETBnMJCXMJGREBCV1dCf6bCXIJGREBCV1dCRIZCXMJARIMAdgNEhIN/igNEWsSGhERGhICrREaEhIaEQAAAgAAAAADTwLhABMAJgAAJSImNDcJAS4BPgIWFwEWFAcBBiEiLgE2NwkBJj4BMhcBFhQHAQYB7Q0SCQEt/tMGBQQMEBAGAUMJCf69Cf7XCQ8HAwcBLf7TCQERGQkBQwkJ/r0JIRIaCQEqASoGEBAMBQUG/sAJGgn+wAkLERIHASoBKgkZEgj+wAkaCf7ACQAABAAAAAAC/gKIAAoAFAAeACYAACUhESE2HgEUDgEnJSEWPgE0LgEHITMhESEeAhQOASUzPgE0JicjAmT+pQFcKEgpKUgo/uEBHxgqGBgqGP7h2/7oARgnQSYmQf7+2yMvLyPbeAEnASdFUUYmAT0BFykvKRYBAScBKUJOQyg8ATJFMgIAAwAAAAADPAKYABEAHQAqAAAlIiY0PwEnJj4BMh8BFhQPAQY3ISImNDYzITIWFAYXIiY1ETQ2MhYVERQGAiQNEgl4eAkBERkJjgoKjgmC/jINEhINAc4MEhJeDBISGRIS0xIaCXh4ChgSCI4JGgmOCY4SGRISGRL5Eg0B8g0SEg3+Dg0SAAAAAAEAAAAAArkCpwAPAAABBR4BPgE1ETQuAQYHBQYUAVUBIgkXFQwMFRcJ/t4NAWL9CAMJFAwB+gwUCQMI/QwkAAABAAAAAANfAkAAEwAAJSInCQEOAS4CNjcBNjIXARYUBgNADQn+1v7WBhAQDAQEBgFACRoJAUAJEsAJAS3+0wYEBAwQDwYBQwkJ/r0JGRIAAAEAAAAAArkCpwAPAAABJS4BDgEVERQeATY3JTY0Aqv+3gkXFQwMFRcJASINAZ79CAMJFAz+BgwUCQMI/QwkAAABAAAAAALBAt8AEQAAJSImNDcJASY0NjIXARYUBwEGAV8NEgkBLf7TCRIZCQFDCQn+vQkhEhoJASoBKgkaEgn+wAkaCf7ACQAEAAAAAANfAt8AFAApADoAPQAAJSInJicmNDc2NzYyFxYXFhQHBgcGAyIHBgcGFBcWFxYyNzY3NjQnJicmAyIuATURND4BMh8BFhQPAQYTFTcCAF9STy8wMC9PUr5STy8wMC9PUl9PQ0EnJycnQUOeQ0EnJycnQUOQBw4JCBARB9UODtUIFX8hMC9PUr5STy8wMC9PUr5STy8wAoAnJ0FDnkNBJycnJ0FDnkNBJyf+MggOCQEcCQ4IBY4KIAqOBQECqlUABAAAAAADXwLfABIAIgAxAE0AACUiLwEmND8BNjIeAQ8BFx4BDgEFISImNRE0NjMhMhYVERQGASIGFREUMyEyNjURNCYjAyEiJjQ2MyEWPgE0LgEHIyImNDY7ATYeARQOAQGdDQlHCQlHCRkRAQkxMQcEBxABdv3IHCcnHAI4HCcn/awCAwUCOAIDAwLO/wAMEhIMAQAVJhUVJhUqDRISDSomQyYmQ9wJRwkZCUgIEhkJMDIGExIKuyccAjgcJycc/cgcJwKAAwL9yAUDAgI4AgP+eRIZEgEUJCokFAESGRICJEFMQSQAAAIAAAAAA2ECwgApAD4AACUiJyYnLgE3Njc+ARcWFxYXFg4BJicuAw4CHgM2Nz4BHgEHDgETIi8BLgI+Ah8BNz4BHgEPAQ4BAdxTSEYqLAcmJENEpktJMDIKAhAZFQEIQGN2bFAjEkJndWsnCRkTAgkte9kGBrEJDAMHDhEIlTwFGBcKBUcDEEUpJ0VGpkpHLi4OIiJBQlMMFQMQDTphPQoqVXFzYDkHLSwKAREZCjM3AUACRwINEhAKAgQ8lgwJChcLsgkKAAAABgAA/9cDfQMpAAsAHgAoADUAQQBPAAAFISImNDYzITIWFAYlIiYvASY0PwE2MhcBFhQPAQ4BJxYyPwEnBwYUFyUiLwEmNDYyHwEWFAYXBwYiLwEmNjMhHgEXBwYUHgEyPgE0LwEmIgNY/VAPFRUPArAPFRX+fhMjDdccHPQQLRABEBAQ8w4jIwcTB+f45wcHAXkPCtcLFh0L1woVU8oRMRLKBQYIAdcIBSgnBw8aHhoQCCcDDigVHhUVHhWHDg7XG08c9BAQ/vAQLhDzDg5PBwfm+OcHEwaEC9YLHhUL1gseFarLERHLBg4BDk1DDR4aDw8aHg1DBgAEAAAAAANfAt8AFAApADYAQgAAJSInJicmNDc2NzYyFxYXFhQHBgcGAyIHBgcGFBcWFxYyNzY3NjQnJicmAyImNRE0NjIWFREUBjchIiY0NjMhMhYUBgIAX1JPLzAwL09SvlJPLzAwL09SX09DQScnJydBQ55DQScnJydBQ08NEhIaEhKC/uINEhINAR4NEhIhMC9PUr5STy8wMC9PUr5STy8wAoAnJ0FDnkNBJycnJ0FDnkNBJyf+MRINAR4NEhIN/uINEo8SGhISGhIAAAAAAwAAAAADXwLnABIAIQAxAAAlIi4CND4DHgIVFAcGBwYDIg4BHgI+ATU0JyYnJgciJjUnND4BMh4BFRcUBiMCAEaBYjY1Y4GLgmI2MC9PUl9YkkMifK2iYScnQUNNDBIFBw4RDgkFEQ0pNWKCi4FjNQE2Y4BGX1JPLzACgGGjrHwiQ5JYTkRBJijZEQ3MCQ4JCA4IzQwTAAADAAAAAANfAt8AFAApADUAACUiJyYnJjQ3Njc2MhcWFxYUBwYHBgMiBwYHBhQXFhcWMjc2NzY0JyYnJhMhIiY0NjMhMhYUBgIAX1JPLzAwL09SvlJPLzAwL09SX09DQScnJydBQ55DQScnJydBQ0D+4g0SEg0BHg0SEiEwL09SvlJPLzAwL09SvlJPLzACgCcnQUOeQ0EnJycnQUOeQ0EnJ/7AEhoSEhoSAAAABAAAAAADPQK7AB8AMwA0AEMAAC0BIiY1EzQ2OwEyFgYrASIVAxQXBTI9ATQ2MhYVBxQGATIWHQEzNh4BFA4BJyMiJj0BNDYXATYWFAcBDgEuAjY3ATYC/v4CGCMCIxj/EBAQEP8EAgQB/gQRFxABI/7nDBCDCA4ICA4IjRMaEB0BEgsQCP7lBQ4QCwMFBgEaCEQCIxkB/hgjHBsF/gMEAQIF/wsQEAz+GSMB6BALhAEHDg8OBwEbEo4LEJ8BKAERFwj+6AYFAwsQDwQBGQgAAAMAAAAAA2AC3wAtAE0AUQAAJSMiJw4BKwEiJjURNDY7ATIWHQEzMjY3Njc+ATsBHgIVFgczMh4BFRQPAQ4BJzMyNj8BNiYnJisBIiY3NicuASsBIgYHBgcOASsBERYHMxEjAnuWPzsDEAqODRISDY4NEhsNFQQUEwg8JgYeMh8CA0YcLxsDOg9d0ZYmPAo5AgUHDBFnDRIBBgIBHRUFERoEFBUKNSEbOshRUSEVCQwSDQGrDBISDAUPDDtOJTABHTIeJUMbLxwMDOg5ST4vJegKFAgMFA1BQhQdFRBUOx8m/s8YAQFtAAADAAAAAANfAt8AIwAzAEMAACUhIiY9ATQ2MhYdARQWMyEyNjURNCYrASImNDY7ATIWFREUBichIiY1ETQ2MyEyFhURFAYBIgYVERQWMyEyNjURNCYjAxz+5BsnEhkSAwIBHAIDAwKxDRISDbEcJyfx/p0cJyccAWMbJyb+gQIDAwIBYwIDAwIhJxyxDRISDbECAwMCARwCAxIZEicb/uQcJ9YnGwFjHCcnHP6dHCYBqgMC/p0CAwMCAWMCAwAAAAADAAAAAANfAt8AIwAzAEMAAAEjIiY1ETQ2MyEyFh0BFAYiJj0BNCYjISIGFREUFjsBMhYUBgEhIiY1ETQ2MyEyFhURFAYBIgYVERQWMyEyNjURNCYjAZWxHCcnHAEcGycSGRIDAv7kAgMDArENEhIBev6dGycmHAFjHCcn/oECAwMCAWMCAwMCAT4nGwEcHCcnHLENEhINsQIDAwL+5AIDEhkS/uMnHAFjHCYnG/6dHCcBqwMC/p0CAwMCAWMCAwADAAAAAAOMAp4ADAAZAD0AADcGJjQ3ATYeAgcBBiEiJwEmND4BFwEWFAYBFSM2NzY3Njc2NzYmIgcGFyc+ATc2FzYXFhUUBwYHBgcOAQdjDRIJAe8JFxACCP4TCQHiDQn+EQgSGQkB7QkRAS2yAw4ZIBcTCgEBFR0LCwEzAQ4NGyEjGhcGCAwQEhgMBBMBExkJAe4IAhEXCf4SCQkB7gkZEQEJ/hIJGRIBri8cFyMcFBcOEQ8VCg4SBREfDBMBAhYWHxEREhASDxYOCAADAAAAAANgAt8ALQBOAFIAACUjIiYnJicuAScjFRQGKwEiJjURNDY7ATIWFzY7ATIWHwEWFRQOASsBFgcOAicyNjc2JyY2OwEyNz4BLwEuASsBIgcRMzIWFxYXHgE7ASUzESMCRQYmPAgTFAQVDRsSDY4NEhINjgoQAzs/ljtdDzoDHC8bRgMCAR4zHRQdAQIGARIOZhEMBwYDOQk8JpY+OhshNQsUFQMaEQX+mlFRITAlTjoMDwEFDRISDQGrDRIMCRVJOegMDBwvHDYyHjEdPRwVQUINFAwHFQrnJS8Y/s4mHzxSERXWAW0AAAMAAAAAA18C4AAfACgARAAAJSEiJjURNDY7ATU0NjIWHQEzNTQ2MhYdATMyFhURFAYBERQzITI2NRElITU0JisBFRQOASIuAT0BIxUUBiImPQEjIgYVAxz9yBwnJxxvEhoS3hIaEm8cJyf9pwUCOAID/b4CQgMCbwgPEA4J3hIaEm8CAyEnHAHxHCcpDBISDCkpDBISDCknHP4PHCcBiP67BQMCAUU9bwIDKQgOCQkOCCkpDRISDSkDAgAABQAAAAADPAK2ABMAJwA0AEQAVAAAASMiJjQ2OwEyNj0BNDYyFh0BFAYhIyImPQE0NjIWHQEUFjsBMhYUBhciJjURNDYyFhURFAYDIi4BNj8BPgEeAgYPAQYzIi8BLgE+AhYfAR4BDgEC+WsNEhINawIDEhkSJ/5eaxsnEhkSAwJrDRISgQ0SEhoSElYJEAcEBpIGEBEMBAUGkgmFDQmSBgUEDBEQBpIGBAcQAaMSGRIDArIMEhIMshsnJxuyDBISDLICAxIZEkcSDAEdDBISDP7jDBL+7woREgeSBgUEDBAQBpIJCZIGEBAMBAUGkgcSEQoAAAMAAAAAA4wCPgAMABkAPQAANwYmNDcBNh4CBwEGISInASY0PgEXARYUBiUVIzY3Njc2NzY3NiYiBwYXJz4BNzYXNhcWFRQHBgcGBw4BB2MNEgkB7wkXEAII/hMJAeINCf4RCBIZCQHtCREBLbIDDhkgFxMKAQEVHQsLATMBDg0bISMaFwYHDRARGA0EEwETGQkB7ggCERcJ/hIJCQHuCRkRAQn+EgkZEikvHBcjHBQXDhEPFQoOEgURHwwTAQIXFR8SEBMPEhAWDQgAAAgAAAAAA2AC3wAUACsAPwBTAGAAbQB8AIsAABMiJj0BNDY7ATIWFAYrASIGHQEOASEiJj0BNCYrASIuATQ+ATsBMhYdAQ4BASMiJj0BNDYyFh0BFDsBMhYUBiMlIyImNDY7ATI2PQE0NjIWHQEOASciLwEmNDYyHwEWFAYlIiY0PwE2MhYUDwEGASImND8BPgEeAgYPAQYjIi8BLgE+AhYfARYUBsANEiccjw0SEg2PAgMBEQJzDRIDAo4IDgkJDgiPHCcBEv4ljhwnEhoSBY8NEhINAamODRISDY8CAxIaEgEnCQwJywkSGgnLCRP9iA0SCcsJGRIIywkBkwwSCcsFERAMBAUGygnjDQnLBgUFCxEQBssJEgHvEg2OHCcSGhIDAo8MEhINjgIDCA8QDgknHI8NEf4yJxyODRISDY8FEhoSARIaEgMCjg0SEg2PHCYLCcsJGRIJywkZEwESGQnLCBIYCcsJAaASGQnLBwQEDBAQBssJCcsGEBAMBAQHywkZEgACAAAAAAMYAt8AFQAkAAAlIi4BNRE0NjMhMhYVERQOASIvAQcGNzIfARE0JiMhIgYVETc2AQcIDgknHAGqHCcJDhAH6uoH8QgHywMC/lYCA8sHIQkOCAJcHCcnHP2kCA4JBIaGBMwEcwImAgMDAv3adAMAAAgAAAAAA2EC4QAUACoAPwBTAGAAbQB8AIsAACUiJj0BNCYrASImNDY7ATIWHQEUBgMjIi4BND4BOwEyNj0BNDYyFh0BFAYTIiY9ATQ2OwEyFhQGKwEiBh0BFAYTIyImPQE0NjIWHQEUFjsBMhYUBhMiLwEmNDYyHwEWFAYhIiY0PwE2MhYUDwEGASImND8BPgEeAgYPAQYjIi8BLgE+AhYfARYUBgGODRIDAo4NEhINjhwmEjCOCA8ICA8IjgIDEhkSJt0NEiccjgwSEgyOAgMSpY4cJxIaEgMCjgwSEh8NCcsIEhkJywkS/XMNEgnLCRkSCMsJAagNEgnLBhAQDAUFBssJ9w0JywYFBQwQEAbLCRI8Eg2OAgMSGRInG44NEgGHCA4RDggDAo4NEhINjhsn/nkSDY4bJxIZEgMCjg0SAYcnG44NEhINjgIDEhkS/l4JywkZEgjLCRoSEhoJywgSGQnLCQG1EhoJywYFBQwQEAbLCQnLBhAQDAUFBssJGhIAAAAEAAAAAANdAt0AIAA2AEoASwAAJSImJy4BNj8BPgEXJjY/AT4BHgIGDwEOAScWBg8BDgEnFjI/AT4BJwcGIiY0PwEmBg8BBhQXARY2PwE2LgIPAQ4BFzc2HgIHFwFFHzkWHhUVHlkfVCkMFB9ZHlFQPBUVHlkfVCkMFB9ZFjljHE8cWBYKDS4JGhMKLRs7FVkbGwE1GzwWWRoBNk4cWBYKDR0JFxACB2cpGBYeUFEeWR8UDClUH1keFRU8UFEeWR4VDClUH1kWGFkbG1kWPBsuChMaCS4MChVYHE8cAQoNChZYHE42ARpaFjwbHQcCEBcJIAAACAAAAAADXwLfAA8AEwAkACgAOAA8AE0AUQAAJSMiJj0BNDY7ATIWHQEUBiczNSMHIyImPQE+ATsBMhYdARQGIyczNSMlIyImPQE0NjsBMhYdAQ4BJzM1IwcjIiY9ATQ2OwEeAR0BFAYjJzM1IwNA+Q0SEg35DRIS57y8rPoNEgESDPkNEhIN2ru7AmH5DRISDfkNEgES5ry8rPoNEhIN+QwSEgzau7shEg35DRISDfkNEj67+RIN+QwSEg34DRI+u48SDfgNEhIN+QwSPbv4Eg34DRIBEgz5DBI9uwAAAAAJAAAAAANjAsMALABDAE8AWwB+AI0AmgCjAKwAACUiJicmPgEWFx4BPgMuAg4CBw4CLgI3Njc2NzYWFxYXFgYHBgcGIwEiJi8BJj4CHgEfATc2HgIOAQ8BBhcGLgE+Ah4BFRYGJyIOAR4CPgE1NCYHIiYnJjYeAjMyNj0BNC4BIg4BFgYiJjUmPgEyHgEHFRYGMyImPQEmPgEyHgEHFRQGJyIGFxUGFjYnNTQmIxciJjQ2MhYUBiciBhQWMjY0JgIkRHwtCAETGggnbHRnQhIjT211ZEAHAQoPEQ0HAQsxMElMpkRDJCYHLCpGSVP+5AkQA0cEAgoQEA4DO5YIEQ0GAgsIsgbTEh0OBxgiIBMBIRcIDgcDCxAPCQ8KEh0FBAwSBQ0ICg8GDA4MBwEJDQkBDxofGw4BASFTExwBDBcbFg0BHBQHCgECEhIBCgdRCxAQFg8PCwMEBAUEBEU4MwkaEQIKLCwGOmBycVUqCjxiOggNBwIKDwlSQ0AiIw4uLkdKp0ZEKCkBQAoJsgcRDQcDCgiVOwMBCw8RDQNHAk0BEyAiGQcNHREYIVMIDxALBAYOCAoPhRURCA8EEQkQCjMHDAgIDA4JCQcPHBAQHA8yGCIcFEUNGA0NGA1FEx2FCgdECwsLC0UHChwPFw8PFw8hBAUEBAUEAAABAAAAAAMyAuYARQAAJQYuATY/AT4BFh8BHgEGDwEOASYvAS4BNj8BPgEeAgYPAQYUHwEWMj8BPgEmLwEuAQ4BDwEOAR4CNj8BNjIWFA8BDgEBy0t9Oh415SFZWSIDIhcXIu8UNDQUAhMODRP7BhERDQQGCPoNDQEMIQzwFRAQFQMQKSwpEOQkGRlIX2AjjQkZEgmLI1shAVOLlDTlIhgWIQMiWloh8BMODBMDEzQ0FPsHBgQMEhEF+gwiDAILC/EWOjsWAhAQAREQ5SRfYEcZGSSMCRIZCY0jJQAABQAAAAADhAJHACUAMwBEAFMAYQAAASInJicmLwEmPgEeARcWFxYXFjMyNzY3Njc+AR4BBwYHBgcGBwYlIi4BNj8BPgEeAQ8BBiEiLwEuAT4CFh8BHgEOASMFIicuAT8BPgEeAQ8BDgElIi8BJj4BFh8BFgYHBgIAY1ZAMxsUAQYIFxgKDxkfKzA9QVVLNiwYCgYYFwgGBBMdJDI6R/5NCQ8HAwZfCRgSAgdgCQK6DglgBgUFDREQBl8GAwcPCf3yBwYMCQY7BRgWCQQ7BA8BSxEJTQYGFRgHTQcFCwgBMjYoQSIjAgwYCwgWFSUfKhgfMyQ6HxULCAsYDAodKyQxHCMFChESBmkIARAYCmkKCmgGERAMAwYHaQcSEQp6AwUYDIELCQsXC4IICgoOeAoZDQUKeAsYBwUACQAAAAADYQLCACkAPgBHAFMAdACBAI4AmgChAAAlIicmJy4BNzY3PgEXFhcWFxYOASYnLgMOAh4DNjc+AR4BBw4BEyIvAS4CPgIfATc+AR4BDwEOAQUiJjQ2MhYUBiciDgEeAj4BNTQmByImJyY+ARYXHgE+AT0BNCYiBhUUBiImNTQ2MhYdARYGMyImPQE0NjIWHQEUBiciBh0BFBYyNj0BNCYXIi4BPgIeARUUBiciBhY2NCYB3FNIRiosByYkQ0SmS0kwMgoCEBkVAQhAY3ZsUCMSQmd1aycJGRMCCS172QYGsQkMAwcOEQiVPAUYFwoFRwMQ/okZIyMyIyMZCQ4HAw0REAoRDBMfBgIGDAwCBBITDhEYEQkNCSMyIwEkXBUeHiseHhYIDAwQDAxSCQ4GAwwRDwoRCwUEBwkERSknRUamSkcuLg4iIkFCUwwVAxANOmE9CipVcXNgOQctLAoBERkKMzcBQAJHAg0SEAoCBDyWDAkKFwuyCQpKIzIjIzIjWQoQEQ0DBw4JDBGPFxIGDAQGBgkJAxAKNAwREQwGCQkGGSMjGTQaJB4VSBUeHhVHFh6PDAhHCQwMCUcIDB4JEBEMAwcOCAwQIwkHBAgEAAAAAgAAAAADUgLSAAwAGAAAJSImNRE0NjIWFREUBgEhIiY0NjMhMhYUBgIADRISGhISASb9mg0SEg0CZg0SEi4SDQJmDRISDf2aDRIBMxIaEhIaEgAABQAAAAADNgK8ABQAKAA0AEEATgAAASImPQE0JisBIiY0NjsBMhYdARQGAyMiJjQ2OwEyNj0BNDYyFh0BFAYTISImNDYzITIWFAYFIi8BJjQ2Mh8BFhQGIyImND8BNjIeAQ8BBgG/DRIDArIMEhIMshsnEjCyDBISDLICAxIZEidQ/uMMEhIMAR0MEhIBBQ0JkgkSGQmSChOeDRIJkgkZEQEJkgkB7xINawIDEhkSJxtrDRL+VhIZEgMCaw0SEg1rGycBHBIaEhIaEkkJkgkaEgmSCRoSEhoJkggSGQmSCQAEAAAAAANkAnUAHgA0AEEASgAAJSInJicmLwEmNzY3Njc2MzIXFhcWHwEWDwEGBwYHBiUWFxYXFjI3Njc2NyYnJicmIgcGBwYFIi4BPgIeARUUDgEnIgYUFjI2NCYCAGRXPzQbEgEHBw0cM0BZZ2RXPzQbEgEHBwESGzQ/V/5/FhwsM0OSQzMsHRUWHCwzQ5JDMywcAQcfNBcMLDw6IhsvHBEYGCIYGIw3KEEiIwEODhslQyk6NyhBIiMBDg4BIyJBKDf0IyAxHSYmHTEgIyMgMR0mJh0xIIkiOjwsDBc0HxwvG48YIhgYIhgAAAQAAAAAAy8C0QARADAANAA4AAAlISImNRE0PwE2MyEyFhURFAYnMzI1ETQrARUUBisBIiY9AQcRFBY7ATU0NjMhMhYVBTM1IxMzNSMC7v4kGiYJiAgNAXYaJiZhRwMDaRINzA0SbAIBRxINARANEv7w0tIijo4wJhoBugwJiQkmG/3gGiY9AwIfBGkNEhINX2z+UwECrQwSEgytjgFNSwAGAAAAAANOAtIAGQAnADcAOwBIAFUAAAEhIiY9ATQ2OwE1NDY7ATIWHQEzMhYdARQGJSE1IyImPQEjFRQGKwEBISImNxM+ATMhMhYXExYGJSEnIRciJj0BNDYyFh0BFAYzIiY9ATQ2MhYdARQGAy79pA0SEg3XEg1wDRLXDRIS/bYCH9gMEjQSDNgCI/3aDhMCJAERDAHgDBEBJAIT/e8B4Bv+VnwNEhIaEhKlDRISGhISATkSDK4NEo8NEhINjxINrgwSPm8SDY+PDRL+SRUOAQoLDw8L/vYOFT3N+BIMawwSEgxrDBISDGsMEhIMawwSAAAAAgAAAAADGgLhABQAIQAAASIvAQcOAS4CNj8BNjIfAR4BDgEBIiY1ETQ2MhYVERQGAvkNCePjBhAQDAQEBvkJGgn5BwQHEf75DBISGRISAakJ5OMGBQQMEBEF+QkJ+QYTEgr+dxIMAoANEhIN/YAMEgAAAAAEAAAAAAMYAt8AFAA4AEgAUgAAJSImNRE0JisBIiY0NjsBMhYVERQGByEiJicRPgE7ATIWFAYrASIGFREUFjMhMjY9ATQ2MhYdAQ4BAyMiJj0BNDY7ATIWHQEUBiczNTQmKwEiBhUC+Q0SAwJqDRISDWocJxIx/lYcJgEBJhxqDRISDWoCAwMCAaoCAxIaEgEmhtYMEicbjhsnEsOYAwKOAgOKEg0BrAIDEhoSJxz+VA0SaSccAfEcJxIaEgMC/g8CAwMCjg0SEg2PHCYB8hINahwnJxxqDRI9TAIDAwIAAAMAAAAAA2QCuwAoADgAPAAANyImNRE0NjsBMh8BFjsBMhYdARQGIiY9ATQmKwEiLwEmKwEiBhURFAYpASImNxM+ATMhMhYHAw4BJSETIcQMEicbjxwTVgECuBwmEhkSAwK4HBNWAQKPAgMSAgT97BETB48EDwkB8hASBWwDEP4QAdBW/k1FEg0CFBsnE1YBJxxqDRISDWoCAxNWAgMC/ewNEhwPAUAIChoP/sEKCz0BAwAAAAMAAAAAA2YC3wAPABsAMAAAJSEiJjURNDYzITIWFREUBiUWMyEWNxEmByEmBwEiJjURJiMhIiY0NjMhMhYVERQGIwJ0/nYhLy8hAYoiLi7+QgkJAYoLCAgK/nUKCAJvDRIJCf5FDRISDQG7IS8SDCEnHAGqHCYmHP5WHCdDBQEHAagHAQEI/oASDQHxBRIaEicc/g8NEgAAAwAAAAADFwLfABMAJQAoAAAlISImJxE+ATsBMjMWHwEWFxEUBgEiBhURFBYzITI2NREjIiY9ARczJwLV/lYcJgEBJhz8AgIIBtYFAib+OwIDAwIBqgIDtg0SPW1tISccAjgcJwIG1wUI/nEbJwJ/AwL9yAIDAwIBaBINtphtAAACAAAAAANhApoAEwAfAAAlIiY0PwEnLgE+AhYfARYUDwEGNyEiJjQ2MyEyFhQGAkkNEgnj4wYFBAwQEQX5CQn5Cen9gAwSEgwCgA0SEmgSGgnj4wYQEAwEBAb5CRoJ+Qn1EhkSEhkSAAIAAAAAA2ECmgATAB8AACUiLwEmND8BPgEeAgYPARcWFAYlISImNDYzITIWFAYBtwwJ+QkJ+QUREAwEBQbj4wkSAX79gA0SEg0CgAwSEmgJ+QkaCfkGBAQMEBAG4+MJGhL1EhkSEhkSAAAAAAIAAAAAAxoC4QAVACIAACUiLwEuAT4CFh8BNz4BHgIGDwEGJyImNRE0NjIWFREUBgIADQn5BgQEDBAQBuPjBhAQDAQEBvkJEgwSEhkSEiAJ+QUREAwEBQbj4wYFBAwQEQX5CQQSDQJ/DBISDP2ADREAAAAABAAAAAADPALiAB0ALgBIAFgAACUiJy4BJyYnAyY+Ah4BFxM2Nz4BFx4BFxYOAQcGJxYXFjc+AScmJyYOAR8BFhcFIicuAjc+ATc2FhcWFxM+AR4BBwEOAQcGNyIHBgcGFhcWNzY3NiYnJgLNFBIbKgsDA/wDAgkPEA4D0RAcFCoUHCkLEAMiHRVSDRwSERYMDQ0hESQOBwYDAf6dGBUcIQMOCykbFSsUHBDRBRgXCQX+/QspGxMDCQkfDQwMFRERIAwNDRQIIQcLKhsICQIqCBAOBgEKB/41Gw0JAggLKRsjSDkOC2cbDAgICjoeIQ4HEDEbDQMEaAsOOUcjHCkLCAIJDhsBzAsJChgM/cUbKgsH1gMOIB47CggIDSAeOwoEAAAAAAMAAAAAA4wCPgAMABkAPQAANwYmNDcBNh4CBwEGISInASY0PgEXARYUBiUVIzY3Njc2NzY3NiYiBwYXJz4BNzYXNhcWFRQHBgcGBw4BB2MNEgkB7wkXEAII/hMJAeINCf4RCBIZCQHtCREBLbIDDhkgFxMKAQEVHQsLATMBDg0bISMaFwYHDRARGA0EEwETGQkB7ggCERcJ/hIJCQHuCRkRAQn+EgkZEuIvGxcjHRMYDRIPFAoOEgURIAsTAQMXFSARERIPEw8WDgcAAAMAAAAAA18C3wAiADIAQgAAJSEiJjURNDY7ATIWFAYrASIGFREUMyEyNj0BNDYyFh0BFAYTISImNRE0NjMhMhYVERQGASIGFREUFjMhMjY1ETQmIwJH/p0cJycc+A0SEg34AgMFAWMCAxIZEie6/uQbJycbARwcJyf+yAIDAwIBHAIDAwIhJxwBYxsnEhkSAwL+nQUDAvgNEhIN+BwnAR0nGwEcHCcnHP7kGycBYwMC/uQCAwMCARwCAwAAAwAA//wDtwMEABMAIQAqAAAlAS4BByYGBwEGHgI3IRY+ATQnATQ+ATIeARURFAYiJjUXIi4BNjIeAQYDrf6JBh0REB0G/oAGAhIYCAMJChYRCv4fDhgcGA4eLB40FyEBIS8hASJaAokPEQICEQ/9aAcbHQ8DAhAdIg4BvA4YDg4YDv70FR8fFcghLyEgLyIACQAAAAADXwLmABwANwBEAFAAXABpAHYAgwCSAAAlIi4BNj8BNjIWFA8BDgEeAjY/ATYyFhQPAQ4BASImND8BNi4CDwEGIiY0PwE+AR4CBg8BBiUiJj0BNDYyFh0BFAYHIyImNDY7ATIWFAYFIyImNDY7ATIWFAYHIiY9ATQ2MhYdARQGNyIvASY0PgEfARYUBiUiJjQ/ATYyHgEPAQYnIi8BLgE+AhYfARYUBgE4KkUgEB50CRkSCXQOCwsdJycPcwkaEglzFDMBTQ0SCXQUASs9F3MJGhIJcxpHSDQTExp0Cf7pDBISGRISm0cNEhINRw0SEgIsRw0SEg1HDRIS4g0SEhkSEpwMCUcIERgJRwkR/rQNEglHCRkRAQlHCb4NCUcGBQQMERAFSAkTPi5NUh10CRIZCXQOKCcdCgoPcwkSGQl0ExUBPBIZCXQXPCsCFXQJEhoJdBoTEzRHRxp0Cd4SDUcMEhIMSA0RjhIZEhIZEtYSGhISGhLVEg1HDRISDUcNEi0JRwkYEQEHRwkaEvgSGglHCBIYCkcJ+QlHBhARCwUFBkcJGhIAAAADAAAAAANDAsQAFgAkADIAACUiJwEmNDc+ARc3NjIfARYUDwEWBgcGCQE+AScmPwEnBwYnJgYDIi4BNj8BNh4CDwEGAlYNCf6GCQkzh0Z7CRkJzgkJewosMgn+pwFLIBcLAwtwonAMEDNlQgkQBwQHnwkZEQEJnwk9CQF6CRoJMiwLewkJzgkaCXtGhzIJAZf+tSllMxAMcKJwCwMLF/5YChETBp8JAREZCZ8JAAAAAAAAEgDeAAEAAAAAAAAAEwAAAAEAAAAAAAEACAATAAEAAAAAAAIABwAbAAEAAAAAAAMACAAiAAEAAAAAAAQACAAqAAEAAAAAAAUACwAyAAEAAAAAAAYACAA9AAEAAAAAAAoAKwBFAAEAAAAAAAsAEwBwAAMAAQQJAAAAJgCDAAMAAQQJAAEAEACpAAMAAQQJAAIADgC5AAMAAQQJAAMAEADHAAMAAQQJAAQAEADXAAMAAQQJAAUAFgDnAAMAAQQJAAYAEAD9AAMAAQQJAAoAVgENAAMAAQQJAAsAJgFjQ3JlYXRlZCBieSBpY29uZm9udGljb25mb250UmVndWxhcmljb25mb250aWNvbmZvbnRWZXJzaW9uIDEuMGljb25mb250R2VuZXJhdGVkIGJ5IHN2ZzJ0dGYgZnJvbSBGb250ZWxsbyBwcm9qZWN0Lmh0dHA6Ly9mb250ZWxsby5jb20AQwByAGUAYQB0AGUAZAAgAGIAeQAgAGkAYwBvAG4AZgBvAG4AdABpAGMAbwBuAGYAbwBuAHQAUgBlAGcAdQBsAGEAcgBpAGMAbwBuAGYAbwBuAHQAaQBjAG8AbgBmAG8AbgB0AFYAZQByAHMAaQBvAG4AIAAxAC4AMABpAGMAbwBuAGYAbwBuAHQARwBlAG4AZQByAGEAdABlAGQAIABiAHkAIABzAHYAZwAyAHQAdABmACAAZgByAG8AbQAgAEYAbwBuAHQAZQBsAGwAbwAgAHAAcgBvAGoAZQBjAHQALgBoAHQAdABwADoALwAvAGYAbwBuAHQAZQBsAGwAbwAuAGMAbwBtAAACAAAAAAAAAAoAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIoBAgEDAQQBBQEGAQcBCAEJAQoBCwEMAQ0BDgEPARABEQESARMBFAEVARYBFwEYARkBGgEbARwBHQEeAR8BIAEhASIBIwEkASUBJgEnASgBKQEqASsBLAEtAS4BLwEwATEBMgEzATQBNQE2ATcBOAE5AToBOwE8AT0BPgE/AUABQQFCAUMBRAFFAUYBRwFIAUkBSgFLAUwBTQFOAU8BUAFRAVIBUwFUAVUBVgFXAVgBWQFaAVsBXAFdAV4BXwFgAWEBYgFjAWQBZQFmAWcBaAFpAWoBawFsAW0BbgFvAXABcQFyAXMBdAF1AXYBdwF4AXkBegF7AXwBfQF+AX8BgAGBAYIBgwGEAYUBhgGHAYgBiQGKAYsACWFsbC1tYXRjaAdyZXBsYWNlCHNob3VjYW5nC3JlcGxhY2UtYWxsB3poaWh1YW4Gc2hhcGVzDnRleHQtdW5kZXJsaW5lEHNoYXBlLWNoYW5nZXNpemUPc2hhcGVzLWNhdGFsb2d5B2V4cGFuZDEOcHJpbnQtZGlzYWJsZWQFcHJpbnQGdW5sb2NrBmVtYWlsMQ1ib3JkZXItcGVuY2lsCmNvcHktZmlsZTEOYWRkLWZpbGUxLWljb24PYWRkLWZvbGRlci1pY29uDWFkZC1maWxlLWljb24EZmlsZQZsYXllcnMMY2FuY2VsLW1lcmdlBnJlbW92ZQthLXppeXVhbjQwOAVtZXJnZQ5lZGl0LXByb3BlcmllcwthLXppeXVhbjM5NQVwaG9uZQR1c2VyBnNlYXJjaApiYWNrZ3JvdW5kBGxvY2sGbG9ja2VkBWNsb3NlDGNvbnRyb2wtaWNvbgJvawVzaGFyZQdwdWJsaXNoB3NldHRpbmcGcmVkdWNlCGRvd25sb2FkBm1lcmdlMQRmbGlwBWFsaWduBGhhbmQJbGluay1saW5lCHNlbGVjdG9yCHBvc2l0aW9uBmFuY2hvcgdtb3ZlLXVwCW1vdmUtZG93bgpmb250LWFsaWduCG1vdmUtdG9wEHRleHQtYWxpZ24tcmlnaHQPdGV4dC1hbGlnbi1sZWZ0CG1pcnJvci1oDXNoYXBlLWFsaWduLWgLbW92ZS1ib3R0b20Sc2hhcGUtYWxpZ24tYm90dG9tDXNoYXBlLWFsaWduLXYQc2hhcGUtZXF1LWRpc3Qtdg9zaGFwZS1hbGlnbi10b3ARc2hhcGUtYWxpZ24tcmlnaHQEZm9udApmb250LWNvbG9yEHNoYXBlLWVxdS1kaXN0LWgQc2hhcGUtYWxpZ24tbGVmdAZlcmFzZXIEdGV4dAxhZGQtZm9udHNpemUDdXAyB2V4cGFuZDIHZXhwYW5kMwtmb250LWl0YWxpYwVkb3duMQ9mb250LWRlbGV0ZWxpbmUIYnRuLWRvd24JYnRuLWxlZnQxDWVxdS1ib3RoLXNpZGUPcmVkdWNlLWZvbnRzaXplBGZpbGwFbGVmdDIFZmlsbDEGYnRuLXVwCWxvY2stY2FzZQtlcXUtdXAtZG93bgdleHBhbmQ0BGJvbGQGcmlnaHQyCGJ0bi1sZWZ0B2J0bi11cDEJYnRuLXJpZ2h0CmJ0bi1yaWdodDEIYnRuLXBsYXkGcmV2ZXJ0BnJlbG9hZApmaWxsLWNvbG9yCWFkZC1sYXllcghyb3RhdGUtMAxyZWR1Y2UtbGF5ZXIGaW1wb3J0BGdvb2QLYS16aXl1YW40MDMLYS16aXl1YW40MDQOdGV4dC1zdWJ0eXBlLTEDYmFkCGNhbGVuZGFyC2NhbmNlbC1saW5rDnRleHQtc3VidHlwZS0zCnN1aXQtcmF0aW8EbWFyawthbGwtZGlzcGxheQRsaW5rBmdyb3Vwcwpyb3RhdGUtMjcwBmF0dGFjaAljbG9zZS1leWUJcm90YXRlLTkwA2FkZAxjYW5jZWwtbGluazIIb3Blbi1leWUEc2F2ZQVicnVzaAJ1cAljb3B5LWZpbGUGZm9sZGVyBXBhc3RlCG5ldy1maWxlBXJpZ2h0BGxlZnQEZG93bgNjdXQOdGV4dC1zdWJ0eXBlLTILYS16aXl1YW40MDcEd2FybgxjYW5jZWwtbGluazEEZGluZwAAAAAA') format('truetype');
}
.icon {
font-family: "iconfont" !important;
font-size: 26px;
width: 26px;
height: 26px;
color: #424242;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
.icon-all-match:before {
content: "\\e6ef";
}
.icon-replace:before {
content: "\\e6ea";
}
.icon-shoucang:before {
content: "\\e6e8";
}
.icon-replace-all:before {
content: "\\e6e3";
}
.icon-zhihuan:before {
content: "\\e6e0";
}
.icon-shapes:before {
content: "\\e63a";
}
.icon-text-underline:before {
content: "\\e700";
}
.icon-shape-changesize:before {
content: "\\e6d4";
}
.icon-shapes-catalogy:before {
content: "\\e6d5";
}
.icon-expand1:before {
content: "\\e6d6";
}
.icon-print-disabled:before {
content: "\\e6d7";
}
.icon-print:before {
content: "\\e6d8";
}
.icon-unlock:before {
content: "\\e6d9";
}
.icon-email1:before {
content: "\\e645";
}
.icon-border-pencil:before {
content: "\\e6da";
}
.icon-copy-file1:before {
content: "\\e63e";
}
.icon-add-file1-icon:before {
content: "\\e63f";
}
.icon-add-folder-icon:before {
content: "\\e640";
}
.icon-edit-file:before {
content: "\\e641";
}
.icon-add-file-icon:before {
content: "\\e642";
}
.icon-file:before {
content: "\\e638";
}
.icon-layers:before {
content: "\\e68a";
}
.icon-cancel-merge:before {
content: "\\e68b";
}
.icon-remove:before {
content: "\\e68c";
}
.icon-a-ziyuan408:before {
content: "\\e68d";
}
.icon-merge:before {
content: "\\e68e";
}
.icon-edit-properies:before {
content: "\\e68f";
}
.icon-a-ziyuan395:before {
content: "\\e690";
}
.icon-phone:before {
content: "\\e691";
}
.icon-user:before {
content: "\\e692";
}
.icon-search:before {
content: "\\e693";
}
.icon-background:before {
content: "\\e694";
}
.icon-lock:before {
content: "\\e695";
}
.icon-locked:before {
content: "\\e696";
}
.icon-close:before {
content: "\\e697";
}
.icon-control-icon:before {
content: "\\e698";
}
.icon-ok:before {
content: "\\e699";
}
.icon-share:before {
content: "\\e69a";
}
.icon-publish:before {
content: "\\e69b";
}
.icon-setting:before {
content: "\\e69c";
}
.icon-reduce:before {
content: "\\e69d";
}
.icon-download:before {
content: "\\e69e";
}
.icon-merge1:before {
content: "\\e69f";
}
.icon-flip:before {
content: "\\e6a0";
}
.icon-align:before {
content: "\\e6a1";
}
.icon-hand:before {
content: "\\e6a2";
}
.icon-link-line:before {
content: "\\e6a3";
}
.icon-selector:before {
content: "\\e6a4";
}
.icon-position:before {
content: "\\e6a5";
}
.icon-anchor:before {
content: "\\e6a6";
}
.icon-move-up:before {
content: "\\e6a7";
}
.icon-move-down:before {
content: "\\e6a8";
}
.icon-font-align:before {
content: "\\e6a9";
}
.icon-move-top:before {
content: "\\e6aa";
}
.icon-text-align-right:before {
content: "\\e6ab";
}
.icon-text-align-left:before {
content: "\\e6ac";
}
.icon-mirror-h:before {
content: "\\e6ad";
}
.icon-mirror-v:before {
content: "\\e6ae";
}
.icon-shape-align-h:before {
content: "\\e6af";
}
.icon-move-bottom:before {
content: "\\e6b0";
}
.icon-shape-align-bottom:before {
content: "\\e6b1";
}
.icon-shape-align-v:before {
content: "\\e6b2";
}
.icon-shape-equ-dist-v:before {
content: "\\e6b3";
}
.icon-shape-align-top:before {
content: "\\e6b4";
}
.icon-shape-align-right:before {
content: "\\e6b5";
}
.icon-font:before {
content: "\\e6b6";
}
.icon-font-color:before {
content: "\\e6b7";
}
.icon-shape-equ-dist-h:before {
content: "\\e6b8";
}
.icon-shape-align-left:before {
content: "\\e6b9";
}
.icon-eraser:before {
content: "\\e6ba";
}
.icon-text:before {
content: "\\e6bb";
}
.icon-add-fontsize:before {
content: "\\e6bc";
}
.icon-up2:before {
content: "\\e6bd";
}
.icon-expand2:before {
content: "\\e6be";
}
.icon-expand3:before {
content: "\\e6bf";
}
.icon-font-italic:before {
content: "\\e6c0";
}
.icon-down1:before {
content: "\\e6c1";
}
.icon-font-deleteline:before {
content: "\\e6c2";
}
.icon-btn-down:before {
content: "\\e6c3";
}
.icon-btn-left1:before {
content: "\\e6c4";
}
.icon-equ-both-side:before {
content: "\\e6c5";
}
.icon-reduce-fontsize:before {
content: "\\e6c6";
}
.icon-fill:before {
content: "\\e6c7";
}
.icon-left2:before {
content: "\\e6c8";
}
.icon-fill1:before {
content: "\\e6c9";
}
.icon-btn-up:before {
content: "\\e6ca";
}
.icon-lock-case:before {
content: "\\e6cb";
}
.icon-equ-up-down:before {
content: "\\e6cc";
}
.icon-expand4:before {
content: "\\e6cd";
}
.icon-bold:before {
content: "\\e6ce";
}
.icon-right2:before {
content: "\\e6cf";
}
.icon-btn-left:before {
content: "\\e6d0";
}
.icon-btn-up1:before {
content: "\\e6d1";
}
.icon-btn-right:before {
content: "\\e6d2";
}
.icon-btn-right1:before {
content: "\\e6d3";
}
.icon-btn-play:before {
content: "\\e683";
}
.icon-revert:before {
content: "\\e684";
}
.icon-reload:before {
content: "\\e685";
}
.icon-fill-color:before {
content: "\\e65d";
}
.icon-add-layer:before {
content: "\\e686";
}
.icon-rotate-0:before {
content: "\\e687";
}
.icon-reduce-layer:before {
content: "\\e688";
}
.icon-import:before {
content: "\\e689";
}
.icon-good:before {
content: "\\e664";
}
.icon-a-ziyuan403:before {
content: "\\e665";
}
.icon-a-ziyuan404:before {
content: "\\e666";
}
.icon-text-subtype-1:before {
content: "\\e672";
}
.icon-bad:before {
content: "\\e673";
}
.icon-calendar:before {
content: "\\e674";
}
.icon-cancel-link:before {
content: "\\e675";
}
.icon-merge2:before {
content: "\\e676";
}
.icon-text-subtype-3:before {
content: "\\e677";
}
.icon-suit-ratio:before {
content: "\\e678";
}
.icon-mark:before {
content: "\\e679";
}
.icon-all-display:before {
content: "\\e67a";
}
.icon-link:before {
content: "\\e67b";
}
.icon-groups:before {
content: "\\e65e";
}
.icon-rotate-270:before {
content: "\\e67c";
}
.icon-attach:before {
content: "\\e67d";
}
.icon-close-eye:before {
content: "\\e67e";
}
.icon-rotate-90:before {
content: "\\e67f";
}
.icon-add:before {
content: "\\e680";
}
.icon-cancel-link2:before {
content: "\\e681";
}
.icon-open-eye:before {
content: "\\e682";
}
.icon-save:before {
content: "\\e668";
}
.icon-brush:before {
content: "\\e667";
}
.icon-up:before {
content: "\\e669";
}
.icon-copy-file:before {
content: "\\e66a";
}
.icon-folder:before {
content: "\\e66b";
}
.icon-paste:before {
content: "\\e66c";
}
.icon-new-file:before {
content: "\\e66d";
}
.icon-right:before {
content: "\\e66e";
}
.icon-left:before {
content: "\\e66f";
}
.icon-down:before {
content: "\\e670";
}
.icon-cut:before {
content: "\\e671";
}
.icon-text-subtype-2:before {
content: "\\e660";
}
.icon-a-ziyuan407:before {
content: "\\e661";
}
.icon-warn:before {
content: "\\e662";
}
.icon-cancel-link1:before {
content: "\\e65f";
}
.icon-ding:before {
content: "\\e663";
}
.ddei-editor {
position: relative;
width: 100%;
height: 100%;
overflow: hidden;
display: flex;
flex-direction: column;
background-color: var(--background);
}
.ddei-editor .icon {
color: var(--icon);
width: 1em;
height: 1em;
vertical-align: -0.15em;
fill: currentColor;
overflow: hidden;
}
.ddei-editor img {
-webkit-user-drag: none;
user-drag: none;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
.ddei-editor div {
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
.ddei-editor * {
box-sizing: border-box;
margin: 0;
font-weight: normal;
}
.ddei-editor *::-webkit-scrollbar {
width: 6px;
height: 6px;
}
.ddei-editor *::-webkit-scrollbar-thumb {
background-color: var(--scroll-hover);
-webkit-box-shadow: inset1px1px0rgba(0, 0, 0, 0.1);
}
.ddei-editor *:hover::-webkit-scrollbar-thumb {
background-color: var(--scroll-hover);
-webkit-box-shadow: inset1px1px0rgba(0, 0, 0, 0.1);
}
.ddei-editor *::-webkit-scrollbar-thumb:hover {
background-color: var(--scroll-hover);
-webkit-box-shadow: inset1px1px0rgba(0, 0, 0, 0.1);
}
.ddei-editor *::-webkit-scrollbar-track {
-webkit-box-shadow: inset006pxrgba(0, 0, 0, 0);
background-color: var(--scroll-background);
}
.ddei-editor *::-webkit-scrollbar-track:hover {
-webkit-box-shadow: inset006pxrgba(0, 0, 0, 0.4);
background-color: var(--scroll-background);
}
.ddei-cut-img-div {
width: 0.1px;
height: 0.1px;
display: flex;
}
.dialog-background-div {
width: 100%;
height: 100vh;
opacity: 50%;
z-index: 500;
left: 0;
top: 0;
display: none;
position: absolute;
}
/**以下是快捷样式编辑的弹出框 */
.ddei-core-dialog-quickpop[data-v-c4337de3] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
position: absolute;
background-color: var(--panel-background);
height: 80px;
z-index: 990;
user-select: none;
color: var(--panel-title);
}
.ddei-core-dialog-quickpop .content[data-v-c4337de3] {
width: 100%;
max-height: 70px;
overflow-y: hidden;
display: flex;
justify-content: start;
align-items: center;
font-size: 14px;
}
.ddei-core-dialog-quickpop .content .panel1[data-v-c4337de3] {
margin-top: 20px;
width: 170px;
height: 70px;
border-right: 1px solid var(--panel-border);
}
.ddei-core-dialog-quickpop .content .panel1 .panel1-content-1[data-v-c4337de3] {
width: 100px;
margin-left: 10px;
float: left;
}
.ddei-core-dialog-quickpop .content .panel1 .panel1-content-2[data-v-c4337de3] {
width: 50px;
float: left;
}
.ddei-core-dialog-quickpop .content .panel1 .panel1-content-3[data-v-c4337de3] {
width: 30px;
padding-left: 10px;
margin-top: 7px;
float: left;
}
.ddei-core-dialog-quickpop .content .panel1 .panel1-split-3[data-v-c4337de3] {
margin-left: 15px;
}
.ddei-core-dialog-quickpop .content .panel1 .panel1-content-4[data-v-c4337de3] {
padding: 0px 5px;
margin-top: 10px;
float: left;
border-radius: 2px;
}
.ddei-core-dialog-quickpop .content .panel1 .panel1-split-4[data-v-c4337de3] {
margin-right: 5px;
}
.ddei-core-dialog-quickpop .content .panel1 .panel1-content-4[data-v-c4337de3]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-dialog-quickpop .content .panel2[data-v-c4337de3] {
margin-top: 10px;
width: 60px;
height: 60px;
display: flex;
justify-content: center;
align-items: center;
text-align: center;
border-right: 1px solid var(--panel-border);
}
.ddei-core-dialog-quickpop .content .panel2 .panel2-content[data-v-c4337de3] {
flex: 1;
border-radius: 4px;
}
.ddei-core-dialog-quickpop .content .panel2 .panel2-content[data-v-c4337de3]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-dialog-quickpop .content .panel3[data-v-c4337de3] {
margin-top: 10px;
width: 150px;
height: 60px;
display: flex;
justify-content: center;
align-items: center;
text-align: center;
border-right: 1px solid var(--panel-border);
}
.ddei-core-dialog-quickpop .content .panel3 .panel3-content[data-v-c4337de3] {
flex: 1;
border-radius: 4px;
}
.ddei-core-dialog-quickpop .content .panel3 .panel3-content[data-v-c4337de3]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-dialog-quickpop .content .panel3 .i1 .icon[data-v-c4337de3] {
font-size: 20px;
margin-top: 5px;
margin-bottom: 2px;
}
.ddei-core-dialog-quickpop .content .panel3 .i2 .ddei-editor-quick-fat-item-box[data-v-c4337de3] {
width: 22px;
height: 26px;
margin: 0 auto;
margin-top: 4px;
}
.ddei-core-dialog-quickpop .content .panel3 .i2 .ddei-editor-quick-fat-item-box[data-v-c4337de3] .icon {
flex: 0 0 22px !important;
}
.ddei-core-dialog-quickpop .content .panel3 .i3 .ddei-editor-quick-fat-item-box[data-v-c4337de3] {
width: 22px;
height: 28px;
margin: 0 auto;
margin-top: 3px;
}
.ddei-core-dialog-quickpop .content .panel3 .i3 .ddei-editor-quick-fat-item-box[data-v-c4337de3] .icon {
flex: 0 0 24px !important;
}
.ddei-core-dialog-quickpop .content .panel4[data-v-c4337de3] {
margin-top: 10px;
padding-left: 10px;
height: 60px;
width: 150px;
display: flex;
justify-content: center;
align-items: center;
text-align: center;
}
.ddei-core-dialog-quickpop .content .panel4 .panel4-content[data-v-c4337de3] {
margin-right: 10px;
flex: 1;
border-radius: 4px;
}
.ddei-core-dialog-quickpop .content .panel4 .panel4-content .icon[data-v-c4337de3] {
margin-top: 2px;
margin-bottom: 1px;
}
.ddei-core-dialog-quickpop .content .panel4 .panel4-content[data-v-c4337de3]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-dialog-quickpop .content .panel5[data-v-c4337de3] {
margin-top: 10px;
height: 60px;
padding-left: 10px;
display: flex;
justify-content: center;
align-items: center;
text-align: center;
border-left: 1px solid var(--panel-border);
}
.ddei-core-dialog-quickpop .content .panel5 .panel5-content[data-v-c4337de3] {
margin-right: 10px;
flex: 1;
border-radius: 4px;
}
.ddei-core-dialog-quickpop .content .panel5 .panel5-content .text[data-v-c4337de3] {
white-space: nowrap;
}
.ddei-core-dialog-quickpop .content .panel5 .panel5-content .icon[data-v-c4337de3] {
margin-top: 2px;
margin-bottom: 1px;
}
.ddei-core-dialog-quickpop .content .panel5 .panel5-content[data-v-c4337de3]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-dialog-quickpop .content .panel12[data-v-c4337de3] {
margin-top: 20px;
width: 225px;
height: 70px;
border-right: 1px solid var(--panel-border);
}
.ddei-core-dialog-quickpop .content .panel12 .panel12-content-1[data-v-c4337de3] {
width: 100px;
margin-left: 10px;
float: left;
}
.ddei-core-dialog-quickpop .content .panel12 .panel12-content-2[data-v-c4337de3] {
width: 50px;
float: left;
}
.ddei-core-dialog-quickpop .content .panel12 .panel12-content-5[data-v-c4337de3] {
padding-left: 5px;
float: left;
}
.ddei-core-dialog-quickpop .content .panel12 .panel12-content-3[data-v-c4337de3] {
width: 30px;
padding-left: 10px;
margin-top: 10px;
float: left;
}
.ddei-core-dialog-quickpop .content .panel12 .panel12-split-3[data-v-c4337de3] {
margin-left: 12px !important;
}
.ddei-core-dialog-quickpop .content .panel12 .panel12-content-4[data-v-c4337de3] {
padding: 0px 5px;
margin-left: 2px;
margin-top: 12px;
float: left;
border-radius: 2px;
}
.ddei-core-dialog-quickpop .content .panel12 .panel12-split-4[data-v-c4337de3] {
margin-right: 5px;
}
.ddei-core-dialog-quickpop .content .panel12 .panel12-content-4[data-v-c4337de3]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-dialog-quickpop .content .panel6[data-v-c4337de3] {
margin-top: 10px;
padding-left: 10px;
height: 60px;
display: flex;
justify-content: center;
align-items: center;
text-align: center;
}
.ddei-core-dialog-quickpop .content .panel6-content1[data-v-c4337de3] {
margin-right: 10px;
white-space: nowrap;
flex: 1;
border-radius: 4px;
}
.ddei-core-dialog-quickpop .content .panel6-content1 .icon[data-v-c4337de3] {
margin-top: 2px;
margin-bottom: 1px;
}
.ddei-core-dialog-quickpop .content .panel6-content[data-v-c4337de3] {
margin-right: 10px;
border-radius: 4px;
}
.ddei-core-dialog-quickpop .content .panel6-content .icon[data-v-c4337de3] {
margin-top: 2px;
margin-bottom: 1px;
}
.ddei-core-dialog-quickpop .content .panel6 .type[data-v-c4337de3] {
width: 40px;
padding-left: 5px;
padding-right: 5px;
}
.ddei-core-dialog-quickpop .content .panel6 .type .ddei-pv-line-type-combox[data-v-c4337de3] {
width: 22px;
height: 28px;
margin: 5px auto 1px auto;
}
.ddei-core-dialog-quickpop .content .panel6 .type .ddei-pv-line-type-combox[data-v-c4337de3] .icon {
flex: 0 0 26px !important;
}
.ddei-core-dialog-quickpop .content .panel6 .color2[data-v-c4337de3] {
padding-left: 5px;
padding-right: 5px;
width: 40px;
}
.ddei-core-dialog-quickpop .content .panel6 .color2 .ddei-editor-quick-fat-item-box[data-v-c4337de3] {
width: 22px;
height: 28px;
margin: 5px auto 3px auto;
}
.ddei-core-dialog-quickpop .content .panel6 .color2 .ddei-editor-quick-fat-item-box[data-v-c4337de3] .icon {
flex: 0 0 26px !important;
}
.ddei-core-dialog-quickpop .content .panel6 .dash[data-v-c4337de3] {
width: 50px;
margin-top: 8px;
}
.ddei-core-dialog-quickpop .content .panel6 .brush[data-v-c4337de3] {
width: 50px;
margin-top: 4px;
}
.ddei-core-dialog-quickpop .content .panel6 .brush[data-v-c4337de3]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-dialog-quickpop .content .panel6 .pointtype[data-v-c4337de3] {
width: 70px;
margin-top: 4px;
}
.ddei-core-dialog-quickpop .content .panel6 .exchange[data-v-c4337de3] {
flex: 0 0 20px !important;
margin-top: -15px;
padding: 0px 2px;
}
.ddei-core-dialog-quickpop .content .panel6 .exchange[data-v-c4337de3]:hover {
background-color: var(--panel-hover);
cursor: pointer;
}
.ddei-core-dialog-quickpop .content .panel6 .exchange .icon[data-v-c4337de3] {
font-size: 18px;
}
.ddei-core-dialog-quickpop .content .panel6-content[data-v-c4337de3]:hover {
background-color: var(--panel-background);
cursor: pointer;
}
.ddei-core-dialog-quickpop .content .panel6-content1[data-v-c4337de3]:hover {
background-color: var(--panel-background);
cursor: pointer;
}
.ddei-core-dialog-quickpop .brush-selected[data-v-c4337de3] {
background-color: var(--panel-selected);
}
.ddei-ext-panel-search[data-v-75611720] {
width: 500px;
background-color: var(--panel-background);
}
.ddei-ext-panel-search .icon[data-v-75611720] {
color: var(--icon);
font-size: 18px;
width: 18px;
height: 18px;
}
.ddei-ext-panel-search-mode[data-v-75611720] {
float: left;
height: 32px;
width: 24px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-ext-panel-search-mode__expand[data-v-75611720] {
height: 64px;
}
.ddei-ext-panel-search-mode[data-v-75611720]:hover {
background: var(--panel-header);
cursor: pointer;
}
.ddei-ext-panel-search-box[data-v-75611720] {
float: left;
height: 30px;
width: 200px;
display: flex;
align-items: center;
justify-content: center;
background: var(--panel-header);
border: 0.5px solid var(--panel-hover);
}
.ddei-ext-panel-search-box[data-v-75611720]:hover {
background: var(--panel-header);
cursor: pointer;
border: 0.5px solid var(--dot);
}
.ddei-ext-panel-search-box-input[data-v-75611720] {
flex: 1;
color: var(--panel-title);
height: 30px;
background: none;
border: none;
outline: none;
}
.ddei-ext-panel-search-box-btn[data-v-75611720] {
width: 25px;
height: 25px;
margin-right: 3px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-ext-panel-search-box-btn[data-v-75611720]:hover {
background-color: var(--dot);
filter: brightness(130%);
cursor: pointer;
border-radius: 4px;
}
.ddei-ext-panel-search-box-btn__selected[data-v-75611720] {
background-color: var(--dot);
filter: brightness(130%);
border-radius: 4px;
}
.ddei-ext-panel-search-result[data-v-75611720] {
float: left;
margin-left: 5px;
height: 30px;
width: 150px;
display: flex;
align-items: center;
justify-content: start;
color: var(--panel-title);
font-size: 14px;
}
.ddei-ext-panel-search-buttons[data-v-75611720] {
float: left;
margin-bottom: 3px;
margin-left: 5px;
height: 30px;
width: 110px;
display: flex;
align-items: center;
justify-content: end;
color: var(--panel-title);
font-size: 14px;
}
.ddei-ext-panel-search-buttons-btn[data-v-75611720] {
display: flex;
align-items: center;
justify-content: center;
width: 30px;
height: 30px;
}
.ddei-ext-panel-search-buttons-btn[data-v-75611720]:hover {
background-color: var(--panel-header);
cursor: pointer;
}
.ddei-ext-panel-search-buttons-btn__selected[data-v-75611720] {
background-color: var(--panel-header);
}
.ddei-ext-panel-search-buttons-btn__disabled .icon[data-v-75611720] {
filter: opacity(0.5);
}
.ddei-ext-panel-search-buttons-btn__disabled[data-v-75611720]:hover {
background: none;
cursor: default;
}
.ddei-ext-panel-search-buttons-btn .icon[data-v-75611720] {
font-size: 18px;
width: 18px;
height: 18px;
}
.ddei-ext-panel-search-replace-buttons[data-v-75611720] {
float: left;
margin-bottom: 3px;
margin-left: 5px;
height: 30px;
width: 110px;
display: flex;
align-items: center;
justify-content: start;
color: var(--panel-title);
font-size: 14px;
}
.ddei-ext-panel-search-replace-buttons-btn[data-v-75611720] {
display: flex;
align-items: center;
justify-content: center;
width: 30px;
height: 30px;
}
.ddei-ext-panel-search-replace-buttons-btn[data-v-75611720]:hover {
background-color: var(--panel-header);
cursor: pointer;
}
.ddei-ext-panel-search-replace-buttons-btn .icon[data-v-75611720] {
font-size: 18px;
width: 18px;
height: 18px;
}
.ddei-ext-dialog-search[data-v-869178bc] {
box-shadow: 0px 2px 24px 0px hwb(0 0% 100% / 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
position: absolute;
padding-top: 3px;
background-color: var(--panel-background);
z-index: 999;
}
.ddei-ext-panel-quickcontrol[data-v-dd1c62d6] {
background: transparent;
pointer-events: none;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-ext-panel-quickcontrol svg[data-v-dd1c62d6] {
pointer-events: auto;
fill: var(--icon);
}
.ddei-ext-panel-quickcontrol svg[data-v-dd1c62d6]:hover {
fill: var(--dot);
cursor: pointer;
}
.ddei-ext-panel-quickcontrol-left[data-v-dd1c62d6] {
display: flex;
justify-content: center;
align-items: center;
flex: 0 0 20px;
}
.ddei-ext-panel-quickcontrol-middle[data-v-dd1c62d6] {
flex: 1;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
height: 100%;
}
.ddei-ext-panel-quickcontrol-middle-top[data-v-dd1c62d6] {
flex: 0 0 20px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-ext-panel-quickcontrol-middle-middle[data-v-dd1c62d6] {
flex: 1;
}
.ddei-ext-panel-quickcontrol-middle-bottom[data-v-dd1c62d6] {
display: flex;
justify-content: center;
align-items: center;
flex: 0 0 20px;
}
.ddei-ext-panel-quickcontrol-right[data-v-dd1c62d6] {
flex: 0 0 20px;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-ext-dialog-quickcontrol[data-v-737aeea8] {
display: none;
overflow: hidden;
position: absolute;
background: transparent;
pointer-events: none;
z-index: 999;
}
.ddei-ext-dialog-quickchoosecontrol[data-v-5bda071e] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: auto;
position: absolute;
background-color: var(--panel-background);
height: 240px;
width: 240px;
z-index: 1999;
user-select: none;
color: var(--panel-title);
}
.ddei-ext-dialog-quickchoosecontrol-group-itempanel[data-v-5bda071e] {
display: flex;
flex-flow: row wrap;
background: var(--toolbox-background);
padding: 15px 15px 15px 15px;
}
.ddei-ext-dialog-quickchoosecontrol-group-itempanel-item[data-v-5bda071e] {
flex: 0 0 50px !important;
height: 45px;
margin: 5px 0px;
display: flex;
overflow: hidden;
justify-content: center;
align-items: center;
flex-flow: column;
}
.ddei-ext-dialog-quickchoosecontrol-group-itempanel-item[data-v-5bda071e]:hover {
background: var(--toolbox-control-hover);
outline: var(--toolbox-control-hover-outline);
cursor: all-scroll;
}
.ddei-ext-dialog-quickchoosecontrol-group-itempanel-item .text[data-v-5bda071e] {
white-space: nowrap;
text-align: center;
font-size: 0.7vw;
font-weight: 400;
color: var(--toolbox-control-title);
}
.ddei-ext-dialog-quickchoosecontrol-group-itempanel-item .icon[data-v-5bda071e] {
width: 90%;
height: 90%;
object-fit: contain;
}
.ddei-ext-dialog-quickchoosecontrol-group-itempanel-item .icon-html[data-v-5bda071e] {
width: 50px;
height: 45px;
object-fit: contain;
display: flex;
justify-content: center;
align-items: center;
}
.ddei-ext-dialog-quickchoosecontrol-group-itempanel-item .icon-html[data-v-5bda071e] > * {
width: 28px !important;
height: 28px !important;
object-fit: contain;
}
/**以下是快捷样式编辑的弹出框 */
.ddei-ext-dialog-tooltip[data-v-d9902947] {
border: 1px solid var(--panel-border);
box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25);
border-radius: 6px;
display: none;
overflow: hidden;
position: absolute;
background-color: var(--panel-background);
z-index: 2999;
user-select: none;
color: var(--panel-title);
}
.ddei-ext-dialog-tooltip-row[data-v-d9902947] {
min-width: 160px;
min-height: 30px;
display: flex;
align-items: center;
justify-content: center;
}
.ddei-ext-dialog-tooltip-row-title[data-v-d9902947] {
flex: 1;
padding-left: 5px;
padding-right: 5px;
text-align: left;
font-weight: bolder;
}
.ddei-ext-dialog-tooltip-row-data[data-v-d9902947] {
flex: 1;
padding-left: 5px;
padding-right: 5px;
text-align: center;
}
@keyframes fadeIn-d9902947 {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
.fade-in[data-v-d9902947] {
animation: fadeIn-d9902947 0.5s ease-in-out forwards;
}
`;
document.head.appendChild(__vite_style__);
var __defProp2 = Object.defineProperty;
var __defNormalProp2 = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __publicField2 = (obj, key, value) => {
__defNormalProp2(obj, typeof key !== "symbol" ? key + "" : key, value);
return value;
};
var freeGlobal = typeof global == "object" && global && global.Object === Object && global;
const freeGlobal$1 = freeGlobal;
var freeSelf = typeof self == "object" && self && self.Object === Object && self;
var root = freeGlobal$1 || freeSelf || Function("return this")();
const root$1 = root;
var Symbol$1 = root$1.Symbol;
const Symbol$2 = Symbol$1;
var objectProto$d = Object.prototype;
var hasOwnProperty$a = objectProto$d.hasOwnProperty;
var nativeObjectToString$1 = objectProto$d.toString;
var symToStringTag$1 = Symbol$2 ? Symbol$2.toStringTag : void 0;
function getRawTag(value) {
var isOwn = hasOwnProperty$a.call(value, symToStringTag$1), tag = value[symToStringTag$1];
try {
value[symToStringTag$1] = void 0;
var unmasked = true;
} catch (e) {
}
var result = nativeObjectToString$1.call(value);
if (unmasked) {
if (isOwn) {
value[symToStringTag$1] = tag;
} else {
delete value[symToStringTag$1];
}
}
return result;
}
var objectProto$c = Object.prototype;
var nativeObjectToString = objectProto$c.toString;
function objectToString(value) {
return nativeObjectToString.call(value);
}
var nullTag = "[object Null]", undefinedTag = "[object Undefined]";
var symToStringTag = Symbol$2 ? Symbol$2.toStringTag : void 0;
function baseGetTag(value) {
if (value == null) {
return value === void 0 ? undefinedTag : nullTag;
}
return symToStringTag && symToStringTag in Object(value) ? getRawTag(value) : objectToString(value);
}
function isObjectLike(value) {
return value != null && typeof value == "object";
}
var symbolTag$2 = "[object Symbol]";
function isSymbol(value) {
return typeof value == "symbol" || isObjectLike(value) && baseGetTag(value) == symbolTag$2;
}
function arrayMap(array, iteratee) {
var index = -1, length = array == null ? 0 : array.length, result = Array(length);
while (++index < length) {
result[index] = iteratee(array[index], index, array);
}
return result;
}
var isArray = Array.isArray;
const isArray$1 = isArray;
var INFINITY = 1 / 0;
var symbolProto$1 = Symbol$2 ? Symbol$2.prototype : void 0, symbolToString = symbolProto$1 ? symbolProto$1.toString : void 0;
function baseToString(value) {
if (typeof value == "string") {
return value;
}
if (isArray$1(value)) {
return arrayMap(value, baseToString) + "";
}
if (isSymbol(value)) {
return symbolToString ? symbolToString.call(value) : "";
}
var result = value + "";
return result == "0" && 1 / value == -INFINITY ? "-0" : result;
}
var reWhitespace = /\s/;
function trimmedEndIndex(string) {
var index = string.length;
while (index-- && reWhitespace.test(string.charAt(index))) {
}
return index;
}
var reTrimStart = /^\s+/;
function baseTrim(string) {
return string ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, "") : string;
}
function isObject(value) {
var type = typeof value;
return value != null && (type == "object" || type == "function");
}
var NAN = 0 / 0;
var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;
var reIsBinary = /^0b[01]+$/i;
var reIsOctal = /^0o[0-7]+$/i;
var freeParseInt = parseInt;
function toNumber(value) {
if (typeof value == "number") {
return value;
}
if (isSymbol(value)) {
return NAN;
}
if (isObject(value)) {
var other = typeof value.valueOf == "function" ? value.valueOf() : value;
value = isObject(other) ? other + "" : other;
}
if (typeof value != "string") {
return value === 0 ? value : +value;
}
value = baseTrim(value);
var isBinary = reIsBinary.test(value);
return isBinary || reIsOctal.test(value) ? freeParseInt(value.slice(2), isBinary ? 2 : 8) : reIsBadHex.test(value) ? NAN : +value;
}
function identity(value) {
return value;
}
var asyncTag = "[object AsyncFunction]", funcTag$2 = "[object Function]", genTag$1 = "[object GeneratorFunction]", proxyTag = "[object Proxy]";
function isFunction(value) {
if (!isObject(value)) {
return false;
}
var tag = baseGetTag(value);
return tag == funcTag$2 || tag == genTag$1 || tag == asyncTag || tag == proxyTag;
}
var coreJsData = root$1["__core-js_shared__"];
const coreJsData$1 = coreJsData;
var maskSrcKey = function() {
var uid = /[^.]+$/.exec(coreJsData$1 && coreJsData$1.keys && coreJsData$1.keys.IE_PROTO || "");
return uid ? "Symbol(src)_1." + uid : "";
}();
function isMasked(func) {
return !!maskSrcKey && maskSrcKey in func;
}
var funcProto$2 = Function.prototype;
var funcToString$2 = funcProto$2.toString;
function toSource(func) {
if (func != null) {
try {
return funcToString$2.call(func);
} catch (e) {
}
try {
return func + "";
} catch (e) {
}
}
return "";
}
var reRegExpChar = /[\\^$.*+?()[\]{}|]/g;
var reIsHostCtor = /^\[object .+?Constructor\]$/;
var funcProto$1 = Function.prototype, objectProto$b = Object.prototype;
var funcToString$1 = funcProto$1.toString;
var hasOwnProperty$9 = objectProto$b.hasOwnProperty;
var reIsNative = RegExp(
"^" + funcToString$1.call(hasOwnProperty$9).replace(reRegExpChar, "\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, "$1.*?") + "$"
);
function baseIsNative(value) {
if (!isObject(value) || isMasked(value)) {
return false;
}
var pattern = isFunction(value) ? reIsNative : reIsHostCtor;
return pattern.test(toSource(value));
}
function getValue(object, key) {
return object == null ? void 0 : object[key];
}
function getNative(object, key) {
var value = getValue(object, key);
return baseIsNative(value) ? value : void 0;
}
var WeakMap = getNative(root$1, "WeakMap");
const WeakMap$1 = WeakMap;
var objectCreate = Object.create;
var baseCreate = function() {
function object() {
}
return function(proto) {
if (!isObject(proto)) {
return {};
}
if (objectCreate) {
return objectCreate(proto);
}
object.prototype = proto;
var result = new object();
object.prototype = void 0;
return result;
};
}();
const baseCreate$1 = baseCreate;
function apply(func, thisArg, args) {
switch (args.length) {
case 0:
return func.call(thisArg);
case 1:
return func.call(thisArg, args[0]);
case 2:
return func.call(thisArg, args[0], args[1]);
case 3:
return func.call(thisArg, args[0], args[1], args[2]);
}
return func.apply(thisArg, args);
}
function copyArray(source, array) {
var index = -1, length = source.length;
array || (array = Array(length));
while (++index < length) {
array[index] = source[index];
}
return array;
}
var HOT_COUNT = 800, HOT_SPAN = 16;
var nativeNow = Date.now;
function shortOut(func) {
var count = 0, lastCalled = 0;
return function() {
var stamp = nativeNow(), remaining = HOT_SPAN - (stamp - lastCalled);
lastCalled = stamp;
if (remaining > 0) {
if (++count >= HOT_COUNT) {
return arguments[0];
}
} else {
count = 0;
}
return func.apply(void 0, arguments);
};
}
function constant(value) {
return function() {
return value;
};
}
var defineProperty = function() {
try {
var func = getNative(Object, "defineProperty");
func({}, "", {});
return func;
} catch (e) {
}
}();
const defineProperty$1 = defineProperty;
var baseSetToString = !defineProperty$1 ? identity : function(func, string) {
return defineProperty$1(func, "toString", {
"configurable": true,
"enumerable": false,
"value": constant(string),
"writable": true
});
};
const baseSetToString$1 = baseSetToString;
var setToString = shortOut(baseSetToString$1);
const setToString$1 = setToString;
function arrayEach(array, iteratee) {
var index = -1, length = array == null ? 0 : array.length;
while (++index < length) {
if (iteratee(array[index], index, array) === false) {
break;
}
}
return array;
}
function baseFindIndex(array, predicate, fromIndex, fromRight) {
var length = array.length, index = fromIndex + (fromRight ? 1 : -1);
while (fromRight ? index-- : ++index < length) {
if (predicate(array[index], index, array)) {
return index;
}
}
return -1;
}
function baseIsNaN(value) {
return value !== value;
}
function strictIndexOf(array, value, fromIndex) {
var index = fromIndex - 1, length = array.length;
while (++index < length) {
if (array[index] === value) {
return index;
}
}
return -1;
}
function baseIndexOf(array, value, fromIndex) {
return value === value ? strictIndexOf(array, value, fromIndex) : baseFindIndex(array, baseIsNaN, fromIndex);
}
var MAX_SAFE_INTEGER$1 = 9007199254740991;
var reIsUint = /^(?:0|[1-9]\d*)$/;
function isIndex(value, length) {
var type = typeof value;
length = length == null ? MAX_SAFE_INTEGER$1 : length;
return !!length && (type == "number" || type != "symbol" && reIsUint.test(value)) && (value > -1 && value % 1 == 0 && value < length);
}
function baseAssignValue(object, key, value) {
if (key == "__proto__" && defineProperty$1) {
defineProperty$1(object, key, {
"configurable": true,
"enumerable": true,
"value": value,
"writable": true
});
} else {
object[key] = value;
}
}
function eq(value, other) {
return value === other || value !== value && other !== other;
}
var objectProto$a = Object.prototype;
var hasOwnProperty$8 = objectProto$a.hasOwnProperty;
function assignValue(object, key, value) {
var objValue = object[key];
if (!(hasOwnProperty$8.call(object, key) && eq(objValue, value)) || value === void 0 && !(key in object)) {
baseAssignValue(object, key, value);
}
}
function copyObject(source, props, object, customizer) {
var isNew = !object;
object || (object = {});
var index = -1, length = props.length;
while (++index < length) {
var key = props[index];
var newValue = customizer ? customizer(object[key], source[key], key, object, source) : void 0;
if (newValue === void 0) {
newValue = source[key];
}
if (isNew) {
baseAssignValue(object, key, newValue);
} else {
assignValue(object, key, newValue);
}
}
return object;
}
var nativeMax$1 = Math.max;
function overRest(func, start, transform) {
start = nativeMax$1(start === void 0 ? func.length - 1 : start, 0);
return function() {
var args = arguments, index = -1, length = nativeMax$1(args.length - start, 0), array = Array(length);
while (++index < length) {
array[index] = args[start + index];
}
index = -1;
var otherArgs = Array(start + 1);
while (++index < start) {
otherArgs[index] = args[index];
}
otherArgs[start] = transform(array);
return apply(func, this, otherArgs);
};
}
function baseRest(func, start) {
return setToString$1(overRest(func, start, identity), func + "");
}
var MAX_SAFE_INTEGER = 9007199254740991;
function isLength(value) {
return typeof value == "number" && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;
}
function isArrayLike(value) {
return value != null && isLength(value.length) && !isFunction(value);
}
function isIterateeCall(value, index, object) {
if (!isObject(object)) {
return false;
}
var type = typeof index;
if (type == "number" ? isArrayLike(object) && isIndex(index, object.length) : type == "string" && index in object) {
return eq(object[index], value);
}
return false;
}
function createAssigner(assigner) {
return baseRest(function(object, sources) {
var index = -1, length = sources.length, customizer = length > 1 ? sources[length - 1] : void 0, guard = length > 2 ? sources[2] : void 0;
customizer = assigner.length > 3 && typeof customizer == "function" ? (length--, customizer) : void 0;
if (guard && isIterateeCall(sources[0], sources[1], guard)) {
customizer = length < 3 ? void 0 : customizer;
length = 1;
}
object = Object(object);
while (++index < length) {
var source = sources[index];
if (source) {
assigner(object, source, index, customizer);
}
}
return object;
});
}
var objectProto$9 = Object.prototype;
function isPrototype(value) {
var Ctor = value && value.constructor, proto = typeof Ctor == "function" && Ctor.prototype || objectProto$9;
return value === proto;
}
function baseTimes(n, iteratee) {
var index = -1, result = Array(n);
while (++index < n) {
result[index] = iteratee(index);
}
return result;
}
var argsTag$2 = "[object Arguments]";
function baseIsArguments(value) {
return isObjectLike(value) && baseGetTag(value) == argsTag$2;
}
var objectProto$8 = Object.prototype;
var hasOwnProperty$7 = objectProto$8.hasOwnProperty;
var propertyIsEnumerable$1 = objectProto$8.propertyIsEnumerable;
var isArguments = baseIsArguments(function() {
return arguments;
}()) ? baseIsArguments : function(value) {
return isObjectLike(value) && hasOwnProperty$7.call(value, "callee") && !propertyIsEnumerable$1.call(value, "callee");
};
const isArguments$1 = isArguments;
function stubFalse() {
return false;
}
var freeExports$2 = typeof exports == "object" && exports && !exports.nodeType && exports;
var freeModule$2 = freeExports$2 && typeof module == "object" && module && !module.nodeType && module;
var moduleExports$2 = freeModule$2 && freeModule$2.exports === freeExports$2;
var Buffer$1 = moduleExports$2 ? root$1.Buffer : void 0;
var nativeIsBuffer = Buffer$1 ? Buffer$1.isBuffer : void 0;
var isBuffer = nativeIsBuffer || stubFalse;
const isBuffer$1 = isBuffer;
var argsTag$1 = "[object Arguments]", arrayTag$1 = "[object Array]", boolTag$2 = "[object Boolean]", dateTag$3 = "[object Date]", errorTag$1 = "[object Error]", funcTag$1 = "[object Function]", mapTag$4 = "[object Map]", numberTag$3 = "[object Number]", objectTag$3 = "[object Object]", regexpTag$2 = "[object RegExp]", setTag$4 = "[object Set]", stringTag$3 = "[object String]", weakMapTag$2 = "[object WeakMap]";
var arrayBufferTag$2 = "[object ArrayBuffer]", dataViewTag$3 = "[object DataView]", float32Tag$2 = "[object Float32Array]", float64Tag$2 = "[object Float64Array]", int8Tag$2 = "[object Int8Array]", int16Tag$2 = "[object Int16Array]", int32Tag$2 = "[object Int32Array]", uint8Tag$2 = "[object Uint8Array]", uint8ClampedTag$2 = "[object Uint8ClampedArray]", uint16Tag$2 = "[object Uint16Array]", uint32Tag$2 = "[object Uint32Array]";
var typedArrayTags = {};
typedArrayTags[float32Tag$2] = typedArrayTags[float64Tag$2] = typedArrayTags[int8Tag$2] = typedArrayTags[int16Tag$2] = typedArrayTags[int32Tag$2] = typedArrayTags[uint8Tag$2] = typedArrayTags[uint8ClampedTag$2] = typedArrayTags[uint16Tag$2] = typedArrayTags[uint32Tag$2] = true;
typedArrayTags[argsTag$1] = typedArrayTags[arrayTag$1] = typedArrayTags[arrayBufferTag$2] = typedArrayTags[boolTag$2] = typedArrayTags[dataViewTag$3] = typedArrayTags[dateTag$3] = typedArrayTags[errorTag$1] = typedArrayTags[funcTag$1] = typedArrayTags[mapTag$4] = typedArrayTags[numberTag$3] = typedArrayTags[objectTag$3] = typedArrayTags[regexpTag$2] = typedArrayTags[setTag$4] = typedArrayTags[stringTag$3] = typedArrayTags[weakMapTag$2] = false;
function baseIsTypedArray(value) {
return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[baseGetTag(value)];
}
function baseUnary(func) {
return function(value) {
return func(value);
};
}
var freeExports$1 = typeof exports == "object" && exports && !exports.nodeType && exports;
var freeModule$1 = freeExports$1 && typeof module == "object" && module && !module.nodeType && module;
var moduleExports$1 = freeModule$1 && freeModule$1.exports === freeExports$1;
var freeProcess = moduleExports$1 && freeGlobal$1.process;
var nodeUtil = function() {
try {
var types = freeModule$1 && freeModule$1.require && freeModule$1.require("util").types;
if (types) {
return types;
}
return freeProcess && freeProcess.binding && freeProcess.binding("util");
} catch (e) {
}
}();
const nodeUtil$1 = nodeUtil;
var nodeIsTypedArray = nodeUtil$1 && nodeUtil$1.isTypedArray;
var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;
const isTypedArray$1 = isTypedArray;
var objectProto$7 = Object.prototype;
var hasOwnProperty$6 = objectProto$7.hasOwnProperty;
function arrayLikeKeys(value, inherited) {
var isArr = isArray$1(value), isArg = !isArr && isArguments$1(value), isBuff = !isArr && !isArg && isBuffer$1(value), isType = !isArr && !isArg && !isBuff && isTypedArray$1(value), skipIndexes = isArr || isArg || isBuff || isType, result = skipIndexes ? baseTimes(value.length, String) : [], length = result.length;
for (var key in value) {
if ((inherited || hasOwnProperty$6.call(value, key)) && !(skipIndexes && // Safari 9 has enumerable `arguments.length` in strict mode.
(key == "length" || // Node.js 0.10 has enumerable non-index properties on buffers.
isBuff && (key == "offset" || key == "parent") || // PhantomJS 2 has enumerable non-index properties on typed arrays.
isType && (key == "buffer" || key == "byteLength" || key == "byteOffset") || // Skip index properties.
isIndex(key, length)))) {
result.push(key);
}
}
return result;
}
function overArg(func, transform) {
return function(arg) {
return func(transform(arg));
};
}
var nativeKeys = overArg(Object.keys, Object);
const nativeKeys$1 = nativeKeys;
var objectProto$6 = Object.prototype;
var hasOwnProperty$5 = objectProto$6.hasOwnProperty;
function baseKeys(object) {
if (!isPrototype(object)) {
return nativeKeys$1(object);
}
var result = [];
for (var key in Object(object)) {
if (hasOwnProperty$5.call(object, key) && key != "constructor") {
result.push(key);
}
}
return result;
}
function keys(object) {
return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);
}
function nativeKeysIn(object) {
var result = [];
if (object != null) {
for (var key in Object(object)) {
result.push(key);
}
}
return result;
}
var objectProto$5 = Object.prototype;
var hasOwnProperty$4 = objectProto$5.hasOwnProperty;
function baseKeysIn(object) {
if (!isObject(object)) {
return nativeKeysIn(object);
}
var isProto = isPrototype(object), result = [];
for (var key in object) {
if (!(key == "constructor" && (isProto || !hasOwnProperty$4.call(object, key)))) {
result.push(key);
}
}
return result;
}
function keysIn(object) {
return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);
}
var nativeCreate = getNative(Object, "create");
const nativeCreate$1 = nativeCreate;
function hashClear() {
this.__data__ = nativeCreate$1 ? nativeCreate$1(null) : {};
this.size = 0;
}
function hashDelete(key) {
var result = this.has(key) && delete this.__data__[key];
this.size -= result ? 1 : 0;
return result;
}
var HASH_UNDEFINED$1 = "__lodash_hash_undefined__";
var objectProto$4 = Object.prototype;
var hasOwnProperty$3 = objectProto$4.hasOwnProperty;
function hashGet(key) {
var data = this.__data__;
if (nativeCreate$1) {
var result = data[key];
return result === HASH_UNDEFINED$1 ? void 0 : result;
}
return hasOwnProperty$3.call(data, key) ? data[key] : void 0;
}
var objectProto$3 = Object.prototype;
var hasOwnProperty$2 = objectProto$3.hasOwnProperty;
function hashHas(key) {
var data = this.__data__;
return nativeCreate$1 ? data[key] !== void 0 : hasOwnProperty$2.call(data, key);
}
var HASH_UNDEFINED = "__lodash_hash_undefined__";
function hashSet(key, value) {
var data = this.__data__;
this.size += this.has(key) ? 0 : 1;
data[key] = nativeCreate$1 && value === void 0 ? HASH_UNDEFINED : value;
return this;
}
function Hash(entries) {
var index = -1, length = entries == null ? 0 : entries.length;
this.clear();
while (++index < length) {
var entry = entries[index];
this.set(entry[0], entry[1]);
}
}
Hash.prototype.clear = hashClear;
Hash.prototype["delete"] = hashDelete;
Hash.prototype.get = hashGet;
Hash.prototype.has = hashHas;
Hash.prototype.set = hashSet;
function listCacheClear() {
this.__data__ = [];
this.size = 0;
}
function assocIndexOf(array, key) {
var length = array.length;
while (length--) {
if (eq(array[length][0], key)) {
return length;
}
}
return -1;
}
var arrayProto = Array.prototype;
var splice = arrayProto.splice;
function listCacheDelete(key) {
var data = this.__data__, index = assocIndexOf(data, key);
if (index < 0) {
return false;
}
var lastIndex = data.length - 1;
if (index == lastIndex) {
data.pop();
} else {
splice.call(data, index, 1);
}
--this.size;
return true;
}
function listCacheGet(key) {
var data = this.__data__, index = assocIndexOf(data, key);
return index < 0 ? void 0 : data[index][1];
}
function listCacheHas(key) {
return assocIndexOf(this.__data__, key) > -1;
}
function listCacheSet(key, value) {
var data = this.__data__, index = assocIndexOf(data, key);
if (index < 0) {
++this.size;
data.push([key, value]);
} else {
data[index][1] = value;
}
return this;
}
function ListCache(entries) {
var index = -1, length = entries == null ? 0 : entries.length;
this.clear();
while (++index < length) {
var entry = entries[index];
this.set(entry[0], entry[1]);
}
}
ListCache.prototype.clear = listCacheClear;
ListCache.prototype["delete"] = listCacheDelete;
ListCache.prototype.get = listCacheGet;
ListCache.prototype.has = listCacheHas;
ListCache.prototype.set = listCacheSet;
var Map$1 = getNative(root$1, "Map");
const Map$2 = Map$1;
function mapCacheClear() {
this.size = 0;
this.__data__ = {
"hash": new Hash(),
"map": new (Map$2 || ListCache)(),
"string": new Hash()
};
}
function isKeyable(value) {
var type = typeof value;
return type == "string" || type == "number" || type == "symbol" || type == "boolean" ? value !== "__proto__" : value === null;
}
function getMapData(map, key) {
var data = map.__data__;
return isKeyable(key) ? data[typeof key == "string" ? "string" : "hash"] : data.map;
}
function mapCacheDelete(key) {
var result = getMapData(this, key)["delete"](key);
this.size -= result ? 1 : 0;
return result;
}
function mapCacheGet(key) {
return getMapData(this, key).get(key);
}
function mapCacheHas(key) {
return getMapData(this, key).has(key);
}
function mapCacheSet(key, value) {
var data = getMapData(this, key), size = data.size;
data.set(key, value);
this.size += data.size == size ? 0 : 1;
return this;
}
function MapCache(entries) {
var index = -1, length = entries == null ? 0 : entries.length;
this.clear();
while (++index < length) {
var entry = entries[index];
this.set(entry[0], entry[1]);
}
}
MapCache.prototype.clear = mapCacheClear;
MapCache.prototype["delete"] = mapCacheDelete;
MapCache.prototype.get = mapCacheGet;
MapCache.prototype.has = mapCacheHas;
MapCache.prototype.set = mapCacheSet;
function toString(value) {
return value == null ? "" : baseToString(value);
}
function arrayPush(array, values) {
var index = -1, length = values.length, offset = array.length;
while (++index < length) {
array[offset + index] = values[index];
}
return array;
}
var getPrototype = overArg(Object.getPrototypeOf, Object);
const getPrototype$1 = getPrototype;
var objectTag$2 = "[object Object]";
var funcProto = Function.prototype, objectProto$2 = Object.prototype;
var funcToString = funcProto.toString;
var hasOwnProperty$1 = objectProto$2.hasOwnProperty;
var objectCtorString = funcToString.call(Object);
function isPlainObject(value) {
if (!isObjectLike(value) || baseGetTag(value) != objectTag$2) {
return false;
}
var proto = getPrototype$1(value);
if (proto === null) {
return true;
}
var Ctor = hasOwnProperty$1.call(proto, "constructor") && proto.constructor;
return typeof Ctor == "function" && Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString;
}
function baseSlice(array, start, end) {
var index = -1, length = array.length;
if (start < 0) {
start = -start > length ? 0 : length + start;
}
end = end > length ? length : end;
if (end < 0) {
end += length;
}
length = start > end ? 0 : end - start >>> 0;
start >>>= 0;
var result = Array(length);
while (++index < length) {
result[index] = array[index + start];
}
return result;
}
function castSlice(array, start, end) {
var length = array.length;
end = end === void 0 ? length : end;
return !start && end >= length ? array : baseSlice(array, start, end);
}
var rsAstralRange$1 = "\\ud800-\\udfff", rsComboMarksRange$1 = "\\u0300-\\u036f", reComboHalfMarksRange$1 = "\\ufe20-\\ufe2f", rsComboSymbolsRange$1 = "\\u20d0-\\u20ff", rsComboRange$1 = rsComboMarksRange$1 + reComboHalfMarksRange$1 + rsComboSymbolsRange$1, rsVarRange$1 = "\\ufe0e\\ufe0f";
var rsZWJ$1 = "\\u200d";
var reHasUnicode = RegExp("[" + rsZWJ$1 + rsAstralRange$1 + rsComboRange$1 + rsVarRange$1 + "]");
function hasUnicode(string) {
return reHasUnicode.test(string);
}
function asciiToArray(string) {
return string.split("");
}
var rsAstralRange = "\\ud800-\\udfff", rsComboMarksRange = "\\u0300-\\u036f", reComboHalfMarksRange = "\\ufe20-\\ufe2f", rsComboSymbolsRange = "\\u20d0-\\u20ff", rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange, rsVarRange = "\\ufe0e\\ufe0f";
var rsAstral = "[" + rsAstralRange + "]", rsCombo = "[" + rsComboRange + "]", rsFitz = "\\ud83c[\\udffb-\\udfff]", rsModifier = "(?:" + rsCombo + "|" + rsFitz + ")", rsNonAstral = "[^" + rsAstralRange + "]", rsRegional = "(?:\\ud83c[\\udde6-\\uddff]){2}", rsSurrPair = "[\\ud800-\\udbff][\\udc00-\\udfff]", rsZWJ = "\\u200d";
var reOptMod = rsModifier + "?", rsOptVar = "[" + rsVarRange + "]?", rsOptJoin = "(?:" + rsZWJ + "(?:" + [rsNonAstral, rsRegional, rsSurrPair].join("|") + ")" + rsOptVar + reOptMod + ")*", rsSeq = rsOptVar + reOptMod + rsOptJoin, rsSymbol = "(?:" + [rsNonAstral + rsCombo + "?", rsCombo, rsRegional, rsSurrPair, rsAstral].join("|") + ")";
var reUnicode = RegExp(rsFitz + "(?=" + rsFitz + ")|" + rsSymbol + rsSeq, "g");
function unicodeToArray(string) {
return string.match(reUnicode) || [];
}
function stringToArray(string) {
return hasUnicode(string) ? unicodeToArray(string) : asciiToArray(string);
}
function stackClear() {
this.__data__ = new ListCache();
this.size = 0;
}
function stackDelete(key) {
var data = this.__data__, result = data["delete"](key);
this.size = data.size;
return result;
}
function stackGet(key) {
return this.__data__.get(key);
}
function stackHas(key) {
return this.__data__.has(key);
}
var LARGE_ARRAY_SIZE = 200;
function stackSet(key, value) {
var data = this.__data__;
if (data instanceof ListCache) {
var pairs = data.__data__;
if (!Map$2 || pairs.length < LARGE_ARRAY_SIZE - 1) {
pairs.push([key, value]);
this.size = ++data.size;
return this;
}
data = this.__data__ = new MapCache(pairs);
}
data.set(key, value);
this.size = data.size;
return this;
}
function Stack(entries) {
var data = this.__data__ = new ListCache(entries);
this.size = data.size;
}
Stack.prototype.clear = stackClear;
Stack.prototype["delete"] = stackDelete;
Stack.prototype.get = stackGet;
Stack.prototype.has = stackHas;
Stack.prototype.set = stackSet;
function baseAssign(object, source) {
return object && copyObject(source, keys(source), object);
}
function baseAssignIn(object, source) {
return object && copyObject(source, keysIn(source), object);
}
var freeExports = typeof exports == "object" && exports && !exports.nodeType && exports;
var freeModule = freeExports && typeof module == "object" && module && !module.nodeType && module;
var moduleExports = freeModule && freeModule.exports === freeExports;
var Buffer = moduleExports ? root$1.Buffer : void 0, allocUnsafe = Buffer ? Buffer.allocUnsafe : void 0;
function cloneBuffer(buffer, isDeep) {
if (isDeep) {
return buffer.slice();
}
var length = buffer.length, result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);
buffer.copy(result);
return result;
}
function arrayFilter(array, predicate) {
var index = -1, length = array == null ? 0 : array.length, resIndex = 0, result = [];
while (++index < length) {
var value = array[index];
if (predicate(value, index, array)) {
result[resIndex++] = value;
}
}
return result;
}
function stubArray() {
return [];
}
var objectProto$1 = Object.prototype;
var propertyIsEnumerable = objectProto$1.propertyIsEnumerable;
var nativeGetSymbols$1 = Object.getOwnPropertySymbols;
var getSymbols = !nativeGetSymbols$1 ? stubArray : function(object) {
if (object == null) {
return [];
}
object = Object(object);
return arrayFilter(nativeGetSymbols$1(object), function(symbol) {
return propertyIsEnumerable.call(object, symbol);
});
};
const getSymbols$1 = getSymbols;
function copySymbols(source, object) {
return copyObject(source, getSymbols$1(source), object);
}
var nativeGetSymbols = Object.getOwnPropertySymbols;
var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {
var result = [];
while (object) {
arrayPush(result, getSymbols$1(object));
object = getPrototype$1(object);
}
return result;
};
const getSymbolsIn$1 = getSymbolsIn;
function copySymbolsIn(source, object) {
return copyObject(source, getSymbolsIn$1(source), object);
}
function baseGetAllKeys(object, keysFunc, symbolsFunc) {
var result = keysFunc(object);
return isArray$1(object) ? result : arrayPush(result, symbolsFunc(object));
}
function getAllKeys(object) {
return baseGetAllKeys(object, keys, getSymbols$1);
}
function getAllKeysIn(object) {
return baseGetAllKeys(object, keysIn, getSymbolsIn$1);
}
var DataView = getNative(root$1, "DataView");
const DataView$1 = DataView;
var Promise$1 = getNative(root$1, "Promise");
const Promise$2 = Promise$1;
var Set = getNative(root$1, "Set");
const Set$1 = Set;
var mapTag$3 = "[object Map]", objectTag$1 = "[object Object]", promiseTag = "[object Promise]", setTag$3 = "[object Set]", weakMapTag$1 = "[object WeakMap]";
var dataViewTag$2 = "[object DataView]";
var dataViewCtorString = toSource(DataView$1), mapCtorString = toSource(Map$2), promiseCtorString = toSource(Promise$2), setCtorString = toSource(Set$1), weakMapCtorString = toSource(WeakMap$1);
var getTag = baseGetTag;
if (DataView$1 && getTag(new DataView$1(new ArrayBuffer(1))) != dataViewTag$2 || Map$2 && getTag(new Map$2()) != mapTag$3 || Promise$2 && getTag(Promise$2.resolve()) != promiseTag || Set$1 && getTag(new Set$1()) != setTag$3 || WeakMap$1 && getTag(new WeakMap$1()) != weakMapTag$1) {
getTag = function(value) {
var result = baseGetTag(value), Ctor = result == objectTag$1 ? value.constructor : void 0, ctorString = Ctor ? toSource(Ctor) : "";
if (ctorString) {
switch (ctorString) {
case dataViewCtorString:
return dataViewTag$2;
case mapCtorString:
return mapTag$3;
case promiseCtorString:
return promiseTag;
case setCtorString:
return setTag$3;
case weakMapCtorString:
return weakMapTag$1;
}
}
return result;
};
}
const getTag$1 = getTag;
var objectProto = Object.prototype;
var hasOwnProperty = objectProto.hasOwnProperty;
function initCloneArray(array) {
var length = array.length, result = new array.constructor(length);
if (length && typeof array[0] == "string" && hasOwnProperty.call(array, "index")) {
result.index = array.index;
result.input = array.input;
}
return result;
}
var Uint8Array$1 = root$1.Uint8Array;
const Uint8Array$2 = Uint8Array$1;
function cloneArrayBuffer(arrayBuffer) {
var result = new arrayBuffer.constructor(arrayBuffer.byteLength);
new Uint8Array$2(result).set(new Uint8Array$2(arrayBuffer));
return result;
}
function cloneDataView(dataView, isDeep) {
var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;
return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);
}
var reFlags = /\w*$/;
function cloneRegExp(regexp) {
var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));
result.lastIndex = regexp.lastIndex;
return result;
}
var symbolProto = Symbol$2 ? Symbol$2.prototype : void 0, symbolValueOf = symbolProto ? symbolProto.valueOf : void 0;
function cloneSymbol(symbol) {
return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};
}
function cloneTypedArray(typedArray, isDeep) {
var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;
return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);
}
var boolTag$1 = "[object Boolean]", dateTag$2 = "[object Date]", mapTag$2 = "[object Map]", numberTag$2 = "[object Number]", regexpTag$1 = "[object RegExp]", setTag$2 = "[object Set]", stringTag$2 = "[object String]", symbolTag$1 = "[object Symbol]";
var arrayBufferTag$1 = "[object ArrayBuffer]", dataViewTag$1 = "[object DataView]", float32Tag$1 = "[object Float32Array]", float64Tag$1 = "[object Float64Array]", int8Tag$1 = "[object Int8Array]", int16Tag$1 = "[object Int16Array]", int32Tag$1 = "[object Int32Array]", uint8Tag$1 = "[object Uint8Array]", uint8ClampedTag$1 = "[object Uint8ClampedArray]", uint16Tag$1 = "[object Uint16Array]", uint32Tag$1 = "[object Uint32Array]";
function initCloneByTag(object, tag, isDeep) {
var Ctor = object.constructor;
switch (tag) {
case arrayBufferTag$1:
return cloneArrayBuffer(object);
case boolTag$1:
case dateTag$2:
return new Ctor(+object);
case dataViewTag$1:
return cloneDataView(object, isDeep);
case float32Tag$1:
case float64Tag$1:
case int8Tag$1:
case int16Tag$1:
case int32Tag$1:
case uint8Tag$1:
case uint8ClampedTag$1:
case uint16Tag$1:
case uint32Tag$1:
return cloneTypedArray(object, isDeep);
case mapTag$2:
return new Ctor();
case numberTag$2:
case stringTag$2:
return new Ctor(object);
case regexpTag$1:
return cloneRegExp(object);
case setTag$2:
return new Ctor();
case symbolTag$1:
return cloneSymbol(object);
}
}
function initCloneObject(object) {
return typeof object.constructor == "function" && !isPrototype(object) ? baseCreate$1(getPrototype$1(object)) : {};
}
var mapTag$1 = "[object Map]";
function baseIsMap(value) {
return isObjectLike(value) && getTag$1(value) == mapTag$1;
}
var nodeIsMap = nodeUtil$1 && nodeUtil$1.isMap;
var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;
const isMap$1 = isMap;
var setTag$1 = "[object Set]";
function baseIsSet(value) {
return isObjectLike(value) && getTag$1(value) == setTag$1;
}
var nodeIsSet = nodeUtil$1 && nodeUtil$1.isSet;
var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;
const isSet$1 = isSet;
var CLONE_DEEP_FLAG$1 = 1, CLONE_FLAT_FLAG = 2, CLONE_SYMBOLS_FLAG$2 = 4;
var argsTag = "[object Arguments]", arrayTag = "[object Array]", boolTag = "[object Boolean]", dateTag$1 = "[object Date]", errorTag = "[object Error]", funcTag = "[object Function]", genTag = "[object GeneratorFunction]", mapTag = "[object Map]", numberTag$1 = "[object Number]", objectTag = "[object Object]", regexpTag = "[object RegExp]", setTag = "[object Set]", stringTag$1 = "[object String]", symbolTag = "[object Symbol]", weakMapTag = "[object WeakMap]";
var arrayBufferTag = "[object ArrayBuffer]", dataViewTag = "[object DataView]", float32Tag = "[object Float32Array]", float64Tag = "[object Float64Array]", int8Tag = "[object Int8Array]", int16Tag = "[object Int16Array]", int32Tag = "[object Int32Array]", uint8Tag = "[object Uint8Array]", uint8ClampedTag = "[object Uint8ClampedArray]", uint16Tag = "[object Uint16Array]", uint32Tag = "[object Uint32Array]";
var cloneableTags = {};
cloneableTags[argsTag] = cloneableTags[arrayTag] = cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] = cloneableTags[boolTag] = cloneableTags[dateTag$1] = cloneableTags[float32Tag] = cloneableTags[float64Tag] = cloneableTags[int8Tag] = cloneableTags[int16Tag] = cloneableTags[int32Tag] = cloneableTags[mapTag] = cloneableTags[numberTag$1] = cloneableTags[objectTag] = cloneableTags[regexpTag] = cloneableTags[setTag] = cloneableTags[stringTag$1] = cloneableTags[symbolTag] = cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] = cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;
cloneableTags[errorTag] = cloneableTags[funcTag] = cloneableTags[weakMapTag] = false;
function baseClone(value, bitmask, customizer, key, object, stack) {
var result, isDeep = bitmask & CLONE_DEEP_FLAG$1, isFlat = bitmask & CLONE_FLAT_FLAG, isFull = bitmask & CLONE_SYMBOLS_FLAG$2;
if (customizer) {
result = object ? customizer(value, key, object, stack) : customizer(value);
}
if (result !== void 0) {
return result;
}
if (!isObject(value)) {
return value;
}
var isArr = isArray$1(value);
if (isArr) {
result = initCloneArray(value);
if (!isDeep) {
return copyArray(value, result);
}
} else {
var tag = getTag$1(value), isFunc = tag == funcTag || tag == genTag;
if (isBuffer$1(value)) {
return cloneBuffer(value, isDeep);
}
if (tag == objectTag || tag == argsTag || isFunc && !object) {
result = isFlat || isFunc ? {} : initCloneObject(value);
if (!isDeep) {
return isFlat ? copySymbolsIn(value, baseAssignIn(result, value)) : copySymbols(value, baseAssign(result, value));
}
} else {
if (!cloneableTags[tag]) {
return object ? value : {};
}
result = initCloneByTag(value, tag, isDeep);
}
}
stack || (stack = new Stack());
var stacked = stack.get(value);
if (stacked) {
return stacked;
}
stack.set(value, result);
if (isSet$1(value)) {
value.forEach(function(subValue) {
result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));
});
} else if (isMap$1(value)) {
value.forEach(function(subValue, key2) {
result.set(key2, baseClone(subValue, bitmask, customizer, key2, value, stack));
});
}
var keysFunc = isFull ? isFlat ? getAllKeysIn : getAllKeys : isFlat ? keysIn : keys;
var props = isArr ? void 0 : keysFunc(value);
arrayEach(props || value, function(subValue, key2) {
if (props) {
key2 = subValue;
subValue = value[key2];
}
assignValue(result, key2, baseClone(subValue, bitmask, customizer, key2, value, stack));
});
return result;
}
var CLONE_SYMBOLS_FLAG$1 = 4;
function clone(value) {
return baseClone(value, CLONE_SYMBOLS_FLAG$1);
}
var CLONE_DEEP_FLAG = 1, CLONE_SYMBOLS_FLAG = 4;
function cloneDeep(value) {
return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);
}
function createBaseFor(fromRight) {
return function(object, iteratee, keysFunc) {
var index = -1, iterable = Object(object), props = keysFunc(object), length = props.length;
while (length--) {
var key = props[fromRight ? length : ++index];
if (iteratee(iterable[key], key, iterable) === false) {
break;
}
}
return object;
};
}
var baseFor = createBaseFor();
const baseFor$1 = baseFor;
var now = function() {
return root$1.Date.now();
};
const now$1 = now;
var FUNC_ERROR_TEXT$1 = "Expected a function";
var nativeMax = Math.max, nativeMin = Math.min;
function debounce(func, wait, options) {
var lastArgs, lastThis, maxWait, result, timerId, lastCallTime, lastInvokeTime = 0, leading = false, maxing = false, trailing = true;
if (typeof func != "function") {
throw new TypeError(FUNC_ERROR_TEXT$1);
}
wait = toNumber(wait) || 0;
if (isObject(options)) {
leading = !!options.leading;
maxing = "maxWait" in options;
maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;
trailing = "trailing" in options ? !!options.trailing : trailing;
}
function invokeFunc(time) {
var args = lastArgs, thisArg = lastThis;
lastArgs = lastThis = void 0;
lastInvokeTime = time;
result = func.apply(thisArg, args);
return result;
}
function leadingEdge(time) {
lastInvokeTime = time;
timerId = setTimeout(timerExpired, wait);
return leading ? invokeFunc(time) : result;
}
function remainingWait(time) {
var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime, timeWaiting = wait - timeSinceLastCall;
return maxing ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke) : timeWaiting;
}
function shouldInvoke(time) {
var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime;
return lastCallTime === void 0 || timeSinceLastCall >= wait || timeSinceLastCall < 0 || maxing && timeSinceLastInvoke >= maxWait;
}
function timerExpired() {
var time = now$1();
if (shouldInvoke(time)) {
return trailingEdge(time);
}
timerId = setTimeout(timerExpired, remainingWait(time));
}
function trailingEdge(time) {
timerId = void 0;
if (trailing && lastArgs) {
return invokeFunc(time);
}
lastArgs = lastThis = void 0;
return result;
}
function cancel() {
if (timerId !== void 0) {
clearTimeout(timerId);
}
lastInvokeTime = 0;
lastArgs = lastCallTime = lastThis = timerId = void 0;
}
function flush() {
return timerId === void 0 ? result : trailingEdge(now$1());
}
function debounced() {
var time = now$1(), isInvoking = shouldInvoke(time);
lastArgs = arguments;
lastThis = this;
lastCallTime = time;
if (isInvoking) {
if (timerId === void 0) {
return leadingEdge(lastCallTime);
}
if (maxing) {
clearTimeout(timerId);
timerId = setTimeout(timerExpired, wait);
return invokeFunc(lastCallTime);
}
}
if (timerId === void 0) {
timerId = setTimeout(timerExpired, wait);
}
return result;
}
debounced.cancel = cancel;
debounced.flush = flush;
return debounced;
}
function assignMergeValue(object, key, value) {
if (value !== void 0 && !eq(object[key], value) || value === void 0 && !(key in object)) {
baseAssignValue(object, key, value);
}
}
function isArrayLikeObject(value) {
return isObjectLike(value) && isArrayLike(value);
}
function safeGet(object, key) {
if (key === "constructor" && typeof object[key] === "function") {
return;
}
if (key == "__proto__") {
return;
}
return object[key];
}
function toPlainObject(value) {
return copyObject(value, keysIn(value));
}
function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {
var objValue = safeGet(object, key), srcValue = safeGet(source, key), stacked = stack.get(srcValue);
if (stacked) {
assignMergeValue(object, key, stacked);
return;
}
var newValue = customizer ? customizer(objValue, srcValue, key + "", object, source, stack) : void 0;
var isCommon = newValue === void 0;
if (isCommon) {
var isArr = isArray$1(srcValue), isBuff = !isArr && isBuffer$1(srcValue), isTyped = !isArr && !isBuff && isTypedArray$1(srcValue);
newValue = srcValue;
if (isArr || isBuff || isTyped) {
if (isArray$1(objValue)) {
newValue = objValue;
} else if (isArrayLikeObject(objValue)) {
newValue = copyArray(objValue);
} else if (isBuff) {
isCommon = false;
newValue = cloneBuffer(srcValue, true);
} else if (isTyped) {
isCommon = false;
newValue = cloneTypedArray(srcValue, true);
} else {
newValue = [];
}
} else if (isPlainObject(srcValue) || isArguments$1(srcValue)) {
newValue = objValue;
if (isArguments$1(objValue)) {
newValue = toPlainObject(objValue);
} else if (!isObject(objValue) || isFunction(objValue)) {
newValue = initCloneObject(srcValue);
}
} else {
isCommon = false;
}
}
if (isCommon) {
stack.set(srcValue, newValue);
mergeFunc(newValue, srcValue, srcIndex, customizer, stack);
stack["delete"](srcValue);
}
assignMergeValue(object, key, newValue);
}
function baseMerge(object, source, srcIndex, customizer, stack) {
if (object === source) {
return;
}
baseFor$1(source, function(srcValue, key) {
stack || (stack = new Stack());
if (isObject(srcValue)) {
baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);
} else {
var newValue = customizer ? customizer(safeGet(object, key), srcValue, key + "", object, source, stack) : void 0;
if (newValue === void 0) {
newValue = srcValue;
}
assignMergeValue(object, key, newValue);
}
}, keysIn);
}
function customDefaultsMerge(objValue, srcValue, key, object, source, stack) {
if (isObject(objValue) && isObject(srcValue)) {
stack.set(srcValue, objValue);
baseMerge(objValue, srcValue, void 0, customDefaultsMerge, stack);
stack["delete"](srcValue);
}
return objValue;
}
var mergeWith = createAssigner(function(object, source, srcIndex, customizer) {
baseMerge(object, source, srcIndex, customizer);
});
const mergeWith$1 = mergeWith;
var defaultsDeep = baseRest(function(args) {
args.push(void 0, customDefaultsMerge);
return apply(mergeWith$1, void 0, args);
});
const defaultsDeep$1 = defaultsDeep;
var stringTag = "[object String]";
function isString(value) {
return typeof value == "string" || !isArray$1(value) && isObjectLike(value) && baseGetTag(value) == stringTag;
}
var dateTag = "[object Date]";
function baseIsDate(value) {
return isObjectLike(value) && baseGetTag(value) == dateTag;
}
var nodeIsDate = nodeUtil$1 && nodeUtil$1.isDate;
var isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate;
const isDate$1 = isDate;
var numberTag = "[object Number]";
function isNumber(value) {
return typeof value == "number" || isObjectLike(value) && baseGetTag(value) == numberTag;
}
var merge = createAssigner(function(object, source, srcIndex) {
baseMerge(object, source, srcIndex);
});
const merge$1 = merge;
var FUNC_ERROR_TEXT = "Expected a function";
function throttle(func, wait, options) {
var leading = true, trailing = true;
if (typeof func != "function") {
throw new TypeError(FUNC_ERROR_TEXT);
}
if (isObject(options)) {
leading = "leading" in options ? !!options.leading : leading;
trailing = "trailing" in options ? !!options.trailing : trailing;
}
return debounce(func, wait, {
"leading": leading,
"maxWait": wait,
"trailing": trailing
});
}
function charsEndIndex(strSymbols, chrSymbols) {
var index = strSymbols.length;
while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {
}
return index;
}
function charsStartIndex(strSymbols, chrSymbols) {
var index = -1, length = strSymbols.length;
while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {
}
return index;
}
function trim(string, chars, guard) {
string = toString(string);
if (string && (guard || chars === void 0)) {
return baseTrim(string);
}
if (!string || !(chars = baseToString(chars))) {
return string;
}
var strSymbols = stringToArray(string), chrSymbols = stringToArray(chars), start = charsStartIndex(strSymbols, chrSymbols), end = charsEndIndex(strSymbols, chrSymbols) + 1;
return castSlice(strSymbols, start, end).join("");
}
/**
* @license
* Copyright 2010-2023 Three.js Authors
* SPDX-License-Identifier: MIT
*/
const REVISION = "156";
function clamp(value, min, max) {
return Math.max(min, Math.min(max, value));
}
class Matrix3 {
constructor(n11, n12, n13, n21, n22, n23, n31, n32, n33) {
Matrix3.prototype.isMatrix3 = true;
this.elements = [
1,
0,
0,
0,
1,
0,
0,
0,
1
];
if (n11 !== void 0) {
this.set(n11, n12, n13, n21, n22, n23, n31, n32, n33);
}
}
set(n11, n12, n13, n21, n22, n23, n31, n32, n33) {
const te = this.elements;
te[0] = n11;
te[1] = n21;
te[2] = n31;
te[3] = n12;
te[4] = n22;
te[5] = n32;
te[6] = n13;
te[7] = n23;
te[8] = n33;
return this;
}
identity() {
this.set(
1,
0,
0,
0,
1,
0,
0,
0,
1
);
return this;
}
copy(m) {
const te = this.elements;
const me = m.elements;
te[0] = me[0];
te[1] = me[1];
te[2] = me[2];
te[3] = me[3];
te[4] = me[4];
te[5] = me[5];
te[6] = me[6];
te[7] = me[7];
te[8] = me[8];
return this;
}
extractBasis(xAxis, yAxis, zAxis) {
xAxis.setFromMatrix3Column(this, 0);
yAxis.setFromMatrix3Column(this, 1);
zAxis.setFromMatrix3Column(this, 2);
return this;
}
setFromMatrix4(m) {
const me = m.elements;
this.set(
me[0],
me[4],
me[8],
me[1],
me[5],
me[9],
me[2],
me[6],
me[10]
);
return this;
}
multiply(m) {
return this.multiplyMatrices(this, m);
}
premultiply(m) {
return this.multiplyMatrices(m, this);
}
multiplyMatrices(a, b) {
const ae = a.elements;
const be = b.elements;
const te = this.elements;
const a11 = ae[0], a12 = ae[3], a13 = ae[6];
const a21 = ae[1], a22 = ae[4], a23 = ae[7];
const a31 = ae[2], a32 = ae[5], a33 = ae[8];
const b11 = be[0], b12 = be[3], b13 = be[6];
const b21 = be[1], b22 = be[4], b23 = be[7];
const b31 = be[2], b32 = be[5], b33 = be[8];
te[0] = a11 * b11 + a12 * b21 + a13 * b31;
te[3] = a11 * b12 + a12 * b22 + a13 * b32;
te[6] = a11 * b13 + a12 * b23 + a13 * b33;
te[1] = a21 * b11 + a22 * b21 + a23 * b31;
te[4] = a21 * b12 + a22 * b22 + a23 * b32;
te[7] = a21 * b13 + a22 * b23 + a23 * b33;
te[2] = a31 * b11 + a32 * b21 + a33 * b31;
te[5] = a31 * b12 + a32 * b22 + a33 * b32;
te[8] = a31 * b13 + a32 * b23 + a33 * b33;
return this;
}
multiplyScalar(s) {
const te = this.elements;
te[0] *= s;
te[3] *= s;
te[6] *= s;
te[1] *= s;
te[4] *= s;
te[7] *= s;
te[2] *= s;
te[5] *= s;
te[8] *= s;
return this;
}
determinant() {
const te = this.elements;
const a = te[0], b = te[1], c = te[2], d = te[3], e = te[4], f = te[5], g = te[6], h = te[7], i2 = te[8];
return a * e * i2 - a * f * h - b * d * i2 + b * f * g + c * d * h - c * e * g;
}
invert() {
const te = this.elements, n11 = te[0], n21 = te[1], n31 = te[2], n12 = te[3], n22 = te[4], n32 = te[5], n13 = te[6], n23 = te[7], n33 = te[8], t11 = n33 * n22 - n32 * n23, t12 = n32 * n13 - n33 * n12, t13 = n23 * n12 - n22 * n13, det = n11 * t11 + n21 * t12 + n31 * t13;
if (det === 0)
return this.set(0, 0, 0, 0, 0, 0, 0, 0, 0);
const detInv = 1 / det;
te[0] = t11 * detInv;
te[1] = (n31 * n23 - n33 * n21) * detInv;
te[2] = (n32 * n21 - n31 * n22) * detInv;
te[3] = t12 * detInv;
te[4] = (n33 * n11 - n31 * n13) * detInv;
te[5] = (n31 * n12 - n32 * n11) * detInv;
te[6] = t13 * detInv;
te[7] = (n21 * n13 - n23 * n11) * detInv;
te[8] = (n22 * n11 - n21 * n12) * detInv;
return this;
}
transpose() {
let tmp;
const m = this.elements;
tmp = m[1];
m[1] = m[3];
m[3] = tmp;
tmp = m[2];
m[2] = m[6];
m[6] = tmp;
tmp = m[5];
m[5] = m[7];
m[7] = tmp;
return this;
}
getNormalMatrix(matrix4) {
return this.setFromMatrix4(matrix4).invert().transpose();
}
transposeIntoArray(r) {
const m = this.elements;
r[0] = m[0];
r[1] = m[3];
r[2] = m[6];
r[3] = m[1];
r[4] = m[4];
r[5] = m[7];
r[6] = m[2];
r[7] = m[5];
r[8] = m[8];
return this;
}
setUvTransform(tx, ty, sx, sy, rotation, cx, cy) {
const c = Math.cos(rotation);
const s = Math.sin(rotation);
this.set(
sx * c,
sx * s,
-sx * (c * cx + s * cy) + cx + tx,
-sy * s,
sy * c,
-sy * (-s * cx + c * cy) + cy + ty,
0,
0,
1
);
return this;
}
//
scale(sx, sy) {
this.premultiply(_m3.makeScale(sx, sy));
return this;
}
rotate(theta) {
this.premultiply(_m3.makeRotation(-theta));
return this;
}
translate(tx, ty) {
this.premultiply(_m3.makeTranslation(tx, ty));
return this;
}
// for 2D Transforms
makeTranslation(x2, y2) {
if (x2.isVector2) {
this.set(
1,
0,
x2.x,
0,
1,
x2.y,
0,
0,
1
);
} else {
this.set(
1,
0,
x2,
0,
1,
y2,
0,
0,
1
);
}
return this;
}
makeRotation(theta) {
const c = Math.cos(theta);
const s = Math.sin(theta);
this.set(
c,
-s,
0,
s,
c,
0,
0,
0,
1
);
return this;
}
makeScale(x2, y2) {
this.set(
x2,
0,
0,
0,
y2,
0,
0,
0,
1
);
return this;
}
//
equals(matrix2) {
const te = this.elements;
const me = matrix2.elements;
for (let i2 = 0; i2 < 9; i2++) {
if (te[i2] !== me[i2])
return false;
}
return true;
}
fromArray(array, offset = 0) {
for (let i2 = 0; i2 < 9; i2++) {
this.elements[i2] = array[i2 + offset];
}
return this;
}
toArray(array = [], offset = 0) {
const te = this.elements;
array[offset] = te[0];
array[offset + 1] = te[1];
array[offset + 2] = te[2];
array[offset + 3] = te[3];
array[offset + 4] = te[4];
array[offset + 5] = te[5];
array[offset + 6] = te[6];
array[offset + 7] = te[7];
array[offset + 8] = te[8];
return array;
}
clone() {
return new this.constructor().fromArray(this.elements);
}
}
const _m3 = /* @__PURE__ */ new Matrix3();
class Quaternion {
constructor(x2 = 0, y2 = 0, z = 0, w = 1) {
this.isQuaternion = true;
this._x = x2;
this._y = y2;
this._z = z;
this._w = w;
}
static slerpFlat(dst, dstOffset, src0, srcOffset0, src1, srcOffset1, t) {
let x0 = src0[srcOffset0 + 0], y0 = src0[srcOffset0 + 1], z0 = src0[srcOffset0 + 2], w0 = src0[srcOffset0 + 3];
const x1 = src1[srcOffset1 + 0], y1 = src1[srcOffset1 + 1], z1 = src1[srcOffset1 + 2], w1 = src1[srcOffset1 + 3];
if (t === 0) {
dst[dstOffset + 0] = x0;
dst[dstOffset + 1] = y0;
dst[dstOffset + 2] = z0;
dst[dstOffset + 3] = w0;
return;
}
if (t === 1) {
dst[dstOffset + 0] = x1;
dst[dstOffset + 1] = y1;
dst[dstOffset + 2] = z1;
dst[dstOffset + 3] = w1;
return;
}
if (w0 !== w1 || x0 !== x1 || y0 !== y1 || z0 !== z1) {
let s = 1 - t;
const cos = x0 * x1 + y0 * y1 + z0 * z1 + w0 * w1, dir = cos >= 0 ? 1 : -1, sqrSin = 1 - cos * cos;
if (sqrSin > Number.EPSILON) {
const sin = Math.sqrt(sqrSin), len = Math.atan2(sin, cos * dir);
s = Math.sin(s * len) / sin;
t = Math.sin(t * len) / sin;
}
const tDir = t * dir;
x0 = x0 * s + x1 * tDir;
y0 = y0 * s + y1 * tDir;
z0 = z0 * s + z1 * tDir;
w0 = w0 * s + w1 * tDir;
if (s === 1 - t) {
const f = 1 / Math.sqrt(x0 * x0 + y0 * y0 + z0 * z0 + w0 * w0);
x0 *= f;
y0 *= f;
z0 *= f;
w0 *= f;
}
}
dst[dstOffset] = x0;
dst[dstOffset + 1] = y0;
dst[dstOffset + 2] = z0;
dst[dstOffset + 3] = w0;
}
static multiplyQuaternionsFlat(dst, dstOffset, src0, srcOffset0, src1, srcOffset1) {
const x0 = src0[srcOffset0];
const y0 = src0[srcOffset0 + 1];
const z0 = src0[srcOffset0 + 2];
const w0 = src0[srcOffset0 + 3];
const x1 = src1[srcOffset1];
const y1 = src1[srcOffset1 + 1];
const z1 = src1[srcOffset1 + 2];
const w1 = src1[srcOffset1 + 3];
dst[dstOffset] = x0 * w1 + w0 * x1 + y0 * z1 - z0 * y1;
dst[dstOffset + 1] = y0 * w1 + w0 * y1 + z0 * x1 - x0 * z1;
dst[dstOffset + 2] = z0 * w1 + w0 * z1 + x0 * y1 - y0 * x1;
dst[dstOffset + 3] = w0 * w1 - x0 * x1 - y0 * y1 - z0 * z1;
return dst;
}
get x() {
return this._x;
}
set x(value) {
this._x = value;
this._onChangeCallback();
}
get y() {
return this._y;
}
set y(value) {
this._y = value;
this._onChangeCallback();
}
get z() {
return this._z;
}
set z(value) {
this._z = value;
this._onChangeCallback();
}
get w() {
return this._w;
}
set w(value) {
this._w = value;
this._onChangeCallback();
}
set(x2, y2, z, w) {
this._x = x2;
this._y = y2;
this._z = z;
this._w = w;
this._onChangeCallback();
return this;
}
clone() {
return new this.constructor(this._x, this._y, this._z, this._w);
}
copy(quaternion) {
this._x = quaternion.x;
this._y = quaternion.y;
this._z = quaternion.z;
this._w = quaternion.w;
this._onChangeCallback();
return this;
}
setFromEuler(euler, update) {
const x2 = euler._x, y2 = euler._y, z = euler._z, order = euler._order;
const cos = Math.cos;
const sin = Math.sin;
const c1 = cos(x2 / 2);
const c2 = cos(y2 / 2);
const c3 = cos(z / 2);
const s1 = sin(x2 / 2);
const s2 = sin(y2 / 2);
const s3 = sin(z / 2);
switch (order) {
case "XYZ":
this._x = s1 * c2 * c3 + c1 * s2 * s3;
this._y = c1 * s2 * c3 - s1 * c2 * s3;
this._z = c1 * c2 * s3 + s1 * s2 * c3;
this._w = c1 * c2 * c3 - s1 * s2 * s3;
break;
case "YXZ":
this._x = s1 * c2 * c3 + c1 * s2 * s3;
this._y = c1 * s2 * c3 - s1 * c2 * s3;
this._z = c1 * c2 * s3 - s1 * s2 * c3;
this._w = c1 * c2 * c3 + s1 * s2 * s3;
break;
case "ZXY":
this._x = s1 * c2 * c3 - c1 * s2 * s3;
this._y = c1 * s2 * c3 + s1 * c2 * s3;
this._z = c1 * c2 * s3 + s1 * s2 * c3;
this._w = c1 * c2 * c3 - s1 * s2 * s3;
break;
case "ZYX":
this._x = s1 * c2 * c3 - c1 * s2 * s3;
this._y = c1 * s2 * c3 + s1 * c2 * s3;
this._z = c1 * c2 * s3 - s1 * s2 * c3;
this._w = c1 * c2 * c3 + s1 * s2 * s3;
break;
case "YZX":
this._x = s1 * c2 * c3 + c1 * s2 * s3;
this._y = c1 * s2 * c3 + s1 * c2 * s3;
this._z = c1 * c2 * s3 - s1 * s2 * c3;
this._w = c1 * c2 * c3 - s1 * s2 * s3;
break;
case "XZY":
this._x = s1 * c2 * c3 - c1 * s2 * s3;
this._y = c1 * s2 * c3 - s1 * c2 * s3;
this._z = c1 * c2 * s3 + s1 * s2 * c3;
this._w = c1 * c2 * c3 + s1 * s2 * s3;
break;
default:
console.warn("THREE.Quaternion: .setFromEuler() encountered an unknown order: " + order);
}
if (update !== false)
this._onChangeCallback();
return this;
}
setFromAxisAngle(axis, angle2) {
const halfAngle = angle2 / 2, s = Math.sin(halfAngle);
this._x = axis.x * s;
this._y = axis.y * s;
this._z = axis.z * s;
this._w = Math.cos(halfAngle);
this._onChangeCallback();
return this;
}
setFromRotationMatrix(m) {
const te = m.elements, m11 = te[0], m12 = te[4], m13 = te[8], m21 = te[1], m22 = te[5], m23 = te[9], m31 = te[2], m32 = te[6], m33 = te[10], trace = m11 + m22 + m33;
if (trace > 0) {
const s = 0.5 / Math.sqrt(trace + 1);
this._w = 0.25 / s;
this._x = (m32 - m23) * s;
this._y = (m13 - m31) * s;
this._z = (m21 - m12) * s;
} else if (m11 > m22 && m11 > m33) {
const s = 2 * Math.sqrt(1 + m11 - m22 - m33);
this._w = (m32 - m23) / s;
this._x = 0.25 * s;
this._y = (m12 + m21) / s;
this._z = (m13 + m31) / s;
} else if (m22 > m33) {
const s = 2 * Math.sqrt(1 + m22 - m11 - m33);
this._w = (m13 - m31) / s;
this._x = (m12 + m21) / s;
this._y = 0.25 * s;
this._z = (m23 + m32) / s;
} else {
const s = 2 * Math.sqrt(1 + m33 - m11 - m22);
this._w = (m21 - m12) / s;
this._x = (m13 + m31) / s;
this._y = (m23 + m32) / s;
this._z = 0.25 * s;
}
this._onChangeCallback();
return this;
}
setFromUnitVectors(vFrom, vTo) {
let r = vFrom.dot(vTo) + 1;
if (r < Number.EPSILON) {
r = 0;
if (Math.abs(vFrom.x) > Math.abs(vFrom.z)) {
this._x = -vFrom.y;
this._y = vFrom.x;
this._z = 0;
this._w = r;
} else {
this._x = 0;
this._y = -vFrom.z;
this._z = vFrom.y;
this._w = r;
}
} else {
this._x = vFrom.y * vTo.z - vFrom.z * vTo.y;
this._y = vFrom.z * vTo.x - vFrom.x * vTo.z;
this._z = vFrom.x * vTo.y - vFrom.y * vTo.x;
this._w = r;
}
return this.normalize();
}
angleTo(q) {
return 2 * Math.acos(Math.abs(clamp(this.dot(q), -1, 1)));
}
rotateTowards(q, step) {
const angle2 = this.angleTo(q);
if (angle2 === 0)
return this;
const t = Math.min(1, step / angle2);
this.slerp(q, t);
return this;
}
identity() {
return this.set(0, 0, 0, 1);
}
invert() {
return this.conjugate();
}
conjugate() {
this._x *= -1;
this._y *= -1;
this._z *= -1;
this._onChangeCallback();
return this;
}
dot(v) {
return this._x * v._x + this._y * v._y + this._z * v._z + this._w * v._w;
}
lengthSq() {
return this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w;
}
length() {
return Math.sqrt(this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w);
}
normalize() {
let l = this.length();
if (l === 0) {
this._x = 0;
this._y = 0;
this._z = 0;
this._w = 1;
} else {
l = 1 / l;
this._x = this._x * l;
this._y = this._y * l;
this._z = this._z * l;
this._w = this._w * l;
}
this._onChangeCallback();
return this;
}
multiply(q) {
return this.multiplyQuaternions(this, q);
}
premultiply(q) {
return this.multiplyQuaternions(q, this);
}
multiplyQuaternions(a, b) {
const qax = a._x, qay = a._y, qaz = a._z, qaw = a._w;
const qbx = b._x, qby = b._y, qbz = b._z, qbw = b._w;
this._x = qax * qbw + qaw * qbx + qay * qbz - qaz * qby;
this._y = qay * qbw + qaw * qby + qaz * qbx - qax * qbz;
this._z = qaz * qbw + qaw * qbz + qax * qby - qay * qbx;
this._w = qaw * qbw - qax * qbx - qay * qby - qaz * qbz;
this._onChangeCallback();
return this;
}
slerp(qb, t) {
if (t === 0)
return this;
if (t === 1)
return this.copy(qb);
const x2 = this._x, y2 = this._y, z = this._z, w = this._w;
let cosHalfTheta = w * qb._w + x2 * qb._x + y2 * qb._y + z * qb._z;
if (cosHalfTheta < 0) {
this._w = -qb._w;
this._x = -qb._x;
this._y = -qb._y;
this._z = -qb._z;
cosHalfTheta = -cosHalfTheta;
} else {
this.copy(qb);
}
if (cosHalfTheta >= 1) {
this._w = w;
this._x = x2;
this._y = y2;
this._z = z;
return this;
}
const sqrSinHalfTheta = 1 - cosHalfTheta * cosHalfTheta;
if (sqrSinHalfTheta <= Number.EPSILON) {
const s = 1 - t;
this._w = s * w + t * this._w;
this._x = s * x2 + t * this._x;
this._y = s * y2 + t * this._y;
this._z = s * z + t * this._z;
this.normalize();
this._onChangeCallback();
return this;
}
const sinHalfTheta = Math.sqrt(sqrSinHalfTheta);
const halfTheta = Math.atan2(sinHalfTheta, cosHalfTheta);
const ratioA = Math.sin((1 - t) * halfTheta) / sinHalfTheta, ratioB = Math.sin(t * halfTheta) / sinHalfTheta;
this._w = w * ratioA + this._w * ratioB;
this._x = x2 * ratioA + this._x * ratioB;
this._y = y2 * ratioA + this._y * ratioB;
this._z = z * ratioA + this._z * ratioB;
this._onChangeCallback();
return this;
}
slerpQuaternions(qa, qb, t) {
return this.copy(qa).slerp(qb, t);
}
random() {
const u1 = Math.random();
const sqrt1u1 = Math.sqrt(1 - u1);
const sqrtu1 = Math.sqrt(u1);
const u2 = 2 * Math.PI * Math.random();
const u3 = 2 * Math.PI * Math.random();
return this.set(
sqrt1u1 * Math.cos(u2),
sqrtu1 * Math.sin(u3),
sqrtu1 * Math.cos(u3),
sqrt1u1 * Math.sin(u2)
);
}
equals(quaternion) {
return quaternion._x === this._x && quaternion._y === this._y && quaternion._z === this._z && quaternion._w === this._w;
}
fromArray(array, offset = 0) {
this._x = array[offset];
this._y = array[offset + 1];
this._z = array[offset + 2];
this._w = array[offset + 3];
this._onChangeCallback();
return this;
}
toArray(array = [], offset = 0) {
array[offset] = this._x;
array[offset + 1] = this._y;
array[offset + 2] = this._z;
array[offset + 3] = this._w;
return array;
}
fromBufferAttribute(attribute, index) {
this._x = attribute.getX(index);
this._y = attribute.getY(index);
this._z = attribute.getZ(index);
this._w = attribute.getW(index);
return this;
}
toJSON() {
return this.toArray();
}
_onChange(callback) {
this._onChangeCallback = callback;
return this;
}
_onChangeCallback() {
}
*[Symbol.iterator]() {
yield this._x;
yield this._y;
yield this._z;
yield this._w;
}
}
class Vector3 {
constructor(x2 = 0, y2 = 0, z = 0) {
Vector3.prototype.isVector3 = true;
this.x = x2;
this.y = y2;
this.z = z;
}
set(x2, y2, z) {
if (z === void 0)
z = this.z;
this.x = x2;
this.y = y2;
this.z = z;
return this;
}
setScalar(scalar) {
this.x = scalar;
this.y = scalar;
this.z = scalar;
return this;
}
setX(x2) {
this.x = x2;
return this;
}
setY(y2) {
this.y = y2;
return this;
}
setZ(z) {
this.z = z;
return this;
}
setComponent(index, value) {
switch (index) {
case 0:
this.x = value;
break;
case 1:
this.y = value;
break;
case 2:
this.z = value;
break;
default:
throw new Error("index is out of range: " + index);
}
return this;
}
getComponent(index) {
switch (index) {
case 0:
return this.x;
case 1:
return this.y;
case 2:
return this.z;
default:
throw new Error("index is out of range: " + index);
}
}
clone() {
return new this.constructor(this.x, this.y, this.z);
}
copy(v) {
this.x = v.x;
this.y = v.y;
this.z = v.z;
return this;
}
add(v) {
this.x += v.x;
this.y += v.y;
this.z += v.z;
return this;
}
addScalar(s) {
this.x += s;
this.y += s;
this.z += s;
return this;
}
addVectors(a, b) {
this.x = a.x + b.x;
this.y = a.y + b.y;
this.z = a.z + b.z;
return this;
}
addScaledVector(v, s) {
this.x += v.x * s;
this.y += v.y * s;
this.z += v.z * s;
return this;
}
sub(v) {
this.x -= v.x;
this.y -= v.y;
this.z -= v.z;
return this;
}
subScalar(s) {
this.x -= s;
this.y -= s;
this.z -= s;
return this;
}
subVectors(a, b) {
this.x = a.x - b.x;
this.y = a.y - b.y;
this.z = a.z - b.z;
return this;
}
multiply(v) {
this.x *= v.x;
this.y *= v.y;
this.z *= v.z;
return this;
}
multiplyScalar(scalar) {
this.x *= scalar;
this.y *= scalar;
this.z *= scalar;
return this;
}
multiplyVectors(a, b) {
this.x = a.x * b.x;
this.y = a.y * b.y;
this.z = a.z * b.z;
return this;
}
applyEuler(euler) {
return this.applyQuaternion(_quaternion$4.setFromEuler(euler));
}
applyAxisAngle(axis, angle2) {
return this.applyQuaternion(_quaternion$4.setFromAxisAngle(axis, angle2));
}
applyMatrix3(m) {
const x2 = this.x, y2 = this.y, z = this.z;
const e = m.elements;
this.x = e[0] * x2 + e[3] * y2 + e[6] * z;
this.y = e[1] * x2 + e[4] * y2 + e[7] * z;
this.z = e[2] * x2 + e[5] * y2 + e[8] * z;
return this;
}
applyNormalMatrix(m) {
return this.applyMatrix3(m).normalize();
}
applyMatrix4(m) {
const x2 = this.x, y2 = this.y, z = this.z;
const e = m.elements;
const w = 1 / (e[3] * x2 + e[7] * y2 + e[11] * z + e[15]);
this.x = (e[0] * x2 + e[4] * y2 + e[8] * z + e[12]) * w;
this.y = (e[1] * x2 + e[5] * y2 + e[9] * z + e[13]) * w;
this.z = (e[2] * x2 + e[6] * y2 + e[10] * z + e[14]) * w;
return this;
}
applyQuaternion(q) {
const x2 = this.x, y2 = this.y, z = this.z;
const qx = q.x, qy = q.y, qz = q.z, qw = q.w;
const ix = qw * x2 + qy * z - qz * y2;
const iy = qw * y2 + qz * x2 - qx * z;
const iz = qw * z + qx * y2 - qy * x2;
const iw = -qx * x2 - qy * y2 - qz * z;
this.x = ix * qw + iw * -qx + iy * -qz - iz * -qy;
this.y = iy * qw + iw * -qy + iz * -qx - ix * -qz;
this.z = iz * qw + iw * -qz + ix * -qy - iy * -qx;
return this;
}
project(camera) {
return this.applyMatrix4(camera.matrixWorldInverse).applyMatrix4(camera.projectionMatrix);
}
unproject(camera) {
return this.applyMatrix4(camera.projectionMatrixInverse).applyMatrix4(camera.matrixWorld);
}
transformDirection(m) {
const x2 = this.x, y2 = this.y, z = this.z;
const e = m.elements;
this.x = e[0] * x2 + e[4] * y2 + e[8] * z;
this.y = e[1] * x2 + e[5] * y2 + e[9] * z;
this.z = e[2] * x2 + e[6] * y2 + e[10] * z;
return this.normalize();
}
divide(v) {
this.x /= v.x;
this.y /= v.y;
this.z /= v.z;
return this;
}
divideScalar(scalar) {
return this.multiplyScalar(1 / scalar);
}
min(v) {
this.x = Math.min(this.x, v.x);
this.y = Math.min(this.y, v.y);
this.z = Math.min(this.z, v.z);
return this;
}
max(v) {
this.x = Math.max(this.x, v.x);
this.y = Math.max(this.y, v.y);
this.z = Math.max(this.z, v.z);
return this;
}
clamp(min, max) {
this.x = Math.max(min.x, Math.min(max.x, this.x));
this.y = Math.max(min.y, Math.min(max.y, this.y));
this.z = Math.max(min.z, Math.min(max.z, this.z));
return this;
}
clampScalar(minVal, maxVal) {
this.x = Math.max(minVal, Math.min(maxVal, this.x));
this.y = Math.max(minVal, Math.min(maxVal, this.y));
this.z = Math.max(minVal, Math.min(maxVal, this.z));
return this;
}
clampLength(min, max) {
const length = this.length();
return this.divideScalar(length || 1).multiplyScalar(Math.max(min, Math.min(max, length)));
}
floor() {
this.x = Math.floor(this.x);
this.y = Math.floor(this.y);
this.z = Math.floor(this.z);
return this;
}
ceil() {
this.x = Math.ceil(this.x);
this.y = Math.ceil(this.y);
this.z = Math.ceil(this.z);
return this;
}
round() {
this.x = Math.round(this.x);
this.y = Math.round(this.y);
this.z = Math.round(this.z);
return this;
}
roundToZero() {
this.x = Math.trunc(this.x);
this.y = Math.trunc(this.y);
this.z = Math.trunc(this.z);
return this;
}
negate() {
this.x = -this.x;
this.y = -this.y;
this.z = -this.z;
return this;
}
dot(v) {
return this.x * v.x + this.y * v.y + this.z * v.z;
}
// TODO lengthSquared?
lengthSq() {
return this.x * this.x + this.y * this.y + this.z * this.z;
}
length() {
return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);
}
manhattanLength() {
return Math.abs(this.x) + Math.abs(this.y) + Math.abs(this.z);
}
normalize() {
return this.divideScalar(this.length() || 1);
}
setLength(length) {
return this.normalize().multiplyScalar(length);
}
lerp(v, alpha) {
this.x += (v.x - this.x) * alpha;
this.y += (v.y - this.y) * alpha;
this.z += (v.z - this.z) * alpha;
return this;
}
lerpVectors(v1, v2, alpha) {
this.x = v1.x + (v2.x - v1.x) * alpha;
this.y = v1.y + (v2.y - v1.y) * alpha;
this.z = v1.z + (v2.z - v1.z) * alpha;
return this;
}
cross(v) {
return this.crossVectors(this, v);
}
crossVectors(a, b) {
const ax = a.x, ay = a.y, az = a.z;
const bx = b.x, by = b.y, bz = b.z;
this.x = ay * bz - az * by;
this.y = az * bx - ax * bz;
this.z = ax * by - ay * bx;
return this;
}
projectOnVector(v) {
const denominator = v.lengthSq();
if (denominator === 0)
return this.set(0, 0, 0);
const scalar = v.dot(this) / denominator;
return this.copy(v).multiplyScalar(scalar);
}
projectOnPlane(planeNormal) {
_vector$b.copy(this).projectOnVector(planeNormal);
return this.sub(_vector$b);
}
reflect(normal) {
return this.sub(_vector$b.copy(normal).multiplyScalar(2 * this.dot(normal)));
}
angleTo(v) {
const denominator = Math.sqrt(this.lengthSq() * v.lengthSq());
if (denominator === 0)
return Math.PI / 2;
const theta = this.dot(v) / denominator;
return Math.acos(clamp(theta, -1, 1));
}
distanceTo(v) {
return Math.sqrt(this.distanceToSquared(v));
}
distanceToSquared(v) {
const dx = this.x - v.x, dy = this.y - v.y, dz = this.z - v.z;
return dx * dx + dy * dy + dz * dz;
}
manhattanDistanceTo(v) {
return Math.abs(this.x - v.x) + Math.abs(this.y - v.y) + Math.abs(this.z - v.z);
}
setFromSpherical(s) {
return this.setFromSphericalCoords(s.radius, s.phi, s.theta);
}
setFromSphericalCoords(radius, phi, theta) {
const sinPhiRadius = Math.sin(phi) * radius;
this.x = sinPhiRadius * Math.sin(theta);
this.y = Math.cos(phi) * radius;
this.z = sinPhiRadius * Math.cos(theta);
return this;
}
setFromCylindrical(c) {
return this.setFromCylindricalCoords(c.radius, c.theta, c.y);
}
setFromCylindricalCoords(radius, theta, y2) {
this.x = radius * Math.sin(theta);
this.y = y2;
this.z = radius * Math.cos(theta);
return this;
}
setFromMatrixPosition(m) {
const e = m.elements;
this.x = e[12];
this.y = e[13];
this.z = e[14];
return this;
}
setFromMatrixScale(m) {
const sx = this.setFromMatrixColumn(m, 0).length();
const sy = this.setFromMatrixColumn(m, 1).length();
const sz = this.setFromMatrixColumn(m, 2).length();
this.x = sx;
this.y = sy;
this.z = sz;
return this;
}
setFromMatrixColumn(m, index) {
return this.fromArray(m.elements, index * 4);
}
setFromMatrix3Column(m, index) {
return this.fromArray(m.elements, index * 3);
}
setFromEuler(e) {
this.x = e._x;
this.y = e._y;
this.z = e._z;
return this;
}
setFromColor(c) {
this.x = c.r;
this.y = c.g;
this.z = c.b;
return this;
}
equals(v) {
return v.x === this.x && v.y === this.y && v.z === this.z;
}
fromArray(array, offset = 0) {
this.x = array[offset];
this.y = array[offset + 1];
this.z = array[offset + 2];
return this;
}
toArray(array = [], offset = 0) {
array[offset] = this.x;
array[offset + 1] = this.y;
array[offset + 2] = this.z;
return array;
}
fromBufferAttribute(attribute, index) {
this.x = attribute.getX(index);
this.y = attribute.getY(index);
this.z = attribute.getZ(index);
return this;
}
random() {
this.x = Math.random();
this.y = Math.random();
this.z = Math.random();
return this;
}
randomDirection() {
const u = (Math.random() - 0.5) * 2;
const t = Math.random() * Math.PI * 2;
const f = Math.sqrt(1 - u ** 2);
this.x = f * Math.cos(t);
this.y = f * Math.sin(t);
this.z = u;
return this;
}
*[Symbol.iterator]() {
yield this.x;
yield this.y;
yield this.z;
}
}
const _vector$b = /* @__PURE__ */ new Vector3();
const _quaternion$4 = /* @__PURE__ */ new Quaternion();
if (typeof __THREE_DEVTOOLS__ !== "undefined") {
__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("register", { detail: {
revision: REVISION
} }));
}
if (typeof window !== "undefined") {
if (window.__THREE__) {
console.warn("WARNING: Multiple instances of Three.js being imported.");
} else {
window.__THREE__ = REVISION;
}
}
var DDeiEnumControlState = /* @__PURE__ */ ((DDeiEnumControlState2) => {
DDeiEnumControlState2["DEFAULT"] = "default";
DDeiEnumControlState2["SELECTED"] = "selected";
DDeiEnumControlState2["CREATING"] = "creating";
return DDeiEnumControlState2;
})(DDeiEnumControlState || {});
class DDeiModelArrtibuteValue {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
/**
* 根据模型的当前状态,获取属性值
* 如果采用缺省值,则当前状态没有值时,会自动去获取外部缺省属性的值
* TODO 未来考虑一个模型多个状态叠加
* @param model 模型
* @param attrPath 属性路径,第一级为属性名称,略过中间的状态层级,如,定义:border.selected.width,写作:border.width
* @param useDefault 是否采用缺省值,默认false不采用
* @param initValue 初始化值
* @returns 模型的值对象
*/
static getAttrValueByState(model, attrPath, useDefault = false, initValue = null) {
var _a3;
let returnValue = null;
if (model && attrPath) {
let relPath = attrPath.split(".");
let attrCode = relPath[0];
let detailCode = relPath.slice(1);
let stateCode = (_a3 = model.state) == null ? void 0 : _a3.toString();
if (model.state == DDeiEnumControlState.DEFAULT || !stateCode) {
stateCode = "";
}
let overwrite = false;
if (model[attrCode]) {
let modelAttr = model[attrCode];
if (modelAttr) {
let path = detailCode;
if (stateCode) {
path = [stateCode].concat(detailCode);
}
try {
let returnJSON = DDeiUtil$1.getDataByPath(modelAttr, path);
if (returnJSON.overwrite && returnJSON.overwrite == true) {
overwrite = true;
}
returnValue = returnJSON.data;
} catch (e) {
}
if (!overwrite && (returnValue == null || returnValue == void 0) && useDefault && stateCode.length > 0) {
path = detailCode;
try {
let returnJSON = DDeiUtil$1.getDataByPath(modelAttr, path);
if (returnJSON.overwrite && returnJSON.overwrite == true) {
overwrite = true;
}
returnValue = returnJSON.data;
} catch (e) {
}
}
}
}
if (!overwrite && (returnValue == null || returnValue == void 0) && initValue && typeof initValue == "object") {
try {
let path = detailCode;
if (stateCode) {
path = [stateCode].concat(detailCode);
}
let returnJSON = DDeiUtil$1.getDataByPath(initValue, path);
if (returnJSON.overwrite && returnJSON.overwrite == true) {
overwrite = true;
}
returnValue = returnJSON.data;
} catch (e) {
}
}
if (!overwrite && (returnValue == null || returnValue == void 0)) {
if (model.modelType != "DDeiSelector" && DDeiUtil$1.getAttrValueByConfig) {
if (stateCode != "") {
let attrCode2 = relPath[0];
let searchPath = attrCode2 + "." + stateCode + attrPath.substring(attrPath.indexOf("."));
let configAtrs = DDeiUtil$1.getAttrValueByConfig(model, searchPath);
if (configAtrs && configAtrs.size > 0) {
let returnJSON = Array.from(configAtrs.values())[0];
if (returnJSON.overwrite && returnJSON.overwrite == true) {
overwrite = true;
}
returnValue = returnJSON.data;
}
}
if (returnValue == null || returnValue == void 0) {
let configAtrs = DDeiUtil$1.getAttrValueByConfig(model, attrPath);
if (configAtrs && configAtrs.size > 0) {
let returnJSON = Array.from(configAtrs.values())[0];
if (returnJSON.overwrite && returnJSON.overwrite == true) {
overwrite = true;
}
returnValue = returnJSON.data;
}
}
}
}
if (!overwrite && (returnValue == null || returnValue == void 0)) {
let sysData = DDeiConfig$1.getSysDefaultData(model);
if (sysData && sysData[attrCode]) {
let path = detailCode;
if (stateCode) {
path = [stateCode].concat(detailCode);
}
try {
let returnJSON = DDeiUtil$1.getDataByPath(sysData[attrCode], path);
if (returnJSON.overwrite && returnJSON.overwrite == true) {
overwrite = true;
}
returnValue = returnJSON.data;
} catch (e) {
}
if (!overwrite && (returnValue == null || returnValue == void 0) && useDefault && stateCode.length > 0) {
path = detailCode;
try {
let returnJSON = DDeiUtil$1.getDataByPath(sysData[attrCode], path);
if (returnJSON.overwrite && returnJSON.overwrite == true) {
overwrite = true;
}
returnValue = returnJSON.data;
} catch (e) {
}
}
}
}
}
return returnValue;
}
// ============================ 属性 ===============================
// ============================ 方法 ===============================
}
class DDeiColor {
constructor(r, g, b, a) {
__publicField2(this, "r");
__publicField2(this, "g");
__publicField2(this, "b");
__publicField2(this, "a", 1);
this.r = r;
this.g = g;
this.b = b;
this.a = a;
}
darken(rate) {
let r = this.r;
let g = this.g;
let b = this.b;
r -= r * rate;
g -= g * rate;
b -= b * rate;
if (r < 0) {
r = 0;
}
if (g < 0) {
g = 0;
}
if (b < 0) {
b = 0;
}
return new DDeiColor(r, g, b, this.a);
}
lighten(rate) {
let r = this.r;
let g = this.g;
let b = this.b;
r += r * rate;
g += g * rate;
b += b * rate;
if (r < 0) {
r = 0;
}
if (g < 0) {
g = 0;
}
if (b < 0) {
b = 0;
}
return new DDeiColor(r, g, b, this.a);
}
toColor() {
return "rgba(" + this.r + "," + this.g + "," + this.b + "," + this.a + ")";
}
}
class DDeiLink {
constructor(props) {
__publicField2(this, "group", "");
__publicField2(this, "sm");
__publicField2(this, "dm");
__publicField2(this, "smpath");
__publicField2(this, "dmpath");
__publicField2(this, "stage");
__publicField2(this, "disabled", false);
for (let i2 in props) {
if (typeof props[i2] != "object" && props[i2]) {
this[i2] = props[i2];
}
}
this.group = props.group;
this.sm = props.sm;
this.dm = props.dm;
this.stage = props.stage;
this.smpath = props.smpath;
this.dmpath = props.dmpath;
this.disabled = props.disabled;
}
/**
* 得到源向量
*/
getSourcePV() {
return DDeiUtil$1.getDataByPathList(this.sm, this.smpath);
}
/**
* 得到目标向量
*/
getDistPV() {
return DDeiUtil$1.getDataByPathList(this.dm, this.dmpath);
}
/**
* 将模型转换为JSON
*/
toJSON() {
let json = new Object();
for (let i2 in this) {
if (typeof this[i2] != "object" && this[i2]) {
json[i2] = this[i2];
}
}
if (this.group) {
json.group = group;
}
if (this.sm) {
json.smid = this.sm.id;
}
if (this.dm) {
json.dmid = this.dm.id;
}
if (this.smpath) {
json.smpath = this.smpath;
}
if (this.dmpath) {
json.dmpath = this.dmpath;
}
return json;
}
}
const __vite_glob_0_4$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiLink,
default: DDeiLink
}, Symbol.toStringTag, { value: "Module" }));
var DDeiEnumOperateType = /* @__PURE__ */ ((DDeiEnumOperateType2) => {
DDeiEnumOperateType2["CREATE"] = "CREATE";
DDeiEnumOperateType2["EDIT"] = "EDIT";
DDeiEnumOperateType2["VIEW"] = "VIEW";
DDeiEnumOperateType2["DRAG"] = "DRAG";
DDeiEnumOperateType2["LINK"] = "LINK";
DDeiEnumOperateType2["DEL"] = "DEL";
DDeiEnumOperateType2["DESTROYED"] = "DESTROYED";
DDeiEnumOperateType2["SELECT"] = "SELECT";
DDeiEnumOperateType2["ROTATE"] = "ROTATE";
DDeiEnumOperateType2["SCALE"] = "SCALE";
DDeiEnumOperateType2["MIRROR"] = "MIRROR";
DDeiEnumOperateType2["COMPOSE"] = "COMPOSE";
return DDeiEnumOperateType2;
})(DDeiEnumOperateType || {});
class DDeiModelLink {
constructor(props) {
__publicField2(this, "depModel");
__publicField2(this, "type");
__publicField2(this, "dm");
__publicField2(this, "dx");
__publicField2(this, "dy");
this.depModel = props.depModel;
this.type = props.type;
this.dm = props.dm;
this.dx = props.dx ? props.dx : 0;
this.dy = props.dy ? props.dy : 0;
}
/**
* 将模型转换为JSON
*/
toJSON() {
let json = new Object();
if (this.type) {
json.type = this.type;
}
if (this.dm) {
json.dmid = this.dm.id;
}
if (this.dx) {
json.dx = this.dx;
}
if (this.dy) {
json.dy = this.dy;
}
return json;
}
}
const __vite_glob_0_5$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiModelLink,
default: DDeiModelLink
}, Symbol.toStringTag, { value: "Module" }));
var __defProp$2 = Object.defineProperty;
var __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __publicField$2 = (obj, key, value) => {
__defNormalProp$2(obj, typeof key !== "symbol" ? key + "" : key, value);
return value;
};
const expressBindValueReg = /#\{[^\{\}]*\}/;
const contentSplitReg = /\+|\-|\*|\//;
const isNumberReg = /^[+-]?\d*(\.\d*)?(e[+-]?\d+)?$/;
const safariReg = /Safari/;
const chromeReg = /Chrome/;
const ytestReg = /(y+)/;
const _DDeiUtil = class _DDeiUtil2 {
/**
* 计算文字的高度和宽度
*/
static measureTextSize(ddInstance, text2, fontFamily, fontSize) {
let canvas = ddInstance.render.getCanvas();
let ctx = canvas.getContext("2d");
ctx.save();
ctx.font = fontSize + "px " + fontFamily;
let textArray = text2.split("\n");
let maxWidth = 0;
let height = textArray.length * fontSize;
textArray.forEach((t) => {
let width = ctx.measureText(t).width;
if (width > maxWidth) {
maxWidth = width;
}
});
ctx.restore();
return { width: maxWidth, height };
}
/**
* 计算文字的高度和宽度
*/
static measureText(text2, font, ctx, fontSize) {
let key = text2 + "_" + font;
if (!_DDeiUtil2.cacheTextCharSize.has(key)) {
ctx.font = font;
let rect = ctx.measureText(text2);
_DDeiUtil2.cacheTextCharSize.set(key, { width: rect.width, height: rect.fontBoundingBoxAscent + rect.fontBoundingBoxDescent, dHeight: rect.fontBoundingBoxAscent });
}
return _DDeiUtil2.cacheTextCharSize.get(key);
}
/**
* 绘制圆角矩形
* @param ctx
* @param x x
* @param y y
* @param width 宽度
* @param height 高度
* @param radius 圆角
* @param stroke 是否绘制
* @param strokeColor 绘制颜色
* @param fill 是否填充
* @param fillColor 填充颜色
*/
static drawRectRound(ctx, x2, y2, width, height, radius = 0, stroke = true, strokeColor = "black", fill = true, fillColor = "white") {
if ((stroke || fill) && width > 0 && height > 0) {
ctx.save();
ctx.beginPath();
ctx.arc(x2 + radius, y2 + radius, radius, Math.PI, Math.PI * 3 / 2);
ctx.lineTo(width - radius + x2, y2);
ctx.arc(width - radius + x2, radius + y2, radius, Math.PI * 3 / 2, Math.PI * 2);
ctx.lineTo(width + x2, height + y2 - radius);
ctx.arc(width - radius + x2, height - radius + y2, radius, 0, Math.PI * 1 / 2);
ctx.lineTo(radius + x2, height + y2);
ctx.arc(radius + x2, height - radius + y2, radius, Math.PI * 1 / 2, Math.PI);
ctx.closePath();
if (fill) {
ctx.fillStyle = fillColor;
ctx.fill();
}
if (stroke) {
ctx.strokeStyle = strokeColor;
ctx.stroke();
}
ctx.restore();
}
}
/**
* 将一组控件按照从上到下从左到右的顺序进行排序,返回新的顺序
* @param element
*/
static getSortedModels(models) {
let returnArray = new Array();
if (models) {
let modelArray = null;
if (models.set) {
modelArray = Array.from(models.values());
} else {
modelArray = models;
}
modelArray.forEach((model) => {
let insert = false;
for (let i2 = returnArray.length - 1; i2 > 0; i2--) {
let rm = returnArray[i2];
if (rm.y <= model.y) {
returnArray.splice(i2 + 1, 0, model);
insert = true;
break;
} else if (rm.y == model.y && rm.x <= model.x) {
returnArray.splice(i2 + 1, 0, model);
insert = true;
break;
}
}
if (!insert) {
returnArray.splice(0, 0, model);
}
});
}
return returnArray;
}
/**
* 获取影子图形
* @param model
*/
static getShadowControl(model) {
let md = null;
if ((model == null ? void 0 : model.baseModelType) == "DDeiTable") {
md = _DDeiUtil2.cloneModel(model, true);
md.id = md.id + "_shadow";
let rows = [];
let cols = [];
for (let i2 = 0; i2 < model.rows.length; i2++) {
let rowObj = model.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let smi = rowObj[j2];
let sm = _DDeiUtil2.getShadowControl(smi);
sm.pModel = md;
if (!rows[sm.row]) {
rows[sm.row] = [];
}
rows[sm.row][sm.col] = sm;
if (!cols[sm.col]) {
cols[sm.col] = [];
}
cols[sm.col][sm.row] = sm;
}
}
md.rows = rows;
md.cols = cols;
md.initRender();
} else {
md = _DDeiUtil2.cloneModel(model, true);
md.id = md.id + "_shadow";
if ((md == null ? void 0 : md.baseModelType) == "DDeiContainer") {
let newModels = /* @__PURE__ */ new Map();
md.models.forEach((smi) => {
let sm = _DDeiUtil2.getShadowControl(smi);
sm.id = sm.id.substring(0, sm.id.lastIndexOf("_shadow"));
sm.pModel = md;
newModels.set(sm.id, sm);
sm.initRender();
});
md.models = newModels;
}
md.initRender();
}
return md;
}
//克隆模型,只克隆关键属性
static cloneModel(sourceModel, isShadowClone = false) {
var _a3, _b2, _c2;
if (!sourceModel) {
return;
}
let returnModel = clone(sourceModel);
if (isShadowClone) {
returnModel.clps = [];
returnModel.isShadowControl = true;
}
if (returnModel.layoutManager) {
returnModel.layoutManager = clone(sourceModel.layoutManager);
returnModel.layoutManager.container = returnModel;
}
returnModel.pvs = [];
sourceModel.pvs.forEach((pv) => {
returnModel.pvs.push(clone(pv));
});
returnModel.sptStyle = cloneDeep(sourceModel.sptStyle);
returnModel.textArea = [];
(_a3 = sourceModel.textArea) == null ? void 0 : _a3.forEach((pv) => {
returnModel.textArea.push(clone(pv));
});
returnModel.exPvs = {};
for (let i2 in sourceModel.exPvs) {
returnModel.exPvs[i2] = clone(sourceModel.exPvs[i2]);
}
returnModel.cpv = clone(sourceModel.cpv);
returnModel.bpv = clone(sourceModel.bpv);
returnModel.ovs = cloneDeep(sourceModel.ovs);
if (((_b2 = sourceModel.composes) == null ? void 0 : _b2.length) > 0) {
let composes = [];
(_c2 = sourceModel.composes) == null ? void 0 : _c2.forEach((com) => {
let comp = _DDeiUtil2.cloneModel(com);
comp.pModel = returnModel;
composes.push(comp);
});
returnModel.composes = composes;
}
returnModel.unicode = _DDeiUtil2.getUniqueCode();
returnModel.initPVS();
return returnModel;
}
/**
* 返回某个点旋转后的坐标
*/
static getRotatedPoint(point2, rotate2 = 0) {
let vc = new Vector3(point2.x, point2.y, point2.z || point2.z == 0 ? point2.z : 1);
if (rotate2) {
let angle2 = (-rotate2 * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
vc.applyMatrix3(rotateMatrix);
}
return vc;
}
/**
* 返回dom绝对坐标
* @param element
*/
static getDomAbsPosition(element, editor) {
let actualLeft = element.offsetLeft;
let actualTop = element.offsetTop;
let current = element.offsetParent;
while (current) {
actualLeft += current.offsetLeft;
actualTop += current.offsetTop + current.clientTop;
current = current.offsetParent;
}
if (editor) {
let editorElement = document.getElementById(editor.id);
let editorPos = _DDeiUtil2.getDomAbsPosition(editorElement);
actualLeft -= editorPos.left;
actualTop -= editorPos.top;
}
return { left: actualLeft, top: actualTop };
}
/**
* 返回dom到editor元素之间的滚动高度
* @param element
*/
static getDomScroll(element, editor) {
let scrollTop = 0;
let scrollLeft = 0;
let current = element.parentElement;
let editorElement = document.getElementById(editor.id);
while (current && current != editorElement) {
scrollTop += current.scrollTop;
scrollLeft += current.scrollLeft;
current = current.parentElement;
}
return { left: scrollLeft, top: scrollTop };
}
/**
* 返回控件在dom下的绝对坐标
* @param element
*/
static getModelsDomAbsPosition(models) {
var _a3;
if ((models == null ? void 0 : models.length) > 0) {
let outRect;
if (models.length == 1) {
let model = models[0];
if (model.rotate) {
let pvs2 = model.operatePVS ? model.operatePVS : model.pvs;
let zeroPvs = _DDeiUtil2.pointsToZero(pvs2, model.cpv, model.rotate);
zeroPvs = _DDeiUtil2.zeroToPoints(zeroPvs, model.cpv, 0, 1, 1);
outRect = DDeiAbstractShape.pvsToOutRect(zeroPvs);
outRect.rotate = model.rotate;
} else {
outRect = DDeiAbstractShape.getOutRectByPV(models);
outRect.rotate = 0;
}
} else {
outRect = DDeiAbstractShape.getOutRectByPV(models);
outRect.rotate = 0;
}
let stageRatio2 = (_a3 = models[0].stage) == null ? void 0 : _a3.getStageRatio();
outRect.x *= stageRatio2;
outRect.x1 *= stageRatio2;
outRect.y *= stageRatio2;
outRect.y1 *= stageRatio2;
outRect.width *= stageRatio2;
outRect.height *= stageRatio2;
let wpv = models[0].stage.wpv;
let domEle = models[0].stage.ddInstance.render.realCanvas.parentElement;
let canvasPos = _DDeiUtil2.getDomAbsPosition(domEle);
outRect.left = canvasPos.left + outRect.x + wpv.x;
outRect.top = canvasPos.top + outRect.y + wpv.y;
outRect.cLeft = canvasPos.left;
outRect.cTop = canvasPos.top;
outRect.cWidth = domEle.clientWidth;
outRect.cHeight = domEle.clientHeight;
return outRect;
} else {
return null;
}
}
static sortRendList(model) {
var _a3;
let rendList = [];
if (((_a3 = model.composes) == null ? void 0 : _a3.length) > 0) {
rendList = rendList.concat(model.composes);
}
rendList.push(model);
rendList.sort((a, b) => {
if ((a.cIndex || a.cIndex == 0) && (b.cIndex || b.cIndex == 0)) {
return a.cIndex - b.cIndex;
} else if ((a.cIndex || a.cIndex == 0) && !(b.cIndex || b.cIndex == 0)) {
return 1;
} else if (!(a.cIndex || a.cIndex == 0) && (b.cIndex || b.cIndex == 0)) {
return -1;
} else {
return 0;
}
});
return rendList;
}
/**
* 设置样式属性,自动创建不存在的层级
* @param model 模型
* @param paths 样式路径,支持传入多个
* @param value 值
*/
static setStyle(model, paths, value) {
if (model) {
let pathArray;
if (typeof paths == "string") {
pathArray = [paths];
} else {
pathArray = paths;
}
pathArray.forEach((path) => {
if (path != "") {
let attrPaths = path.split(".");
let curObj = model;
for (let i2 = 0; i2 < attrPaths.length; i2++) {
if (i2 != attrPaths.length - 1) {
if (!curObj[attrPaths[i2]]) {
curObj[attrPaths[i2]] = {};
}
curObj = curObj[attrPaths[i2]];
} else {
curObj[attrPaths[i2]] = value;
}
}
}
});
}
}
/**
* 根据Path获取JSON的数据
* 如果data路径中存在override,则强制覆盖不从上级获取
*/
static getDataByPathList(data, ...paths) {
if (data && paths) {
for (let ix = 0; ix < paths.length; ix++) {
if (paths[ix]) {
let obj = paths[ix];
let pathArray = null;
if (typeof obj == "string") {
pathArray = paths[ix].split(".");
try {
let returnJSON = _DDeiUtil2.getDataByPath(data, pathArray);
if ((returnJSON == null ? void 0 : returnJSON.data) || (returnJSON == null ? void 0 : returnJSON.data) == 0) {
return returnJSON.data;
}
} catch (e) {
}
} else if (Array.isArray(obj)) {
if (obj.length > 0) {
for (let jx = 0; jx < obj.length; jx++) {
pathArray = obj[jx].split(".");
try {
let returnJSON = _DDeiUtil2.getDataByPath(data, pathArray);
if ((returnJSON == null ? void 0 : returnJSON.data) || (returnJSON == null ? void 0 : returnJSON.data) == 0) {
return returnJSON.data;
}
} catch (e) {
}
}
}
}
}
}
}
return null;
}
/**
* 根据配置定义,设置属性值
* @param model 模型
* @param paths 属性路径,支持传入多个
* @param value值
* @return 由构成的属性的实际路径和配置中对应的值组成的Map
*/
static setAttrValueByPath(model, paths, value) {
if (model && paths) {
let attrPaths = null;
if (typeof paths == "string") {
attrPaths = paths.split(",");
} else {
attrPaths = paths;
}
for (let i2 = 0; i2 < attrPaths.length; i2++) {
let attCode = attrPaths[i2];
let attrCodePaths = attCode.split(".");
let currentObj = model;
for (let j2 = 0; j2 < attrCodePaths.length; j2++) {
let code = attrCodePaths[j2];
if (j2 == attrCodePaths.length - 1) {
currentObj[code] = value;
} else {
if (!currentObj[code]) {
currentObj[code] = {};
}
currentObj = currentObj[code];
}
}
}
}
}
/**
* 生成唯一编码
* @returns
*/
static getUniqueCode() {
let data = (/* @__PURE__ */ new Date()).getTime();
if (window.performance && typeof window.performance.now === "function") {
data += performance.now();
}
let codeId = "xxxxxxxxxxxx6xxxyxxxxxxxxxxxxxxx".replace(/[xy]/g, function(msg) {
let rand = (data + Math.random() * 16) % 16 | 0;
data = Math.floor(data / 16);
return (msg == "x" ? rand : rand & 3 | 8).toString(16);
});
return codeId;
}
/**
* 求两点距离
*/
static getPointDistance(x0, y0, x1, y1) {
return Math.sqrt((x1 - x0) ** 2 + (y1 - y0) ** 2);
}
/**
* 创建依附快捷控件
* @param model 被依附控件
* @param text 文本
*/
static createDepLinkModel(model, text2, type = null) {
var _a3, _b2;
if (text2 && model) {
let stage2 = model.stage;
let ddInstance = stage2.ddInstance;
let editState = _DDeiUtil2.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: [model] }, ddInstance);
if (editState == 0 || editState == 1) {
let realModel = null;
let posPoint = null;
let posType;
let isCreateRealModel = false;
let isLineLM = false;
if (model.baseModelType == "DDeiLine") {
posType = type ? type : 3;
let pi = Math.floor(model.pvs.length / 2);
if (model.pvs.length % 3 == 0) {
posPoint = model.pvs[pi];
} else {
posPoint = {
x: (model.pvs[pi - 1].x + model.pvs[pi].x) / 2,
y: (model.pvs[pi - 1].y + model.pvs[pi].y) / 2
};
}
model.linkModels.forEach((lm) => {
if (lm.type == posType) {
realModel = lm.dm;
}
});
if (!realModel) {
isCreateRealModel = true;
isLineLM = true;
}
} else {
let modelDefine = _DDeiUtil2.getControlDefine(model);
if ((_b2 = (_a3 = modelDefine == null ? void 0 : modelDefine.define) == null ? void 0 : _a3.sample) == null ? void 0 : _b2.depPos) {
let depPos = modelDefine.define.sample.depPos;
let essBounds = model.essBounds;
let dmEssBounds = { width: 80, height: 18 };
posType = depPos.type;
if (!type || posType == type) {
if (depPos.type == 5) {
posPoint = model.cpv;
} else if (depPos.type == 6) {
posPoint = {
x: model.cpv.x,
y: essBounds.y - dmEssBounds.height / 2
};
} else if (depPos.type == 7) {
posPoint = {
x: essBounds.x1 + dmEssBounds.width / 2,
y: model.cpv.y
};
} else if (depPos.type == 8) {
posPoint = {
x: model.cpv.x,
y: essBounds.y1 + dmEssBounds.height / 2
};
} else if (depPos.type == 9) {
posPoint = {
x: essBounds.x - dmEssBounds.width / 2,
y: model.cpv.y
};
}
isCreateRealModel = true;
}
}
}
if (isCreateRealModel) {
let dataJson = {
modelCode: "100200"
};
let controlDefine = _DDeiUtil2.getControlDefine(dataJson);
for (let i2 in controlDefine == null ? void 0 : controlDefine.define) {
dataJson[i2] = cloneDeep(controlDefine.define[i2]);
}
dataJson["id"] = "lsm_" + stage2.idIdx++;
dataJson["width"] = 80;
dataJson["height"] = 28;
dataJson["font"] = { size: 12 };
dataJson["text"] = text2;
dataJson["textStyle"] = { paddingWeight: 0 };
if (isLineLM) {
dataJson["fill"] = { type: 1, color: "white" };
}
realModel = ddInstance.controlModelClasses["DDeiPolygon"].initByJSON(
dataJson,
{ currentStage: stage2, currentDdInstance: ddInstance, currentContainer: model.pModel }
);
let move1Matrix = new Matrix3(
1,
0,
posPoint.x,
0,
1,
posPoint.y,
0,
0,
1
);
realModel.transVectors(move1Matrix);
model.layer.addModel(realModel, false);
realModel.initRender();
let lineLink = new DDeiModelLink({
depModel: model,
type: posType,
dm: realModel,
dx: 0,
dy: 0
});
realModel.depModel = model;
model.linkModels.set(realModel.id, lineLink);
}
}
}
}
/**
* 已知两点求其中间以及延长线上的第三点,有len和rate两种计算策略,如果超出按out值,返回实际长度(0),或者按照out设置的值作为长度比例
* @param x0 点1x
* @param y0 点1y
* @param x1 点2x
* @param y1 点2y
* @param mode 模式,1长度,2比例
* @param value 值
* @param out 超出策略,-1原样,其他,比例
*/
static getPathPoint(x0, y0, x1, y1, mode = 1, value = 0, out = -1, distance = null) {
let pointDistance = distance ? distance : _DDeiUtil2.getPointDistance(x0, y0, x1, y1);
let targetLen;
let rate;
if (mode == 1) {
targetLen = value;
if (out != -1 && targetLen > pointDistance) {
targetLen = pointDistance * out;
}
rate = targetLen / pointDistance;
} else {
targetLen = pointDistance * value;
if (out != -1 && targetLen > pointDistance) {
targetLen = pointDistance * out;
}
rate = targetLen / pointDistance;
}
let sita = parseFloat(_DDeiUtil2.getLineAngle(x0, y0, x1, y1).toFixed(4));
let point2 = new Vector3(targetLen, 0, 1);
let m12 = new Matrix3();
if (sita != 0 && sita != 360) {
let angle2 = (-sita * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let moveMatrix2 = new Matrix3(
1,
0,
x0,
0,
1,
y0,
0,
0,
1
);
m12.premultiply(moveMatrix2);
point2.applyMatrix3(m12);
point2.sita = sita;
point2.rate = rate;
point2.len = targetLen;
return point2;
}
/**
* 判断点是否在线上
*/
static isPointInLine(q, p1, p2) {
if (!p1 || !p2 || !q) {
return false;
}
let x0 = q.x;
let y0 = q.y;
let plLength = Infinity;
let x1 = p1.x;
let y1 = p1.y;
let x2 = p2.x;
let y2 = p2.y;
if (x1 == x2 && y1 == y2) {
plLength = _DDeiUtil2.getPointDistance(x0, y0, x1, y1);
} else {
let s = (x0 - x1) * (y2 - y1) - (y0 - y1) * (x2 - x1);
let d = _DDeiUtil2.getPointDistance(x0, y0, x1, y1);
plLength = s / d;
}
if (Math.abs(plLength) <= 1) {
return true;
}
}
/**
* 获取移动路径
*/
static getMovePath(sAngle, eAngle, startPoint, endPoint) {
let movePath = "";
switch (sAngle) {
case 0:
{
switch (eAngle) {
case 180:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:-0.25,x:-1.5,y:0.25";
}
} else if (startPoint.y > endPoint.y) {
if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:-0.5,x:-1.5,y:-0.5";
} else {
movePath = "x:0.5,y:-1";
}
} else {
if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:0.5,x:-1.5,y:0.5";
} else {
movePath = "x:0.5,y:1";
}
}
}
break;
case -90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:-0.25,x:-1.25";
}
} else if (startPoint.y > endPoint.y) {
if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:-1.25,x:-1.25";
} else {
movePath = "x:0.5,y:-1.25,x:0.5";
}
} else {
if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:0.5,x:-1.25";
} else {
movePath = "x:1";
}
}
}
break;
case 90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:0.25,x:-1.25,y:-0.25";
}
} else if (startPoint.y > endPoint.y) {
if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:-0.5,x:-1.25";
} else {
movePath = "x:1";
}
} else {
if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:1.25,x:-1.25";
} else {
movePath = "x:0.5,y:1.25,x:0.5";
}
}
}
break;
case 0:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
movePath = "x:0.25,y:0.25,x:-1.25,y:-0.25";
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "x:0.25,y:-1";
} else if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:-1";
} else {
movePath = "x:1.25,y:-1";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "x:0.25,y:1";
} else if (startPoint.x > endPoint.x) {
movePath = "x:0.25,y:1";
} else {
movePath = "x:1.25,y:1";
}
}
}
break;
}
}
break;
case 180:
{
switch (eAngle) {
case 0:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "";
} else {
movePath = "x:-0.25,y:-0.25,x:1.5,y:0.25";
}
} else if (startPoint.y > endPoint.y) {
if (startPoint.x > endPoint.x) {
movePath = "x:-0.25,y:-1";
} else {
movePath = "x:-0.25,y:-0.5,x:1.5,y:-0.5";
}
} else {
if (startPoint.x > endPoint.x) {
movePath = "x:-0.25,y:1";
} else {
movePath = "x:-0.25,y:0.5,x:1.5,y:0.5";
}
}
}
break;
case -90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x < endPoint.x) {
movePath = "x:-0.25,y:-0.25,x:1.25,y:0.25";
}
} else if (startPoint.y > endPoint.y) {
if (startPoint.x > endPoint.x) {
movePath = "x:-0.5,y:-1.25,x:-0.5";
} else {
movePath = "x:-0.25,y:-1.25,x:1.25";
}
} else {
if (startPoint.x > endPoint.x) {
movePath = "x:-1";
} else {
movePath = "x:-0.25,y:0.5,x:1.25";
}
}
}
break;
case 90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x < endPoint.x) {
movePath = "x:-0.25,y:0.25,x:1.25";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "x:-1";
} else {
movePath = "x:-0.25,y:-0.5,x:1.25";
}
} else {
if (startPoint.x > endPoint.x) {
movePath = "x:-0.5,y:1.25,x:-0.5";
} else {
movePath = "x:-0.5,y:1.25,x:1.5";
}
}
}
break;
case 180:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "x:-0.25,y:-0.25,x:-1,y:0.25";
} else {
movePath = "x:-0.25,y:-0.25,x:1,y:0.25";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "x:-0.25,y:-1";
} else if (startPoint.x > endPoint.x) {
movePath = "x:-1.25,y:-1";
} else {
movePath = "x:-0.25,y:-1";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "x:-0.25,y:1";
} else if (startPoint.x > endPoint.x) {
movePath = "x:-1.25,y:1";
} else {
movePath = "x:-0.25,y:1";
}
}
}
break;
}
}
break;
case -90:
{
switch (eAngle) {
case 90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1)
;
else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "y:-0.5,x:-1";
} else {
movePath = "y:-0.5,x:1";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "y:-0.25,x:-0.5,y:1.5,x:-0.5";
} else if (startPoint.x > endPoint.x) {
movePath = "y:-0.25,x:-0.5,y:1.5,x:-0.5";
} else {
movePath = "y:-0.25,x:0.5,y:1.5,x:0.5";
}
}
}
break;
case 0:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x < endPoint.x) {
movePath = "y:-0.5,x:1.25,y:0.5";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "y:-1";
} else {
movePath = "y:-0.5,x:1.25,y:-0.5";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "y:-0.25,x:0.5,y:1.25";
} else if (startPoint.x > endPoint.x) {
movePath = "y:-0.25,x:-0.5,y:1.25";
} else {
movePath = "y:-0.25,x:1.25,y:1.25";
}
}
}
break;
case 180:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "y:-0.5,x:-1.25,y:0.5";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "y:-0.5,x:-1.25,y:-0.5";
} else {
movePath = "y:-1";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "y:-0.25,x:-0.5,y:1.25";
} else if (startPoint.x > endPoint.x) {
movePath = "y:-0.25,x:-1.25,y:1.25";
} else {
movePath = "y:-0.25,x:0.5,y:1.25";
}
}
}
break;
case -90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "y:-0.25,x:-1";
} else {
movePath = "y:-0.25,x:1";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "y:-0.25,x:-0.5,y:-1,x:0.5";
} else if (startPoint.x > endPoint.x) {
movePath = "y:-1.25,x:-1";
} else {
movePath = "y:-1.25,x:1";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "y:-0.25,x:-0.5,y:1.25,x:0.5";
} else if (startPoint.x > endPoint.x) {
movePath = "y:-0.25,x:-1";
} else {
movePath = "y:-0.25,x:1";
}
}
}
break;
}
}
break;
case 90:
{
switch (eAngle) {
case -90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1)
;
else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "y:0.25,x:0.5,y:-1.5,x:-0.5";
} else if (startPoint.x > endPoint.x) {
movePath = "y:0.25,x:-0.5,y:-1.5,x:-0.5";
} else {
movePath = "y:0.25,x:0.5,y:-1.5,x:0.5";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "y:0.5,x:-1";
} else {
movePath = "y:0.5,x:1";
}
}
}
break;
case 0:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x < endPoint.x) {
movePath = "y:0.5,x:1.25,y:-0.5";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "y:0.25,x:-0.5,y:-1.25";
} else {
movePath = "y:0.25,x:1.25,y:-1.25";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "y:1";
} else {
movePath = "y:0.5,x:1.25,y:0.5";
}
}
}
break;
case 180:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "y:0.5,x:-1.25,y:-0.5";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "y:0.25,x:-1.25,y:-1.25";
} else {
movePath = "y:0.25,x:0.5,y:-1.25";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "y:0.5,x:-1.25,y:0.5";
} else {
movePath = "y:1";
}
}
}
break;
case 90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1)
;
else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "y:0.25,x:-0.5,y:-1,x:0.5";
} else if (startPoint.x > endPoint.x) {
movePath = "y:0.25,x:-1";
} else {
movePath = "y:0.25,x:1";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "y:0.25,x:0.5,y:1,x:-0.5";
} else if (startPoint.x > endPoint.x) {
movePath = "y:1.25,x:-1";
} else {
movePath = "y:1.25,x:1";
}
}
}
break;
}
}
break;
}
return movePath;
}
/**
* 判断两条线段是否相交
* @param l1 线段1
* @param l2 线段2
* @returns
*/
static isLineCross(l1, l2) {
if ((l1.x1 > l1.x2 ? l1.x1 : l1.x2) < (l2.x1 < l2.x2 ? l2.x1 : l2.x2) || (l1.y1 > l1.y2 ? l1.y1 : l1.y2) < (l2.y1 < l2.y2 ? l2.y1 : l2.y2) || (l2.x1 > l2.x2 ? l2.x1 : l2.x2) < (l1.x1 < l1.x2 ? l1.x1 : l1.x2) || (l2.y1 > l2.y2 ? l2.y1 : l2.y2) < (l1.y1 < l1.y2 ? l1.y1 : l1.y2)) {
return false;
}
if (((l1.x1 - l2.x1) * (l2.y2 - l2.y1) - (l1.y1 - l2.y1) * (l2.x2 - l2.x1)) * ((l1.x2 - l2.x1) * (l2.y2 - l2.y1) - (l1.y2 - l2.y1) * (l2.x2 - l2.x1)) > 0 || ((l2.x1 - l1.x1) * (l1.y2 - l1.y1) - (l2.y1 - l1.y1) * (l1.x2 - l1.x1)) * ((l2.x2 - l1.x1) * (l1.y2 - l1.y1) - (l2.y2 - l1.y1) * (l1.x2 - l1.x1)) > 0) {
return false;
}
return true;
}
/**
* 取得两条线相交的点
* @param p1 线1点1
* @param p2 线1点2
* @param p3 线2点1
* @param p4 线2点2
* @returns
*/
static getLineCorssPoint(p1, p2, p3, p4) {
let abc = (p1.x - p3.x) * (p2.y - p3.y) - (p1.y - p3.y) * (p2.x - p3.x);
let abd = (p1.x - p4.x) * (p2.y - p4.y) - (p1.y - p4.y) * (p2.x - p4.x);
if (abc * abd >= 0) {
return null;
}
let cda = (p3.x - p1.x) * (p4.y - p1.y) - (p3.y - p1.y) * (p4.x - p1.x);
let cdb = cda + abc - abd;
if (cda * cdb >= 0) {
return null;
}
let t = cda / (abd - abc);
let dx = t * (p2.x - p1.x), dy = t * (p2.y - p1.y);
return { x: p1.x + dx, y: p1.y + dy };
}
/**
* 两个矩形是否相交
* @param rect1
* @param rect2
* @returns
*/
static isRectCross(rect1, rect2) {
let maxX, maxY, minX, minY;
maxX = rect1.x + rect1.width >= rect2.x + rect2.width ? rect1.x + rect1.width : rect2.x + rect2.width;
maxY = rect1.y + rect1.height >= rect2.y + rect2.height ? rect1.y + rect1.height : rect2.y + rect2.height;
minX = rect1.x <= rect2.x ? rect1.x : rect2.x;
minY = rect1.y <= rect2.y ? rect1.y : rect2.y;
if (maxX - minX <= rect1.width + rect2.width && maxY - minY <= rect1.height + rect2.height) {
return true;
} else {
return false;
}
}
/**
* 计算线段相对于窗口的角度
*/
static getLineAngle(x1, y1, x2, y2, radius = false) {
x2 -= x1;
y2 -= y1;
let v1 = new Vector3(1, 0, 0);
let v2 = new Vector3(x2, y2, 0);
if (radius) {
return v1.angleTo(v2);
} else {
let lineAngle = v1.angleTo(v2) * 180 / Math.PI;
if (v1.cross(v2).z < 0) {
lineAngle = -lineAngle;
}
return lineAngle;
}
}
/**
* 计算两条线的夹角,连续相邻折线
*/
static getLinesAngle(l1x1, l1y1, l1x2, l1y2, l2x1, l2y1, l2x2, l2y2, radius = false) {
let vectorZero1 = new Vector3(1, 0, 0);
let vectorZero2 = new Vector3(1, 0, 0);
let vectorA = new Vector3(l1x1 - l1x2, l1y1 - l1y2, 0);
let vectorB = new Vector3(l2x2 - l1x2, l2y2 - l1y2, 0);
let angle1 = vectorZero1.angleTo(vectorA);
if (vectorZero1.cross(vectorA).z < 0) {
angle1 = -angle1;
}
let angle2 = vectorZero2.angleTo(vectorB);
if (vectorZero2.cross(vectorB).z < 0) {
angle2 = -angle2;
}
let ar1 = angle1;
let ar2 = angle2;
let angleRadians = ar2 - ar1;
if (!radius) {
angleRadians = angleRadians * 180 / Math.PI;
}
return angleRadians;
}
/**
* 根据Path获取JSON的数据
* 如果data路径中存在override,则强制覆盖不从上级获取
*/
static getDataByPath(data, path) {
if (!path || path.length === 0) {
return {
data,
overwrite: (data == null ? void 0 : data.overwrite) === true
};
}
let currentData = data;
let isOverwrite = false;
for (let i2 = 0; i2 < path.length; i2++) {
const p = path[i2];
if (p.includes("[")) {
const [arrayName, indexStr] = p.split("[");
const index = parseInt(indexStr);
if (!isNaN(index) && Array.isArray(currentData[arrayName])) {
currentData = currentData[arrayName][index];
} else {
return { data: null, overwrite: false };
}
} else {
currentData = currentData[p];
}
if (currentData == null) {
return { data: null, overwrite: false };
}
if (currentData.overwrite === true) {
isOverwrite = true;
}
}
return {
data: currentData,
overwrite: isOverwrite
};
}
/**
* 获取设备像素比
*/
static getPixelRatio(context) {
let backingStore = context.backingStorePixelRatio || context.webkitBackingStorePixelRatio || context.mozBackingStorePixelRatio || context.msBackingStorePixelRatio || context.oBackingStorePixelRatio || context.backingStorePixelRatio || 1;
window.remRatio = window.rem > 168 ? window.rem / 168 : 1;
let ratio = (window.devicePixelRatio || 1) / backingStore;
return ratio;
}
/**
* 将任意单位的长度转换为像素
* @param number
* @param unit
*/
static unitToPix(number, unit, dpi) {
let unitWeight = 0;
switch (unit) {
case "mm": {
unitWeight = _DDeiUtil2.mmToPx(number, dpi);
break;
}
case "cm": {
unitWeight = _DDeiUtil2.cmToPx(number, dpi);
break;
}
case "m": {
unitWeight = _DDeiUtil2.mToPx(number, dpi);
break;
}
case "inch": {
unitWeight = _DDeiUtil2.inchToPx(number, dpi);
break;
}
case "px": {
unitWeight = number;
break;
}
}
return unitWeight;
}
//毫米转像素
static mmToPx(mm, dpi) {
return mm / 25.4 * dpi;
}
//厘米转像素
static cmToPx(cm, dpi) {
return cm / 2.54 * dpi;
}
//米转像素
static mToPx(m, dpi) {
return m / 0.0254 * dpi;
}
//英寸转像素
static inchToPx(inc, dpi) {
return inc * dpi;
}
/**
* 获取屏幕DPI
*/
static getDPI() {
if (window.screen.deviceXDPI) {
return { x: window.screen.deviceXDPI, y: window.screen.deviceYDPI };
} else {
let tmpNode = document.createElement("DIV");
tmpNode.style.cssText = "width:1in;height:1in;position:absolute;left:0px;top:0px;z-index:99;visibility:hidden";
document.body.appendChild(tmpNode);
let x2 = parseInt(tmpNode.offsetWidth);
let y2 = parseInt(tmpNode.offsetHeight);
tmpNode.parentNode.removeChild(tmpNode);
return { x: x2, y: y2 };
}
}
// 16进制编码转rgb
static hex2rgb(hex) {
let hexNum = hex.substring(1);
hexNum = "0x" + (hexNum.length < 6 ? repeatLetter(hexNum, 2) : hexNum);
let r = hexNum >> 16;
let g = hexNum >> 8 & "0xff";
let b = hexNum & "0xff";
return `rgb(${r},${g},${b})`;
}
static hex2ddeicolor(hex) {
let hexNum = hex.substring(1);
hexNum = "0x" + (hexNum.length < 6 ? repeatLetter(hexNum, 2) : hexNum);
let r = hexNum >> 16;
let g = hexNum >> 8 & "0xff";
let b = hexNum & "0xff";
return new DDeiColor(r, g, b, 1);
}
static repeatWord(word, num) {
let result = "";
for (let i2 = 0; i2 < num; i2++) {
result += word;
}
return result;
}
static repeatLetter(word, num) {
var result = "";
for (let letter of word) {
result += repeatWord(letter, num);
}
return result;
}
// rgb转16进制
static rgb2hex(color) {
if (color) {
if (color.toLowerCase().startsWith("rgb")) {
let rgb = color.split(",");
let r = parseInt(rgb[0].split("(")[1]);
let g = parseInt(rgb[1]);
let b = parseInt(rgb[2].split(")")[0]);
let hex = "#" + ((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1);
return hex;
} else if (color.startsWith("#")) {
return color;
}
switch (color) {
case "black":
return "#000000";
case "white":
return "#FFFFFF";
case "red":
return "#FF0000";
case "green":
return "#00FF00";
case "blue":
return "#0000FF";
case "grey":
return "#808080";
case "yellow":
return "#FFFF00";
}
}
return "";
}
// 将颜色转换为可用颜色(rgb),其他情况原样返回
static getColor(color) {
if (!color) {
return null;
}
if (typeof color == "string" && color.startsWith("#")) {
return _DDeiUtil2.hex2rgb(color);
} else {
return color;
}
}
// 将颜色转换为可用颜色(rgb),其他情况原样返回
static getColorObj(color) {
if (!color) {
return null;
}
if (typeof color == "string" && color.startsWith("#")) {
return _DDeiUtil2.hex2ddeicolor(color);
} else {
let hexColor = _DDeiUtil2.rgb2hex(color);
return _DDeiUtil2.hex2ddeicolor(hexColor);
}
}
/**
* 四舍五入保留小数
* @param number 原始数字
* @param pos 小数位数
*/
static round(number, pos = 0) {
let n = number.toFixed(pos);
return parseFloat(n);
}
/**
* 将N个点,归0坐标
*/
static pointsToZero(points, cpv, rotate2) {
if ((points == null ? void 0 : points.length) > 0 && cpv) {
let toZeroMatrix = new Matrix3(
1,
0,
-cpv.x,
0,
1,
-cpv.y,
0,
0,
1
);
if (rotate2) {
let angle2 = _DDeiUtil2.preciseTimes(rotate2, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
toZeroMatrix.premultiply(rotateMatrix);
}
let returnPoints = [];
points.forEach((pv) => {
let npv = new Vector3();
for (let i2 in pv) {
npv[i2] = pv[i2];
}
npv.z = pv.z || pv.z === 0 ? pv.z : 1;
npv.applyMatrix3(toZeroMatrix);
returnPoints.push(npv);
});
return returnPoints;
}
return [];
}
/**
* 将N个归0点,放回坐标
*/
static zeroToPoints(points, cpv, rotate2, scaleX2 = 1, scaleY2 = 1) {
if ((points == null ? void 0 : points.length) > 0 && cpv) {
let m12 = new Matrix3(
1,
0,
0,
0,
1,
0,
0,
0,
1
);
if (scaleX2 != 1 || scaleY2 != 1) {
let scaleMatrix2 = new Matrix3(
scaleX2,
0,
0,
0,
scaleY2,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
}
if (rotate2) {
let angle2 = (-rotate2 * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let moveMatrix2 = new Matrix3(
1,
0,
cpv.x,
0,
1,
cpv.y,
0,
0,
1
);
m12.premultiply(moveMatrix2);
let returnPoints = [];
points.forEach((pv) => {
let npv = new Vector3();
for (let i2 in pv) {
npv[i2] = pv[i2];
}
npv.z = pv.z || pv.z === 0 ? pv.z : 1;
npv.applyMatrix3(m12);
returnPoints.push(npv);
});
return returnPoints;
}
return [];
}
/**
* 根据类别获取OVS
* @param ovs
* @param type
* @returns
*/
static getOVSByType(model, type) {
var _a3, _b2, _c2;
if (!type) {
return model.ovs;
}
let returnOVS = [];
let ovds = (_b2 = (_a3 = _DDeiUtil2.getControlDefine(model)) == null ? void 0 : _a3.define) == null ? void 0 : _b2.ovs;
for (let i2 = 0; i2 < ((_c2 = model == null ? void 0 : model.ovs) == null ? void 0 : _c2.length); i2++) {
let ov = model.ovs[i2];
let ovd = ovds[i2];
if (ovd.type == type) {
returnOVS.push(ov);
}
}
return returnOVS;
}
/**
* 对坐标以及大小进行缩放,并返回新的坐标
* @param pos 原始位置
* @param ratio 缩放比率
* @returns 缩放后的坐标
*/
static getRatioPosition(pos, ratio) {
if (!pos) {
return null;
} else {
let returnP = {};
if (pos.x || pos.x == 0) {
returnP.x = pos.x * ratio;
}
if (pos.y || pos.y == 0) {
returnP.y = pos.y * ratio;
}
if (pos.width || pos.width == 0) {
returnP.width = pos.width * ratio;
}
if (pos.height || pos.height == 0) {
returnP.height = pos.height * ratio;
}
return returnP;
}
}
/**
* 时间格式化
* @param date
* @param fmt
* @returns
*/
static formatDate(date, fmt) {
let o = {
"M+": date.getMonth() + 1,
//月份
"d+": date.getDate(),
//日
"h+": date.getHours(),
//小时
"m+": date.getMinutes(),
//分
"s+": date.getSeconds()
//秒
};
if (ytestReg.test(fmt)) {
fmt = fmt.replace(RegExp.$1, (date.getFullYear() + "").substr(4 - RegExp.$1.length));
}
for (let k in o) {
if (new RegExp("(" + k + ")").test(fmt))
fmt = fmt.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));
}
return fmt;
}
/**
* 复制属性值,再将最终的结果返回,如果目标不存在属性,则动态创建
* @param source 源
* @param dist 目标
*/
static copyJSONValue(source, dist) {
let distType;
if (dist) {
distType = typeof dist;
}
let sourceType = typeof source;
let type = distType && distType != "undefined" ? distType : sourceType;
if (type != void 0 && type != void 0) {
switch (type) {
case "string":
return source;
case "number":
return source;
case "bigint":
return source;
case "boolean":
return source;
case "function":
return source;
case "object": {
if (!dist) {
dist = {};
}
for (let i2 in source) {
dist[i2] = _DDeiUtil2.copyJSONValue(source[i2], dist[i2]);
}
return dist;
}
}
}
return null;
}
/**
* 判断是否具备某种权限
* @operate 操作
* @control 控件
* @propName 属性
* @mode 模式
*/
static isAccess(operate, control, propName, mode, ddInstance) {
let strkey = "AC_" + mode + "_" + operate;
if (control) {
if (propName) {
let accessValue3 = _DDeiUtil2.getConfigValue(strkey + "_" + control.id + "_" + propName, ddInstance);
if (accessValue3 || accessValue3 == false) {
return accessValue3;
} else {
if (control.code) {
accessValue3 = _DDeiUtil2.getConfigValue(strkey + "_" + control.code + "_" + propName, ddInstance);
}
if (accessValue3 || accessValue3 == false) {
return accessValue3;
} else {
if (control.modelCode) {
accessValue3 = _DDeiUtil2.getConfigValue(strkey + "_" + control.modelCode + "_" + propName, ddInstance);
}
if (accessValue3 || accessValue3 == false) {
return accessValue3;
} else {
if (control.modelType) {
accessValue3 = _DDeiUtil2.getConfigValue(strkey + "_" + control.modelType + "_" + propName, ddInstance);
}
if (accessValue3 || accessValue3 == false) {
return accessValue3;
}
}
}
}
}
let accessValue2 = _DDeiUtil2.getConfigValue(strkey + "_" + control.id, ddInstance);
if (accessValue2 || accessValue2 == false) {
return accessValue2;
} else {
if (control.code) {
accessValue2 = _DDeiUtil2.getConfigValue(strkey + "_" + control.code, ddInstance);
}
if (accessValue2 || accessValue2 == false) {
return accessValue2;
} else {
if (control.modelCode) {
accessValue2 = _DDeiUtil2.getConfigValue(strkey + "_" + control.modelCode, ddInstance);
}
if (accessValue2 || accessValue2 == false) {
return accessValue2;
} else {
if (control.modelType) {
accessValue2 = _DDeiUtil2.getConfigValue(strkey + "_" + control.modelType, ddInstance);
}
if (accessValue2 || accessValue2 == false) {
return accessValue2;
}
}
}
}
}
let accessValue = _DDeiUtil2.getConfigValue(strkey, ddInstance);
if (accessValue || accessValue == false) {
return accessValue;
}
return true;
}
/**
* 获取配置属性值
* @param key key
*/
static getConfigValue(key, ddInstance) {
if (ddInstance && (ddInstance[key] || ddInstance[key] == false || ddInstance[key] == 0)) {
return ddInstance[key];
} else {
return DDeiConfig$1[key];
}
}
/**
*@param num:格式化目标数字
*@param decimal:保留几位小数,默认2位
*@param split:千分位分隔符,默认为空
*/
static formatNumber(num, decimal = 0, split = "") {
if (num != null && num != void 0 && isFinite(num)) {
let res = "";
let dotIndex = String(num).indexOf(".");
if (dotIndex === -1) {
if (decimal === 0) {
res = String(num).replace(/(\d)(?=(?:\d{3})+$)/g, `$1${split}`);
} else {
res = String(num).replace(/(\d)(?=(?:\d{3})+$)/g, `$1${split}`) + "." + "0".repeat(decimal);
}
} else {
let numStr = String((Math.round(num * Math.pow(10, decimal)) / Math.pow(10, decimal)).toFixed(decimal));
let decimals = numStr.slice(dotIndex, dotIndex + decimal + 1);
res = String(numStr.slice(0, dotIndex)).replace(/(\d)(?=(?:\d{3})+$)/g, `$1${split}`) + decimals;
}
return res;
} else {
return num;
}
}
/**
* 是否为safari浏览器
*/
static isSafari() {
return safariReg.test(navigator.userAgent) && !chromeReg.test(navigator.userAgent);
}
/**
* 获取可替换的数据值
* 主要用于得到经过业务替换值绑定后的数据
* @param model 对象
* @param keypath 属性路径,一般用.隔开
* @param format 是否需要格式化
* @param replaceSPT 是否替换特殊样式
*/
static getReplacibleValue(model, keypath, format = false, replaceSPT = false, initData = null) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k;
if (model) {
let hasTempSpt = false;
let replaceDetail = null;
let originValue = (_a3 = model == null ? void 0 : model.render) == null ? void 0 : _a3.getCachedValue(keypath);
if (!originValue && initData) {
let rp1 = keypath.split(".");
if (rp1.length > 1) {
let detailCode = rp1.slice(1);
let rd = _DDeiUtil2.getDataByPath(initData, detailCode);
if (rd) {
originValue = rd.data;
}
}
}
let returnValue = originValue;
if (originValue && originValue.indexOf("#") != -1) {
let busiData = _DDeiUtil2.getBusiData(model.stage.ddInstance);
if (busiData) {
let replaceResult = _DDeiUtil2.expressBindValue(originValue, busiData);
if (replaceResult == null ? void 0 : replaceResult.data) {
returnValue = replaceResult.data;
replaceDetail = replaceResult.detail;
}
}
}
let hasFormatted = false;
if (format) {
let fmtType = (_b2 = model == null ? void 0 : model.render) == null ? void 0 : _b2.getCachedValue("fmt.type");
let formatValue = null;
switch (fmtType) {
case 1:
{
let scale = (_c2 = model == null ? void 0 : model.render) == null ? void 0 : _c2.getCachedValue("fmt.nscale");
let tmark = (_d2 = model == null ? void 0 : model.render) == null ? void 0 : _d2.getCachedValue("fmt.tmark");
formatValue = _DDeiUtil2.formatNumber(returnValue, !scale || isNaN(scale) ? 0 : scale, tmark == 1 ? "," : "");
}
break;
case 2:
{
let mrmb = (_e2 = model == null ? void 0 : model.render) == null ? void 0 : _e2.getCachedValue("fmt.mrmb");
if (mrmb == 1) {
formatValue = _DDeiUtil2.toBigMoney(returnValue);
} else {
let scale = (_f = model == null ? void 0 : model.render) == null ? void 0 : _f.getCachedValue("fmt.nscale");
let tmark = (_g = model == null ? void 0 : model.render) == null ? void 0 : _g.getCachedValue("fmt.tmark");
let munit = (_h = model == null ? void 0 : model.render) == null ? void 0 : _h.getCachedValue("fmt.munit");
let mmark = (_i = model == null ? void 0 : model.render) == null ? void 0 : _i.getCachedValue("fmt.mmark");
formatValue = _DDeiUtil2.formatNumber(returnValue, !scale || isNaN(scale) ? 0 : scale, tmark == 1 ? "," : "");
formatValue = (mmark ? mmark : "") + formatValue + (munit ? munit : "");
}
}
break;
case 3:
{
let dtype = (_j = model == null ? void 0 : model.render) == null ? void 0 : _j.getCachedValue("fmt.dtype");
let isFmt = false;
let dv = null;
if (isDate$1(returnValue)) {
isFmt = true;
dv = returnValue;
} else if (isString(returnValue) || isNumber(returnValue) && ("" + returnValue).length == 13) {
try {
dv = new Date(parseInt(returnValue));
isFmt = true;
} catch (e) {
}
}
if (isFmt) {
switch (dtype) {
case 1:
{
formatValue = _DDeiUtil2.formatDate(dv, "yyyy-MM-dd");
}
break;
case 2:
{
formatValue = _DDeiUtil2.formatDate(dv, "hh:mm:ss");
}
break;
case 3:
{
formatValue = _DDeiUtil2.formatDate(dv, "yyyy-MM-dd hh:mm:ss");
}
break;
case 99:
{
let format2 = (_k = model == null ? void 0 : model.render) == null ? void 0 : _k.getCachedValue("fmt.format");
if (format2) {
formatValue = _DDeiUtil2.formatDate(dv, format2);
}
}
break;
}
}
}
break;
}
if (formatValue) {
if (returnValue != formatValue && model.render && replaceSPT && model.sptStyle) {
let tempSptStyleArr = _DDeiUtil2.sptStyleToArray(JSON.parse(JSON.stringify(model.sptStyle)));
let tempStyle = null;
for (let i2 = 0; i2 < tempSptStyleArr.length; i2++) {
let v = tempSptStyleArr[i2];
if (v && JSON.stringify(v) != "{}") {
tempStyle = v;
break;
}
}
if (tempStyle) {
tempSptStyleArr = _DDeiUtil2.copyElementToArray(tempStyle, formatValue.length);
}
if ((tempSptStyleArr == null ? void 0 : tempSptStyleArr.length) > 0) {
model.render.tempSptStyle = _DDeiUtil2.sptStyleArrayToObject(tempSptStyleArr);
hasTempSpt = true;
} else {
delete model.render.tempSptStyle;
}
} else {
delete model.render.tempSptStyle;
}
returnValue = formatValue;
hasFormatted = true;
}
}
if (!hasFormatted && model.render && replaceSPT && (replaceDetail == null ? void 0 : replaceDetail.length) > 0 && model.sptStyle) {
let tempSptStyleArr = _DDeiUtil2.sptStyleToArray(JSON.parse(JSON.stringify(model.sptStyle)));
let deltaI = 0;
replaceDetail.forEach((detail) => {
let sidx = detail.index;
let eidx = detail.index + detail.bind.length;
let tempStyle = null;
for (let i2 = sidx; i2 < eidx; i2++) {
let v = _DDeiUtil2.getDataByPathList(model, "sptStyle." + i2);
if (v && JSON.stringify(v) != "{}") {
tempStyle = v;
break;
}
}
if (tempStyle) {
let insertArr = _DDeiUtil2.copyElementToArray(tempStyle, detail.value.length);
tempSptStyleArr.splice(sidx + deltaI, eidx - sidx, ...insertArr);
deltaI += detail.value.length - eidx + sidx;
}
});
if ((tempSptStyleArr == null ? void 0 : tempSptStyleArr.length) > 0) {
hasTempSpt = true;
model.render.tempSptStyle = _DDeiUtil2.sptStyleArrayToObject(tempSptStyleArr);
}
}
if (!hasTempSpt) {
delete model.render.tempSptStyle;
}
return returnValue;
}
return null;
}
/**
* 把一个元素复制到一个数组中
* @param element
* @param size
*/
static copyElementToArray(element, size) {
let arr = [];
if (size > 0) {
for (let i2 = 0; i2 < size; i2++) {
let data = cloneDeep(element);
arr.push(data);
}
}
return arr;
}
/**
* 将sptStyle,按照key的大小转换为数组形式
* @param sptStyle
*/
static sptStyleToArray(sptStyle) {
let max = -Infinity, min = Infinity;
let arr = [];
for (let i2 in sptStyle) {
max = Math.max(max, parseInt(i2));
min = Math.min(min, parseInt(i2));
}
if (max != -Infinity && min != Infinity) {
for (let i2 = 0; i2 < min; i2++) {
arr.push(null);
}
for (let i2 = min; i2 <= max; i2++) {
arr.push(sptStyle[i2]);
}
}
return arr;
}
/**
* 将sptStyle,按照key的大小转换为数组形式
* @param sptStyle
*/
static sptStyleArrayToObject(sptStyle) {
let obj = {};
for (let i2 = 0; i2 < sptStyle.length; i2++) {
if (sptStyle[i2]) {
obj[i2] = sptStyle[i2];
}
}
return obj;
}
/**
* 用于处理绑定字段或文本的表达式替换
* @return 返回替换后的字符串,以及替换的详情信息
*/
static expressBindValue(originValue, busiData, row) {
if (originValue && originValue.indexOf("#{") != -1) {
let t = originValue;
let replaceData = "";
let replaceDetail = [];
let usedCharIdx = 0;
while (t && t != "") {
let result = expressBindValueReg.exec(t);
if (result != null && result.length > 0) {
replaceData += t.substring(0, result.index);
let rs = result[0].replaceAll(" ", "");
let aer = this.analysisExpress(rs.substring(2, rs.length - 1), busiData, row);
replaceDetail.push({ index: result.index + usedCharIdx, bind: result[0], value: aer });
replaceData += aer;
usedCharIdx += result.index + result[0].length;
t = t.substr(result.index + result[0].length);
} else {
replaceData += t;
break;
}
}
return { data: replaceData, detail: replaceDetail };
}
}
/**
* 处理表达式计算,格式如下:
* 列表.行#费用 列表的当前行费用
* 列表.行#费用-列表.行#收入 列表当前行费用-当前行收入
* 列表.0#费用 第一行的费用字段
* 列表.数量 列表长度
* 列表.平均#费用 对列表中的费用字段求平均值
* 列表.求和#费用 对列表中的费用字段求合
* 列表.求和#收入-列表#求和#费用 列表中收入-费用
* 列表.求和#收入-100 列表中收入-100
*/
static analysisExpress(expressContent, busiData, row) {
expressContent = expressContent.replaceAll(" ", "");
let expressArray = expressContent.split(contentSplitReg);
if (expressArray != null && expressArray.length > 0) {
for (let i2 = 0; i2 < expressArray.length; i2++) {
let ea = expressArray[i2];
let eaValue = this.calculExpressValue(ea, busiData, row);
expressContent = expressContent.replaceAll(ea, eaValue);
}
}
try {
if (contentSplitReg.test(expressContent)) {
expressContent = expressContent.replaceAll("null", "0");
let result = new Function("return " + expressContent)();
return result;
} else {
return expressContent.replaceAll("null", "");
}
} catch (e) {
console.error(e);
return "";
}
}
//解析简单的,不带任何运算符号的表达式
static calculExpressValue(ea, busiData, row) {
let rd = null;
if (isNumberReg.test(ea)) {
return ea;
} else {
if (ea.indexOf(".") == -1 && ea.indexOf("#") == -1) {
rd = busiData[ea];
} else if (ea.indexOf(".") != -1) {
try {
let listKey = ea.split(".")[0];
let listDataExpress = ea.split(".")[1];
if (listKey && listDataExpress) {
let listSubKey = listDataExpress.split("#")[0];
let listData = busiData[listKey];
if ("平均" == listSubKey || "平均值" == listSubKey) {
let listSubEP = listDataExpress.split("#")[1];
if (busiData[ea + "_catch_avg"]) {
rd = busiData[ea + "_catch_avg"];
} else {
let countNum = 0;
if (busiData[ea + "_catch_count"]) {
countNum = busiData[ea + "_catch_count"];
} else {
for (let i2 = 0; i2 < listData.length; i2++) {
var ld = listData[i2][listSubEP];
if (ld && isNumberReg.test(ld)) {
countNum += parseFloat(ld);
}
}
busiData[ea + "_catch_count"] = countNum;
}
let avgNNum = countNum / listData.length;
busiData[ea + "_catch_avg"] = avgNNum;
rd = avgNNum;
}
} else if ("最大" == listSubKey || "最大值" == listSubKey) {
let listSubEP = listDataExpress.split("#")[1];
let maxNum = null;
if (busiData[ea + "_catch_max"]) {
maxNum = busiData[ea + "_catch_max"];
} else {
for (let i2 = 0; i2 < listData.length; i2++) {
let ld2 = listData[i2][listSubEP];
if (ld2 && isNumberReg.test(ld2)) {
if (maxNum == null) {
maxNum = ld2;
} else if (maxNum < ld2) {
maxNum = ld2;
}
}
}
busiData[ea + "_catch_max"] = maxNum;
}
rd = maxNum;
} else if ("最小" == listSubKey || "最小值" == listSubKey) {
let listSubEP = listDataExpress.split("#")[1];
let minNum = null;
if (busiData[ea + "_catch_min"]) {
minNum = busiData[ea + "_catch_min"];
} else {
for (let i2 = 0; i2 < listData.length; i2++) {
let ld2 = listData[i2][listSubEP];
if (ld2 && isNumberReg.test(ld2)) {
if (minNum == null) {
minNum = ld2;
} else if (minNum > ld2) {
minNum = ld2;
}
}
}
busiData[ea + "_catch_min"] = minNum;
}
rd = minNum;
} else if ("合计" == listSubKey || "求和" == listSubKey || "求合" == listSubKey) {
let listSubEP = listDataExpress.split("#")[1];
let countNum = 0;
if (busiData[ea + "_catch_count"]) {
countNum = busiData[ea + "_catch_count"];
} else {
for (let i2 = 0; i2 < listData.length; i2++) {
var ld = listData[i2][listSubEP];
if (ld && isNumberReg.test(ld)) {
countNum += parseFloat(ld);
}
}
busiData[ea + "_catch_count"] = countNum;
}
rd = countNum;
} else if ("数量" == listSubKey || "长度" == listSubKey) {
rd = busiData[listKey].length;
} else if ("尾行" == listSubKey) {
let listSubEP = listDataExpress.split("#")[1];
let ld2 = listData[listData.length - 1][listSubEP];
if (ld2 && isNumberReg.test(ld2)) {
rd = parseFloat(ld2);
} else if (ld2) {
rd = ld2;
}
} else if ("首行" == listSubKey) {
let listSubEP = listDataExpress.split("#")[1];
let ld2 = listData[0][listSubEP];
if (ld2 && isNumberReg.test(ld2)) {
rd = parseFloat(ld2);
} else if (ld2) {
rd = ld2;
}
} else if ("行" == listSubKey) {
let listSubEP = listDataExpress.split("#")[1];
let ld2 = listData[row][listSubEP];
if (ld2 && isNumberReg.test(ld2)) {
rd = parseFloat(ld2);
} else if (ld2) {
rd = ld2;
}
} else if (isNumberReg.test(listSubKey)) {
let listSubEP = listDataExpress.split("#")[1];
let ld2 = listData[listSubKey][listSubEP];
if (ld2 && isNumberReg.test(ld2)) {
rd = parseFloat(ld2);
} else if (ld2) {
rd = ld2;
}
}
}
} catch (e) {
console.error(e);
}
}
}
if (rd != null && isNumberReg.test(rd)) {
return rd;
} else if (rd) {
return rd;
}
return null;
}
/**
* 对输入数据进行合并拆分等处理,主要用来处理分页打印,多页打印等功能
*/
static analysisDataFromTemplate(iData, templateJSON) {
let tableListConfig = {};
let pdJSON = templateJSON;
for (let j2 in pdJSON.rootModels) {
if (pdJSON.rootModels[j2].modelType == "PDTable") {
let outDataRowStrategy = pdJSON.rootModels[j2]["outDataRowStrategy"];
if (outDataRowStrategy == 1 || outDataRowStrategy == "1") {
let maxDataRow = pdJSON.rootModels[j2]["maxDataRow"];
if (maxDataRow != 0 && maxDataRow != null && maxDataRow != "") {
let table2 = pdJSON.rootModels[j2];
let dataRowStart = -1;
let dataRowEnd = -1;
let listKey = null;
for (let ri = 0; ri < table2.rows.length; ri++) {
for (let rj = 0; rj < table2.rows[ri].length; rj++) {
let curCell = table2.rows[ri][rj];
if (curCell.dataRow == 2 || curCell.dataRow == "2" || curCell.attrs["dataRow"] == 2 || curCell.attrs["dataRow"] == "2") {
if (dataRowStart == -1) {
dataRowStart = ri;
}
if (dataRowEnd < ri) {
dataRowEnd = ri;
}
let expressContent = null;
if (curCell.bindField || curCell.attrs.bindField) {
expressContent = curCell.bindField ? curCell.bindField : curCell.attrs.bindField;
} else if (curCell.text && curCell.text.indexOf("#{") != -1) {
let t = curCell.text;
let reg = /#\{[^\{\}]*\}/g;
let result = reg.exec(t);
if (result != null && result.length > 0) {
let rs = result[0].replaceAll(" ", "");
expressContent = rs.substring(2, rs.length - 1);
}
}
if (expressContent) {
expressContent = expressContent.replaceAll(" ", "");
let expressArray = expressContent.split(contentSplitReg);
if (expressArray != null && expressArray.length > 0) {
for (let i2 = 0; i2 < expressArray.length; i2++) {
let ea = expressArray[i2];
if (ea.indexOf(".") != -1) {
try {
listKey = ea.split(".")[0];
} catch (e) {
}
}
}
}
}
}
}
}
if (listKey) {
let rowNum = parseInt(maxDataRow / (dataRowEnd - dataRowStart + 1));
if (rowNum >= 1) {
tableListConfig[listKey] = rowNum;
}
}
}
}
}
}
let newIDatas = [];
for (let listKey in tableListConfig) {
if (iData[listKey] && tableListConfig[listKey] && tableListConfig[listKey] > 0 && iData[listKey].length > tableListConfig[listKey]) {
let subArrays = this.subArrayGroup(iData[listKey], tableListConfig[listKey]);
for (let si = 0; si < subArrays.length; si++) {
let newIData = cloneDeep(iData);
newIData[listKey] = subArrays[si];
newIDatas[newIDatas.length] = newIData;
}
}
}
if (newIDatas.length == 0) {
newIDatas[0] = iData;
}
return newIDatas;
}
/**
* 以templateJSON为模板,循环inputData,替换模板值后,生成新的JSON数组返回
*/
static analysisBindData(inputData, templateJSON) {
let processDatas = inputData.flatMap((idata) => this.analysisDataFromTemplate(idata, templateJSON));
return processDatas.map((idata) => {
let pdJSON = JSON.parse(JSON.stringify(templateJSON.toJSON()));
this.processWatermark(pdJSON.pdPaper, idata);
for (let control of pdJSON.rootModels) {
if (control.modelType === "PDTable") {
this.processTableControl(control, idata);
} else if (control.modelType === "PDImage") {
this.processImageControl(control, idata);
} else {
this.processTextControl(control, idata);
}
}
return pdJSON;
});
}
// 处理水印
static processWatermark(pdPaper, idata) {
let watermarkReplaceData = this.processTextOrBindFieldExpress(pdPaper, idata);
if (watermarkReplaceData) {
pdPaper.watermarkBase64 = watermarkReplaceData;
pdPaper.attrs["watermarkBase64"] = watermarkReplaceData;
pdPaper.watermark = watermarkReplaceData;
pdPaper.attrs["watermark"] = watermarkReplaceData;
pdPaper.bindField = null;
pdPaper.attrs["bindField"] = null;
}
}
// 处理表格控件
static processTableControl(table2, idata) {
}
// 处理图片控件
static processImageControl(control, idata) {
let replaceData = this.processTextOrBindFieldExpress(control, idata);
if (replaceData) {
control.base64 = replaceData;
control.attrs["base64"] = replaceData;
control.src = replaceData;
control.attrs["src"] = replaceData;
control.bindField = null;
control.attrs["bindField"] = null;
}
}
// 处理文本控件
static processTextControl(control, idata) {
let replaceData = this.processTextOrBindFieldExpress(control, idata);
control.text = replaceData;
control.attrs["text"] = replaceData;
control.bindField = null;
control.attrs["bindField"] = null;
control.convertToRMBY = "1";
}
/**
* 用于处理绑定字段或文本的表达式替换
*/
static processTextOrBindFieldExpress(control, idata, row) {
if (control.bindField || control.attrs.bindField) {
let replaceData = "";
let expressContent = control.bindField ? control.bindField : control.attrs.bindField;
replaceData = this.analysisExpress(expressContent, idata, row);
if (!replaceData) {
replaceData = "";
}
if (control.attrs.convertToRMBY == 2 || control.attrs.convertToRMBY == "2" || control.convertToRMBY == 2 || control.convertToRMBY == "2") {
replaceData = PDSetting.dealBigMoney(replaceData);
}
return replaceData;
} else if (control.text && control.text.indexOf("#{") != -1) {
let t = control.text;
let replaceData = "";
while (t && t != "") {
let reg = /#\{[^\{\}]*\}/g;
let result = reg.exec(t);
if (result != null && result.length > 0) {
replaceData += t.substring(0, result.index);
let rs = result[0].replaceAll(" ", "");
let aer = this.analysisExpress(rs.substring(2, rs.length - 1), idata, row);
if (control.attrs.convertToRMBY == 2 || control.attrs.convertToRMBY == "2" || control.convertToRMBY == 2 || control.convertToRMBY == "2") {
aer = this.dealBigMoney(aer);
}
replaceData += aer;
t = t.substr(result.index + result[0].length);
} else {
replaceData += t;
break;
}
}
return replaceData;
} else if (control.text) {
if (control.attrs.convertToRMBY == 2 || control.attrs.convertToRMBY == "2" || control.convertToRMBY == 2 || control.convertToRMBY == "2") {
return this.dealBigMoney(control.text);
} else {
return control.text;
}
}
}
/**
* 转换为人民币大写
* @param money 数字
* @returns
*/
static toBigMoney(money) {
let cnNums = new Array("零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖");
let cnIntRadice = new Array("", "拾", "佰", "仟");
let cnIntUnits = new Array("", "万", "亿", "兆");
let cnDecUnits = new Array("角", "分", "毫", "厘");
let cnInteger = "整";
let cnIntLast = "元";
let maxNum = 1e15;
let integerNum;
let decimalNum;
let chineseStr = "";
let parts;
if (money == "" || money == null || money == void 0) {
return "";
}
money = parseFloat(money);
if (money >= maxNum) {
return "";
}
if (money == 0) {
chineseStr = cnNums[0] + cnIntLast + cnInteger;
return chineseStr;
}
money = money.toString();
if (money.indexOf(".") == -1) {
integerNum = money;
decimalNum = "";
} else {
parts = money.split(".");
integerNum = parts[0];
decimalNum = parts[1].substr(0, 4);
}
if (parseInt(integerNum, 10) > 0) {
let zeroCount = 0;
let IntLen = integerNum.length;
for (let i2 = 0; i2 < IntLen; i2++) {
let n = integerNum.substr(i2, 1);
let p = IntLen - i2 - 1;
let q = p / 4;
let m = p % 4;
if (n == "0") {
zeroCount++;
} else {
if (zeroCount > 0) {
chineseStr += cnNums[0];
}
zeroCount = 0;
chineseStr += cnNums[parseInt(n)] + cnIntRadice[m];
}
if (m == 0 && zeroCount < 4) {
chineseStr += cnIntUnits[q];
}
}
chineseStr += cnIntLast;
}
if (decimalNum != "") {
let decLen = decimalNum.length;
for (let i2 = 0; i2 < decLen; i2++) {
let n = decimalNum.substr(i2, 1);
if (n != "0") {
chineseStr += cnNums[Number(n)] + cnDecUnits[i2];
}
}
}
if (chineseStr == "") {
chineseStr += cnNums[0] + cnIntLast + cnInteger;
} else if (decimalNum == "") {
chineseStr += cnInteger;
}
return chineseStr;
}
/**
* 精准返回num1除以num2的结果
*/
static preciseDiv(num1, num2) {
let t1 = 0, t2 = 0, r1, r2;
try {
t1 = num1.toString().split(".")[1].length;
} catch (e) {
}
try {
t2 = num2.toString().split(".")[1].length;
} catch (e) {
}
r1 = Number(num1.toString().replace(".", ""));
r2 = Number(num2.toString().replace(".", ""));
return r1 / r2 * Math.pow(10, t2 - t1);
}
/**
* 精准返回num1乘以num2的结果
*/
static preciseTimes(num1, num2) {
let m = 0, s1 = num1.toString(), s2 = num2.toString();
try {
m += s1.split(".")[1].length;
} catch (e) {
}
try {
m += s2.split(".")[1].length;
} catch (e) {
}
return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m);
}
/**
* 精准返回num1+num2的结果
*/
static preciseAdd(num1, num2) {
let r1, r2, m;
try {
r1 = num1.toString().split(".")[1].length;
} catch (e) {
r1 = 0;
}
try {
r2 = num2.toString().split(".")[1].length;
} catch (e) {
r2 = 0;
}
m = Math.pow(10, Math.max(r1, r2));
return (num1 * m + num2 * m) / m;
}
/**
* 精准返回num1-num2的结果
*/
static preciseSub(num1, num2) {
let r1, r2, m, n;
try {
r1 = num1.toString().split(".")[1].length;
} catch (e) {
r1 = 0;
}
try {
r2 = num2.toString().split(".")[1].length;
} catch (e) {
r2 = 0;
}
m = Math.pow(10, Math.max(r1, r2));
n = r1 >= r2 ? r1 : r2;
return parseFloat(((num1 * m - num2 * m) / m).toFixed(n));
}
/**
* 读取最近写入颜色
*/
static readRecentlyChooseColors() {
let colorStrs = localStorage.getItem("ddei-recently-choose-colors");
if (colorStrs) {
let colors = colorStrs.split(",");
_DDeiUtil2.recentlyChooseColors = colors;
}
}
/**
* 写入最近选取颜色
*/
static whiteRecentlyChooseColors(newValue) {
if (!_DDeiUtil2.recentlyChooseColors) {
_DDeiUtil2.recentlyChooseColors = [];
}
if (_DDeiUtil2.recentlyChooseColors.indexOf(newValue) != -1) {
_DDeiUtil2.recentlyChooseColors.splice(_DDeiUtil2.recentlyChooseColors.indexOf(newValue), 1);
}
_DDeiUtil2.recentlyChooseColors.splice(0, 0, newValue);
if (_DDeiUtil2.recentlyChooseColors.length > 10) {
_DDeiUtil2.recentlyChooseColors.splice(10, 1);
}
localStorage.setItem("ddei-recently-choose-colors", _DDeiUtil2.recentlyChooseColors.toString());
}
static canvasToImage(canvas) {
return new Promise((resolve, rejected) => {
let dataURL = canvas.toDataURL("image/png");
let img = new Image();
img.src = dataURL;
img.onload = function() {
resolve(img);
};
img.onerror = function() {
rejected(img);
};
});
}
/**
* 将当前实例的stage转换为image
* @param ddInstance
* @param width
* @param height
*/
static stageScreenToImage(ddInstance, width, height) {
return new Promise((resolve, rejected) => {
try {
let canvas = document.createElement("canvas");
let ctx = canvas.getContext("2d");
let rat1 = ddInstance.render.ratio;
let rat2 = Math.max(ddInstance.pixel, _DDeiUtil2.getPixelRatio(ctx));
ddInstance.render.tempCanvas = canvas;
let models = ddInstance.stage.getLayerModels();
let outRect = DDeiAbstractShape.getOutRectByPV(models);
let lineOffset = models[0].render.getCachedValue("border.width");
let addWidth = 0;
if (lineOffset) {
addWidth = lineOffset * rat1;
if (models.length > 1) {
addWidth = lineOffset * 2;
}
}
let scaleW = 1, scaleH = 1;
if (outRect.width * rat1 > width * rat1) {
scaleW = width / outRect.width;
}
if (outRect.height * rat1 > height * rat1) {
scaleH = height / outRect.height;
}
canvas.setAttribute("style", "-webkit-font-smoothing:antialiased;-moz-transform-origin:left top;-moz-transform:scale(" + 1 / rat2 + ");display:block;zoom:" + 1 / rat2);
if (scaleW != 1 || scaleH != 1) {
canvas.setAttribute("width", width * rat1 + addWidth);
canvas.setAttribute("height", height * rat1 + addWidth);
ctx.translate(-outRect.x * rat1 * scaleW + addWidth / 2, -outRect.y * rat1 * scaleH + addWidth / 2);
ctx.scale(scaleW, scaleH);
} else {
canvas.setAttribute("width", outRect.width * rat1 + addWidth);
canvas.setAttribute("height", outRect.height * rat1 + addWidth);
ctx.translate(-outRect.x * rat1 + addWidth / 2, -outRect.y * rat1 + addWidth / 2);
}
models.forEach((item) => {
item.render.drawShape();
});
let base64 = canvas.toDataURL("image/png");
ddInstance.render.tempCanvas = null;
resolve(base64);
} catch (e) {
ddInstance.render.tempCanvas = null;
resolve("");
}
});
}
/**
* 将当前实例的stage按一定大小比例剪切为多张图片
*/
static async cutStageToImages(ddInstance, stage2, width, height, sx, sy, ex, ey, scaleSize = 2, bg = false, mask = false, autoScale = false) {
return new Promise((resolve, rejected) => {
var _a3;
try {
let canvas = document.createElement("canvas");
let ctx = canvas.getContext("2d");
let oldRat1 = ddInstance.render.ratio;
let rat1 = scaleSize ? scaleSize : oldRat1;
let stageRatio2 = stage2.getStageRatio();
ddInstance.render.tempCanvas = canvas;
ddInstance.render.ratio = rat1;
let editorId = _DDeiUtil2.getEditorId(ddInstance);
let containerDiv = document.getElementById(editorId + "_ddei_cut_img_div");
canvas.setAttribute("style", "-webkit-font-smoothing:antialiased;-moz-transform-origin:left top;-moz-transform:scale(" + 1 / rat1 + ");display:block;zoom:" + 1 / rat1);
canvas.setAttribute("width", width * rat1);
canvas.setAttribute("height", height * rat1);
containerDiv.appendChild(canvas);
let imagesBase64 = [];
let forceBreak = false;
for (let i2 = sy; (ey > i2 || Math.abs(ey - height - i2) <= 0.01) && !forceBreak; i2 = i2 + height) {
for (let j2 = sx; (ex > j2 || Math.abs(ex - width - j2) <= 0.01) && !forceBreak; j2 = j2 + width) {
ctx.save();
ctx.clearRect(0, 0, width * rat1, height * rat1);
ctx.translate(-j2 * rat1, -i2 * rat1);
for (let li = stage2.layers.length - 1; li >= 0; li--) {
if (stage2.layers[li].display == 1 && stage2.layers[li].print != false) {
if (bg) {
stage2.layers[li].render.drawBackground(sx * rat1, sy * rat1, (ex - sx) * rat1, (ey - sy) * rat1);
}
}
}
ctx.restore();
ctx.save();
if (autoScale) {
let models = stage2.getLayerModels();
let outRect = DDeiAbstractShape.getOutRectByPV(models);
let scaleW = outRect.width / stageRatio2 / width;
let scaleH = outRect.height / stageRatio2 / height;
ctx.scale(1 / scaleW, 1 / scaleH);
ctx.translate(-outRect.x * rat1 / stageRatio2, -outRect.y * rat1 / stageRatio2);
forceBreak = true;
} else {
ctx.translate(-j2 * rat1, -i2 * rat1);
}
ctx.scale(1 / stageRatio2, 1 / stageRatio2);
let hasPrint = true;
stage2.render.selector.resetState();
for (let li = stage2.layers.length - 1; li >= 0; li--) {
if (stage2.layers[li].display == 1 && stage2.layers[li].print != false) {
stage2.layers[li].opPoints = [];
delete stage2.layers[li].opLine;
(_a3 = stage2.layers[li].shadowControls) == null ? void 0 : _a3.forEach((c) => {
c.destroyed();
});
stage2.layers[li].shadowControls = [];
stage2.layers[li].render.drawShape(false);
hasPrint = true;
}
}
ctx.restore();
if (mask) {
ctx.save();
ctx.scale(1 / stageRatio2, 1 / stageRatio2);
stage2.render.drawMark();
ctx.restore();
}
if (hasPrint) {
let base64 = canvas.toDataURL("image/png");
imagesBase64.push(base64);
}
}
}
ddInstance.render.ratio = oldRat1;
ddInstance.render.tempCanvas = null;
containerDiv.removeChild(canvas);
resolve(imagesBase64);
} catch (e) {
ddInstance.render.tempCanvas = null;
resolve("");
}
});
}
/**
* 根据属性获取纸张大小
*/
static getPaperSize(stage2, paperType, useRat = true) {
let paperWidth = 0;
let paperHeight = 0;
let paperInit;
if (stage2.ddInstance.paper && typeof stage2.ddInstance.paper == "object") {
paperInit = stage2.ddInstance.paper;
}
if (!paperType) {
paperType = DDeiModelArrtibuteValue.getAttrValueByState(stage2, "paper.type", true, paperInit);
}
let paperConfig = DDeiConfig$1.PAPER[paperType];
if (paperConfig) {
let stageRatio2 = stage2.getStageRatio();
let ratio;
if (useRat) {
let rat1 = stage2.render.ddRender.ratio;
ratio = rat1 * stageRatio2;
} else {
ratio = stageRatio2;
}
let xDPI = stage2.ddInstance.dpi.x;
let paperDirect = DDeiModelArrtibuteValue.getAttrValueByState(stage2, "paper.direct", true, paperInit);
let w = paperConfig.width;
let h = paperConfig.height;
let unit = paperConfig.unit;
if (paperType == "自定义") {
let custWidth = DDeiModelArrtibuteValue.getAttrValueByState(stage2, "paper.width", true, paperInit);
if (custWidth || custWidth == 0) {
w = custWidth;
}
let custHeight = DDeiModelArrtibuteValue.getAttrValueByState(stage2, "paper.height", true, paperInit);
if (custHeight || custHeight == 0) {
h = custHeight;
}
let custUnit = DDeiModelArrtibuteValue.getAttrValueByState(stage2, "paper.unit", true, paperInit);
if (custUnit) {
unit = custUnit;
}
}
if (paperDirect == 1 || paperDirect == "1") {
paperWidth = _DDeiUtil2.unitToPix(w, unit, xDPI) * ratio;
paperHeight = _DDeiUtil2.unitToPix(h, unit, xDPI) * ratio;
} else {
paperHeight = _DDeiUtil2.unitToPix(w, unit, xDPI) * ratio;
paperWidth = _DDeiUtil2.unitToPix(h, unit, xDPI) * ratio;
}
}
return { width: paperWidth, height: paperHeight };
}
static dataURLtoBlob(dataurl) {
let arr = dataurl.split(","), mime = arr[0].match(/:(.*?);/)[1], bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
return new Blob([u8arr], { type: mime });
}
/**
* 将页面坐标(像素)转换为标尺坐标
* @param point 转换的点
* @param stage 舞台
* @param unit 单位
*/
static toRulerCoord(point2, stage2, unit) {
let stageRatio2 = stage2.getStageRatio();
let xDPI = stage2.ddInstance.dpi.x;
let rulerConfig = DDeiConfig$1.RULER[unit];
let unitWeight = _DDeiUtil2.unitToPix(rulerConfig.size, unit, xDPI);
let marginWeight = unitWeight * stageRatio2;
return {
x: (point2.x - stage2.spv.x) / marginWeight * rulerConfig.size,
y: (point2.y - stage2.spv.y) / marginWeight * rulerConfig.size,
unit
};
}
/**
* 将标尺坐标转换为页面坐标(像素)
* @param point 转换的点
* @param stage 舞台
* @param unit 单位
*/
static toPageCoord(point2, stage2, unit) {
let stageRatio2 = (stage2 == null ? void 0 : stage2.ratio) ? stage2.ratio : stage2.getStageRatio();
let xDPI = stage2.dpi ? stage2.dpi : stage2.ddInstance.dpi.x;
let unitWeight = _DDeiUtil2.unitToPix(1, unit, xDPI) * stageRatio2;
return {
x: point2.x * unitWeight + (stage2.spv ? stage2.spv.x : 0),
y: point2.y * unitWeight + (stage2.spv ? stage2.spv.y : 0)
};
}
/**
* 转换子元素的坐标
* @param container 容器
* @param stage 画布
* @param unit 单位
*/
static convertChildrenJsonUnit(model, stage2, unit) {
var _a3;
if (model.cpv) {
let cpv = _DDeiUtil2.toPageCoord({ x: model.cpv.x, y: model.cpv.y }, stage2, unit);
model.cpv.x = cpv.x;
model.cpv.y = cpv.y;
}
if (model.bpv) {
let bpv2 = _DDeiUtil2.toPageCoord({ x: model.bpv.x, y: model.bpv.y }, stage2, unit);
model.bpv.x = bpv2.x;
model.bpv.y = bpv2.y;
}
if (model.hpv) {
for (let k = 0; k < model.hpv.length; k++) {
let hpv = _DDeiUtil2.toPageCoord({ x: model.hpv[k].x, y: model.hpv[k].y }, stage2, unit);
model.hpv[k].x = hpv.x;
model.hpv[k].y = hpv.y;
}
}
if (model.exPvs) {
for (let k in model.exPvs) {
let pv = _DDeiUtil2.toPageCoord({ x: model.exPvs[k].x, y: model.exPvs[k].y }, stage2, unit);
model.exPvs[k].x = pv.x;
model.exPvs[k].y = pv.y;
}
}
if (model.pvs) {
for (let k = 0; k < model.pvs.length; k++) {
let pv = _DDeiUtil2.toPageCoord({ x: model.pvs[k].x, y: model.pvs[k].y }, stage2, unit);
model.pvs[k].x = pv.x;
model.pvs[k].y = pv.y;
}
}
if (((_a3 = model.composes) == null ? void 0 : _a3.length) > 0) {
for (let k = 0; k < model.composes.length; k++) {
_DDeiUtil2.convertChildrenJsonUnit(model.composes[k], stage2, unit);
}
}
if (model.midList) {
for (let i2 = 0; i2 < model.midList.length; i2++) {
if (model.models[model.midList[i2]]) {
let subModel = model.models[model.midList[i2]];
_DDeiUtil2.convertChildrenJsonUnit(subModel, stage2, unit);
}
}
}
}
static addLineLink(model, smodel, point2, type) {
var _a3, _b2;
let pathPvs = smodel.pvs;
let proPoints = DDeiAbstractShape.getProjPointDists(pathPvs, point2.x, point2.y, false, 1);
let index = proPoints[0].index;
let distance = _DDeiUtil2.getPointDistance(pathPvs[index].x, pathPvs[index].y, pathPvs[index + 1].x, pathPvs[index + 1].y);
let sita = _DDeiUtil2.getLineAngle(pathPvs[index].x, pathPvs[index].y, pathPvs[index + 1].x, pathPvs[index + 1].y);
let pointDistance = _DDeiUtil2.getPointDistance(pathPvs[index].x, pathPvs[index].y, proPoints[0].x, proPoints[0].y);
let rate = pointDistance / distance;
rate = rate > 1 ? rate : rate;
let id = "_" + _DDeiUtil2.getUniqueCode();
let dmpath;
if (type == 1) {
dmpath = "startPoint";
smodel.exPvs[id] = new Vector3(model.startPoint.x, model.startPoint.y, model.startPoint.z);
} else if (type == 2) {
dmpath = "endPoint";
smodel.exPvs[id] = new Vector3(model.endPoint.x, model.endPoint.y, model.endPoint.z);
}
smodel.exPvs[id].rate = rate;
smodel.exPvs[id].sita = sita;
smodel.exPvs[id].index = index;
smodel.exPvs[id].id = id;
let link2 = new DDeiLink({
sm: smodel,
dm: model,
smpath: "exPvs." + id,
dmpath,
stage: model.stage
});
(_a3 = model.stage) == null ? void 0 : _a3.addLink(link2);
smodel.transVectors(new Matrix3());
smodel.updateLinkModels();
(_b2 = smodel.render) == null ? void 0 : _b2.enableRefreshShape();
}
/**
* 删除对象的属性
* @param obj 对象
* @param path 属性路径
*/
static deletePropertyByPath(obj, path) {
const parts = path.split(".");
let current = obj;
for (let i2 = 0; i2 < parts.length - 1; i2++) {
if (current[parts[i2]] === void 0) {
return;
}
current = current[parts[i2]];
}
delete current[parts[parts.length - 1]];
}
};
__publicField$2(_DDeiUtil, "getAttrValueByConfig");
__publicField$2(_DDeiUtil, "getControlDefine");
__publicField$2(_DDeiUtil, "getMenuConfig");
__publicField$2(_DDeiUtil, "getMenuControlId");
__publicField$2(_DDeiUtil, "showContextMenu");
__publicField$2(_DDeiUtil, "getSubControlJSON");
__publicField$2(_DDeiUtil, "getLineInitJSON");
__publicField$2(_DDeiUtil, "getModelInitJSON");
__publicField$2(_DDeiUtil, "getBusiData");
__publicField$2(_DDeiUtil, "getEditorText");
__publicField$2(_DDeiUtil, "getStyleValue");
__publicField$2(_DDeiUtil, "getEditorId");
__publicField$2(_DDeiUtil, "invokeCallbackFunc");
__publicField$2(_DDeiUtil, "notifyChange");
__publicField$2(_DDeiUtil, "getEditorInsByDDei");
__publicField$2(_DDeiUtil, "createControl");
__publicField$2(_DDeiUtil, "isBackActive");
__publicField$2(_DDeiUtil, "createRenderViewer", function(model, operate, tempShape, composeRender) {
var _a3;
if ((_a3 = model == null ? void 0 : model.stage) == null ? void 0 : _a3.ddInstance) {
let editor = _DDeiUtil.getEditorInsByDDei(model.stage.ddInstance);
if (editor) {
editor.createRenderViewer(model, operate, tempShape, composeRender);
}
}
});
__publicField$2(_DDeiUtil, "removeRenderViewer", function(model, operate, tempShape, composeRender) {
var _a3;
if ((_a3 = model == null ? void 0 : model.stage) == null ? void 0 : _a3.ddInstance) {
let editor = _DDeiUtil.getEditorInsByDDei(model.stage.ddInstance);
if (editor) {
editor.removeRenderViewer(model, operate, tempShape, composeRender);
}
}
});
__publicField$2(_DDeiUtil, "isModelHidden", function(model) {
if (model.hidden) {
return true;
} else {
let pModel = model.pModel;
while (pModel && pModel.baseModelType != "DDeiLayer") {
if (pModel.hidden) {
return true;
}
pModel = pModel.pModel;
}
}
return false;
});
__publicField$2(_DDeiUtil, "offsetX");
__publicField$2(_DDeiUtil, "offsetY");
__publicField$2(_DDeiUtil, "screenX");
__publicField$2(_DDeiUtil, "screenY");
__publicField$2(_DDeiUtil, "p331t3", Math.pow(1 - 0.333, 3));
__publicField$2(_DDeiUtil, "p331t2", Math.pow(1 - 0.333, 2));
__publicField$2(_DDeiUtil, "p33t2", Math.pow(0.333, 2));
__publicField$2(_DDeiUtil, "p33t3", Math.pow(0.333, 3));
__publicField$2(_DDeiUtil, "p33t21t3", 3 * (1 - 0.333) * _DDeiUtil.p33t2);
__publicField$2(_DDeiUtil, "p331t2t3", 3 * _DDeiUtil.p331t2 * 0.333);
__publicField$2(_DDeiUtil, "p661t3", Math.pow(1 - 0.666, 3));
__publicField$2(_DDeiUtil, "p661t2", Math.pow(1 - 0.666, 2));
__publicField$2(_DDeiUtil, "p66t2", Math.pow(0.666, 2));
__publicField$2(_DDeiUtil, "p66t3", Math.pow(0.666, 3));
__publicField$2(_DDeiUtil, "p661t2t3", 3 * _DDeiUtil.p661t2 * 0.666);
__publicField$2(_DDeiUtil, "p66t21t3", 3 * (1 - 0.666) * _DDeiUtil.p66t2);
__publicField$2(_DDeiUtil, "cacheTextCharSize", /* @__PURE__ */ new Map());
__publicField$2(_DDeiUtil, "PI2", Math.PI * 2);
__publicField$2(_DDeiUtil, "recentlyChooseColors", null);
__publicField$2(_DDeiUtil, "USER_OS", "");
(() => {
let userAgent = navigator.userAgent;
_DDeiUtil.USER_OS = "WIN";
if (/Mac|iPod|iPhone|iPad/.test(userAgent)) {
_DDeiUtil.USER_OS = "MAC";
} else if (/Linux/.test(userAgent)) {
_DDeiUtil.USER_OS = "LINUX";
}
})();
let DDeiUtil = _DDeiUtil;
const DDeiUtil$1 = DDeiUtil;
var __defProp$1 = Object.defineProperty;
var __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __publicField$1 = (obj, key, value) => {
__defNormalProp$1(obj, typeof key !== "symbol" ? key + "" : key, value);
return value;
};
const _DDeiConfig = class _DDeiConfig2 {
/**
* 应用外部配置文件,覆写配置文件内容
* @param config
*/
static applyConfig(config2) {
if (config2) {
for (let i2 in config2) {
if (i2 != "SERI_FIELDS") {
_DDeiConfig2[i2] = config2[i2];
}
}
if (config2.SERI_FIELDS != void 0 && config2.SERI_FIELDS != null) {
for (let i2 in config2.SERI_FIELDS) {
_DDeiConfig2.SERI_FIELDS.set(i2, config2.SERI_FIELDS[i2]);
}
}
}
}
/**
* 获取系统缺省属性
* @param model 模型
*/
static getSysDefaultData(model) {
switch (model.modelType) {
case "DDeiLayer":
return _DDeiConfig2.LAYER;
case "DDeiTable":
return _DDeiConfig2.TABLE;
case "DDeiTableCell":
return _DDeiConfig2.TABLE.CELL;
case "DDeiRectangle":
return _DDeiConfig2.RECTANGLE;
case "DDeiCircle":
return _DDeiConfig2.CIRCLE;
case "DDeiDiamond":
return _DDeiConfig2.DIAMOND;
case "DDeiSelector":
return _DDeiConfig2.SELECTOR;
case "DDeiPolygonContainer":
return _DDeiConfig2.CONTAINER;
case "DDeiStage":
return _DDeiConfig2.STAGE;
default:
return null;
}
}
/**
* 根据配置文件的配置,将模型与渲染器绑定
* @param model 模型
*/
static bindRender(model) {
var _a3;
let clsName = model.modelType + this.RENDER_TYPE + "Render";
if (model.modelType == "DDeiStage") {
model.render = model == null ? void 0 : model.ddInstance.controlViewClasses[clsName].newInstance({ model });
} else {
model.render = (_a3 = model.stage) == null ? void 0 : _a3.ddInstance.controlViewClasses[clsName].newInstance({ model });
}
let modelDefine = DDeiUtil$1.getControlDefine(model);
if (modelDefine == null ? void 0 : modelDefine.viewer) {
model.render.viewer = modelDefine.viewer;
}
}
};
__publicField$1(_DDeiConfig, "STORE_KEY", "DDEI");
__publicField$1(_DDeiConfig, "ROTATE_UNIT", Math.PI / 180);
__publicField$1(_DDeiConfig, "RENDER_TYPE", "Canvas");
__publicField$1(_DDeiConfig, "ALLOW_CLIPBOARD");
__publicField$1(_DDeiConfig, "KEY_DOWN_STATE", /* @__PURE__ */ new Map());
__publicField$1(_DDeiConfig, "KEY_DOWN_INTERVAL", /* @__PURE__ */ new Map());
__publicField$1(_DDeiConfig, "KEY_DOWN_TIMES", /* @__PURE__ */ new Map());
__publicField$1(_DDeiConfig, "SERI_FIELDS", {
"DDei": { "TOJSON": ["stage"], "SKIP": ["bus", "render", "unicode", "editMode"] },
"DDeiStage": { "TOJSON": ["layers", "links"], "SKIP": ["ddInstance", "selectedModels", "render", "unicode", "histroy", "histroyIdx", "sourceLinkCache", "distLinkCache", "tempCursorOPpoint", "tempStartOPpoint", "drawing"] },
"DDeiLayer": { "TOJSON": ["models"], "SKIP": ["ddInstance", "stage", "render", "unicode", "opPoints", "opLine", "dragInPoints", "dragOutPoints", "shadowControls", "layoutManager", "tempDisplay"] },
"DDeiContainer": { "TOJSON": ["models"], "SKIP": ["ddInstance", "__destroyed", "stage", "layer", "pModel", "render", "unicode", "hpv", "loosePVS", "x", "y", "width", "height", "layoutManager", "isShadowControl"] },
"AbstractShape": {
"TOJSON": ["composes", "linkModels"],
"SKIP": ["ddInstance", "depModel", "offsetY", "offsetX", "__destroyed", "stage", "layer", "pModel", "state", "render", "unicode", "loosePVS", "x", "y", "width", "height", "ruleEvals", "sample", "operatePVS", "isShadowControl"],
"SKIP2": ["ddInstance", "stage", "layer", "pModel", "state", "render", "unicode", "loosePVS", "x", "y", "width", "height", "ruleEvals", "sample", "operatePVS", "isShadowControl", "pvs", "opps", "apvs", "textArea", "essBounds", "baseModelType"]
},
"DDeiLine": { "SKIP": ["ddInstance", "__destroyed", "stage", "layer", "pModel", "state", "render", "unicode", "looseCanvas", "loosePVS", "x", "y", "width", "height", "startPoint", "endPoint", "cpv", "clps", "isShadowControl", "updateLooseCanvasSync", "baseModelType"] },
"DDeiTable": { "TOJSON": ["rows"], "SKIP": ["ddInstance", "stage", "layer", "pModel", "render", "unicode", "hpv", "loosePVS", "x", "y", "width", "height", "cols", "selector", "initColNum", "initRowNum", "tempDragCell", "tempDragType", "curCol", "curRow", "specilDrag", "tempUpCel", "dragChanging", "dragType", "dragCell", "isShadowControl"] },
"DDeiTableCell": { "TOJSON": ["models"], "SKIP": ["ddInstance", "stage", "layer", "pModel", "render", "unicode", "hpv", "loosePVS", "x", "y", "width", "height", "layoutManager", "id", "table", "mergedCell", "isShadowControl"] }
});
__publicField$1(_DDeiConfig, "BORDER", {
default: { width: 0, color: null, dash: null, round: 0 },
selected: { width: 1, color: "black", dash: null, round: 0 }
});
__publicField$1(_DDeiConfig, "STAGE", {
//水印
mark: {
font: {
family: "Microsoft YaHei",
color: "grey",
size: "16"
}
}
});
__publicField$1(_DDeiConfig, "SELECTOR", {
//选择器边框
border: {
width: 1,
color: "rgb(1,127,255)",
dash: [10, 5],
round: 0,
selected: { width: 1, color: "rgb(1,127,255)", dash: [10, 5], round: 0 }
},
//操作区域的填充样式,根据选中和未选中状态可以有所变化
OPERATE_ICON: {
weight: 8,
FILL: {
default: "white",
pass: "rgb(198,230,255)"
}
},
//间隔宽度,根据选中单个控件、选中多个控件,间隔宽度可以有所变化
PADDING_WEIGHT: {
default: { single: 0, multiple: 0 },
selected: { single: 0, multiple: 10 }
}
});
__publicField$1(_DDeiConfig, "TABLE", {
//选择器边框
selector: {
border: {
width: 2,
color: "rgb(31,187,125)",
dash: null,
round: 0,
selected: { width: 2, color: "rgb(31,187,125)", dash: null, round: 0 }
},
//间隔宽度,根据选中单个控件、选中多个控件,间隔宽度可以有所变化
PADDING_WEIGHT: {
default: { single: 0, multiple: 0 },
selected: { single: 0, multiple: 0 }
}
},
CELL: {
border: {
top: {
width: 1,
color: "black",
dash: null,
round: 0,
disabled: false
},
right: {
width: 1,
color: "black",
dash: null,
round: 0
},
bottom: {
width: 1,
color: "black",
dash: null,
round: 0,
opacity: 1
},
left: {
width: 1,
color: "black",
dash: null,
round: 0,
opacity: 1
},
selected: {
top: {
width: 1,
color: "black",
dash: null,
round: 0
},
right: {
width: 1,
color: "black",
dash: null,
round: 0
},
bottom: {
width: 1,
color: "black",
dash: null,
round: 0
},
left: {
width: 1,
color: "black",
dash: null,
round: 0
}
}
}
}
});
__publicField$1(_DDeiConfig, "FILL", {
default: { color: null },
selected: { color: "white" }
});
__publicField$1(_DDeiConfig, "FONT", {
default: { family: "Microsoft YaHei", color: "#000000", size: "16" },
selected: { family: "Microsoft YaHei", color: "#000000", size: "16" }
});
__publicField$1(_DDeiConfig, "LAYER", {
//背景的类型,0无背景,1纯色,2图片
type: 0,
//背景色
bgcolor: "grey",
//透明度,0完全透明~1完全不透明
opacity: 0.5
});
__publicField$1(_DDeiConfig, "RECTANGLE", {
// 默认矩形边框
border: {
top: {
width: 1,
color: "black",
dash: null,
round: 0,
disabled: false
},
right: {
width: 1,
color: "black",
dash: null,
round: 0
},
bottom: {
width: 1,
color: "black",
dash: null,
round: 0,
opacity: 1
},
left: {
width: 1,
color: "black",
dash: null,
round: 0,
opacity: 1
},
selected: {
top: {
width: 1,
color: "black",
dash: null,
round: 0
},
right: {
width: 1,
color: "black",
dash: null,
round: 0
},
bottom: {
width: 1,
color: "black",
dash: null,
round: 0
},
left: {
width: 1,
color: "black",
dash: null,
round: 0
}
}
},
// 默认矩形填充
fill: {
color: "red",
opacity: 1,
selected: { color: "white" }
},
// 默认矩形填充
image: {
opacity: 1
},
// 默认矩形字体
font: {
//字体
family: "Microsoft YaHei",
//颜色
color: "white",
//大小
size: 16,
selected: { family: "Microsoft YaHei", color: "#000000", size: 16 }
},
// 默认矩形文本样式
textStyle: {
//水平对齐,1,2,3左中右,默认1
align: 1,
//垂直对齐,1,2,3上中下,默认2
valign: 2,
//自动换行,0/null不换行,1换行,默认0
feed: 1,
//缩小字体填充,0/null不缩小,1缩小,默认0
scale: 1,
//镂空,0/null不镂空,1镂空,默认0
hollow: 0,
selected: {
align: 1,
valign: 2,
feed: 0,
scale: 0,
hollow: 0
}
}
});
__publicField$1(_DDeiConfig, "CIRCLE", {
// 默认矩形边框
border: {
width: 1,
color: "black",
dash: null,
round: 0,
disabled: false,
opacity: 1,
selected: { width: 1, color: "black", dash: null, round: 0, opacity: 1 }
},
// 默认矩形填充
fill: {
color: "white",
opacity: 1,
selected: { color: "white" }
},
// 默认矩形字体
font: {
//字体
family: "Microsoft YaHei",
//颜色
color: "white",
//大小
size: 16,
selected: { family: "Microsoft YaHei", color: "#000000", size: 16 }
},
// 默认矩形文本样式
textStyle: {
//水平对齐,1,2,3左中右,默认1
align: 2,
//垂直对齐,1,2,3上中下,默认2
valign: 2,
//自动换行,0/null不换行,1换行,默认0
feed: 1,
//缩小字体填充,0/null不缩小,1缩小,默认0
scale: 1,
//镂空,0/null不镂空,1镂空,默认0
hollow: 0,
selected: {
align: 2,
valign: 2,
feed: 0,
scale: 0,
hollow: 0
}
}
});
__publicField$1(_DDeiConfig, "DIAMOND", {
border: {
top: {
width: 1,
color: "black",
dash: null,
round: 0,
disabled: false
},
right: {
width: 1,
color: "black",
dash: null,
round: 0
},
bottom: {
width: 1,
color: "black",
dash: null,
round: 0,
opacity: 1
},
left: {
width: 1,
color: "black",
dash: null,
round: 0,
opacity: 1
},
selected: {
top: {
width: 1,
color: "black",
dash: null,
round: 0
},
right: {
width: 1,
color: "black",
dash: null,
round: 0
},
bottom: {
width: 1,
color: "black",
dash: null,
round: 0
},
left: {
width: 1,
color: "black",
dash: null,
round: 0
}
}
},
// 默认矩形填充
fill: {
color: "red",
opacity: 1,
selected: { color: "white" }
},
// 默认矩形字体
font: {
//字体
family: "Microsoft YaHei",
//颜色
color: "white",
//大小
size: 16,
selected: { family: "Microsoft YaHei", color: "#000000", size: 16 }
},
// 默认矩形文本样式
textStyle: {
//水平对齐,1,2,3左中右,默认1
align: 1,
//垂直对齐,1,2,3上中下,默认2
valign: 2,
//自动换行,0/null不换行,1换行,默认0
feed: 1,
//缩小字体填充,0/null不缩小,1缩小,默认0
scale: 1,
//镂空,0/null不镂空,1镂空,默认0
hollow: 0,
selected: {
align: 1,
valign: 2,
feed: 0,
scale: 0,
hollow: 0
}
}
});
__publicField$1(_DDeiConfig, "CONTAINER", {
// 默认矩形边框
border: {
top: {
width: 1,
color: "black",
dash: null,
round: 0
},
right: {
width: 1,
color: "black",
dash: null,
round: 0
},
bottom: {
width: 1,
color: "black",
dash: null,
round: 0
},
left: {
width: 1,
color: "black",
dash: null,
round: 0
},
selected: {
top: {
width: 1,
color: "black",
dash: null,
round: 0
},
right: {
width: 1,
color: "black",
dash: null,
round: 0
},
bottom: {
width: 1,
color: "black",
dash: null,
round: 0
},
left: {
width: 1,
color: "black",
dash: null,
round: 0
}
}
},
// 默认填充
fill: {
color: "#787878",
opacity: 0,
selected: { color: "#23AE78", opacity: 0 }
}
});
__publicField$1(_DDeiConfig, "RULER", {
"mm": { size: 10, parts: [2, 5], title: "mm" },
"cm": { size: 1, parts: [2, 5], title: "cm" },
"m": { size: 0.05, parts: [2, 5], title: "m" },
"inch": { size: 1, parts: [8], title: "in" },
"px": { size: 50, parts: [5, 10], title: "px" }
});
__publicField$1(_DDeiConfig, "PAPER", {
"自定义": { width: 210, height: 297, unit: "mm", desc: "可以自由设置宽高" },
"Letter": { width: 216, height: 279, unit: "mm" },
"Legal": { width: 216, height: 356, unit: "mm" },
"A0": { width: 841, height: 1189, unit: "mm" },
"A1": { width: 594, height: 841, unit: "mm" },
"A2": { width: 420, height: 594, unit: "mm" },
"A3": { width: 297, height: 420, unit: "mm" },
"A4": { width: 210, height: 297, unit: "mm", desc: "常用打印纸" },
"A5": { width: 148, height: 210, unit: "mm" },
"A6": { width: 105, height: 148, unit: "mm" },
"A7": { width: 74, height: 105, unit: "mm" },
"A8": { width: 52, height: 74, unit: "mm" },
"A9": { width: 37, height: 52, unit: "mm" },
"A10": { width: 26, height: 37, unit: "mm" },
"B0": { width: 1e3, height: 1414, unit: "mm" },
"B1": { width: 700, height: 1e3, unit: "mm" },
"B2": { width: 500, height: 707, unit: "mm" },
"B3": { width: 353, height: 500, unit: "mm" },
"B4": { width: 250, height: 353, unit: "mm" },
"B5": { width: 176, height: 250, unit: "mm" },
"B6": { width: 125, height: 176, unit: "mm" },
"B7": { width: 88, height: 125, unit: "mm" },
"B8": { width: 62, height: 88, unit: "mm" },
"B9": { width: 42, height: 62, unit: "mm" },
"B10": { width: 31, height: 44, unit: "mm" },
"一寸照片": { width: 2.5, height: 3.6, unit: "cm" },
"二寸照片": { width: 3.5, height: 5.3, unit: "cm" },
"三寸照片": { width: 5.5, height: 8.4, unit: "cm" },
"五寸照片": { width: 3.5, height: 5, unit: "cm" },
"六寸照片": { width: 4, height: 6, unit: "cm" },
"七寸照片": { width: 5, height: 7, unit: "cm" },
"八寸照片": { width: 6, height: 8, unit: "cm" },
"十寸照片": { width: 8, height: 10, unit: "cm" },
"十二寸照片": { width: 10, height: 12, unit: "cm" },
"十四寸照片": { width: 12, height: 14, unit: "cm" },
"十六寸照片": { width: 12, height: 16, unit: "cm" },
"十八寸照片": { width: 12, height: 18, unit: "cm" },
"名片-横版": { width: 90, height: 55, unit: "mm" },
"名片-横版-欧式": { width: 85, height: 54, unit: "mm" },
"名片-竖版": { width: 54, height: 85, unit: "mm" },
"名片-竖版-美式": { width: 50, height: 90, unit: "mm" },
"名片-方版-1": { width: 90, height: 90, unit: "mm" },
"名片-方版-2": { width: 90, height: 95, unit: "mm" },
"海报-1": { width: 420, height: 570, unit: "mm" },
"海报-2": { width: 500, height: 700, unit: "mm" },
"海报-3": { width: 570, height: 840, unit: "mm" },
"海报-4": { width: 600, height: 900, unit: "mm" },
"二折页": { width: 285, height: 210, unit: "mm" },
"二折页-1": { width: 140, height: 105, unit: "mm" },
"二折页-2": { width: 210, height: 95, unit: "mm" },
"二折页-3": { width: 210, height: 140, unit: "mm" },
"二折页-4": { width: 285, height: 140, unit: "mm" },
"全开": { width: 889, height: 1194, paddingLeft: 102, paddingTop: 102, unit: "mm" },
"对开": { width: 570, height: 840, paddingLeft: 50, paddingTop: 100, unit: "mm" },
"4开": { width: 420, height: 570, paddingLeft: 50, paddingTop: 50, unit: "mm" },
"8开": { width: 285, height: 420, paddingLeft: 25, paddingTop: 50, unit: "mm" },
"16开": { width: 210, height: 285, paddingLeft: 25, paddingTop: 25, unit: "mm" },
"32开": { width: 142, height: 210, paddingLeft: 12, paddingTop: 25, unit: "mm" },
"64开": { width: 110, height: 142, paddingLeft: 18, paddingTop: 12, unit: "mm" }
});
__publicField$1(_DDeiConfig, "SPACE_WIDTH_MAP", {});
(() => {
_DDeiConfig.PAPER_DATASOURCE = [{ code: "无", name: "无", desc: "不显示纸张" }];
for (let i2 in _DDeiConfig.PAPER) {
let data = _DDeiConfig.PAPER[i2];
data.desc = data.desc;
if (!data.desc && data.width && data.height) {
data.desc = data.width + " x " + data.height + data.unit;
}
data.code = i2;
data.name = i2;
_DDeiConfig.PAPER_DATASOURCE.push(data);
}
})();
let DDeiConfig = _DDeiConfig;
const DDeiConfig$1 = DDeiConfig;
class DDeiAbstractShape {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "id");
__publicField2(this, "width");
__publicField2(this, "height");
__publicField2(this, "modelCode");
__publicField2(this, "modelType", "AbstractShape");
__publicField2(this, "baseModelType", "AbstractShape");
__publicField2(this, "state", DDeiEnumControlState.DEFAULT);
__publicField2(this, "layer");
__publicField2(this, "pModel", null);
__publicField2(this, "stage");
__publicField2(this, "zIndex");
__publicField2(this, "cIndex");
__publicField2(this, "rotate");
__publicField2(this, "hidden", null);
__publicField2(this, "__destroyed", null);
__publicField2(this, "cpv");
__publicField2(this, "hpv");
__publicField2(this, "pvs");
__publicField2(this, "exPvs");
__publicField2(this, "ovs");
__publicField2(this, "unicode");
__publicField2(this, "fmt");
__publicField2(this, "poly");
__publicField2(this, "linkModels");
__publicField2(this, "depModel", null);
__publicField2(this, "mirrorX", false);
__publicField2(this, "mirrorY", false);
__publicField2(this, "composes");
__publicField2(this, "sptStyle");
for (let i2 in props) {
this[i2] = props[i2];
}
this.id = props.id;
this.width = props.width ? props.width : 0;
this.height = props.height ? props.height : 0;
this.zIndex = props.zIndex ? props.zIndex : null;
this.rotate = props.rotate ? props.rotate : null;
this.modelCode = props.modelCode ? props.modelCode : null;
this.unicode = props.unicode ? props.unicode : DDeiUtil$1.getUniqueCode();
this.fmt = props.fmt;
this.sptStyle = props.sptStyle ? props.sptStyle : {};
this.poly = props.poly;
this.composes = props.composes;
this.cIndex = props.cIndex ? props.cIndex : null;
this.ruleEvals = [];
this.initCPV = props.initCPV ? props.initCPV : null;
if (props.mirrorX) {
this.mirrorX = props.mirrorX;
}
if (props.mirrorY) {
this.mirrorY = props.mirrorY;
}
if (props.cpv) {
this.cpv = new Vector3(props.cpv.x, props.cpv.y, props.cpv.z || props.cpv.z == 0 ? props.cpv.z : 1);
}
if (props.pvs) {
this.pvs = [];
props.pvs.forEach((pvd) => {
let pv = new Vector3();
for (let i2 in pvd) {
pv[i2] = pvd[i2];
}
pv.z = pvd.z || pvd.z === 0 ? pvd.z : 1;
this.pvs.push(pv);
});
}
this.hpv = [];
if (props.hpv) {
props.hpv.forEach((pv) => {
this.hpv.push(new Vector3(pv.x, pv.y, pv.z || pv.z == 0 ? pv.z : 1));
});
}
this.ovs = [];
if (props.ovs) {
props.ovs.forEach((pvd) => {
let pv = new Vector3(pvd.x, pvd.y, pvd.z || pvd.z == 0 ? pvd.z : 1);
if (pvd.index || pvd.index == 0) {
pv.index = pvd.index;
}
if (pvd.rate || pvd.rate == 0) {
pv.rate = pvd.rate;
}
if (pvd.sita || pvd.sita == 0) {
pv.sita = pvd.sita;
}
if (pvd.ovi) {
let ovi = new Vector3(pvd.ovi.x, pvd.ovi.y, pvd.ovi.z || pvd.ovi.z == 0 ? pvd.ovi.z : 1);
pv.ovi = ovi;
}
this.ovs.push(pv);
});
}
if (props.bpv) {
this.bpv = new Vector3(props.bpv.x, props.bpv.y, props.bpv.z || props.bpv.z == 0 ? props.bpv.z : 1);
}
this.exPvs = {};
if (props.exPvs) {
for (let i2 in props.exPvs) {
let pvd = props.exPvs[i2];
let pv = new Vector3(pvd.x, pvd.y, pvd.z || pvd.z == 0 ? pvd.z : 1);
pv.id = pvd.id;
if (pvd.index || pvd.index == 0) {
pv.index = pvd.index;
}
if (pvd.rate || pvd.rate == 0) {
pv.rate = pvd.rate;
}
if (pvd.sita || pvd.sita == 0) {
pv.sita = pvd.sita;
}
this.exPvs[pvd.id] = pv;
}
}
this.linkModels = props.linkModels ? props.linkModels : /* @__PURE__ */ new Map();
}
// ============================ 方法 ============================
/**
* 初始化向量,基于width和height构建向量,默认中心点在0,0的位置
*/
initPVS() {
var _a3, _b2, _c2, _d2, _e2;
if (!this.cpv) {
this.cpv = this.initCPV ? new Vector3(this.initCPV.x, this.initCPV.y, 1) : new Vector3(0, 0, 1);
delete this.initCPV;
}
if (!(((_a3 = this.ovs) == null ? void 0 : _a3.length) > 0)) {
const defineOvs = (_c2 = (_b2 = DDeiUtil$1.getControlDefine(this)) == null ? void 0 : _b2.define) == null ? void 0 : _c2.ovs;
if ((defineOvs == null ? void 0 : defineOvs.length) > 0) {
const stageRatio2 = 1;
const scaleX2 = this.width / 100;
const scaleY2 = this.height / 100;
this.ovs = defineOvs.map((ovd) => {
if (ovd.constraint.type == 3) {
const rad = -ovd.isita * DDeiConfig$1.ROTATE_UNIT;
const x2 = ovd.constraint.r * Math.cos(rad);
const y2 = ovd.constraint.r * Math.sin(rad);
const ov = new Vector3(x2 * scaleX2 * stageRatio2, y2 * scaleY2 * stageRatio2, ovd.z || ovd.z == 0 ? ovd.z : 1);
ov.ovi = new Vector3(0, 0, ovd.z || ovd.z == 0 ? ovd.z : 1);
return ov;
} else {
const ov = new Vector3(ovd.x * scaleX2 * stageRatio2, ovd.y * scaleY2 * stageRatio2, ovd.z || ovd.z == 0 ? ovd.z : 1);
ov.ovi = new Vector3(ovd.ix * scaleX2 * stageRatio2, ovd.iy * scaleY2 * stageRatio2, ovd.iz || ovd.iz == 0 ? ovd.iz : 1);
return ov;
}
});
}
}
if (this.poly == 2) {
if (!(((_d2 = this.hpv) == null ? void 0 : _d2.length) > 0)) {
this.hpv = [new Vector3(0, 0, 1), new Vector3(100, 0, 1)];
}
if (!this.bpv) {
this.bpv = new Vector3(this.cpv.x + this.width, this.cpv.y + this.height, 1);
}
this.executeSample();
} else {
if (!this.pvs || this.pvs.length == 0) {
const halfWidth = this.width / 2;
const halfHeight = this.height / 2;
this.pvs = [
new Vector3(-halfWidth, -halfHeight, 1),
new Vector3(halfWidth, -halfHeight, 1),
new Vector3(halfWidth, halfHeight, 1),
new Vector3(-halfWidth, halfHeight, 1)
];
}
this.initHPV();
}
this.calRotate();
this.calLoosePVS();
this.refreshLinkModels();
(_e2 = this.composes) == null ? void 0 : _e2.forEach((compose) => compose.initPVS());
if (!this.isShadowControl) {
this.updateExPvs();
}
}
/**
* 根据坐标获取特殊操作点
* @param x
* @param y
* @returns 操作点
*/
getOvPointByPos(x2 = 0, y2 = 0) {
var _a3, _b2;
if (x2 && y2 && ((_a3 = this.ovs) == null ? void 0 : _a3.length) > 0) {
for (let i2 = 0; i2 < ((_b2 = this.ovs) == null ? void 0 : _b2.length); i2++) {
let point2 = this.ovs[i2];
if (Math.abs(x2 - point2.x) <= 8 && Math.abs(y2 - point2.y) <= 8) {
return point2;
}
}
}
return null;
}
/**
* 执行采样计算pvs
*/
executeSample() {
var _a, _b, _c, _d, _e;
let defineSample = (_b = (_a = DDeiUtil$1.getControlDefine(this)) == null ? void 0 : _a.define) == null ? void 0 : _b.sample;
let stageRatio = 1;
if (((_c = defineSample == null ? void 0 : defineSample.rules) == null ? void 0 : _c.length) > 0) {
let originOVS = [];
if (((_d = this.ovs) == null ? void 0 : _d.length) > 0) {
originOVS = cloneDeep(this.ovs);
let bpv2 = DDeiUtil$1.pointsToZero([this.bpv], this.cpv, this.rotate)[0];
let scaleX2 = Math.abs(DDeiUtil$1.preciseDiv(bpv2.x, 100));
let scaleY2 = Math.abs(DDeiUtil$1.preciseDiv(bpv2.y, 100));
let m12 = new Matrix3();
let move1Matrix = new Matrix3(
1,
0,
-this.cpv.x,
0,
1,
-this.cpv.y,
0,
0,
1
);
m12.premultiply(move1Matrix);
let rotate2 = 0;
if (this.rotate) {
rotate2 = this.rotate;
let angle2 = DDeiUtil$1.preciseTimes(rotate2, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let scaleMatrix2 = new Matrix3(
1 / scaleX2,
0,
0,
0,
1 / scaleY2,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
let move2Matrix = new Matrix3(
1,
0,
this.cpv.x,
0,
1,
this.cpv.y,
0,
0,
1
);
m12.premultiply(move2Matrix);
originOVS.forEach((ov) => {
ov.sita = parseFloat(DDeiUtil$1.getLineAngle(this.cpv.x, this.cpv.y, ov.x, ov.y).toFixed(2)) - rotate2;
ov.applyMatrix3(m12);
ov.ovi.applyMatrix3(m12);
});
}
let rotate = this.rotate;
if (!rotate) {
rotate = 0;
}
let bpv = DDeiUtil$1.pointsToZero([this.bpv], this.cpv, rotate)[0];
let scaleX = Math.abs(bpv.x / 100);
let scaleY = Math.abs(bpv.y / 100);
this.scale = { x: scaleX, y: scaleY, stageRatio: 1 };
let sampliesResult = [];
let loop = defineSample.loop;
let pn = 360 / loop;
let angle = defineSample.angle;
for (let i = 0; i < loop; i++) {
defineSample.sita = angle + i * pn;
defineSample.rad = defineSample.sita * DDeiConfig$1.ROTATE_UNIT;
defineSample.cos = parseFloat(Math.cos(defineSample.rad).toFixed(4));
defineSample.sin = parseFloat(Math.sin(defineSample.rad).toFixed(4));
defineSample.x = defineSample.r * defineSample.cos;
defineSample.y = defineSample.r * defineSample.sin;
for (let j = 0; j < ((_e = defineSample.rules) == null ? void 0 : _e.length); j++) {
if (this.ruleEvals && !this.ruleEvals[j]) {
eval("this.ruleEvals[j] = function" + defineSample.rules[j]);
}
let spFn = this.ruleEvals[j];
if (!sampliesResult[j]) {
sampliesResult[j] = [];
}
let spResult = sampliesResult[j];
spFn(i, defineSample, spResult, this, originOVS);
}
}
delete this.scale;
let pvs = [];
let apvs = [];
let textArea = [];
let operatePVS = [];
let opps = [];
for (let i2 = 0; i2 < sampliesResult.length; i2++) {
if (sampliesResult[i2].length > 0) {
sampliesResult[i2].forEach((pvd) => {
let pv = new Vector3();
pv.group = i2;
if (pvd.dx || pvd.dx == 0 || pvd.dy || pvd.dy == 0) {
if (!pvd.dx) {
pvd.dx = 0;
}
if (!pvd.dy) {
pvd.dy = 0;
}
let dp = DDeiUtil$1.getRotatedPoint({ x: pvd.dx * scaleX / stageRatio, y: pvd.dy * scaleY / stageRatio, z: 1 }, rotate);
pvd.dx = dp.x;
pvd.dy = dp.y;
}
for (let i3 in pvd) {
pv[i3] = pvd[i3];
}
pv.z = pvd.z || pvd.z === 0 ? pvd.z : 1;
pvs.push(pv);
if (pvd.select) {
operatePVS.push(pv);
}
if (pvd.oppoint) {
opps.push(pv);
}
if (pvd.align) {
apvs.push(pv);
}
if (pvd.text) {
textArea.push(pv);
}
});
}
}
let m1 = new Matrix3();
let scaleMatrix = new Matrix3(
scaleX,
0,
0,
0,
scaleY,
0,
0,
0,
1
);
m1.premultiply(scaleMatrix);
if (this.rotate) {
let angle2 = -DDeiUtil$1.preciseTimes(this.rotate, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m1.premultiply(rotateMatrix);
}
let moveMatrix = new Matrix3(
1,
0,
this.cpv.x,
0,
1,
this.cpv.y,
0,
0,
1
);
m1.premultiply(moveMatrix);
pvs.forEach((pv) => {
pv.applyMatrix3(m1);
});
this.pvs = pvs;
this.operatePVS = operatePVS;
this.textArea = textArea;
this.opps = opps;
this.apvs = apvs;
}
}
getOperatePVS(compose = false) {
var _a3;
let pvs2 = this.operatePVS ? this.operatePVS : this.pvs;
let returnPVS = [];
if (pvs2) {
pvs2.forEach((pv) => {
returnPVS.push(pv);
});
}
if (compose && ((_a3 = this.composes) == null ? void 0 : _a3.length) > 0) {
this.composes.forEach((comp) => {
let ps = comp.getOperatePVS(compose);
if (ps) {
ps.forEach((pv) => {
returnPVS.push(pv);
});
}
});
}
return returnPVS;
}
getAPVS() {
var _a3;
let arr = [this.cpv];
if (((_a3 = this.apvs) == null ? void 0 : _a3.length) > 0) {
arr = arr.concat(this.apvs);
}
return arr;
}
/**
* 刷新链接模型
*/
refreshLinkModels() {
var _a3;
if ((_a3 = this.linkModels) == null ? void 0 : _a3.has) {
this.linkModels.forEach((lm) => {
if (lm.dm) {
let oldCPVX = lm.dm.cpv.x;
let oldCPVY = lm.dm.cpv.y;
let point2 = null;
if (this.baseModelType == "DDeiLine") {
if (lm.type == 1) {
point2 = this.startPoint;
} else if (lm.type == 2) {
point2 = this.endPoint;
} else if (lm.type == 3) {
let pi = Math.floor(this.pvs.length / 2);
if (this.pvs.length % 2 == 1) {
point2 = this.pvs[pi];
} else {
point2 = {
x: (this.pvs[pi - 1].x + this.pvs[pi].x) / 2,
y: (this.pvs[pi - 1].y + this.pvs[pi].y) / 2
};
}
}
} else {
if (lm.type == 5) {
point2 = this.cpv;
} else {
let essBounds = this.essBounds;
let dmEssBounds = lm.dm.essBounds;
if (lm.type == 6) {
point2 = {
x: this.cpv.x,
y: essBounds.y - dmEssBounds.height / 2
};
} else if (lm.type == 7) {
point2 = {
x: essBounds.x1 + dmEssBounds.width / 2,
y: this.cpv.y
};
} else if (lm.type == 8) {
point2 = {
x: this.cpv.x,
y: essBounds.y1 + dmEssBounds.height / 2
};
} else if (lm.type == 9) {
point2 = {
x: essBounds.x - dmEssBounds.width / 2,
y: this.cpv.y
};
}
}
}
let newCPVX = point2.x + lm.dx;
let newCPVY = point2.y + lm.dy;
let moveMatrix2 = new Matrix3(
1,
0,
newCPVX - oldCPVX,
0,
1,
newCPVY - oldCPVY,
0,
0,
1
);
lm.dm.transVectors(moveMatrix2);
lm.dm.updateLinkModels();
}
});
}
}
/**
* 删除本图形的依附链接图形
* @param dmid 依附图形id
*/
removeLinkModel(dmid, destroy = true, notify = true) {
var _a3;
if ((_a3 = this.linkModels) == null ? void 0 : _a3.has) {
let link2 = this.linkModels.get(dmid);
if (link2) {
this.linkModels.delete(dmid);
this.pModel.removeModel(link2.dm, destroy, notify);
}
}
}
/**
* 初始化链接模型
*/
initLinkModels() {
let linkModels = /* @__PURE__ */ new Map();
for (let key in this.linkModels) {
let item = this.linkModels[key];
if (item == null ? void 0 : item.dmid) {
let dm = this.stage.getModelById(item.dmid);
item.dm = dm;
item.depModel = this;
dm.depModel = this;
let lm = new DDeiModelLink(item);
linkModels.set(key, lm);
}
}
this.linkModels = linkModels;
}
/**
* 同步向量
* @param source 源模型
* @param cloneVP 是否克隆向量,默认false
*/
syncVectors(source, clonePV = false) {
var _a3, _b2, _c2, _d2;
if (this.poly == 2) {
if (clonePV) {
this.cpv = cloneDeep(source.cpv);
this.exPvs = cloneDeep(source.exPvs);
this.bpv = cloneDeep(source.bpv);
this.ovs = cloneDeep(source.ovs);
} else {
this.cpv = source.cpv;
this.exPvs = source.exPvs;
this.bpv = source.bpv;
this.ovs = source.ovs;
}
this.executeSample();
} else {
if (clonePV) {
this.pvs = cloneDeep(source.pvs);
this.cpv = cloneDeep(source.cpv);
this.exPvs = cloneDeep(source.exPvs);
this.ovs = cloneDeep(source.ovs);
} else {
this.pvs = source.pvs;
this.cpv = source.cpv;
this.exPvs = source.exPvs;
this.ovs = source.ovs;
}
}
this.initHPV();
this.calRotate();
this.calLoosePVS();
for (let i2 = 0; i2 < ((_a3 = source.composes) == null ? void 0 : _a3.length); i2++) {
let scop = source.composes[i2];
let tcop = this.composes[i2];
tcop.syncVectors(scop, clonePV);
}
(_c2 = (_b2 = this.getTopContainer()) == null ? void 0 : _b2.render) == null ? void 0 : _c2.enableRefreshShape();
(_d2 = this.render) == null ? void 0 : _d2.enableRefreshShape();
}
/**
* 变换向量
*/
transVectors(matrix2, params) {
var _a3, _b2, _c2, _d2;
this.cpv.applyMatrix3(matrix2);
if (this.poly == 2) {
if (!(params == null ? void 0 : params.skipSample)) {
if (!(params == null ? void 0 : params.ignoreHPV)) {
this.hpv.forEach((pv) => {
pv.applyMatrix3(matrix2);
});
}
for (let i2 in this.exPvs) {
let pv = this.exPvs[i2];
pv.applyMatrix3(matrix2);
}
if (!(params == null ? void 0 : params.ignoreBPV)) {
this.bpv.applyMatrix3(matrix2);
}
if (!(params == null ? void 0 : params.ignoreOVS)) {
(_a3 = this.ovs) == null ? void 0 : _a3.forEach((pv) => {
pv.applyMatrix3(matrix2);
if (pv.ovi) {
pv.ovi.applyMatrix3(matrix2);
}
});
}
this.initHPV();
this.calRotate();
this.executeSample();
this.calLoosePVS();
} else {
if (!(params == null ? void 0 : params.ignoreHPV)) {
this.hpv.forEach((pv) => {
pv.applyMatrix3(matrix2);
});
}
for (let i2 in this.exPvs) {
let pv = this.exPvs[i2];
pv.applyMatrix3(matrix2);
}
this.pvs.forEach((pv) => {
pv.applyMatrix3(matrix2);
});
if (!(params == null ? void 0 : params.ignoreBPV)) {
this.bpv.applyMatrix3(matrix2);
}
if (!(params == null ? void 0 : params.ignoreOVS)) {
(_b2 = this.ovs) == null ? void 0 : _b2.forEach((pv) => {
pv.applyMatrix3(matrix2);
if (pv.ovi) {
pv.ovi.applyMatrix3(matrix2);
}
});
}
}
} else {
this.pvs.forEach((pv) => {
pv.applyMatrix3(matrix2);
});
for (let i2 in this.exPvs) {
let pv = this.exPvs[i2];
pv.applyMatrix3(matrix2);
}
(_c2 = this.ovs) == null ? void 0 : _c2.forEach((pv) => {
pv.applyMatrix3(matrix2);
if (pv.ovi) {
pv.ovi.applyMatrix3(matrix2);
}
});
this.initHPV();
this.calRotate();
this.calLoosePVS();
}
if (!(params == null ? void 0 : params.ignoreComposes)) {
(_d2 = this.composes) == null ? void 0 : _d2.forEach((compose) => {
compose.transVectors(matrix2);
});
}
}
/**
* 设置特殊文本样式
* @param sIdx 开始文本坐标
* @param eIdx 结束文本坐标
*/
setSptStyle(sIdx, eIdx, paths, value, emptyDelete = true) {
var _a3, _b2;
let attrPaths = [];
if (typeof paths == "string") {
attrPaths = paths.split(",");
} else {
attrPaths = paths;
}
if ((attrPaths == null ? void 0 : attrPaths.length) > 0 && sIdx > -1 && eIdx > -1 && sIdx <= eIdx) {
for (let k = sIdx; k < eIdx; k++) {
for (let i2 = 0; i2 < attrPaths.length; i2++) {
if ((value === null || value === void 0 || isNumber(value) && isNaN(value)) && emptyDelete) {
DDeiUtil$1.deletePropertyByPath(this.sptStyle, k + "." + attrPaths[i2]);
if (((_a3 = this.sptStyle[k]) == null ? void 0 : _a3.textStyle) && JSON.stringify(this.sptStyle[k].textStyle) == "{}") {
delete this.sptStyle[k].textStyle;
}
if (((_b2 = this.sptStyle[k]) == null ? void 0 : _b2.font) && JSON.stringify(this.sptStyle[k].font) == "{}") {
delete this.sptStyle[k].font;
}
if (this.sptStyle[k] && JSON.stringify(this.sptStyle[k]) == "{}") {
delete this.sptStyle[k];
}
} else {
DDeiUtil$1.setAttrValueByPath(this, ["sptStyle." + k + "." + attrPaths[i2]], value);
}
}
}
}
}
/**
* 获取特殊文本样式,返回同样的样式
* @param sIdx 开始文本坐标
* @param eIdx 结束文本坐标
*/
getSptStyle(sIdx, eIdx, paths) {
let attrPaths = [];
if (typeof paths == "string") {
attrPaths = paths.split(",");
} else {
attrPaths = paths;
}
if ((attrPaths == null ? void 0 : attrPaths.length) > 0 && sIdx > -1 && eIdx > -1 && sIdx <= eIdx) {
let first = true;
let firstValue = void 0;
for (; sIdx < eIdx; sIdx++) {
for (let i2 = 0; i2 < attrPaths.length; i2++) {
let v = DDeiUtil$1.getDataByPathList(this, "sptStyle." + sIdx + "." + attrPaths[i2]);
if (first) {
firstValue = v == null || v == void 0 ? void 0 : v;
first = false;
} else if (v != void 0 && firstValue != v) {
return void 0;
}
}
}
return firstValue;
}
return void 0;
}
/**
* 获取特殊文本样式,返回所有的样式
* @param sIdx 开始文本坐标
* @param eIdx 结束文本坐标
*/
getSptAllStyles(sIdx, eIdx) {
let returnArray = [];
if (sIdx > -1 && eIdx > -1 && sIdx <= eIdx) {
for (; sIdx < eIdx; sIdx++) {
let v = DDeiUtil$1.getDataByPathList(this, "sptStyle." + sIdx);
returnArray.push(v);
}
}
return returnArray;
}
/**
* 清空特殊文本样式
*/
clearSptStyle() {
this.sptStyle = {};
}
/**
* 设置当前最新的hpv
*/
initHPV() {
this.hpv[0] = clone(this.pvs[0]);
this.hpv[1] = clone(this.pvs[1]);
}
/**
* 基于当前向量计算宽松判定向量
*/
calLoosePVS() {
var _a3;
this.loosePVS = ((_a3 = this.operatePVS) == null ? void 0 : _a3.length) > 2 ? cloneDeep(this.operatePVS) : cloneDeep(this.pvs);
let move1Matrix = new Matrix3(
1,
0,
-this.cpv.x,
0,
1,
-this.cpv.y,
0,
0,
1
);
this.loosePVS.forEach((fpv) => {
fpv.applyMatrix3(move1Matrix);
});
if (this.rotate && this.rotate != 0) {
let angle2 = DDeiUtil$1.preciseTimes(this.rotate, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
this.loosePVS.forEach((fpv) => {
fpv.applyMatrix3(rotateMatrix);
});
}
let outRect = DDeiAbstractShape.pvsToOutRect(this.loosePVS);
if (this.loosePVS.length < 4) {
this.loosePVS = DDeiAbstractShape.outRectToPV(outRect);
}
this.x = outRect.x;
this.y = outRect.y;
this.width = outRect.width;
this.height = outRect.height;
this.essBounds = outRect;
let m12 = new Matrix3();
let scX = 1, scY = 1;
if (this.width <= 30) {
scX = 1 + 10 / this.width;
} else {
scX = 1 + Math.min(0.1, 20 / this.width);
}
if (this.height <= 30) {
scY = 1 + 10 / this.height;
} else {
scY = 1 + Math.min(0.1, 20 / this.height);
}
let scaleMatrix2 = new Matrix3(
scX,
0,
0,
0,
scY,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
if (this.rotate && this.rotate != 0) {
let angle2 = -DDeiUtil$1.preciseTimes(this.rotate, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let move2Matrix = new Matrix3(
1,
0,
this.cpv.x,
0,
1,
this.cpv.y,
0,
0,
1
);
m12.premultiply(move2Matrix);
this.loosePVS.forEach((fpv) => {
fpv.applyMatrix3(m12);
});
this.x += this.cpv.x;
this.y += this.cpv.y;
this.essBounds.x += this.cpv.x;
this.essBounds.y += this.cpv.y;
this.essBounds.x1 += this.cpv.x;
this.essBounds.y1 += this.cpv.y;
}
/**
* 设置旋转角度
*/
setRotate(rotate2 = 0) {
if (this.rotate != rotate2) {
let m12 = new Matrix3();
let toZeroMatrix = new Matrix3(
1,
0,
-this.cpv.x,
0,
1,
-this.cpv.y,
0,
0,
1
);
m12.premultiply(toZeroMatrix);
if (this.rotate) {
let angle2 = DDeiUtil$1.preciseTimes(this.rotate, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
if (rotate2) {
let angle2 = -DDeiUtil$1.preciseTimes(rotate2, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let restoreMatrix = new Matrix3(
1,
0,
this.cpv.x,
0,
1,
this.cpv.y,
0,
0,
1
);
m12.premultiply(restoreMatrix);
this.transVectors(m12);
this.rotate = rotate2;
}
}
/**
* 基于当前大小缩放
*/
scale(scaleX2 = 1, scaleY2 = 1) {
if (scaleX2 != 1 || scaleY2 != 1) {
let m12 = new Matrix3();
let move1Matrix = new Matrix3(
1,
0,
-this.cpv.x,
0,
1,
-this.cpv.y,
0,
0,
1
);
m12.premultiply(move1Matrix);
let scaleMatrix2 = new Matrix3(
scaleX2,
0,
0,
0,
scaleY2,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
let move2Matrix = new Matrix3(
1,
0,
this.cpv.x,
0,
1,
this.cpv.y,
0,
0,
1
);
m12.premultiply(move2Matrix);
this.transVectors(m12);
}
}
/**
* 计算旋转角度,基于隐藏点与坐标系的夹角
*/
calRotate() {
let lineV = new Vector3(this.hpv[1].x, this.hpv[1].y, 1);
let toZeroMatrix = new Matrix3(
1,
0,
-this.hpv[0].x,
0,
1,
-this.hpv[0].y,
0,
0,
1
);
lineV.applyMatrix3(toZeroMatrix);
let angle2 = (new Vector3(1, 0, 0).angleTo(new Vector3(lineV.x, lineV.y, 0)) * 180 / Math.PI).toFixed(4);
if (lineV.x >= 0 && lineV.y >= 0)
;
else if (lineV.x <= 0 && lineV.y >= 0)
;
else if (lineV.x <= 0 && lineV.y <= 0) {
angle2 = -angle2;
} else if (lineV.x >= 0 && lineV.y <= 0) {
angle2 = -angle2;
}
this.rotate = parseFloat(angle2);
}
/**
* 设置当前图片base64
* @param base64
*/
setImgBase64(base64) {
this.imgBase64 = base64;
if (this.render) {
this.render.imgObj = null;
this.render.initImage();
}
}
notifyChange() {
var _a3, _b2;
(_a3 = this.render) == null ? void 0 : _a3.clearCachedValue();
DDeiUtil$1.notifyChange((_b2 = this.stage) == null ? void 0 : _b2.ddInstance);
}
/**
* 更新关联图形
*/
updateLinkModels(ignoreModelIds) {
let links = this.stage.getSourceModelLinks(this.id);
let removeLinks = [];
links == null ? void 0 : links.forEach((link2) => {
var _a3, _b2, _c2;
if (!link2.disabled && (!ignoreModelIds || (ignoreModelIds == null ? void 0 : ignoreModelIds.indexOf((_a3 = link2.dm) == null ? void 0 : _a3.id)) == -1)) {
let dpv = link2.getDistPV();
if (dpv) {
let spv = link2.getSourcePV();
if (spv) {
dpv.x = spv.x;
dpv.y = spv.y;
dpv.z = spv.z;
link2.dm.refreshLinePoints();
link2.dm.updateOVS();
let pvs2 = link2.dm.pvs;
link2.dm.setLineType1PointPosition(0, pvs2[0].x, pvs2[0].y);
if (((_b2 = link2.dm.pModel) == null ? void 0 : _b2.modelType) != "DDeiLayer") {
(_c2 = link2.dm.pModel) == null ? void 0 : _c2.changeParentsBounds();
}
} else {
removeLinks.push(link2);
}
}
}
});
if (removeLinks.length > 0) {
this.stage.removeLink(removeLinks);
}
}
/**
* 单独修改向量导致两点关系发生变化后同步调整exPvs点的位置
*/
updateExPvs() {
for (let i2 in this.exPvs) {
let ov = this.exPvs[i2];
let x2, y2;
let pathPvs = this.opps;
let st, en;
let op2Paths = [];
for (let qi = 0; qi < pathPvs.length; qi++) {
let opp = pathPvs[qi];
if (opp.oppoint == 2) {
op2Paths.push(opp);
}
}
if (op2Paths.length > 0) {
if (!(ov.index || ov.index == 0) || op2Paths.length <= ov.index) {
let index = -1;
for (let qi = 0; qi < op2Paths.length; qi++) {
let isInLine = false;
if (qi == op2Paths.length - 1) {
isInLine = DDeiUtil$1.isPointInLine(ov, op2Paths[qi], op2Paths[0]);
} else {
isInLine = DDeiUtil$1.isPointInLine(ov, op2Paths[qi], op2Paths[qi + 1]);
}
if (isInLine) {
index = qi;
break;
}
}
if (index != -1) {
x2 = ov.x;
y2 = ov.y;
ov.index = index;
} else {
let proPoints = DDeiAbstractShape.getProjPointDists(op2Paths, ov.x, ov.y, false, 1);
x2 = proPoints[0].x;
y2 = proPoints[0].y;
ov.index = proPoints[0].index;
index = proPoints[0].index;
}
if (index == op2Paths.length - 1) {
st = index;
en = 0;
} else {
st = index;
en = index + 1;
}
let pointDistance = DDeiUtil$1.getPointDistance(op2Paths[st].x, op2Paths[st].y, ov.x, ov.y);
let distance = DDeiUtil$1.getPointDistance(op2Paths[st].x, op2Paths[st].y, op2Paths[en].x, op2Paths[en].y);
let rate = pointDistance / distance;
ov.rate = rate > 1 ? rate : rate;
} else {
let index = ov.index;
if (index == op2Paths.length - 1) {
st = index;
en = 0;
} else {
st = index;
en = index + 1;
}
x2 = op2Paths[st].x + ov.rate * (op2Paths[en].x - op2Paths[st].x);
y2 = op2Paths[st].y + ov.rate * (op2Paths[en].y - op2Paths[st].y);
}
ov.x = x2;
ov.y = y2;
}
let outRect = this.essBounds;
if (ov.x == outRect.x && ov.y > outRect.y && ov.y < outRect.y1) {
ov.sita = 180;
} else if (ov.x == outRect.x1 && ov.y > outRect.y && ov.y < outRect.y1) {
ov.sita = 0;
} else if (ov.y == outRect.y && ov.x > outRect.x && ov.x < outRect.x1) {
ov.sita = -90;
} else if (ov.y == outRect.y1 && ov.x > outRect.x && ov.x < outRect.x1) {
ov.sita = 90;
}
}
this.updateLinkModels();
}
/**
* 更改图形后同步调整OVS点的位置
*/
updateOVS() {
var _a3, _b2, _c2;
if (((_a3 = this.ovs) == null ? void 0 : _a3.length) > 0) {
let defineOvs = (_c2 = (_b2 = DDeiUtil$1.getControlDefine(this)) == null ? void 0 : _b2.define) == null ? void 0 : _c2.ovs;
for (let i2 = 0; i2 < this.ovs.length; i2++) {
let ov = this.ovs[i2];
let ovd = defineOvs[i2];
switch (ovd.constraint.type) {
case 0: {
let dx = ov.x - ov.ovi.x;
let dy = ov.y - ov.ovi.y;
let m12 = new Matrix3(
1,
0,
this.cpv.x + dx - ov.x,
0,
1,
this.cpv.y + dy - ov.y,
0,
0,
1
);
ov.x = this.cpv.x + dx;
ov.y = this.cpv.y + dy;
ov.ovi.x = ov.x - dx;
ov.ovi.y = ov.y - dy;
this.updateOVSLink(ov, ovd, m12);
break;
}
case 1: {
let pathPvs = [];
let pvsStr = ovd.constraint.pvs;
if ((pvsStr == null ? void 0 : pvsStr.length) > 0) {
pvsStr.forEach((pvsS) => {
let pvsData = DDeiUtil$1.getDataByPathList(this, pvsS);
if (Array.isArray(pvsData)) {
pvsData.forEach((pvsD) => {
pathPvs.push(pvsD);
});
} else {
pathPvs.push(pvsData);
}
});
}
if (pathPvs.length > 1) {
let x2, y2, st, en;
if (!(ov.index || ov.index == 0) || pathPvs.length <= ov.index) {
let proPoints = DDeiAbstractShape.getProjPointDists(pathPvs, ov.x, ov.y, false, 1);
let index = proPoints[0].index;
ov.index = index;
x2 = proPoints[0].x;
y2 = proPoints[0].y;
if (index == pathPvs.length - 1) {
st = index;
en = 0;
} else {
st = index;
en = index + 1;
}
let pointDistance = DDeiUtil$1.getPointDistance(pathPvs[st].x, pathPvs[st].y, ov.x, ov.y);
let distance = DDeiUtil$1.getPointDistance(pathPvs[st].x, pathPvs[st].y, pathPvs[en].x, pathPvs[en].y);
let rate = pointDistance / distance;
ov.rate = rate > 1 ? rate : rate;
} else {
let index = ov.index;
if (index == pathPvs.length - 1) {
st = index;
en = 0;
} else {
st = index;
en = index + 1;
}
x2 = pathPvs[st].x + ov.rate * (pathPvs[en].x - pathPvs[st].x);
y2 = pathPvs[st].y + ov.rate * (pathPvs[en].y - pathPvs[st].y);
}
let sita = parseFloat(DDeiUtil$1.getLineAngle(pathPvs[st].x, pathPvs[st].y, pathPvs[en].x, pathPvs[en].y).toFixed(4));
let m12 = new Matrix3();
let dx = x2 - ov.x, dy = y2 - ov.y;
let deltaMoveMatrix = new Matrix3(
1,
0,
dx,
0,
1,
dy,
0,
0,
1
);
m12.premultiply(deltaMoveMatrix);
let ovSita = ov.sita;
if (!ovSita) {
ovSita = 0;
}
if (sita != ovSita) {
let move1Matrix = new Matrix3(
1,
0,
-x2,
0,
1,
-y2,
0,
0,
1
);
let angle2 = (-(sita - ovSita) * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
let move2Matrix = new Matrix3(
1,
0,
x2,
0,
1,
y2,
0,
0,
1
);
m12.premultiply(move1Matrix).premultiply(rotateMatrix).premultiply(move2Matrix);
}
ov.x = x2;
ov.y = y2;
ov.sita = sita;
this.updateOVSLink(ov, ovd, m12);
}
break;
}
case 5: {
let pathPvs = [];
let pvsStr = ovd.constraint.pvs;
if ((pvsStr == null ? void 0 : pvsStr.length) > 0) {
pvsStr.forEach((pvsS) => {
let pvsData = DDeiUtil$1.getDataByPathList(this, pvsS);
if (Array.isArray(pvsData)) {
pvsData.forEach((pvsD) => {
pathPvs.push(pvsD);
});
} else {
pathPvs.push(pvsData);
}
});
}
if (pathPvs.length == 2) {
let mode = 1;
let value;
if (ovd.constraint.rate || ovd.constraint.rate == 0) {
mode = 2;
value = ovd.constraint.rate;
} else {
value = ovd.constraint.len ? ovd.constraint.len : 0;
}
let point2 = DDeiUtil$1.getPathPoint(pathPvs[0].x, pathPvs[0].y, pathPvs[1].x, pathPvs[1].y, mode, value, 0.5);
ov.x = point2.x;
ov.y = point2.y;
ov.sita = point2.sita;
ov.rate = point2.rate;
ov.len = point2.len;
this.updateOVSLink(ov, ovd);
}
break;
}
}
}
}
}
updateOVSLink(point, pointDefine, matrix) {
if (pointDefine == null ? void 0 : pointDefine.links) {
pointDefine.links.forEach((link) => {
switch (link.type) {
case 1: {
let pvsStr = link.pvs;
if ((pvsStr == null ? void 0 : pvsStr.length) > 0) {
pvsStr.forEach((pvsS) => {
let pvsData = DDeiUtil$1.getDataByPathList(this, pvsS);
if (pvsData) {
if (Array.isArray(pvsData)) {
pvsData.forEach((pvsD) => {
pvsD.applyMatrix3(matrix);
});
} else {
if (pvsData.transVectors) {
pvsData.transVectors(matrix);
} else {
pvsData.applyMatrix3(matrix);
}
}
}
});
}
break;
}
case 2: {
let pvsStr = link.pvs;
if ((pvsStr == null ? void 0 : pvsStr.length) > 0) {
pvsStr.forEach((pvsS) => {
let pvsData = DDeiUtil$1.getDataByPathList(this, pvsS);
if (pvsData) {
let m12 = new Matrix3();
let moveMatrix2 = new Matrix3(
1,
0,
-pvsData.cpv.x,
0,
1,
-pvsData.cpv.y,
0,
0,
1
);
m12.premultiply(moveMatrix2);
if (pvsData.rotate != 0 && pvsData.rotate != 360) {
let angle2 = (pvsData.rotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
if (point.sita != 0 && point.sita != 360) {
let angle2 = (-point.sita * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let moveMatrix1 = new Matrix3(
1,
0,
point.x,
0,
1,
point.y,
0,
0,
1
);
m12.premultiply(moveMatrix1);
pvsData.transVectors(m12);
}
});
}
break;
}
case 99: {
if (!link.evalScript && link.script) {
eval("link.evalScript = function" + link.script);
}
if (link.evalScript) {
link.evalScript(this, point, pointDefine, link);
}
break;
}
}
});
}
}
/**
* 获取实际的内部容器控件
* @return 容器控件根据布局的模式不同返回不同的内部控件,普通控件返回null
*/
getAccuContainer() {
return null;
}
/**
* 获取顶级容器(Layer之下)
* @return 获取layer之下的顶级容器
*/
getTopContainer() {
let model = this;
while (model.pModel && model.pModel.baseModelType != "DDeiLayer") {
model = model.pModel;
}
if (model == this) {
return null;
} else {
return model;
}
}
/**
* 获取实际的内部容器控件
* @param x 相对路径坐标
* @param y 相对路径坐标
* @return 容器控件根据布局的模式不同返回不同的内部控件,普通控件返回null
*/
getAccuContainerByPos(x2, y2) {
return null;
}
/**
* 判断是否在某个边线上
* @param direct 1,2,3,4 上、右、下、左
*/
isBorderOn(direct, x2, y2, inWeight = -3, outWeight = 3) {
let projPoint = this.getProjPointOnLine(
{ x: x2, y: y2 },
{ in: inWeight, out: outWeight },
1,
direct - 1
);
if (projPoint) {
return true;
} else {
return false;
}
}
/**
* 获取中心点操作点
*/
getCenterOpPoints() {
var _a3;
if (((_a3 = this.opps) == null ? void 0 : _a3.length) > 0) {
return cloneDeep(this.opps);
}
return [];
}
/**
* 得到点在图形某条线上的投射点
* @param point 测试点
* @param distance 内外部判定区间的距离
* @param direct 方向,1外部,2内部 默认1
* @param index 线开始点向量的下标
* @returns 投影点的坐标
*/
getProjPointOnLine(point2, distance = { in: 0, out: 15 }, direct = 1, index) {
var _a3;
let x0 = point2.x;
let y0 = point2.y;
if (((_a3 = this.opps) == null ? void 0 : _a3.length) > index) {
let st, en;
let plLength = Infinity;
if (index == this.opps.length - 1) {
st = index;
en = 0;
} else {
st = index;
en = index + 1;
}
let x1 = this.opps[st].x;
let y1 = this.opps[st].y;
let x2 = this.opps[en].x;
let y2 = this.opps[en].y;
if (x1 == x2 && y1 == y2) {
plLength = Math.sqrt((x1 - x0) * (x1 - x0) + (y1 - y0) * (y1 - y0));
} else {
let s = (x0 - x1) * (y2 - y1) - (y0 - y1) * (x2 - x1);
let d = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);
plLength = s / d;
}
let flag = false;
if (direct == 1) {
if (plLength >= distance.in && plLength <= distance.out) {
flag = true;
}
} else if (direct == 2) {
if (plLength <= distance.in && plLength >= distance.out) {
flag = true;
}
}
if (flag) {
let lineV = new Vector3(x2, y2, 1);
let pointV = new Vector3(x0, y0, 1);
let toZeroMatrix = new Matrix3(
1,
0,
-x1,
0,
1,
-y1,
0,
0,
1
);
lineV.applyMatrix3(toZeroMatrix);
pointV.applyMatrix3(toZeroMatrix);
let lineAngle = (new Vector3(1, 0, 0).angleTo(new Vector3(lineV.x, lineV.y, 0)) * 180 / Math.PI).toFixed(4);
let angle2 = 0;
if (lineV.x >= 0 && lineV.y >= 0) {
angle2 = (lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (lineV.x <= 0 && lineV.y >= 0) {
angle2 = (lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (lineV.x <= 0 && lineV.y <= 0) {
angle2 = (-lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (lineV.x >= 0 && lineV.y <= 0) {
angle2 = (-lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
}
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
lineV.applyMatrix3(rotateMatrix);
pointV.applyMatrix3(rotateMatrix);
if (pointV.x >= 0 && pointV.x <= lineV.x) {
let v1 = new Vector3(pointV.x, 0, 1);
angle2 = -angle2;
let rotateMatrix2 = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
v1.applyMatrix3(rotateMatrix2);
let removeMatrix = new Matrix3(
1,
0,
x1,
0,
1,
y1,
0,
0,
1
);
v1.applyMatrix3(removeMatrix);
return v1;
}
}
}
return null;
}
/**
* 得到点在图形连接线上的投射点
* @param point 测试点
* @param distance 内外部判定区间的距离
* @param direct 方向,1外部,2内部 默认1
* @param pointType 用于判定的点类别,1操作点,2范围点,缺省操作点
* @returns 投影点的坐标
*/
getProjPoint(point2, distance = { in: 0, out: 15 }, direct = 1, pointType = 1) {
var _a3;
let x0 = point2.x;
let y0 = point2.y;
let opPVS = [];
if (pointType == 1) {
if ((_a3 = this.opps) == null ? void 0 : _a3.length) {
this.opps.forEach((opvs) => {
if (opvs.oppoint == 2) {
opPVS.push(opvs);
}
});
}
} else {
opPVS = this.getOperatePVS();
}
if ((opPVS == null ? void 0 : opPVS.length) > 0) {
let st, en;
for (let j2 = 0; j2 < opPVS.length; j2++) {
let plLength = Infinity;
if (j2 == opPVS.length - 1) {
st = j2;
en = 0;
} else {
st = j2;
en = j2 + 1;
}
let x1 = opPVS[st].x;
let y1 = opPVS[st].y;
let x2 = opPVS[en].x;
let y2 = opPVS[en].y;
if (x1 == x2 && y1 == y2) {
plLength = Math.sqrt((x1 - x0) * (x1 - x0) + (y1 - y0) * (y1 - y0));
} else {
let s = (x0 - x1) * (y2 - y1) - (y0 - y1) * (x2 - x1);
let d = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);
plLength = s / d;
}
let flag = false;
if (direct == 1) {
if (plLength >= distance.in && plLength <= distance.out) {
flag = true;
}
} else if (direct == 2) {
if (plLength <= distance.in && plLength >= distance.out) {
flag = true;
}
}
if (flag) {
let lineV = new Vector3(x2, y2, 1);
let pointV = new Vector3(x0, y0, 1);
let toZeroMatrix = new Matrix3(
1,
0,
-x1,
0,
1,
-y1,
0,
0,
1
);
lineV.applyMatrix3(toZeroMatrix);
pointV.applyMatrix3(toZeroMatrix);
let angle2 = new Vector3(1, 0, 0).angleTo(new Vector3(lineV.x, lineV.y, 0));
let lineAngle = angle2 / DDeiConfig$1.ROTATE_UNIT;
if (lineV.x >= 0 && lineV.y >= 0)
;
else if (lineV.x <= 0 && lineV.y >= 0)
;
else if (lineV.x <= 0 && lineV.y <= 0) {
angle2 = -angle2;
} else if (lineV.x >= 0 && lineV.y <= 0) {
angle2 = -angle2;
}
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
lineV.applyMatrix3(rotateMatrix);
pointV.applyMatrix3(rotateMatrix);
if (pointV.x >= 0 && pointV.x <= lineV.x) {
let isMiddle = false;
if (Math.abs(lineV.x / 2 - pointV.x) <= 5) {
pointV.x = lineV.x / 2;
isMiddle = true;
}
let v1 = new Vector3(pointV.x, 0, 1);
angle2 = -angle2;
let rotateMatrix2 = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
v1.applyMatrix3(rotateMatrix2);
let removeMatrix = new Matrix3(
1,
0,
x1,
0,
1,
y1,
0,
0,
1
);
v1.applyMatrix3(removeMatrix);
v1.isMiddle = isMiddle;
v1.sita = lineAngle;
let rate = Math.abs(pointV.x / lineV.x);
v1.rate = rate > 1 ? 1 : rate;
v1.index = st;
v1.plLength = plLength;
return v1;
}
}
}
}
return null;
}
/**
* 返回计算后的坐标、大小
*/
getBounds() {
return { x: this.x, y: this.y, width: this.width, height: this.height, x1: this.x + this.width, y1: this.y + this.height };
}
/**
* 获取画布缩放比率
*/
getStageRatio() {
if (this.stage) {
let stageRatio2 = parseFloat(this.stage.ratio) ? parseFloat(this.stage.ratio) : 1;
if (!stageRatio2 || isNaN(stageRatio2)) {
stageRatio2 = this.stage.ddInstance.ratio;
}
return stageRatio2;
} else {
return 1;
}
}
/**
* 修改自身状态
*/
setState(state) {
var _a3;
if (this.state != state) {
this.state = state;
(_a3 = this.render) == null ? void 0 : _a3.renderCacheData.clear();
}
}
/**
* 根据点的数量判断图形是否在一个区域内
* @param x
* @param y
* @param x1
* @param y1
* @param pointNumber 在区域内点的数量,达到这个数量则看作在区域内,默认1
* @returns 是否在区域内
*/
isInRect(x2, y2, x1, y1, pointNumber = 1) {
var _a3;
if (x2 === void 0 || y2 === void 0 || x1 === void 0 || y1 === void 0) {
return false;
}
let pvs2 = ((_a3 = this.operatePVS) == null ? void 0 : _a3.length) > 2 ? this.operatePVS : this.pvs;
let len = pvs2.length;
let pn2 = 0;
let modelLines = [];
for (let i2 = 0; i2 < len; i2++) {
let ps = pvs2[i2];
if (ps.x >= x2 && ps.y >= y2 && ps.x <= x1 && ps.y <= y1) {
pn2++;
}
if (pn2 >= pointNumber) {
return true;
}
if (i2 == len - 1) {
modelLines.push({ x1: pvs2[i2].x, y1: pvs2[i2].y, x2: pvs2[0].x, y2: pvs2[0].y });
} else {
modelLines.push({ x1: pvs2[i2].x, y1: pvs2[i2].y, x2: pvs2[i2 + 1].x, y2: pvs2[i2 + 1].y });
}
}
let rectLines = [
{ x1: x2, y1: y2, x2: x1, y2 },
{ x1, y1: y2, x2: x1, y2: y1 },
{ x1, y1, x2, y2: y1 },
{ x1: x2, y1, x2, y2 }
];
len = modelLines.length;
for (let i2 = 0; i2 < len; i2++) {
for (let j2 = 0; j2 < 4; j2++) {
if (DDeiUtil$1.isLineCross(modelLines[i2], rectLines[j2])) {
pn2++;
if (pn2 >= pointNumber) {
return true;
}
}
}
}
let outRect = DDeiAbstractShape.pvsToOutRect(pvs2);
if (x2 >= outRect.x && x2 <= outRect.x1 && y2 >= outRect.y && y2 <= outRect.y1) {
return true;
}
return false;
}
/**
* 判断某个线段是否与当前图形相交
*/
isLineCross(line2) {
for (let i2 = 0; i2 < this.pvs.length; i2++) {
let s = i2;
let e = i2 + 1;
if (i2 == this.pvs.length - 1) {
e = 0;
}
if (DDeiUtil$1.isLineCross(line2, { x1: this.pvs[s].x, y1: this.pvs[s].y, x2: this.pvs[e].x, y2: this.pvs[e].y })) {
return true;
}
}
return false;
}
/**
* 判断图形是否在一个文本编辑的区域内
* @param x
* @param y
* @returns 是否在区域内
*/
isInTextArea(x2 = void 0, y2 = void 0) {
var _a3;
if (x2 === void 0 || y2 === void 0) {
return false;
}
if (((_a3 = this.textArea) == null ? void 0 : _a3.length) > 0) {
return DDeiAbstractShape.isInsidePolygon(
this.textArea,
{ x: x2, y: y2 }
);
}
return false;
}
/**
* 判断图形是否在一个区域内,采用宽松的判定模式,允许传入一个大小值
* @param x
* @param y
* @param loose 宽松判定,默认false
* @returns 是否在区域内
*/
isInAreaLoose(x2 = void 0, y2 = void 0, loose = false) {
var _a3, _b2;
if (x2 === void 0 || y2 === void 0) {
return false;
}
let ps = null;
if (loose && ((_a3 = this.loosePVS) == null ? void 0 : _a3.length) > 0) {
ps = this.loosePVS;
} else if (((_b2 = this.pvs) == null ? void 0 : _b2.length) > 0) {
ps = this.pvs;
}
if ((ps == null ? void 0 : ps.length) > 0) {
return DDeiAbstractShape.isInsidePolygon(
ps,
{ x: x2, y: y2 }
);
}
return false;
}
/**
* 获取当前图形的除layer的所有父节点对象
*/
getParents() {
let pModel = this.pModel;
let returnControls = [];
while ((pModel == null ? void 0 : pModel.baseModelType) != "DDeiLayer") {
returnControls.push(pModel);
pModel = pModel.pModel;
}
return returnControls;
}
/**
* 获取控件坐标
* @param coord 坐标系:1标尺坐标/2页面坐标
* @param unit 标尺单位
* @param type 坐标类型:1左上角/2中心点
*/
getPosition(coord = 2, unit = "", type = 2) {
switch (coord) {
case 1:
{
if (type == 1) {
return DDeiUtil$1.toRulerCoord({ x: this.x, y: this.y }, this.stage, unit);
} else if (type == 2) {
return DDeiUtil$1.toRulerCoord({ x: this.cpv.x, y: this.cpv.y }, this.stage, unit);
}
}
break;
case 2:
{
if (type == 1) {
return { x: this.x, y: this.y };
} else if (type == 2) {
return { x: this.cpv.x, y: this.cpv.y };
}
}
break;
}
return { x: this.x, y: this.y };
}
/**
* 设置控件坐标
* @param point 坐标点
* @param coord 坐标系:1标尺坐标/2页面坐标
* @param unit 标尺单位
* @param type 坐标类型:1左上角/2中心点
*/
setPosition(point2, coord = 2, unit = "", type = 2) {
let moveX = 0, moveY = 0;
switch (coord) {
case 1:
{
if (type == 1) {
let pv1 = DDeiUtil$1.toPageCoord(point2, this.stage, unit);
moveX = pv1.x - this.x;
moveY = pv1.y - this.y;
} else if (type == 2) {
let pv1 = DDeiUtil$1.toPageCoord(point2, this.stage, unit);
moveX = pv1.x - this.cpv.x;
moveY = pv1.y - this.cpv.y;
}
}
break;
case 2:
{
if (type == 1) {
moveX = point2.x - this.x;
moveY = point2.y - this.y;
} else if (type == 2) {
moveX = point2.x - this.cpv.x;
moveY = point2.y - this.cpv.y;
}
}
break;
}
DDeiAbstractShape.moveModels([this], moveX, moveY);
}
/**
* 设置当前模型为被修改状态
*/
setModelChanged() {
var _a3;
(_a3 = this.layer) == null ? void 0 : _a3.setModelChanged();
}
/**
* 判断当前模型是否已被修改
*/
isModelChanged() {
var _a3;
return (_a3 = this.layer) == null ? void 0 : _a3.isModelChanged();
}
/**
* 移除自身的方法
*/
destroyed() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i;
if (!this.__destroyed) {
if (!this.isShadowControl) {
let sourceLinks = (_a3 = this.stage) == null ? void 0 : _a3.getSourceModelLinks(this.id);
sourceLinks == null ? void 0 : sourceLinks.forEach((link2) => {
var _a22;
if (link2.dm) {
link2.dm.pModel.removeModel(link2.dm, true);
}
(_a22 = this.stage) == null ? void 0 : _a22.removeLink(link2);
});
let lines = (_b2 = this.stage) == null ? void 0 : _b2.getModelsByBaseType("DDeiLine");
lines == null ? void 0 : lines.forEach((line2) => {
var _a22;
if ((_a22 = line2.linkModels) == null ? void 0 : _a22.has(this.id)) {
line2.linkModels.delete(this.id);
}
});
(_c2 = this.linkModels) == null ? void 0 : _c2.forEach((lm) => {
var _a22;
if (lm.dm) {
(_a22 = lm.dm.pModel) == null ? void 0 : _a22.removeModel(lm.dm, true);
lm.dm.destroyed();
}
});
(_d2 = this.linkModels) == null ? void 0 : _d2.clear();
this.linkModels = null;
if (this.depModel) {
(_e2 = this.depModel.linkModels) == null ? void 0 : _e2.delete(this.id);
}
}
if ((_f = this.render) == null ? void 0 : _f.tempCanvas) {
this.render.tempCanvas.remove();
delete this.render.tempCanvas;
}
if ((_g = this.render) == null ? void 0 : _g.viewer) {
DDeiUtil$1.removeRenderViewer(this);
}
(_h = this.composes) == null ? void 0 : _h.forEach((comp) => {
comp.destroyed();
});
this.render = null;
this.__destroyed = true;
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_DEL_AFTER", DDeiEnumOperateType.DESTROYED, { models: [this] }, (_i = this.stage) == null ? void 0 : _i.ddInstance, null);
}
}
/**
* 移除渲染器
*/
destroyRender() {
var _a3, _b2, _c2, _d2;
if ((_a3 = this.render) == null ? void 0 : _a3.tempCanvas) {
this.render.tempCanvas.remove();
delete this.render.tempCanvas;
}
if ((_b2 = this.render) == null ? void 0 : _b2.viewer) {
DDeiUtil$1.removeRenderViewer(this);
}
(_c2 = this.composes) == null ? void 0 : _c2.forEach((comp) => {
comp.destroyRender();
});
if (this.models) {
(_d2 = this.midList) == null ? void 0 : _d2.forEach((mid) => {
var _a22;
(_a22 = this.models.get(mid)) == null ? void 0 : _a22.destroyRender();
});
}
this.render = null;
}
/**
* 将模型转换为JSON
*/
toJSON() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m;
let json = new Object();
let skipFields = (_a3 = DDeiConfig$1.SERI_FIELDS[this.modelType]) == null ? void 0 : _a3.SKIP;
if (!((skipFields == null ? void 0 : skipFields.length) > 0)) {
skipFields = (_b2 = DDeiConfig$1.SERI_FIELDS[this.baseModelType]) == null ? void 0 : _b2.SKIP;
}
if (!((skipFields == null ? void 0 : skipFields.length) > 0)) {
if (this.poly == 2) {
skipFields = (_c2 = DDeiConfig$1.SERI_FIELDS["AbstractShape"]) == null ? void 0 : _c2.SKIP2;
} else {
skipFields = (_d2 = DDeiConfig$1.SERI_FIELDS["AbstractShape"]) == null ? void 0 : _d2.SKIP;
}
}
let toJSONFields = (_e2 = DDeiConfig$1.SERI_FIELDS[this.modelType]) == null ? void 0 : _e2.TOJSON;
if (!((toJSONFields == null ? void 0 : toJSONFields.length) > 0)) {
toJSONFields = (_f = DDeiConfig$1.SERI_FIELDS[this.baseModelType]) == null ? void 0 : _f.TOJSON;
}
if (!((toJSONFields == null ? void 0 : toJSONFields.length) > 0)) {
toJSONFields = (_g = DDeiConfig$1.SERI_FIELDS["AbstractShape"]) == null ? void 0 : _g.TOJSON;
}
for (let i2 in this) {
if (!skipFields || (skipFields == null ? void 0 : skipFields.indexOf(i2)) == -1) {
if (toJSONFields && toJSONFields.indexOf(i2) != -1 && this[i2]) {
if (Array.isArray(this[i2])) {
let array = [];
for (let xi = 0; xi < this[i2].length; xi++) {
let element = this[i2][xi];
if (Array.isArray(element)) {
let subArray = [];
element.forEach((subEle) => {
if (subEle == null ? void 0 : subEle.toJSON) {
subArray.push(subEle.toJSON());
} else {
subArray.push(subEle);
}
});
array.push(subArray);
} else if (element == null ? void 0 : element.toJSON) {
array.push(element.toJSON());
} else {
array.push(element);
}
}
if (array.length > 0) {
json[i2] = array;
}
} else if (((_h = this[i2]) == null ? void 0 : _h.set) && ((_i = this[i2]) == null ? void 0 : _i.has)) {
let map = {};
this[i2].forEach((element, key) => {
if (element == null ? void 0 : element.toJSON) {
map[key] = element.toJSON();
} else {
map[key] = element;
}
});
if (JSON.stringify(map) != "{}") {
json[i2] = map;
}
} else if ((_j = this[i2]) == null ? void 0 : _j.toJSON) {
json[i2] = this[i2].toJSON();
} else if (this[i2] || this[i2] == 0) {
json[i2] = this[i2];
}
} else {
if (Array.isArray(this[i2])) {
let array = [];
for (let xi = 0; xi < this[i2].length; xi++) {
let element = this[i2][xi];
if (Array.isArray(element)) {
let subArray = [];
element.forEach((subEle) => {
if (subEle == null ? void 0 : subEle.toJSON) {
subArray.push(subEle.toJSON());
} else {
subArray.push(subEle);
}
});
array.push(subArray);
} else if (element == null ? void 0 : element.toJSON) {
array.push(element.toJSON());
} else if (element == null ? void 0 : element.isVector3) {
let dt = clone(element);
delete dt.z;
array.push(dt);
} else {
array.push(element);
}
}
if (array.length > 0) {
json[i2] = array;
}
} else if (((_k = this[i2]) == null ? void 0 : _k.set) && ((_l = this[i2]) == null ? void 0 : _l.has)) {
let map = {};
this[i2].forEach((element, key) => {
if (element == null ? void 0 : element.toJSON) {
map[key] = element.toJSON();
} else {
map[key] = element;
}
});
if (JSON.stringify(map) != "{}") {
json[i2] = map;
}
} else if ((_m = this[i2]) == null ? void 0 : _m.toJSON) {
json[i2] = this[i2].toJSON();
} else if (this[i2] || this[i2] == 0) {
if (i2 == "rotate" && this[i2] == 0)
;
else if ((i2 == "text" || i2 == "imgBase64") && this[i2] == "")
;
else if (this[i2].isVector3) {
json[i2] = clone(this[i2]);
delete json[i2].z;
} else {
json[i2] = this[i2];
}
}
}
}
}
return json;
}
// ============================ 静态方法 ============================
/**
* 移动控件位置
* @param models
* @param dx
* @param dy
*/
static moveModels(models, dx = 0, dy = 0, ignoreModelIds) {
if ((dx != 0 || dy != 0) && (models == null ? void 0 : models.length) > 0) {
let moveMatrix2 = new Matrix3(
1,
0,
dx,
0,
1,
dy,
0,
0,
1
);
models.forEach((m) => {
m.transVectors(moveMatrix2);
m.refreshLinkModels();
m.updateLinkModels(ignoreModelIds);
});
}
}
/**
* 以矩形的大小变化为参照物,修改模型的大小
*/
static changeModelBoundByRect(models, rectObj, data) {
var _a3;
if (!((models == null ? void 0 : models.length) > 0)) {
return;
}
let deltaX = data.deltaX ? data.deltaX : 0;
let deltaY = data.deltaY ? data.deltaY : 0;
let deltaWidth = data.deltaWidth ? data.deltaWidth : 0;
let deltaHeight = data.deltaHeight ? data.deltaHeight : 0;
let selector = rectObj;
let stageRatio2 = models[0].getStageRatio();
let paddingWeight = 0;
if (selector.modelType) {
let paddingWeightInfo = ((_a3 = selector.paddingWeight) == null ? void 0 : _a3.selected) ? selector.paddingWeight.selected : DDeiConfig$1.SELECTOR.PADDING_WEIGHT.selected;
if (models.length > 1) {
paddingWeight = paddingWeightInfo.multiple;
} else {
paddingWeight = paddingWeightInfo.single;
}
}
selector.width -= 2 * paddingWeight;
selector.height -= 2 * paddingWeight;
if (selector.width + deltaWidth < 10) {
return;
}
if (selector.height + deltaHeight < 10) {
return;
}
let selectCPVXDelta = deltaX == 0 ? deltaWidth / 2 : deltaX / 2;
let selectCPVYDelta = deltaY == 0 ? deltaHeight / 2 : deltaY / 2;
let scaleWRate = 1 + deltaWidth / selector.width / stageRatio2;
let scaleHRate = 1 + deltaHeight / selector.height / stageRatio2;
let itemMoveMatrix = new Matrix3(
1,
0,
-selector.cpv.x,
0,
1,
-selector.cpv.y,
0,
0,
1
);
let scaleMatrix2 = new Matrix3(
scaleWRate,
0,
0,
0,
scaleHRate,
0,
0,
0,
1
);
let itemMove1Matrix = new Matrix3(
1,
0,
selector.cpv.x + selectCPVXDelta,
0,
1,
selector.cpv.y + selectCPVYDelta,
0,
0,
1
);
models.forEach((item) => {
var _a22, _b2, _c2, _d2;
let m2 = new Matrix3();
m2.premultiply(itemMoveMatrix);
if (item.rotate) {
let angle2 = item.rotate * DDeiConfig$1.ROTATE_UNIT;
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m2.premultiply(rotateMatrix);
}
m2.premultiply(scaleMatrix2);
if (item.rotate) {
let angle2 = -item.rotate * DDeiConfig$1.ROTATE_UNIT;
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m2.premultiply(rotateMatrix);
}
m2.premultiply(itemMove1Matrix);
if (item.baseModelType == "DDeiContainer") {
(_a22 = item.layoutManager) == null ? void 0 : _a22.transVectors(m2);
} else {
item.transVectors(m2);
}
item.initPVS();
(_c2 = (_b2 = item.getTopContainer()) == null ? void 0 : _b2.render) == null ? void 0 : _c2.enableRefreshShape();
(_d2 = this.render) == null ? void 0 : _d2.enableRefreshShape();
});
}
/**
* 通过射线法判断点是否在图形内部
* @param pps 多边形顶点
* @param point 测试点
* @returns
*/
static isInsidePolygon(polygon2, point2) {
let x2 = point2.x, y2 = point2.y;
let inside = false;
for (var i2 = 0, j2 = polygon2.length - 1; i2 < polygon2.length; j2 = i2++) {
var xi = polygon2[i2].x, yi = polygon2[i2].y;
var xj = polygon2[j2].x, yj = polygon2[j2].y;
var intersect = yi > y2 != yj > y2 && x2 < (xj - xi) * (y2 - yi) / (yj - yi) + xi;
if (intersect) {
inside = !inside;
}
}
return inside;
}
/**
* 基于向量点获取一组图形模型的宽高
* @param models
*/
static getOutRectByPV(models, ratio = 1) {
models = models.filter((item) => !!item);
if (!models.length) {
return { x: 0, y: 0, width: 0, height: 0 };
}
let points = [];
models.forEach((item) => {
let pvs2 = item.operatePVS ? item.operatePVS : item.pvs;
points = points.concat(pvs2);
});
return DDeiAbstractShape.pvsToOutRect(points, ratio);
}
/**
* 获取最靠外部的一组向量
* @param models
*/
static getOutPV(models) {
let o = DDeiAbstractShape.getOutRectByPV(models);
return DDeiAbstractShape.outRectToPV(o);
}
/**
* 返回外接矩形的点集合
*/
static outRectToPV(o) {
return [
new Vector3(o.x, o.y, 1),
new Vector3(o.x1, o.y, 1),
new Vector3(o.x1, o.y1, 1),
new Vector3(o.x, o.y1, 1)
];
}
/**
* 返回点集合的外接矩形
*/
static pvsToOutRect(points, ratio = 1) {
let x2 = Infinity, y2 = Infinity, x1 = -Infinity, y1 = -Infinity;
points.forEach((p) => {
x2 = Math.min(p.x, x2);
x1 = Math.max(p.x, x1);
y2 = Math.min(p.y, y2);
y1 = Math.max(p.y, y1);
});
return {
x: x2 * ratio,
y: y2 * ratio,
width: (x1 - x2) * ratio,
height: (y1 - y2) * ratio,
x1: x1 * ratio,
y1: y1 * ratio
};
}
/**
* 获取某个控件下的最底层componse控件,如果没有则返回控件本身
*/
static findBottomComponseByArea(control, x2 = void 0, y2 = void 0) {
var _a3;
let componses = [];
if (control) {
(_a3 = control.composes) == null ? void 0 : _a3.forEach((item) => {
if (item.isInAreaLoose(x2, y2, true)) {
let subComponse = DDeiAbstractShape.findBottomComponseByArea(item, x2, y2);
if (subComponse) {
componses.push(subComponse);
} else {
componses.push(item);
}
}
});
if (componses.length > 0) {
componses.sort(function(a, b) {
if ((a.cIndex || a.cIndex == 0) && (b.cIndex || b.cIndex == 0)) {
return a.cIndex - b.cIndex;
} else if ((a.cIndex || a.cIndex == 0) && !(b.cIndex || b.cIndex == 0)) {
return 1;
} else if (!(a.cIndex || a.cIndex == 0) && (b.cIndex || b.cIndex == 0)) {
return -1;
} else {
return 0;
}
});
return componses[0];
} else {
return control;
}
}
}
/**
* 得到点在某个路径组合上的投射点
* @param opPVS 构成路径的点
* @param x0,y0 测试点
* @param isClose 是否闭合
* @param sort 是否排序后返回(按照投射距离的绝对值)
* @returns 每一条路径上的投影点的坐标
*/
static getProjPointDists(opPVS, x0, y0, isClose = false, sort = 0) {
if ((opPVS == null ? void 0 : opPVS.length) > 0) {
let st, en;
let returnData = [];
for (let j2 = 0; j2 < opPVS.length; j2++) {
let plLength = Infinity;
if (j2 == opPVS.length - 1) {
if (isClose) {
st = j2;
en = 0;
} else {
continue;
}
} else {
st = j2;
en = j2 + 1;
}
let x1 = opPVS[st].x;
let y1 = opPVS[st].y;
let x2 = opPVS[en].x;
let y2 = opPVS[en].y;
if (x1 == x2 && y1 == y2) {
plLength = Math.sqrt((x1 - x0) * (x1 - x0) + (y1 - y0) * (y1 - y0));
} else {
let s = (x0 - x1) * (y2 - y1) - (y0 - y1) * (x2 - x1);
let d = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);
plLength = s / d;
}
let lineV = new Vector3(x2, y2, 1);
let pointV = new Vector3(x0, y0, 1);
let toZeroMatrix = new Matrix3(
1,
0,
-x1,
0,
1,
-y1,
0,
0,
1
);
lineV.applyMatrix3(toZeroMatrix);
pointV.applyMatrix3(toZeroMatrix);
let lineAngle = (new Vector3(1, 0, 0).angleTo(new Vector3(lineV.x, lineV.y, 0)) * 180 / Math.PI).toFixed(4);
let angle2 = 0;
if (lineV.x >= 0 && lineV.y >= 0) {
angle2 = (lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (lineV.x <= 0 && lineV.y >= 0) {
angle2 = (lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (lineV.x <= 0 && lineV.y <= 0) {
angle2 = (-lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (lineV.x >= 0 && lineV.y <= 0) {
angle2 = (-lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
}
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
lineV.applyMatrix3(rotateMatrix);
pointV.applyMatrix3(rotateMatrix);
if (pointV.x < 0) {
pointV.x = 0;
} else if (pointV.x > lineV.x) {
pointV.x = lineV.x;
}
let v1 = new Vector3(pointV.x, 0, 1);
angle2 = -angle2;
let rotateMatrix1 = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
v1.applyMatrix3(rotateMatrix1);
let removeMatrix = new Matrix3(
1,
0,
x1,
0,
1,
y1,
0,
0,
1
);
v1.applyMatrix3(removeMatrix);
returnData.push({ index: st, dist: plLength, x: v1.x, y: v1.y });
}
if (sort == 1) {
returnData.sort((a, b) => {
return Math.abs(a.dist) - Math.abs(b.dist);
});
} else if (sort == 2) {
returnData.sort((a, b) => {
return Math.abs(b.dist) - Math.abs(a.dist);
});
}
return returnData;
}
return null;
}
/**
* 获取某个容器下选中区域的所有控件,如果控件已被选中,且是一个容器,则继续向下直到最底层
* @param container 容器
* @param x X坐标
* @param y Y坐标
* @param loose 启用宽松判定
* @param deep 启动深度判定
* @returns
*/
static findBottomModelsByArea(container2, x2 = void 0, y2 = void 0, loose = false, deep = false) {
let controls2 = [];
if (container2) {
for (let mg = container2.midList.length - 1; mg >= 0; mg--) {
let item = container2.models.get(container2.midList[mg]);
if (!DDeiUtil$1.isModelHidden(item) && item.isInAreaLoose(x2, y2, loose)) {
if ((item.state == DDeiEnumControlState.SELECTED || deep) && item.baseModelType == "DDeiContainer") {
let subControls = DDeiAbstractShape.findBottomModelsByArea(item, x2, y2, loose, deep);
if (subControls && subControls.length > 0) {
controls2 = controls2.concat(subControls);
} else {
controls2.push(item);
}
} else if ((item.state == DDeiEnumControlState.SELECTED || deep) && item.baseModelType == "DDeiTable") {
let currentCell = item.getAccuContainerByPos(x2, y2);
if ((currentCell == null ? void 0 : currentCell.state) == DDeiEnumControlState.SELECTED) {
let subControls = DDeiAbstractShape.findBottomModelsByArea(currentCell, x2, y2, loose, deep);
if (subControls && subControls.length > 0) {
controls2 = controls2.concat(subControls);
} else {
controls2.push(item);
}
} else {
controls2.push(item);
}
} else {
controls2.push(item);
}
}
}
}
if (controls2.length > 1) {
controls2.sort(function(a, b) {
let anumber = -1;
let bnumber = -1;
if (a.baseModelType == "DDeiLine") {
anumber = 1e3 + (a.zIndex ? b.zIndex : 0);
} else if (a.id.startsWith("lsm_")) {
anumber = 2100 + (a.zIndex ? b.zIndex : 0);
} else {
anumber = 1e3 + (a.zIndex ? b.zIndex : 0);
}
if (b.baseModelType == "DDeiLine") {
bnumber = 1e3 + (b.zIndex ? b.zIndex : 0);
} else if (b.id.startsWith("lsm_")) {
bnumber = 2100 + (b.zIndex ? b.zIndex : 0);
} else {
bnumber = 1e3 + (b.zIndex ? b.zIndex : 0);
}
if (a.baseModelType == "DDeiContainer" && a.layout == "compose") {
anumber -= 5e3;
}
if (b.baseModelType == "DDeiContainer" && b.layout == "compose") {
bnumber -= 5e3;
}
return bnumber - anumber;
});
}
return controls2;
}
/**
* 获取某个容器下选中区域的最底层容器
* @param area 选中区域
* @returns
*/
static findBottomContainersByArea(container2, x2 = void 0, y2 = void 0) {
let controls2 = [];
if (container2) {
for (let mg = container2.midList.length - 1; mg >= 0; mg--) {
let item = container2.models.get(container2.midList[mg]);
if (!DDeiUtil$1.isModelHidden(item) && DDeiAbstractShape.isInsidePolygon(item.pvs, { x: x2, y: y2 })) {
let accuContainer = item.getAccuContainerByPos(x2, y2);
if (accuContainer) {
let subControls = DDeiAbstractShape.findBottomContainersByArea(accuContainer, x2, y2);
if (subControls && subControls.length > 0) {
controls2 = controls2.concat(subControls);
} else {
controls2.push(accuContainer);
}
}
}
}
}
return controls2;
}
}
const __vite_glob_0_10$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiAbstractShape,
default: DDeiAbstractShape
}, Symbol.toStringTag, { value: "Module" }));
var DDeiEnumBusCommandType = /* @__PURE__ */ ((DDeiEnumBusCommandType2) => {
DDeiEnumBusCommandType2["ModelChangeSelect"] = "model-change-select";
DDeiEnumBusCommandType2["StageChangeSelectModels"] = "stage-change-select-models";
DDeiEnumBusCommandType2["CancelCurLevelSelectedModels"] = "cancel-curlevel-selected-models";
DDeiEnumBusCommandType2["UpdateSelectorBounds"] = "update-selector-bounds";
DDeiEnumBusCommandType2["ClearTemplateVars"] = "clear-template-vars";
DDeiEnumBusCommandType2["RefreshShape"] = "refresh-shape";
DDeiEnumBusCommandType2["ModelChangeContainer"] = "model-change-container";
DDeiEnumBusCommandType2["ModelRemove"] = "model-remove";
DDeiEnumBusCommandType2["ModelChangeBounds"] = "model-change-bounds";
DDeiEnumBusCommandType2["ModelChangePosition"] = "model-change-position";
DDeiEnumBusCommandType2["ModelEdgePosition"] = "model-edge-position";
DDeiEnumBusCommandType2["SetHelpLine"] = "set-helpline";
DDeiEnumBusCommandType2["UpdateDragObj"] = "update-dragobj";
DDeiEnumBusCommandType2["ChangeSelectorPassIndex"] = "change-selector-passindex";
DDeiEnumBusCommandType2["ChangeCursor"] = "change-cursor";
DDeiEnumBusCommandType2["ModelChangeRotate"] = "model-change-rotate";
DDeiEnumBusCommandType2["ResetSelectorState"] = "reset-selector-state";
DDeiEnumBusCommandType2["ModelPush"] = "model-push";
DDeiEnumBusCommandType2["CreateDepLinkModel"] = "create-dep-linkmodel";
DDeiEnumBusCommandType2["ModelChangeValue"] = "model-change-value";
DDeiEnumBusCommandType2["ChangeLayout"] = "change-layout";
DDeiEnumBusCommandType2["CopyStyle"] = "copy-style";
DDeiEnumBusCommandType2["AddHistroy"] = "add-histroy";
DDeiEnumBusCommandType2["ModelAlign"] = "model-align";
DDeiEnumBusCommandType2["ModelMerge"] = "model-merge";
DDeiEnumBusCommandType2["ModelCancelMerge"] = "model-cancel-merge";
DDeiEnumBusCommandType2["ModelAutoPos"] = "model-auto-pos";
DDeiEnumBusCommandType2["ChangeEditMode"] = "change-edit-mode";
DDeiEnumBusCommandType2["ChangeStageRatio"] = "change-stage-ratio";
DDeiEnumBusCommandType2["ChangeStageWPV"] = "change-stage-wpv";
DDeiEnumBusCommandType2["CenterStageWPV"] = "center-stage-wpv";
DDeiEnumBusCommandType2["NodifyChange"] = "nodify-change";
DDeiEnumBusCommandType2["NodifyControlCreated"] = "nodify-control-created";
DDeiEnumBusCommandType2["ChangeLinePoint"] = "change-line-point";
DDeiEnumBusCommandType2["TextEditorChangeSelectPos"] = "texteditor-change-select-pos";
DDeiEnumBusCommandType2["OVSChangePosition"] = "ovs-change-position";
DDeiEnumBusCommandType2["UpdatePaperArea"] = "update-paper-area";
return DDeiEnumBusCommandType2;
})(DDeiEnumBusCommandType || {});
class DDeiBusCommand {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "code");
__publicField2(this, "name");
__publicField2(this, "desc");
this.code = props.code;
this.name = props.name;
this.desc = props.desc;
}
}
const _DDeiBusCommandAddHistroy = class _DDeiBusCommandAddHistroy2 extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置当前控件的选中状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let stage2 = bus.ddInstance.stage;
if (stage2) {
let data2 = JSON.stringify(stage2.toJSON());
let lastData = null;
if (stage2.histroyIdx != -1) {
lastData = stage2.histroy[stage2.histroyIdx];
}
if (data2 != lastData) {
_DDeiBusCommandAddHistroy2.addHistroy(stage2, data2);
}
return true;
} else {
return false;
}
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new _DDeiBusCommandAddHistroy2({ code: DDeiEnumBusCommandType.AddHistroy, name: "", desc: "" });
}
static addHistroy(stage2, data) {
stage2.addHistroy(data);
}
};
_DDeiBusCommandAddHistroy.addHistroy = debounce(_DDeiBusCommandAddHistroy.addHistroy, 200, { trailing: true, leading: false });
let DDeiBusCommandAddHistroy = _DDeiBusCommandAddHistroy;
const __vite_glob_0_0$3$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandAddHistroy,
default: DDeiBusCommandAddHistroy
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandCancelCurLevelSelectedModels extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置当前控件的选中状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let stage2 = bus.ddInstance.stage;
if (stage2) {
let ignoreModels = data == null ? void 0 : data.ignoreModels;
let optContainer = data == null ? void 0 : data.container;
if (!optContainer) {
optContainer = stage2.render.currentOperateContainer;
}
if (!optContainer) {
optContainer = stage2.layers[stage2.layerIndex];
}
if (optContainer) {
if ((data == null ? void 0 : data.curLevel) == true) {
optContainer.cancelSelectModels(null, ignoreModels);
} else {
optContainer.cancelAllLevelSelectModels(ignoreModels);
}
return true;
}
} else {
return false;
}
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandCancelCurLevelSelectedModels({ code: DDeiEnumBusCommandType.CancelCurLevelSelectedModels, name: "", desc: "" });
}
}
const __vite_glob_0_1$3$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandCancelCurLevelSelectedModels,
default: DDeiBusCommandCancelCurLevelSelectedModels
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandCenterStageWPV extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,重绘所有图形
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3;
let stage2 = bus.ddInstance.stage;
if (stage2) {
let maxOutRect = DDeiAbstractShape.getOutRectByPV(
stage2.getLayerModels()
);
let canvas = bus.ddInstance.render.canvas;
let rat1 = bus.ddInstance.render.ratio;
let stageRatio2 = stage2.getStageRatio();
let ruleDisplay;
if ((_a3 = stage2.ruler) == null ? void 0 : _a3.display) {
ruleDisplay = stage2.ruler.display;
} else if (stage2.ddInstance.ruler != null && stage2.ddInstance.ruler != void 0) {
if (typeof stage2.ddInstance.ruler == "boolean") {
ruleDisplay = stage2.ddInstance.ruler ? 1 : 0;
} else {
ruleDisplay = stage2.ddInstance.ruler.display;
}
} else {
ruleDisplay = DDeiModelArrtibuteValue.getAttrValueByState(stage2, "ruler.display", true);
}
let ruleWeight = 0;
if (ruleDisplay == 1 || ruleDisplay == "1") {
ruleWeight = 15;
}
let centerX = stage2.width / 2 - (maxOutRect.x + maxOutRect.width / 2) * stageRatio2;
let centerY = stage2.height / 2 - (maxOutRect.y + maxOutRect.height / 2) * stageRatio2;
stage2.wpv.x = -stage2.width / 2 + canvas.width / rat1 / 2 + ruleWeight + centerX;
stage2.wpv.y = -stage2.height / 2 + canvas.height / rat1 / 2 + ruleWeight + centerY;
return true;
} else {
return false;
}
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
bus.push(DDeiEnumBusCommandType.RefreshShape);
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandCenterStageWPV({ code: DDeiEnumBusCommandType.CenterStageWPV, name: "", desc: "" });
}
}
const __vite_glob_0_2$3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandCenterStageWPV,
default: DDeiBusCommandCenterStageWPV
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiRectangle = class _DDeiRectangle2 extends DDeiAbstractShape {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "border");
__publicField2(this, "fill");
__publicField2(this, "font");
__publicField2(this, "imgBase64");
__publicField2(this, "text");
__publicField2(this, "textStyle");
__publicField2(this, "modelType", "DDeiRectangle");
__publicField2(this, "baseModelType", "DDeiRectangle");
this.border = props.border ? props.border : null;
this.fill = props.fill ? props.fill : null;
this.font = props.font ? props.font : null;
this.text = props.text ? props.text : "";
this.imgBase64 = props.imgBase64 ? props.imgBase64 : "";
this.textStyle = props.textStyle ? props.textStyle : null;
}
// ============================ 静态变量 ============================
// ============================ 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static loadFromJSON(json, tempData = {}) {
let model = new _DDeiRectangle2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
if (!model.pModel) {
model.pModel = model.layer;
}
tempData[model.id] = model;
model.initPVS();
model.initRender();
return model;
}
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json, tempData = {}) {
let model = new _DDeiRectangle2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
model.initPVS();
return model;
}
// ============================ 方法 ===============================
/**
* 初始化渲染器
*/
initRender() {
DDeiConfig$1.bindRender(this);
this.render.init();
}
/**
* 返回某个点,相对于该图形的角度
*/
getPointAngle(point2) {
if (DDeiUtil$1.isPointInLine(point2, this.pvs[0], this.pvs[1])) {
return DDeiUtil$1.getLineAngle(0, 0, 0, -2);
} else if (DDeiUtil$1.isPointInLine(point2, this.pvs[1], this.pvs[2])) {
return DDeiUtil$1.getLineAngle(0, 0, 2, 0);
} else if (DDeiUtil$1.isPointInLine(point2, this.pvs[2], this.pvs[3])) {
return DDeiUtil$1.getLineAngle(0, 0, 0, 2);
} else if (DDeiUtil$1.isPointInLine(point2, this.pvs[3], this.pvs[0])) {
return DDeiUtil$1.getLineAngle(0, 0, -2, 0);
}
}
};
__publicField2(_DDeiRectangle, "ClsName", "DDeiRectangle");
let DDeiRectangle = _DDeiRectangle;
const __vite_glob_0_8$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiRectangle,
default: DDeiRectangle
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiCircle = class _DDeiCircle2 extends DDeiRectangle {
constructor() {
super(...arguments);
__publicField2(this, "modelType", "DDeiCircle");
__publicField2(this, "baseModelType", "DDeiRectangle");
}
// ============================ 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static loadFromJSON(json, tempData = {}) {
let model = new _DDeiCircle2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
if (!model.pModel) {
model.pModel = model.layer;
}
tempData[model.id] = model;
model.initRender();
return model;
}
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json) {
let shape = new _DDeiCircle2(json);
return shape;
}
};
__publicField2(_DDeiCircle, "ClsName", "DDeiCircle");
let DDeiCircle = _DDeiCircle;
const __vite_glob_0_0$2$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiCircle,
default: DDeiCircle
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiDiamond = class _DDeiDiamond2 extends DDeiRectangle {
constructor() {
super(...arguments);
__publicField2(this, "modelType", "DDeiDiamond");
__publicField2(this, "baseModelType", "DDeiRectangle");
}
/**
* 得到点在图形连接线上的投射点
* @param point 测试点
* @param distance 内外部判定区间的距离
* @param direct 方向,1外部,2内部 默认1
* @returns 投影点的坐标
*/
getProjPoint(point2, distance = { in: -5, out: 15 }, direct = 1) {
let pvs2 = [];
for (let i2 = 0; i2 < this.currentPointVectors.length; i2++) {
let s = null;
let e = null;
if (i2 == this.currentPointVectors.length - 1) {
s = this.currentPointVectors[i2];
e = this.currentPointVectors[0];
} else {
s = this.currentPointVectors[i2];
e = this.currentPointVectors[i2 + 1];
}
let p = { x: (s.x + e.x) / 2, y: (s.y + e.y) / 2 };
pvs2.push(p);
}
let x0 = point2.x;
let y0 = point2.y;
if ((pvs2 == null ? void 0 : pvs2.length) > 0) {
let st, en;
for (let j2 = 0; j2 < pvs2.length; j2++) {
let plLength = Infinity;
if (j2 == pvs2.length - 1) {
st = j2;
en = 0;
} else {
st = j2;
en = j2 + 1;
}
let x1 = pvs2[st].x;
let y1 = pvs2[st].y;
let x2 = pvs2[en].x;
let y2 = pvs2[en].y;
if (x1 == x2 && y1 == y2) {
plLength = Math.sqrt((x1 - x0) * (x1 - x0) + (y1 - y0) * (y1 - y0));
} else {
let s = (x0 - x1) * (y2 - y1) - (y0 - y1) * (x2 - x1);
let d = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);
plLength = s / d;
}
let flag = false;
if (direct == 1) {
if (plLength >= distance.in && plLength <= distance.out) {
flag = true;
}
} else if (direct == 2) {
if (plLength <= distance.in && plLength >= distance.out) {
flag = true;
}
}
if (flag) {
let lineV = new Vector3(x2, y2, 1);
let pointV = new Vector3(x0, y0, 1);
let toZeroMatrix = new Matrix3(
1,
0,
-x1,
0,
1,
-y1,
0,
0,
1
);
lineV.applyMatrix3(toZeroMatrix);
pointV.applyMatrix3(toZeroMatrix);
let lineAngle = (new Vector3(1, 0, 0).angleTo(new Vector3(lineV.x, lineV.y, 0)) * 180 / Math.PI).toFixed(4);
let angle2 = 0;
if (lineV.x >= 0 && lineV.y >= 0) {
angle2 = (lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (lineV.x <= 0 && lineV.y >= 0) {
angle2 = (lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (lineV.x <= 0 && lineV.y <= 0) {
angle2 = (-lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (lineV.x >= 0 && lineV.y <= 0) {
angle2 = (-lineAngle * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
}
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
lineV.applyMatrix3(rotateMatrix);
pointV.applyMatrix3(rotateMatrix);
if (pointV.x >= 0 && pointV.x <= lineV.x) {
let v1 = new Vector3(pointV.x, 0, 1);
angle2 = -angle2;
let rotateMatrix2 = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
v1.applyMatrix3(rotateMatrix2);
let removeMatrix = new Matrix3(
1,
0,
x1,
0,
1,
y1,
0,
0,
1
);
v1.applyMatrix3(removeMatrix);
return v1;
}
}
}
}
return null;
}
// ============================ 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static loadFromJSON(json, tempData = {}) {
let model = new _DDeiDiamond2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
if (!model.pModel) {
model.pModel = model.layer;
}
tempData[model.id] = model;
model.initRender();
return model;
}
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json) {
let shape = new _DDeiDiamond2(json);
return shape;
}
};
__publicField2(_DDeiDiamond, "ClsName", "DDeiDiamond");
let DDeiDiamond = _DDeiDiamond;
const __vite_glob_0_1$2$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiDiamond,
default: DDeiDiamond
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiLayer = class _DDeiLayer2 {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "id");
__publicField2(this, "name");
__publicField2(this, "models");
__publicField2(this, "midList");
__publicField2(this, "modelType", "DDeiLayer");
__publicField2(this, "baseModelType", "DDeiLayer");
__publicField2(this, "stage");
__publicField2(this, "index");
__publicField2(this, "background");
__publicField2(this, "display", 1);
__publicField2(this, "tempDisplay", false);
__publicField2(this, "lock", false);
__publicField2(this, "print", true);
__publicField2(this, "unicode");
__publicField2(this, "bg");
__publicField2(this, "opPoints", []);
__publicField2(this, "opLine", null);
__publicField2(this, "centerOpPoints", []);
__publicField2(this, "layoutManager");
__publicField2(this, "dragInPoints", []);
__publicField2(this, "dragOutPoints", []);
__publicField2(this, "shadowControls", []);
__publicField2(this, "modelCode", "DDeiLayer");
__publicField2(this, "modelChanged", true);
__publicField2(this, "modelNumber", 0);
this.id = props.id;
this.name = props.name;
this.models = props.models ? props.models : /* @__PURE__ */ new Map();
this.midList = props.midList ? props.midList : new Array();
this.stage = null;
this.index = -1;
this.background = props.background ? props.background : null;
this.display = props.display || props.display == 0 ? props.display : 1;
this.tempDisplay = props.tempDisplay ? props.tempDisplay : false;
this.lock = props.lock ? props.lock : false;
this.print = props.print ? props.print : true;
this.unicode = props.unicode ? props.unicode : DDeiUtil$1.getUniqueCode();
this.bg = props.bg;
}
// ============================ 静态变量 ============================
// ============================ 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static loadFromJSON(json, tempData = {}) {
var _a3;
let layer2 = new _DDeiLayer2(json);
layer2.stage = tempData["currentStage"];
tempData["currentLayer"] = layer2;
let ddInstance = (_a3 = layer2.stage) == null ? void 0 : _a3.ddInstance;
tempData[layer2.id] = layer2;
let models = /* @__PURE__ */ new Map();
let midList = layer2.midList ? layer2.midList : new Array();
for (let key in json.models) {
let item = json.models[key];
let model = ddInstance.controlModelClasses[item.modelType].loadFromJSON(item, tempData);
models.set(key, model);
if (midList.indexOf(model.id) == -1) {
midList.push(model.id);
}
}
tempData["currentLayer"] = null;
layer2.models = models;
layer2.midList = midList;
layer2.initRender();
layer2.calModelNumber();
return layer2;
}
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json) {
let layer2 = new _DDeiLayer2(json);
return layer2;
}
// ============================ 方法 ===============================
/**
* 计算当前layer的模型总数量
*/
calModelNumber() {
let num = 0;
this.midList.forEach((mid) => {
let model = this.models.get(mid);
if ((model == null ? void 0 : model.baseModelType) == "DDeiContainer") {
num += model.calModelNumber();
} else if ((model == null ? void 0 : model.baseModelType) == "DDeiTable") {
num += model.calModelNumber();
} else {
num++;
}
});
this.modelNumber = num;
return num;
}
/**
* 初始化渲染器
*/
initRender() {
DDeiConfig$1.bindRender(this);
this.render.init();
this.models.forEach((item, key) => {
item.initRender();
});
}
/**
* 获取画布缩放比率
*/
getStageRatio() {
if (this.stage) {
let stageRatio2 = parseFloat(this.stage.ratio) ? parseFloat(this.stage.ratio) : 1;
if (!stageRatio2 || isNaN(stageRatio2)) {
stageRatio2 = this.stage.ddInstance.ratio;
}
return stageRatio2;
} else {
return 1;
}
}
notifyChange() {
var _a3;
(_a3 = this.stage) == null ? void 0 : _a3.notifyChange();
}
/**
* 获取子模型
*/
getSubModels(ignoreModelIds, level = 1, rect) {
let models = [];
this.midList.forEach((mid) => {
if (ignoreModelIds && (ignoreModelIds == null ? void 0 : ignoreModelIds.indexOf(mid)) != -1) {
return;
}
let subModel = null;
if (this.models.get) {
subModel = this.models.get(mid);
} else {
subModel = this.models[mid];
}
if (subModel) {
if (!rect || subModel.isInRect(rect.x, rect.y, rect.x1, rect.y1)) {
if (level > 1 && (subModel == null ? void 0 : subModel.getSubModels)) {
let subModels = subModel.getSubModels(ignoreModelIds, level - 1, rect);
models = models.concat(subModels);
}
models.push(subModel);
}
}
});
return models;
}
/**
* 获取子模型,通过一个过滤器
*/
getSubModelsByFilter(filterName = null, ignoreModelIds, level = 1, params) {
let models = [];
this.midList.forEach((mid) => {
if (ignoreModelIds && (ignoreModelIds == null ? void 0 : ignoreModelIds.indexOf(mid)) != -1) {
return;
}
let subModel = null;
if (this.models.get) {
subModel = this.models.get(mid);
} else {
subModel = this.models[mid];
}
if (subModel) {
let filterMethod = null;
if (filterName) {
let define2 = DDeiUtil$1.getControlDefine(subModel);
if (define2 && define2.filters && define2.filters[filterName]) {
filterMethod = define2.filters[filterName];
}
}
if (!filterMethod || filterMethod(subModel, params)) {
if (level > 1 && (subModel == null ? void 0 : subModel.getSubModelsByFilter)) {
let subModels = subModel.getSubModelsByFilter(filterName, ignoreModelIds, level - 1, params);
models = models.concat(subModels);
}
models.push(subModel);
}
}
});
return models;
}
/**
* 添加模型,并维护关系
* @param model 被添加的模型
*/
addModel(model, notify = true) {
if (this.midList.indexOf(model.id) == -1) {
model.stage = this.stage;
this.models.set(model.id, model);
if (this.midList && this.midList.length > 0) {
model.zIndex = this.models.get(this.midList[this.midList.length - 1]).zIndex;
}
this.midList.push(model.id);
model.layer = this;
model.pModel = this;
this.resortModelByZIndex();
if (notify) {
this.notifyChange();
}
}
}
/**
* 移除模型,并维护关系
* @param model 被移除的模型
* @param destroy 销毁,缺省false
*/
removeModels(models, destroy = false, notify = true) {
models == null ? void 0 : models.forEach((model) => {
this.removeModel(model, destroy, false);
});
if (notify) {
this.notifyChange();
}
}
/**
* 移除所有元素
*/
clearModels(destroy = false) {
this.models.forEach((model) => {
this.removeModel(model, destroy);
});
}
cascadeRemoveSelf() {
}
/**
* 移除自身的方法
*/
destroyed() {
var _a3, _b2;
if ((_a3 = this.render) == null ? void 0 : _a3.containerViewer) {
this.render.containerViewer.remove();
delete this.render.containerViewer;
}
this.render = null;
(_b2 = this.models) == null ? void 0 : _b2.forEach((item, key) => {
item == null ? void 0 : item.destroyed();
});
}
/**
* 移除渲染器
*/
destroyRender() {
var _a3, _b2;
if ((_a3 = this.render) == null ? void 0 : _a3.containerViewer) {
this.render.containerViewer.remove();
delete this.render.containerViewer;
}
(_b2 = this.models) == null ? void 0 : _b2.forEach((item, key) => {
item == null ? void 0 : item.destroyRender();
});
this.render = null;
}
/**
* 移除模型,并维护关系
* @param model 被移除的模型
* @param destroy 销毁,缺省false
*/
removeModel(model, destroy = false, notify = true) {
var _a3;
this.models.delete(model.id);
let idx = this.midList.indexOf(model.id);
if (idx != -1) {
this.midList.splice(idx, 1);
}
if (destroy) {
model.destroyed();
}
model.layer = null;
model.stage = null;
model.render = null;
if ((_a3 = this.stage) == null ? void 0 : _a3.render) {
this.stage.render.refreshJumpLine = false;
}
if (notify) {
this.notifyChange();
}
}
/**
* 根据ID删除元素
*/
removeModelById(ids, notify = true) {
ids == null ? void 0 : ids.forEach((id) => {
let model = this.getModelById(id);
if (model) {
this.removeModel(model);
}
});
this.models.forEach((model) => {
if (model.baseModelType == "DDeiContainer") {
model.removeModelById(ids);
}
});
if (notify) {
this.notifyChange();
}
}
/**
* 根据基础模型获取控件
* @param bmt 基础模型类别
*/
getModelsByBaseType(bmt) {
let returnValues = [];
this.midList.forEach((mid) => {
let model = this.models.get(mid);
if ((model == null ? void 0 : model.baseModelType) == bmt) {
returnValues.push(model);
} else if ((model == null ? void 0 : model.baseModelType) == "DDeiContainer") {
let datas2 = model.getModelsByBaseType(bmt);
datas2.forEach((dt) => {
returnValues.push(dt);
});
}
});
return returnValues;
}
/**
* 获取当前图形的除layer的所有父节点对象
*/
getParents() {
return [];
}
/**
* 将控件设置到顶层
*/
pushTop(models, notify = true) {
models.forEach((item) => {
let lastItem = this.models.get(this.midList[this.midList.length - 1]);
if (lastItem.id != item.id) {
let lastIndex = lastItem.zIndex ? lastItem == null ? void 0 : lastItem.zIndex : 0;
item.zIndex = lastIndex + 1;
}
});
this.resortModelByZIndex();
if (notify) {
this.notifyChange();
}
}
/**
* 将控件设置到底层
*/
pushBottom(models, notify = true) {
models.forEach((item) => {
item.zIndex = null;
let oldIdIndex = this.midList.indexOf(item.id);
if (oldIdIndex > 0) {
this.midList.splice(oldIdIndex, 1);
this.midList.splice(0, 0, item.id);
}
});
this.resortModelByZIndex();
if (notify) {
this.notifyChange();
}
}
/**
* 将控件设置到上一层
*/
pushUp(models, notify = true) {
models.forEach((item) => {
if (!item.zIndex) {
item.zIndex = 1;
} else {
item.zIndex++;
}
});
this.resortModelByZIndex();
if (notify) {
this.notifyChange();
}
}
/**
* 将控件设置到下一层
*/
pushDown(models, notify = true) {
models.forEach((item) => {
if (!item.zIndex || item.zIndex <= 1) {
item.zIndex = null;
let oldIdIndex = this.midList.indexOf(item.id);
if (oldIdIndex > 0) {
let temp = this.midList[oldIdIndex];
this.midList[oldIdIndex] = this.midList[oldIdIndex - 1];
this.midList[oldIdIndex - 1] = temp;
}
} else {
item.zIndex--;
}
});
this.resortModelByZIndex();
if (notify) {
this.notifyChange();
}
}
/**
* 按照Zindex的顺序,从小到大排列,并重新设置子元素的zindex确保其连续,最后将排序后的List设置成新的midList
*/
resortModelByZIndex() {
let newMidList = new Array();
let hadZIndexList = new Array();
for (let mg = 0; mg < this.midList.length; mg++) {
let item = this.models.get(this.midList[mg]);
if (item.zIndex && item.zIndex > 0) {
let insertIndex = hadZIndexList.length;
for (let j2 = 0; j2 < hadZIndexList.length; j2++) {
if (this.models.get(hadZIndexList[j2]).zIndex > item.zIndex) {
insertIndex = j2;
break;
}
}
hadZIndexList.splice(insertIndex, 0, item.id);
} else {
newMidList.push(item.id);
}
}
this.midList = newMidList.concat(hadZIndexList);
}
/**
* 获取当前图形的绝对旋转坐标值
*/
getAbsRotate() {
return 0;
}
/**
* 取消选择控件,默认取消所有
*/
cancelSelectModels(models, ignoreModels) {
if (!models) {
models = Array.from(this.models.values());
}
models.forEach((item) => {
if (!ignoreModels || (ignoreModels == null ? void 0 : ignoreModels.indexOf(item)) == -1) {
item.setState(DDeiEnumControlState.DEFAULT);
}
});
}
/**
* 取消选择控件,默认取消所有
*/
cancelAllLevelSelectModels(ignoreModels) {
this.models.forEach((item) => {
if (!ignoreModels || (ignoreModels == null ? void 0 : ignoreModels.indexOf(item)) == -1) {
item.setState(DDeiEnumControlState.DEFAULT);
}
if (item.baseModelType == "DDeiContainer") {
item.cancelAllLevelSelectModels(ignoreModels);
}
});
}
/**
* 获取绝对的控件坐标
*/
getAbsPosition(pm) {
return { x: 0, y: 0 };
}
getPosition() {
return { x: 0, y: 0 };
}
/**
* 根据坐标获取操作点
* @param x
* @param y
* @returns 操作点
*/
getOpPointByPos(x2 = 0, y2 = 0) {
var _a3, _b2, _c2, _d2;
let minLength = Infinity;
let minPoint = null;
if (x2 && y2 && (((_a3 = this.opPoints) == null ? void 0 : _a3.length) > 0 || ((_b2 = this.centerOpPoints) == null ? void 0 : _b2.length) > 0)) {
for (let i2 = 0; i2 < ((_c2 = this.opPoints) == null ? void 0 : _c2.length); i2++) {
let point2 = this.opPoints[i2];
let absX = Math.abs(x2 - point2.x);
let absY = Math.abs(y2 - point2.y);
if (absX <= 8 && absY <= 8) {
if (absX + absY < minLength) {
minLength = absX + absY;
minPoint = point2;
}
}
}
for (let i2 = 0; i2 < ((_d2 = this.centerOpPoints) == null ? void 0 : _d2.length); i2++) {
let point2 = this.centerOpPoints[i2];
let absX = Math.abs(x2 - point2.x);
let absY = Math.abs(y2 - point2.y);
if (absX <= 8 && absY <= 8) {
if (absX + absY < minLength) {
minLength = absX + absY;
minPoint = point2;
}
}
}
}
return minPoint;
}
/**
* 获取某个选中区域的所有控件
* @param area 选中区域
* @returns
*/
findModelsByArea(x2 = void 0, y2 = void 0, width = 0, height = 0) {
let controls2 = [];
this.models.forEach((item) => {
if (DDeiAbstractShape.isInsidePolygon(item.pvs, { x: x2, y: y2 })) {
controls2.push(item);
}
});
return controls2;
}
/**
* 修改上层模型大小
*/
changeParentsBounds() {
return true;
}
/**
* 获取实际的内部容器控件
* @param x 相对路径坐标
* @param y 相对路径坐标
* @return 容器控件根据布局的模式不同返回不同的内部控件,普通控件返回null
*/
getAccuContainer() {
return this;
}
/**
* 获取实际的内部容器控件
* @param x 相对路径坐标
* @param y 相对路径坐标
* @return 容器控件根据布局的模式不同返回不同的内部控件,普通控件返回null
*/
getAccuContainerByPos(x2, y2) {
return this;
}
/**
* 获取选中状态的所有控件
* @returns
*/
getSelectedModels() {
let controls2 = /* @__PURE__ */ new Map();
this.models.forEach((item, key) => {
if (item.state == DDeiEnumControlState.SELECTED) {
controls2.set(item.id, item);
}
});
return controls2;
}
/**
* 设置当前模型为被修改状态
*/
setModelChanged() {
this.modelChanged = true;
}
/**
* 判断当前模型是否已被修改
*/
isModelChanged() {
return this.modelChanged;
}
/**
* 根据ID获取模型
* @param id 模型id
*/
getModelById(id) {
let reutrnModel = null;
if (id) {
if (this.models.has(id)) {
reutrnModel = this.models.get(id);
} else {
this.models.forEach((item) => {
let container2 = item.getAccuContainer();
if (container2) {
let rm = container2.getModelById(id);
if (rm) {
reutrnModel = rm;
}
}
});
}
}
if (!reutrnModel) {
reutrnModel = null;
}
return reutrnModel;
}
/**
* 将模型转换为JSON
*/
toJSON() {
var _a3, _b2, _c2, _d2, _e2, _f;
let json = new Object();
let skipFields = (_a3 = DDeiConfig$1.SERI_FIELDS[this.modelType]) == null ? void 0 : _a3.SKIP;
if (!((skipFields == null ? void 0 : skipFields.length) > 0)) {
skipFields = (_b2 = DDeiConfig$1.SERI_FIELDS[this.baseModelType]) == null ? void 0 : _b2.SKIP;
}
if (!((skipFields == null ? void 0 : skipFields.length) > 0)) {
skipFields = (_c2 = DDeiConfig$1.SERI_FIELDS["AbstractShape"]) == null ? void 0 : _c2.SKIP;
}
let toJSONFields = (_d2 = DDeiConfig$1.SERI_FIELDS[this.modelType]) == null ? void 0 : _d2.TOJSON;
if (!((toJSONFields == null ? void 0 : toJSONFields.length) > 0)) {
toJSONFields = (_e2 = DDeiConfig$1.SERI_FIELDS[this.baseModelType]) == null ? void 0 : _e2.TOJSON;
}
if (!((toJSONFields == null ? void 0 : toJSONFields.length) > 0)) {
toJSONFields = (_f = DDeiConfig$1.SERI_FIELDS["AbstractShape"]) == null ? void 0 : _f.TOJSON;
}
for (let i2 in this) {
if (!skipFields || (skipFields == null ? void 0 : skipFields.indexOf(i2)) == -1) {
if (toJSONFields && toJSONFields.indexOf(i2) != -1 && this[i2]) {
if (Array.isArray(this[i2])) {
let array = [];
this[i2].forEach((element) => {
if (element == null ? void 0 : element.toJSON) {
array.push(element.toJSON());
} else {
array.push(element);
}
});
json[i2] = array;
} else if (this[i2].set && this[i2].has) {
let map = {};
this[i2].forEach((element, key) => {
if (element == null ? void 0 : element.toJSON) {
map[key] = element.toJSON();
} else {
map[key] = element;
}
});
json[i2] = map;
} else if (this[i2].toJSON) {
json[i2] = this[i2].toJSON();
} else {
json[i2] = this[i2];
}
} else {
json[i2] = this[i2];
}
}
}
return json;
}
};
__publicField2(_DDeiLayer, "ClsName", "DDeiLayer");
let DDeiLayer = _DDeiLayer;
const __vite_glob_0_2$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiLayer,
default: DDeiLayer
}, Symbol.toStringTag, { value: "Module" }));
const calAutoLinePath = function(sd, ed, obis, extConfig) {
var _a3, _b2;
let startTime = (/* @__PURE__ */ new Date()).getTime();
if (!sd.direct) {
sd.direct = 3;
switch (sd.angle) {
case -90:
sd.direct = 1;
break;
case 0:
sd.direct = 2;
break;
case 90:
sd.direct = 3;
break;
case 180:
sd.direct = 4;
break;
}
}
if (!ed.direct) {
ed.direct = 1;
switch (ed.angle) {
case -90:
ed.direct = 1;
break;
case 0:
ed.direct = 2;
break;
case 90:
ed.direct = 3;
break;
case 180:
ed.direct = 4;
break;
}
}
if (!extConfig) {
extConfig = {};
}
if (!extConfig.recomWeight) {
extConfig.recomWeight = 100;
}
if (!extConfig.rectMidWeight) {
extConfig.rectMidWeight = 50;
}
let outRects = [];
let extLines = [];
let corssPoints = [];
ed.point.isEnd = true;
ed.point.direct = ed.direct;
sd.point.direct = sd.direct;
sd.point.isStart = true;
corssPoints.push(sd.point);
corssPoints.push(ed.point);
genSEExtLine(sd, corssPoints, extLines);
genSEExtLine(ed, corssPoints, extLines);
getAutoLineItemExtPoints(corssPoints, outRects, extLines, obis);
for (let i2 = 0; i2 < outRects.length; i2++) {
let octi = outRects[i2];
for (let j2 = 1; j2 < outRects.length; j2++) {
let octj = outRects[j2];
if (i2 != j2 && octi.isStartOrEnd && octj.isStartOrEnd) {
if (octj.y1 < octi.y) {
let mdy = octj.y1 + (octi.y - octj.y1) / 2;
extLines.push([{ x: octj.x - 5e4, y: mdy, prio: extConfig == null ? void 0 : extConfig.rectMidWeight }, { x: octj.x + 5e4, y: mdy }]);
} else if (octj.y > octi.y1) {
let mdy = octi.y1 + (octj.y - octi.y1) / 2;
extLines.push([{ x: octj.x - 5e4, y: mdy, prio: extConfig == null ? void 0 : extConfig.rectMidWeight }, { x: octj.x + 5e4, y: mdy }]);
}
if (octj.x1 < octi.x) {
let mdx = octj.x1 + (octi.x - octj.x1) / 2;
extLines.push([{ x: mdx, y: octj.y - 5e4, prio: extConfig == null ? void 0 : extConfig.rectMidWeight }, { x: mdx, y: octj.y + 5e4 }]);
} else if (octj.x > octi.x1) {
let mdx = octi.x1 + (octj.x - octi.x1) / 2;
extLines.push([{ x: mdx, y: octj.y - 5e4, prio: extConfig == null ? void 0 : extConfig.rectMidWeight }, { x: mdx, y: octj.y + 5e4 }]);
}
}
}
}
(_a3 = extConfig == null ? void 0 : extConfig.recommendPaths) == null ? void 0 : _a3.forEach((point2) => {
if (point2.type == "x") {
extLines.push([{ x: point2.x, y: point2.y - 5e4, isRecommend: 1, prio: extConfig.recomWeight, color: "blue" }, { x: point2.x, y: point2.y + 5e4 }]);
} else if (point2.type == "y") {
extLines.push([{ x: point2.x - 5e4, y: point2.y, isRecommend: 1, prio: extConfig.recomWeight, color: "blue" }, { x: point2.x + 5e4, y: point2.y }]);
}
});
(_b2 = extConfig == null ? void 0 : extConfig.forcePaths) == null ? void 0 : _b2.forEach((point2) => {
if (point2.x) {
extLines.push([{ x: point2.x, y: point2.y - 5e4, isForce: 1, prio: 9999, color: "orange" }, { x: point2.x, y: point2.y + 5e4 }]);
} else if (point2.y) {
extLines.push([{ x: point2.x - 5e4, y: point2.y, isForce: 1, prio: 9999, color: "orange" }, { x: point2.x + 5e4, y: point2.y }]);
}
});
for (let i2 = 0; i2 < extLines.length; i2++) {
let linei = extLines[i2];
let lineil = [linei[0]];
if (linei[0].x == linei[1].x) {
if (linei[0].y >= linei[1].y) {
lineil.push({ x: linei[1].x, y: linei[1].y - 1e3 });
} else {
lineil.push({ x: linei[1].x, y: linei[1].y + 1e3 });
}
} else if (linei[0].y == linei[1].y) {
if (linei[0].x >= linei[1].x) {
lineil.push({ x: linei[1].x - 1e3, y: linei[1].y });
} else {
lineil.push({ x: linei[1].x + 1e3, y: linei[1].y });
}
}
for (let j2 = i2 + 1; j2 < extLines.length; j2++) {
let linej = extLines[j2];
let linejl = [linej[0]];
if (linej[0].x == linej[1].x) {
if (linej[0].y >= linej[1].y) {
linejl.push({ x: linej[1].x, y: linej[1].y - 1e3 });
} else {
linejl.push({ x: linej[1].x, y: linej[1].y + 1e3 });
}
} else if (linej[0].y == linej[1].y) {
if (linej[0].x >= linej[1].x) {
linejl.push({ x: linej[1].x - 1e3, y: linej[1].y });
} else {
linejl.push({ x: linej[1].x + 1e3, y: linej[1].y });
}
}
let cp = getLineCorssPoint(lineil[0], lineil[1], linejl[0], linejl[1]);
if (cp) {
cp.prio = (lineil[0].prio ? lineil[0].prio : 1) + (linejl[0].prio ? linejl[0].prio : 1);
corssPoints.push(cp);
}
}
}
let yIntIndex = {};
let xIntIndex = {};
corssPoints.forEach((point2) => {
let intX = parseInt(point2.x);
let intY = parseInt(point2.y);
point2.intX = intX;
point2.intY = intY;
if (!yIntIndex[intY]) {
yIntIndex[intY] = [];
}
let arr = yIntIndex[intY];
let idx = -1;
for (let i2 = 0; i2 < arr.length; i2++) {
if (intX < parseInt(arr[i2].x)) {
arr.splice(i2, 0, point2);
idx = i2;
break;
} else if (intX == parseInt(arr[i2].x)) {
if (point2.isStart)
arr[i2].isStart = point2.isStart;
if (point2.isEnd)
arr[i2].isEnd = point2.isEnd;
if (point2.prio) {
arr[i2].prio = (arr[i2].prio ? arr[i2].prio : 0) + point2.prio;
}
idx = i2;
break;
}
}
if (idx == -1) {
arr.push(point2);
}
if (!xIntIndex[intX]) {
xIntIndex[intX] = [];
}
arr = xIntIndex[intX];
idx = -1;
for (let i2 = 0; i2 < arr.length; i2++) {
if (intY < parseInt(arr[i2].y)) {
arr.splice(i2, 0, point2);
idx = i2;
break;
} else if (intY == parseInt(arr[i2].y)) {
if (point2.isStart)
arr[i2].isStart = point2.isStart;
if (point2.isEnd)
arr[i2].isEnd = point2.isEnd;
if (point2.prio) {
arr[i2].prio = (arr[i2].prio ? arr[i2].prio : 0) + point2.prio;
}
idx = i2;
break;
}
}
if (idx == -1) {
arr.push(point2);
}
});
let buildPointTime = (/* @__PURE__ */ new Date()).getTime();
let successPaths = [];
getLookForPath(null, sd.point, ed.point, 0, outRects, xIntIndex, yIntIndex, 0, 0, "root", [], successPaths);
let lookForTime = (/* @__PURE__ */ new Date()).getTime();
let minTurnNum = -1, minDistance = -1, maxPrio = 0;
let candidatePaths = [];
for (let i2 = 0; i2 < successPaths.length; i2++) {
if (minTurnNum == -1 || minTurnNum > successPaths[i2].turnNum) {
minTurnNum = successPaths[i2].turnNum;
candidatePaths = [successPaths[i2].pathPoints];
minDistance = successPaths[i2].distance;
maxPrio = successPaths[i2].prio;
} else if (minTurnNum == successPaths[i2].turnNum) {
if (maxPrio < successPaths[i2].prio) {
minTurnNum = successPaths[i2].turnNum;
candidatePaths = [successPaths[i2].pathPoints];
minDistance = successPaths[i2].distance;
candidatePaths.push(successPaths[i2].pathPoints);
maxPrio = successPaths[i2].prio;
} else if (maxPrio == successPaths[i2].prio && parseInt(minDistance) > parseInt(successPaths[i2].distance)) {
minTurnNum = successPaths[i2].turnNum;
candidatePaths = [successPaths[i2].pathPoints];
minDistance = successPaths[i2].distance;
candidatePaths.push(successPaths[i2].pathPoints);
} else if (maxPrio == successPaths[i2].prio && parseInt(minDistance) == parseInt(successPaths[i2].distance)) {
candidatePaths.push(successPaths[i2].pathPoints);
}
}
}
let newPaths = [];
for (let i2 = 0; i2 < candidatePaths.length; i2++) {
let paths = candidatePaths[i2];
let upX = paths[0].x, upY = paths[0].y;
let upSX = paths[0].x, upSY = paths[0].y;
let newPath = [paths[0]], d = 0;
for (let j2 = 1; j2 < paths.length; j2++) {
let cp = paths[j2];
if (!d) {
if (cp.intX == parseInt(upSX) && cp.intY == parseInt(upSY))
;
else if (cp.intX == parseInt(upSX)) {
d = 2;
} else if (cp.intY == parseInt(upSY)) {
d = 1;
}
} else if (d == 1) {
if (cp.intY != parseInt(upSY)) {
d = 2;
upSX = cp.x;
upSY = cp.y;
newPath.push({ x: upX, y: upY });
}
} else if (d == 2) {
if (cp.intX != parseInt(upSX)) {
d = 1;
upSX = cp.x;
upSY = cp.y;
newPath.push({ x: upX, y: upY });
}
}
upX = cp.x;
upY = cp.y;
}
if (parseInt(upX) != newPath[newPath.length - 1].intX || parseInt(upY) != newPath[newPath.length - 1].intY) {
newPath.push({ x: upX, y: upY });
}
newPaths.push(newPath);
}
let pathPoints = [];
if (newPaths.length > 0) {
pathPoints = newPaths[0];
let minDiff = Infinity, bestI = -1;
for (let i2 = 0; i2 < newPaths.length; i2++) {
let paths = newPaths[i2];
if (paths.length > 2) {
let maxDiffY = 0, maxDiffX = 0;
let d = paths[0].intX == paths[1].intX ? 2 : 1;
for (let j2 = 2; j2 < paths.length; j2++) {
if (d == 2) {
if (maxDiffY < Math.abs(paths[j2 - 2].y - paths[j2].y)) {
maxDiffY = Math.abs(paths[j2 - 2].y - paths[j2].y);
}
} else {
if (maxDiffX < Math.abs(paths[j2 - 2].x - paths[j2].x)) {
maxDiffX = Math.abs(paths[j2 - 2].x - paths[j2].x);
}
}
}
if (minDiff > maxDiffY + maxDiffX) {
minDiff = maxDiffY + maxDiffX;
bestI = i2;
}
}
}
pathPoints = newPaths[bestI];
}
let endTime = (/* @__PURE__ */ new Date()).getTime();
return { corssPoints, pathPoints, extLines, totalTime: endTime - startTime, lookForTime: lookForTime - buildPointTime, selectPathTime: endTime - lookForTime, buildPointTime: buildPointTime - startTime };
};
const getLookForPath = function(upPoint, curPoint, endPoint, fromDirect, outRects, xIntIndex, yIntIndex, turnNum, distance, fullpath, passPoints, successPaths) {
let directSortList = [1, 2, 3, 4];
if (!curPoint) {
return { state: -1, end: 1, fullpath };
}
if (turnNum >= 5 || turnNum > endPoint.minTurnNum) {
return { state: -1 };
}
let intX = curPoint.intX;
let intY = curPoint.intY;
if (isNaN(intX) || isNaN(intY)) {
return { state: -1, end: 1, fullpath };
}
let xyIndex = curPoint.xyIndex;
if (!xyIndex) {
xyIndex = xIntIndex[intX].indexOf(curPoint);
curPoint.xyIndex = xyIndex;
}
let yxIndex = curPoint.yxIndex;
if (!yxIndex) {
yxIndex = yIntIndex[intY].indexOf(curPoint);
curPoint.yxIndex = yxIndex;
}
let intXEnd = endPoint.intX;
let intYEnd = endPoint.intY;
if (xyIndex == -1 || yxIndex == -1) {
return { state: -1, end: 1, fullpath };
} else if (passPoints.indexOf(curPoint) != -1) {
return { state: -1, end: 1, fullpath };
} else if (upPoint) {
let obiLine = { x1: upPoint.intX, y1: upPoint.intY, x2: intX, y2: intY };
let isCorss = isCorssRect(obiLine, upPoint, curPoint, outRects);
if (isCorss) {
return { state: 0, close: 1, fullpath };
}
}
if (curPoint == endPoint || curPoint.isEnd || intXEnd == intX && intYEnd == intY) {
endPoint.minTurnNum = Math.min(endPoint.minTurnNum ? endPoint.minTurnNum : 10, turnNum);
let prio = 0;
passPoints.forEach((pt) => {
prio += pt.prio ? pt.prio : 0;
});
successPaths.push({ fullpath, turnNum, distance, prio, pathPoints: [...passPoints, curPoint] });
return { state: 1, end: 1, fullpath };
}
let allClose = true;
directSortList.forEach((searchDirect) => {
let isClose = deepLookForByDirect(searchDirect);
if (!isClose) {
allClose = false;
}
});
function deepLookForByDirect(direct) {
switch (direct) {
case 1: {
if (!curPoint.upClose) {
let nextPointXYIndex = xyIndex - 1;
if (nextPointXYIndex < 0) {
curPoint.upClose = 1;
return 1;
} else if (endPoint.direct == 3 && !curPoint.isStart && intYEnd > intY) {
curPoint.upClose = 1;
return 1;
} else {
let nextPoint = xIntIndex[intX][nextPointXYIndex];
let nextTurnNum = fromDirect == 0 || fromDirect == 3 ? turnNum : turnNum + 1;
let nextDistance = distance + (nextPoint ? Math.abs(nextPoint.y - intY) : 0);
let nextPointResult = getLookForPath(curPoint, nextPoint, endPoint, 3, outRects, xIntIndex, yIntIndex, nextTurnNum, nextDistance, fullpath + "-up", [...passPoints, curPoint], successPaths);
if ((nextPointResult == null ? void 0 : nextPointResult.close) == 1 || (nextPointResult == null ? void 0 : nextPointResult.state) == -1) {
return 1;
}
}
} else {
return 1;
}
break;
}
case 3: {
if (!curPoint.downClose) {
let nextPointXYIndex = xyIndex + 1;
if (nextPointXYIndex >= xIntIndex[intX].length) {
curPoint.downClose = 1;
return 1;
} else if (endPoint.direct == 1 && !curPoint.isStart && intYEnd < intY) {
curPoint.downClose = 1;
return 1;
} else {
let nextPoint = xIntIndex[intX][nextPointXYIndex];
let nextTurnNum = fromDirect == 0 || fromDirect == 1 ? turnNum : turnNum + 1;
let nextDistance = distance + (nextPoint ? Math.abs(nextPoint.y - intY) : 0);
let nextPointResult = getLookForPath(curPoint, nextPoint, endPoint, 1, outRects, xIntIndex, yIntIndex, nextTurnNum, nextDistance, fullpath + "-down", [...passPoints, curPoint], successPaths);
if ((nextPointResult == null ? void 0 : nextPointResult.close) == 1 || (nextPointResult == null ? void 0 : nextPointResult.state) == -1) {
return 1;
}
}
} else {
return 1;
}
break;
}
case 4: {
if (!curPoint.leftClose) {
let nextPointYXIndex = yxIndex - 1;
if (nextPointYXIndex < 0) {
curPoint.leftClose = 1;
return 1;
} else if (endPoint.direct == 2 && !curPoint.isStart && intXEnd > intX) {
curPoint.leftClose = 1;
return 1;
} else {
let nextPoint = yIntIndex[intY][nextPointYXIndex];
let nextTurnNum = fromDirect == 0 || fromDirect == 2 ? turnNum : turnNum + 1;
let nextDistance = distance + (nextPoint ? Math.abs(nextPoint.x - intX) : 0);
let nextPointResult = getLookForPath(curPoint, nextPoint, endPoint, 2, outRects, xIntIndex, yIntIndex, nextTurnNum, nextDistance, fullpath + "-left", [...passPoints, curPoint], successPaths);
if ((nextPointResult == null ? void 0 : nextPointResult.close) == 1 || (nextPointResult == null ? void 0 : nextPointResult.state) == -1) {
return 1;
}
}
} else {
return 1;
}
}
case 2: {
if (!curPoint.rightClose) {
let nextPointYXIndex = yxIndex + 1;
if (nextPointYXIndex >= yIntIndex[intY].length) {
curPoint.rightClose = 1;
return 1;
} else if (endPoint.direct == 4 && !curPoint.isStart && intXEnd < intX) {
curPoint.rightClose = 1;
return 1;
} else {
let nextPoint = yIntIndex[intY][nextPointYXIndex];
let nextTurnNum = fromDirect == 0 || fromDirect == 4 ? turnNum : turnNum + 1;
let nextDistance = distance + (nextPoint ? Math.abs(nextPoint.x - intX) : 0);
let nextPointResult = getLookForPath(curPoint, nextPoint, endPoint, 4, outRects, xIntIndex, yIntIndex, nextTurnNum, nextDistance, fullpath + "-right", [...passPoints, curPoint], successPaths);
if ((nextPointResult == null ? void 0 : nextPointResult.close) == 1 || (nextPointResult == null ? void 0 : nextPointResult.state) == -1) {
return 1;
}
}
} else {
return 1;
}
break;
}
}
}
if (allClose) {
return { state: -1, close: 1, fullpath };
}
return { state: 0, fullpath };
};
const genSEExtLine = function(ed, corssPoints, extLines) {
var _a3, _b2, _c2, _d2;
switch (ed.direct) {
case 1:
corssPoints.push({ x: ed.point.x, y: ed.point.y - (((_a3 = ed.rect) == null ? void 0 : _a3.height) > 0 ? ed.rect.height / 4 : 50) });
extLines.push([{ x: ed.point.x, y: ed.point.y }, { x: ed.point.x, y: ed.point.y - 5e4 }]);
if (!ed.rect) {
extLines.push([{ x: ed.point.x - 5e4, y: ed.point.y }, { x: ed.point.x + 5e4, y: ed.point.y }]);
}
break;
case 2:
corssPoints.push({ y: ed.point.y, x: ed.point.x + (((_b2 = ed.rect) == null ? void 0 : _b2.width) > 0 ? ed.rect.width / 4 : 50) });
extLines.push([{ x: ed.point.x, y: ed.point.y }, { x: ed.point.x + 5e4, y: ed.point.y }]);
if (!ed.rect) {
extLines.push([{ x: ed.point.x, y: ed.point.y - 5e4 }, { x: ed.point.x, y: ed.point.y + 5e4 }]);
}
break;
case 3:
corssPoints.push({ x: ed.point.x, y: ed.point.y + (((_c2 = ed.rect) == null ? void 0 : _c2.height) > 0 ? ed.rect.height / 4 : 50) });
extLines.push([{ x: ed.point.x, y: ed.point.y }, { x: ed.point.x, y: ed.point.y + 5e4 }]);
if (!ed.rect) {
extLines.push([{ x: ed.point.x - 5e4, y: ed.point.y }, { x: ed.point.x + 5e4, y: ed.point.y }]);
}
break;
case 4:
corssPoints.push({ y: ed.point.y, x: ed.point.x - (((_d2 = ed.rect) == null ? void 0 : _d2.width) > 0 ? ed.rect.width / 4 : 50) });
extLines.push([{ x: ed.point.x, y: ed.point.y }, { x: ed.point.x - 5e4, y: ed.point.y }]);
if (!ed.rect) {
extLines.push([{ x: ed.point.x, y: ed.point.y - 5e4 }, { x: ed.point.x, y: ed.point.y + 5e4 }]);
}
break;
}
};
const getAutoLineItemExtPoints = function(corssPoints, outRects, extLines, dbis) {
let outRectExtRate = 0.25;
dbis.forEach((dbi) => {
let outRect = pvsToOutRect(dbi.points);
if (dbi.isStartOrEnd) {
outRect.isStartOrEnd = true;
let perWidth = outRect.width * outRectExtRate;
let perHeight = outRect.height * outRectExtRate;
dbi.points.forEach((point2) => {
corssPoints.push({ x: point2.x, y: point2.y });
});
corssPoints.push({ x: outRect.x - perWidth, y: outRect.y });
corssPoints.push({ x: outRect.x - perWidth, y: outRect.y + outRect.height * 0.5 });
corssPoints.push({ x: outRect.x - perWidth, y: outRect.y1 });
extLines.push([{ x: outRect.x - perWidth, y: outRect.y - 5e4 }, { x: outRect.x - perWidth, y: outRect.y + 5e4 }]);
extLines.push([{ x: outRect.x, y: outRect.y }, { x: outRect.x - perWidth, y: outRect.y }]);
extLines.push([{ x: outRect.x, y: outRect.y + outRect.height * 0.5 }, { x: outRect.x - perWidth, y: outRect.y + outRect.height * 0.5 }]);
extLines.push([{ x: outRect.x, y: outRect.y1 }, { x: outRect.x - perWidth, y: outRect.y1 }]);
corssPoints.push({ x: outRect.x1 + perWidth, y: outRect.y });
corssPoints.push({ x: outRect.x1 + perWidth, y: outRect.y + outRect.height * 0.5 });
corssPoints.push({ x: outRect.x1 + perWidth, y: outRect.y1 });
extLines.push([{ x: outRect.x1 + perWidth, y: outRect.y - 5e4 }, { x: outRect.x1 + perWidth, y: outRect.y + 5e4 }]);
extLines.push([{ x: outRect.x1, y: outRect.y }, { x: outRect.x1 + perWidth, y: outRect.y }]);
extLines.push([{ x: outRect.x1, y: outRect.y + outRect.height * 0.5 }, { x: outRect.x1 + perWidth, y: outRect.y + outRect.height * 0.5 }]);
extLines.push([{ x: outRect.x1, y: outRect.y1 }, { x: outRect.x1 + perWidth, y: outRect.y1 }]);
corssPoints.push({ x: outRect.x, y: outRect.y - perHeight });
corssPoints.push({ x: outRect.x + outRect.width / 2, y: outRect.y - perHeight });
corssPoints.push({ x: outRect.x1, y: outRect.y - perHeight });
extLines.push([{ x: outRect.x - 5e4, y: outRect.y - perHeight }, { x: outRect.x + 5e4, y: outRect.y - perHeight }]);
extLines.push([{ x: outRect.x, y: outRect.y }, { x: outRect.x, y: outRect.y - perHeight }]);
extLines.push([{ x: outRect.x + outRect.width / 2, y: outRect.y }, { x: outRect.x + outRect.width / 2, y: outRect.y - perHeight }]);
extLines.push([{ x: outRect.x1, y: outRect.y }, { x: outRect.x1, y: outRect.y - perHeight }]);
corssPoints.push({ x: outRect.x, y: outRect.y1 + perHeight });
corssPoints.push({ x: outRect.x + outRect.width / 2, y: outRect.y1 + perHeight });
corssPoints.push({ x: outRect.x1, y: outRect.y1 + perHeight });
extLines.push([{ x: outRect.x - 5e4, y: outRect.y1 + perHeight }, { x: outRect.x + 5e4, y: outRect.y1 + perHeight }]);
extLines.push([{ x: outRect.x, y: outRect.y1 }, { x: outRect.x, y: outRect.y1 + perHeight }]);
extLines.push([{ x: outRect.x + outRect.width / 2, y: outRect.y1 }, { x: outRect.x + outRect.width / 2, y: outRect.y1 + perHeight }]);
extLines.push([{ x: outRect.x1, y: outRect.y1 }, { x: outRect.x1, y: outRect.y1 + perHeight }]);
}
outRects.push(outRect);
});
};
const isCorssRect = function(obiLine, spt, ept, outRects) {
for (let o = 0; o < outRects.length; o++) {
let outRect = outRects[o];
let l2;
l2 = { x1: parseInt(outRect.x), y1: parseInt(outRect.y), x2: parseInt(outRect.x1), y2: parseInt(outRect.y) };
if (isLineCross(obiLine, l2)) {
if (!ept.isEnd && !spt.isStart) {
return true;
} else {
if (ept.isEnd && ept.intY == l2.y2 && spt.intY < l2.y2)
;
else if (spt.isStart && spt.intY == l2.y2 && ept.intY < l2.y2)
;
else {
return true;
}
}
}
l2 = { x1: parseInt(outRect.x), y1: parseInt(outRect.y1), x2: parseInt(outRect.x1), y2: parseInt(outRect.y1) };
if (isLineCross(obiLine, l2)) {
if (!ept.isEnd && !spt.isStart) {
return true;
} else {
if (ept.isEnd && ept.intY == l2.y2 && spt.intY > l2.y2)
;
else if (spt.isStart && spt.intY == l2.y2 && ept.intY > l2.y2)
;
else {
return true;
}
}
}
l2 = { x1: parseInt(outRect.x), y1: parseInt(outRect.y), x2: parseInt(outRect.x), y2: parseInt(outRect.y1) };
if (isLineCross(obiLine, l2)) {
if (!ept.isEnd && !spt.isStart) {
return true;
} else {
if (ept.isEnd && ept.intX == l2.x2 && spt.intX < l2.x2)
;
else if (spt.isStart && spt.intX == l2.x2 && ept.intX < l2.x2)
;
else {
return true;
}
}
}
l2 = { x1: parseInt(outRect.x1), y1: parseInt(outRect.y), x2: parseInt(outRect.x1), y2: parseInt(outRect.y1) };
if (isLineCross(obiLine, l2)) {
if (!ept.isEnd && !spt.isStart) {
return true;
} else {
if (ept.isEnd && ept.intX == l2.x2 && spt.intX > l2.x2)
;
else if (spt.isStart && spt.intX == l2.x2 && ept.intX > l2.x2)
;
else {
return true;
}
}
}
}
return false;
};
const isLineCross = function(l1, l2) {
if ((l1.x1 > l1.x2 ? l1.x1 : l1.x2) < (l2.x1 < l2.x2 ? l2.x1 : l2.x2) || (l1.y1 > l1.y2 ? l1.y1 : l1.y2) < (l2.y1 < l2.y2 ? l2.y1 : l2.y2) || (l2.x1 > l2.x2 ? l2.x1 : l2.x2) < (l1.x1 < l1.x2 ? l1.x1 : l1.x2) || (l2.y1 > l2.y2 ? l2.y1 : l2.y2) < (l1.y1 < l1.y2 ? l1.y1 : l1.y2)) {
return false;
}
if (((l1.x1 - l2.x1) * (l2.y2 - l2.y1) - (l1.y1 - l2.y1) * (l2.x2 - l2.x1)) * ((l1.x2 - l2.x1) * (l2.y2 - l2.y1) - (l1.y2 - l2.y1) * (l2.x2 - l2.x1)) > 0 || ((l2.x1 - l1.x1) * (l1.y2 - l1.y1) - (l2.y1 - l1.y1) * (l1.x2 - l1.x1)) * ((l2.x2 - l1.x1) * (l1.y2 - l1.y1) - (l2.y2 - l1.y1) * (l1.x2 - l1.x1)) > 0) {
return false;
}
return true;
};
const getLineCorssPoint = function(p1, p2, p3, p4) {
let abc = (p1.x - p3.x) * (p2.y - p3.y) - (p1.y - p3.y) * (p2.x - p3.x);
let abd = (p1.x - p4.x) * (p2.y - p4.y) - (p1.y - p4.y) * (p2.x - p4.x);
if (abc * abd >= 0) {
return null;
}
let cda = (p3.x - p1.x) * (p4.y - p1.y) - (p3.y - p1.y) * (p4.x - p1.x);
let cdb = cda + abc - abd;
if (cda * cdb >= 0) {
return null;
}
let t = cda / (abd - abc);
let dx = t * (p2.x - p1.x), dy = t * (p2.y - p1.y);
return { x: p1.x + dx, y: p1.y + dy };
};
const pvsToOutRect = function(points) {
let x2 = Infinity, y2 = Infinity, x1 = -Infinity, y1 = -Infinity;
points.forEach((p) => {
x2 = Math.min(p.x, x2);
x1 = Math.max(p.x, x1);
y2 = Math.min(p.y, y2);
y1 = Math.max(p.y, y1);
});
return {
x: x2,
y: y2,
width: x1 - x2,
height: y1 - y2,
x1,
y1
};
};
const getMovePath = function(sAngle, eAngle, startPoint, endPoint) {
let movePath = "";
switch (sAngle) {
case 0:
{
switch (eAngle) {
case 180:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "sx:0.25,ex:-0.25";
}
} else if (startPoint.y > endPoint.y) {
if (startPoint.x > endPoint.x) {
movePath = "sx:0.25,ex:-0.25";
}
} else {
if (startPoint.x > endPoint.x) {
movePath = "sx:0.25,ex:-0.25";
}
}
}
break;
case -90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1)
;
else if (startPoint.y > endPoint.y) {
if (startPoint.x > endPoint.x) {
movePath = "sx:0.25,ey:-0.25";
} else {
movePath = "ey:-0.25";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sx:0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "sx:0.25";
}
}
}
break;
case 90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "sx:0.25,sy2:0.25";
} else {
movePath = "ey:0.25";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sx:0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "sx:0.25";
} else
;
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "sx:0.25,ey:0.25";
} else {
movePath = "ey:0.25";
}
}
}
break;
case 0:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "sx:0.25,sy1:-0.25";
} else {
movePath = "ey1:-0.25";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sx:0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "sx:0.25";
} else {
movePath = "ex:0.25";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sx:0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "sx:0.25";
} else {
movePath = "ex:0.25";
}
}
}
break;
}
}
break;
case 180:
{
switch (eAngle) {
case 0:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x)
;
else {
movePath = "sx:-0.25,ey1:-0.25,ex:0.25";
}
} else if (startPoint.y > endPoint.y) {
if (startPoint.x > endPoint.x)
;
else {
movePath = "sx:-0.25,ex:0.25";
}
} else {
if (startPoint.x > endPoint.x)
;
else {
movePath = "sx:-0.25,ex:0.25";
}
}
}
break;
case -90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x < endPoint.x) {
movePath = "sx:-0.25,ry-s:-0.25";
} else {
movePath = "sx:-0.25,ry-s:-0.25";
}
} else if (startPoint.y > endPoint.y) {
if (startPoint.x > endPoint.x) {
movePath = "sx:-0.25,ey:-0.25";
} else {
movePath = "sx:-0.25,ey:-0.25";
}
} else {
if (startPoint.x > endPoint.x)
;
else {
movePath = "sx:-0.25";
}
}
}
break;
case 90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x < endPoint.x) {
movePath = "rx-s:-0.25,ry1-e:0.25";
} else {
movePath = "ey2:0.25";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x)
;
else {
movePath = "sx:-0.25";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "ex2:-0.25,ey2:0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "ey:0.25";
} else {
movePath = "sx:-0.25,ey:0.25";
}
}
}
break;
case 180:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "ey1:-0.25,ex:-0.25";
} else {
movePath = "sx:-0.25,ey1:-0.25";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sx:-0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "ex:-0.25";
} else {
movePath = "sx:-0.25";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sx:-0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "ex:-0.25";
} else {
movePath = "sx:-0.25";
}
}
}
break;
}
}
break;
case -90:
{
switch (eAngle) {
case 90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
movePath = "sy:-0.25,ey:0.25";
} else if (startPoint.y > endPoint.y)
;
else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sy:-0.25,sx1:-0.25,ey:0.25";
} else {
movePath = "sy:-0.25,ey:0.25";
}
}
}
break;
case 0:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "sy:-0.25";
} else {
movePath = "sy:-0.25";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x)
;
else {
movePath = "ex:0.25";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sy:-0.25,sx2:0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "sy:-0.25,sx2:0.25";
} else {
movePath = "sy:-0.25,ex:0.25";
}
}
}
break;
case 180:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "sy:-0.25";
} else {
movePath = "sy:-0.25";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sx:-0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "ex:-0.25";
} else
;
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sy:-0.25,rx-s:-0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "sy:-0.25,ex:-0.25";
} else {
movePath = "sy:-0.25";
}
}
}
break;
case -90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
movePath = "sy:-0.25,ex:0";
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "ey:-0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "ey:-0.25,ex:0";
} else {
movePath = "ey:-0.25,ex:0";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sx1:-0.25,eymid";
} else if (startPoint.x > endPoint.x) {
movePath = "sy:-0.25,ex:0";
} else {
movePath = "sy:-0.25,ex:0";
}
}
}
break;
}
}
break;
case 90:
{
switch (eAngle) {
case -90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
if (startPoint.x > endPoint.x) {
movePath = "sy:0.25,ey:-0.25";
} else {
movePath = "sy:0.25,ey:-0.25";
}
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sy:0.25,ey:-0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "sy:0.25,ey:-0.25";
} else {
movePath = "sy:0.25,ey:-0.25";
}
} else
;
}
break;
case 0:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
movePath = "sy:0.25";
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sy:0.25,ex:0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "sy:0.25";
} else {
movePath = "sy:0.25,ex:0.25";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x)
;
else {
movePath = "ex:0.25";
}
}
}
break;
case 180:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
movePath = "sy:0.25";
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1)
;
else if (startPoint.x > endPoint.x) {
movePath = "sy:0.25,ex:-0.25";
} else {
movePath = "sy:0.25";
}
} else {
if (startPoint.x > endPoint.x) {
movePath = "ex:-0.25";
}
}
}
break;
case 90:
{
if (Math.abs(startPoint.y - endPoint.y) <= 1) {
movePath = "sy:0.25";
} else if (startPoint.y > endPoint.y) {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "sy:0.25,sx1:-0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "sy:0.25";
} else {
movePath = "sy:0.25";
}
} else {
if (Math.abs(startPoint.x - endPoint.x) <= 1) {
movePath = "ex2:0.25,ey:0.25";
} else if (startPoint.x > endPoint.x) {
movePath = "ey:0.25";
} else {
movePath = "ey:0.25";
}
}
}
break;
}
}
break;
}
return movePath;
};
const getRecommendPath = function(sAngle, eAngle, startPoint, endPoint, startRect, endRect, outRect) {
let recommendPaths = [];
let movePath = getMovePath(sAngle, eAngle, startPoint, endPoint);
if (movePath) {
let mPaths = movePath.split(",");
mPaths.forEach((mPath) => {
let mpa = mPath.split(":");
let opType = mpa[0];
let opSize = parseFloat(mpa[1]);
let cPoint = {};
switch (opType) {
case "sx":
cPoint.x = startPoint.x + opSize * startRect.width;
cPoint.y = startPoint.y;
cPoint.type = "x";
break;
case "sy":
cPoint.y = startPoint.y + opSize * startRect.height;
cPoint.x = startPoint.x;
cPoint.type = "y";
break;
case "ex":
cPoint.x = endPoint.x + opSize * endRect.width;
cPoint.y = endPoint.y;
cPoint.type = "x";
break;
case "sxmid":
cPoint.y = startPoint.y;
if (outRect) {
cPoint.x = outRect.x + outRect.width / 2;
} else {
cPoint.x = (startPoint.x + endPoint.x) / 2;
}
cPoint.type = "x";
break;
case "symid":
cPoint.x = startPoint.x;
if (outRect) {
cPoint.y = outRect.y + outRect.height / 2;
} else {
cPoint.y = (startPoint.y + endPoint.y) / 2;
}
cPoint.type = "y";
break;
case "exmid":
cPoint.y = endPoint.y;
if (outRect) {
cPoint.x = outRect.x + outRect.width / 2;
} else {
cPoint.x = (startPoint.x + endPoint.x) / 2;
}
cPoint.type = "x";
break;
case "eymid":
cPoint.x = endPoint.x;
if (outRect) {
cPoint.y = outRect.y + outRect.height / 2;
} else {
cPoint.y = (endPoint.y + endPoint.y) / 2;
}
cPoint.type = "y";
break;
case "sx1":
cPoint.y = startPoint.y;
cPoint.x = startRect.x + startRect.width * opSize;
cPoint.type = "x";
break;
case "sx2":
cPoint.y = startPoint.y;
cPoint.x = startRect.x1 + startRect.width * opSize;
cPoint.type = "x";
break;
case "ex1":
cPoint.y = endPoint.y;
cPoint.x = endRect.x + endRect.width * opSize;
cPoint.type = "x";
break;
case "ex2":
cPoint.y = endPoint.y;
cPoint.x = endRect.x1 + endRect.width * opSize;
cPoint.type = "x";
break;
case "sy1":
cPoint.x = startPoint.x;
cPoint.y = startRect.y + startRect.height * opSize;
cPoint.type = "y";
break;
case "sy2":
cPoint.x = startPoint.x;
cPoint.y = startRect.y1 + startRect.height * opSize;
cPoint.type = "y";
break;
case "ey":
cPoint.y = endPoint.y + opSize * endRect.height;
cPoint.x = endPoint.x;
cPoint.type = "y";
break;
case "ey1":
cPoint.x = endPoint.x;
cPoint.y = endRect.y + endRect.height * opSize;
cPoint.type = "y";
break;
case "ey2":
cPoint.x = endPoint.x;
cPoint.y = endRect.y1 + endRect.height * opSize;
cPoint.type = "y";
break;
case "rx-s":
if (outRect) {
cPoint.x = outRect.x + startRect.width * opSize;
cPoint.y = outRect.y;
cPoint.type = "x";
} else {
cPoint = null;
}
break;
case "rx1-s":
if (outRect) {
cPoint.x = outRect.x1 + startRect.width * opSize;
cPoint.y = outRect.y;
cPoint.type = "x";
} else {
cPoint = null;
}
break;
case "rx-e":
if (outRect) {
cPoint.x = outRect.x + endRect.width * opSize;
cPoint.y = outRect.y;
cPoint.type = "x";
} else {
cPoint = null;
}
break;
case "rx1-e":
if (outRect) {
cPoint.x = outRect.x1 + endRect.width * opSize;
cPoint.y = outRect.y;
cPoint.type = "x";
} else {
cPoint = null;
}
break;
case "ry-s":
if (outRect) {
cPoint.y = outRect.y + startRect.height * opSize;
cPoint.x = outRect.x;
cPoint.type = "y";
} else {
cPoint = null;
}
break;
case "ry1-s":
if (outRect) {
cPoint.y = outRect.y1 + startRect.height * opSize;
cPoint.x = outRect.x;
cPoint.type = "y";
} else {
cPoint = null;
}
break;
case "ry-e":
if (outRect) {
cPoint.y = outRect.y + endRect.height * opSize;
cPoint.x = outRect.x;
cPoint.type = "y";
} else {
cPoint = null;
}
break;
case "ry1-e":
if (outRect) {
cPoint.y = outRect.y1 + endRect.height * opSize;
cPoint.x = outRect.x;
cPoint.type = "y";
} else {
cPoint = null;
}
break;
}
if (cPoint) {
recommendPaths.push(cPoint);
}
});
}
return recommendPaths;
};
var __defProp = Object.defineProperty;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __publicField = (obj, key, value) => {
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
return value;
};
const _DDeiLine = class _DDeiLine2 extends DDeiAbstractShape {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "weight");
__publicField2(this, "color");
__publicField2(this, "fill");
__publicField2(this, "modelType", "DDeiLine");
__publicField2(this, "baseModelType", "DDeiLine");
__publicField2(this, "estyle");
__publicField2(this, "sstyle");
__publicField2(this, "dash");
__publicField2(this, "type");
__publicField2(this, "sp");
__publicField2(this, "ep");
__publicField2(this, "opacity");
__publicField2(this, "round");
__publicField2(this, "startPoint");
__publicField2(this, "endPoint");
__publicField2(this, "spvs");
__publicField2(this, "clps", {});
__publicField2(this, "freeze");
this.color = props.color;
this.weight = props.weight;
this.estyle = props.estyle;
this.sstyle = props.sstyle;
this.dash = props.dash;
this.type = props.type ? props.type : 1;
this.sp = props.sp;
this.ep = props.ep;
this.opacity = props.opacity;
this.round = props.round;
this.spvs = props.spvs ? props.spvs : [];
this.freeze = props.freeze ? props.freeze : 0;
this.fill = props.fill;
this.updateLooseCanvasSync = debounce(this.updateLooseCanvasSync, 30);
}
// ============================ 静态变量 ============================
// ============================ 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static loadFromJSON(json, tempData = {}, initPVS = true) {
var _a3, _b2;
let model = new _DDeiLine2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
if (!model.pModel) {
model.pModel = model.layer;
}
let ddInstance = (_a3 = model.stage) == null ? void 0 : _a3.ddInstance;
tempData[model.id] = model;
if (((_b2 = json == null ? void 0 : json.composes) == null ? void 0 : _b2.length) > 0) {
let composes = [];
json == null ? void 0 : json.composes.forEach((composeJSON) => {
let def = DDeiUtil$1.getControlDefine(composeJSON);
let composeModel = ddInstance.controlModelClasses[def.type].loadFromJSON(
composeJSON,
tempData,
false
);
composeModel.pModel = model;
composes.push(composeModel);
});
model.composes = composes;
}
if (initPVS) {
model.initPVS();
}
return model;
}
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json, tempData = {}, initPVS = true) {
var _a3, _b2;
let model = new _DDeiLine2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
let ddInstance = (_a3 = model.stage) == null ? void 0 : _a3.ddInstance;
if (((_b2 = json == null ? void 0 : json.composes) == null ? void 0 : _b2.length) > 0) {
let composes = [];
for (let ci = 0; ci < json.composes.length; ci++) {
let composeJSON = json.composes[ci];
let def = DDeiUtil$1.getControlDefine(composeJSON);
let composeModel = ddInstance.controlModelClasses[def.type].initByJSON(
composeJSON,
tempData,
false
);
composeModel.modelCode = composeModel.id;
composeModel.id = model.id + "_comp_" + ci;
composeModel.pModel = model;
composes.push(composeModel);
}
model.composes = composes;
}
if (initPVS) {
model.initPVS();
}
return model;
}
/**
* 计算线段交叉点,用于绘制错线效果
* 该方法在所有线段的calPoints方法执行完后执行,修改已计算好的节点
*/
static calLineCrossSync(layer2) {
return new Promise((resolve, reject) => {
if (!layer2.stage.render.refreshJumpLine) {
let lines = layer2.getModelsByBaseType("DDeiLine");
_DDeiLine2.calLineCross(layer2);
lines.forEach((line2) => {
line2.updateLooseCanvas();
});
layer2.stage.render.refreshJumpLine = true;
}
resolve();
});
}
static calLineCross(layer2) {
var _a3, _b2, _c2, _d2;
if (!layer2) {
return;
}
if (!layer2.stage.render.refreshJumpLine) {
let lines = layer2.getModelsByBaseType("DDeiLine");
lines.forEach((line2) => {
line2.clps = {};
});
let wl = 12 * ((_a3 = layer2.stage) == null ? void 0 : _a3.getStageRatio());
let len = lines.length;
let rectMap = /* @__PURE__ */ new Map();
let corssLinePoints = [];
for (let i2 = 0; i2 < len - 1; i2++) {
let l1 = lines[i2];
if (l1.type == 3) {
continue;
}
let jumpLine;
if (layer2.stage.ddInstance.jumpline == 0 || layer2.stage.ddInstance.jumpline) {
jumpLine = layer2.stage.ddInstance.jumpline;
} else {
jumpLine = DDeiModelArrtibuteValue.getAttrValueByState(l1, "jumpline", true);
if (jumpLine == 0 || !jumpLine) {
if ((_b2 = layer2.stage.global) == null ? void 0 : _b2.jumpline) {
jumpLine = layer2.stage.global.jumpline;
} else if (layer2.stage.ddInstance.jumpline) {
jumpLine = layer2.stage.ddInstance.jumpline;
} else {
jumpLine = DDeiModelArrtibuteValue.getAttrValueByState(layer2.stage, "global.jumpline", true);
}
}
}
if (jumpLine == 1) {
if (!rectMap.has(l1.id)) {
rectMap.set(l1.id, DDeiAbstractShape.getOutRectByPV([l1]));
}
let l1Rect = rectMap.get(l1.id);
for (let j2 = i2 + 1; j2 < len; j2++) {
let l2 = lines[j2];
if (l2.type == 3) {
continue;
}
if (l1 != l2) {
if (!rectMap.has(l2.id)) {
rectMap.set(l2.id, DDeiAbstractShape.getOutRectByPV([l2]));
}
let l2Rect = rectMap.get(l2.id);
if (DDeiUtil$1.isRectCross(l1Rect, l2Rect)) {
for (let pi = 0; pi < l1.pvs.length - 1; pi++) {
let p1 = l1.pvs[pi];
let p2 = l1.pvs[pi + 1];
for (let pj = 0; pj < l2.pvs.length - 1; pj++) {
let p3 = l2.pvs[pj];
let p4 = l2.pvs[pj + 1];
let crossPoint = DDeiUtil$1.getLineCorssPoint(p1, p2, p3, p4);
if (crossPoint != null) {
let pRotate = DDeiUtil$1.getLineAngle(p1.x, p1.y, p2.x, p2.y);
let pAngle = (pRotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let pVectorUnit = new Vector3(1, 0, 1);
let pRotateMatrix = new Matrix3(
Math.cos(pAngle),
Math.sin(pAngle),
0,
-Math.sin(pAngle),
Math.cos(pAngle),
0,
0,
0,
1
);
pVectorUnit.applyMatrix3(pRotateMatrix);
let sdist = DDeiUtil$1.getPointDistance(p1.x, p1.y, crossPoint.x, crossPoint.y);
let edist = DDeiUtil$1.getPointDistance(p2.x, p2.y, crossPoint.x, crossPoint.y);
let s1dist = DDeiUtil$1.getPointDistance(p3.x, p3.y, crossPoint.x, crossPoint.y);
let e1dist = DDeiUtil$1.getPointDistance(p4.x, p4.y, crossPoint.x, crossPoint.y);
if (sdist > wl && edist > wl && s1dist > wl && e1dist > wl) {
corssLinePoints.push({ line: l1, index: pi, cp: crossPoint, unit: pVectorUnit, r: pRotate, dist: sdist });
}
}
}
}
}
}
}
}
corssLinePoints.forEach((clp) => {
var _a22;
if (!clp.line.clps[clp.index]) {
clp.line.clps[clp.index] = [];
}
let dist = clp.dist;
let has = false;
let lineClps = clp.line.clps[clp.index];
let len2 = lineClps.length;
for (let di = 0; di < len2; di++) {
if (lineClps[di].cp.x == clp.cp.x && lineClps[di].cp.y == clp.cp.y) {
has = true;
break;
}
if (dist <= ((_a22 = lineClps[di]) == null ? void 0 : _a22.dist)) {
lineClps.splice(di, 0, clp);
has = true;
break;
}
}
if (!has) {
clp.line.clps[clp.index].push(clp);
}
});
lines.forEach((line2) => {
var _a22;
line2.updateLooseCanvas();
(_a22 = line2.render) == null ? void 0 : _a22.enableRefreshShape();
});
(_c2 = layer2.stage) == null ? void 0 : _c2.ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
(_d2 = layer2.stage) == null ? void 0 : _d2.ddInstance.bus.executeAll();
layer2.stage.render.refreshJumpLine = true;
}
}
}
// ============================ 方法 ===============================
/**
* 初始化向量,默认开始在0,0的位置
*/
initPVS() {
var _a3, _b2, _c2, _d2, _e2;
if (!this.cpv && !(((_a3 = this.pvs) == null ? void 0 : _a3.length) > 0)) {
this.cpv = new Vector3(0, 0, 1);
} else {
this.cpv = this.pvs[0];
}
if (!(((_b2 = this.ovs) == null ? void 0 : _b2.length) > 0)) {
let defineOvs = (_d2 = (_c2 = DDeiUtil$1.getControlDefine(this)) == null ? void 0 : _c2.define) == null ? void 0 : _d2.ovs;
if ((defineOvs == null ? void 0 : defineOvs.length) > 0) {
let stageRatio2 = this.getStageRatio();
let ovs = [];
defineOvs.forEach((ovd) => {
let ov = new Vector3(ovd.x * stageRatio2, ovd.y * stageRatio2, ovd.z || ovd.z == 0 ? ovd.z : 1);
let ovi = new Vector3(ovd.ix * stageRatio2, ovd.iy * stageRatio2, ovd.iz || ovd.iz == 0 ? ovd.iz : 1);
ov.ovi = ovi;
ovs.push(ov);
});
this.ovs = ovs;
}
}
this.initHPV();
this.calRotate();
this.startPoint = this.pvs[0];
this.endPoint = this.pvs[this.pvs.length - 1];
this.calLoosePVS();
this.refreshLinkModels();
(_e2 = this.composes) == null ? void 0 : _e2.forEach((compose) => {
compose.initPVS();
});
}
/**
* 交换开始和结束节点
*/
exchangeStartAndEnd() {
var _a3;
let startPoint = this.startPoint;
let endPoint = this.endPoint;
let distLinks = (_a3 = this.stage) == null ? void 0 : _a3.getDistModelLinks(this.id);
let sms = [];
distLinks == null ? void 0 : distLinks.forEach((dl) => {
if (dl.dmpath == "startPoint") {
dl.dmpath = "endPoint";
} else if (dl.dmpath == "endPoint") {
dl.dmpath = "startPoint";
}
if (dl.sm) {
sms.push(dl.sm);
}
});
this.startPoint = endPoint;
this.endPoint = startPoint;
this.cpv = this.startPoint;
this.pvs[0] = this.startPoint;
this.pvs[this.pvs.length - 1] = this.endPoint;
sms.forEach((sm) => {
sm.updateLinkModels();
});
}
/**
* 重新计算线路径并更新图形
*/
refreshLinePoints() {
var _a3;
this.calPoints();
this.calLoosePVS();
this.refreshLinkModels();
(_a3 = this.composes) == null ? void 0 : _a3.forEach((compose) => {
compose.initPVS();
});
}
/**
* 设置当前最新的hpv
*/
initHPV() {
if (!this.hpv || this.hpv.length < 2) {
this.hpv[0] = new Vector3(this.cpv.x, this.cpv.y, 1);
this.hpv[1] = new Vector3(this.cpv.x + 100, this.cpv.y, 1);
}
}
/**
* 根据开始节点和结束节点的关系,自动计算中间节点路径的坐标
*/
calPoints() {
var _a3;
switch (this.type) {
case 1:
{
this.pvs = [this.startPoint, this.endPoint];
}
break;
case 2:
{
this.calLineType3();
}
break;
case 3:
{
if (this.freeze != 1) {
this.calLineType3();
if (this.pvs.length < 4) {
if (this.pvs.length == 2) {
let x1 = this.pvs[0].x + (this.pvs[1].x - this.pvs[0].x) * 0.33;
let y1 = this.pvs[0].y + (this.pvs[1].y - this.pvs[0].y) * 0.33;
let x2 = this.pvs[0].x + (this.pvs[1].x - this.pvs[0].x) * 0.66;
let y2 = this.pvs[0].y + (this.pvs[1].y - this.pvs[0].y) * 0.66;
this.pvs = [this.pvs[0], new Vector3(x1, y1, 1), new Vector3(x2, y2, 1), this.pvs[1]];
} else if (this.pvs.length == 3) {
let x1 = this.pvs[0].x + (this.pvs[1].x - this.pvs[0].x) * 0.66;
let y1 = this.pvs[0].y + (this.pvs[1].y - this.pvs[0].y) * 0.66;
let x2 = this.pvs[1].x + (this.pvs[2].x - this.pvs[1].x) * 0.33;
let y2 = this.pvs[1].y + (this.pvs[2].y - this.pvs[1].y) * 0.33;
this.pvs = [this.pvs[0], new Vector3(x1, y1, 1), new Vector3(x2, y2, 1), this.pvs[2]];
}
} else if (this.pvs.length > 4) {
let appendPointSize = 3 - (this.pvs.length - 4) % 3;
for (let i2 = 0; i2 < appendPointSize; i2++) {
let maxS = -1;
let maxlength = 0;
for (let j2 = 0; j2 < this.pvs.length - 1; j2++) {
let p1 = this.pvs[j2];
let p2 = this.pvs[j2 + 1];
let l = DDeiUtil$1.getPointDistance(p1.x, p1.y, p2.x, p2.y);
if (!maxlength) {
maxlength = l;
maxS = j2;
} else if (l > maxlength) {
maxlength = l;
maxS = j2;
}
}
let s = maxS;
let e = maxS + 1;
let x1 = this.pvs[s].x + (this.pvs[e].x - this.pvs[s].x) * 0.5;
let y1 = this.pvs[s].y + (this.pvs[e].y - this.pvs[s].y) * 0.5;
this.pvs.splice(s + 1, 0, new Vector3(x1, y1, 1));
}
}
}
}
break;
}
(_a3 = this.render) == null ? void 0 : _a3.enableRefreshShape();
_DDeiLine2.calLineCross(this.layer);
}
/**
* 计算折线连线点
*/
calLineType3() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
this.pvs;
let id = this.id;
if (id.indexOf("_shadow") != -1) {
id = id.substring(0, id.lastIndexOf("_shadow"));
}
let lineLinks = (_a3 = this.stage) == null ? void 0 : _a3.getDistModelLinks(id);
let startLink = null;
let endLink = null;
lineLinks == null ? void 0 : lineLinks.forEach((lk) => {
if (lk.dmpath == "startPoint") {
startLink = lk;
} else if (lk.dmpath == "endPoint") {
endLink = lk;
}
});
let sAngle = null;
let eAngle = null;
let startModel = (startLink == null ? void 0 : startLink.sm) ? startLink == null ? void 0 : startLink.sm : (_b2 = this.stage.tempStartOPpoint) == null ? void 0 : _b2.model;
let endModel = (endLink == null ? void 0 : endLink.sm) ? endLink == null ? void 0 : endLink.sm : (_c2 = this.stage.tempCursorOPpoint) == null ? void 0 : _c2.model;
let startRect, endRect;
if (((_d2 = startModel == null ? void 0 : startModel.operatePVS) == null ? void 0 : _d2.length) > 0) {
startRect = DDeiAbstractShape.pvsToOutRect(startModel.operatePVS);
}
if (((_e2 = endModel == null ? void 0 : endModel.operatePVS) == null ? void 0 : _e2.length) > 0) {
endRect = DDeiAbstractShape.pvsToOutRect(endModel.operatePVS);
}
let startPoint = this.startPoint;
let endPoint = this.endPoint;
if (this == this.stage.render.currentOperateShape) {
let passIndex = (_f = this.stage.render.dragObj) == null ? void 0 : _f.passIndex;
let opvsIndex = (_g = this.stage.render.dragObj) == null ? void 0 : _g.opvsIndex;
if (passIndex == 1) {
if (opvsIndex == 0) {
startPoint = this.stage.tempCursorOPpoint ? this.stage.tempCursorOPpoint : this.startPoint;
this.startPoint.x = startPoint.x;
this.startPoint.y = startPoint.y;
} else if (opvsIndex == ((_i = (_h = this.stage.render.dragObj) == null ? void 0 : _h.opvs) == null ? void 0 : _i.length) - 1) {
endPoint = this.stage.tempCursorOPpoint ? this.stage.tempCursorOPpoint : this.endPoint;
this.endPoint.x = endPoint.x;
this.endPoint.y = endPoint.y;
}
}
}
if (startModel == null ? void 0 : startModel.getPointAngle) {
sAngle = startModel.getPointAngle(startPoint);
sAngle = this.calSpecilPointAngle(sAngle);
}
if (endModel == null ? void 0 : endModel.getPointAngle) {
eAngle = endModel.getPointAngle(endPoint);
eAngle = this.calSpecilPointAngle(eAngle);
}
let outRect = null;
if (startRect && endRect) {
outRect = {
x: Math.min(startRect.x, endRect.x),
x1: Math.max(startRect.x1, endRect.x1),
y: Math.min(startRect.y, endRect.y),
y1: Math.max(startRect.y1, endRect.y1)
};
outRect.width = outRect.x1 - outRect.x;
outRect.height = outRect.y1 - outRect.y;
}
let recommendPaths = getRecommendPath(sAngle, eAngle, startPoint, endPoint, startRect, endRect, outRect);
let allModels = this.layer.getSubModelsByFilter("LINE_OBI_FILTER", null, 10, { line: this });
let obis = [];
allModels.forEach((model) => {
var _a22;
if (model.baseModelType != "DDeiLine" && ((_a22 = model.operatePVS) == null ? void 0 : _a22.length) > 0 && !model.depModel) {
let obj = { points: model.operatePVS };
if (model.id == (startModel == null ? void 0 : startModel.id) || model.id == (endModel == null ? void 0 : endModel.id)) {
obj.isStartOrEnd = true;
}
obis.push(obj);
}
});
let marr = [startModel, endModel];
marr.forEach((model) => {
if (model) {
let modelConts = model.getParents();
modelConts.forEach((contModel) => {
let rmIdx = allModels.indexOf(contModel);
if (rmIdx != -1) {
allModels.splice(rmIdx, 1);
}
});
}
});
let forcePaths = [];
(_j = this.spvs) == null ? void 0 : _j.forEach((pv) => {
if (pv) {
let newPV = { x: 0, y: 0 };
if (pv.x) {
newPV.x = pv.x + this.startPoint.x;
}
if (pv.y) {
newPV.y = pv.y + this.startPoint.y;
}
forcePaths.push(newPV);
}
});
let linePathData = calAutoLinePath(
{
point: {
x: startPoint.x,
y: startPoint.y
},
rect: startRect,
angle: sAngle
},
{
point: {
x: endPoint.x,
y: endPoint.y
},
rect: endRect,
angle: eAngle
},
obis,
{ recommendPaths, forcePaths, recomWeight: 100, rectMidWeight: 50 }
);
this.pvs = [this.startPoint];
if (linePathData) {
if ((_k = this.stage) == null ? void 0 : _k.render) {
this.stage.render.linePathData = linePathData;
}
if (((_l = linePathData.pathPoints) == null ? void 0 : _l.length) > 2) {
for (let i2 = 1; i2 < linePathData.pathPoints.length - 1; i2++) {
let mp = linePathData.pathPoints[i2];
this.pvs.push(new Vector3(mp.x, mp.y, 1));
}
}
}
this.pvs.push(this.endPoint);
}
/**
* 计算特殊点位的角度
*/
calSpecilPointAngle(eAngle) {
if (eAngle > 1e3) {
switch (eAngle) {
case 1001:
if (Math.abs(this.startPoint.x - this.endPoint.x) > Math.abs(this.startPoint.y - this.endPoint.y)) {
eAngle = 180;
} else {
eAngle = -90;
}
break;
case 1002:
if (Math.abs(this.startPoint.x - this.endPoint.x) > Math.abs(this.startPoint.y - this.endPoint.y)) {
eAngle = 0;
} else {
eAngle = -90;
}
break;
case 1003:
if (Math.abs(this.startPoint.x - this.endPoint.x) > Math.abs(this.startPoint.y - this.endPoint.y)) {
eAngle = 0;
} else {
eAngle = 90;
}
break;
case 1004:
if (Math.abs(this.startPoint.x - this.endPoint.x) > Math.abs(this.startPoint.y - this.endPoint.y)) {
eAngle = 180;
} else {
eAngle = 90;
}
break;
}
}
return eAngle;
}
/**
* 设置直线的坐标,会根据约束关系来调整位置
*/
setLineType1PointPosition(pointType, ex, ey) {
var _a3, _b2, _c2, _d2;
let sx = this.pvs[0].x;
let sy = this.pvs[0].y;
let endX = this.pvs[this.pvs.length - 1].x;
let endY = this.pvs[this.pvs.length - 1].y;
if (pointType == 0) {
sx = ex;
sy = ey;
} else if (pointType == 1) {
endX = ex;
endY = ey;
}
let constraint = (_b2 = (_a3 = DDeiUtil$1.getControlDefine(this)) == null ? void 0 : _a3.define) == null ? void 0 : _b2.constraint;
if (((_d2 = (_c2 = constraint == null ? void 0 : constraint.type[1]) == null ? void 0 : _c2.angles) == null ? void 0 : _d2.length) > 0) {
let lineAngle = DDeiUtil$1.getLineAngle(sx, sy, endX, endY);
let angle2 = this.rotate ? this.rotate : 0;
let inArea = false;
let minAngle = lineAngle;
let minAngleABS = Infinity;
for (let i2 = 0; i2 < constraint.type[1].angles.length; i2++) {
let angleArea = constraint.type[1].angles[i2];
if (angleArea[0] + angle2 <= lineAngle && angleArea[1] + angle2 >= lineAngle) {
inArea = true;
break;
}
if (Math.abs(angleArea[0] + angle2 - lineAngle) < minAngleABS) {
minAngleABS = Math.abs(angleArea[0] + angle2 - lineAngle);
minAngle = angleArea[0] + angle2;
}
if (Math.abs(angleArea[1] + angle2 - lineAngle) < minAngleABS) {
minAngleABS = Math.abs(angleArea[1] + angle2 - lineAngle);
minAngle = angleArea[1] + angle2;
}
}
if (pointType == 0) {
let sdx = this.pvs[this.pvs.length - 1].x - this.pvs[0].x;
let sdy = this.pvs[this.pvs.length - 1].y - this.pvs[0].y;
let zeroEndPoints = [new Vector3(sdx, sdy, 1)];
let endPoint = DDeiUtil$1.zeroToPoints(zeroEndPoints, new Vector3(sx, sy), minAngle - lineAngle)[0];
endX = endPoint.x;
endY = endPoint.y;
} else if (!inArea && pointType == 1) {
let zeroEndPoints = DDeiUtil$1.pointsToZero([new Vector3(endX, endY, 1)], new Vector3(sx, sy), 0);
let endPoint = DDeiUtil$1.zeroToPoints(zeroEndPoints, new Vector3(sx, sy), minAngle - lineAngle)[0];
endX = endPoint.x;
endY = endPoint.y;
}
}
this.pvs[0].x = sx;
this.pvs[0].y = sy;
this.pvs[this.pvs.length - 1].x = endX;
this.pvs[this.pvs.length - 1].y = endY;
}
/**
* 基于当前向量计算宽松判定向量
*/
calLoosePVS() {
this.loosePVS = this.pvs;
this.updateLooseCanvasSync();
}
updateLooseCanvasSync() {
return new Promise((resolve, reject) => {
this.updateLooseCanvas();
resolve();
});
}
updateLooseCanvas() {
var _a3;
if (!this.isShadowControl && this.render) {
if (!this.looseCanvas) {
this.looseCanvas = document.createElement("canvas");
this.looseCanvas.setAttribute("style", "-moz-transform-origin:left top;position:absolute;left:0px;top:0px;");
}
let canvas = this.looseCanvas;
let stageRatio2 = (_a3 = this.stage) == null ? void 0 : _a3.getStageRatio();
let pvs2 = this.pvs;
let outRect = DDeiAbstractShape.pvsToOutRect(pvs2, stageRatio2);
let weight = 10;
if (this.weight) {
weight = this.weight + 5;
}
outRect.x -= weight;
outRect.x1 += weight;
outRect.y -= weight;
outRect.y1 += weight;
outRect.width += 2 * weight;
outRect.height += 2 * weight;
this.loosePVS = this.pvs;
canvas.setAttribute("width", outRect.width);
canvas.setAttribute("height", outRect.height);
let ctx = canvas.getContext("2d", { willReadFrequently: true });
ctx.translate(-outRect.x, -outRect.y);
this.render.drawLine({ color: "red", weight, dash: [], rat1: 1, fill: { color: "red" } }, ctx);
}
}
/**
* 变换向量
*/
transVectors(matrix2, params) {
var _a3, _b2, _c2;
this.pvs.forEach((pv) => {
pv.applyMatrix3(matrix2);
});
for (let i2 in this.exPvs) {
let pv = this.exPvs[i2];
pv.applyMatrix3(matrix2);
}
(_a3 = this.ovs) == null ? void 0 : _a3.forEach((pv) => {
pv.applyMatrix3(matrix2);
if (pv.ovi) {
pv.ovi.applyMatrix3(matrix2);
}
});
this.hpv[0].applyMatrix3(matrix2);
this.hpv[1].applyMatrix3(matrix2);
this.calRotate();
this.calLoosePVS();
(_b2 = this.composes) == null ? void 0 : _b2.forEach((compose) => {
compose.transVectors(matrix2, params);
});
(_c2 = this.render) == null ? void 0 : _c2.enableRefreshShape();
}
/**
* 获取中心点操作点
*/
getCenterOpPoints() {
return [];
}
/**
* 判断图形是否在一个区域内,采用宽松的判定模式,允许传入一个大小值
* @param x
* @param y
* @param loose 宽松判定,默认false
* @returns 是否在区域内
*/
isInAreaLoose(x2 = void 0, y2 = void 0, loose = false) {
var _a3;
if (this.looseCanvas) {
let isArea = false;
let projPoint = this.getProjPoint(
{ x: x2, y: y2 },
{ in: -10, out: 10 },
1,
2
);
if (projPoint) {
isArea = true;
}
if (isArea) {
let ctx = this.looseCanvas.getContext("2d");
let stageRatio2 = (_a3 = this.stage) == null ? void 0 : _a3.getStageRatio();
let outRect = DDeiAbstractShape.pvsToOutRect(this.pvs, stageRatio2);
let weight = 10;
if (this.weight) {
weight = this.weight + 5;
}
outRect.x -= weight;
outRect.y -= weight;
let cx = x2 * stageRatio2 - outRect.x;
let cy = y2 * stageRatio2 - outRect.y;
let cdata = ctx.getImageData(cx, cy, 1, 1).data;
if (cdata && cdata[0] == 255 && cdata[1] != 255 && cdata[2] != 255) {
return true;
}
}
}
return false;
}
/**
* 移除自身的方法
*/
destroyed() {
var _a3;
let layer2 = this.layer;
if (!this.isShadowControl) {
let distLinks = (_a3 = this.stage) == null ? void 0 : _a3.getDistModelLinks(this.id);
distLinks == null ? void 0 : distLinks.forEach((dl) => {
var _a22, _b2;
if ((dl == null ? void 0 : dl.sm) && (dl == null ? void 0 : dl.smpath)) {
DDeiUtil$1.deletePropertyByPath(dl.sm, dl.smpath);
dl.sm.transVectors(new Matrix3());
dl.sm.updateLinkModels();
(_a22 = dl.sm.render) == null ? void 0 : _a22.enableRefreshShape();
}
(_b2 = this.stage) == null ? void 0 : _b2.removeLink(dl);
});
}
super.destroyed();
_DDeiLine2.calLineCross(layer2);
}
syncVectors(source, clonePV = false) {
var _a3, _b2;
super.syncVectors(source, clonePV);
if (source.freeze != null && source.freeze != void 0) {
this.freeze = source.freeze;
}
this.startPoint = this.pvs[0];
this.endPoint = this.pvs[this.pvs.length - 1];
let distLinks = (_a3 = this.stage) == null ? void 0 : _a3.getDistModelLinks(this.id);
distLinks == null ? void 0 : distLinks.forEach((dl) => {
let pv = null;
if (dl.dmpath == "startPoint") {
pv = this.startPoint;
} else {
pv = this.endPoint;
}
if ((dl == null ? void 0 : dl.sm) && (dl == null ? void 0 : dl.smpath)) {
DDeiUtil$1.setAttrValueByPath(dl.sm, dl.smpath + ".x", pv.x);
DDeiUtil$1.setAttrValueByPath(dl.sm, dl.smpath + ".y", pv.y);
}
});
for (let i2 = 0; i2 < ((_b2 = source.composes) == null ? void 0 : _b2.length); i2++) {
let scop = source.composes[i2];
let tcop = this.composes[i2];
tcop.syncVectors(scop, clonePV);
}
}
/**
* 初始化渲染器
*/
initRender() {
var _a3;
DDeiConfig$1.bindRender(this);
this.render.init();
(_a3 = this.composes) == null ? void 0 : _a3.forEach((compose) => {
compose.initRender();
});
delete this.__destroyed;
}
toJSON() {
var _a3, _b2, _c2;
let json = super.toJSON();
let ruleDisplay;
let ruleInit;
if (((_a3 = this.stage.ruler) == null ? void 0 : _a3.display) || ((_b2 = this.stage.ruler) == null ? void 0 : _b2.display) == 0 || ((_c2 = this.stage.ruler) == null ? void 0 : _c2.display) == false) {
ruleDisplay = this.stage.ruler.display;
} else if (this.stage.ddInstance.ruler != null && this.stage.ddInstance.ruler != void 0) {
if (typeof this.stage.ddInstance.ruler == "boolean") {
ruleDisplay = this.stage.ddInstance.ruler ? 1 : 0;
} else {
ruleInit = this.stage.ddInstance.ruler;
ruleDisplay = ruleInit.display;
}
} else {
ruleDisplay = DDeiModelArrtibuteValue.getAttrValueByState(this.stage, "ruler.display", true);
}
let unit = DDeiModelArrtibuteValue.getAttrValueByState(this.stage, "ruler.unit", true, ruleInit);
if (ruleDisplay) {
if (this.hpv) {
json.hpv = cloneDeep(this.hpv);
for (let i2 = 0; i2 < this.hpv.length; i2++) {
let hpv = DDeiUtil$1.toRulerCoord({ x: this.hpv[i2].x, y: this.hpv[i2].y }, this.stage, unit);
json.hpv[i2].x = hpv.x;
json.hpv[i2].y = hpv.y;
}
}
if (this.pvs) {
json.pvs = cloneDeep(this.pvs);
for (let i2 = 0; i2 < this.pvs.length; i2++) {
let pv = DDeiUtil$1.toRulerCoord({ x: this.pvs[i2].x, y: this.pvs[i2].y }, this.stage, unit);
json.pvs[i2].x = pv.x;
json.pvs[i2].y = pv.y;
}
}
if (this.exPvs) {
json.exPvs = cloneDeep(this.exPvs);
for (let i2 in this.exPvs) {
let pv = DDeiUtil$1.toRulerCoord({ x: this.exPvs[i2].x, y: this.exPvs[i2].y }, this.stage, unit);
json.exPvs[i2].x = pv.x;
json.exPvs[i2].y = pv.y;
}
}
}
return json;
}
};
_DDeiLine.calLineCross = debounce(_DDeiLine.calLineCross, 50);
__publicField(_DDeiLine, "ClsName", "DDeiLine");
let DDeiLine = _DDeiLine;
const __vite_glob_0_3$3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiLine,
default: DDeiLine
}, Symbol.toStringTag, { value: "Module" }));
class DDeiLayoutManager {
constructor(container2 = null) {
__publicField2(this, "container");
this.container = container2;
}
/**
* 计算时拖入待确认时的显示图形的向量
*/
calDragInPVS(x2, y2, models) {
if (this.container.layer) {
let pvs2 = this.container.pvs;
this.container.layer.dragInPoints = pvs2;
}
}
/**
* 计算时拖出确认时的显示图形的向量
*/
calDragOutPVS(x2, y2, models) {
if (this.container.layer) {
let pvs2 = this.container.pvs;
this.container.layer.dragOutPoints = pvs2;
}
}
/**
* 获取实际的内部容器控件
* @return 容器控件根据布局的模式不同返回不同的内部控件,普通控件返回null
*/
getAccuContainer() {
return this.container;
}
/**
* 获取实际的内部容器控件
* @param x 相对路径坐标
* @param y 相对路径坐标
* @return 容器控件根据布局的模式不同返回不同的内部控件,普通控件返回null
*/
getAccuContainerByPos(x2, y2) {
return this.container;
}
/**
* 获取切分区域的点,超出区域的范围不会显示内容
*/
getAreasPVS(rotated = true) {
return [this.container.pvs];
}
}
class DDeiLayoutManagerCompose extends DDeiLayoutManager {
// ============================ 方法 ===============================
/**
* 修改模型的位置和大小
*/
changeSubModelBounds() {
}
transVectors(matrix2) {
this.container.transVectors(matrix2);
}
/**
* 根据子模型大小,修改自身大小
*/
changeParentsBounds() {
this.container.updateBoundsByModels();
if (this.container.pModel) {
this.container.pModel.changeParentsBounds();
}
}
canAppend(x2, y2, models) {
return true;
}
append(x2, y2, models) {
models.forEach((item) => {
let oldContainer = item.pModel;
let newContainer = this.container;
if (oldContainer) {
item.destroyRender();
oldContainer.removeModel(item, false, false);
}
newContainer.addModel(item, false);
item.initRender();
});
return true;
}
/**
* 修改布局信息
*/
updateLayout(x2, y2, models, isAlt = false) {
}
canConvertLayout(oldLayout) {
return false;
}
convertLayout(oldLayout) {
}
canChangePosition(x2, y2, models, isAlt = false) {
return true;
}
canChangeSize(x2, y2, models) {
return true;
}
canChangeRotate() {
return true;
}
// ============================ 静态方法 ============================
/**
* 返回当前实例
*/
static newInstance(model) {
return new DDeiLayoutManagerCompose();
}
}
const __vite_glob_0_0$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiLayoutManagerCompose,
default: DDeiLayoutManagerCompose
}, Symbol.toStringTag, { value: "Module" }));
class DDeiLayoutManagerFree extends DDeiLayoutManager {
// ============================ 方法 ===============================
/**
* 根据自身大小修改子模型大小
*/
changeSubModelBounds() {
}
transVectors(matrix2) {
this.container.transSelfVectors(matrix2);
}
/**
* 根据子模型大小,修改自身大小
*/
changeParentsBounds() {
}
canAppend(x2, y2, models) {
var _a3;
let parentControls = this.container.getParents();
for (let i2 = 0; i2 < models.length; i2++) {
let model = models[i2];
if (model) {
if (model.id.indexOf("_shadow") != -1) {
let id = model.id.substring(model.id, model.id.lastIndexOf("_shadow"));
model = (_a3 = this.container.stage) == null ? void 0 : _a3.getModelById(id);
}
if (model == this.container) {
return false;
} else if (parentControls.indexOf(model) != -1) {
return false;
}
}
}
return true;
}
append(x2, y2, models) {
models.forEach((item) => {
if (item) {
let oldContainer = item.pModel;
let newContainer = this.container;
if (oldContainer) {
item.destroyRender();
oldContainer.removeModel(item, false, false);
}
newContainer.addModel(item, false);
item.initRender();
}
});
return true;
}
/**
* 修改布局信息
*/
updateLayout(x2, y2, models, isAlt = false) {
}
canConvertLayout(oldLayout) {
return true;
}
convertLayout(oldLayout) {
}
canChangePosition(x2, y2, models, isAlt = false) {
return true;
}
canChangeSize(x2, y2, models) {
return true;
}
canChangeRotate() {
return true;
}
// ============================ 静态方法 ============================
/**
* 返回当前实例
*/
static newInstance(model) {
return new DDeiLayoutManagerFree();
}
}
const __vite_glob_0_1$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiLayoutManagerFree,
default: DDeiLayoutManagerFree
}, Symbol.toStringTag, { value: "Module" }));
class DDeiLayoutManagerFull extends DDeiLayoutManager {
// ============================ 方法 ===============================
/**
* 修改模型的位置和大小
*/
changeSubModelBounds() {
if (this.container.models.size == 1) {
let model = Array.from(this.container.models.values())[0];
let m12 = new Matrix3();
let moveZeroMatrix = new Matrix3(
1,
0,
-model.cpv.x,
0,
1,
-model.cpv.y,
0,
0,
1
);
m12.premultiply(moveZeroMatrix);
if (model.rotate) {
let angle2 = (model.rotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let scaleMatrix2 = new Matrix3(
this.container.width / model.width,
0,
0,
0,
this.container.height / model.height,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
if (model.rotate) {
let angle2 = -(model.rotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let moveContainerMatrix = new Matrix3(
1,
0,
this.container.cpv.x,
0,
1,
this.container.cpv.y,
0,
0,
1
);
m12.premultiply(moveContainerMatrix);
model.transVectors(m12);
}
}
transVectors(matrix2) {
this.container.transVectors(matrix2);
}
/**
* 根据子模型大小,修改自身大小
*/
changeParentsBounds() {
}
canConvertLayout(oldLayout) {
if (this.container.models.size <= 1) {
return true;
} else {
return false;
}
}
convertLayout(oldLayout) {
}
updateLayout(x2, y2, models, isAlt = false) {
this.changeSubModelBounds();
}
canAppend(x2, y2, models) {
var _a3;
if ((models == null ? void 0 : models.length) == 1) {
let parentControls = this.container.getParents();
let model = models[0];
if (model.id.indexOf("_shadow") != -1) {
let id = model.id.substring(model.id, model.id.lastIndexOf("_shadow"));
model = (_a3 = this.container.stage) == null ? void 0 : _a3.getModelById(id);
}
if (model == this.container) {
return false;
} else if (parentControls.indexOf(model) != -1) {
return false;
}
return true;
}
return false;
}
append(x2, y2, models) {
var _a3;
let item = models[0];
let oldModel = null;
if (this.container.models.size == 1) {
oldModel = Array.from(this.container.models.values())[0];
}
let oldContainer = item.pModel;
let newContainer = this.container;
oldContainer.removeModel(item, false);
newContainer.addModel(item, false);
item.initRender();
if (oldModel) {
newContainer.removeModel(oldModel, false);
oldContainer.addModel(oldModel, false);
if (item.originCPV && item.originPVS) {
oldModel.cpv = item.originCPV;
oldModel.pvs = item.originPVS;
let rotate2 = oldModel.rotate;
oldModel.initPVS();
oldModel.setRotate(rotate2);
item.originCPV = null;
item.originPVS = null;
} else {
oldModel.syncVectors(item, true);
}
oldModel.initRender();
let oldAbsPos2 = oldContainer.getAbsPosition();
(_a3 = oldContainer.layoutManager) == null ? void 0 : _a3.updateLayout(oldAbsPos2.x, oldAbsPos2.y, [oldModel]);
}
return true;
}
canChangePosition(x2, y2, models, isAlt = false) {
if (isAlt) {
return true;
}
return false;
}
canChangeSize(x2, y2, models) {
return false;
}
canChangeRotate() {
return true;
}
// ============================ 静态方法 ============================
/**
* 返回当前实例
*/
static newInstance(model) {
return new DDeiLayoutManagerFull(model);
}
}
const __vite_glob_0_2$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiLayoutManagerFull,
default: DDeiLayoutManagerFull
}, Symbol.toStringTag, { value: "Module" }));
class DDeiLayoutManagerNine extends DDeiLayoutManager {
// ============================ 方法 ===============================
/**
* 是否可以从其他布局转换到当前布局的方法
* @return true可以转换,false不可以转换
*/
canConvertLayout(oldLayout) {
if (oldLayout == "free" || !oldLayout) {
if (this.container.models.size <= 9) {
return true;
} else {
return false;
}
} else if (oldLayout == "full") {
return true;
} else
;
return false;
}
/**
* 从其他布局转换到当前布局的方法
*/
convertLayout(oldLayout) {
var _a3;
if (!this.container.layoutData) {
this.container.layoutData = {};
}
this.container.layoutData.nine = {};
if (oldLayout == "free" || !oldLayout) {
let models = DDeiUtil$1.getSortedModels(this.container.models);
let idx = 0;
for (let row = 0; row < 3; row++) {
for (let col = 0; col < 3; col++) {
if (models.length > idx) {
this.container.layoutData.nine[models[idx].id] = { "row": row, "col": col };
idx++;
}
}
}
} else if (oldLayout == "full") {
if (((_a3 = this.container.models) == null ? void 0 : _a3.size) > 0) {
let model = Array.from(this.container.models.values())[0];
this.container.layoutData.nine[model.id] = { "row": 1, "col": 1 };
}
} else
;
}
/**
* 根据layoutData修改模型的位置和大小
*/
changeSubModelBounds() {
let layoutData = this.container.layoutData.nine;
let unitWidth = this.container.width / 3;
let unitHeight = this.container.height / 3;
let areasPVS = this.getAreasPVS();
for (let key in layoutData) {
let model = this.container.models.get(key);
let data = layoutData[key];
if (model) {
let m12 = new Matrix3();
let moveZeroMatrix = new Matrix3(
1,
0,
-model.cpv.x,
0,
1,
-model.cpv.y,
0,
0,
1
);
m12.premultiply(moveZeroMatrix);
if (model.rotate) {
let angle2 = (model.rotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let scaleMatrix2 = new Matrix3(
unitWidth / model.width,
0,
0,
0,
unitHeight / model.height,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
if (model.rotate) {
let angle2 = -(model.rotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let areaPV = areasPVS[data.row * 3 + data.col];
let areaPVC = { x: (areaPV[0].x + areaPV[2].x) / 2, y: (areaPV[0].y + areaPV[2].y) / 2 };
let moveContainerMatrix = new Matrix3(
1,
0,
areaPVC.x,
0,
1,
areaPVC.y,
0,
0,
1
);
m12.premultiply(moveContainerMatrix);
model.transVectors(m12);
if (model.changeChildrenBounds) {
model.changeChildrenBounds();
}
}
}
}
/**
* 根据子模型大小,修改自身大小
*/
changeParentsBounds() {
}
transVectors(matrix2) {
this.container.transVectors(matrix2);
}
canAppend(x2, y2, models) {
var _a3;
if ((models == null ? void 0 : models.length) == 1 || (models == null ? void 0 : models.length) <= 9 - this.container.models.size) {
let parentControls = this.container.getParents();
for (let i2 = 0; i2 < models.length; i2++) {
let model = models[i2];
if (model.id.indexOf("_shadow") != -1) {
let id = model.id.substring(model.id, model.id.lastIndexOf("_shadow"));
model = (_a3 = this.container.stage) == null ? void 0 : _a3.getModelById(id);
}
if (model == this.container) {
return false;
} else if (parentControls.indexOf(model) != -1) {
return false;
}
}
return true;
}
return false;
}
append(x2, y2, models) {
var _a3, _b2, _c2, _d2;
let layoutData = null;
if ((_b2 = (_a3 = this == null ? void 0 : this.container) == null ? void 0 : _a3.layoutData) == null ? void 0 : _b2.nine) {
layoutData = this.container.layoutData.nine;
}
let layoutIndex = this.getLayoutIndex(x2, y2);
let indexModel = null;
let emptyAreas = [
[0, 0, 0],
[0, 0, 0],
[0, 0, 0]
];
for (let key in layoutData) {
let data = layoutData[key];
if (data.row == layoutIndex.row && data.col == layoutIndex.col) {
indexModel = this.container.models.get(key);
}
emptyAreas[data.row][data.col] = 1;
}
let newContainer = this.container;
for (let i2 = 0; i2 < models.length; i2++) {
let item = models[i2];
let oldContainer = item.pModel;
if (oldContainer) {
oldContainer.removeModel(item, false);
}
newContainer.addModel(item, false);
item.initRender();
if (models.length == 1 && layoutIndex.row != -1 && layoutIndex.col != -1) {
layoutData[item.id] = { row: layoutIndex.row, col: layoutIndex.col };
if (indexModel) {
newContainer.removeModel(indexModel, false);
if (item.dragOriginX || item.dragOriginX == 0) {
indexModel.setBounds(item.dragOriginX, item.dragOriginY, item.dragOriginWidth, item.dragOriginHeight);
item.dragOriginX = null;
item.dragOriginY = null;
item.dragOriginWidth = null;
item.dragOriginHeight = null;
}
if (oldContainer.layout == "nine") {
let oldLayoutData = (_c2 = oldContainer == null ? void 0 : oldContainer.layoutData) == null ? void 0 : _c2.nine;
let oldLayoutInfo = oldLayoutData[item.id];
if (oldLayoutInfo) {
delete oldLayoutData[item.id];
oldLayoutData[indexModel.id] = oldLayoutInfo;
}
}
oldContainer.addModel(indexModel, false);
indexModel.initRender();
(_d2 = oldContainer.layoutManager) == null ? void 0 : _d2.updateLayout(oldAbsPos.x, oldAbsPos.y, [indexModel]);
}
} else {
for (let sr = 0; sr < 3; sr++) {
let has = false;
for (let sc = 0; sc < 3; sc++) {
if (emptyAreas[sr][sc] == 0) {
layoutData[item.id] = { row: sr, col: sc };
emptyAreas[sr][sc] = 1;
has = true;
break;
}
}
if (has) {
break;
}
}
}
}
return true;
}
/**
* 修改布局信息
*/
updateLayout(x2, y2, models) {
var _a3, _b2;
if (((_b2 = (_a3 = this == null ? void 0 : this.container) == null ? void 0 : _a3.layoutData) == null ? void 0 : _b2.nine) && (models == null ? void 0 : models.length) > 0) {
let layoutData = this.container.layoutData.nine;
let layoutIndex = this.getLayoutIndex(x2, y2);
if (layoutIndex.row != -1 && layoutIndex.col != -1) {
let oldRow = -1;
let oldCol = -1;
if (layoutData[models[0].id]) {
oldRow = layoutData[models[0].id].row;
oldCol = layoutData[models[0].id].col;
}
let oldModel = null;
for (let key in layoutData) {
let data = layoutData[key];
if (data.row == layoutIndex.row && data.col == layoutIndex.col) {
oldModel = this.container.models.get(key);
break;
}
}
if (oldRow == -1 && oldModel)
;
else if (oldRow != -1 && oldModel) {
layoutData[models[0].id] = { row: layoutIndex.row, col: layoutIndex.col };
layoutData[oldModel.id] = { row: oldRow, col: oldCol };
} else if (!oldModel) {
layoutData[models[0].id] = { row: layoutIndex.row, col: layoutIndex.col };
}
}
}
this.changeSubModelBounds();
}
canChangePosition(x2, y2, models, isAlt = false) {
if (isAlt) {
return true;
} else if (this.container.isInAreaLoose(x2, y2, 0)) {
return true;
}
return false;
}
canChangeSize(x2, y2, models) {
return false;
}
canChangeRotate() {
return true;
}
/**
* 获取切分区域的点,超出区域的范围不会显示内容
*/
getAreasPVS() {
var _a3;
let stageRatio2 = (_a3 = this.container) == null ? void 0 : _a3.getStageRatio();
let vc1 = new Vector3(this.container.pvs[0].x, this.container.pvs[0].y, 1);
let vc2 = new Vector3(this.container.pvs[1].x, this.container.pvs[1].y, 1);
let vc3 = new Vector3(this.container.pvs[2].x, this.container.pvs[2].y, 1);
let vc4 = new Vector3(this.container.pvs[3].x, this.container.pvs[3].y, 1);
let width = this.container.width * stageRatio2;
let height = this.container.height * stageRatio2;
let unitWidth = width / 3;
let unitHeight = height / 3;
if (this.container.rotate) {
let move1Matrix = new Matrix3(
1,
0,
-this.container.cpv.x,
0,
1,
-this.container.cpv.y,
0,
0,
1
);
let angle2 = this.container.rotate * DDeiConfig$1.ROTATE_UNIT;
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
let move2Matrix = new Matrix3(
1,
0,
this.container.cpv.x,
0,
1,
this.container.cpv.y,
0,
0,
1
);
let m12 = new Matrix3().premultiply(move1Matrix).premultiply(rotateMatrix).premultiply(move2Matrix);
vc1.applyMatrix3(m12);
vc2.applyMatrix3(m12);
vc3.applyMatrix3(m12);
vc4.applyMatrix3(m12);
}
let p11 = new Vector3(vc1.x, vc1.y, 1);
let p12 = new Vector3(vc1.x + unitWidth, vc1.y, 1);
let p13 = new Vector3(vc1.x + unitWidth * 2, vc1.y, 1);
let p14 = new Vector3(vc2.x, vc2.y, 1);
let p21 = new Vector3(vc1.x, vc1.y + unitHeight, 1);
let p22 = new Vector3(vc1.x + unitWidth, vc1.y + unitHeight, 1);
let p23 = new Vector3(vc1.x + unitWidth * 2, vc1.y + unitHeight, 1);
let p24 = new Vector3(vc2.x, vc1.y + unitHeight, 1);
let p31 = new Vector3(vc1.x, vc1.y + unitHeight * 2, 1);
let p32 = new Vector3(vc1.x + unitWidth, vc1.y + unitHeight * 2, 1);
let p33 = new Vector3(vc1.x + unitWidth * 2, vc1.y + unitHeight * 2, 1);
let p34 = new Vector3(vc2.x, vc1.y + unitHeight * 2, 1);
let p41 = new Vector3(vc4.x, vc4.y, 1);
let p42 = new Vector3(vc4.x + unitWidth, vc4.y, 1);
let p43 = new Vector3(vc4.x + unitWidth * 2, vc4.y, 1);
let p44 = new Vector3(vc3.x, vc4.y, 1);
if (this.container.rotate) {
let centerPoint = this.container.cpv;
let move1Matrix = new Matrix3(
1,
0,
-centerPoint.x,
0,
1,
-centerPoint.y,
0,
0,
1
);
let angle2 = -this.container.rotate * DDeiConfig$1.ROTATE_UNIT;
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
let move2Matrix = new Matrix3(
1,
0,
centerPoint.x,
0,
1,
centerPoint.y,
0,
0,
1
);
let m12 = new Matrix3().premultiply(move1Matrix).premultiply(rotateMatrix).premultiply(move2Matrix);
p11.applyMatrix3(m12);
p12.applyMatrix3(m12);
p13.applyMatrix3(m12);
p14.applyMatrix3(m12);
p21.applyMatrix3(m12);
p22.applyMatrix3(m12);
p23.applyMatrix3(m12);
p24.applyMatrix3(m12);
p31.applyMatrix3(m12);
p32.applyMatrix3(m12);
p33.applyMatrix3(m12);
p34.applyMatrix3(m12);
p41.applyMatrix3(m12);
p42.applyMatrix3(m12);
p43.applyMatrix3(m12);
p44.applyMatrix3(m12);
}
let returnArray = [
[p11, p12, p22, p21],
[p12, p13, p23, p22],
[p13, p14, p24, p23],
[p21, p22, p32, p31],
[p22, p23, p33, p32],
[p23, p24, p34, p33],
[p31, p32, p42, p41],
[p32, p33, p43, p42],
[p33, p34, p44, p43]
];
return returnArray;
}
/**
* 计算时拖入待确认时的显示图形的向量
*/
calDragInPVS(x2, y2, models) {
if (this.container.layer) {
let areasPVS = this.getAreasPVS();
for (let i2 = 0; i2 < areasPVS.length; i2++) {
let inArea = DDeiAbstractShape.isInsidePolygon(
areasPVS[i2],
{ x: x2, y: y2 }
);
if (inArea) {
this.container.layer.dragInPoints = areasPVS[i2];
return;
}
}
}
}
/**
* 计算时拖入出确认时的显示图形的向量
*/
calDragOutPVS(x2, y2, models) {
var _a3, _b2;
if (this.container.layer && models.length > 0) {
let model = models[0];
if (model.id.indexOf("_shadow") != -1) {
model = (_b2 = (_a3 = this.container) == null ? void 0 : _a3.stage) == null ? void 0 : _b2.getModelById(model.id.substring(0, model.id.lastIndexOf("_shadow")));
}
let areasPVS = this.getAreasPVS();
for (let i2 = 0; i2 < areasPVS.length; i2++) {
let inArea = DDeiAbstractShape.isInsidePolygon(
areasPVS[i2],
{ x: model.cpv.x, y: model.cpv.y }
);
if (inArea) {
this.container.layer.dragOutPoints = areasPVS[i2];
return;
}
}
}
}
/**
* 获取落入的布局行列
* @param x
* @param y
* @returns
*/
getLayoutIndex(x2, y2) {
if (this.container.layer) {
let areasPVS = this.getAreasPVS();
for (let i2 = 0; i2 < areasPVS.length; i2++) {
let inArea = DDeiAbstractShape.isInsidePolygon(
areasPVS[i2],
{ x: x2, y: y2 }
);
if (inArea) {
let row = parseInt(i2 / 3);
let col = parseInt(i2 % 3);
return { row, col };
}
}
}
return { row: -1, col: -1 };
}
// ============================ 静态方法 ============================
/**
* 返回当前实例
*/
static newInstance(model) {
return new DDeiLayoutManagerNine(model);
}
}
const __vite_glob_0_3$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiLayoutManagerNine,
default: DDeiLayoutManagerNine
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiLayoutManagerFactory = class _DDeiLayoutManagerFactory2 {
/**
* 根据layout获取layout实例
*/
static getLayoutInstance(layout) {
var _a3, _b2;
if (_DDeiLayoutManagerFactory2.LayoutManagers.size == 0) {
let modules2 = /* @__PURE__ */ Object.assign({ "./manager/layout-manager-compose.ts": __vite_glob_0_0$1$1, "./manager/layout-manager-free.ts": __vite_glob_0_1$1$1, "./manager/layout-manager-full.ts": __vite_glob_0_2$1$1, "./manager/layout-manager-nine.ts": __vite_glob_0_3$2 });
for (let i2 in modules2) {
let cls = modules2[i2].default;
let newI = i2.substring(i2.lastIndexOf("-") + 1, i2.lastIndexOf("."));
_DDeiLayoutManagerFactory2.LayoutManagers.set(newI, cls);
}
}
if (layout) {
let lm = (_a3 = _DDeiLayoutManagerFactory2.LayoutManagers.get(layout)) == null ? void 0 : _a3.newInstance();
if (lm) {
return lm;
}
}
return (_b2 = _DDeiLayoutManagerFactory2.LayoutManagers.get("free")) == null ? void 0 : _b2.newInstance();
}
};
__publicField2(_DDeiLayoutManagerFactory, "LayoutManagers", /* @__PURE__ */ new Map());
let DDeiLayoutManagerFactory = _DDeiLayoutManagerFactory;
const _DDeiPolygon = class _DDeiPolygon2 extends DDeiAbstractShape {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "border");
__publicField2(this, "fill");
__publicField2(this, "font");
__publicField2(this, "imgBase64");
__publicField2(this, "text");
__publicField2(this, "textStyle");
__publicField2(this, "textArea");
__publicField2(this, "modelType", "DDeiPolygon");
__publicField2(this, "baseModelType", "DDeiPolygon");
this.border = props.border ? props.border : null;
this.fill = props.fill ? props.fill : null;
this.font = props.font ? props.font : null;
this.text = props.text ? props.text : "";
this.imgBase64 = props.imgBase64 ? props.imgBase64 : "";
this.textStyle = props.textStyle ? props.textStyle : null;
if (props.textArea) {
this.textArea = [];
props.textArea.forEach((pvd) => {
let pv = new Vector3();
for (let i2 in pvd) {
pv[i2] = pvd[i2];
}
pv.z = pvd.z || pvd.z === 0 ? pvd.z : 1;
this.textArea.push(pv);
});
}
}
// ============================ 静态变量 ============================
// ============================ 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static loadFromJSON(json, tempData = {}, initPVS = true) {
var _a3, _b2;
let model = new _DDeiPolygon2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
let ddInstance = (_a3 = model.stage) == null ? void 0 : _a3.ddInstance;
if (!model.pModel) {
model.pModel = model.layer;
}
tempData[model.id] = model;
if (((_b2 = json == null ? void 0 : json.composes) == null ? void 0 : _b2.length) > 0) {
let composes = [];
json == null ? void 0 : json.composes.forEach((composeJSON) => {
let def = DDeiUtil$1.getControlDefine(composeJSON);
let composeModel = ddInstance.controlModelClasses[def.type].loadFromJSON(
composeJSON,
tempData,
false
);
composeModel.pModel = model;
composes.push(composeModel);
});
model.composes = composes;
}
if (initPVS) {
model.initPVS();
}
model.initRender();
return model;
}
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json, tempData = {}, initPVS = true) {
var _a3, _b2;
let model = new _DDeiPolygon2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
let ddInstance = (_a3 = model.stage) == null ? void 0 : _a3.ddInstance;
if (((_b2 = json == null ? void 0 : json.composes) == null ? void 0 : _b2.length) > 0) {
let composes = [];
for (let ci = 0; ci < json.composes.length; ci++) {
let composeJSON = json.composes[ci];
let def = DDeiUtil$1.getControlDefine(composeJSON);
let composeModel = ddInstance.controlModelClasses[def.type].initByJSON(
composeJSON,
tempData,
false
);
composeModel.modelCode = composeModel.id;
composeModel.id = model.id + "_comp_" + ci;
composeModel.pModel = model;
composes.push(composeModel);
}
model.composes = composes;
}
if (initPVS) {
model.initPVS();
}
return model;
}
// ============================ 方法 ===============================
/**
* 初始化渲染器
*/
initRender() {
var _a3;
DDeiConfig$1.bindRender(this);
this.render.init();
(_a3 = this.composes) == null ? void 0 : _a3.forEach((compose) => {
compose.initRender();
});
delete this.__destroyed;
}
//覆写hpv
initHPV() {
}
transVectors(matrix2, params) {
if (this.poly == 2)
;
else {
this.textArea.forEach((pv) => {
pv.applyMatrix3(matrix2);
});
this.hpv.forEach((pv) => {
pv.applyMatrix3(matrix2);
});
}
super.transVectors(matrix2, params);
}
/**
* 同步向量
* @param source 源模型
* @param cloneVP 是否克隆向量,默认false
*/
syncVectors(source, clonePV = false) {
if (this.poly == 2)
;
else {
if (clonePV) {
this.textArea = cloneDeep(source.textArea);
this.hpv = cloneDeep(source.hpv);
} else {
this.textArea = source.textArea;
this.hpv = source.hpv;
}
}
super.syncVectors(source, clonePV);
}
/**
* 返回某个点,相对于该图形的角度
*/
getPointAngle(point2) {
let bpv2 = DDeiUtil$1.pointsToZero([this.bpv], this.cpv, this.rotate)[0];
let scaleX2 = Math.abs(bpv2.x / 100);
let scaleY2 = Math.abs(bpv2.y / 100);
let zeroPoint = DDeiUtil$1.pointsToZero([new Vector3(point2.x, point2.y, 1)], this.cpv, this.rotate)[0];
zeroPoint.x /= scaleX2;
zeroPoint.y /= scaleY2;
let lineAngle = parseFloat(DDeiUtil$1.getLineAngle(0, 0, zeroPoint.x, zeroPoint.y).toFixed(4));
if (lineAngle < -45 && lineAngle > -135) {
return -90;
} else if (lineAngle > -45 && lineAngle < 45) {
return 0;
} else if (lineAngle > 45 && lineAngle < 135) {
return 90;
} else {
switch (lineAngle) {
case -45:
return 1002;
case 45:
return 1003;
case -135:
return 1001;
case 135:
return 1004;
}
return 180;
}
}
toJSON() {
var _a3, _b2, _c2;
let json = super.toJSON();
let ruleDisplay;
let ruleInit;
if (((_a3 = this.stage.ruler) == null ? void 0 : _a3.display) || ((_b2 = this.stage.ruler) == null ? void 0 : _b2.display) == 0 || ((_c2 = this.stage.ruler) == null ? void 0 : _c2.display) == false) {
ruleDisplay = this.stage.ruler.display;
} else if (this.stage.ddInstance.ruler != null && this.stage.ddInstance.ruler != void 0) {
if (typeof this.stage.ddInstance.ruler == "boolean") {
ruleDisplay = this.stage.ddInstance.ruler ? 1 : 0;
} else {
ruleInit = this.stage.ddInstance.ruler;
ruleDisplay = ruleInit.display;
}
} else {
ruleDisplay = DDeiModelArrtibuteValue.getAttrValueByState(this.stage, "ruler.display", true);
}
let unit = DDeiModelArrtibuteValue.getAttrValueByState(this.stage, "ruler.unit", true, ruleInit);
if (ruleDisplay) {
if (this.cpv) {
json.cpv = cloneDeep(this.cpv);
let cpv = DDeiUtil$1.toRulerCoord({ x: this.cpv.x, y: this.cpv.y }, this.stage, unit);
json.cpv.x = cpv.x;
json.cpv.y = cpv.y;
}
if (this.hpv) {
json.hpv = cloneDeep(this.hpv);
for (let i2 = 0; i2 < this.hpv.length; i2++) {
let hpv = DDeiUtil$1.toRulerCoord({ x: this.hpv[i2].x, y: this.hpv[i2].y }, this.stage, unit);
json.hpv[i2].x = hpv.x;
json.hpv[i2].y = hpv.y;
}
}
if (this.bpv) {
json.bpv = cloneDeep(this.bpv);
let bpv2 = DDeiUtil$1.toRulerCoord({ x: this.bpv.x, y: this.bpv.y }, this.stage, unit);
json.bpv.x = bpv2.x;
json.bpv.y = bpv2.y;
}
if (this.exPvs) {
json.exPvs = cloneDeep(this.exPvs);
for (let i2 in this.exPvs) {
let pv = DDeiUtil$1.toRulerCoord({ x: this.exPvs[i2].x, y: this.exPvs[i2].y }, this.stage, unit);
json.exPvs[i2].x = pv.x;
json.exPvs[i2].y = pv.y;
}
}
}
return json;
}
};
__publicField2(_DDeiPolygon, "ClsName", "DDeiPolygon");
let DDeiPolygon = _DDeiPolygon;
const __vite_glob_0_7$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiPolygon,
default: DDeiPolygon
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiPolygonContainer = class _DDeiPolygonContainer2 extends DDeiPolygon {
constructor(props) {
super(props);
__publicField2(this, "modelType", "DDeiPolygonContainer");
__publicField2(this, "baseModelType", "DDeiContainer");
__publicField2(this, "layout");
__publicField2(this, "layoutData");
__publicField2(this, "layoutManager");
__publicField2(this, "models");
__publicField2(this, "midList");
this.layout = props.layout;
this.layoutData = props.layoutData;
this.models = props.models ? props.models : /* @__PURE__ */ new Map();
this.midList = props.midList ? props.midList : new Array();
this.layoutManager = DDeiLayoutManagerFactory.getLayoutInstance(this.layout);
this.layoutManager.container = this;
}
// ============================ 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static loadFromJSON(json, tempData = {}) {
var _a3;
let container2 = new _DDeiPolygonContainer2(json);
container2.layer = tempData["currentLayer"];
container2.stage = tempData["currentStage"];
container2.pModel = tempData["currentContainer"];
if (!container2.pModel) {
container2.pModel = container2.layer;
}
let ddInstance = (_a3 = container2.stage) == null ? void 0 : _a3.ddInstance;
tempData[container2.id] = container2;
let models = /* @__PURE__ */ new Map();
let midList = new Array();
for (let key in json.models) {
tempData["currentContainer"] = container2;
let item = json.models[key];
let model = ddInstance.controlModelClasses[item.modelType].loadFromJSON(item, tempData);
models.set(key, model);
tempData["currentContainer"] = null;
midList.push(model.id);
}
container2.models = models;
container2.midList = midList;
container2.initPVS();
container2.initRender();
return container2;
}
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json, tempData = {}) {
let model = new _DDeiPolygonContainer2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
model.initPVS();
return model;
}
// ============================ 方法 ===============================
/**
* 计算当前容器的模型总数量
*/
calModelNumber() {
let num = 0;
this.midList.forEach((mid) => {
let model = this.models.get(mid);
if ((model == null ? void 0 : model.baseModelType) == "DDeiContainer") {
num += model.calModelNumber();
} else if ((model == null ? void 0 : model.baseModelType) == "DDeiTable") {
num += model.calModelNumber();
} else {
num++;
}
});
return num;
}
/**
* 初始化渲染器
*/
initRender() {
DDeiConfig$1.bindRender(this);
this.render.init();
this.models.forEach((item, key) => {
item.initRender();
});
delete this.__destroyed;
}
/**
* 添加模型,并维护关系
* @param model 被添加的模型
*/
addModel(model, notify = true) {
if (this.midList.indexOf(model.id) == -1) {
model.stage = this.stage;
this.models.set(model.id, model);
this.midList.push(model.id);
model.pModel = this;
model.layer = this.layer;
this.resortModelByZIndex();
if (notify) {
this.notifyChange();
}
}
}
/**
* 移除模型,并维护关系
* @param model 被移除的模型
* @param destroy 销毁,缺省false
*/
removeModels(models, destroy = false, notify = true) {
models == null ? void 0 : models.forEach((model) => {
this.removeModel(model, destroy);
});
if (notify) {
this.notifyChange();
}
}
/**
* 移除模型,并维护关系
* @param model 被移除的模型
* @param destroy 销毁,缺省false
*/
removeModel(model, destroy = false, notify = true) {
var _a3;
this.models.delete(model.id);
let idx = this.midList.indexOf(model.id);
if (idx != -1) {
this.midList.splice(idx, 1);
}
if (destroy) {
model.destroyed();
}
model.pModel = null;
model.stage = null;
model.render = null;
if ((_a3 = this.stage) == null ? void 0 : _a3.render) {
this.stage.render.refreshJumpLine = false;
}
if (notify) {
this.notifyChange();
}
}
/**
* 移除自身的方法
*/
destroyed() {
this.midList.forEach((key) => {
let item = this.models.get(key);
item.destroyed();
});
super.destroyed();
}
/**
* 移除渲染器
*/
destroyRender() {
super.destroyRender();
this.midList.forEach((key) => {
let item = this.models.get(key);
item == null ? void 0 : item.destroyRender();
});
}
/**
* 仅变换自身向量
*/
transSelfVectors(matrix2) {
super.transVectors(matrix2);
}
/**
* 变换向量
*/
transVectors(matrix2, params) {
super.transVectors(matrix2, params);
if (!(params == null ? void 0 : params.ignoreChildren)) {
this.midList.forEach((key) => {
let item = this.models.get(key);
item.transVectors(matrix2, params);
});
}
}
/**
* 变换向量,只能用于两个结构和数据相同的变量进行交换,如影子控件
*/
syncVectors(source) {
super.syncVectors(source);
this.midList.forEach((key) => {
let itemDist = this.models.get(key);
let itemSource = source.models.get(key);
itemDist.syncVectors(itemSource);
});
}
/**
* 获取实际的内部容器控件
* @return 容器控件根据布局的模式不同返回不同的内部控件,普通控件返回null
*/
getAccuContainer() {
return this.layoutManager ? this.layoutManager.getAccuContainer() : this;
}
/**
* 获取实际的内部容器控件
* @param x 相对路径坐标
* @param y 相对路径坐标
* @return 容器控件根据布局的模式不同返回不同的内部控件,普通控件返回null
*/
getAccuContainerByPos(x2, y2) {
return this.layoutManager ? this.layoutManager.getAccuContainerByPos(x2, y2) : this;
}
/**
* 根据基础模型获取控件
* @param bmt 基础模型类别
*/
getModelsByBaseType(bmt) {
let returnValues = [];
this.midList.forEach((mid) => {
let model = this.models.get(mid);
if ((model == null ? void 0 : model.baseModelType) == bmt) {
returnValues.push(model);
} else if ((model == null ? void 0 : model.baseModelType) == "DDeiContainer") {
let datas2 = model.getModelsByBaseType(bmt);
datas2.forEach((dt) => {
returnValues.push(dt);
});
}
});
return returnValues;
}
/**
* 获取子模型
*/
getSubModels(ignoreModelIds, level = 1, rect) {
let models = [];
this.midList.forEach((mid) => {
if (ignoreModelIds && (ignoreModelIds == null ? void 0 : ignoreModelIds.indexOf(mid)) != -1) {
return;
}
let subModel = this.models.get(mid);
if (subModel) {
if (!rect || subModel.isInRect(rect.x, rect.y, rect.x1, rect.y1)) {
if (level > 1 && subModel.getSubModels) {
let subModels = subModel.getSubModels(ignoreModelIds, level - 1, rect);
models = models.concat(subModels);
}
models.push(subModel);
}
}
});
return models;
}
/**
* 获取子模型,通过一个过滤器
*/
getSubModelsByFilter(filterName = null, ignoreModelIds, level = 1, params) {
let models = [];
this.midList.forEach((mid) => {
if (ignoreModelIds && (ignoreModelIds == null ? void 0 : ignoreModelIds.indexOf(mid)) != -1) {
return;
}
let subModel = null;
if (this.models.get) {
subModel = this.models.get(mid);
} else {
subModel = this.models[mid];
}
if (subModel) {
let filterMethod = null;
if (filterName) {
let define2 = DDeiUtil$1.getControlDefine(subModel);
if (define2 && define2.filters && define2.filters[filterName]) {
filterMethod = define2.filters[filterName];
}
}
if (!filterMethod || filterMethod(subModel, params)) {
if (level > 1 && (subModel == null ? void 0 : subModel.getSubModelsByFilter)) {
let subModels = subModel.getSubModelsByFilter(filterName, ignoreModelIds, level - 1, params);
models = models.concat(subModels);
}
models.push(subModel);
}
}
});
return models;
}
/**
* 将控件设置到顶层
*/
pushTop(models) {
models.forEach((item) => {
let lastItem = this.models.get(this.midList[this.midList.length - 1]);
if (lastItem.id != item.id) {
let lastIndex = lastItem.zIndex ? lastItem == null ? void 0 : lastItem.zIndex : 0;
item.zIndex = lastIndex + 1;
}
});
this.resortModelByZIndex();
}
/**
* 将控件设置到底层
*/
pushBottom(models) {
models.forEach((item) => {
item.zIndex = null;
let oldIdIndex = this.midList.indexOf(item.id);
if (oldIdIndex > 0) {
this.midList.splice(oldIdIndex, 1);
this.midList.splice(0, 0, item.id);
}
});
this.resortModelByZIndex();
}
/**
* 将控件设置到上一层
*/
pushUp(models) {
models.forEach((item) => {
if (!item.zIndex) {
item.zIndex = 1;
} else {
item.zIndex++;
}
});
this.resortModelByZIndex();
}
/**
* 将控件设置到下一层
*/
pushDown(models) {
models.forEach((item) => {
if (!item.zIndex || item.zIndex <= 1) {
item.zIndex = null;
let oldIdIndex = this.midList.indexOf(item.id);
if (oldIdIndex > 0) {
let temp = this.midList[oldIdIndex];
this.midList[oldIdIndex] = this.midList[oldIdIndex - 1];
this.midList[oldIdIndex - 1] = temp;
}
} else {
item.zIndex--;
}
});
this.resortModelByZIndex();
}
/**
* 按照Zindex的顺序,从小到大排列,并重新设置子元素的zindex确保其连续,最后将排序后的List设置成新的midList
*/
resortModelByZIndex() {
let newMidList = new Array();
let hadZIndexList = new Array();
for (let mg = 0; mg < this.midList.length; mg++) {
let item = this.models.get(this.midList[mg]);
if (item.zIndex && item.zIndex > 0) {
let insertIndex = hadZIndexList.length;
for (let j2 = 0; j2 < hadZIndexList.length; j2++) {
if (this.models.get(hadZIndexList[j2]).zIndex > item.zIndex) {
insertIndex = j2;
break;
}
}
hadZIndexList.splice(insertIndex, 0, item.id);
} else {
newMidList.push(item.id);
}
}
this.midList = newMidList.concat(hadZIndexList);
}
cascadeRemoveSelf() {
var _a3, _b2;
let newContainer = this.pModel;
if (newContainer.baseModelType == "DDeiLayer" && !newContainer.layoutManager) {
let freeLayoutManager = DDeiLayoutManagerFactory.getLayoutInstance("free");
freeLayoutManager.container = newContainer;
newContainer.layoutManager = freeLayoutManager;
}
if (this.layout == "compose" && this.models.size <= 1) {
let models = Array.from(this.models.values());
(_a3 = newContainer.layoutManager) == null ? void 0 : _a3.append(null, null, models);
newContainer.changeParentsBounds();
(_b2 = newContainer.layoutManager) == null ? void 0 : _b2.updateLayout(null, null, models);
newContainer.removeModel(this, true);
}
newContainer == null ? void 0 : newContainer.cascadeRemoveSelf();
}
/**
* 获取选中状态的所有控件
* @returns
*/
getSelectedModels() {
let controls2 = /* @__PURE__ */ new Map();
this.models.forEach((item, key) => {
if (item.state == DDeiEnumControlState.SELECTED) {
controls2.set(item.id, item);
}
});
return controls2;
}
/**
* 取消选择控件,默认取消所有
*/
cancelSelectModels(models, ignoreModels) {
if (!models) {
models = Array.from(this.models.values());
}
models.forEach((item) => {
if (!ignoreModels || (ignoreModels == null ? void 0 : ignoreModels.indexOf(item)) == -1) {
item.setState(DDeiEnumControlState.DEFAULT);
}
});
}
/**
* 取消选择控件,默认取消所有
*/
cancelAllLevelSelectModels(ignoreModels) {
this.models.forEach((item) => {
if (!ignoreModels || (ignoreModels == null ? void 0 : ignoreModels.indexOf(item)) == -1) {
item.setState(DDeiEnumControlState.DEFAULT);
}
if (item.baseModelType == "DDeiContainer") {
item.cancelAllLevelSelectModels(ignoreModels);
}
});
}
/**
* 根据ID获取模型
* @param id 模型id
*/
getModelById(id) {
let reutrnModel = null;
if (id) {
if (this.models.has(id)) {
reutrnModel = this.models.get(id);
} else {
this.models.forEach((item) => {
let container2 = item.getAccuContainer();
if (container2) {
let rm = container2.getModelById(id);
if (rm) {
reutrnModel = rm;
}
}
});
}
}
if (!reutrnModel) {
reutrnModel = null;
}
return reutrnModel;
}
/**
* 修改上层模型大小
*/
changeParentsBounds() {
if (this.layoutManager) {
this.layoutManager.changeParentsBounds();
}
return true;
}
/**
* 通过下层模型更新本层模型的信息
*/
updateBoundsByModels() {
let subModels = Array.from(this.models.values());
let outRect = DDeiAbstractShape.getOutRectByPV(subModels);
this.setSelfBounds(outRect.x, outRect.y, outRect.width, outRect.height);
this.setModelChanged();
}
//仅设置自身的大小以及宽高
setSelfBounds(x2, y2, width, height) {
let m12 = new Matrix3();
let move1Matrix = new Matrix3(
1,
0,
-this.cpv.x,
0,
1,
-this.cpv.y,
0,
0,
1
);
m12.premultiply(move1Matrix);
if (this.rotate) {
let angle2 = DDeiUtil$1.preciseTimes(this.rotate, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let scaleMatrix2 = new Matrix3(
width / this.essBounds.width,
0,
0,
0,
height / this.essBounds.height,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
if (this.rotate) {
let angle2 = -DDeiUtil$1.preciseTimes(this.rotate, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let move2Matrix = new Matrix3(
1,
0,
x2 + width / 2,
0,
1,
y2 + height / 2,
0,
0,
1
);
m12.premultiply(move2Matrix);
this.transSelfVectors(m12);
}
/**
* 修改子元素大小
*/
changeChildrenBounds() {
if (this.layoutManager) {
this.layoutManager.changeSubModelBounds();
}
return true;
}
/**
* 更新关联图形
*/
updateLinkModels(ignoreModelIds) {
super.updateLinkModels(ignoreModelIds);
this.models.forEach((model) => {
model.updateLinkModels(ignoreModelIds);
});
}
getAPVS() {
let arr = [this.cpv];
this.models.forEach((model) => {
let modelarr = model.getAPVS();
arr = arr.concat(modelarr);
});
return arr;
}
removeModelById(ids) {
ids == null ? void 0 : ids.forEach((id) => {
let model = this.getModelById(id);
if (model) {
this.removeModel(model);
}
});
this.models.forEach((model) => {
if (model.baseModelType == "DDeiContainer") {
model.removeModelById(ids);
}
});
}
toJSON() {
var _a3, _b2, _c2;
let json = super.toJSON();
let ruleDisplay;
let ruleInit;
if (((_a3 = this.stage.ruler) == null ? void 0 : _a3.display) || ((_b2 = this.stage.ruler) == null ? void 0 : _b2.display) == 0 || ((_c2 = this.stage.ruler) == null ? void 0 : _c2.display) == false) {
ruleDisplay = this.stage.ruler.display;
} else if (this.stage.ddInstance.ruler != null && this.stage.ddInstance.ruler != void 0) {
if (typeof this.stage.ddInstance.ruler == "boolean") {
ruleDisplay = this.stage.ddInstance.ruler ? 1 : 0;
} else {
ruleInit = this.stage.ddInstance.ruler;
ruleDisplay = ruleInit.display;
}
} else {
ruleDisplay = DDeiModelArrtibuteValue.getAttrValueByState(this.stage, "ruler.display", true);
}
let unit = DDeiModelArrtibuteValue.getAttrValueByState(this.stage, "ruler.unit", true, ruleInit);
if (ruleDisplay) {
if (this.cpv) {
json.cpv = cloneDeep(this.cpv);
let cpv = DDeiUtil$1.toRulerCoord({ x: this.cpv.x, y: this.cpv.y }, this.stage, unit);
json.cpv.x = cpv.x;
json.cpv.y = cpv.y;
}
if (this.pvs) {
json.pvs = cloneDeep(this.pvs);
for (let i2 = 0; i2 < this.pvs.length; i2++) {
let pv = DDeiUtil$1.toRulerCoord({ x: this.pvs[i2].x, y: this.pvs[i2].y }, this.stage, unit);
json.pvs[i2].x = pv.x;
json.pvs[i2].y = pv.y;
}
}
if (this.exPvs) {
json.exPvs = cloneDeep(this.exPvs);
for (let i2 in this.exPvs) {
let pv = DDeiUtil$1.toRulerCoord({ x: this.exPvs[i2].x, y: this.exPvs[i2].y }, this.stage, unit);
json.exPvs[i2].x = pv.x;
json.exPvs[i2].y = pv.y;
}
}
}
return json;
}
};
__publicField2(_DDeiPolygonContainer, "ClsName", "DDeiPolygonContainer");
let DDeiPolygonContainer = _DDeiPolygonContainer;
const __vite_glob_0_6$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiPolygonContainer,
default: DDeiPolygonContainer
}, Symbol.toStringTag, { value: "Module" }));
var DDeiEnumState = /* @__PURE__ */ ((DDeiEnumState2) => {
DDeiEnumState2[DDeiEnumState2["IN_ACTIVITY"] = -1] = "IN_ACTIVITY";
DDeiEnumState2[DDeiEnumState2["NONE"] = 0] = "NONE";
return DDeiEnumState2;
})(DDeiEnumState || {});
const _DDeiStage = class _DDeiStage2 {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "id");
__publicField2(this, "layers");
__publicField2(this, "layerIndex");
__publicField2(this, "idIdx");
__publicField2(this, "modelType", "DDeiStage");
__publicField2(this, "ddInstance", null);
__publicField2(this, "selectedModels", null);
__publicField2(this, "histroy", []);
__publicField2(this, "histroyIdx", -1);
__publicField2(this, "unicode");
__publicField2(this, "ratio", 1.2);
__publicField2(this, "width");
__publicField2(this, "height");
__publicField2(this, "wpv");
__publicField2(this, "links");
__publicField2(this, "mark");
__publicField2(this, "paper");
__publicField2(this, "spv", null);
__publicField2(this, "ruler");
__publicField2(this, "grid");
__publicField2(this, "modelCode", "DDeiStage");
var _a3;
this.id = props.id;
this.layers = [];
this.layerIndex = props.layerIndex != void 0 && props.layerIndex != null && props.layerIndex >= 0 ? props.layerIndex : -1;
this.idIdx = props.idIdx ? props.idIdx : 0;
this.unicode = props.unicode ? props.unicode : DDeiUtil$1.getUniqueCode();
this.histroy = props.histroy ? props.histroy : [];
this.histroyIdx = props.histroyIdx || props.histroyIdx == 0 ? props.histroyIdx : -1;
this.ratio = props.ratio;
this.width = props.width;
this.height = props.height;
this.wpv = props.wpv;
this.mark = props.mark;
this.paper = props.paper;
this.ruler = props.ruler;
this.grid = props.grid;
this.global = props.global;
if (props.spv) {
this.spv = new Vector3(props.spv.x, props.spv.y, 1);
}
this.links = [];
(_a3 = props == null ? void 0 : props.links) == null ? void 0 : _a3.forEach((link2) => {
this.links.push(link2);
});
}
// ============================ 静态变量 ============================
// ============================ 静态方法 ============================
/**
* 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
*/
static loadFromJSON(json, tempData = {}) {
var _a3;
let stage2 = new _DDeiStage2(json);
stage2.ddInstance = tempData["currentDdInstance"];
if (!stage2.ratio) {
stage2.ratio = (_a3 = stage2.ddInstance) == null ? void 0 : _a3.ratio;
}
tempData["currentStage"] = stage2;
tempData[stage2.id] = stage2;
let layers = [];
json.layers.forEach((layer2) => {
let model = DDeiLayer.loadFromJSON(layer2, tempData);
layers.push(model);
});
stage2.layers = layers;
stage2.initHistroy();
stage2.initRender();
if (stage2.links) {
let links = [];
stage2.links.forEach((lk) => {
let sm = null;
let dm = null;
if (lk.sm) {
sm = lk.sm;
} else if (lk.smid) {
sm = stage2.getModelById(lk.smid);
}
if (lk.dm) {
dm = lk.dm;
} else if (lk.dmid) {
dm = stage2.getModelById(lk.dmid);
}
lk.stage = stage2;
lk.sm = sm;
lk.dm = dm;
let link2 = new DDeiLink(lk);
links.push(link2);
});
stage2.links = links;
stage2.refreshLinkCache();
}
let models = stage2.getLayerModels([], 100);
models.forEach((model) => {
if (model.baseModelType == "DDeiLine") {
model.initPVS();
}
model.initLinkModels();
});
return stage2;
}
/**
* 通过JSON初始化对象,数据未传入时将初始化数据
*/
static initByJSON(json, tempData = {}) {
var _a3;
let stage2 = new _DDeiStage2(json);
stage2.ddInstance = tempData["currentDdInstance"];
if (!stage2.ratio) {
stage2.ratio = (_a3 = stage2.ddInstance) == null ? void 0 : _a3.ratio;
}
let dDeiLayer1 = DDeiLayer.initByJSON({ id: "layer_default", name: "L-1" });
dDeiLayer1.index = 0;
dDeiLayer1.stage = stage2;
stage2.layers[0] = dDeiLayer1;
stage2.layerIndex = 0;
stage2.initHistroy();
return stage2;
}
// ============================ 方法 ===============================
/**
* 添加连接点
* @param link 链接点
*/
addLink(...links) {
links == null ? void 0 : links.forEach((link2) => {
if (link2) {
if (this.links.indexOf(link2) == -1) {
this.links.push(link2);
}
}
});
this.refreshLinkCache();
}
/**
* 删除连接点
* @param link 链接点
*/
removeLink(...links) {
links == null ? void 0 : links.forEach((link2) => {
if (link2) {
let index = this.links.indexOf(link2);
if (index != -1) {
this.links.splice(index, 1);
}
}
});
this.refreshLinkCache();
}
/**
* 刷新链接缓存
*/
refreshLinkCache() {
this.sourceLinkCache = /* @__PURE__ */ new Map();
this.distLinkCache = /* @__PURE__ */ new Map();
this.links.forEach((link2) => {
if (link2.sm) {
let smid = link2.sm.id;
if (!this.sourceLinkCache.has(smid)) {
this.sourceLinkCache.set(smid, []);
}
let sourceLinks = this.sourceLinkCache.get(smid);
if (sourceLinks.indexOf(link2) == -1) {
sourceLinks.push(link2);
}
}
if (link2.dm) {
let dmid = link2.dm.id;
if (!this.distLinkCache.has(dmid)) {
this.distLinkCache.set(dmid, []);
}
let distLinks = this.distLinkCache.get(dmid);
if (distLinks.indexOf(link2) == -1) {
distLinks.push(link2);
}
}
});
}
/**
* 获取源模型的链接
* @param modelId 模型ID
*/
getSourceModelLinks(modelId) {
var _a3;
if (modelId) {
return (_a3 = this.sourceLinkCache) == null ? void 0 : _a3.get(modelId);
}
}
getPaperArea(paperType) {
let stageRatio2 = this.getStageRatio();
let offsetWidth = 1 * stageRatio2 / 2;
let paperSize = DDeiUtil$1.getPaperSize(this, paperType, false);
let paperWidth = paperSize.width;
let paperHeight = paperSize.height;
if (!this.spv) {
let sx = this.width / 2 - paperWidth / 2;
let sy = this.height / 2 - paperHeight / 2;
this.spv = new Vector3(sx, sy, 1);
}
let startPaperX = this.spv.x + 1;
let startPaperY = this.spv.y + 1;
let posX = startPaperX + offsetWidth;
let posY = startPaperY + offsetWidth;
this.paperStartX = posX;
this.paperStartY = posY;
let maxOutRect = DDeiAbstractShape.getOutRectByPV(this.getLayerModels([], 100));
let leftExtNum = 0, rightExtNum = 0, topExtNum = 0, bottomExtNum = 0;
if (maxOutRect.width > 0 && maxOutRect.height > 0) {
if (maxOutRect.x < startPaperX) {
leftExtNum = parseInt((startPaperX - maxOutRect.x) / paperWidth);
if (Math.abs((startPaperX - maxOutRect.x) % paperWidth) > 1) {
leftExtNum++;
}
}
if (maxOutRect.x1 > startPaperX + paperWidth) {
rightExtNum = parseInt((maxOutRect.x1 - startPaperX - paperWidth) / paperWidth);
if (Math.abs((maxOutRect.x1 - startPaperX - paperWidth) % paperWidth) > 1) {
rightExtNum++;
}
}
if (maxOutRect.y < startPaperY) {
topExtNum = parseInt((startPaperY - maxOutRect.y) / paperHeight);
if (Math.abs((startPaperY - maxOutRect.y) % paperHeight) > 1) {
topExtNum++;
}
}
if (maxOutRect.y1 > startPaperY + paperHeight) {
bottomExtNum = parseInt((maxOutRect.y1 - startPaperY - paperHeight) / paperHeight);
if (Math.abs((maxOutRect.y1 - startPaperY - paperHeight) % paperHeight) > 1) {
bottomExtNum++;
}
}
}
let paperOutRect = {
x: posX + -leftExtNum * paperWidth,
y: posY + -topExtNum * paperHeight,
w: (rightExtNum + leftExtNum + 1) * paperWidth,
h: (bottomExtNum + topExtNum + 1) * paperHeight,
unitWidth: paperWidth,
unitHeight: paperHeight
};
paperOutRect.x /= stageRatio2;
paperOutRect.y /= stageRatio2;
paperOutRect.w /= stageRatio2;
paperOutRect.h /= stageRatio2;
paperOutRect.unitWidth /= stageRatio2;
paperOutRect.unitHeight /= stageRatio2;
return paperOutRect;
}
/**
* 获取目标模型的链接
* @param modelId 模型ID
*/
getDistModelLinks(modelId) {
var _a3;
if (modelId) {
return (_a3 = this.distLinkCache) == null ? void 0 : _a3.get(modelId);
}
}
/**
* 计算当前stage的模型总数量
*/
calModelNumber() {
let num = 0;
this.layers.forEach((layer2) => {
num += layer2.calModelNumber();
});
return num;
}
/**
* 初始化渲染器
*/
initRender() {
DDeiConfig$1.bindRender(this);
this.render.init();
for (let i2 = 0; i2 < this.layers.length; i2++) {
this.layers[i2].initRender();
}
DDeiLine.calLineCross(this.layers[this.layerIndex]);
this.initStageSize();
}
initStageSize() {
var _a3, _b2, _c2, _d2, _e2;
let stage2 = this;
if (!stage2.width || !stage2.height || !stage2.spv) {
let paperType;
if ((_a3 = stage2.paper) == null ? void 0 : _a3.type) {
paperType = stage2.paper.type;
} else if (stage2.ddInstance.paper) {
if (typeof stage2.ddInstance.paper == "string") {
paperType = stage2.ddInstance.paper;
} else {
paperType = stage2.ddInstance.paper.type;
}
} else {
paperType = DDeiModelArrtibuteValue.getAttrValueByState(stage2, "paper.type", true);
}
let paperSize = DDeiUtil$1.getPaperSize(stage2, paperType, false);
let w = stage2.ddInstance.render.canvas.width / stage2.ddInstance.render.ratio;
let h = stage2.ddInstance.render.canvas.height / stage2.ddInstance.render.ratio;
if (!stage2.width) {
stage2.width = ((_b2 = stage2.ddInstance) == null ? void 0 : _b2.width) ? (_c2 = stage2.ddInstance) == null ? void 0 : _c2.width : (paperSize == null ? void 0 : paperSize.width) ? w > 2 * paperSize.width ? w : 2 * paperSize.width : w;
}
if (!stage2.height) {
stage2.height = ((_d2 = stage2.ddInstance) == null ? void 0 : _d2.height) ? (_e2 = stage2.ddInstance) == null ? void 0 : _e2.height : (paperSize == null ? void 0 : paperSize.height) ? h > 2 * paperSize.height ? h : 2 * paperSize.height : h;
}
let stageRatio2 = stage2.getStageRatio();
if (!stage2.spv) {
let sx = stage2.width / 2 - paperSize.width / 2 - (stageRatio2 - 1) * (paperSize.width / (stageRatio2 * 2));
let sy = stage2.height / 2 - paperSize.height / 2 - (stageRatio2 - 1) * (paperSize.height / (stageRatio2 * 2));
stage2.spv = new Vector3(sx, sy, 1);
}
if (!stage2.wpv) {
stage2.wpv = {
x: stage2.width > w ? -(stage2.width - w) / 2 : 0,
y: stage2.height > h ? -(stage2.height - h) / 2 : 0,
z: 0
};
}
}
}
notifyChange() {
DDeiUtil$1.notifyChange(this.ddInstance);
}
/**
* 添加图层到某一层,如果不指定则添加到最外层
* @param layer 被添加的图层
* @param layerIndex 图层Index
*/
addLayer(layer2, layerIndex, notify = true) {
var _a3;
if (!layer2) {
let curIdx = this.idIdx++;
layer2 = DDeiLayer.initByJSON({ id: "layer_" + curIdx, name: "L-" + curIdx });
} else if (((_a3 = layer2.constructor) == null ? void 0 : _a3.ClsName) == "DDeiLayer")
;
else {
let json = layer2;
if (!(json == null ? void 0 : json.id)) {
let curIdx = this.idIdx++;
json.id = "layer_" + curIdx;
}
if (!(json == null ? void 0 : json.name)) {
json.name = "L-" + this.idIdx;
}
layer2 = DDeiLayer.initByJSON(json);
}
layer2.stage = this;
if (!layerIndex || layerIndex < 0) {
layerIndex = 0;
} else if (layerIndex > this.layers.length - 1) {
layerIndex = this.layers.length - 1;
}
this.layers.splice(layerIndex, 0, layer2);
for (let i2 = 0; i2 < this.layers.length; i2++) {
this.layers[i2].index = i2;
}
this.layerIndex = layerIndex;
if (notify) {
this.notifyChange();
}
return layer2;
}
/**
* 修改当前图层
* @param layerIndex 图层下标
*/
changeLayer(layerIndex) {
this.layerIndex = layerIndex;
}
/**
* 获取画布缩放比率
*/
getStageRatio() {
let stageRatio2 = parseFloat(this.ratio) ? parseFloat(this.ratio) : 1;
if (!stageRatio2 || isNaN(stageRatio2)) {
stageRatio2 = this.ddInstance.ratio;
}
return stageRatio2;
}
/**
* 设置全局缩放比率
*/
setStageRatio(newValue = 1) {
if (newValue != this.ratio) {
if (this.ratio || this.ratio == 0) {
this.oldRatio = this.ratio;
}
this.ratio = newValue;
}
}
/**
* 隐藏图层
* @param layerIndex 图层下标,不传则为当前图层
*/
hiddenLayer(layerIndex) {
if (!layerIndex) {
layerIndex = this.layerIndex;
}
this.layers[layerIndex].display = 0;
}
/**
* 显示图层
* @param layerIndex 图层下标,不传则为当前图层
* @param temp 是否临时显示
*/
displayLayer(layerIndex, temp = false) {
if (!layerIndex || layerIndex < 0 || layerIndex > this.layers[layerIndex].length - 1) {
layerIndex = this.layerIndex;
}
if (temp) {
this.layers.forEach((layer2) => {
layer2.tempDisplay = false;
});
this.layers[layerIndex].tempDisplay = true;
} else {
this.layers[layerIndex].display = 1;
}
}
/**
* 移除图层,如果不指定则移除当前图层
* @param layerIndex 移除图层的index
*/
removeLayer(layerIndex, notify = true) {
if (this.layers.length <= 1) {
return null;
}
if (!layerIndex && layerIndex != 0) {
layerIndex = this.layerIndex;
}
if (layerIndex < 0) {
layerIndex = 0;
} else if (layerIndex > this.layers.length - 1) {
layerIndex = this.layers.length - 1;
}
let layer2 = this.layers[layerIndex];
this.layers.splice(layerIndex, 1);
if (layerIndex > this.layers.length - 1) {
layerIndex = this.layers.length - 1;
}
for (let i2 = 0; i2 < this.layers.length; i2++) {
this.layers[i2].index = i2;
}
this.layerIndex = layerIndex;
if (notify) {
this.notifyChange();
}
return layer2;
}
/**
* 添加模型到当前图层
*/
addModel(model) {
if (this.layerIndex != -1) {
if (this.layers[this.layerIndex]) {
this.layers[this.layerIndex].addModel(model);
}
}
}
destroyed() {
this.layers.forEach((layer2) => {
layer2.destroyed();
});
}
/**
* 移除渲染器
*/
destroyRender() {
this.layers.forEach((layer2) => {
layer2.destroyRender();
});
this.render = null;
}
/**
* 移除当前图层模型
*/
removeModel(model, destroy = false) {
if (this.layerIndex != -1) {
if (this.layers[this.layerIndex]) {
this.layers[this.layerIndex].removeModel(model, destroy);
}
}
}
/**
* 清除当前画布所有控件
*/
clearModels(destroy = false) {
this.layers.forEach((layer2) => {
layer2.clearModels(destroy);
});
}
/**
* 根据ID删除元素
*/
removeModelById(ids) {
this.layers.forEach((layer2) => {
layer2.removeModelById(ids);
});
}
/**
* 选择控件
*/
makeSelectModels(models, cancelSelectOther = true) {
if (cancelSelectOther) {
for (let i2 = 0; i2 < this.layers.length; i2++) {
this.layers[i2].cancelAllLevelSelectModels();
}
}
models == null ? void 0 : models.forEach((model) => {
model.state = DDeiEnumControlState.SELECTED;
});
}
/**
* 全部取消所有已选控件
*/
cancelSelectModels(models, ignoreModels) {
for (let i2 = 0; i2 < this.layers.length; i2++) {
this.layers[i2].cancelSelectModels(models, ignoreModels);
}
}
/**
* 根据ID获取控件
* @param id 控件ID
* @param allLayer 是否查询所有layer,true是,false只查询当前layer
*/
getModelById(id, allLayer = false) {
let reutrnModel = null;
let curLayer = this.layers[this.layerIndex];
if (curLayer) {
reutrnModel = curLayer.getModelById(id);
}
if (!reutrnModel && allLayer) {
for (let i2 = 0; i2 < this.layers.length; i2++) {
if (i2 != this.layerIndex) {
reutrnModel = this.layers[i2].getModelById(id);
if (reutrnModel) {
break;
}
}
}
}
return reutrnModel;
}
/**
* 根据基础模型获取控件
* @param bmt 基础模型类别
*/
getModelsByBaseType(bmt) {
let returnValues = [];
this.layers.forEach((layer2) => {
let datas2 = layer2.getModelsByBaseType(bmt);
datas2.forEach((dt) => {
returnValues.push(dt);
});
});
return returnValues;
}
/**
* 更改选中控件
*/
changeSelecetdModels(selectedModels) {
var _a3;
if (this.selectedModels != selectedModels) {
(_a3 = this.selectedModels) == null ? void 0 : _a3.forEach((item) => {
var _a22, _b2, _c2;
(_b2 = (_a22 = item.getTopContainer()) == null ? void 0 : _a22.render) == null ? void 0 : _b2.enableRefreshShape();
(_c2 = item.render) == null ? void 0 : _c2.enableRefreshShape();
});
selectedModels == null ? void 0 : selectedModels.forEach((item) => {
var _a22, _b2, _c2;
(_b2 = (_a22 = item.getTopContainer()) == null ? void 0 : _a22.render) == null ? void 0 : _b2.enableRefreshShape();
(_c2 = item.render) == null ? void 0 : _c2.enableRefreshShape();
});
this.selectedModels = selectedModels;
}
}
/**
* 获取所有图层的模型
*/
getLayerModels(ignoreModelIds, level = 1, rect) {
let models = [];
for (let i2 = 0; i2 < this.layers.length; i2++) {
let subModels = this.layers[i2].getSubModels(ignoreModelIds, level, rect);
models = models.concat(subModels);
}
return models;
}
/**
* 获取多个图层之间的所有对齐模型
* @param data 判定的数据
* @param souceModels 源模型,可能包含多个
* @param points 判定的点,如果传入,则直接以这个点作为判定点,忽略其他点
* @returns
*/
getAlignData(data, souceModels, points = null) {
let hpoint = {};
let vpoint = {};
let hasH = false;
let hasV = false;
let hAds = Infinity;
let vAds = Infinity;
if (souceModels.set) {
souceModels = Array.from(souceModels.values());
}
let fModel = null;
let sourceModelKeys = [];
for (let k = 0; k < souceModels.length; k++) {
let item = souceModels[k];
let id = item.id;
if (id.lastIndexOf("_shadow") != -1) {
id = id.substring(id, id.lastIndexOf("_shadow"));
}
sourceModelKeys.push(id);
if (!fModel) {
fModel = this.getModelById(id);
}
}
let canvas = this.ddInstance.render.getCanvas();
let rat1 = this.ddInstance.render.ratio;
let x2 = -this.wpv.x;
let y2 = -this.wpv.y;
let x1 = x2 + canvas.width / rat1;
let y1 = y2 + canvas.height / rat1;
let stageRatio2 = this.getStageRatio();
let curLevelModels = fModel.pModel.getSubModels(sourceModelKeys, 1, { x: x2 / stageRatio2, y: y2 / stageRatio2, x1: x1 / stageRatio2, y1: y1 / stageRatio2 });
curLevelModels.forEach((model) => {
let outPVS = (points == null ? void 0 : points.length) > 0 ? points : data.pvs;
let inPVS = model.getAPVS();
outPVS.forEach((pv) => {
inPVS == null ? void 0 : inPVS.forEach((mpv) => {
let pvy = pv.y;
let pvx = pv.x;
let mpvy = mpv.y;
let mpvx = mpv.x;
if (Math.abs(pvy - mpvy) < 1) {
hasH = true;
if (!hpoint[pvy]) {
hpoint[pvy] = { sx: Math.min(pvx, mpvx), ex: Math.max(pvx, mpvx) };
} else {
hpoint[pvy].sx = Math.min(hpoint[pvy].sx, pvx, mpvx);
hpoint[pvy].ex = Math.max(hpoint[pvy].sx, pvx, mpvx);
}
}
if (hAds == Infinity && Math.abs(pvy - mpvy) <= this.ddInstance.GLOBAL_ADV_WEIGHT) {
hAds = pvy - mpvy;
}
if (Math.abs(pvx - mpvx) < 1) {
hasV = true;
if (!vpoint[pvx]) {
vpoint[pvx] = { sy: Math.min(pvy, mpvy), ey: Math.max(pvy, mpvy) };
} else {
vpoint[pvx].sy = Math.min(vpoint[pvx].sy, pvy, mpvy);
vpoint[pvx].ey = Math.max(vpoint[pvx].sy, pvy, mpvy);
}
}
if (vAds == Infinity && Math.abs(pvx - mpvx) <= this.ddInstance.GLOBAL_ADV_WEIGHT) {
vAds = pvx - mpvx;
}
});
});
});
return { hpoint: hasH ? hpoint : null, vpoint: hasV ? vpoint : null, hAds, vAds };
}
/**
* 将模型转换为JSON
*/
toJSON() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i;
let json = new Object();
let skipFields = (_a3 = DDeiConfig$1.SERI_FIELDS[this.modelType]) == null ? void 0 : _a3.SKIP;
if (!((skipFields == null ? void 0 : skipFields.length) > 0)) {
skipFields = (_b2 = DDeiConfig$1.SERI_FIELDS[this.baseModelType]) == null ? void 0 : _b2.SKIP;
}
if (!((skipFields == null ? void 0 : skipFields.length) > 0)) {
skipFields = (_c2 = DDeiConfig$1.SERI_FIELDS["AbstractShape"]) == null ? void 0 : _c2.SKIP;
}
let toJSONFields = (_d2 = DDeiConfig$1.SERI_FIELDS[this.modelType]) == null ? void 0 : _d2.TOJSON;
if (!((toJSONFields == null ? void 0 : toJSONFields.length) > 0)) {
toJSONFields = (_e2 = DDeiConfig$1.SERI_FIELDS[this.baseModelType]) == null ? void 0 : _e2.TOJSON;
}
if (!((toJSONFields == null ? void 0 : toJSONFields.length) > 0)) {
toJSONFields = (_f = DDeiConfig$1.SERI_FIELDS["AbstractShape"]) == null ? void 0 : _f.TOJSON;
}
for (let i2 in this) {
if (!skipFields || (skipFields == null ? void 0 : skipFields.indexOf(i2)) == -1) {
if (toJSONFields && toJSONFields.indexOf(i2) != -1 && this[i2]) {
if (Array.isArray(this[i2])) {
let array = [];
this[i2].forEach((element) => {
if (Array.isArray(element)) {
let subArray = [];
element.forEach((subEle) => {
if (subEle == null ? void 0 : subEle.toJSON) {
subArray.push(subEle.toJSON());
} else {
subArray.push(subEle);
}
});
array.push(subArray);
} else if (element == null ? void 0 : element.toJSON) {
array.push(element.toJSON());
} else {
array.push(element);
}
});
json[i2] = array;
} else if (this[i2].set && this[i2].has) {
let map = {};
this[i2].forEach((element, key) => {
if (element == null ? void 0 : element.toJSON) {
map[key] = element.toJSON();
} else {
map[key] = element;
}
});
json[i2] = map;
} else if (this[i2].toJSON) {
json[i2] = this[i2].toJSON();
} else {
json[i2] = this[i2];
}
} else {
json[i2] = this[i2];
}
}
}
let ruleDisplay;
let ruleInit;
if (((_g = this.ruler) == null ? void 0 : _g.display) || ((_h = this.ruler) == null ? void 0 : _h.display) == 0 || ((_i = this.ruler) == null ? void 0 : _i.display) == false) {
ruleDisplay = this.ruler.display;
} else if (this.ddInstance.ruler != null && this.ddInstance.ruler != void 0) {
if (typeof this.ddInstance.ruler == "boolean") {
ruleDisplay = this.ddInstance.ruler ? 1 : 0;
} else {
ruleInit = this.ddInstance.ruler;
ruleDisplay = ruleInit.display;
}
} else {
ruleDisplay = DDeiModelArrtibuteValue.getAttrValueByState(this, "ruler.display", true);
}
if (ruleDisplay) {
json.unit = DDeiModelArrtibuteValue.getAttrValueByState(this, "ruler.unit", true, ruleInit);
}
return json;
}
/**
* 初始化日志,记录初始化状态
*/
initHistroy() {
if (this.histroy.length == 0 && this.histroyIdx == -1) {
this.histroy.push({ time: (/* @__PURE__ */ new Date()).getTime(), data: JSON.stringify(this.toJSON()) });
this.histroyIdx = 0;
}
}
/**
* 记录日志
* @param layerIndex 图层下标
*/
addHistroy(data) {
if (this.histroyIdx == -1) {
this.histroy = this.histroy.slice(0, 1);
this.histroyIdx = 0;
} else {
this.histroy = this.histroy.slice(0, this.histroyIdx + 1);
}
this.histroy.push({ time: (/* @__PURE__ */ new Date()).getTime(), data });
this.histroyIdx = this.histroy.length - 1;
}
/**
* 返回上一个历史数据,并将下标-1
* @param layerIndex 图层下标
*/
revokeHistroyData() {
if (this.histroyIdx != -1) {
this.histroyIdx--;
if (this.histroyIdx == -1) {
this.histroyIdx = 0;
return this.histroy[0];
} else {
return this.histroy[this.histroyIdx];
}
}
}
/**
* 撤销上一次撤销并将下标+1
* @param layerIndex 图层下标
*/
reRevokeHistroyData() {
if (this.histroyIdx < this.histroy.length - 1) {
this.histroyIdx++;
return this.histroy[this.histroyIdx];
}
}
/**
* 根据属性搜索控件
* @param keywords 关键字/正则表达式
* @param attr 搜索的属性
* @param isReg 是否正则表达式
* @param matchCase 区分大小写
* @param matchAll 全字匹配
*/
searchModels(keywords, attr, isReg = false, matchCase = false, matchAll = false) {
let resultArray = new Array();
if (keywords && attr) {
let models = this.getLayerModels([], 100);
if (isReg)
;
else {
for (let i2 = 0; i2 < models.length; i2++) {
let model = models[i2];
let data = model[attr];
if (data && typeof data == "string") {
if (!matchCase) {
data = data.toLowerCase();
keywords = keywords.toLowerCase();
}
if (!matchAll) {
let searchIndex = 0;
while (true) {
let ix = data.indexOf(keywords, searchIndex);
if (ix != -1) {
resultArray.push({ model, attr, index: ix, len: keywords.length });
searchIndex = ix + 1;
} else {
break;
}
}
} else {
if (data == keywords) {
resultArray.push({ model, attr, index: 0, len: keywords.length });
}
}
}
}
}
}
return resultArray;
}
/**
* 返回画布图片
* @models 选中控件模型,如果不传入则返回整个画布
*/
toImageDataUrl(models = null) {
let ddInstance = this.ddInstance;
if (ddInstance == null ? void 0 : ddInstance.render) {
let canvas = document.createElement("canvas");
let ctx = canvas.getContext("2d");
let rat1 = ddInstance.render.ratio;
let allLayers = false;
if (!models || models.length < 0) {
models = this.getLayerModels(null, 100);
allLayers = true;
}
let outRect = DDeiAbstractShape.getOutRectByPV(models);
let stageRatio2 = this.getStageRatio();
outRect.x *= stageRatio2;
outRect.y *= stageRatio2;
outRect.width *= stageRatio2;
outRect.height *= stageRatio2;
let lineOffset = 5 * stageRatio2;
let addWidth = 2 * lineOffset;
let editorId = DDeiUtil$1.getEditorId(ddInstance);
let containerDiv = document.getElementById(editorId + "_ddei_cut_img_div");
canvas.setAttribute("style", "-webkit-font-smoothing:antialiased;-moz-transform-origin:left top;-moz-transform:scale(" + 1 / rat1 + ");display:block;zoom:" + 1 / rat1);
let cW = (outRect.width + addWidth) * rat1;
let cH = (outRect.height + addWidth) * rat1;
canvas.setAttribute("width", cW);
canvas.setAttribute("height", cH);
ctx.translate((-outRect.x + lineOffset - 5 * stageRatio2) * rat1, (-outRect.y + lineOffset - 5 * stageRatio2) * rat1);
containerDiv.appendChild(canvas);
if (allLayers) {
let layers = this.layers;
layers.forEach((ly) => {
ly.midList.forEach((mid) => {
var _a3, _b2;
let model = ly.models.get(mid);
(_a3 = model == null ? void 0 : model.render) == null ? void 0 : _a3.clearCachedValue();
(_b2 = model == null ? void 0 : model.render) == null ? void 0 : _b2.drawShape();
if (model.baseModelType == "DDeiLine") {
let lineRect = DDeiAbstractShape.getOutRectByPV([model]);
ctx.drawImage(model.render.tempCanvas, (lineRect.x - 5) * stageRatio2 * rat1, (lineRect.y - 5) * stageRatio2 * rat1);
} else if (!model.render.viewer) {
ctx.drawImage(model.render.tempCanvas, model.x * stageRatio2 * rat1, model.y * stageRatio2 * rat1);
}
});
});
} else {
models[0].pModel.midList.forEach((mid) => {
models.forEach((item) => {
if (item.id == mid) {
let rendList = DDeiUtil$1.sortRendList(item);
rendList.forEach((rendItem) => {
rendItem.render.clearCachedValue();
rendItem.render.drawShape({});
if (rendItem.baseModelType == "DDeiLine") {
let lineRect = DDeiAbstractShape.getOutRectByPV([rendItem]);
ctx.drawImage(rendItem.render.tempCanvas, (lineRect.x - 5) * stageRatio2 * rat1, (lineRect.y - 5) * stageRatio2 * rat1);
} else if (!rendItem.render.viewer) {
ctx.drawImage(rendItem.render.tempCanvas, rendItem.x * stageRatio2 * rat1, rendItem.y * stageRatio2 * rat1);
}
this.drawComposeImageToCanvas(rendItem, ctx, stageRatio2, rat1);
});
}
});
});
}
let dataURL = canvas.toDataURL();
containerDiv.removeChild(canvas);
return dataURL;
}
return null;
}
drawComposeImageToCanvas(model, ctx, stageRatio2, rat1) {
var _a3;
(_a3 = model.composes) == null ? void 0 : _a3.forEach((comp) => {
comp.render.clearCachedValue();
comp.render.drawShape();
if (comp.baseModelType == "DDeiLine") {
let lineRect = DDeiAbstractShape.getOutRectByPV([comp]);
ctx.drawImage(comp.render.tempCanvas, (lineRect.x - 5) * stageRatio2 * rat1, (lineRect.y - 5) * stageRatio2 * rat1);
} else if (!comp.render.viewer) {
ctx.drawImage(comp.render.tempCanvas, comp.x * stageRatio2 * rat1, comp.y * stageRatio2 * rat1);
}
this.drawComposeImageToCanvas(comp, ctx, stageRatio2, rat1);
});
}
};
__publicField2(_DDeiStage, "ClsName", "DDeiStage");
let DDeiStage = _DDeiStage;
const __vite_glob_0_11$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiStage,
default: DDeiStage
}, Symbol.toStringTag, { value: "Module" }));
class DDeiFuncCallResult {
constructor() {
__publicField2(this, "state", 0);
}
}
const _DDei = class _DDei2 {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "id");
__publicField2(this, "containerid");
__publicField2(this, "stage");
__publicField2(this, "modelType", "DDei");
__publicField2(this, "disabled", false);
__publicField2(this, "pixel", 2);
__publicField2(this, "controlModelClasses");
__publicField2(this, "controlViewClasses");
__publicField2(this, "state", DDeiEnumState.NONE);
__publicField2(this, "bus", null);
__publicField2(this, "editMode", 1);
__publicField2(this, "width", 0);
__publicField2(this, "height", 0);
__publicField2(this, "ratio", 1);
__publicField2(this, "mark", null);
__publicField2(this, "ruler", null);
__publicField2(this, "grid", null);
__publicField2(this, "paper", null);
__publicField2(this, "background", null);
__publicField2(this, "EXT_STAGE_WIDTH", true);
__publicField2(this, "EXT_STAGE_HEIGHT", true);
__publicField2(this, "GLOBAL_ALLOW_STAGE_RATIO", true);
__publicField2(this, "GLOBAL_ADV_WEIGHT", 5);
__publicField2(this, "GLOBAL_HELP_LINE_ENABLE", true);
__publicField2(this, "EVENT_LOAD_FILE", null);
__publicField2(this, "EVENT_SAVE_FILE", null);
__publicField2(this, "EVENT_CONTROL_SELECT_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_SELECT_AFTER", null);
__publicField2(this, "EVENT_CONTROL_CREATE_BEFORE", null);
__publicField2(this, "EVENT_MOUSE_OPERATING", null);
__publicField2(this, "EVENT_CONTROL_CREATE_AFTER", null);
__publicField2(this, "EVENT_CONTROL_DRAG_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_DRAG_AFTER", null);
__publicField2(this, "EVENT_LINE_DRAG_BEFORE", null);
__publicField2(this, "EVENT_LINE_DRAG_AFTER", null);
__publicField2(this, "EVENT_CONTROL_DEL_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_DEL_AFTER", null);
__publicField2(this, "EVENT_CONTROL_EDIT_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_EDIT_AFTER", null);
__publicField2(this, "EVENT_CONTROL_VIEW_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_VIEW_AFTER", null);
__publicField2(this, "EVENT_STAGE_CHANGE_WPV", null);
__publicField2(this, "EVENT_STAGE_CHANGE_RATIO", null);
__publicField2(this, "dpi", null);
this.id = props.id;
this.containerid = props.containerid;
this.stage = null;
this.EVENT_CONTROL_SELECT_BEFORE = _DDei2.beforeOperateValid;
this.EVENT_CONTROL_CREATE_BEFORE = _DDei2.beforeOperateValid;
this.EVENT_CONTROL_DRAG_BEFORE = _DDei2.beforeOperateValid;
this.EVENT_CONTROL_DEL_BEFORE = _DDei2.beforeOperateValid;
this.EVENT_CONTROL_EDIT_BEFORE = _DDei2.beforeOperateValid;
this.EVENT_CONTROL_VIEW_BEFORE = _DDei2.beforeOperateValid;
}
// ============================ 静态方法 ============================
/**
* 选中前,一般用于校验,默认根据权限配置参数进行校验
*/
static beforeOperateValid(operate, data, ddInstance, evt) {
let modeName = DDeiUtil$1.getConfigValue("MODE_NAME", ddInstance);
let rs = new DDeiFuncCallResult();
rs.state = 1;
let models = data == null ? void 0 : data.models;
let propName = data == null ? void 0 : data.propName;
for (let i2 = 0; i2 < (models == null ? void 0 : models.length); i2++) {
let access = DDeiUtil$1.isAccess(
operate,
models[i2],
propName,
modeName,
ddInstance
);
if (!access) {
rs.state = -2;
return rs;
}
}
return rs;
}
/**
* 给予container构建一个DDei实例
* 每一个DDei至少包含1个文件
* @param {id} id 文件id
* @param {containerid} containerid 容器id
* @param {stagejson} stagejson 内容JSON,如果没有则会创建一个
*/
static newInstance(id, containerid, stagejson, editor) {
if (id && containerid) {
if (!_DDei2.INSTANCE_POOL.get(id)) {
let ddInstance = new _DDei2({ id, containerid });
if (editor) {
editor.ddInstance = ddInstance;
}
if (stagejson) {
ddInstance.stage = DDeiStage.loadFromJSON(stagejson, { currentDdInstance: ddInstance });
} else {
ddInstance.stage = DDeiStage.initByJSON({ id: "stage_1" }, { currentDdInstance: ddInstance });
}
ddInstance.stage.ddInstance = ddInstance;
_DDei2.INSTANCE_POOL.set(id, ddInstance);
ddInstance.bus = new DDeiBus$1({ ddInstance });
ddInstance.dpi = DDeiUtil$1.getDPI();
return ddInstance;
} else {
let ddInstance = _DDei2.INSTANCE_POOL.get(id);
return ddInstance;
}
}
}
//以上字段为初始化时传入的全局控制变量或钩子函数,在运行时不会改变
// ============================ 方法 ============================
/**
* 初始化渲染器
*/
initRender() {
if (this.render) {
this.render.destroyed();
}
DDeiConfig$1.bindRender(this);
this.render.init();
this.stage.initRender();
}
/**
* 修改当前编辑模式
* @param mode 编辑模式
*/
changeEditMode(mode) {
if (this.editMode != mode) {
this.editMode = mode;
}
}
/**
* 应用外部配置文件,覆写配置文件内容
* @param config
*/
applyConfig(config2) {
if (config2) {
for (let i2 in config2) {
if (i2 != "SERI_FIELDS") {
this[i2] = config2[i2];
}
}
}
}
/**
* 将模型转换为JSON
*/
toJSON() {
var _a3, _b2, _c2, _d2, _e2, _f;
let json = new Object();
let skipFields = (_a3 = DDeiConfig$1.SERI_FIELDS[this.modelType]) == null ? void 0 : _a3.SKIP;
if (!((skipFields == null ? void 0 : skipFields.length) > 0)) {
skipFields = (_b2 = DDeiConfig$1.SERI_FIELDS[this.baseModelType]) == null ? void 0 : _b2.SKIP;
}
if (!((skipFields == null ? void 0 : skipFields.length) > 0)) {
skipFields = (_c2 = DDeiConfig$1.SERI_FIELDS["AbstractShape"]) == null ? void 0 : _c2.SKIP;
}
let toJSONFields = (_d2 = DDeiConfig$1.SERI_FIELDS[this.modelType]) == null ? void 0 : _d2.TOJSON;
if (!((toJSONFields == null ? void 0 : toJSONFields.length) > 0)) {
toJSONFields = (_e2 = DDeiConfig$1.SERI_FIELDS[this.baseModelType]) == null ? void 0 : _e2.TOJSON;
}
if (!((toJSONFields == null ? void 0 : toJSONFields.length) > 0)) {
toJSONFields = (_f = DDeiConfig$1.SERI_FIELDS["AbstractShape"]) == null ? void 0 : _f.TOJSON;
}
for (let i2 in this) {
if (!skipFields || (skipFields == null ? void 0 : skipFields.indexOf(i2)) == -1) {
if (toJSONFields && toJSONFields.indexOf(i2) != -1 && this[i2]) {
if (Array.isArray(this[i2])) {
let array = [];
this[i2].forEach((element) => {
if (element == null ? void 0 : element.toJSON) {
array.push(element.toJSON());
} else {
array.push(element);
}
});
json[i2] = array;
} else if (this[i2].set && this[i2].has) {
let map = {};
this[i2].forEach((element, key) => {
if (element == null ? void 0 : element.toJSON) {
map[key] = element.toJSON();
} else {
map[key] = element;
}
});
json[i2] = map;
} else if (this[i2].toJSON) {
json[i2] = this[i2].toJSON();
} else {
json[i2] = this[i2];
}
} else {
json[i2] = this[i2];
}
}
}
return json;
}
};
__publicField2(_DDei, "INSTANCE_POOL", /* @__PURE__ */ new Map());
__publicField2(_DDei, "KEY_DOWN_STATE", /* @__PURE__ */ new Map());
let DDei = _DDei;
var DDeiEnumOperateState = /* @__PURE__ */ ((DDeiEnumOperateState2) => {
DDeiEnumOperateState2[DDeiEnumOperateState2["NONE"] = 0] = "NONE";
DDeiEnumOperateState2[DDeiEnumOperateState2["CONTROL_CONFIRMING"] = 1] = "CONTROL_CONFIRMING";
DDeiEnumOperateState2[DDeiEnumOperateState2["CONTROL_CREATING"] = 2] = "CONTROL_CREATING";
DDeiEnumOperateState2[DDeiEnumOperateState2["CONTROL_DRAGING"] = 3] = "CONTROL_DRAGING";
DDeiEnumOperateState2[DDeiEnumOperateState2["CONTROL_CHANGING_BOUND"] = 4] = "CONTROL_CHANGING_BOUND";
DDeiEnumOperateState2[DDeiEnumOperateState2["CONTROL_ROTATE"] = 5] = "CONTROL_ROTATE";
DDeiEnumOperateState2[DDeiEnumOperateState2["SELECT_WORKING"] = 10] = "SELECT_WORKING";
DDeiEnumOperateState2[DDeiEnumOperateState2["TABLE_INNER_DRAG"] = 11] = "TABLE_INNER_DRAG";
DDeiEnumOperateState2[DDeiEnumOperateState2["GRAB_WORKING"] = 20] = "GRAB_WORKING";
DDeiEnumOperateState2[DDeiEnumOperateState2["STAGE_SCROLL_WORKING"] = 21] = "STAGE_SCROLL_WORKING";
DDeiEnumOperateState2[DDeiEnumOperateState2["TEXT_CREATING"] = 30] = "TEXT_CREATING";
DDeiEnumOperateState2[DDeiEnumOperateState2["LINE_POINT_CHANGING"] = 40] = "LINE_POINT_CHANGING";
DDeiEnumOperateState2[DDeiEnumOperateState2["LINE_POINT_CHANGING_CONFIRM"] = 41] = "LINE_POINT_CHANGING_CONFIRM";
DDeiEnumOperateState2[DDeiEnumOperateState2["QUICK_EDITING"] = 50] = "QUICK_EDITING";
DDeiEnumOperateState2[DDeiEnumOperateState2["QUICK_EDITING_TEXT_SELECTING"] = 51] = "QUICK_EDITING_TEXT_SELECTING";
DDeiEnumOperateState2[DDeiEnumOperateState2["OV_POINT_CHANGING"] = 60] = "OV_POINT_CHANGING";
return DDeiEnumOperateState2;
})(DDeiEnumOperateState || {});
const _DDeiSelector = class _DDeiSelector2 extends DDeiRectangle {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "modelType", "DDeiSelector");
__publicField2(this, "baseModelType", "DDeiSelector");
__publicField2(this, "paddingWeight");
__publicField2(this, "operateIconFill");
__publicField2(this, "passIndex", -1);
__publicField2(this, "opvsIndex", -1);
__publicField2(this, "passType", "");
__publicField2(this, "passChange", false);
this.paddingWeight = props.paddingWeight;
this.operateIconFill = props.operateIconFill;
}
// ============================ 静态变量 ============================
// ============================ 静态方法 ============================
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json) {
let shape = new _DDeiSelector2(json);
return shape;
}
// ============================ 方法 ===============================
/**
* 设置passindex
* @param index pass值
*/
setPassIndex(passType, passIndex, opvsIndex) {
if (this.passType != passType || this.passIndex != passIndex || this.opvsIndex != opvsIndex) {
this.passIndex = passIndex;
this.passType = passType;
this.opvsIndex = opvsIndex;
this.passChange = true;
}
}
/**
* 重制状态
*/
resetState(x2 = -1, y2 = -1) {
this.startX = x2;
this.startY = y2;
this.updatePVSByRect(0, 0, 0, 0);
this.setState(DDeiEnumControlState.DEFAULT);
}
/**
* 获取当前选择器包含的模型
* @returns
*/
getIncludedModels() {
let rectPVS = this.pvs;
let selectBounds = DDeiAbstractShape.pvsToOutRect(rectPVS);
let looseWeight = 2;
selectBounds.x -= looseWeight;
selectBounds.y -= looseWeight;
selectBounds.x1 += 2 * looseWeight;
selectBounds.y1 += 2 * looseWeight;
let models = /* @__PURE__ */ new Map();
this.stage.layers[this.stage.layerIndex].models.forEach((item, key) => {
if (item.id != this.id) {
let pvs2 = item.pvs;
let inRectNum = 0;
pvs2.forEach((pv) => {
if (selectBounds.x <= pv.x && selectBounds.y < pv.y && selectBounds.x1 >= pv.x && selectBounds.y1 >= pv.y) {
inRectNum++;
}
});
if (pvs2.length > 3 && inRectNum >= pvs2.length - 1) {
models.set(item.id, item);
} else if (inRectNum == pvs2.length) {
models.set(item.id, item);
}
}
});
return models;
}
/**
* 获取画布缩放比率
*/
getStageRatio() {
var _a3;
return (_a3 = this.stage) == null ? void 0 : _a3.getStageRatio();
}
updatePVSByRect(x2, y2, w, h) {
let pvs2 = [];
pvs2.push(new Vector3(x2, y2, 1));
pvs2.push(new Vector3(x2 + w, y2, 1));
pvs2.push(new Vector3(x2 + w, y2 + h, 1));
pvs2.push(new Vector3(x2, y2 + h, 1));
this.cpv = this.cpv = new Vector3(x2 + w / 2, y2 + h / 2, 1);
this.pvs = pvs2;
this.initHPV();
this.calRotate();
this.calOPVS();
this.calLoosePVS();
}
/**
* 根据已选择的控件更新向量信息
* @param pContainerModel 上层容器控件
*/
updatePVSByModels(models) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j;
if (!models) {
models = (_a3 = this.stage) == null ? void 0 : _a3.selectedModels;
}
if (!models) {
let pContainerModel = this.stage.layers[this.stage.layerIndex];
models = pContainerModel.getSelectedModels();
}
if ((models == null ? void 0 : models.size) > 0 || (models == null ? void 0 : models.length) > 0) {
if (models.set) {
models = Array.from(models.values());
}
let paddingWeightInfo = ((_b2 = this.paddingWeight) == null ? void 0 : _b2.selected) ? this.paddingWeight.selected : DDeiConfig$1.SELECTOR.PADDING_WEIGHT.selected;
let paddingWeight = 0;
if (models.length > 1) {
paddingWeight = paddingWeightInfo.multiple;
} else {
paddingWeight = paddingWeightInfo.single;
}
let pvs2 = null;
let exeCalLoosePVS = true;
if (models.length == 1) {
if (models[0].baseModelType == "DDeiLine") {
exeCalLoosePVS = false;
pvs2 = cloneDeep(models[0].pvs);
this.cpv = cloneDeep(models[0].cpv);
}
pvs2 = DDeiUtil$1.pointsToZero(models[0].operatePVS, models[0].cpv, models[0].rotate);
let oct = DDeiAbstractShape.pvsToOutRect(pvs2);
pvs2 = [new Vector3(oct.x, oct.y, 1), new Vector3(oct.x1, oct.y, 1), new Vector3(oct.x1, oct.y1, 1), new Vector3(oct.x, oct.y1, 1)];
pvs2 = DDeiUtil$1.zeroToPoints(pvs2, models[0].cpv, models[0].rotate);
this.cpv = clone(models[0].cpv);
let defineSample2 = (_d2 = (_c2 = DDeiUtil$1.getControlDefine(models[0])) == null ? void 0 : _c2.define) == null ? void 0 : _d2.sample;
this.eqrat = ((_f = (_e2 = models[0]) == null ? void 0 : _e2.sample) == null ? void 0 : _f.eqrat) || (defineSample2 == null ? void 0 : defineSample2.eqrat);
} else {
this.eqrat = false;
for (let i2 = 0; i2 < models.length; i2++) {
let defineSample2 = (_h = (_g = DDeiUtil$1.getControlDefine(models[i2])) == null ? void 0 : _g.define) == null ? void 0 : _h.sample;
if (((_j = (_i = models[i2]) == null ? void 0 : _i.sample) == null ? void 0 : _j.eqrat) || (defineSample2 == null ? void 0 : defineSample2.eqrat)) {
this.eqrat = true;
break;
}
}
let outRectBounds = DDeiAbstractShape.getOutRectByPV(models);
pvs2 = DDeiAbstractShape.getOutPV(models);
pvs2[0].x -= paddingWeight;
pvs2[0].y -= paddingWeight;
pvs2[1].x += paddingWeight;
pvs2[1].y -= paddingWeight;
pvs2[2].x += paddingWeight;
pvs2[2].y += paddingWeight;
pvs2[3].x -= paddingWeight;
pvs2[3].y += paddingWeight;
this.cpv = new Vector3(outRectBounds.x + outRectBounds.width / 2, outRectBounds.y + outRectBounds.height / 2, 1);
}
this.pvs = pvs2;
this.initHPV();
this.calRotate();
this.calOPVS();
if (exeCalLoosePVS) {
this.calLoosePVS();
}
this.setState(DDeiEnumControlState.SELECTED);
} else {
this.resetState();
}
}
/**
* 变换向量
*/
transVectors(matrix2, params) {
this.cpv.applyMatrix3(matrix2);
this.pvs.forEach((pv) => {
pv.applyMatrix3(matrix2);
});
for (let i2 in this.exPvs) {
let pv = this.exPvs[i2];
pv.applyMatrix3(matrix2);
}
this.initHPV();
this.calRotate();
this.calOPVS();
this.calLoosePVS();
}
/**
* 基于当前向量计算宽松判定向量
*/
calLoosePVS() {
var _a3, _b2, _c2, _d2, _e2;
let stageRatio2 = (_a3 = this.stage) == null ? void 0 : _a3.getStageRatio();
let looseWeight = DDeiConfig$1.SELECTOR.OPERATE_ICON.weight / 2;
let tempPVS = cloneDeep(this.pvs);
let move1Matrix = new Matrix3(
1,
0,
-this.cpv.x,
0,
1,
-this.cpv.y,
0,
0,
1
);
tempPVS.forEach((fpv) => {
fpv.applyMatrix3(move1Matrix);
});
if (this.rotate && this.rotate != 0) {
let angle2 = DDeiUtil$1.preciseTimes(this.rotate, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
tempPVS.forEach((fpv) => {
fpv.applyMatrix3(rotateMatrix);
});
}
this.x = tempPVS[0].x / stageRatio2;
this.y = tempPVS[0].y / stageRatio2;
let models = null;
if (((_c2 = (_b2 = this.stage) == null ? void 0 : _b2.selectedModels) == null ? void 0 : _c2.size) > 0) {
models = Array.from(this.stage.selectedModels.values());
}
if (this.stage.render.operateState == DDeiEnumOperateState.SELECT_WORKING || !((models == null ? void 0 : models.length) == 1 && ((_d2 = models[0]) == null ? void 0 : _d2.baseModelType) == "DDeiLine" || tempPVS.length == 2)) {
this.width = (tempPVS[1].x - tempPVS[0].x) / stageRatio2;
this.height = (tempPVS[3].y - tempPVS[0].y) / stageRatio2;
this.essBounds = { x: tempPVS[0].x, y: tempPVS[0].y, width: tempPVS[1].x - tempPVS[0].x, height: tempPVS[3].y - tempPVS[0].y };
this.loosePVS = [];
this.loosePVS[0] = new Vector3(tempPVS[0].x - looseWeight, tempPVS[0].y - looseWeight, 1);
this.loosePVS[1] = new Vector3(tempPVS[0].x + (tempPVS[1].x - tempPVS[0].x) / 2 - looseWeight, tempPVS[0].y - looseWeight, 1);
this.loosePVS[2] = new Vector3(this.loosePVS[1].x, this.loosePVS[1].y - 40, 1);
this.loosePVS[3] = new Vector3(this.loosePVS[2].x + 2 * looseWeight, this.loosePVS[2].y, 1);
this.loosePVS[4] = new Vector3(this.loosePVS[3].x, this.loosePVS[3].y - 40, 1);
this.loosePVS[5] = new Vector3(tempPVS[1].x + looseWeight, tempPVS[1].y - looseWeight, 1);
this.loosePVS[6] = new Vector3(this.loosePVS[5].x, tempPVS[2].y + looseWeight, 1);
this.loosePVS[7] = new Vector3(tempPVS[3].x - looseWeight, this.loosePVS[6].y, 1);
} else if ((models == null ? void 0 : models.length) == 1 && ((_e2 = models[0]) == null ? void 0 : _e2.baseModelType) == "DDeiLine" || tempPVS.length == 2) {
this.width = (tempPVS[1].x - tempPVS[0].x) / stageRatio2;
this.height = (tempPVS[1].y - tempPVS[0].y) / stageRatio2;
this.essBounds = { x: tempPVS[0].x, y: tempPVS[0].y, width: tempPVS[1].x - tempPVS[0].x, height: tempPVS[1].y - tempPVS[0].y };
this.loosePVS = [];
this.loosePVS[0] = new Vector3(tempPVS[0].x - looseWeight, tempPVS[0].y - looseWeight, 1);
this.loosePVS[1] = new Vector3(tempPVS[1].x + looseWeight, tempPVS[0].y - looseWeight, 1);
this.loosePVS[2] = new Vector3(tempPVS[1].x + looseWeight, tempPVS[1].y + looseWeight, 1);
this.loosePVS[3] = new Vector3(tempPVS[0].x - looseWeight, tempPVS[1].y + looseWeight, 1);
}
if (this.rotate && this.rotate != 0) {
let angle2 = -DDeiUtil$1.preciseTimes(this.rotate, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
this.loosePVS.forEach((fpv) => {
fpv.applyMatrix3(rotateMatrix);
});
}
let move2Matrix = new Matrix3(
1,
0,
this.cpv.x,
0,
1,
this.cpv.y,
0,
0,
1
);
this.loosePVS.forEach((fpv) => {
fpv.applyMatrix3(move2Matrix);
});
this.x += this.cpv.x / stageRatio2;
this.y += this.cpv.y / stageRatio2;
this.essBounds.x += this.cpv.x;
this.essBounds.y += this.cpv.y;
}
/**
* 根据向量点计算操作图标的向量点
*/
calOPVS() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i;
let models = null;
if (((_b2 = (_a3 = this.stage) == null ? void 0 : _a3.selectedModels) == null ? void 0 : _b2.size) > 0) {
models = Array.from(this.stage.selectedModels.values());
}
if ((models == null ? void 0 : models.length) == 1 && ((_c2 = models[0]) == null ? void 0 : _c2.baseModelType) == "DDeiLine") {
let lineModel = models[0];
let type = DDeiModelArrtibuteValue.getAttrValueByState(lineModel, "type", true);
let { startDX, startDY, endDX, endDY } = lineModel.render.getPointShapeSize();
let opvs = [];
let opvsType = [];
let pvs2 = lineModel.pvs;
opvs.push(pvs2[0]);
opvsType.push(1);
switch (type) {
case 2: {
for (let i2 = 1; i2 < pvs2.length; i2++) {
let x2 = (pvs2[i2].x + pvs2[i2 - 1].x) / 2;
let y2 = (pvs2[i2].y + pvs2[i2 - 1].y) / 2;
opvs.push(new Vector3(x2, y2, 1));
opvsType.push(3);
if (i2 != pvs2.length - 1) {
opvs.push(pvs2[i2]);
opvsType.push(2);
}
}
break;
}
case 3: {
if (pvs2.length >= 4) {
for (let i2 = 4; i2 <= pvs2.length; i2 += 3) {
let i0 = i2 - 4;
let i1 = i2 - 3;
let i22 = i2 - 2;
let i3 = i2 - 1;
if (i0 != 0) {
opvs.push(new Vector3(pvs2[i0].x, pvs2[i0].y, 1));
opvsType.push(4);
}
let stratX = pvs2[i0].x;
let stratY = pvs2[i0].y;
let endX = pvs2[i3].x;
let endY = pvs2[i3].y;
if (i0 == 0) {
stratX = pvs2[i0].x + startDX;
stratY = pvs2[i0].y + startDY;
}
if (i2 == pvs2.length) {
endX = pvs2[i3].x + endDX;
endY = pvs2[i3].y + endDY;
}
let btx = stratX * DDeiUtil$1.p331t3 + DDeiUtil$1.p331t2t3 * pvs2[i1].x + DDeiUtil$1.p33t21t3 * pvs2[i22].x + DDeiUtil$1.p33t3 * endX;
let bty = stratY * DDeiUtil$1.p331t3 + DDeiUtil$1.p331t2t3 * pvs2[i1].y + DDeiUtil$1.p33t21t3 * pvs2[i22].y + DDeiUtil$1.p33t3 * endY;
opvs.push(new Vector3(btx, bty, 1));
opvsType.push(4);
btx = stratX * DDeiUtil$1.p661t3 + DDeiUtil$1.p661t2t3 * pvs2[i1].x + DDeiUtil$1.p66t21t3 * pvs2[i22].x + DDeiUtil$1.p66t3 * endX;
bty = stratY * DDeiUtil$1.p661t3 + DDeiUtil$1.p661t2t3 * pvs2[i1].y + DDeiUtil$1.p66t21t3 * pvs2[i22].y + DDeiUtil$1.p66t3 * endY;
opvs.push(new Vector3(btx, bty, 1));
opvsType.push(4);
}
}
break;
}
}
opvs.push(pvs2[pvs2.length - 1]);
opvsType.push(1);
this.opvs = opvs;
this.opvsType = opvsType;
} else {
let canRotate = DDei.beforeOperateValid(DDeiEnumOperateType.ROTATE, { models }, (_d2 = this.stage) == null ? void 0 : _d2.ddInstance, null);
let canScale = DDei.beforeOperateValid(DDeiEnumOperateType.SCALE, { models }, (_e2 = this.stage) == null ? void 0 : _e2.ddInstance, null);
let pvs2 = this.pvs;
let opvs = [];
let opvsType = [];
let lockWidth = 0;
let scale = 0;
if ((models == null ? void 0 : models.length) == 1) {
scale = (_g = (_f = models[0]) == null ? void 0 : _f.render) == null ? void 0 : _g.getCachedValue("textStyle.scale");
if (scale == 3) {
lockWidth = (_i = (_h = models[0]) == null ? void 0 : _h.render) == null ? void 0 : _i.getCachedValue("textStyle.lockWidth");
}
}
if ((pvs2 == null ? void 0 : pvs2.length) > 0) {
if (canScale.state == 0 || canScale.state == 1) {
if (scale == 3) {
if (lockWidth == 1) {
opvs[3] = { x: (pvs2[1].x + pvs2[2].x) / 2, y: (pvs2[1].y + pvs2[2].y) / 2 };
opvs[7] = { x: (pvs2[0].x + pvs2[3].x) / 2, y: (pvs2[0].y + pvs2[3].y) / 2 };
}
} else {
opvs[1] = { x: (pvs2[0].x + pvs2[1].x) / 2, y: (pvs2[0].y + pvs2[1].y) / 2 };
opvs[3] = { x: (pvs2[1].x + pvs2[2].x) / 2, y: (pvs2[1].y + pvs2[2].y) / 2 };
opvs[5] = { x: (pvs2[2].x + pvs2[3].x) / 2, y: (pvs2[2].y + pvs2[3].y) / 2 };
opvs[7] = { x: (pvs2[0].x + pvs2[3].x) / 2, y: (pvs2[0].y + pvs2[3].y) / 2 };
if (!this.eqrat) {
opvs[2] = { x: pvs2[1].x, y: pvs2[1].y };
opvs[4] = { x: pvs2[2].x, y: pvs2[2].y };
opvs[6] = { x: pvs2[3].x, y: pvs2[3].y };
opvs[8] = { x: pvs2[0].x, y: pvs2[0].y };
}
}
}
let v1 = new Vector3(pvs2[1].x, pvs2[1].y, 1);
let moveMatrix2 = new Matrix3(
1,
0,
-(pvs2[0].x + pvs2[1].x) / 2,
0,
1,
-(pvs2[0].y + pvs2[1].y) / 2,
0,
0,
1
);
v1.applyMatrix3(moveMatrix2);
let angle1 = (new Vector3(1, 0, 0).angleTo(new Vector3(v1.x, v1.y, 0)) * 180 / Math.PI).toFixed(4);
let angle2 = 0;
if (v1.x >= 0 && v1.y >= 0) {
angle2 = (angle1 * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (v1.x <= 0 && v1.y >= 0) {
angle2 = (angle1 * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (v1.x <= 0 && v1.y <= 0) {
angle2 = (-angle1 * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
} else if (v1.x >= 0 && v1.y <= 0) {
angle2 = (-angle1 * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
}
if (canRotate.state == 0 || canRotate.state == 1) {
let angleR1 = (90 * DDeiConfig$1.ROTATE_UNIT).toFixed(4) - angle2;
v1 = new Vector3(20, 0, 1);
let rotateMatrix = new Matrix3(
Math.cos(angleR1),
Math.sin(angleR1),
0,
-Math.sin(angleR1),
Math.cos(angleR1),
0,
0,
0,
1
);
v1.applyMatrix3(rotateMatrix);
let removeMatrix = new Matrix3(
1,
0,
(pvs2[0].x + pvs2[1].x) / 2,
0,
1,
(pvs2[0].y + pvs2[1].y) / 2,
0,
0,
1
);
v1.applyMatrix3(removeMatrix);
opvs[9] = v1;
}
let v2 = new Vector3(25, 0, 1);
let angleR2 = (135 * DDeiConfig$1.ROTATE_UNIT).toFixed(4) - angle2;
let rotateMatrix2 = new Matrix3(
Math.cos(angleR2),
Math.sin(angleR2),
0,
-Math.sin(angleR2),
Math.cos(angleR2),
0,
0,
0,
1
);
v2.applyMatrix3(rotateMatrix2);
let removeMatrix2 = new Matrix3(
1,
0,
pvs2[0].x,
0,
1,
pvs2[0].y,
0,
0,
1
);
v2.applyMatrix3(removeMatrix2);
opvs[10] = v2;
this.opvs = opvs;
this.opvsType = opvsType;
}
}
}
/**
* 返回当前坐标是否在操作点上,并返回操作点的类型
* @param direct 操作点下标
* @param x
* @param y
*/
isOpvOnLine(x2, y2) {
let weight = DDeiConfig$1.SELECTOR.OPERATE_ICON.weight;
let halfWeigth = weight * 0.5;
for (let i2 = 0; i2 < this.opvs.length; i2++) {
let pv = this.opvs[i2];
if (DDeiAbstractShape.isInsidePolygon(
[
{ x: pv.x - halfWeigth, y: pv.y - halfWeigth },
{ x: pv.x + halfWeigth, y: pv.y - halfWeigth },
{ x: pv.x + halfWeigth, y: pv.y + halfWeigth },
{ x: pv.x - halfWeigth, y: pv.y + halfWeigth }
],
{ x: x2, y: y2 }
)) {
return { type: this.opvsType[i2], index: i2 };
}
}
return null;
}
/**
* 判断是否在某个操作点上
* @param direct 操作点下标
* @param x
* @param y
*/
isOpvOn(direct, x2, y2) {
if (this.opvs && this.opvs[direct]) {
let pv = this.opvs[direct];
if (pv) {
let width = DDeiConfig$1.SELECTOR.OPERATE_ICON.weight;
let halfWidth = width * 0.5;
return DDeiAbstractShape.isInsidePolygon(
[
{ x: pv.x - halfWidth, y: pv.y - halfWidth },
{ x: pv.x + halfWidth, y: pv.y - halfWidth },
{ x: pv.x + halfWidth, y: pv.y + halfWidth },
{ x: pv.x - halfWidth, y: pv.y + halfWidth }
],
{ x: x2, y: y2 }
);
}
}
return false;
}
/**
* 判断图形是否在一个区域内,采用宽松的判定模式,允许传入一个大小值
* @param x
* @param y
* @param loose 宽松判定,默认false
* @returns 是否在区域内
*/
isInAreaLoose(x2 = void 0, y2 = void 0, loose = false) {
var _a3, _b2, _c2;
let models = null;
if (((_b2 = (_a3 = this.stage) == null ? void 0 : _a3.selectedModels) == null ? void 0 : _b2.size) > 0) {
models = Array.from(this.stage.selectedModels.values());
}
if ((models == null ? void 0 : models.length) == 1 && ((_c2 = models[0]) == null ? void 0 : _c2.baseModelType) == "DDeiLine") {
return models[0].isInAreaLoose(x2, y2, loose);
} else {
return super.isInAreaLoose(x2, y2, loose);
}
}
};
__publicField2(_DDeiSelector, "ClsName", "DDeiSelector");
let DDeiSelector = _DDeiSelector;
const __vite_glob_0_9$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiSelector,
default: DDeiSelector
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiTableCell = class _DDeiTableCell2 extends DDeiPolygonContainer {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "modelType", "DDeiTableCell");
__publicField2(this, "baseModelType", "DDeiTableCell");
__publicField2(this, "table");
__publicField2(this, "mergeRowNum");
__publicField2(this, "mergeColNum");
__publicField2(this, "mergedCell");
__publicField2(this, "originWidth");
__publicField2(this, "originHeight");
__publicField2(this, "row");
__publicField2(this, "col");
this.table = props.table;
this.row = props.row;
this.col = props.col;
this.mergeRowNum = props.mergeRowNum;
this.mergeColNum = props.mergeColNum;
this.mergedCell = props.mergedCell;
this.originWidth = props.originWidth;
this.originHeight = props.originHeight;
}
// ============================ 方法 ===============================
/**
* 当前单元格是否为合并单元格
*/
isMergeCell() {
return this.mergeRowNum > 1 || this.mergeColNum > 1;
}
/**
* 当前单元格是否为被合并单元格
*/
isMergedCell() {
return this.mergedCell != null;
}
/**
* 设置当前单元格状态为选中
*/
selectCell() {
this.setState(DDeiEnumControlState.SELECTED);
this.table.curRow = this.row;
this.table.curCol = this.col;
}
/**
* 选择或者取消选择当前单元格
*/
selectOrCancelCell() {
if (this.state == DDeiEnumControlState.SELECTED) {
this.setState(DDeiEnumControlState.DEFAULT);
this.table.curRow = -1;
this.table.curCol = -1;
} else {
this.selectCell();
}
}
// ============================ 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static loadFromJSON(json, tempData = {}) {
var _a3;
let container2 = new _DDeiTableCell2(json);
container2.layer = tempData["currentLayer"];
container2.stage = tempData["currentStage"];
container2.pModel = tempData["currentContainer"];
if (!container2.pModel) {
container2.pModel = container2.layer;
}
tempData[container2.id] = container2;
let ddInstance = (_a3 = container2.stage) == null ? void 0 : _a3.ddInstance;
let models = /* @__PURE__ */ new Map();
for (let key in json.models) {
tempData["currentContainer"] = container2;
let item = json.models[key];
let model = ddInstance.controlModelClasses[item.modelType].loadFromJSON(item, tempData);
models.set(key, model);
tempData["currentContainer"] = null;
}
container2.models = models;
container2.initPVS();
container2.initRender();
return container2;
}
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json, tempData = {}) {
let model = new _DDeiTableCell2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
model.initPVS();
return model;
}
};
__publicField2(_DDeiTableCell, "ClsName", "DDeiTableCell");
let DDeiTableCell = _DDeiTableCell;
const __vite_glob_0_12$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiTableCell,
default: DDeiTableCell
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiTableSelector = class _DDeiTableSelector2 extends DDeiSelector {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "modelType", "DDeiTableSelector");
__publicField2(this, "baseModelType", "DDeiSelector");
__publicField2(this, "table");
this.table = props.table;
}
// ============================ 方法 ===============================
/**
* 根据已选择的表格单元格,更新自身的大小以及位置
*/
updatedBounds() {
if (this.table.state == DDeiEnumControlState.DEFAULT) {
this.setBounds(0, 0, 0, 0);
} else {
let minMax = this.table.getMinMaxRowAndCol(this.table.getSelectedCells());
if (minMax) {
let rect = this.table.getCellPositionRect(minMax.minRow, minMax.minCol, minMax.maxRow, minMax.maxCol);
let tableAbsPos = this.table.getAbsPosition();
this.setBounds(tableAbsPos.x + rect.x, tableAbsPos.y + rect.y, rect.width, rect.height);
} else {
this.setBounds(0, 0, 0, 0);
}
}
}
// ============================ 静态变量 ============================
// ============================ 静态方法 ============================
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json, tempData = {}) {
let model = new _DDeiTableSelector2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
model.initPVS();
return model;
}
// ============================ 方法 ===============================
/**
* 获取画布缩放比率
*/
getStageRatio() {
if (this.stage) {
let stageRatio2 = parseFloat(this.stage.ratio) ? this.stage.ratio : 1;
if (!stageRatio2 || isNaN(stageRatio2)) {
stageRatio2 = this.stage.ddInstance.ratio;
}
return stageRatio2;
} else {
return 1;
}
}
};
__publicField2(_DDeiTableSelector, "ClsName", "DDeiTableSelector");
let DDeiTableSelector = _DDeiTableSelector;
const __vite_glob_0_13$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiTableSelector,
default: DDeiTableSelector
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiTable = class _DDeiTable2 extends DDeiAbstractShape {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "modelType", "DDeiTable");
__publicField2(this, "baseModelType", "DDeiTable");
__publicField2(this, "cols");
__publicField2(this, "rows");
__publicField2(this, "initRowNum", 5);
__publicField2(this, "initColNum", 5);
__publicField2(this, "curCol", -1);
__publicField2(this, "curRow", -1);
__publicField2(this, "selector", null);
this.cols = props.cols;
this.rows = props.rows;
this.initRowNum = props.initRowNum ? props.initRowNum : 5;
this.initColNum = props.initColNum ? props.initColNum : 5;
}
// ============================ 方法 ===============================
/**
* 初始化渲染器
*/
initRender() {
DDeiConfig$1.bindRender(this);
this.render.init();
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cellObj = rowObj[j2];
cellObj.stage = this.stage;
cellObj.table = this;
cellObj.layer = this.layer;
cellObj.pModel = this;
cellObj.ddInstance = this.ddInstance;
cellObj.initRender();
}
}
this.initSelector();
}
/**
* 初始化表格
*/
initTable() {
var _a3, _b2, _c2;
if (!(((_a3 = this.rows) == null ? void 0 : _a3.length) > 0 && ((_b2 = this.cols) == null ? void 0 : _b2.length) > 0)) {
let initWidth = parseFloat((this.width / this.initColNum).toFixed(4));
let initHeight = parseFloat((this.height / this.initRowNum).toFixed(4));
this.rows = [];
this.cols = [];
for (let i2 = 0; i2 < this.initRowNum; i2++) {
this.rows[i2] = [];
for (let j2 = 0; j2 < this.initColNum; j2++) {
if (i2 == 0) {
this.cols[j2] = [];
}
let initJSON = DDeiUtil$1.getSubControlJSON(this.modelCode, (_c2 = this.stage) == null ? void 0 : _c2.ddInstance);
initJSON.id = this.id + "_c_" + i2 + "_" + j2;
let x2 = (j2 + 0.5) * initWidth;
let y2 = (i2 + 0.5) * initHeight;
initJSON.row = i2;
initJSON.col = j2;
initJSON.width = initWidth;
initJSON.height = initHeight;
initJSON.table = this;
this.rows[i2][j2] = DDeiTableCell.initByJSON(initJSON, { currentStage: this.stage });
this.rows[i2][j2].cpv.x += this.x + x2;
this.rows[i2][j2].cpv.y += this.y + y2;
this.rows[i2][j2].pvs.forEach((pv) => {
pv.x += this.x + x2;
pv.y += this.y + y2;
});
this.rows[i2][j2].calLoosePVS();
this.cols[j2][i2] = this.rows[i2][j2];
}
}
}
}
/**
* 初始化选择器
*/
initSelector() {
if (!this.selector) {
this.selector = DDeiTableSelector.initByJSON({
id: this.id + "_table_selector",
border: DDeiConfig$1.TABLE.selector.border,
fill: { default: {}, selected: {} },
table: this
});
this.selector.stage = this.stage;
DDeiConfig$1.bindRender(this.selector);
this.selector.initRender();
this.selector.resetState();
}
}
/**
* 清除所有选中的单元格,并将curRow和curCol归位
*/
clearSelectionCells() {
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cellObj = rowObj[j2];
cellObj.setState(DDeiEnumControlState.DEFAULT);
}
}
this.curRow = -1;
this.curCol = -1;
}
//重设所有单元格的行列关系,以及对应的坐标、向量等
resetCellData() {
let tmpY = 0;
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
let tmpX = 0;
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cellObj = rowObj[j2];
cellObj.row = i2;
cellObj.col = j2;
cellObj.setPosition(tmpX, tmpY);
if (cellObj.mergedCell != null || cellObj.mergeRowNum > 1 || cellObj.mergeColNum > 1) {
tmpX = tmpX + cellObj.originWidth;
} else {
tmpX = tmpX + cellObj.width;
}
if (j2 == rowObj.length - 1) {
if (cellObj.mergedCell != null || cellObj.mergeRowNum > 1 || cellObj.mergeColNum > 1) {
tmpY = tmpY + cellObj.originHeight;
} else {
tmpY = tmpY + cellObj.height;
}
}
}
}
}
/**
* 获取子模型
*/
getSubModels(ignoreModelIds, level = 1) {
let models = [];
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let subModels = rowObj[j2].getSubModels(ignoreModelIds, level - 1);
models = models.concat(subModels);
}
}
return models;
}
/**
* 设置表格大小
* @param w
* @param h
*/
setSize(w, h) {
if (this.width && this.height) {
let wR = w / this.width;
let hR = h / this.height;
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cellObj = rowObj[j2];
cellObj.setBounds(cellObj.x * wR, cellObj.y * hR, cellObj.width * wR, cellObj.height * hR);
cellObj.originWidth = cellObj.originWidth * wR;
cellObj.originHeight = cellObj.originHeight * hR;
}
}
}
super.setSize(w, h);
}
/**
* 在第row行(下标)之下插入一个新行,插入的行的大小等于row的大小
* 插入后会重新维护所有行列关系
* 插入后会维护合并单元格关系
* 插入行后会往下增加表格的总高度,使表格高度=SUM(行高)
* @param row 行数
* @param direction 1向上,2向下
*/
insertRow(row, direction) {
var _a3;
let firstInsert = false;
if (row < 0) {
row = 0;
firstInsert = true;
} else if (row > this.rows.length - 1) {
row = this.rows.length - 1;
}
let currentRow = this.rows[row];
let newRow = [];
let corssMergeCell = [];
let addHeight = 0;
for (let i2 = 0; i2 < currentRow.length; i2++) {
let oldCell = currentRow[i2];
let newWidth = 0;
let newHeight = 0;
if (oldCell.mergeRowNum > 1 || oldCell.mergeColNum > 1 || oldCell.mergedCell) {
newWidth = oldCell.originWidth;
newHeight = oldCell.originHeight;
} else {
newWidth = oldCell.width;
newHeight = oldCell.height;
}
let initJSON = DDeiUtil$1.getSubControlJSON(this.modelCode, (_a3 = this.stage) == null ? void 0 : _a3.ddInstance);
initJSON.width = newWidth;
initJSON.height = newHeight;
initJSON.table = this;
let newCell = DDeiTableCell.initByJSON(initJSON, { currentStage: this.stage });
newCell.cpv.x += x;
newCell.cpv.y += y;
newCell.pvs.forEach((pv) => {
pv.x += x;
pv.y += y;
});
newCell.calLoosePVS();
newCell.layer = this.layer;
newCell.stage = this.stage;
newCell.pModel = this;
newCell.initRender();
newRow[i2] = newCell;
if (i2 == 0) {
addHeight = newCell.height;
}
let mCell = null;
if (!firstInsert && (oldCell.mergeRowNum > 1 || oldCell.mergeColNum > 1 || oldCell.mergedCell)) {
if (oldCell.mergeRowNum > 1 || oldCell.mergeColNum > 1) {
mCell = oldCell;
} else if (oldCell.mergedCell) {
mCell = this.rows[oldCell.mergedCell.row][oldCell.mergedCell.col];
}
newCell.mergedCell = mCell;
if (corssMergeCell.indexOf(mCell) == -1) {
corssMergeCell[corssMergeCell.length] = mCell;
mCell.mergeRowNum = mCell.mergeRowNum + 1;
mCell.setSize(void 0, parseFloat(mCell.height) + parseFloat(newCell.height));
}
newCell.originWidth = newCell.width;
newCell.originHeight = newCell.height;
newCell.height = 0;
newCell.width = 0;
}
}
this.height = this.height + addHeight;
this.setModelChanged();
for (let i2 = 0; i2 < this.cols.length; i2++) {
let currentCol = this.cols[i2];
if (firstInsert) {
currentCol.splice(0, 0, newRow[i2]);
} else {
currentCol.splice(row + 1, 0, newRow[i2]);
}
}
if (firstInsert) {
this.rows.splice(0, 0, newRow);
} else {
this.rows.splice(row + 1, 0, newRow);
}
this.resetCellData();
window.globalTableCopyData = null;
window.globalTableCutData = null;
if (this.copyAreaShape) {
this.copyAreaShape.style.display = "none";
}
this.clearSelectionCells();
if (firstInsert) {
if (direction == 1) {
this.curRow = 0;
} else {
this.curRow = 1;
}
} else {
this.curRow = row + 1;
}
this.setState(DDeiEnumControlState.SELECTED);
for (let i2 = 0; i2 < this.cols.length; i2++) {
this.cols[i2][this.curRow].setState(DDeiEnumControlState.SELECTED);
}
this.changeChildrenBounds();
}
/**
* 修改自身状态
*/
setState(state) {
super.setState(state);
if (this.state == DDeiEnumControlState.DEFAULT) {
this.selector.resetState();
}
}
/**
* 计算单元格的点旋转后的坐标
* @param rotateMatrix 旋转矩阵
*/
calCellsRotatePointVectors(rotateMatrix) {
var _a3;
let looseWeight = 10;
let parentCenterPointVector = this.centerPointVector;
if (parentCenterPointVector) {
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let item = rowObj[j2];
let halfWidth = item.width * 0.5;
let halfHeight = item.height * 0.5;
let vc, vc1, vc2, vc3, vc4;
let loosePointVectors = null;
if (((_a3 = item.pointVectors) == null ? void 0 : _a3.length) > 0) {
vc = item.centerPointVector;
vc1 = item.pointVectors[0];
vc2 = item.pointVectors[1];
vc3 = item.pointVectors[2];
vc4 = item.pointVectors[3];
loosePointVectors = item.loosePointVectors;
} else {
item.pointVectors = [];
let absBoundsOrigin = item.getAbsBounds();
vc = new Vector3(absBoundsOrigin.x + halfWidth, absBoundsOrigin.y + halfHeight, 1);
vc1 = new Vector3(vc.x - halfWidth, vc.y - halfHeight, 1);
vc2 = new Vector3(vc.x + halfWidth, vc.y - halfHeight, 1);
vc3 = new Vector3(vc.x + halfWidth, vc.y + halfHeight, 1);
vc4 = new Vector3(vc.x - halfWidth, vc.y + halfHeight, 1);
item.pointVectors.push(vc1);
item.pointVectors.push(vc2);
item.pointVectors.push(vc3);
item.pointVectors.push(vc4);
item.centerPointVector = vc;
let stageRatio2 = item.getStageRatio();
let globalScaleMatrix = new Matrix3(
stageRatio2,
0,
0,
0,
stageRatio2,
0,
0,
0,
1
);
item.centerPointVector.applyMatrix3(globalScaleMatrix);
item.pointVectors.forEach((pv) => {
pv.applyMatrix3(globalScaleMatrix);
});
loosePointVectors = [];
loosePointVectors.push(new Vector3(vc1.x - looseWeight, vc1.y - looseWeight, vc1.z));
loosePointVectors.push(new Vector3(vc2.x + looseWeight, vc2.y - looseWeight, vc2.z));
loosePointVectors.push(new Vector3(vc3.x + looseWeight, vc3.y + looseWeight, vc3.z));
loosePointVectors.push(new Vector3(vc4.x - looseWeight, vc4.y + looseWeight, vc4.z));
item.loosePointVectors = loosePointVectors;
}
vc1.applyMatrix3(rotateMatrix);
vc2.applyMatrix3(rotateMatrix);
vc3.applyMatrix3(rotateMatrix);
vc4.applyMatrix3(rotateMatrix);
vc.applyMatrix3(rotateMatrix);
loosePointVectors == null ? void 0 : loosePointVectors.forEach((pv) => {
pv.applyMatrix3(rotateMatrix);
});
item.calChildrenRotatePointVectors(rotateMatrix);
}
}
}
}
/**
* 修改上层模型大小
*/
changeParentsBounds() {
if (this.pModel) {
this.pModel.changeParentsBounds();
}
return true;
}
/**
* 修改子元素大小
*/
changeChildrenBounds(originRect, newRect) {
var _a3;
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cell = rowObj[j2];
(_a3 = cell == null ? void 0 : cell.layoutManager) == null ? void 0 : _a3.changeSubModelBounds();
}
}
return true;
}
/**
* 在第col列(下标)之下插入一个新列,插入的列的大小等于col的大小
* 插入后会重新维护所有行列关系
* 插入后会维护合并单元格关系
* 插入行后会往下增加表格的总高度,使表格高度=SUM(行高)
* @param col
* @param direction 1左边,2右边
*/
insertCol(col, direction) {
var _a3;
let firstInsert = false;
if (col < 0) {
col = 0;
firstInsert = true;
} else if (col > this.cols.length - 1) {
col = this.cols.length - 1;
}
let currentCol = this.cols[col];
let newCol = [];
let corssMergeCell = [];
let addWidth = 0;
for (let i2 = 0; i2 < currentCol.length; i2++) {
let oldCell = currentCol[i2];
let newWidth = 0;
let newHeight = 0;
if (oldCell.mergeRowNum > 1 || oldCell.mergeColNum > 1 || oldCell.mergedCell) {
newWidth = oldCell.originWidth;
newHeight = oldCell.originHeight;
} else {
newWidth = oldCell.width;
newHeight = oldCell.height;
}
let initJSON = DDeiUtil$1.getSubControlJSON(this.modelCode, (_a3 = this.stage) == null ? void 0 : _a3.ddInstance);
initJSON.width = newWidth;
initJSON.height = newHeight;
initJSON.table = this;
let newCell = DDeiTableCell.initByJSON(initJSON);
newCell.layer = this.layer;
newCell.stage = this.stage;
newCell.pModel = this;
newCell.initRender();
newCol[i2] = newCell;
if (i2 == 0) {
addWidth = newCell.width;
}
let mCell = null;
if (!firstInsert && (oldCell.mergeRowNum > 1 || oldCell.mergeColNum > 1 || oldCell.mergedCell)) {
if (oldCell.mergeRowNum > 1 || oldCell.mergeColNum > 1) {
mCell = oldCell;
} else if (oldCell.mergedCell) {
mCell = this.rows[oldCell.mergedCell.row][oldCell.mergedCell.col];
}
newCell.mergedCell = mCell;
if (corssMergeCell.indexOf(mCell) == -1) {
corssMergeCell[corssMergeCell.length] = mCell;
mCell.mergeColNum = mCell.mergeColNum + 1;
mCell == null ? void 0 : mCell.setSize(parseFloat(mCell.width) + parseFloat(newCell.width));
}
newCell.originWidth = newCell.width;
newCell.originHeight = newCell.height;
newCell.height = 0;
newCell.width = 0;
}
}
this.width = this.width + addWidth;
this.setModelChanged();
for (let i2 = 0; i2 < this.rows.length; i2++) {
let currentRow = this.rows[i2];
if (firstInsert) {
currentRow.splice(0, 0, newCol[i2]);
} else {
currentRow.splice(col + 1, 0, newCol[i2]);
}
}
if (firstInsert) {
this.cols.splice(0, 0, newCol);
} else {
this.cols.splice(col + 1, 0, newCol);
}
this.resetCellData();
window.globalTableCopyData = null;
window.globalTableCutData = null;
if (this.copyAreaShape) {
this.copyAreaShape.style.display = "none";
}
this.clearSelectionCells();
if (firstInsert) {
if (direction == 1) {
this.curCol = 0;
} else {
this.curCol = 1;
}
} else {
this.curCol = col + 1;
}
this.setState(DDeiEnumControlState.SELECTED);
for (let i2 = 0; i2 < this.rows.length; i2++) {
this.rows[i2][this.curCol].setState(DDeiEnumControlState.SELECTED);
}
this.changeChildrenBounds();
}
/**
* 删除行
* @param row
*/
removeRow(row) {
if (this.rows.length <= 1) {
return;
}
let firstRemove = false;
if (row < 0) {
row = 0;
firstRemove = true;
} else if (row > this.rows.length - 1) {
row = this.rows.length - 1;
}
let removeCells = null;
if (firstRemove) {
removeCells = this.rows[0];
} else {
removeCells = this.rows[row];
}
let removeHeight = 0;
let corssMergeCell = [];
for (let x2 = 0; x2 < removeCells.length; x2++) {
let removeCell = removeCells[x2];
removeHeight = removeCell.height;
let mCell = null;
if (removeCell.mergeRowNum == 1)
;
else if (removeCell.mergeRowNum > 1 || removeCell.mergeColNum > 1) {
mCell = this.rows[removeCell.row + 1][x2];
mCell.setSize(removeCell.width, removeCell.height);
mCell.mergeRowNum = removeCell.mergeRowNum;
mCell.mergeColNum = removeCell.mergeColNum;
for (let i2 = mCell.row; i2 < mCell.row + removeCell.mergeRowNum - 1; i2++) {
for (let j2 = mCell.col; j2 < mCell.col + mCell.mergeColNum; j2++) {
this.rows[i2][j2].mergedCell = mCell;
}
}
removeHeight = removeCell.originHeight;
} else if (removeCell.mergedCell != null) {
mCell = removeCell.mergedCell;
removeHeight = removeCell.originHeight;
}
if (mCell != null) {
if (corssMergeCell.indexOf(mCell) == -1) {
corssMergeCell[corssMergeCell.length] = mCell;
mCell.mergeRowNum = mCell.mergeRowNum - 1;
mCell.setSize(mCell.width, parseInt(mCell.height) - removeHeight);
}
}
}
if (firstRemove) {
this.rows.splice(0, 1);
} else {
this.rows.splice(row, 1);
}
this.height = this.height - removeHeight;
this.setModelChanged();
for (let i2 = 0; i2 < this.cols.length; i2++) {
let currentCol = this.cols[i2];
if (firstRemove) {
currentCol.splice(0, 1);
} else {
currentCol.splice(row, 1);
}
}
if (row < 0) {
this.curRow = 0;
} else if (row > this.rows.length - 1) {
this.curRow = this.rows.length - 1;
} else {
this.curRow = row;
}
this.resetCellData();
}
/**
* 删除列
* @param col
*/
removeCol(col) {
if (this.cols.length <= 1) {
return;
}
let firstRemove = false;
if (col < 0) {
col = 0;
firstRemove = true;
} else if (col > this.cols.length - 1) {
col = this.cols.length - 1;
}
let removeCells = null;
if (firstRemove) {
removeCells = this.cols[0];
} else {
removeCells = this.cols[col];
}
let removeWidth = 0;
let corssMergeCell = [];
for (let x2 = 0; x2 < removeCells.length; x2++) {
let removeCell = removeCells[x2];
removeWidth = removeCell.width;
let mCell = null;
if (removeCell.mergeColNum == 1)
;
else if (removeCell.mergeColNum > 1 || removeCell.mergeRowNum > 1) {
mCell = this.rows[x2][removeCell.col + 1];
mCell.setSize(removeCell.width, removeCell.height);
mCell.mergeRowNum = removeCell.mergeRowNum;
mCell.mergeColNum = removeCell.mergeColNum;
for (let i2 = mCell.col; i2 < mCell.col + removeCell.mergeColNum - 1; i2++) {
for (let j2 = mCell.row; j2 < mCell.row + mCell.mergeRowNum; j2++) {
this.rows[j2][i2].mergedCell = mCell;
}
}
removeWidth = removeCell.originWidth;
} else if (removeCell.mergedCell != null) {
mCell = removeCell.mergedCell;
removeWidth = removeCell.originWidth;
}
if (mCell != null) {
if (corssMergeCell.indexOf(mCell) == -1) {
corssMergeCell[corssMergeCell.length] = mCell;
mCell.mergeColNum = mCell.mergeColNum - 1;
mCell.setSize(parseInt(mCell.width) - removeWidth, mCell.height);
}
}
}
this.width = this.width - removeWidth;
this.setModelChanged();
if (firstRemove) {
this.cols.splice(0, 1);
} else {
this.cols.splice(col, 1);
}
for (let i2 = 0; i2 < this.rows.length; i2++) {
let currentRow = this.rows[i2];
if (firstRemove) {
currentRow.splice(0, 1);
} else {
currentRow.splice(col, 1);
}
}
if (col < 0) {
this.curCol = 0;
} else if (col > this.cols.length - 1) {
this.curCol = this.cols.length - 1;
} else {
this.curCol = col;
}
this.resetCellData();
}
// 取得区域内的所有单元格
getCellsByRect(minRow, minCol, maxRow, maxCol) {
let returnCells = [];
for (let i2 = minRow; i2 <= maxRow; i2++) {
for (let j2 = minCol; j2 <= maxCol; j2++) {
returnCells[returnCells.length] = this.rows[i2][j2];
}
}
return returnCells;
}
/**
* 合并选中的单元格
*/
mergeSelectedCells() {
let selectedCells = this.getSelectedCells();
this.cancelMergeCells(selectedCells);
selectedCells = this.getSelectedCells();
this.mergeCells(selectedCells);
}
/**
* 合并的单元格
*/
mergeCells(selectedCells) {
var _a3, _b2, _c2;
let minMaxRowCol = this.getMinMaxRowAndCol(selectedCells);
let firstCell = this.rows[minMaxRowCol.minRow][minMaxRowCol.minCol];
let mergeHeight = 0;
for (let i2 = minMaxRowCol.minRow; i2 <= minMaxRowCol.maxRow; i2++) {
mergeHeight = mergeHeight + this.rows[i2][minMaxRowCol.minCol].height;
}
let mergeWidth = 0;
for (let j2 = minMaxRowCol.minCol; j2 <= minMaxRowCol.maxCol; j2++) {
mergeWidth = mergeWidth + this.rows[minMaxRowCol.minRow][j2].width;
}
firstCell.originWidth = firstCell.width;
firstCell.originHeight = firstCell.height;
for (let i2 = minMaxRowCol.minRow; i2 <= minMaxRowCol.maxRow; i2++) {
for (let j2 = minMaxRowCol.minCol; j2 <= minMaxRowCol.maxCol; j2++) {
this.rows[i2][j2].originWidth = this.rows[i2][j2].width;
this.rows[i2][j2].originHeight = this.rows[i2][j2].height;
this.rows[i2][j2].setSize(0, 0);
this.rows[i2][j2].mergedCell = firstCell;
if ((!firstCell.text || firstCell.text.trim() == "") && firstCell.midList.length == 0) {
if (this.rows[i2][j2].midList.length > 0) {
(_c2 = (_b2 = (_a3 = this.stage) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.bus) == null ? void 0 : _c2.push(DDeiEnumBusCommandType.ModelChangeContainer, { oldContainer: this.rows[i2][j2], newContainer: firstCell, models: Array.from(this.rows[i2][j2].models.values()) }, { offsetX: 0, offsetY: 0 });
} else if (this.rows[i2][j2].text && this.rows[i2][j2].text.trim() != "") {
firstCell.text = this.rows[i2][j2].text;
this.rows[i2][j2].text = "";
}
}
this.rows[i2][j2].setState(DDeiEnumControlState.DEFAULT);
}
}
firstCell.mergeRowNum = minMaxRowCol.maxRow - minMaxRowCol.minRow + 1;
firstCell.mergeColNum = minMaxRowCol.maxCol - minMaxRowCol.minCol + 1;
firstCell.setSize(mergeWidth, mergeHeight);
firstCell.setState(DDeiEnumControlState.SELECTED);
this.curRow = firstCell.row;
this.curCol = firstCell.col;
this.changeChildrenBounds();
}
/**
* 将当前选中的单元格取消合并
*/
cancelSelectedMergeCells() {
let selectedCells = this.getSelectedCells();
this.cancelMergeCells(selectedCells);
}
/**
* 取得区域的开始和结束坐标
*/
getCellPositionRect(startRow, startCol, endRow, endCol) {
let x2 = 0, y2 = 0, width = 0, height = 0;
x2 = this.rows[startRow][startCol].x;
y2 = this.rows[startRow][startCol].y;
for (let i2 = startRow; i2 <= endRow; i2++) {
let rowWidth = 0;
for (let j2 = startCol; j2 <= endCol; j2++) {
rowWidth = rowWidth + this.rows[i2][j2].width;
}
if (rowWidth > width) {
width = rowWidth;
}
}
for (let i2 = startCol; i2 <= endCol; i2++) {
let colHeight = 0;
for (let j2 = startRow; j2 <= endRow; j2++) {
colHeight = colHeight + this.cols[i2][j2].height;
}
if (colHeight > height) {
height = colHeight;
}
}
return { x: x2, y: y2, width, height };
}
/**
* 取消合并传入的单元格
*/
cancelMergeCells(cells) {
if (cells != null) {
for (let c = 0; c < cells.length; c++) {
let firstCell = cells[c];
for (let i2 = firstCell.row; i2 < firstCell.row + firstCell.mergeRowNum; i2++) {
for (let j2 = firstCell.col; j2 < firstCell.col + firstCell.mergeColNum; j2++) {
let cel = this.rows[i2][j2];
cel.setSize(cel.originWidth, cel.originHeight);
cel.originWidth = null;
cel.originHeight = null;
cel.mergedCell = null;
cel.setState(DDeiEnumControlState.SELECTED);
}
}
firstCell.mergeRowNum = null;
firstCell.mergeColNum = null;
this.curRow = firstCell.row;
this.curCol = firstCell.col;
}
this.changeChildrenBounds();
}
}
/**
* 根据表格内坐标获取单元格
*/
getCellByTablePosition(x2, y2) {
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cell = rowObj[j2];
if (cell.width <= 0 || cell.height <= 0) {
continue;
}
if (cell.isInAreaLoose(x2, y2)) {
return cell;
}
}
}
return null;
}
// 返回当前表格所有选中的单元格,ignoreMerged默认为false,不忽略
getSelectedCells() {
let arr = [];
for (let i2 = 0; i2 < this.rows.length; i2++) {
for (let j2 = 0; j2 < this.rows[i2].length; j2++) {
if (this.rows[i2][j2].state == DDeiEnumControlState.SELECTED) {
arr[arr.length] = this.rows[i2][j2];
}
}
}
return arr;
}
/**
* 根据ID获取模型
* @param id 模型id
*/
getModelById(id) {
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cell = rowObj[j2];
let returnModel = cell.getModelById(id);
if (returnModel) {
return returnModel;
}
}
}
}
/**
* 获取实际的内部容器控件
* @return 容器控件根据布局的模式不同返回不同的内部控件,普通控件返回null
*/
getAccuContainer() {
return this;
}
/**
* 获取实际的内部容器控件
* @param x 相对路径坐标
* @param y 相对路径坐标
* @return 容器控件根据布局的模式不同返回不同的内部控件,普通控件返回null
*/
getAccuContainerByPos(x2, y2) {
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cell = rowObj[j2];
if (cell.width <= 0 || cell.height <= 0) {
continue;
}
if (cell.isInAreaLoose(x2, y2)) {
return cell;
}
}
}
return null;
}
// 判断两个区域是否有重合
isOverlap(rect1, rect2) {
let l1 = { x: rect1.minCol, y: rect1.minRow };
let r1 = { x: rect1.maxCol, y: rect1.maxRow };
let l2 = { x: rect2.minCol, y: rect2.minRow };
let r2 = { x: rect2.maxCol, y: rect2.maxRow };
if (l1.x > r2.x || l2.x > r1.x || l1.y > r2.y || l2.y > r1.y)
return false;
return true;
}
// 判断区域内是否存在合并单元格或被合并单元格
hasMergeCell(minRow, minCol, maxRow, maxCol) {
for (let i2 = minRow; i2 <= maxRow && i2 <= this.rows.length - 1; i2++) {
for (let j2 = minCol; j2 <= maxCol && j2 <= this.cols.length - 1; j2++) {
if (this.rows[i2][j2].isMergeCell() || this.rows[i2][j2].isMergedCell()) {
return true;
}
}
}
return false;
}
/**
* 获取单元格的最大外接矩形区域
* @arr 单元格
*/
getMinMaxRowAndCol(arr) {
let minCol = -1, maxCol = -1, minRow = -1, maxRow = -1;
for (let i2 = 0; i2 < arr.length; i2++) {
if (i2 == 0) {
minRow = arr[i2].row;
minCol = arr[i2].col;
maxRow = arr[i2].row;
maxCol = arr[i2].col;
if (arr[i2].mergeRowNum > 1 || arr[i2].mergeColNum > 1) {
maxRow = arr[i2].row + arr[i2].mergeRowNum - 1;
maxCol = arr[i2].col + arr[i2].mergeColNum - 1;
}
} else {
if (minRow > arr[i2].row) {
minRow = arr[i2].row;
}
if (minCol > arr[i2].col) {
minCol = arr[i2].col;
}
if (arr[i2].mergeRowNum > 1 || arr[i2].mergeColNum > 1) {
let r1 = arr[i2].row + arr[i2].mergeRowNum - 1;
let c1 = arr[i2].col + arr[i2].mergeColNum - 1;
if (maxRow < r1) {
maxRow = r1;
}
if (maxCol < c1) {
maxCol = c1;
}
} else {
if (maxRow < arr[i2].row) {
maxRow = arr[i2].row;
}
if (maxCol < arr[i2].col) {
maxCol = arr[i2].col;
}
}
}
}
if (minRow != -1 && maxRow != -1 && minCol != -1 && maxCol != -1) {
for (let i2 = minRow; i2 <= maxRow; i2++) {
for (let j2 = minCol; j2 <= maxCol; j2++) {
if (this.rows[i2][j2].mergeRowNum > 1 || this.rows[i2][j2].mergeColNum > 1) {
if (this.rows[i2][j2].row + this.rows[i2][j2].mergeRowNum - 1 > maxRow || this.rows[i2][j2].col + this.rows[i2][j2].mergeColNum - 1 > maxCol) {
arr[arr.length] = this.rows[i2][j2];
return this.getMinMaxRowAndCol(arr);
}
} else if (this.rows[i2][j2].mergedCell != null) {
let mCell = this.rows[this.rows[i2][j2].mergedCell.row][this.rows[i2][j2].mergedCell.col];
if (mCell.row + mCell.mergeRowNum - 1 > maxRow || mCell.col + mCell.mergeColNum - 1 > maxCol || mCell.col < minCol || mCell.row < minRow) {
arr[arr.length] = mCell;
return this.getMinMaxRowAndCol(arr);
}
}
}
}
}
if (minCol != -1 && maxCol != -1 && minRow != -1 && maxRow != -1) {
return { minCol, maxCol, minRow, maxRow };
}
return null;
}
/**
* 判断指定区域内的所有单元格是否都被选中
* @param r 行
* @param c 列
* @param r1 行1
* @param c1 列1
* @returns true都选中,false都没选中
*/
isAllSelected(r, c, r1, c1) {
let returnData = true;
let minCol = c > c1 ? c1 : c;
let maxCol = c > c1 ? c : c1;
let minRow = r > r1 ? r1 : r;
let maxRow = r > r1 ? r : r1;
for (let i2 = minRow; i2 <= maxRow; i2++) {
for (let j2 = minCol; j2 <= maxCol; j2++) {
if (this.rows[i2][j2].mergedCell != null) {
continue;
}
if (this.rows[i2][j2].state != DDeiEnumControlState.SELECTED) {
return false;
}
}
}
return returnData;
}
/**
* 从上边调整表格的大小
* 该方法在拖拽过程中调用,会处理由拖拽引起的合并单元格的变动
*/
changeTableSizeToTop(x2, y2) {
let table2 = this;
let dragObj = table2.stage.render.dragObj;
let changeHeight = dragObj.y - y2;
dragObj.y = dragObj.y - changeHeight;
if (changeHeight != 0) {
let processedCells = [];
for (let i2 = 0; i2 < table2.cols.length; i2++) {
let afterCell = table2.cols[i2][0];
if (afterCell.height != 0 && afterCell.height + changeHeight < 5 || afterCell.originHeight != null && afterCell.originHeight + changeHeight < 5) {
return;
}
}
for (let i2 = 0; i2 < table2.cols.length; i2++) {
let rowObj = table2.cols[i2];
let afterCell = table2.cols[i2][0];
if (processedCells.indexOf(afterCell) == -1) {
if (!afterCell.isMergedCell() && !afterCell.isMergeCell()) {
afterCell.setSize(void 0, afterCell.height + changeHeight);
processedCells[processedCells.length] = afterCell;
} else if (afterCell.isMergeCell()) {
let mCell = afterCell;
mCell.originHeight = mCell.originHeight + changeHeight;
mCell.setSize(void 0, mCell.height + changeHeight);
processedCells[processedCells.length] = mCell;
} else if (afterCell.isMergedCell()) {
afterCell.originHeight = afterCell.originHeight + changeHeight;
processedCells[processedCells.length] = afterCell;
}
}
for (let j2 = 1; j2 < rowObj.length; j2++) {
rowObj[j2].setPosition(void 0, rowObj[j2].y + changeHeight);
}
}
table2.height = table2.height + changeHeight;
table2.setPosition(void 0, table2.y - changeHeight);
this.updateCopyShapeArea();
this.changeChildrenBounds();
}
}
/**
* 从下边调整表格的大小
* 该方法在拖拽过程中调用,会处理由拖拽引起的合并单元格的变动
*/
changeTableSizeToBottom(x2, y2) {
let table2 = this;
let dragObj = table2.stage.render.dragObj;
let changeHeight = y2 - dragObj.y;
dragObj.y = dragObj.y + changeHeight;
if (changeHeight != 0) {
let processedCells = [];
for (let i2 = 0; i2 < table2.cols.length; i2++) {
let beforeCell = table2.cols[i2][table2.rows.length - 1];
if (beforeCell.height != 0 && beforeCell.height + changeHeight < 5 || beforeCell.originHeight != null && beforeCell.originHeight + changeHeight < 5) {
return;
}
}
for (let i2 = 0; i2 < table2.cols.length; i2++) {
let beforeCell = table2.cols[i2][table2.rows.length - 1];
if (processedCells.indexOf(beforeCell) == -1) {
if (!beforeCell.isMergedCell() && !beforeCell.isMergeCell()) {
beforeCell.setSize(void 0, beforeCell.height + changeHeight);
processedCells[processedCells.length] = beforeCell;
} else if (beforeCell.isMergeCell()) {
beforeCell.originHeight = beforeCell.originHeight + changeHeight;
beforeCell.setSize(void 0, beforeCell.height + changeHeight);
processedCells[processedCells.length] = beforeCell;
} else if (beforeCell.isMergedCell()) {
let mCell = beforeCell.mergedCell;
beforeCell.originHeight = beforeCell.originHeight + changeHeight;
if (processedCells.indexOf(mCell) == -1) {
processedCells[processedCells.length] = mCell;
mCell.setSize(void 0, mCell.height + changeHeight);
}
processedCells[processedCells.length] = beforeCell;
}
}
}
table2.height = table2.height + changeHeight;
table2.setModelChanged();
this.updateCopyShapeArea();
this.changeChildrenBounds();
}
}
/**
* 从左边调整表格的大小
* 该方法在拖拽过程中调用,会处理由拖拽引起的合并单元格的变动
*/
changeTableSizeToLeft(x2, y2) {
let table2 = this;
let dragObj = table2.stage.render.dragObj;
let changeWidth = dragObj.x - x2;
dragObj.x = dragObj.x - changeWidth;
if (changeWidth != 0) {
let processedCells = [];
for (let i2 = 0; i2 < table2.rows.length; i2++) {
let afterCell = table2.rows[i2][0];
if (afterCell.width != 0 && afterCell.width + changeWidth < 5 || afterCell.originWidth != null && afterCell.originWidth + changeWidth < 5) {
return;
}
}
for (let i2 = 0; i2 < table2.rows.length; i2++) {
let rowObj = table2.rows[i2];
let afterCell = table2.rows[i2][0];
if (processedCells.indexOf(afterCell) == -1) {
if (!afterCell.isMergedCell() && !afterCell.isMergeCell()) {
afterCell.setSize(afterCell.width + changeWidth);
processedCells[processedCells.length] = afterCell;
} else if (afterCell.isMergeCell()) {
let mCell = afterCell;
mCell.originWidth = mCell.originWidth + changeWidth;
mCell.setSize(mCell.width + changeWidth);
processedCells[processedCells.length] = mCell;
} else if (afterCell.isMergedCell()) {
afterCell.originWidth = afterCell.originWidth + changeWidth;
processedCells[processedCells.length] = afterCell;
}
}
for (let j2 = 1; j2 < rowObj.length; j2++) {
rowObj[j2].setPosition(rowObj[j2].x + changeWidth);
}
}
table2.width = table2.width + changeWidth;
table2.setPosition(table2.x - changeWidth);
this.updateCopyShapeArea();
this.changeChildrenBounds();
}
}
/**
* 从右边调整表格的大小
* 该方法在拖拽过程中调用,会处理由拖拽引起的合并单元格的变动
*/
changeTableSizeToRight(x2, y2) {
let table2 = this;
let dragObj = table2.stage.render.dragObj;
let changeWidth = x2 - dragObj.x;
dragObj.x = dragObj.x + changeWidth;
if (changeWidth != 0) {
let processedCells = [];
for (let i2 = 0; i2 < table2.rows.length; i2++) {
let beforeCell = table2.rows[i2][table2.cols.length - 1];
if (beforeCell.width != 0 && beforeCell.width + changeWidth < 5 || beforeCell.originWidth != null && beforeCell.originWidth + changeWidth < 5) {
return;
}
}
for (let i2 = 0; i2 < table2.rows.length; i2++) {
let beforeCell = table2.rows[i2][table2.cols.length - 1];
if (processedCells.indexOf(beforeCell) == -1) {
if (!beforeCell.isMergedCell() && !beforeCell.isMergeCell()) {
beforeCell.setSize(beforeCell.width + changeWidth);
processedCells[processedCells.length] = beforeCell;
} else if (beforeCell.isMergeCell()) {
beforeCell.originWidth = beforeCell.originWidth + changeWidth;
beforeCell.setSize(beforeCell.width + changeWidth);
processedCells[processedCells.length] = beforeCell;
} else if (beforeCell.isMergedCell()) {
let mCell = beforeCell.mergedCell;
beforeCell.originWidth = beforeCell.originWidth + changeWidth;
if (processedCells.indexOf(mCell) == -1) {
processedCells[processedCells.length] = mCell;
mCell.setSize(mCell.width + changeWidth);
}
processedCells[processedCells.length] = beforeCell;
}
}
}
table2.width = table2.width + changeWidth;
table2.setModelChanged();
this.updateCopyShapeArea();
this.changeChildrenBounds();
}
}
/**
* 拖拽行大小
* 该方法在拖拽过程中调用,会处理由拖拽引起的合并单元格的变动
*/
dragRow(x2, y2) {
let cell = this.dragCell;
let table2 = this;
if (cell.row >= table2.rows.length - 1) {
return;
}
for (let i2 = 0; i2 < table2.rows.length; i2++) {
if (table2.cols[cell.col][i2].specilCol) {
this.specilDrag = true;
for (let j2 = 0; j2 < table2.rows.length; j2++) {
if (!table2.cols[cell.col][j2].specilCol) {
table2.cols[cell.col][j2].specilCol = true;
}
}
break;
}
}
let dragObj = table2.stage.render.dragObj;
let changeHeight = y2 - dragObj.y;
dragObj.y = dragObj.y + changeHeight;
if (changeHeight != 0) {
if (this.specilDrag) {
let pass = false;
for (let i2 = 0; i2 < table2.rows.length; i2++) {
if (table2.cols[cell.col][i2].isMergedCell() || table2.cols[cell.col][i2].isMergeCell()) {
pass = true;
break;
}
}
if (cell.height != 0 && cell.height + changeHeight < 5 || table2.cols[cell.col][cell.row + 1].height != 0 && table2.cols[cell.col][cell.row + 1].height - changeHeight < 5) {
pass = true;
}
if (!pass) {
cell.setSize(void 0, cell.height + changeHeight);
table2.cols[cell.col][cell.row + 1].setSize(void 0, table2.cols[cell.col][cell.row + 1].height - changeHeight);
table2.cols[cell.col][cell.row + 1].setPosition(void 0, table2.cols[cell.col][cell.row + 1].y + changeHeight);
for (let i2 = 0; i2 < table2.rows.length; i2++) {
table2.cols[cell.col][i2].specilCol = true;
}
return;
}
}
let processedCells = [];
for (let i2 = 0; i2 < table2.cols.length; i2++) {
let beforeCell = table2.cols[i2][cell.row];
let afterCell = table2.cols[i2][cell.row + 1];
if (!beforeCell.specilCol && (beforeCell.height != 0 && beforeCell.height + changeHeight < 5 || beforeCell.originHeight != null && beforeCell.originHeight + changeHeight < 5)) {
return;
}
if (!afterCell.specilCol && (afterCell.height != 0 && afterCell.height - changeHeight < 5 || afterCell.originHeight != null && afterCell.originHeight - changeHeight < 5)) {
return;
}
}
for (let i2 = 0; i2 < table2.cols.length; i2++) {
let beforeCell = table2.cols[i2][cell.row];
if (processedCells.indexOf(beforeCell) == -1 && !beforeCell.specilCol) {
if (!beforeCell.isMergedCell() && !beforeCell.isMergeCell()) {
beforeCell.setSize(void 0, beforeCell.height + changeHeight);
processedCells[processedCells.length] = beforeCell;
} else if (beforeCell.isMergeCell()) {
let mCell = beforeCell;
if (mCell.mergeRowNum == 1) {
beforeCell.originHeight = beforeCell.originHeight + changeHeight;
beforeCell.setSize(void 0, beforeCell.height + changeHeight);
processedCells[processedCells.length] = beforeCell;
} else {
beforeCell.originHeight = beforeCell.originHeight + changeHeight;
processedCells[processedCells.length] = beforeCell;
}
} else if (beforeCell.isMergedCell()) {
let mCell = beforeCell.mergedCell;
if (mCell.row + mCell.mergeRowNum - 1 == beforeCell.row) {
beforeCell.originHeight = beforeCell.originHeight + changeHeight;
if (processedCells.indexOf(mCell) == -1) {
processedCells[processedCells.length] = mCell;
mCell.setSize(void 0, mCell.height + changeHeight);
}
processedCells[processedCells.length] = beforeCell;
} else {
beforeCell.originHeight = beforeCell.originHeight + changeHeight;
processedCells[processedCells.length] = beforeCell;
}
}
}
let afterCell = table2.cols[i2][cell.row + 1];
if (processedCells.indexOf(afterCell) == -1 && !afterCell.specilCol) {
if (!afterCell.isMergedCell() && !afterCell.isMergeCell()) {
afterCell.setSize(void 0, afterCell.height - changeHeight);
afterCell.setPosition(void 0, afterCell.y + changeHeight);
processedCells[processedCells.length] = afterCell;
} else if (afterCell.isMergeCell()) {
let mCell = afterCell;
mCell.originHeight = mCell.originHeight - changeHeight;
mCell.setSize(void 0, mCell.height - changeHeight);
mCell.setPosition(void 0, mCell.y + changeHeight);
processedCells[processedCells.length] = mCell;
for (let x3 = mCell.col + 1; x3 < mCell.col + mCell.mergeColNum; x3++) {
if (!table2.cols[x3][mCell.row].specilCol) {
table2.cols[x3][mCell.row].originHeight = table2.cols[x3][mCell.row].originHeight - changeHeight;
table2.cols[x3][mCell.row].setPosition(void 0, table2.cols[x3][mCell.row].y + changeHeight);
processedCells[processedCells.length] = table2.cols[x3][mCell.row];
}
}
} else if (afterCell.isMergedCell()) {
let mCell = afterCell.mergedCell;
if (mCell.row + mCell.mergeRowNum == afterCell.row) {
afterCell.originHeight = afterCell.originHeight - changeHeight;
if (processedCells.indexOf(mCell) == -1) {
mCell.setSize(void 0, mCell.height - changeHeight);
processedCells[processedCells.length] = mCell;
}
processedCells[processedCells.length] = afterCell;
} else {
afterCell.originHeight = afterCell.originHeight - changeHeight;
afterCell.setPosition(void 0, afterCell.y + changeHeight);
processedCells[processedCells.length] = afterCell;
}
}
}
}
this.updateCopyShapeArea();
this.changeChildrenBounds();
}
}
/**
* 拖拽时选中单元格
* @param x
* @param y
*/
dragAndSelectedCell(x2, y2) {
let cell = this.dragCell;
let table2 = this;
if (!table2.tempUpCel) {
table2.tempUpCel = cell;
}
let targetCell = table2.getCellByTablePosition(x2, y2);
if (targetCell && table2.tempUpCel != targetCell) {
let minMax = table2.getMinMaxRowAndCol([cell, table2.tempUpCel]);
for (let i2 = minMax.minRow; i2 <= minMax.maxRow; i2++) {
for (let j2 = minMax.minCol; j2 <= minMax.maxCol; j2++) {
table2.rows[i2][j2].setState(DDeiEnumControlState.DEFAULT);
}
}
table2.tempUpCel = targetCell;
minMax = table2.getMinMaxRowAndCol([cell, table2.tempUpCel]);
for (let i2 = minMax.minRow; i2 <= minMax.maxRow; i2++) {
for (let j2 = minMax.minCol; j2 <= minMax.maxCol; j2++) {
table2.rows[i2][j2].setState(DDeiEnumControlState.SELECTED);
}
}
}
}
/**
* 拖拽列大小
* 该方法在拖拽过程中调用,会处理由拖拽引起的合并单元格的变动
*/
dragCol(x2, y2) {
let cell = this.dragCell;
let table2 = this;
if (cell.col >= table2.cols.length - 1) {
return;
}
for (let i2 = 0; i2 < table2.cols.length; i2++) {
if (table2.rows[cell.row][i2].specilRow) {
this.specilDrag = true;
for (let j2 = 0; j2 < table2.cols.length; j2++) {
if (!table2.rows[cell.row][j2].specilRow) {
table2.rows[cell.row][j2].specilRow = true;
}
}
break;
}
}
let dragObj = table2.stage.render.dragObj;
let changeWidth = x2 - dragObj.x;
dragObj.x = dragObj.x + changeWidth;
if (changeWidth != 0) {
if (this.specilDrag) {
let pass = false;
for (let i2 = 0; i2 < table2.cols.length; i2++) {
if (table2.rows[cell.row][i2].isMergedCell() || table2.rows[cell.row][i2].isMergeCell()) {
pass = true;
break;
}
}
if (cell.width != 0 && cell.width + changeWidth < 5 || table2.rows[cell.row][cell.col + 1].width != 0 && table2.rows[cell.row][cell.col + 1].width - changeWidth < 5) {
pass = true;
}
if (!pass) {
cell.setSize(cell.width + changeWidth);
table2.rows[cell.row][cell.col + 1].setSize(table2.rows[cell.row][cell.col + 1].width - changeWidth);
table2.rows[cell.row][cell.col + 1].setPosition(table2.rows[cell.row][cell.col + 1].x + changeWidth);
for (let i2 = 0; i2 < table2.cols.length; i2++) {
table2.rows[cell.row][i2].specilRow = true;
}
return;
}
}
for (let i2 = 0; i2 < table2.rows.length; i2++) {
let beforeCell = table2.rows[i2][cell.col];
let afterCell = table2.rows[i2][cell.col + 1];
if (!beforeCell.specilRow && (beforeCell.width != 0 && beforeCell.width + changeWidth < 5 || beforeCell.originWidth != null && beforeCell.originWidth + changeWidth < 5)) {
return;
}
if (!afterCell.specilRow && (afterCell.width != 0 && afterCell.width - changeWidth < 5 || afterCell.originWidth != null && afterCell.originWidth - changeWidth < 5)) {
return;
}
}
let processedCells = [];
for (let i2 = 0; i2 < table2.rows.length; i2++) {
let beforeCell = table2.rows[i2][cell.col];
if (processedCells.indexOf(beforeCell) == -1 && !beforeCell.specilRow) {
if (!beforeCell.isMergedCell() && !beforeCell.isMergeCell()) {
beforeCell.setSize(beforeCell.width + changeWidth);
processedCells[processedCells.length] = beforeCell;
} else if (beforeCell.isMergeCell()) {
let mCell = beforeCell;
if (mCell.mergeColNum == 1) {
beforeCell.originWidth = beforeCell.originWidth + changeWidth;
beforeCell.setSize(beforeCell.width + changeWidth);
processedCells[processedCells.length] = beforeCell;
} else {
beforeCell.originWidth = beforeCell.originWidth + changeWidth;
processedCells[processedCells.length] = beforeCell;
}
} else if (beforeCell.isMergedCell()) {
let mCell = beforeCell.mergedCell;
if (mCell.col + mCell.mergeColNum - 1 == beforeCell.col) {
beforeCell.originWidth = beforeCell.originWidth + changeWidth;
if (processedCells.indexOf(mCell) == -1) {
processedCells[processedCells.length] = mCell;
mCell.setSize(mCell.width + changeWidth);
}
processedCells[processedCells.length] = beforeCell;
} else {
beforeCell.originWidth = beforeCell.originWidth + changeWidth;
processedCells[processedCells.length] = beforeCell;
}
}
}
let afterCell = table2.rows[i2][cell.col + 1];
if (processedCells.indexOf(afterCell) == -1 && !afterCell.specilRow) {
if (!afterCell.isMergedCell() && !afterCell.isMergeCell()) {
afterCell.setSize(afterCell.width - changeWidth);
afterCell.setPosition(afterCell.x + changeWidth);
processedCells[processedCells.length] = afterCell;
} else if (afterCell.isMergeCell()) {
let mCell = afterCell;
mCell.originWidth = mCell.originWidth - changeWidth;
mCell.setSize(mCell.width - changeWidth);
mCell.setPosition(mCell.x + changeWidth);
processedCells[processedCells.length] = mCell;
for (let x3 = mCell.row + 1; x3 < mCell.row + mCell.mergeRowNum; x3++) {
if (!table2.rows[x3][mCell.col].specilRow) {
table2.rows[x3][mCell.col].originWidth = table2.rows[x3][mCell.col].originWidth - changeWidth;
table2.rows[x3][mCell.col].setPosition(table2.rows[x3][mCell.col].x + changeWidth);
processedCells[processedCells.length] = table2.rows[x3][mCell.col];
}
}
} else if (afterCell.isMergedCell()) {
let mCell = afterCell.mergedCell;
if (mCell.col + mCell.mergeColNum == afterCell.col) {
afterCell.originWidth = afterCell.originWidth - changeWidth;
if (processedCells.indexOf(mCell) == -1) {
mCell.setSize(mCell.width - changeWidth);
processedCells[processedCells.length] = mCell;
}
processedCells[processedCells.length] = afterCell;
} else {
afterCell.originWidth = afterCell.originWidth - changeWidth;
afterCell.setPosition(afterCell.x + changeWidth);
processedCells[processedCells.length] = afterCell;
}
}
}
}
this.updateCopyShapeArea();
this.changeChildrenBounds();
}
}
/**
* TODO 更新复制图形的区域
*/
updateCopyShapeArea() {
if (window.globalTableCopyData || window.globalTableCutData) {
let sourceCells = null;
if (window.globalTableCopyData && window.globalTableCopyData.length > 0) {
sourceCells = window.globalTableCopyData;
} else {
sourceCells = window.globalTableCutData;
}
if (sourceCells[0].table == this) {
let minMaxColRow = this.getMinMaxRowAndCol(sourceCells);
let rect = this.getCellPositionRect(minMaxColRow.minRow, minMaxColRow.minCol, minMaxColRow.maxRow, minMaxColRow.maxCol);
this.copyAreaShape.style.width = rect.width - 1 + "px";
this.copyAreaShape.style.height = rect.height - 1 + "px";
this.copyAreaShape.style.left = PDSetting.DEFAULT_TABLE_BORDER_PADDING + rect.x - 1 + "px";
this.copyAreaShape.style.top = PDSetting.DEFAULT_TABLE_BORDER_PADDING + rect.y - 1 + "px";
this.copyAreaShape.style.display = "block";
}
}
}
/**
* 变换向量
*/
transVectors(matrix2, params) {
super.transVectors(matrix2);
for (let i2 = 0; i2 < this.rows.length; i2++) {
let rowObj = this.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cellObj = rowObj[j2];
cellObj.transVectors(matrix2);
}
}
}
// ============================ 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static loadFromJSON(json, tempData = {}) {
let model = new _DDeiTable2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
if (!model.pModel) {
model.pModel = model.layer;
}
tempData[model.id] = model;
let rows = [];
let cols = [];
for (let i2 = 0; i2 < json.rows.length; i2++) {
let rowJSON = json.rows[i2];
rows[i2] = [];
for (let j2 = 0; j2 < rowJSON.length; j2++) {
if (i2 == 0) {
cols[j2] = [];
}
let cell = DDeiTableCell.loadFromJSON(rowJSON[j2], tempData);
cell.table = model;
rows[i2][j2] = cell;
cols[j2][i2] = cell;
}
}
for (let i2 = 0; i2 < rows.length; i2++) {
for (let j2 = 0; j2 < cols.length; j2++) {
let cellJSON = json.rows[i2][j2];
if (cellJSON.mergeRowNum > 1 || cellJSON.mergeColNum > 1) {
let mergedCell = rows[i2][j2];
for (let mr = 0; mr < cellJSON.mergeRowNum; mr++) {
for (let mj = 0; mj < cellJSON.mergeColNum; mj++) {
let mergeCell = rows[i2 + mr][j2 + mj];
mergeCell.mergedCell = mergedCell;
}
}
}
}
}
model.rows = rows;
model.cols = cols;
model.initPVS();
model.initRender();
return model;
}
// 通过JSON初始化对象,数据未传入时将初始化数据
static initByJSON(json, tempData = {}) {
let model = new _DDeiTable2(json);
model.layer = tempData["currentLayer"];
model.stage = tempData["currentStage"];
model.pModel = tempData["currentContainer"];
model.initPVS();
model.initTable();
return model;
}
};
__publicField2(_DDeiTable, "ClsName", "DDeiTable");
__publicField2(_DDeiTable, "initSubControlJson", null);
let DDeiTable = _DDeiTable;
const __vite_glob_0_14$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiTable,
default: DDeiTable
}, Symbol.toStringTag, { value: "Module" }));
class DDeiAbstractShapeRender {
constructor(props) {
__publicField2(this, "model");
__publicField2(this, "stage");
__publicField2(this, "layer");
__publicField2(this, "ddRender");
__publicField2(this, "stageRender");
__publicField2(this, "layerRender");
__publicField2(this, "renderCacheData", /* @__PURE__ */ new Map());
__publicField2(this, "refreshShape", true);
this.model = props.model;
this.ddRender = null;
}
enableRefreshShape() {
var _a3, _b2;
this.refreshShape = true;
(_a3 = this.model.composes) == null ? void 0 : _a3.forEach((comp) => {
var _a22;
(_a22 = comp.render) == null ? void 0 : _a22.enableRefreshShape();
});
(_b2 = this.model.linkModels) == null ? void 0 : _b2.forEach((lm) => {
var _a22;
if (lm.dm) {
(_a22 = lm.dm.render) == null ? void 0 : _a22.enableRefreshShape();
}
});
}
/**
* 获取html
*/
getHTML() {
return null;
}
/**
* 获取缓存的渲染数据
*/
getCachedValue(attrPath) {
let returnValue = null;
if (!this.renderCacheData.has(attrPath)) {
returnValue = DDeiModelArrtibuteValue.getAttrValueByState(this.model, attrPath, true);
this.setCachedValue(attrPath, returnValue);
} else {
returnValue = this.renderCacheData.get(attrPath);
}
return returnValue;
}
/**
* 设置渲染缓存数据
*/
setCachedValue(attrPath, value) {
if (attrPath) {
if (Array.isArray(attrPath)) {
attrPath.forEach((item) => {
this.renderCacheData.set(item, value);
this.changeComposesCacheValue(item, value);
});
} else {
this.renderCacheData.set(attrPath, value);
this.changeComposesCacheValue(attrPath, value);
}
}
}
clearCachedValue() {
this.renderCacheData.clear();
this.enableRefreshShape();
this.clearComposesCacheValue();
}
clearComposesCacheValue() {
var _a3, _b2, _c2;
let define2 = (_a3 = DDeiUtil$1.getControlDefine(this.model)) == null ? void 0 : _a3.define;
if (((_b2 = define2 == null ? void 0 : define2.composes) == null ? void 0 : _b2.length) > 0) {
for (let i2 = 0; i2 < define2.composes.length; i2++) {
let comDef = define2.composes[i2];
let comModel = this.model.composes[i2];
if (((_c2 = comDef.attrLinks) == null ? void 0 : _c2.length) > 0) {
comDef.attrLinks.forEach((attrLink) => {
attrLink.mapping.forEach((mp) => {
var _a22, _b22;
if (mp == "*") {
(_a22 = comModel.render) == null ? void 0 : _a22.clearCachedValue();
} else {
(_b22 = comModel.render) == null ? void 0 : _b22.clearCachedValue();
}
});
});
}
}
}
}
changeComposesCacheValue(attrPath, value) {
var _a3, _b2, _c2;
let define2 = (_a3 = DDeiUtil$1.getControlDefine(this.model)) == null ? void 0 : _a3.define;
if (((_b2 = define2 == null ? void 0 : define2.composes) == null ? void 0 : _b2.length) > 0) {
for (let i2 = 0; i2 < define2.composes.length; i2++) {
let comDef = define2.composes[i2];
let comModel = this.model.composes[i2];
if (((_c2 = comDef.attrLinks) == null ? void 0 : _c2.length) > 0) {
comDef.attrLinks.forEach((attrLink) => {
var _a22;
if (attrPath.startsWith(attrLink.code) && ((_a22 = attrLink.mapping) == null ? void 0 : _a22.length) > 0) {
attrLink.mapping.forEach((mp) => {
if (mp == "*") {
comModel.render.setCachedValue(attrPath, value);
} else {
comModel.render.setCachedValue(mp, value);
}
});
}
});
}
}
}
}
// ============================== 事件 ===============================
/**
* 拖拽本控件结束
* @param evt
*/
controlDragEnd(evt) {
}
/**
* 鼠标按下事件
*/
mouseDown(evt) {
}
/**
* 绘制图形
*/
mouseUp(evt) {
this.controlSelect();
}
/**
* 选中
*/
controlSelect(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i;
let pContainerModel = this.model.pModel;
let pushMulits = [];
this.stageRender.currentOperateContainer = pContainerModel;
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_SELECT_BEFORE", DDeiEnumOperateType.SELECT, { models: [this.model] }, (_a3 = this.stage) == null ? void 0 : _a3.ddInstance, evt);
if (rsState == 0 || rsState == 1) {
let isCtrl = DDei.KEY_DOWN_STATE.get("ctrl");
if (isCtrl) {
if (((_b2 = this.stageRender.currentOperateShape) == null ? void 0 : _b2.state) == DDeiEnumControlState.SELECTED) {
pushMulits.push({ actionType: DDeiEnumBusCommandType.ModelChangeSelect, data: [{ id: this.model.id, value: DDeiEnumControlState.DEFAULT }] });
} else {
pushMulits.push({ actionType: DDeiEnumBusCommandType.ModelChangeSelect, data: [{ id: this.model.id, value: DDeiEnumControlState.SELECTED }] });
}
} else {
pushMulits.push({ actionType: DDeiEnumBusCommandType.CancelCurLevelSelectedModels, data: { ignoreModels: [this.model] } });
pushMulits.push({ actionType: DDeiEnumBusCommandType.ModelChangeSelect, data: [{ id: this.model.id, value: DDeiEnumControlState.SELECTED }] });
}
this.model.layer.render.enableRefreshShape();
pushMulits.push({ actionType: DDeiEnumBusCommandType.StageChangeSelectModels });
(_e2 = (_d2 = (_c2 = this.stage) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.bus) == null ? void 0 : _e2.pushMulit(pushMulits, evt);
(_h = (_g = (_f = this.stage) == null ? void 0 : _f.ddInstance) == null ? void 0 : _g.bus) == null ? void 0 : _h.executeAll();
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_SELECT_AFTER", DDeiEnumOperateType.SELECT, { models: [this.model] }, (_i = this.stage) == null ? void 0 : _i.ddInstance, evt);
}
return true;
}
/**
* 鼠标移动
*/
mouseMove(evt) {
var _a3, _b2, _c2;
if (this.layer) {
this.stage.ddInstance.bus.insert(DDeiEnumBusCommandType.ChangeCursor, { cursor: "all-scroll" }, evt, 0);
let modeName = DDeiUtil$1.getConfigValue("MODE_NAME", (_a3 = this.ddRender) == null ? void 0 : _a3.model);
let accessLink = DDeiUtil$1.isAccess(
DDeiEnumOperateType.LINK,
[this.model],
null,
modeName,
(_b2 = this.ddRender) == null ? void 0 : _b2.model
);
if (accessLink) {
let stageRatio2 = (_c2 = this.stage) == null ? void 0 : _c2.getStageRatio();
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= this.stage.wpv.x;
ey -= this.stage.wpv.y;
ex /= stageRatio2;
ey /= stageRatio2;
this.changeOpPoints(ex, ey);
}
}
}
changeOpPoints(ex, ey, pointMode = null) {
var _a3;
let appendPoints = [];
let hasPoint = false;
let projPoint;
if (((_a3 = this.stageRender) == null ? void 0 : _a3.operateState) == DDeiEnumOperateState.LINE_POINT_CHANGING) {
projPoint = this.model.getProjPoint({ x: ex, y: ey }, { in: -8, out: 15 });
} else {
let modelWeight = Math.min(this.model.width, this.model.height);
let inWeight = -8;
if (modelWeight <= 24) {
inWeight = 0;
}
projPoint = this.model.getProjPoint({ x: ex, y: ey }, { in: inWeight, out: 15 });
}
let pots = [];
if (projPoint) {
projPoint.model = this.model;
projPoint.mode = pointMode;
hasPoint = true;
pots.push(projPoint);
}
let centerOpPoints = this.model.getCenterOpPoints();
centerOpPoints.forEach((op) => {
op.model = this.model;
op.mode = 3;
if (op.oppoint == 1 || op.oppoint == 3) {
let dist = DDeiUtil$1.getPointDistance(op.x, op.y, ex, ey);
if (Math.abs(dist) <= 5) {
op.isMiddle = true;
this.stage.tempCursorOPpoint = op;
delete op.mode;
hasPoint = true;
}
}
if (op.oppoint == 3) {
let rotate2 = this.model.rotate;
if (!rotate2) {
rotate2 = 0;
}
let bpv2 = DDeiUtil$1.pointsToZero([this.model.bpv], this.model.cpv, rotate2)[0];
let scaleX2 = Math.abs(bpv2.x / 100);
let scaleY2 = Math.abs(bpv2.y / 100);
let dist1 = DDeiUtil$1.getPointDistance(0, 0, (ex - op.x) / scaleX2, (ey - op.y) / scaleY2);
if (Math.abs(op.r - dist1) <= 5) {
let dr = op.r - dist1;
let rotate22 = DDeiUtil$1.getLineAngle(op.x, op.y, ex, ey);
let dx = dr * Math.cos(rotate22 * DDeiConfig$1.ROTATE_UNIT);
let dy = dr * Math.sin(rotate22 * DDeiConfig$1.ROTATE_UNIT);
let op1 = new Vector3(ex + dx, ey + dy, 1);
op1.model = this.model;
op1.oppoint = op.oppoint;
pots.push(op1);
hasPoint = true;
}
} else {
let angle2 = DDeiUtil$1.getLineAngle(this.model.cpv.x, this.model.cpv.y, op.x, op.y);
angle2 -= this.model.rotate ? this.model.rotate : 0;
op.sita = angle2;
appendPoints.push(op);
}
});
pots.forEach((po) => {
let insert = true;
for (let i2 = 0; i2 < centerOpPoints.length; i2++) {
let co = centerOpPoints[i2];
if (co.isMiddle) {
let dist = DDeiUtil$1.getPointDistance(po.x, po.y, co.x, co.y);
if (Math.abs(dist) <= 5) {
insert = false;
}
}
}
if (insert) {
let angle2 = DDeiUtil$1.getLineAngle(this.model.cpv.x, this.model.cpv.y, po.x, po.y);
angle2 -= this.model.rotate ? this.model.rotate : 0;
po.sita = angle2;
this.stage.tempCursorOPpoint = po;
appendPoints.push(po);
}
});
if (appendPoints.length > 0) {
appendPoints.forEach((po) => {
this.layer.opPoints.push(po);
});
this.layer.opPoints.push({ isSplit: 1 });
}
if (hasPoint) {
this.stage.ddInstance.bus.insert(DDeiEnumBusCommandType.ChangeCursor, { cursor: "pointer" }, null, 1);
}
}
//数据
refreshView(editor, vNode, tempShape, composeRender) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L, _M;
let shapeElement = vNode.el;
let model = this.model;
let stage2 = model.stage;
let ddInstance = stage2.ddInstance;
let render = model.render;
let ruleWeight = 0;
if (stage2.render.tempRuleDisplay == 1 || stage2.render.tempRuleDisplay == "1") {
ruleWeight = 15;
}
let stageRatio2 = model.getStageRatio();
let rat1 = window.remRatio;
if (DDeiUtil$1.isModelHidden(model)) {
shapeElement.style.display = "none";
} else {
shapeElement.style.width = model.width * rat1 + "px";
shapeElement.style.height = model.height * rat1 + "px";
let transform = "";
if (stageRatio2 > 0 && stageRatio2 != 1) {
transform += " scale(" + stageRatio2 + ")";
}
if (model.rotate) {
transform += " rotate(" + model.rotate + "deg)";
}
if (this.model.mirrorX) {
transform += " rotateY(180deg)";
}
if (this.model.mirrorY) {
transform += " rotateX(180deg)";
}
shapeElement.style.transform = transform;
let type = ((_a3 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _a3.type) || ((_b2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _b2.type) == 0 ? (_c2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _c2.type : render.getCachedValue("border.type");
let opacity = ((_d2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _d2.opacity) || ((_e2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _e2.opacity) == 0 ? (_f = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _f.opacity : render.getCachedValue("border.opacity");
let width = ((_g = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _g.width) || ((_h = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _h.width) == 0 ? (_i = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _i.width : render.getCachedValue("border.width");
let dash = ((_j = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _j.dash) || ((_k = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _k.dash) == 0 ? (_l = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _l.dash : render.getCachedValue("border.dash");
let color = ((_m = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _m.color) || ((_n = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _n.color) == 0 ? (_o = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _o.color : render.getCachedValue("border.color");
let drawLine = (type == 1 || type == "1") && width > 0;
if (drawLine) {
let type2 = !dash || dash.length == 0 ? "solid" : "dashed";
if (!color) {
color = "var(--border)";
}
if (opacity >= 0 && opacity < 1) {
let value16 = parseInt(opacity * 255);
color += value16.toString(16);
}
shapeElement.style.setProperty("--borderColor", color);
shapeElement.style.setProperty("--borderType", type2);
shapeElement.style.setProperty("--borderWidth", width + "px");
}
shapeElement.style.left = model.cpv.x * stageRatio2 + stage2.wpv.x - (shapeElement.offsetWidth ? shapeElement.offsetWidth : model.width * rat1) / 2 - ruleWeight + "px";
shapeElement.style.top = model.cpv.y * stageRatio2 + stage2.wpv.y - (shapeElement.offsetHeight ? shapeElement.offsetHeight : model.height * rat1) / 2 - ruleWeight + "px";
let fillColor = ((_p = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _p.color) ? tempShape.fill.color : render.getCachedValue("fill.color");
if (!fillColor) {
fillColor = DDeiUtil$1.getStyleValue("canvas-control-background", ddInstance);
}
let fillOpacity = ((_q = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _q.opacity) ? tempShape.fill.opacity : render.getCachedValue("fill.opacity");
let fillType = ((_r = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _r.type) ? tempShape.fill.type : render.getCachedValue("fill.type");
if (fillType == 1) {
if (fillOpacity >= 0 && fillOpacity < 1) {
let value16 = parseInt(fillOpacity * 255);
fillColor += value16.toString(16);
}
shapeElement.style.setProperty("--fillColor", fillColor);
}
let round = ((_s = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _s.round) ? (_t = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _t.round : render.getCachedValue("border.round");
if (round) {
shapeElement.style.setProperty("--borderRound", round + "px");
}
let fiFamily = ((_u = tempShape == null ? void 0 : tempShape.font) == null ? void 0 : _u.family) ? (_v = tempShape == null ? void 0 : tempShape.font) == null ? void 0 : _v.family : render.getCachedValue("font.family");
let fiSize = ((_w = tempShape == null ? void 0 : tempShape.font) == null ? void 0 : _w.size) ? (_x = tempShape == null ? void 0 : tempShape.font) == null ? void 0 : _x.size : render.getCachedValue("font.size");
let fiColor = ((_y = tempShape == null ? void 0 : tempShape.font) == null ? void 0 : _y.color) ? (_z = tempShape == null ? void 0 : tempShape.font) == null ? void 0 : _z.color : render.getCachedValue("font.color");
if (!fiColor) {
fiColor = DDeiUtil$1.getStyleValue("canvas-control-title", ddInstance);
}
if (fiFamily) {
shapeElement.style.setProperty("--fontFamily", fiFamily);
}
if (fiSize) {
shapeElement.style.setProperty("--fontSize", fiSize + "px");
}
if (fiColor) {
shapeElement.style.setProperty("--fontColor", fiColor);
}
let bold = ((_A = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _A.bold) ? (_B = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _B.bold : render.getCachedValue("textStyle.bold");
if (bold == 1 || bold == "1") {
shapeElement.style.setProperty("--fontWeight", "bold");
}
let italic = ((_C = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _C.italic) ? (_D = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _D.italic : render.getCachedValue("textStyle.italic");
if (italic == 1 || italic == "1") {
shapeElement.style.setProperty("--fontStyle", "italic");
}
let underline = ((_E = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _E.underline) ? (_F = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _F.underline : render.getCachedValue("textStyle.underline");
if (underline == "1" || underline == 1) {
shapeElement.style.setProperty("--textDecoration", "underline");
} else {
let deleteline = ((_G = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _G.deleteline) ? (_H = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _H.deleteline : render.getCachedValue("textStyle.deleteline");
if (deleteline == "1" || deleteline == 1) {
shapeElement.style.setProperty("--textDecoration", "line-through");
} else {
let overline = ((_I = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _I.topline) ? (_J = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _J.topline : render.getCachedValue("textStyle.topline");
if (overline == "1" || overline == 1) {
shapeElement.style.setProperty("--textDecoration", "overline");
}
}
}
let textBgColor = ((_K = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _K.bgcolor) ? (_L = tempShape == null ? void 0 : tempShape.textStyle) == null ? void 0 : _L.bgcolor : render.getCachedValue("textStyle.bgcolor");
if (textBgColor) {
shapeElement.style.setProperty("--textBgColor", textBgColor);
}
shapeElement.style.zIndex = model.render.tempZIndex;
shapeElement.style.display = "block";
if (model.baseModelType == "DDeiContainer") {
for (let m = 0; m < ((_M = model.midList) == null ? void 0 : _M.length); m++) {
let key = model.midList[m];
let item = model.models.get(key);
if (item == null ? void 0 : item.render) {
item.render.tempZIndex = model.render.tempZIndex + (m + 1);
item.render.drawShape(tempShape, composeRender);
}
}
}
if (vNode.component.ctx.refreshView) {
vNode.component.ctx.refreshView(model, vNode, tempShape, composeRender);
}
}
}
removeViewerCanvas() {
var _a3, _b2;
if (!this.viewer) {
(_a3 = this.tempCanvas) == null ? void 0 : _a3.remove();
(_b2 = this.model.composes) == null ? void 0 : _b2.forEach((comp) => {
comp.render.removeViewerCanvas();
});
} else {
DDeiUtil$1.createRenderViewer(this.model, "VIEW-HIDDEN");
}
}
}
const __vite_glob_1_9 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiAbstractShapeRender,
default: DDeiAbstractShapeRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiRectangleCanvasRender = class _DDeiRectangleCanvasRender2 extends DDeiAbstractShapeRender {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "textUsedArea", []);
__publicField2(this, "clip", true);
}
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiRectangleCanvasRender2(props);
}
// ============================== 方法 ===============================
/**
* 初始化
*/
init() {
this.ddRender = this.model.stage.ddInstance.render;
this.stage = this.model.stage;
this.stageRender = this.model.stage.render;
if (this.model.layer) {
this.layer = this.model.layer;
this.layerRender = this.model.layer.render;
}
}
initImage() {
let that = this;
let bgImage = DDeiUtil$1.getReplacibleValue(this.model, "fill.image");
if ((this.model.bgImageBase64 || bgImage) && !this.imgObj) {
let img = new Image();
img.onload = function() {
that.imgObj = img;
that.upFillImage = bgImage;
that.ddRender.model.bus.push(DDeiEnumBusCommandType.RefreshShape, null, null);
that.ddRender.model.bus.executeAll();
};
img.src = this.model.bgImageBase64 ? this.model.bgImageBase64 : bgImage;
}
}
/**
* 创建图形
*/
drawShape(tempShape) {
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_BEFORE", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
if (rsState == 0 || rsState == 1) {
let rsState1 = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", DDeiEnumOperateType.VIEW, { models: [this.model], tempShape }, this.ddRender.model, null);
if (rsState1 == 0 || rsState1 == 1) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
ctx.save();
this.drawBorder(tempShape);
this.drawFill(tempShape);
this.drawText(tempShape);
this.tempFillAreaRect = null;
ctx.restore();
}
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_AFTER", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
}
}
/**
* 生成边框的区域向量
*/
getBorderPVS(tempBorder) {
let topRound = this.getBorderInfo(tempBorder, 1, "round");
let topType = this.getBorderInfo(tempBorder, 1, "type");
let topWidth = this.getBorderInfo(tempBorder, 1, "width");
let rightType = this.getBorderInfo(tempBorder, 2, "type");
let rightWidth = this.getBorderInfo(tempBorder, 2, "width");
let bottomType = this.getBorderInfo(tempBorder, 3, "type");
let bottomWidth = this.getBorderInfo(tempBorder, 3, "width");
let leftType = this.getBorderInfo(tempBorder, 4, "type");
let leftWidth = this.getBorderInfo(tempBorder, 4, "width");
if (!topType) {
topWidth = 0;
}
if (rightType) {
rightWidth = 0;
}
if (bottomType) {
bottomWidth = 0;
}
if (leftType) {
leftWidth = 0;
}
leftWidth = leftWidth / 2;
rightWidth = rightWidth / 2;
bottomWidth = bottomWidth / 2;
topWidth = topWidth / 2;
let borderPVS = [];
let essBounds = this.model.essBounds;
borderPVS[0] = new Vector3(essBounds.x + topRound, essBounds.y + topWidth, 1);
borderPVS[4] = new Vector3(essBounds.x + leftWidth, essBounds.y + topWidth, 1);
borderPVS[1] = new Vector3(essBounds.x + essBounds.width - rightWidth, essBounds.y + topWidth, 1);
borderPVS[2] = new Vector3(essBounds.x + essBounds.width - rightWidth, essBounds.y + essBounds.height - bottomWidth, 1);
borderPVS[3] = new Vector3(essBounds.x + leftWidth, essBounds.y + essBounds.height - bottomWidth, 1);
if (this.model.rotate && this.model.rotate != 0) {
let m12 = new Matrix3();
let move1Matrix = new Matrix3(
1,
0,
-this.model.cpv.x,
0,
1,
-this.model.cpv.y,
0,
0,
1
);
m12.premultiply(move1Matrix);
let angle2 = -(this.model.rotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
let move2Matrix = new Matrix3(
1,
0,
this.model.cpv.x,
0,
1,
this.model.cpv.y,
0,
0,
1
);
m12.premultiply(move2Matrix);
borderPVS.forEach((fpv) => {
fpv.applyMatrix3(m12);
});
}
this.borderPVS = borderPVS;
}
/**
* 取得边框的绘制区域
*/
getBorderRatPos() {
let stageRatio2 = this.model.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
let absBounds = this.model.getAbsBounds();
return DDeiUtil$1.getRatioPosition(absBounds, ratio);
}
/**
* 获取边框信息
* @param tempBorder
*/
getBorderInfo(tempBorder, direct, path) {
let borderInfo = null;
if (tempBorder) {
try {
let returnJSON = DDeiUtil$1.getDataByPath(tempBorder, path.split("."));
borderInfo = returnJSON.data;
} catch (e) {
}
} else {
let attrpath = null;
if (direct == 1) {
attrpath = "border.top." + path;
} else if (direct == 2) {
attrpath = "border.right." + path;
} else if (direct == 3) {
attrpath = "border.bottom." + path;
} else if (direct == 4) {
attrpath = "border.left." + path;
}
borderInfo = this.getCachedValue(attrpath);
}
return borderInfo;
}
/**
* 绘制边框
* @param tempBorder 临时边框,优先级最高
* @param usePV 是否采用向量输出
*/
drawBorder(tempBorder) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let rat1 = this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
rat1 = ratio;
let type = this.getBorderInfo(tempBorder, 1, "type");
let color = this.getBorderInfo(tempBorder, 1, "color");
let opacity = this.getBorderInfo(tempBorder, 1, "opacity");
let width = this.getBorderInfo(tempBorder, 1, "width");
let dash = this.getBorderInfo(tempBorder, 1, "dash");
let round = this.getBorderInfo(null, 1, "round");
if (!(type == 0 || type == "0") && color && (!opacity || opacity > 0) && width > 0) {
let lineOffset = 1 * ratio / 2;
let lineWidth = width * ratio;
ctx.lineWidth = lineWidth;
ctx.beginPath();
if (dash) {
ctx.setLineDash(dash);
}
if (opacity != null && opacity != void 0) {
ctx.globalAlpha = opacity;
}
ctx.strokeStyle = DDeiUtil$1.getColor(color);
this.getBorderPVS(tempBorder);
let pvs2 = this.borderPVS;
if ((pvs2 == null ? void 0 : pvs2.length) > 0) {
lineOffset = 0;
ctx.moveTo(pvs2[0].x * rat1 + lineOffset, pvs2[0].y * rat1 + lineOffset);
ctx.arcTo(pvs2[1].x * rat1 + lineOffset, pvs2[1].y * rat1 + lineOffset, pvs2[2].x * rat1 + lineOffset, pvs2[2].y * rat1 + lineOffset, round * rat1);
ctx.arcTo(pvs2[2].x * rat1 + lineOffset, pvs2[2].y * rat1 + lineOffset, pvs2[3].x * rat1 + lineOffset, pvs2[3].y * rat1 + lineOffset, round * rat1);
ctx.arcTo(pvs2[3].x * rat1 + lineOffset, pvs2[3].y * rat1 + lineOffset, pvs2[4].x * rat1 + lineOffset, pvs2[4].y * rat1 + lineOffset, round * rat1);
ctx.arcTo(pvs2[4].x * rat1 + lineOffset, pvs2[4].y * rat1 + lineOffset, pvs2[1].x * rat1 + lineOffset, pvs2[1].y * rat1 + lineOffset, round * rat1);
}
ctx.stroke();
if (this.clip) {
ctx.clip();
}
ctx.globalAlpha = 1;
ctx.lineWidth = 1;
ctx.lineColor = "black";
ctx.setLineDash([]);
}
}
/**
* 填充图片
*/
drawImage() {
let bgImage = DDeiUtil$1.getReplacibleValue(this.model, "fill.image");
if (!this.imgObj || bgImage != this.upFillImage) {
this.initImage();
} else {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let rat1 = this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
let fillRect = this.tempFillAreaRect;
ctx.save();
let imgFillInfo = this.getCachedValue("fill.opacity");
if (imgFillInfo) {
ctx.globalAlpha = imgFillInfo;
}
let lineOffset = 1 * ratio / 2;
ctx.translate(this.model.cpv.x * rat1, this.model.cpv.y * rat1);
ctx.rotate(this.model.rotate * DDeiConfig$1.ROTATE_UNIT);
ctx.translate(-this.model.cpv.x * rat1, -this.model.cpv.y * rat1);
ctx.drawImage(this.imgObj, (this.model.cpv.x - fillRect.width / 2) * rat1 + lineOffset, (this.model.cpv.y - fillRect.height / 2) * rat1 + lineOffset, fillRect.width * rat1, fillRect.height * rat1);
ctx.restore();
}
}
/**
* 绘制填充
*/
drawFill(tempShape) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let fillPVS = this.getFillAreaPVS();
let rat1 = this.ddRender.ratio;
ctx.save();
let fillType = ((_a3 = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _a3.type) ? (_b2 = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _b2.type : this.getCachedValue("fill.type");
if (this.isEditoring) {
if (!fillType || fillType == "0") {
fillType = 1;
}
}
if (fillType == 1) {
let fillColor = ((_c2 = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _c2.color) ? (_d2 = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _d2.color : this.getCachedValue("fill.color");
let fillOpacity = ((_e2 = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _e2.opacity) ? (_f = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _f.opacity : this.getCachedValue("fill.opacity");
let fillType2 = ((_g = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _g.type) ? (_h = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _h.type : this.getCachedValue("fill.type");
if (this.isEditoring) {
fillType2 = 0;
fillOpacity = 1;
}
if (!fillType2 && fillColor && (!fillOpacity || fillOpacity > 0)) {
ctx.fillStyle = DDeiUtil$1.getColor(fillColor);
if (fillOpacity != null && !fillOpacity != void 0) {
ctx.globalAlpha = fillOpacity;
}
ctx.beginPath();
for (let i2 = 0; i2 < fillPVS.length; i2++) {
if (i2 == fillPVS.length - 1) {
ctx.lineTo(fillPVS[i2].x * rat1, fillPVS[i2].y * rat1);
ctx.lineTo(fillPVS[0].x * rat1, fillPVS[0].y * rat1);
} else if (i2 == 0) {
ctx.moveTo(fillPVS[i2].x * rat1, fillPVS[i2].y * rat1);
} else {
ctx.lineTo(fillPVS[i2].x * rat1, fillPVS[i2].y * rat1);
}
}
ctx.closePath();
ctx.fill();
}
} else if (fillType == 2) {
this.drawImage();
}
ctx.restore();
}
/**
* 绘制文本
*/
drawText() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L;
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let rat1 = this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
let fillRect = this.tempFillAreaRect;
let ratPos = DDeiUtil$1.getRatioPosition(fillRect, rat1);
ctx.textAlign = "left";
ctx.textBaseline = "top";
let editorText = null;
if (this.isEditoring) {
editorText = DDeiUtil$1.getEditorText();
}
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
this.stageRender.editorShadowControl.tempCursorStart = curSIdx;
this.stageRender.editorShadowControl.tempCursorEnd = curEIdx;
}
let align = this.getCachedValue("textStyle.align");
let valign = this.getCachedValue("textStyle.valign");
let scale = this.getCachedValue("textStyle.scale");
let feed = this.getCachedValue("textStyle.feed");
let fiFamily = this.getCachedValue("font.family");
let fiSize = this.getCachedValue("font.size");
let fiColor = this.getCachedValue("font.color");
let hollow = this.getCachedValue("textStyle.hollow");
let bold = this.getCachedValue("textStyle.bold");
let italic = this.getCachedValue("textStyle.italic");
let underline = this.getCachedValue("textStyle.underline");
let deleteline = this.getCachedValue("textStyle.deleteline");
let topline = this.getCachedValue("textStyle.topline");
let textBgColor = this.getCachedValue("textStyle.bgcolor");
ctx.save();
ctx.translate(this.model.cpv.x * rat1, this.model.cpv.y * rat1);
ctx.rotate(this.model.rotate * DDeiConfig$1.ROTATE_UNIT);
let textContainer = [];
let loop2 = true;
let fontSize = fiSize;
let cText = null;
let sptStyle = null;
if (this.isEditoring) {
sptStyle = this.model.sptStyle;
feed = "1";
scale = "1";
cText = this.getCachedValue("text");
} else {
cText = DDeiUtil$1.getReplacibleValue(this.model, "text", true, true);
sptStyle = this.tempSptStyle ? this.tempSptStyle : this.model.sptStyle;
}
if (cText && trim(cText) != "") {
cText = "" + cText;
let contentWidth = ratPos.width;
let subtractionFontSize = 0;
while (loop2) {
let usedWidth = 0;
let usedHeight = 0;
let textRowContainer = { text: "", widths: [], heights: [] };
textContainer.push(textRowContainer);
let isOutSize = false;
let maxFontSize = 0;
if (fontSize > ratPos.height) {
if (scale == 1) {
textContainer = [];
let ds = fontSize < 50 ? 0.5 : Math.floor(fontSize / 50);
fontSize -= ds;
continue;
}
}
let baseFont = fontSize + "px " + fiFamily;
if (bold == "1") {
baseFont = "bold " + baseFont;
}
if (italic == "1") {
baseFont = "italic " + baseFont;
}
let rcIndex = 0;
let lastUnSubTypeFontSize2 = 0;
for (let ti = 0; ti < cText.length; ti++, rcIndex++) {
let te = cText[ti];
let font = null;
let fontHeight = null;
let isEnter = false;
let fontShapeRect = null;
if ((feed == 1 || feed == "1") && te == "\n") {
isEnter = true;
textRowContainer.text += te;
textRowContainer.widths[rcIndex] = 0;
textRowContainer.heights[rcIndex] = 0;
textRowContainer.width = Math.max(0, usedWidth);
textRowContainer.height = Math.max(0, textRowContainer.height ? textRowContainer.height : 0, lastUnSubTypeFontSize2 * ratio);
} else {
if (sptStyle[ti]) {
let ftsize = ((_b2 = (_a3 = sptStyle[ti]) == null ? void 0 : _a3.font) == null ? void 0 : _b2.size) ? ((_d2 = (_c2 = sptStyle[ti]) == null ? void 0 : _c2.font) == null ? void 0 : _d2.size) - subtractionFontSize : fontSize;
if ((_e2 = sptStyle[ti].textStyle) == null ? void 0 : _e2.subtype) {
if (!lastUnSubTypeFontSize2) {
lastUnSubTypeFontSize2 = ftsize;
}
ftsize = lastUnSubTypeFontSize2 / 2;
} else if (ftsize < 1) {
ftsize = 2;
}
let ftfamily = ((_g = (_f = sptStyle[ti]) == null ? void 0 : _f.font) == null ? void 0 : _g.family) ? (_i = (_h = sptStyle[ti]) == null ? void 0 : _h.font) == null ? void 0 : _i.family : fiFamily;
font = ftsize + "px " + ftfamily;
if (((_k = (_j = sptStyle[ti]) == null ? void 0 : _j.textStyle) == null ? void 0 : _k.bold) == "1") {
font = "bold " + font;
}
if (((_m = (_l = sptStyle[ti]) == null ? void 0 : _l.textStyle) == null ? void 0 : _m.italic) == "1") {
font = "italic " + font;
}
fontHeight = ftsize;
}
if (!font) {
font = baseFont;
fontHeight = fontSize;
}
if (!((_o = (_n = sptStyle[ti]) == null ? void 0 : _n.textStyle) == null ? void 0 : _o.subtype)) {
lastUnSubTypeFontSize2 = fontHeight;
}
maxFontSize = Math.max(maxFontSize, fontHeight);
let rc1 = DDeiUtil$1.measureText(te, font, ctx, fontHeight);
fontShapeRect = { width: rc1.width * ratio, height: rc1.height * ratio };
usedWidth += fontShapeRect.width;
textRowContainer.text += te;
textRowContainer.widths[rcIndex] = fontShapeRect.width;
textRowContainer.heights[rcIndex] = fontHeight * ratio;
textRowContainer.width = usedWidth;
textRowContainer.height = Math.max(fontHeight * ratio, textRowContainer.height ? textRowContainer.height : 0, lastUnSubTypeFontSize2 * ratio);
}
if (feed == 0) {
if (scale == 1 && usedWidth > contentWidth) {
isOutSize = true;
break;
} else if (usedWidth > contentWidth) {
textRowContainer.text = textRowContainer.text.substring(0, textRowContainer.text.length - 1);
usedWidth -= fontShapeRect.width;
textRowContainer.width = usedWidth;
break;
}
} else if (feed == 1 || feed == "1") {
if (isEnter) {
usedWidth = 0;
usedHeight += textRowContainer.height;
if (usedHeight + textRowContainer.height > ratPos.height) {
if (scale == 1) {
isOutSize = true;
}
break;
}
rcIndex = -1;
textRowContainer = { text: "", widths: [], heights: [] };
textRowContainer.width = usedWidth;
textRowContainer.height = 0;
textContainer.push(textRowContainer);
} else if (usedWidth > contentWidth) {
textRowContainer.text = textRowContainer.text.substring(0, textRowContainer.text.length - 1);
textRowContainer.width -= fontShapeRect.width;
textRowContainer.widths.splice(rcIndex, 1);
textRowContainer.heights.splice(rcIndex, 1);
usedWidth = fontShapeRect.width;
usedHeight += textRowContainer.height;
if (usedHeight + textRowContainer.height > ratPos.height) {
if (scale == 1) {
isOutSize = true;
}
break;
}
rcIndex = 0;
textRowContainer = { text: te, widths: [], heights: [] };
textRowContainer.widths[rcIndex] = fontShapeRect.width;
textRowContainer.heights[rcIndex] = fontHeight * ratio;
textRowContainer.width = usedWidth;
textRowContainer.height = Math.max(fontHeight * ratio, lastUnSubTypeFontSize2 * ratio);
textContainer.push(textRowContainer);
}
}
}
if (!isOutSize) {
loop2 = false;
} else {
textContainer = [];
let ds = maxFontSize < 50 ? 0.5 : Math.floor(maxFontSize / 50);
fontSize -= ds;
subtractionFontSize += ds;
}
}
let containerRect = { width: 0, height: 0 };
for (let i2 = 0; i2 < textContainer.length; i2++) {
if (i2 == 0) {
containerRect.width += textContainer[i2].width;
}
containerRect.height += textContainer[i2].height;
}
let containerWidth = containerRect.width;
let containerHeight = containerRect.height;
let x2, y2;
if (align == 1) {
x2 = 0;
} else if (align == 2) {
x2 = (ratPos.width - containerWidth) * 0.5;
} else if (align == 3) {
x2 = ratPos.width - containerWidth;
}
x2 = x2 + ratPos.x;
if (valign == 1) {
y2 = 0;
} else if (valign == 2) {
y2 = (ratPos.height - containerHeight) * 0.5;
} else if (valign == 3) {
y2 = ratPos.height - containerHeight;
}
y2 = y2 + ratPos.y;
let cursorX = -Infinity;
let cursorY = -Infinity;
let cursorHeight = 0;
let tempIdx = 0;
let usedY = 0, usedX = 0;
let lastUsedX, lastUsedY, lastWidth, lastHeight;
let lastUnSubTypeFontSize = 0;
if (textContainer.length > 0) {
textContainer[0].textPosCache = [];
}
for (let tci = 0; tci < textContainer.length; tci++) {
let rRect = textContainer[tci];
let x1, y1;
if (align == 1) {
x1 = x2;
y1 = y2 + usedY;
} else if (align == 2) {
x1 = ratPos.x + (ratPos.width - rRect.width) * 0.5;
y1 = y2 + usedY;
} else if (align == 3) {
x1 = ratPos.x + (ratPos.width - rRect.width);
y1 = y2 + usedY;
}
textContainer[tci].x = x1;
textContainer[tci].y = y1;
usedX = x1;
for (let tj = 0; tj < textContainer[tci].text.length; tj++, tempIdx++) {
let width = textContainer[tci].widths[tj];
let height = textContainer[tci].heights[tj];
lastWidth = width;
lastHeight = height;
ctx.save();
let font = fontSize * ratio + "px " + fiFamily;
if (bold == "1") {
font = "bold " + font;
}
if (italic == "1") {
font = "italic " + font;
}
let tHollow = hollow;
let tUnderline = underline;
let tDeleteline = deleteline;
let tTopline = topline;
let tFontColor = fiColor;
let tBgColor = textBgColor;
let ftsize = fontSize * ratio;
let subScriptOffY = 0;
if (sptStyle[tempIdx]) {
tBgColor = ((_p = sptStyle[tempIdx].textStyle) == null ? void 0 : _p.bgcolor) ? sptStyle[tempIdx].textStyle.bgcolor : textBgColor;
ftsize = ((_q = sptStyle[tempIdx].font) == null ? void 0 : _q.size) ? ((_r = sptStyle[tempIdx].font) == null ? void 0 : _r.size) - subtractionFontSize : fontSize;
ftsize *= ratio;
if ((_s = sptStyle[tempIdx].textStyle) == null ? void 0 : _s.subtype) {
if (!lastUnSubTypeFontSize) {
lastUnSubTypeFontSize = ftsize;
}
ftsize = lastUnSubTypeFontSize / 2;
switch ((_t = sptStyle[tempIdx].textStyle) == null ? void 0 : _t.subtype) {
case 1:
subScriptOffY = -(lastUnSubTypeFontSize - ftsize);
break;
case 2:
subScriptOffY = -(lastUnSubTypeFontSize - ftsize) / 2;
break;
}
} else if (ftsize < 1) {
ftsize = 2 * ratio;
}
let ftfamily = ((_u = sptStyle[tempIdx].font) == null ? void 0 : _u.family) ? (_v = sptStyle[tempIdx].font) == null ? void 0 : _v.family : fiFamily;
font = ftsize + "px " + ftfamily;
if (((_x = (_w = sptStyle[tempIdx]) == null ? void 0 : _w.textStyle) == null ? void 0 : _x.bold) == "1") {
font = "bold " + font;
}
if (((_z = (_y = sptStyle[tempIdx]) == null ? void 0 : _y.textStyle) == null ? void 0 : _z.italic) == "1") {
font = "italic " + font;
}
tHollow = ((_B = (_A = sptStyle[tempIdx]) == null ? void 0 : _A.textStyle) == null ? void 0 : _B.hollow) == "1" ? "1" : tHollow;
tUnderline = ((_D = (_C = sptStyle[tempIdx]) == null ? void 0 : _C.textStyle) == null ? void 0 : _D.underline) == "1" ? "1" : tUnderline;
tDeleteline = ((_F = (_E = sptStyle[tempIdx]) == null ? void 0 : _E.textStyle) == null ? void 0 : _F.deleteline) == "1" ? "1" : tDeleteline;
tTopline = ((_H = (_G = sptStyle[tempIdx]) == null ? void 0 : _G.textStyle) == null ? void 0 : _H.topline) == "1" ? "1" : tTopline;
tFontColor = ((_J = (_I = sptStyle[tempIdx]) == null ? void 0 : _I.font) == null ? void 0 : _J.color) ? sptStyle[tempIdx].font.color : tFontColor;
}
if (!((_L = (_K = sptStyle[tempIdx]) == null ? void 0 : _K.textStyle) == null ? void 0 : _L.subtype)) {
lastUnSubTypeFontSize = ftsize;
}
if (!textContainer[tci].tHollow) {
textContainer[tci].tHollow = [];
textContainer[tci].tUnderline = [];
textContainer[tci].tDeleteline = [];
textContainer[tci].tTopline = [];
textContainer[tci].tFontColor = [];
textContainer[tci].font = [];
textContainer[tci].subScriptOffY = [];
}
textContainer[tci].tHollow[tj] = tHollow;
textContainer[tci].tUnderline[tj] = tUnderline;
textContainer[tci].tDeleteline[tj] = tDeleteline;
textContainer[tci].tTopline[tj] = tTopline;
textContainer[tci].tFontColor[tj] = tFontColor;
textContainer[tci].font[tj] = font;
textContainer[tci].subScriptOffY[tj] = subScriptOffY;
let ofY = rRect.height - height + subScriptOffY;
if (tempIdx >= curSIdx && tempIdx < curEIdx) {
ctx.save();
ctx.fillStyle = "#017fff";
ctx.globalAlpha = 0.4;
ctx.fillRect(usedX - 0.5, y1 + ofY, width + 1, height);
ctx.restore();
} else if (tBgColor) {
ctx.save();
ctx.fillStyle = DDeiUtil$1.getColor(tBgColor);
ctx.fillRect(usedX - 0.5, y1 + ofY, width + 1, height);
ctx.restore();
}
if (curSIdx == curEIdx && tempIdx == curEIdx) {
cursorX = usedX;
cursorHeight = tj > 1 ? textContainer[tci].heights[tj - 1] : height;
ofY = rRect.height - cursorHeight + (tj > 1 ? textContainer[tci].subScriptOffY[tj - 1] : subScriptOffY);
cursorY = y1 + ofY;
}
ctx.fillStyle = tFontColor;
ctx.font = font;
lastUsedY = y1 + ofY;
lastUsedX = usedX;
usedX += width;
ctx.restore();
}
usedX = x1;
for (let tj = 0; tj < textContainer[tci].text.length; tj++) {
let outputText = textContainer[tci].text[tj];
let width = textContainer[tci].widths[tj];
let height = textContainer[tci].heights[tj];
ctx.save();
let tHollow = textContainer[tci].tHollow[tj];
let tUnderline = textContainer[tci].tUnderline[tj];
let tDeleteline = textContainer[tci].tDeleteline[tj];
let tTopline = textContainer[tci].tTopline[tj];
let tFontColor = textContainer[tci].tFontColor[tj];
let font = textContainer[tci].font[tj];
let subScriptOffY = textContainer[tci].subScriptOffY[tj];
let ofY = rRect.height - height + subScriptOffY;
ctx.fillStyle = tFontColor;
ctx.font = font;
if (tHollow == "1") {
ctx.strokeStyle = tFontColor;
ctx.strokeText(outputText, usedX, y1 + ofY);
} else {
ctx.fillText(outputText, usedX, y1 + ofY);
}
if (curSIdx != -1 && curEIdx != -1) {
textContainer[0].textPosCache.push({ x: usedX, y: y1 + ofY });
}
if (tUnderline == "1") {
ctx.beginPath();
ctx.strokeStyle = tFontColor;
ctx.moveTo(usedX, y1 + ofY + height);
ctx.lineTo(usedX + width, y1 + ofY + height);
ctx.closePath();
ctx.stroke();
}
if (tDeleteline == "1") {
ctx.beginPath();
ctx.strokeStyle = tFontColor;
ctx.moveTo(usedX, y1 + ofY + height / 2);
ctx.lineTo(usedX + width, y1 + ofY + height / 2);
ctx.closePath();
ctx.stroke();
}
if (tTopline == "1") {
ctx.beginPath();
ctx.strokeStyle = tFontColor;
ctx.moveTo(usedX, y1 + ofY);
ctx.lineTo(usedX + width, y1 + ofY);
ctx.closePath();
ctx.stroke();
}
usedX += width;
ctx.restore();
}
usedY += rRect.height;
}
if (cursorX != -Infinity && cursorY != -Infinity && curSIdx == curEIdx) {
ctx.strokeStyle = "black";
ctx.lineWidth = 1.5;
ctx.beginPath();
ctx.moveTo(cursorX, cursorY - 2);
ctx.lineTo(cursorX, cursorY + cursorHeight + 2);
ctx.closePath();
ctx.stroke();
} else if ((editorText == null ? void 0 : editorText.selectionEnd) == cText.length) {
ctx.strokeStyle = "black";
ctx.lineWidth = 1.5;
ctx.beginPath();
ctx.moveTo(lastUsedX + lastWidth, lastUsedY - 2);
ctx.lineTo(lastUsedX + lastWidth, lastUsedY + lastHeight + 2);
ctx.closePath();
ctx.stroke();
}
this.textUsedArea = textContainer;
}
ctx.restore();
}
/**
* 计算除边框外的填充区域,用于填充颜色和字体
*/
getFillArea() {
let type = this.getBorderInfo(null, 1, "type");
let color = this.getBorderInfo(null, 1, "color");
let opacity = this.getBorderInfo(null, 1, "opacity");
let width = this.getBorderInfo(null, 1, "width");
if (!(!(type == 0 || type == "0") && color && (!opacity || opacity > 0) && width > 0)) {
width = 0;
}
return {
x: this.model.x + width,
y: this.model.y + width,
width: this.model.width - 2 * width,
height: this.model.height - 2 * width
};
}
/**
* 计算除边框外的填充区域,用于填充颜色和字体
*/
getFillAreaPVS() {
let topDisabled = this.getCachedValue("border.top.disabled");
let topColor = this.getCachedValue("border.top.color");
let topOpac = this.getCachedValue("border.top.opacity");
let topWidth = this.getCachedValue("border.top.width");
let rightDisabled = this.getCachedValue("border.right.disabled");
let rightColor = this.getCachedValue("border.right.color");
let rightOpac = this.getCachedValue("border.right.opacity");
let rightWidth = this.getCachedValue("border.right.width");
let bottomDisabled = this.getCachedValue("border.bottom.disabled");
let bottomColor = this.getCachedValue("border.bottom.color");
let bottomOpac = this.getCachedValue("border.bottom.opacity");
let bottomWidth = this.getCachedValue("border.bottom.width");
let leftDisabled = this.getCachedValue("border.left.disabled");
let leftColor = this.getCachedValue("border.left.color");
let leftOpac = this.getCachedValue("border.left.opacity");
let leftWidth = this.getCachedValue("border.left.width");
if (!(!leftDisabled && leftColor && (!leftOpac || leftOpac > 0) && leftWidth > 0)) {
leftWidth = 0;
}
if (!(!rightDisabled && rightColor && (!rightOpac || rightOpac > 0) && rightWidth > 0)) {
rightWidth = 0;
}
if (!(!topDisabled && topColor && (!topOpac || topOpac > 0) && topWidth > 0)) {
bottomWidth = 0;
}
if (!(!bottomDisabled && bottomColor && (!bottomOpac || bottomOpac > 0) && bottomWidth > 0)) {
bottomWidth = 0;
}
topWidth = topWidth / 2;
bottomWidth = bottomWidth / 2;
leftWidth = leftWidth / 2;
rightWidth = rightWidth / 2;
let fillPVS = cloneDeep(this.model.pvs);
let move1Matrix = new Matrix3(
1,
0,
-this.model.cpv.x,
0,
1,
-this.model.cpv.y,
0,
0,
1
);
fillPVS.forEach((fpv) => {
fpv.applyMatrix3(move1Matrix);
});
if (this.model.rotate && this.model.rotate != 0) {
let angle2 = (this.model.rotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
fillPVS.forEach((fpv) => {
fpv.applyMatrix3(rotateMatrix);
});
}
fillPVS[1].x -= rightWidth;
fillPVS[0].y += topWidth;
fillPVS[2].x -= rightWidth;
fillPVS[1].y += topWidth;
fillPVS[2].y -= bottomWidth;
fillPVS[3].y -= bottomWidth;
fillPVS[0].x += leftWidth;
fillPVS[3].x += leftWidth;
this.tempFillAreaRect = { x: fillPVS[0].x, y: fillPVS[0].y, width: fillPVS[1].x - fillPVS[0].x, height: fillPVS[3].y - fillPVS[0].y };
if (this.model.rotate && this.model.rotate != 0) {
let angle2 = -(this.model.rotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
fillPVS.forEach((fpv) => {
fpv.applyMatrix3(rotateMatrix);
});
}
let move2Matrix = new Matrix3(
1,
0,
this.model.cpv.x,
0,
1,
this.model.cpv.y,
0,
0,
1
);
fillPVS.forEach((fpv) => {
fpv.applyMatrix3(move2Matrix);
});
return fillPVS;
}
// ============================== 事件 ===============================
/**
* 鼠标按下事件
*/
mouseDown(evt) {
super.mouseDown(evt);
}
/**
* 绘制图形
*/
mouseUp(evt) {
super.mouseUp(evt);
}
/**
* 鼠标移动
*/
mouseMove(evt) {
super.mouseMove(evt);
}
/**
* 鼠标双击
* @param evt
*/
dblClick(evt) {
}
};
__publicField2(_DDeiRectangleCanvasRender, "ClsName", "DDeiRectangleCanvasRender");
let DDeiRectangleCanvasRender = _DDeiRectangleCanvasRender;
const __vite_glob_1_7$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiRectangleCanvasRender,
default: DDeiRectangleCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiCircleCanvasRender = class _DDeiCircleCanvasRender2 extends DDeiRectangleCanvasRender {
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiCircleCanvasRender2(props);
}
// ============================== 方法 ===============================
/**
* 绘制边框
* @param tempBorder 临时border信息
*/
drawBorder(tempBorder) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
let ratPos = this.getBorderRatPos();
let borderType = null;
let borderColor = null;
let borderOpac = null;
let borderWidth = null;
let borderDash = null;
if (tempBorder) {
borderType = tempBorder == null ? void 0 : tempBorder.type;
borderColor = tempBorder == null ? void 0 : tempBorder.color;
borderOpac = tempBorder == null ? void 0 : tempBorder.opacity;
borderWidth = tempBorder == null ? void 0 : tempBorder.width;
borderDash = tempBorder == null ? void 0 : tempBorder.dash;
} else {
borderType = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "border.type", true);
borderColor = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "border.color", true);
borderOpac = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "border.opacity", true);
borderWidth = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "border.width", true);
borderDash = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "border.dash", true);
}
if ((borderType == 1 || borderType == "1") && borderColor && (!borderOpac || borderOpac > 0) && borderWidth > 0) {
ctx.save();
this.doRotate(ctx, ratPos);
ctx.beginPath();
ctx.lineWidth = borderWidth * ratio;
if (borderDash) {
ctx.setLineDash(borderDash);
}
if (borderOpac) {
ctx.globalAlpha = borderOpac;
}
ctx.strokeStyle = DDeiUtil$1.getColor(border.color);
ctx.ellipse(ratPos.x + ratPos.width * 0.5 + 0.5, ratPos.y + ratPos.height * 0.5 + 0.5, ratPos.width * 0.5, ratPos.height * 0.5, 0, 0, Math.PI * 2);
ctx.stroke();
ctx.restore();
}
}
/**
* 绘制填充
*/
drawFill() {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
let fillAreaE = this.getFillArea();
let ratPos = DDeiUtil$1.getRatioPosition(fillAreaE, ratio);
ctx.save();
this.doRotate(ctx, ratPos);
let fillColor = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "fill.color", true);
if (fillColor) {
ctx.fillStyle = DDeiUtil$1.getColor(fillColor);
let fillOpac = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "fill.opacity", true);
if (fillOpac) {
ctx.globalAlpha = fillOpac;
}
ctx.ellipse(ratPos.x + ratPos.width * 0.5, ratPos.y + ratPos.height * 0.5, ratPos.width * 0.5, ratPos.height * 0.5, 0, 0, Math.PI * 2);
ctx.fill();
}
ctx.restore();
}
/**
* 填充图片
*/
drawImage() {
if (this.imgObj) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
let fillAreaE = this.getFillArea();
let ratPos = DDeiUtil$1.getRatioPosition(fillAreaE, ratio);
ctx.save();
this.doRotate(ctx, ratPos);
let imgFillInfo = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "image.opacity", true);
if (imgFillInfo) {
ctx.globalAlpha = imgFillInfo;
}
ctx.ellipse(ratPos.x + ratPos.width * 0.5, ratPos.y + ratPos.height * 0.5, ratPos.width * 0.5, ratPos.height * 0.5, 0, 0, Math.PI * 2);
ctx.clip();
ctx.drawImage(this.imgObj, ratPos.x, ratPos.y, ratPos.width, ratPos.height);
ctx.restore();
}
}
/**
* 绘制文本
*/
drawText() {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
let fillAreaE = this.getFillArea();
let ratPos = DDeiUtil$1.getRatioPosition(fillAreaE, ratio);
ctx.textAlign = "left";
ctx.textBaseline = "top";
let fiFamily = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "font.family", true);
let fiSize = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "font.size", true);
let fiColor = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "font.color", true);
let align = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "textStyle.align", true);
let valign = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "textStyle.valign", true);
let scale = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "textStyle.scale", true);
let hollow = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "textStyle.hollow", true);
let feed = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "textStyle.feed", true);
if (!fiFamily) {
return;
}
if (!align) {
align = 1;
}
if (!valign) {
valign = 2;
}
if (!scale) {
scale = 0;
}
if (!hollow) {
hollow = 0;
}
if (!feed) {
feed = 0;
}
ctx.save();
this.doRotate(ctx, ratPos);
let textContainer = [];
let loop2 = true;
let fontSize = fiSize * ratio;
let cText = this.model.text;
cText = "" + cText;
let contentWidth = ratPos.width;
while (loop2) {
let usedWidth = 0;
let usedHeight = 0;
let textRowContainer = { text: "" };
textContainer.push(textRowContainer);
let isOutSize = false;
if (fontSize > ratPos.height) {
if (scale == 1) {
textContainer = [];
fontSize = fontSize - 0.5;
continue;
}
}
ctx.font = fontSize + "px " + fiFamily;
ctx.fillStyle = fiColor;
for (let ti = 0; ti < cText.length; ti++) {
let te = cText[ti];
textRowContainer.text += te;
let fontShapeRect = ctx.measureText(textRowContainer.text);
usedWidth = fontShapeRect.width;
let fontHeight = parseFloat(fontSize);
textRowContainer.width = usedWidth;
textRowContainer.height = fontHeight;
if (feed == 0) {
if (scale == 1 && usedWidth > contentWidth) {
isOutSize = true;
break;
} else if (usedWidth > contentWidth) {
textRowContainer.text = textRowContainer.text.substring(0, textRowContainer.text.length - 1);
let fontShapeRect2 = ctx.measureText(textRowContainer.text);
usedWidth = fontShapeRect2.width;
textRowContainer.width = usedWidth;
break;
}
} else if (feed == 1) {
if (usedWidth > contentWidth) {
textRowContainer.text = textRowContainer.text.substring(0, textRowContainer.text.length - 1);
let fontShapeRect2 = ctx.measureText(textRowContainer.text);
textRowContainer.width = fontShapeRect2.width;
usedWidth = 0;
usedHeight += fontHeight;
if (usedHeight + fontHeight > ratPos.height) {
if (scale == 1) {
isOutSize = true;
}
break;
}
textRowContainer = { text: te };
fontShapeRect2 = ctx.measureText(textRowContainer.text);
usedWidth = fontShapeRect2.width;
textRowContainer.width = usedWidth;
textRowContainer.height = fontHeight;
textContainer.push(textRowContainer);
}
}
}
if (!isOutSize) {
loop2 = false;
} else {
textContainer = [];
fontSize = fontSize - 0.5;
}
}
let containerRect = { width: 0, height: 0 };
for (let i2 = 0; i2 < textContainer.length; i2++) {
if (i2 == 0) {
containerRect.width += textContainer[i2].width;
}
containerRect.height += textContainer[i2].height;
}
let containerWidth = containerRect.width;
let containerHeight = containerRect.height;
let x2, y2;
if (align == 1) {
x2 = 0;
} else if (align == 2) {
x2 = (ratPos.width - containerWidth) * 0.5;
} else if (align == 3) {
x2 = ratPos.width - containerWidth;
}
x2 = x2 + ratPos.x;
if (valign == 1) {
y2 = 0;
} else if (valign == 2) {
y2 = (ratPos.height - containerHeight) * 0.5;
} else if (valign == 3) {
y2 = ratPos.height - containerHeight;
}
y2 = y2 + ratPos.y;
if (feed == 1) {
for (let tci = 0; tci < textContainer.length; tci++) {
let rRect = textContainer[tci];
if (align == 1) {
if (hollow == 1) {
ctx.strokeText(rRect.text, x2, y2 + rRect.height * tci);
} else {
ctx.fillText(rRect.text, x2, y2 + rRect.height * tci);
}
} else if (align == 2) {
if (hollow == 1) {
ctx.strokeText(rRect.text, ratPos.x + (ratPos.width - rRect.width) * 0.5, y2 + rRect.height * tci);
} else {
ctx.fillText(rRect.text, ratPos.x + (ratPos.width - rRect.width) * 0.5, y2 + rRect.height * tci);
}
} else if (align == 3) {
if (hollow == 1) {
ctx.strokeText(rRect.text, ratPos.x + (ratPos.width - rRect.width), y2 + rRect.height * tci);
} else {
ctx.fillText(rRect.text, ratPos.x + (ratPos.width - rRect.width), y2 + rRect.height * tci);
}
}
}
} else {
if (hollow == 1) {
ctx.strokeText(textContainer[0].text, x2, y2);
} else {
ctx.fillText(textContainer[0].text, x2, y2);
}
}
ctx.restore();
}
/**
* 私有函数,计算除边框外的填充区域,用于填充颜色
*/
getFillArea() {
let borderType = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "border.type", true);
let borderColor = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "border.color", true);
let borderOpac = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "border.opacity", true);
let borderWidth = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "border.width", true);
if (!((borderType == 1 || borderType == "1") && borderColor && (!borderOpac || borderOpac > 0) && borderWidth > 0)) {
borderWidth = 0;
}
let absBounds = this.model.getAbsBounds();
let fillAreaE = {
x: absBounds.x + borderWidth,
y: absBounds.y + borderWidth,
width: absBounds.width - borderWidth - borderWidth,
height: absBounds.height - borderWidth - borderWidth
};
return fillAreaE;
}
/**
* 私有函数,计算除边框外的填充区域字体
*/
getTextArea(fillArea, fInfo) {
let stageRatio2 = this.model.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
if (!fillArea) {
fillArea = this.getFillArea();
fillArea = DDeiUtil$1.getRatioPosition(fillArea, ratio);
}
if (!fInfo) {
fInfo = this.model.font && this.model.font.default ? this.model.font.default : DDeiConfig$1.CIRCLE.FONT.default;
if (this.model.state == DDeiEnumControlState.SELECTED) {
fInfo = this.model.font && this.model.font.selected ? this.model.font.selected : DDeiConfig$1.CIRCLE.FONT.selected;
}
}
fInfo.size * ratio;
fillArea.width * 0.5;
}
};
__publicField2(_DDeiCircleCanvasRender, "ClsName", "DDeiCircleCanvasRender");
let DDeiCircleCanvasRender = _DDeiCircleCanvasRender;
const __vite_glob_1_0$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiCircleCanvasRender,
default: DDeiCircleCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiCanvasRender = class _DDeiCanvasRender2 {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "model");
__publicField2(this, "canvas", null);
__publicField2(this, "tempCanvas", null);
__publicField2(this, "ratio", 1);
this.model = props.model;
}
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiCanvasRender2(props);
}
// ============================== 方法 ===============================
/**
* 初始化
*/
init() {
this.container = document.getElementById(this.model.containerid);
if (this.container) {
if (this.container.children.length > 0) {
let cvs = this.container.getElementsByTagName("canvas");
while ((cvs == null ? void 0 : cvs.length) > 0) {
cvs[0].remove();
}
}
if (this.model.width) {
this.container.style.width = this.model.width + "px";
}
if (this.model.height) {
this.container.style.height = this.model.height + "px";
}
this.realCanvas = document.createElement("canvas");
this.realCanvas.setAttribute("id", this.model.id + "_canvas");
let ctx = this.realCanvas.getContext("2d");
let ratio = Math.max(this.model.pixel, DDeiUtil$1.getPixelRatio(ctx));
this.container.appendChild(this.realCanvas);
let w = this.model.width ? this.model.width : this.container.clientWidth;
let h = this.model.height ? this.model.height : this.container.clientHeight;
this.canvas = this.realCanvas;
this.realCanvas.setAttribute("style", "pointer-events:none;z-index:100;position:absolute;-webkit-font-smoothing:antialiased;-moz-transform-origin:left top;-moz-transform:scale(" + 1 / ratio + ");display:block;zoom:" + 1 / ratio);
this.realCanvas.setAttribute("width", w * ratio);
this.realCanvas.setAttribute("height", h * ratio);
this.ratio = ratio * window.remRatio;
this.bindEvent();
} else {
throw new Error("容器" + this.model.containerid + "不存在");
}
}
// webglTest() {
// let canvas = document.createElement('canvas');
// canvas.setAttribute("width", 480)
// canvas.setAttribute("height", 240)
// canvas.setAttribute("style", "border:1px solid red;position:absolute;left:0;top:400px;")
// document.body.appendChild(canvas)
// let gl = canvas.getContext('webgl')
// gl.viewport(0, 0, 480, 240)
// //创建顶点着色器
// const vertexShader = gl.createShader(gl.VERTEX_SHADER)
// //创建片元着色器
// const fragmentShader = gl.createShader(gl.FRAGMENT_SHADER)
// //顶点着色器代码
// const vertexShaderSource = `
// attribute vec4 a_pos;
// void main() {
// gl_Position = a_pos;
// }
// `
// //片元着色器代码
// const fragmentShaderSource = `
// void main() {
// gl_FragColor = vec4(0.0,0.0,0.0,1.0);
// }
// `
// //绑定数据源
// gl.shaderSource(vertexShader, vertexShaderSource)
// gl.shaderSource(fragmentShader, fragmentShaderSource)
// // 编译着色器
// gl.compileShader(vertexShader)
// gl.compileShader(fragmentShader)
// // 创建着色器程序
// const program = gl.createProgram()
// gl.attachShader(program, vertexShader)
// gl.attachShader(program, fragmentShader)
// // 链接 并使用着色器
// gl.linkProgram(program)
// gl.useProgram(program)
// gl.program = program
// // //错误输出日志
// // const success = gl.getProgramParameter(program, gl.LINK_STATUS)
// // if (success) {
// // gl.useProgram(program)
// // return program
// // }
// // console.error(gl.getProgramInfoLog(program), 'test---')
// // gl.deleteProgram(program)
// //抗锯齿
// // gl.enable(gl.MULTISAMPLE)
// //创建顶点缓冲对象
// const buffer = gl.createBuffer()
// //把标识符buffer设置为当前缓冲区,后面的所有的数据都会都会被放入当前缓冲区,直到bindBuffer绑定另一个当前缓冲区
// gl.bindBuffer(gl.ARRAY_BUFFER, buffer)
// //构造三角形的点
// let data = new Float32Array([-0.2, 0.5,
// -0.5, -0.3,
// 0, -0.3,
// 0.29, 0.5])
// gl.bufferData(gl.ARRAY_BUFFER, data, gl?.DYNAMIC_DRAW)
// //从刚才创建的GLSL着色程序中找到这个属性值所在的位置。
// const aposlocation = gl.getAttribLocation(program, 'a_pos')
// gl.enableVertexAttribArray(aposlocation)
// //从缓冲中读取数据绑定给被激活的aposlocation的位置
// gl.vertexAttribPointer(aposlocation, 2, gl.FLOAT, false, 2 * 4, 0 * 4)
// //渲染
// //清空颜色
// gl.clearColor(1, 1, 1, 1)
// gl.clear(gl.COLOR_BUFFER_BIT)
// // gl.drawArrays(gl?.LINE_LOOP, 0, 4)
// //索引缓冲区,可以控制绘制的顺序
// let indexArr = new Uint16Array([
// 0, 1, 2,
// 0, 3, 1,
// ]);
// let indexBuffer = gl?.createBuffer()
// gl?.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, indexBuffer)
// gl?.bufferData(gl.ELEMENT_ARRAY_BUFFER, indexArr, gl.STATIC_DRAW)
// gl?.drawElements(gl.TRIANGLES, indexArr.length, gl.UNSIGNED_SHORT, 0)
// let indexArr1 = new Uint16Array([
// 1, 2, 3
// ]);
// gl?.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, indexBuffer)
// gl?.bufferData(gl.ELEMENT_ARRAY_BUFFER, indexArr1, gl.STATIC_DRAW)
// gl?.drawElements(gl.LINE_LOOP, indexArr1.length, gl.UNSIGNED_SHORT, 0)
// // data = new Float32Array([0.3, 0.5, 0.1, -0.3, 0.5, -0.3])
// // gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW)
// // gl.drawArrays(gl?.LINE_LOOP, 0, 3)
// // gl.drawArrays(gl?.TRIANGLES, 0, 3)
// }
/**
* 获取当前画布
*/
getCanvas() {
if (this.tempCanvas) {
return this.tempCanvas;
}
return this.canvas;
}
/**
* 显示
*/
show() {
document.getElementById(this.model.containerid).style.display = "block";
}
/**
* 隐藏
*/
hidden() {
document.getElementById(this.model.containerid).style.display = "none";
}
/**
* 重新设置大小
*/
setSize(width = 0, height = 0, deltaX = 0, deltaY = 0) {
if (!width || width == 0) {
width = this.container.clientWidth;
}
width += deltaX;
if (!height || height == 0) {
height = this.container.clientHeight;
}
height += deltaY;
this.realCanvas.setAttribute("width", width * this.ratio / window.remRatio);
this.realCanvas.setAttribute("height", height * this.ratio / window.remRatio);
}
/**
* 绘制图形
*/
drawShape() {
var _a3, _b2;
if (this.model.stage) {
if (((_a3 = this.model.stage.render) == null ? void 0 : _a3.refresh) || ((_b2 = this.model.stage.render) == null ? void 0 : _b2.editorShadowControl)) {
this.model.stage.render.drawShape();
this.model.stage.drawing = false;
this.model.stage.render.refresh = false;
}
} else {
throw new Error("当前实例未加载舞台模型,无法渲染图形");
}
}
// ============================== 事件 ===============================
/**
* 绑定事件
*/
bindEvent() {
this.interval = setInterval(() => {
if (this.model.render != this) {
this.destroyRender();
} else if (!this.model.disabled) {
let allowBackActive = DDeiUtil$1.isBackActive(this.model);
if (allowBackActive) {
this.mouseInEdge();
}
this.model.stage.drawing = true;
this.drawShape();
}
}, 20);
}
destroyed() {
if (this.interval) {
clearInterval(this.interval);
}
}
/**
* 鼠标在画布边缘
*/
mouseInEdge() {
var _a3, _b2;
if (this.upInEdge != this.inEdge) {
this.inEdgeTime = 0;
this.upInEdge = this.inEdge;
}
if (this.inEdge) {
this.inEdgeTime += 20;
(_b2 = (_a3 = this.model.stage) == null ? void 0 : _a3.render) == null ? void 0 : _b2.mouseInEdge(this.inEdge, this.inEdgeTime);
}
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_IN_AREA", "MOUSE_IN_AREA", { x: this.inAreaX, y: this.inAreaY, models: this.inAreaControls }, this.model, null);
}
/**
* 鼠标按下事件
*/
mouseDown(evt) {
this.model.eventCancel = false;
this.model.stage.render.mouseDown(evt);
}
/**
* 绘制图形
*/
mouseUp(evt) {
this.model.eventCancel = false;
this.model.stage.render.mouseUp(evt);
}
/**
* 鼠标移动
*/
mouseMove(evt) {
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
let sx = evt.screenX;
let sy = evt.screenY;
sx /= window.remRatio;
sy /= window.remRatio;
let stage2 = this.model.stage;
ex -= stage2.wpv.x;
ey -= stage2.wpv.y;
sx -= stage2.wpv.x;
sy -= stage2.wpv.y;
this.model.eventCancel = false;
this.model.stage.render.mouseMove(evt);
}
/**
* 鼠标滚轮或滑动事件
*/
mouseWheel(evt) {
let wheelDeltaY = evt.wheelDeltaY;
let wheelDeltaYAbs = Math.abs(wheelDeltaY);
if (wheelDeltaYAbs > 0 && wheelDeltaYAbs % 120 == 0) {
if (DDeiUtil$1.getConfigValue("GLOBAL_ALLOW_STAGE_RATIO", this.model)) {
this.mouseScale(evt.wheelDeltaY, evt);
}
} else if (evt.wheelDeltaX || evt.wheelDeltaY) {
let ctrl = DDei.KEY_DOWN_STATE.get("ctrl");
if (DDeiUtil$1.getConfigValue("GLOBAL_ALLOW_STAGE_RATIO", this.model) && ctrl && evt.wheelDeltaY) {
this.mouseScale(evt.wheelDeltaY, evt);
} else {
let dx = 0;
let dy = 0;
if (Math.abs(evt.wheelDeltaX) > Math.abs(evt.wheelDeltaY)) {
dx = evt.wheelDeltaX;
} else {
dy = evt.wheelDeltaY;
}
this.mouseWPV(dx, dy, evt);
}
}
}
/**
* 通过鼠标放大或缩小
*/
mouseScale(delta, evt) {
let stage2 = this.model.stage;
if (stage2) {
let ratio = stage2.getStageRatio();
let newValue = ratio;
let dn = 0.02 * ratio;
if (delta > 0) {
newValue = ratio + dn;
} else {
newValue = ratio - dn;
}
if (newValue < 0.1) {
newValue = 0.1;
} else if (newValue > 10) {
newValue = 10;
}
if (newValue != ratio) {
stage2.setStageRatio(newValue);
if (!this.model.ratioWatch) {
this.model.bus.push(
DDeiEnumBusCommandType.ChangeStageRatio,
{
oldValue: ratio,
newValue
},
null
);
this.model.bus.executeAll();
}
}
}
}
/**
* 通过鼠标平移窗体
*/
mouseWPV(dx, dy, evt) {
let stage2 = this.model.stage;
let rat1 = this.ratio;
let stageRatio2 = stage2.getStageRatio();
if (stage2) {
let maxMove = 75 * stageRatio2 * rat1;
dx *= stageRatio2 * rat1;
dy *= stageRatio2 * rat1;
if (dx > maxMove) {
dx = maxMove;
} else if (dx < -maxMove) {
dx = -maxMove;
}
if (dy > maxMove) {
dy = maxMove;
} else if (dy < -maxMove) {
dy = -maxMove;
}
this.model.bus.push(DDeiEnumBusCommandType.ChangeStageWPV, {
dragObj: { dx: 0, dy: 0 },
x: dx,
y: dy
});
this.model.bus.executeAll();
}
}
};
__publicField2(_DDeiCanvasRender, "ClsName", "DDeiCanvasRender");
let DDeiCanvasRender = _DDeiCanvasRender;
const __vite_glob_1_1$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: DDeiCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiDiamondCanvasRender = class _DDeiDiamondCanvasRender2 extends DDeiRectangleCanvasRender {
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiDiamondCanvasRender2(props);
}
// ============================== 方法 ===============================
/**
* 创建图形
*/
drawShape() {
this.drawBorderAndFill();
this.drawImage();
this.drawText();
}
/**
* 填充图片
*/
drawImage() {
if (this.imgObj) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = parseFloat(this.stage.ratio) ? this.stage.ratio : 1;
if (!stageRatio2 || isNaN(stageRatio2)) {
stageRatio2 = 1;
}
let ratio = this.ddRender.ratio * stageRatio2;
let fillAreaE = this.getFillArea();
let ratPos = DDeiUtil$1.getRatioPosition(fillAreaE, ratio);
ctx.save();
this.doRotate(ctx, ratPos);
let imgFillInfo = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "image.opacity", true);
if (imgFillInfo) {
ctx.globalAlpha = imgFillInfo;
}
ctx.beginPath();
ctx.moveTo(ratPos.x + ratPos.width * 0.5, ratPos.y);
ctx.lineTo(ratPos.x + ratPos.width, ratPos.y + ratPos.height * 0.5);
ctx.lineTo(ratPos.x + ratPos.width * 0.5, ratPos.y + ratPos.height);
ctx.lineTo(ratPos.x, ratPos.y + ratPos.height * 0.5);
ctx.lineTo(ratPos.x + ratPos.width * 0.5, ratPos.y);
ctx.clip();
ctx.drawImage(this.imgObj, ratPos.x, ratPos.y, ratPos.width, ratPos.height);
ctx.closePath();
ctx.restore();
}
}
/**
* 绘制边框
* @param tempBorder 临时边框,优先级最高
*/
drawBorderAndFill(tempBorder) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
let ratPos = this.getBorderRatPos();
ctx.save();
if (this.model.rotate) {
ctx.translate(ratPos.x + ratPos.width * 0.5, ratPos.y + ratPos.height * 0.5);
ctx.rotate(this.model.rotate * DDeiConfig$1.ROTATE_UNIT);
ctx.translate(-ratPos.x - ratPos.width * 0.5, -ratPos.y - ratPos.height * 0.5);
}
for (let i2 = 1; i2 <= 4; i2++) {
let disabled = this.getBorderInfo(tempBorder, i2, "disabled");
let color = this.getBorderInfo(tempBorder, i2, "color");
let opacity = this.getBorderInfo(tempBorder, i2, "opacity");
let width = this.getBorderInfo(tempBorder, i2, "width");
let dash = this.getBorderInfo(tempBorder, i2, "dash");
if (!disabled && color && (!opacity || opacity > 0) && width > 0) {
ctx.beginPath();
ctx.lineWidth = width * ratio;
if (dash) {
ctx.setLineDash(dash);
}
if (opacity != null && opacity != void 0) {
ctx.globalAlpha = opacity;
}
ctx.strokeStyle = DDeiUtil$1.getColor(color);
if (i2 == 1) {
ctx.moveTo(ratPos.x + ratPos.width * 0.5, ratPos.y);
ctx.lineTo(ratPos.x + ratPos.width, ratPos.y + ratPos.height * 0.5);
} else if (i2 == 2) {
ctx.moveTo(ratPos.x + ratPos.width, ratPos.y + ratPos.height * 0.5);
ctx.lineTo(ratPos.x + ratPos.width * 0.5, ratPos.y + ratPos.height);
} else if (i2 == 3) {
ctx.moveTo(ratPos.x + ratPos.width * 0.5, ratPos.y + ratPos.height);
ctx.lineTo(ratPos.x, ratPos.y + ratPos.height * 0.5);
} else if (i2 == 4) {
ctx.moveTo(ratPos.x, ratPos.y + ratPos.height * 0.5);
ctx.lineTo(ratPos.x + ratPos.width * 0.5, ratPos.y);
}
ctx.stroke();
ctx.closePath();
}
}
let fillColor = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "fill.color", true);
if (fillColor) {
ctx.fillStyle = DDeiUtil$1.getColor(fillColor);
let fillOpac = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "fill.opacity", true);
if (fillOpac) {
ctx.globalAlpha = fillOpac;
}
ctx.beginPath();
ctx.moveTo(ratPos.x + ratPos.width * 0.5, ratPos.y);
ctx.lineTo(ratPos.x + ratPos.width, ratPos.y + ratPos.height * 0.5);
ctx.lineTo(ratPos.x + ratPos.width * 0.5, ratPos.y + ratPos.height);
ctx.lineTo(ratPos.x, ratPos.y + ratPos.height * 0.5);
ctx.lineTo(ratPos.x + ratPos.width * 0.5, ratPos.y);
ctx.closePath();
ctx.fill();
}
ctx.restore();
}
};
__publicField2(_DDeiDiamondCanvasRender, "ClsName", "DDeiDiamondCanvasRender");
let DDeiDiamondCanvasRender = _DDeiDiamondCanvasRender;
const __vite_glob_1_2$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiDiamondCanvasRender,
default: DDeiDiamondCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiLayerCanvasRender = class _DDeiLayerCanvasRender2 {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "model");
__publicField2(this, "stage");
__publicField2(this, "ddRender");
__publicField2(this, "stageRender");
__publicField2(this, "renderCacheData", /* @__PURE__ */ new Map());
__publicField2(this, "containerViewer", null);
this.model = props.model;
this.ddRender = null;
}
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiLayerCanvasRender2(props);
}
// ============================ 方法 ===============================
/**
* 初始化
*/
init() {
this.ddRender = this.model.stage.ddInstance.render;
this.stage = this.model.stage;
this.stageRender = this.model.stage.render;
this.initContainerViewer();
}
initContainerViewer() {
var _a3;
if (!this.containerViewer) {
let editorId = DDeiUtil$1.getEditorId((_a3 = this.ddRender) == null ? void 0 : _a3.model);
this.containerViewer = document.getElementById(editorId + "_layer_" + this.model.id);
if (!this.containerViewer) {
let canvasViewerElement = this.ddRender.getCanvas().parentElement;
if (canvasViewerElement) {
let containerElement = document.createElement("div");
containerElement.setAttribute("class", "ddei-editor-canvasview-contentlayer");
containerElement.setAttribute("id", editorId + "_layer_" + this.model.id);
canvasViewerElement.insertBefore(containerElement, this.ddRender.realCanvas);
this.containerViewer = containerElement;
}
}
}
}
/**
* 清空shadowControl
*/
clearShadowControls() {
var _a3;
(_a3 = this.model.shadowControls) == null ? void 0 : _a3.forEach((c) => {
if (c.isShadowControl) {
c.destroyed();
}
});
this.model.shadowControls = [];
}
/**
* 绘制图形
*/
drawShape(inRect = true) {
var _a3, _b2, _c2;
this.initContainerViewer();
if (this.model.display || this.model.tempDisplay) {
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_BEFORE", DDeiEnumOperateType.VIEW, { models: [this.model] }, (_a3 = this.stage) == null ? void 0 : _a3.ddInstance, null);
if (rsState == 0 || rsState == 1) {
let rsState1 = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", DDeiEnumOperateType.VIEW, { models: [this.model] }, (_b2 = this.stage) == null ? void 0 : _b2.ddInstance, null);
if (rsState1 == 0 || rsState1 == 1) {
this.containerViewer.style.display = "block";
this.containerViewer.style.zIndex = this.tempZIndex;
this.drawChildrenShapes(inRect);
this.drawOpPoints();
this.drawOpLine();
this.drawDragInOutPoints();
this.drawShadowControls();
this.modelChanged = false;
}
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_AFTER", DDeiEnumOperateType.VIEW, { models: [this.model] }, (_c2 = this.stage) == null ? void 0 : _c2.ddInstance, null);
}
} else {
this.containerViewer.style.display = "none";
this.drawChildrenShapes(inRect, true);
}
}
/**
* 绘制背景
*/
drawBackground(px, py, pw, ph, isBottom) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m;
this.initContainerViewer();
if (this.containerViewer && (this.model.display || this.model.tempDisplay)) {
let ratio = this.ddRender.ratio;
if (!this.bgCanvas) {
let editorId = DDeiUtil$1.getEditorId((_a3 = this.ddRender) == null ? void 0 : _a3.model);
this.bgCanvas = document.getElementById(editorId + "_layerbg_" + this.model.id);
if (!this.bgCanvas) {
let bgCanvas = document.createElement("canvas");
bgCanvas.setAttribute("style", "z-index:0;position:absolute;-webkit-font-smoothing:antialiased;-moz-transform-origin:left top;-moz-transform:scale(" + 1 / ratio + ");display:block;zoom:" + 1 / ratio);
bgCanvas.setAttribute("id", editorId + "_layerbg_" + this.model.id);
this.containerViewer.appendChild(bgCanvas);
this.bgCanvas = bgCanvas;
}
}
this.bgCanvas.setAttribute("width", this.containerViewer.clientWidth * ratio);
this.bgCanvas.setAttribute("height", this.containerViewer.clientHeight * ratio);
let canvas = this.bgCanvas;
let ctx = canvas.getContext("2d");
let rat1 = this.ddRender.ratio;
ctx.save();
let ruleWeight = 0;
if (this.stageRender.tempRuleDisplay == 1 || this.stageRender.tempRuleDisplay == "1") {
ruleWeight = 15;
}
ctx.translate(-ruleWeight * rat1, -ruleWeight * rat1);
let bgInit;
if (((_b2 = this.ddRender) == null ? void 0 : _b2.model.background) && typeof ((_c2 = this.ddRender) == null ? void 0 : _c2.model.background) == "object") {
bgInit = (_d2 = this.ddRender) == null ? void 0 : _d2.model.background;
}
let bgInfoType = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "bg.type", true, bgInit);
let bgInfoColor;
if ((_e2 = this.model.bg) == null ? void 0 : _e2.color) {
bgInfoColor = this.model.bg.color;
} else if ((_f = this.ddRender) == null ? void 0 : _f.model.background) {
if (typeof ((_g = this.ddRender) == null ? void 0 : _g.model.background) == "string" || typeof ((_h = this.ddRender) == null ? void 0 : _h.model.background) == "number") {
if (((_i = this.ddRender) == null ? void 0 : _i.model.background) == "-1" || ((_j = this.ddRender) == null ? void 0 : _j.model.background) == -1) {
bgInfoType = -1;
} else {
bgInfoColor = (_k = this.ddRender) == null ? void 0 : _k.model.background;
if (!bgInfoType) {
bgInfoType = 1;
}
}
} else {
bgInfoColor = (_l = this.ddRender) == null ? void 0 : _l.model.background.color;
}
} else {
bgInfoColor = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "bg.color", true);
}
if (!bgInfoColor && isBottom) {
bgInfoColor = DDeiUtil$1.getStyleValue("panel-background", this.ddRender.model);
}
if (bgInfoType == 1) {
if (bgInfoColor) {
let bgInfoOpacity = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "bg.opacity", true, bgInit);
ctx.fillStyle = DDeiUtil$1.getColor(bgInfoColor);
if (bgInfoOpacity || bgInfoOpacity == 0) {
ctx.globalAlpha = bgInfoOpacity;
}
ctx.fillRect(px, py, pw, ph);
}
} else if (bgInfoType == 2) {
let bgImage = DDeiUtil$1.getReplacibleValue(this.model, "bg.image");
if (!bgImage) {
bgImage = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "bg.image", true, bgInit);
}
if (!this.bgImgObj || bgImage != this.upBgImage) {
this.initBgImage();
} else {
let bgImgMode = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "bg.imageMode", true, bgInit);
let bgInfoOpacity = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "bg.opacity", true, bgInit);
if (bgInfoOpacity || bgInfoOpacity == 0) {
ctx.globalAlpha = bgInfoOpacity;
}
let x2 = px;
let y2 = py;
let w = this.bgImgObj.width;
let h = this.bgImgObj.height;
let cwidth = pw;
let cheight = ph;
let ruleDisplay;
if ((_m = this.stage.ruler) == null ? void 0 : _m.display) {
ruleDisplay = this.stage.ruler.display;
} else if (this.stage.ddInstance.ruler != null && this.stage.ddInstance.ruler != void 0) {
if (typeof this.model.ddInstance.ruler == "boolean") {
ruleDisplay = this.stage.ddInstance.ruler ? 1 : 0;
} else {
ruleDisplay = this.stage.ddInstance.ruler.display;
}
} else {
ruleDisplay = DDeiModelArrtibuteValue.getAttrValueByState(this.stage, "ruler.display", true);
}
if (ruleDisplay == 1) {
cwidth -= 16 * rat1;
cheight -= 16 * rat1;
}
let scrollWeight = rat1 * 15;
if (this.stageRender.hScroll == 1) {
cheight -= scrollWeight;
}
if (this.stageRender.vScroll == 1) {
cwidth -= scrollWeight;
}
if (bgImgMode == 2) {
w = cwidth;
h = cheight;
} else if (bgImgMode == 1) {
let bgImageScale = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "bg.imageScale", true, bgInit);
w = w * bgImageScale;
h = h * bgImageScale;
}
if (bgImgMode != 2) {
let bgImageAlign = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "bg.imageAlign", true, bgInit);
let align = 2;
let valign = 2;
switch (bgImageAlign) {
case 1:
align = 1;
valign = 1;
break;
case 2:
align = 2;
valign = 1;
break;
case 3:
align = 3;
valign = 1;
break;
case 4:
align = 1;
valign = 2;
break;
case 5:
align = 2;
valign = 2;
break;
case 6:
align = 3;
valign = 2;
break;
case 7:
align = 1;
valign = 3;
break;
case 8:
align = 2;
valign = 3;
break;
case 9:
align = 3;
valign = 3;
break;
}
switch (align) {
case 1:
x2 = px;
break;
case 2:
x2 = px + (cwidth - w) / 2;
break;
case 3:
x2 = px + cwidth - w;
break;
}
switch (valign) {
case 1:
y2 = py;
break;
case 2:
y2 = py + (cheight - h) / 2;
break;
case 3:
y2 = py + cheight - h;
break;
}
}
ctx.drawImage(this.bgImgObj, x2, y2, w, h);
}
}
ctx.restore();
}
}
/**
* 初始化背景图片
*/
initBgImage() {
var _a3, _b2, _c2;
let that = this;
let bgImage = DDeiUtil$1.getReplacibleValue(this.model, "bg.image");
if (!bgImage) {
let bgInit;
if (((_a3 = this.ddRender) == null ? void 0 : _a3.model.background) && typeof ((_b2 = this.ddRender) == null ? void 0 : _b2.model.background) == "object") {
bgInit = (_c2 = this.ddRender) == null ? void 0 : _c2.model.background;
}
bgImage = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "bg.image", true, bgInit);
}
if (this.model.bgImageBase64 || bgImage) {
let img = new Image();
img.onload = function() {
if (!that.mark) {
that.mark = {};
}
that.upBgImage = bgImage;
that.bgImgObj = img;
that.ddRender.model.bus.push(DDeiEnumBusCommandType.RefreshShape, null, null);
that.ddRender.model.bus.executeAll();
};
img.src = this.model.bgImageBase64 ? this.model.bgImageBase64 : bgImage;
}
}
/**
* 绘制影子元素
*/
drawShadowControls() {
var _a3;
if (((_a3 = this.model.shadowControls) == null ? void 0 : _a3.length) > 0) {
this.model.shadowControls.forEach((item) => {
item.render.enableRefreshShape();
if (item.modelType == "DDeiLine") {
item.render.drawShape({ color: "#017fff", dash: [], opacity: 0.7, fill: { color: "#017fff", opacity: 0.7 } }, 0, null, 99999);
} else {
item.render.drawShape({ fill: { color: "#017fff", opacity: 0.7 } }, 0, null, 99999);
}
});
}
}
/**
* 绘制子元素
*/
drawChildrenShapes(inRect = true, hidden = false) {
var _a3;
if (this.model.models) {
let canvas = this.ddRender.getCanvas();
let rat1 = this.ddRender.ratio;
let stageRatio2 = this.model.getStageRatio();
let x2 = -this.stage.wpv.x / stageRatio2;
let y2 = -this.stage.wpv.y / stageRatio2;
let x1 = x2 + canvas.width / rat1 / stageRatio2;
let y1 = y2 + canvas.height / rat1 / stageRatio2;
if (!hidden) {
let rect = inRect ? { x: x2, y: y2, x1, y1 } : null;
for (let li = 0; li < this.model.midList.length; li++) {
let key = this.model.midList[li];
let item = this.model.models.get(key);
(_a3 = item == null ? void 0 : item.render) == null ? void 0 : _a3.drawShape(null, 0, rect, this.tempZIndex + (li + 1));
}
} else {
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", "VIEW-HIDDEN", { models: Array.from(this.model.models.values()) }, this.ddRender.model, null);
}
}
}
/**
* 绘制操作点
*/
drawOpPoints() {
var _a3, _b2, _c2, _d2;
if (((_b2 = (_a3 = this.model) == null ? void 0 : _a3.opPoints) == null ? void 0 : _b2.length) > 0) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = (_c2 = this.stage) == null ? void 0 : _c2.getStageRatio();
let rat1 = this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
ctx.save();
let firstOp2Point, beforeOp2Point;
(_d2 = this.model) == null ? void 0 : _d2.opPoints.forEach((point2) => {
if (!point2 || point2.isSplit) {
beforeOp2Point = null;
firstOp2Point = null;
} else if (point2.mode == 3) {
if (point2.oppoint == 2 || point2.oppoint == 4) {
if (!beforeOp2Point) {
beforeOp2Point = point2;
firstOp2Point = point2;
} else {
let weight = 4;
ctx.fillStyle = "white";
ctx.strokeStyle = "#017fff";
ctx.beginPath();
ctx.ellipse((point2.x + beforeOp2Point.x) / 2 * ratio, (point2.y + beforeOp2Point.y) / 2 * ratio, weight * ratio, weight * ratio, 0, 0, Math.PI * 2);
ctx.fill();
ctx.stroke();
ctx.closePath();
beforeOp2Point = point2;
if (point2.op2close == 1) {
ctx.beginPath();
ctx.ellipse((point2.x + firstOp2Point.x) / 2 * ratio, (point2.y + firstOp2Point.y) / 2 * ratio, weight * ratio, weight * ratio, 0, 0, Math.PI * 2);
ctx.fill();
ctx.stroke();
ctx.closePath();
}
}
} else {
let weight = 4;
ctx.fillStyle = "white";
ctx.strokeStyle = "#017fff";
ctx.beginPath();
ctx.ellipse(point2.x * ratio, point2.y * ratio, weight * ratio, weight * ratio, 0, 0, Math.PI * 2);
ctx.fill();
ctx.stroke();
ctx.closePath();
}
} else {
let weight = 4;
if (point2.isMiddle) {
weight = 5;
}
ctx.fillStyle = "white";
ctx.beginPath();
ctx.ellipse(point2.x * ratio, point2.y * ratio, (weight + 1) * ratio, (weight + 1) * ratio, 0, 0, Math.PI * 2);
ctx.fill();
ctx.closePath();
if (point2.mode == 1) {
ctx.fillStyle = "red";
} else {
ctx.fillStyle = "#017fff";
}
ctx.beginPath();
ctx.ellipse(point2.x * ratio, point2.y * ratio, weight * ratio, weight * ratio, 0, 0, Math.PI * 2);
ctx.fill();
ctx.closePath();
}
});
ctx.restore();
}
}
enableRefreshShape() {
}
/**
* 绘制操作线
*/
drawOpLine() {
if (this.model.opLine) {
let opLine = this.model.opLine;
let lineRender = this.model.opLine.render;
lineRender.getCachedValue("color");
let weight = lineRender.getCachedValue("weight");
lineRender.enableRefreshShape();
opLine.render.drawShape({ color: "red", opacity: 0.5, weight: weight * 1.5 }, false, null, this.model.opLine.render.tempZIndex);
opLine.render.drawOpShape();
}
}
/**
* 绘制移入移出效果图形
*/
drawDragInOutPoints() {
var _a3, _b2, _c2, _d2, _e2;
if (((_b2 = (_a3 = this.model) == null ? void 0 : _a3.dragInPoints) == null ? void 0 : _b2.length) > 0 || ((_d2 = (_c2 = this.model) == null ? void 0 : _c2.dragOutPoints) == null ? void 0 : _d2.length) > 0) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = (_e2 = this.stage) == null ? void 0 : _e2.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
ctx.save();
ctx.lineWidth = 2.5 * ratio;
ctx.setLineDash([0, 1 * ratio, 1 * ratio]);
ctx.strokeStyle = DDeiUtil$1.getColor("green");
let lineOffset = 0;
let pvs2 = this.model.dragInPoints;
for (let i2 = 0; i2 < (pvs2 == null ? void 0 : pvs2.length); i2++) {
let s = i2;
let e = i2 + 1;
if (i2 == pvs2.length - 1) {
e = 0;
}
ctx.beginPath();
ctx.moveTo(pvs2[s].x * ratio + lineOffset, pvs2[s].y * ratio + lineOffset);
ctx.lineTo(pvs2[e].x * ratio + lineOffset, pvs2[e].y * ratio + lineOffset);
ctx.stroke();
ctx.closePath();
}
ctx.strokeStyle = DDeiUtil$1.getColor("red");
pvs2 = this.model.dragOutPoints;
for (let i2 = 0; i2 < (pvs2 == null ? void 0 : pvs2.length); i2++) {
let s = i2;
let e = i2 + 1;
if (i2 == pvs2.length - 1) {
e = 0;
}
ctx.beginPath();
ctx.moveTo(pvs2[s].x * ratio + lineOffset, pvs2[s].y * ratio + lineOffset);
ctx.lineTo(pvs2[e].x * ratio + lineOffset, pvs2[e].y * ratio + lineOffset);
ctx.stroke();
ctx.closePath();
}
ctx.restore();
}
this.model.dragInPoints = [];
this.model.dragOutPoints = [];
}
/**
* 获取缓存的渲染数据
*/
getCachedValue(attrPath) {
let returnValue = null;
if (!this.renderCacheData.has(attrPath)) {
returnValue = DDeiModelArrtibuteValue.getAttrValueByState(this.model, attrPath, true);
this.renderCacheData.set(attrPath, returnValue);
} else {
returnValue = this.renderCacheData.get(attrPath);
}
return returnValue;
}
/**
* 设置渲染缓存数据
*/
setCachedValue(attrPath, value) {
if (attrPath) {
if (Array.isArray(attrPath)) {
attrPath.forEach((item) => {
this.renderCacheData.set(item, value);
});
} else {
this.renderCacheData.set(attrPath, value);
}
}
}
clearCachedValue() {
this.renderCacheData.clear();
this.model.models.forEach((item) => {
var _a3;
(_a3 = item == null ? void 0 : item.render) == null ? void 0 : _a3.clearCachedValue();
});
}
/**
* 获取单个点移动后的坐标增量
* 考虑最小移动像素
* @param evt 事件
* @returns 计算的坐标增量
*/
getMovedPositionDelta(evt) {
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
this.stage.getStageRatio();
ex -= this.stage.wpv.x;
ey -= this.stage.wpv.y;
let movedBounds = {
x: ex - this.stageRender.dragObj.x,
y: ey - this.stageRender.dragObj.y
};
return movedBounds;
}
// ============================== 事件 ===============================
/**
* 鼠标按下事件
*/
mouseDown(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L, _M, _N, _O, _P, _Q, _R, _S, _T, _U, _V, _W, _X, _Y, _Z;
if (this.stage.ddInstance.disabled) {
return;
}
if (this.stage.ddInstance.state == DDeiEnumState.IN_ACTIVITY) {
return;
}
if (this.stage.ddInstance.eventCancel) {
return;
}
if (!this.model.display && !this.model.tempDisplay || this.model.lock) {
return;
}
let isCtrl = DDei.KEY_DOWN_STATE.get("ctrl");
let stageRatio2 = this.model.getStageRatio();
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= this.stage.wpv.x;
ey -= this.stage.wpv.y;
let ex2 = ex / stageRatio2;
let ey2 = ey / stageRatio2;
if (((_a3 = this.stageRender) == null ? void 0 : _a3.operateState) == DDeiEnumOperateState.QUICK_EDITING) {
let canvas = this.ddRender.getCanvas();
if ((evt.target == canvas || evt.target == canvas.parentElement) && (!this.stageRender.editorShadowControl || !((_b2 = this.stageRender.editorShadowControl) == null ? void 0 : _b2.isInAreaLoose(ex, ey)))) {
(_c2 = DDeiUtil$1.getEditorText()) == null ? void 0 : _c2.enterValue();
}
}
let isOvPoint = false;
if (((_e2 = (_d2 = this.stage) == null ? void 0 : _d2.selectedModels) == null ? void 0 : _e2.size) == 1) {
let model = Array.from((_f = this.stage) == null ? void 0 : _f.selectedModels.values())[0];
let ovPoint = model.getOvPointByPos(ex2, ey2);
if (ovPoint) {
let ovsDefine = (_h = (_g = DDeiUtil$1.getControlDefine(model)) == null ? void 0 : _g.define) == null ? void 0 : _h.ovs;
let ovd = ovsDefine[model.ovs.indexOf(ovPoint)];
if (((_i = ovd == null ? void 0 : ovd.constraint) == null ? void 0 : _i.type) && ovd.constraint.type != 5) {
isOvPoint = true;
this.stageRender.operateState = DDeiEnumOperateState.OV_POINT_CHANGING;
(_l = (_k = (_j = this.stage) == null ? void 0 : _j.ddInstance) == null ? void 0 : _k.bus) == null ? void 0 : _l.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj: { x: ex2, y: ey2, opPoint: ovPoint, model } }, evt);
(_o = (_n = (_m = this.stage) == null ? void 0 : _m.ddInstance) == null ? void 0 : _n.bus) == null ? void 0 : _o.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "pointer" }, evt);
}
}
}
if (isOvPoint)
;
else if (this.stageRender.selector && this.stageRender.selector.isInAreaLoose(ex2, ey2, true) && (this.stageRender.selector.passIndex >= 1 && this.stageRender.selector.passIndex <= 9 || this.stageRender.selector.passIndex == 13)) {
this.stageRender.selector.render.mouseDown(evt);
} else {
let opPoint = this.model.getOpPointByPos(ex2, ey2);
let isStop = false;
if (opPoint) {
let innerSize = 0;
let outRect = DDeiAbstractShape.getOutRectByPV([opPoint.model]);
if (outRect.height > 20 && outRect.width > 20) {
innerSize = -5;
}
if (opPoint.oppoint == 3 || opPoint.model.getProjPoint({ x: ex2, y: ey2 }, { in: innerSize, out: 15 }, 1, 2)) {
let modeName = DDeiUtil$1.getConfigValue("MODE_NAME", this.stage.ddInstance);
let accessLink = DDeiUtil$1.isAccess(
DDeiEnumOperateType.LINK,
null,
null,
modeName,
this.stage.ddInstance
);
if (accessLink) {
isStop = true;
(_r = (_q = (_p = this.stage) == null ? void 0 : _p.ddInstance) == null ? void 0 : _q.bus) == null ? void 0 : _r.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj: { opPoint } }, evt);
(_u = (_t = (_s = this.stage) == null ? void 0 : _s.ddInstance) == null ? void 0 : _t.bus) == null ? void 0 : _u.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, null, evt);
this.stageRender.operateState = DDeiEnumOperateState.LINE_POINT_CHANGING_CONFIRM;
}
}
}
if (!isStop) {
let operateControls = DDeiAbstractShape.findBottomModelsByArea(this.model, ex2, ey2, true);
if (operateControls != null && operateControls.length > 0) {
let operateControl = operateControls[0];
this.stageRender.currentOperateShape = operateControl;
this.stageRender.tempSX = ex2;
this.stageRender.tempSY = ey2;
this.stageRender.operateState = DDeiEnumOperateState.CONTROL_CONFIRMING;
operateControl.render.mouseDown(evt);
let pContainerModel = operateControl.pModel;
if (pContainerModel) {
if (!isCtrl) {
let selectedModels = pContainerModel.getSelectedModels();
if (!selectedModels.has(operateControl.id)) {
(_x = (_w = (_v = this.stage) == null ? void 0 : _v.ddInstance) == null ? void 0 : _w.bus) == null ? void 0 : _x.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, { container: pContainerModel, curLevel: true }, evt);
(_A = (_z = (_y = this.stage) == null ? void 0 : _y.ddInstance) == null ? void 0 : _z.bus) == null ? void 0 : _A.push(DDeiEnumBusCommandType.ResetSelectorState, {}, evt);
}
}
}
} else {
if ((_B = this.stage) == null ? void 0 : _B.brushData) {
this.stage.brushData = null;
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "default" }, evt);
}
(_E = (_D = (_C = this.stage) == null ? void 0 : _C.ddInstance) == null ? void 0 : _D.bus) == null ? void 0 : _E.push(DDeiEnumBusCommandType.ResetSelectorState, { x: ex2, y: ey2 }, evt);
let clearSelect = false;
switch ((_F = this.stage.ddInstance) == null ? void 0 : _F.editMode) {
case 1: {
this.stageRender.operateState = DDeiEnumOperateState.SELECT_WORKING;
clearSelect = !isCtrl;
break;
}
case 2: {
(_I = (_H = (_G = this.stage) == null ? void 0 : _G.ddInstance) == null ? void 0 : _H.bus) == null ? void 0 : _I.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj: { dx: ex, dy: ey } }, evt);
this.stageRender.operateState = DDeiEnumOperateState.GRAB_WORKING;
clearSelect = !isCtrl;
break;
}
case 3: {
(_L = (_K = (_J = this.stage) == null ? void 0 : _J.ddInstance) == null ? void 0 : _K.bus) == null ? void 0 : _L.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj: { dx: ex2, dy: ey2 } }, evt);
this.stageRender.operateState = DDeiEnumOperateState.TEXT_CREATING;
clearSelect = true;
}
case 4: {
let modeName = DDeiUtil$1.getConfigValue("MODE_NAME", (_M = this.stage) == null ? void 0 : _M.ddInstance);
let accessLink = DDeiUtil$1.isAccess(
DDeiEnumOperateType.LINK,
null,
null,
modeName,
(_N = this.stage) == null ? void 0 : _N.ddInstance
);
if (accessLink) {
(_Q = (_P = (_O = this.stage) == null ? void 0 : _O.ddInstance) == null ? void 0 : _P.bus) == null ? void 0 : _Q.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj: { dx: ex2, dy: ey2 } }, evt);
this.stageRender.operateState = DDeiEnumOperateState.LINE_POINT_CHANGING;
clearSelect = true;
}
}
}
if (clearSelect) {
(_T = (_S = (_R = this.stage) == null ? void 0 : _R.ddInstance) == null ? void 0 : _S.bus) == null ? void 0 : _T.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, null, evt);
}
}
}
}
(_W = (_V = (_U = this.stage) == null ? void 0 : _U.ddInstance) == null ? void 0 : _V.bus) == null ? void 0 : _W.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
(_Z = (_Y = (_X = this.stage) == null ? void 0 : _X.ddInstance) == null ? void 0 : _Y.bus) == null ? void 0 : _Z.executeAll();
}
/**
* 绘制图形
*/
mouseUp(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L, _M, _N, _O, _P, _Q, _R, _S, _T, _U, _V, _W, _X, _Y, _Z, __, _$, _aa, _ba, _ca, _da, _ea, _fa, _ga, _ha, _ia, _ja, _ka, _la, _ma, _na, _oa, _pa, _qa, _ra, _sa, _ta, _ua, _va, _wa, _xa, _ya, _za, _Aa, _Ba, _Ca, _Da, _Ea, _Fa, _Ga, _Ha, _Ia, _Ja, _Ka, _La, _Ma, _Na, _Oa, _Pa, _Qa, _Ra, _Sa, _Ta, _Ua, _Va, _Wa, _Xa, _Ya, _Za, __a;
if (this.stage.ddInstance.disabled) {
return;
}
if (this.stage.ddInstance.state == DDeiEnumState.IN_ACTIVITY) {
return;
}
if (this.stage.ddInstance.eventCancel) {
return;
}
if (!this.model.display && !this.model.tempDisplay || this.model.lock) {
return;
}
let isAlt = DDei.KEY_DOWN_STATE.get("alt");
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
let stageRatio2 = this.stage.getStageRatio();
ex -= this.stage.wpv.x;
ey -= this.stage.wpv.y;
let ex2 = ex / stageRatio2;
let ey2 = ey / stageRatio2;
if (evt.button == 2) {
let operateControls = DDeiAbstractShape.findBottomModelsByArea(this.model, ex2, ey2);
if (operateControls != null && operateControls.length > 0) {
DDeiUtil$1.showContextMenu(operateControls[0], (_a3 = this.ddRender) == null ? void 0 : _a3.model, evt);
}
this.model.opPoints = [];
if ((_b2 = this.model.opLine) == null ? void 0 : _b2.render) {
this.model.opLine.render.enableRefreshShape();
}
delete this.model.opLine;
this.clearShadowControls();
} else {
switch (this.stageRender.operateState) {
case DDeiEnumOperateState.LINE_POINT_CHANGING_CONFIRM: {
let operateControls = DDeiAbstractShape.findBottomModelsByArea(this.model, ex2, ey2, true);
if (operateControls != null && operateControls.length > 0) {
let operateControl = operateControls[0];
this.stageRender.currentOperateShape = operateControl;
}
}
case DDeiEnumOperateState.CONTROL_CONFIRMING: {
this.stageRender.currentOperateShape.render.mouseUp(evt);
if ((_c2 = this.stage) == null ? void 0 : _c2.brushData) {
(_f = (_e2 = (_d2 = this.stage) == null ? void 0 : _d2.ddInstance) == null ? void 0 : _e2.bus) == null ? void 0 : _f.push(DDeiEnumBusCommandType.CopyStyle, { models: [this.stageRender.currentOperateShape], brushData: this.stage.brushData }, evt);
}
this.clearShadowControls();
break;
}
case DDeiEnumOperateState.SELECT_WORKING:
let pushDatas = [];
let includedModels = this.stageRender.selector.getIncludedModels();
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_SELECT_BEFORE", DDeiEnumOperateType.SELECT, { models: Array.from(includedModels.values()) }, (_g = this.stage) == null ? void 0 : _g.ddInstance, evt);
if (rsState == 0 || rsState == 1) {
let isCtrl = DDei.KEY_DOWN_STATE.get("ctrl");
if (!isCtrl) {
(_j = (_i = (_h = this.stage) == null ? void 0 : _h.ddInstance) == null ? void 0 : _i.bus) == null ? void 0 : _j.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, null, evt);
}
this.stageRender.currentOperateContainer = this.model;
includedModels.forEach((model, key) => {
pushDatas.push({ id: model.id, value: DDeiEnumControlState.SELECTED });
});
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ModelChangeSelect, pushDatas, evt);
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.StageChangeSelectModels);
this.stage.ddInstance.bus.executeAll();
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_SELECT_AFTER", DDeiEnumOperateType.SELECT, { models: Array.from(includedModels.values()) }, (_k = this.stage) == null ? void 0 : _k.ddInstance, evt);
} else {
(_n = (_m = (_l = this.stage) == null ? void 0 : _l.ddInstance) == null ? void 0 : _m.bus) == null ? void 0 : _n.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
this.stageRender.operateState = DDeiEnumOperateState.NONE;
}
break;
case DDeiEnumOperateState.GRAB_WORKING:
break;
case DDeiEnumOperateState.TEXT_CREATING:
break;
case DDeiEnumOperateState.LINE_POINT_CHANGING: {
let hasChange2 = false;
if (this.model.shadowControls.length > 0) {
let item = this.model.shadowControls[0];
let id = item.id.substring(item.id, item.id.lastIndexOf("_shadow"));
let model = (_o = this.stage) == null ? void 0 : _o.getModelById(id);
let isStop2 = false;
let rsState2 = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_DRAG_AFTER", DDeiEnumOperateType.DRAG, this.stageRender.dragObj, (_p = this.stage) == null ? void 0 : _p.ddInstance, null);
if (rsState2 == 0 || rsState2 == 1) {
if (model) {
model.syncVectors(item);
} else {
let opPoint = this.model.getOpPointByPos(ex2, ey2);
let maxLength = 0;
if (!(opPoint == null ? void 0 : opPoint.model)) {
for (let i2 = 0; i2 < item.pvs.length - 1; i2++) {
maxLength += DDeiUtil$1.getPointDistance(item.pvs[i2].x, item.pvs[i2].y, item.pvs[i2 + 1].x, item.pvs[i2 + 1].y);
}
}
if ((opPoint == null ? void 0 : opPoint.model) && (Math.abs(opPoint.x - item.startPoint.x) >= 1 || Math.abs(opPoint.y - item.startPoint.y) >= 1) || maxLength >= 15) {
item.id = id;
item.destroyRender();
this.model.addModel(item, false);
item.initRender();
model = item;
delete model.isShadowControl;
} else {
isStop2 = true;
}
}
if (!isStop2) {
let passIndex = this.stageRender.dragObj.passIndex;
if (passIndex == 1) {
let skip = false;
let constraint = (_r = (_q = DDeiUtil$1.getControlDefine(model)) == null ? void 0 : _q.define) == null ? void 0 : _r.constraint;
let opvsIndex = this.stageRender.dragObj.opvsIndex;
let dmpath = "";
if (opvsIndex == 0) {
if ((constraint == null ? void 0 : constraint.sp) && constraint.sp.link == false) {
skip = true;
} else {
dmpath = "startPoint";
}
} else {
if ((constraint == null ? void 0 : constraint.ep) && constraint.ep.link == false) {
skip = true;
} else {
dmpath = "endPoint";
}
}
if (!skip) {
let distLinks = (_s = this.stage) == null ? void 0 : _s.getDistModelLinks(model.id);
distLinks == null ? void 0 : distLinks.forEach((dl) => {
var _a22, _b22;
if (dl.dmpath == dmpath) {
(_a22 = this.stage) == null ? void 0 : _a22.removeLink(dl);
if ((dl == null ? void 0 : dl.sm) && (dl == null ? void 0 : dl.smpath)) {
DDeiUtil$1.deletePropertyByPath(dl.sm, dl.smpath);
dl.sm.transVectors(new Matrix3());
dl.sm.updateLinkModels();
(_b22 = dl.sm.render) == null ? void 0 : _b22.enableRefreshShape();
}
}
});
let opPoint = this.model.getOpPointByPos(ex2, ey2);
if (opPoint) {
let smodel = opPoint.model;
let id2 = "_" + DDeiUtil$1.getUniqueCode();
smodel.exPvs[id2] = new Vector3(opPoint.x, opPoint.y, opPoint.z);
smodel.exPvs[id2].rate = opPoint.rate;
smodel.exPvs[id2].sita = opPoint.sita;
smodel.exPvs[id2].index = opPoint.index;
smodel.exPvs[id2].id = id2;
let link2 = new DDeiLink({
sm: smodel,
dm: model,
smpath: "exPvs." + id2,
dmpath,
stage: this.stage
});
this.stage.addLink(link2);
model.initPVS();
}
}
}
let dlinks = (_t = this.stage) == null ? void 0 : _t.getDistModelLinks(model.id);
dlinks == null ? void 0 : dlinks.forEach((dl) => {
if (dl.sm) {
dl.sm.transVectors(new Matrix3());
dl.sm.updateLinkModels();
dl.sm.render.enableRefreshShape();
}
});
model.initPVS();
model.updateOVS();
model.clps = [];
this.stageRender.refreshJumpLine = false;
if (model.pModel != this.model) {
(_u = model.pModel) == null ? void 0 : _u.changeParentsBounds();
}
hasChange2 = true;
this.stage.refreshLinkCache();
}
}
}
(_x = (_w = (_v = this.stage) == null ? void 0 : _v.ddInstance) == null ? void 0 : _w.bus) == null ? void 0 : _x.push(DDeiEnumBusCommandType.ClearTemplateVars);
if (hasChange2) {
(_A = (_z = (_y = this.stage) == null ? void 0 : _y.ddInstance) == null ? void 0 : _z.bus) == null ? void 0 : _A.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
(_D = (_C = (_B = this.stage) == null ? void 0 : _B.ddInstance) == null ? void 0 : _C.bus) == null ? void 0 : _D.push(DDeiEnumBusCommandType.NodifyChange);
(_G = (_F = (_E = this.stage) == null ? void 0 : _E.ddInstance) == null ? void 0 : _F.bus) == null ? void 0 : _G.push(DDeiEnumBusCommandType.AddHistroy);
}
(_J = (_I = (_H = this.stage) == null ? void 0 : _H.ddInstance) == null ? void 0 : _I.bus) == null ? void 0 : _J.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "grab" }, evt);
this.clearShadowControls();
break;
}
case DDeiEnumOperateState.CONTROL_DRAGING:
let isStop = false;
let hasChange = false;
if (isAlt) {
let mouseOnContainers = DDeiAbstractShape.findBottomContainersByArea(this.model, ex2, ey2);
let lastOnContainer = this.model;
let pContainerModel = this.stageRender.currentOperateShape.pModel;
if (mouseOnContainers && mouseOnContainers.length > 0) {
for (let k = mouseOnContainers.length - 1; k >= 0; k--) {
if (mouseOnContainers[k].id != this.stageRender.currentOperateShape.id) {
lastOnContainer = mouseOnContainers[k];
break;
}
}
}
if (lastOnContainer.id != pContainerModel.id || lastOnContainer.unicode != pContainerModel.unicode) {
if (!lastOnContainer.layoutManager || lastOnContainer.layoutManager.canAppend(ex2, ey2, this.model.shadowControls)) {
let operateModels2 = [];
let selMods = [];
this.model.shadowControls.forEach((item) => {
var _a22;
let id = item.id.substring(item.id, item.id.lastIndexOf("_shadow"));
let model = (_a22 = this.stage) == null ? void 0 : _a22.getModelById(id);
model.originCPV = model.cpv;
model.originPVS = model.pvs;
model.syncVectors(item, true);
operateModels2.push(model);
selMods.push({ id: model == null ? void 0 : model.id, value: DDeiEnumControlState.SELECTED });
});
if (pContainerModel.baseModelType == "DDeiTableCell") {
selMods.push({ id: (_K = pContainerModel.pModel) == null ? void 0 : _K.id, value: DDeiEnumControlState.DEFAULT });
} else {
selMods.push({ id: pContainerModel.id, value: DDeiEnumControlState.DEFAULT });
}
if ((lastOnContainer == null ? void 0 : lastOnContainer.baseModelType) == "DDeiTableCell") {
selMods.push({ id: (_L = lastOnContainer.pModel) == null ? void 0 : _L.id, value: DDeiEnumControlState.SELECTED });
} else {
selMods.push({ id: lastOnContainer == null ? void 0 : lastOnContainer.id, value: DDeiEnumControlState.SELECTED });
}
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_DRAG_AFTER", DDeiEnumOperateType.DRAG, { models: operateModels2 }, (_M = this.stage) == null ? void 0 : _M.ddInstance, null);
(_P = (_O = (_N = this.stage) == null ? void 0 : _N.ddInstance) == null ? void 0 : _O.bus) == null ? void 0 : _P.push(DDeiEnumBusCommandType.ModelChangeContainer, { oldContainer: pContainerModel, newContainer: lastOnContainer, models: operateModels2 }, evt);
(_S = (_R = (_Q = this.stage) == null ? void 0 : _Q.ddInstance) == null ? void 0 : _R.bus) == null ? void 0 : _S.push(DDeiEnumBusCommandType.ModelChangeSelect, selMods, evt);
hasChange = true;
}
isStop = true;
}
}
if (!isStop) {
let pContainerModel = this.stageRender.currentOperateShape.pModel;
if (!pContainerModel.layoutManager || pContainerModel.layoutManager.canChangePosition(ex2, ey2, this.model.shadowControls)) {
let operateModels2 = [];
let lines = (_T = this.stage) == null ? void 0 : _T.getModelsByBaseType("DDeiLine");
let moveOriginModels = [];
let moveOriginModelIds = [];
let moveOriginLines = [];
this.model.shadowControls.forEach((item) => {
var _a22;
let id = item.id.substring(item.id, item.id.lastIndexOf("_shadow"));
let momodel = (_a22 = this.stage) == null ? void 0 : _a22.getModelById(id);
if (momodel) {
if ((momodel == null ? void 0 : momodel.baseModelType) == "DDeiLine") {
moveOriginLines.push(momodel.id);
}
moveOriginModels.push(momodel);
moveOriginModelIds.push(momodel.id);
}
});
for (let i2 = 0; i2 < this.model.shadowControls.length; i2++) {
let item = this.model.shadowControls[i2];
let model = moveOriginModels[i2];
model.syncVectors(item);
hasChange = true;
operateModels2.push(model);
if (model.modelType == "DDeiLine") {
let distLinks = (_U = this.stage) == null ? void 0 : _U.getDistModelLinks(model.id);
let skipStart = false, skipEnd = false;
distLinks == null ? void 0 : distLinks.forEach((dl) => {
var _a22, _b22;
if (!dl.disabled && (!dl.sm || moveOriginModels.indexOf(dl.sm) == -1)) {
(_a22 = this.stage) == null ? void 0 : _a22.removeLink(dl);
if ((dl == null ? void 0 : dl.sm) && (dl == null ? void 0 : dl.smpath)) {
DDeiUtil$1.deletePropertyByPath(dl.sm, dl.smpath);
dl.sm.transVectors(new Matrix3());
dl.sm.updateLinkModels();
(_b22 = dl.sm.render) == null ? void 0 : _b22.enableRefreshShape();
}
} else {
if (dl.dmpath == "startPoint") {
skipStart = true;
} else if (dl.dmpath == "endPoint") {
skipEnd = true;
}
}
});
if (!skipStart) {
let lineInModelsStart = DDeiAbstractShape.findBottomModelsByArea(this.model, model.startPoint.x, model.startPoint.y, true, true);
if (lineInModelsStart.length > 0) {
for (let li = 0; li < lineInModelsStart.length; li++) {
if (!((_V = model.linkModels) == null ? void 0 : _V.has(lineInModelsStart[li].id)) && moveOriginModelIds.indexOf(lineInModelsStart[li].id) == -1) {
DDeiUtil$1.addLineLink(model, lineInModelsStart[li], model.startPoint, 1);
}
break;
}
}
}
if (!skipEnd) {
let lineInModelsEnd = DDeiAbstractShape.findBottomModelsByArea(this.model, model.endPoint.x, model.endPoint.y, true, true);
if (lineInModelsEnd.length > 0) {
for (let li = 0; li < lineInModelsEnd.length; li++) {
if (!((_W = model.linkModels) == null ? void 0 : _W.has(lineInModelsEnd[li].id)) && moveOriginModelIds.indexOf(lineInModelsEnd[li].id) == -1) {
DDeiUtil$1.addLineLink(model, lineInModelsEnd[li], model.endPoint, 2);
}
break;
}
}
}
} else {
model.updateLinkModels(moveOriginLines);
if (model.depModel) {
let lm = (_X = model.depModel.linkModels) == null ? void 0 : _X.get(model.id);
if (model.depModel.baseModelType == "DDeiLine") {
let point2 = null;
if (lm.type == 1) {
point2 = model.depModel.startPoint;
} else if (lm.type == 2) {
point2 = model.depModel.endPoint;
} else if (lm.type == 3) {
let pi = Math.floor(model.depModel.pvs.length / 2);
if (model.depModel.pvs.length % 3 == 0) {
point2 = model.depModel.pvs[pi];
} else {
point2 = {
x: (model.depModel.pvs[pi - 1].x + model.depModel.pvs[pi].x) / 2,
y: (model.depModel.pvs[pi - 1].y + model.depModel.pvs[pi].y) / 2
};
}
}
lm.dx = model.cpv.x - point2.x;
lm.dy = model.cpv.y - point2.y;
} else {
if (lm.type == 5) {
lm.dx = model.cpv.x - model.depModel.cpv.x;
lm.dy = model.cpv.y - model.depModel.cpv.y;
} else {
let essBounds = model.depModel.essBounds;
let dmEssBounds = lm.dm.essBounds;
let point2;
if (lm.type == 6) {
point2 = {
x: model.depModel.cpv.x,
y: essBounds.y - dmEssBounds.height / 2
};
} else if (lm.type == 7) {
point2 = {
y: model.depModel.cpv.y,
x: essBounds.x1 + dmEssBounds.width / 2
};
} else if (lm.type == 8) {
point2 = {
x: model.depModel.cpv.x,
y: essBounds.y1 + dmEssBounds.height / 2
};
} else if (lm.type == 9) {
point2 = {
y: model.depModel.cpv.y,
x: essBounds.x - dmEssBounds.width / 2
};
}
lm.dx = model.cpv.x - point2.x;
lm.dy = model.cpv.y - point2.y;
}
}
}
}
model.refreshLinkModels();
}
lines == null ? void 0 : lines.forEach((line2) => {
line2.clps = [];
});
this.stageRender.refreshJumpLine = false;
pContainerModel == null ? void 0 : pContainerModel.changeParentsBounds();
(_Y = pContainerModel == null ? void 0 : pContainerModel.layoutManager) == null ? void 0 : _Y.updateLayout(ex2, ey2, operateModels2);
operateModels2 == null ? void 0 : operateModels2.forEach((item) => {
var _a22;
(_a22 = item.render) == null ? void 0 : _a22.controlDragEnd(evt);
});
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_DRAG_AFTER", DDeiEnumOperateType.DRAG, { models: operateModels2 }, (_Z = this.stage) == null ? void 0 : _Z.ddInstance, null);
}
}
if (hasChange) {
(_aa = (_$ = (__ = this.stage) == null ? void 0 : __.ddInstance) == null ? void 0 : _$.bus) == null ? void 0 : _aa.push(DDeiEnumBusCommandType.UpdatePaperArea);
(_da = (_ca = (_ba = this.stage) == null ? void 0 : _ba.ddInstance) == null ? void 0 : _ca.bus) == null ? void 0 : _da.push(DDeiEnumBusCommandType.StageChangeSelectModels);
(_ga = (_fa = (_ea = this.stage) == null ? void 0 : _ea.ddInstance) == null ? void 0 : _fa.bus) == null ? void 0 : _ga.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
(_ja = (_ia = (_ha = this.stage) == null ? void 0 : _ha.ddInstance) == null ? void 0 : _ia.bus) == null ? void 0 : _ja.push(DDeiEnumBusCommandType.NodifyChange);
(_ma = (_la = (_ka = this.stage) == null ? void 0 : _ka.ddInstance) == null ? void 0 : _la.bus) == null ? void 0 : _ma.push(DDeiEnumBusCommandType.AddHistroy);
}
this.clearShadowControls();
break;
case DDeiEnumOperateState.TABLE_INNER_DRAG:
let table2 = this.stageRender.currentOperateShape;
(_na = table2 == null ? void 0 : table2.render) == null ? void 0 : _na.mouseUp(evt);
(_pa = (_oa = this.stage) == null ? void 0 : _oa.ddInstance) == null ? void 0 : _pa.bus.push(DDeiEnumBusCommandType.CopyStyle, { models: [table2], brushData: this.stage.brushData });
break;
case DDeiEnumOperateState.CONTROL_ROTATE:
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_ROTATE_AFTER", DDeiEnumOperateType.ROTATE, { models: this.stageRender.dragObj.models }, (_qa = this.stage) == null ? void 0 : _qa.ddInstance, evt);
(_ta = (_sa = (_ra = this.stage) == null ? void 0 : _ra.ddInstance) == null ? void 0 : _sa.bus) == null ? void 0 : _ta.push(DDeiEnumBusCommandType.ClearTemplateVars);
(_wa = (_va = (_ua = this.stage) == null ? void 0 : _ua.ddInstance) == null ? void 0 : _va.bus) == null ? void 0 : _wa.push(DDeiEnumBusCommandType.NodifyChange);
(_za = (_ya = (_xa = this.stage) == null ? void 0 : _xa.ddInstance) == null ? void 0 : _ya.bus) == null ? void 0 : _za.push(DDeiEnumBusCommandType.AddHistroy);
break;
case DDeiEnumOperateState.CONTROL_CHANGING_BOUND:
let operateModels = [];
this.model.shadowControls.forEach((item) => {
var _a22;
let id = item.id.substring(item.id, item.id.lastIndexOf("_shadow"));
let model = (_a22 = this.stage) == null ? void 0 : _a22.getModelById(id);
if (model) {
model.syncVectors(item);
if (model.changeChildrenBounds) {
model.changeChildrenBounds();
}
model.updateLinkModels();
operateModels.push(model);
}
});
(_Ca = (_Ba = (_Aa = this.stage) == null ? void 0 : _Aa.ddInstance) == null ? void 0 : _Ba.bus) == null ? void 0 : _Ca.push(DDeiEnumBusCommandType.NodifyChange);
(_Fa = (_Ea = (_Da = this.stage) == null ? void 0 : _Da.ddInstance) == null ? void 0 : _Ea.bus) == null ? void 0 : _Fa.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
this.stageRender.selector.updatePVSByModels(operateModels);
this.clearShadowControls();
break;
case DDeiEnumOperateState.QUICK_EDITING_TEXT_SELECTING:
delete this.stage.brushData;
if (((_Ga = this.stage.brushDataText) == null ? void 0 : _Ga.length) > 0) {
let shadowControl = this.stage.render.editorShadowControl;
if (shadowControl) {
let editorText = DDeiUtil$1.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
let tempI = 0;
if (curSIdx > -1 && curEIdx > -1 && curSIdx <= curEIdx) {
for (; curSIdx < curEIdx; curSIdx++) {
shadowControl.sptStyle[curSIdx] = cloneDeep(this.stage.brushDataText[tempI]);
tempI++;
if (tempI >= this.stage.brushDataText.length) {
tempI = 0;
}
}
}
}
}
delete this.stage.brushDataText;
}
this.stageRender.operateState = DDeiEnumOperateState.QUICK_EDITING;
(_Ja = (_Ia = (_Ha = this.stage) == null ? void 0 : _Ha.ddInstance) == null ? void 0 : _Ia.bus) == null ? void 0 : _Ja.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
(_Ma = (_La = (_Ka = this.stage) == null ? void 0 : _Ka.ddInstance) == null ? void 0 : _La.bus) == null ? void 0 : _Ma.push(DDeiEnumBusCommandType.RefreshShape);
(_Pa = (_Oa = (_Na = this.stage) == null ? void 0 : _Na.ddInstance) == null ? void 0 : _Oa.bus) == null ? void 0 : _Pa.executeAll();
return;
case DDeiEnumOperateState.QUICK_EDITING:
let canvas = this.ddRender.getCanvas();
if ((evt.target == canvas || evt.target == canvas.parentElement) && (!this.stageRender.editorShadowControl || !((_Qa = this.stageRender.editorShadowControl) == null ? void 0 : _Qa.isInAreaLoose(ex, ey)))) {
(_Ra = DDeiUtil$1.getEditorText()) == null ? void 0 : _Ra.enterValue();
} else if (evt.target != canvas && evt.target != canvas.parentElement) {
return;
}
break;
}
}
(_Ua = (_Ta = (_Sa = this.stage) == null ? void 0 : _Sa.ddInstance) == null ? void 0 : _Ta.bus) == null ? void 0 : _Ua.push(DDeiEnumBusCommandType.ClearTemplateVars, null, evt);
(_Xa = (_Wa = (_Va = this.stage) == null ? void 0 : _Va.ddInstance) == null ? void 0 : _Wa.bus) == null ? void 0 : _Xa.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
(__a = (_Za = (_Ya = this.stage) == null ? void 0 : _Ya.ddInstance) == null ? void 0 : _Za.bus) == null ? void 0 : __a.executeAll();
}
/**
* 鼠标移动
*/
mouseMove(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L, _M, _N, _O, _P, _Q, _R, _S, _T, _U, _V, _W, _X, _Y, _Z, __, _$, _aa, _ba, _ca, _da, _ea, _fa, _ga, _ha, _ia, _ja, _ka, _la, _ma, _na, _oa, _pa, _qa, _ra, _sa, _ta, _ua, _va, _wa, _xa, _ya, _za, _Aa, _Ba, _Ca, _Da, _Ea, _Fa, _Ga, _Ha, _Ia, _Ja, _Ka, _La, _Ma, _Na, _Oa, _Pa, _Qa, _Ra, _Sa, _Ta, _Ua, _Va, _Wa, _Xa, _Ya, _Za;
if (this.stage.ddInstance.disabled) {
return;
}
if (this.stage.ddInstance.state == DDeiEnumState.IN_ACTIVITY) {
return;
}
if (this.stage.ddInstance.eventCancel) {
return;
}
if (!this.model.display && !this.model.tempDisplay || this.model.lock) {
return;
}
let isCtrl = DDei.KEY_DOWN_STATE.get("ctrl");
let isAlt = DDei.KEY_DOWN_STATE.get("alt");
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
let rat1 = (_a3 = this.ddRender) == null ? void 0 : _a3.ratio;
let canvasWidth = this.ddRender.canvas.width / rat1;
let canvasHeight = this.ddRender.canvas.height / rat1;
let edgeWeight = 25;
if (ex < edgeWeight) {
this.ddRender.inEdge = 4;
} else if (ex > canvasWidth - edgeWeight) {
this.ddRender.inEdge = 2;
} else if (ey < edgeWeight) {
this.ddRender.inEdge = 1;
} else if (ey > canvasHeight - edgeWeight) {
this.ddRender.inEdge = 3;
} else {
this.ddRender.inEdge = 0;
}
ex -= this.stage.wpv.x;
ey -= this.stage.wpv.y;
let stageRatio2 = this.model.getStageRatio();
let ex2 = ex / stageRatio2;
let ey2 = ey / stageRatio2;
this.ddRender.inAreaX = ex2;
this.ddRender.inAreaY = ey2;
switch (this.stageRender.operateState) {
case DDeiEnumOperateState.CONTROL_CONFIRMING: {
if (Math.abs(ex2 - this.stageRender.tempSX) <= 2 && Math.abs(ey2 - this.stageRender.tempSY) <= 2) {
return;
}
this.model.opPoints = [];
if ((_b2 = this.model.opLine) == null ? void 0 : _b2.render) {
this.model.opLine.render.enableRefreshShape();
}
delete this.model.opLine;
let operateControl = this.stageRender.currentOperateShape;
if (operateControl.pModel != this.model && operateControl.state != DDeiEnumControlState.SELECTED) {
operateControl = operateControl.pModel;
}
let pContainerModel = operateControl.pModel;
let dragObj = {
x: ex,
y: ey,
model: this.stageRender.currentOperateShape
};
(_e2 = (_d2 = (_c2 = this.stage) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.bus) == null ? void 0 : _e2.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj }, evt);
if (((_f = this.stageRender.currentOperateShape) == null ? void 0 : _f.baseModelType) == "DDeiTable" && !isCtrl) {
this.stageRender.operateState = DDeiEnumOperateState.TABLE_INNER_DRAG;
(_i = (_h = (_g = this.stage) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.bus) == null ? void 0 : _i.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, { ignoreModels: [this.stageRender.currentOperateShape] }, evt);
(_l = (_k = (_j = this.stage) == null ? void 0 : _j.ddInstance) == null ? void 0 : _k.bus) == null ? void 0 : _l.push(DDeiEnumBusCommandType.ModelChangeSelect, [{ id: this.stageRender.currentOperateShape.id, value: DDeiEnumControlState.SELECTED }], evt);
} else {
let selectedModels = pContainerModel.getSelectedModels();
let sms = Array.from(selectedModels.values());
if (sms.indexOf(this.stageRender.currentOperateShape) == -1) {
sms.push(this.stageRender.currentOperateShape);
}
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_DRAG_BEFORE", DDeiEnumOperateType.DRAG, { models: sms }, this.ddRender.model, evt);
if (rsState == 0 || rsState == 1) {
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", DDeiEnumOperateType.DRAG, { models: sms }, this.ddRender.model, evt);
this.stageRender.operateState = DDeiEnumOperateState.CONTROL_DRAGING;
sms.forEach((m) => {
let md = DDeiUtil$1.getShadowControl(m);
dragObj[md.id] = { dx: md.cpv.x - ex2, dy: md.cpv.y - ey2 };
this.model.shadowControls.push(md);
});
this.stageRender.currentOperateShape = this.model.shadowControls[this.model.shadowControls.length - 1];
} else {
this.stageRender.operateState = DDeiEnumOperateState.NONE;
}
}
break;
}
case DDeiEnumOperateState.SELECT_WORKING: {
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", "SELECT_WORKING", null, (_m = this.stage) == null ? void 0 : _m.ddInstance, evt);
(_p = (_o = (_n = this.stage) == null ? void 0 : _n.ddInstance) == null ? void 0 : _o.bus) == null ? void 0 : _p.push(DDeiEnumBusCommandType.UpdateSelectorBounds, { operateState: this.stageRender.operateState }, evt);
(_s = (_r = (_q = this.stage) == null ? void 0 : _q.ddInstance) == null ? void 0 : _r.bus) == null ? void 0 : _s.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
break;
}
case DDeiEnumOperateState.GRAB_WORKING: {
(_v = (_u = (_t = this.stage) == null ? void 0 : _t.ddInstance) == null ? void 0 : _u.bus) == null ? void 0 : _v.push(DDeiEnumBusCommandType.ChangeStageWPV, { x: ex, y: ey, dragObj: this.stageRender.dragObj }, evt);
break;
}
case DDeiEnumOperateState.LINE_POINT_CHANGING_CONFIRM: {
let dx, dy, opPoint;
if (this.stageRender.dragObj.opPoint) {
opPoint = this.stageRender.dragObj.opPoint;
dx = opPoint.x;
dy = opPoint.y;
} else {
dx = this.stageRender.dragObj.dx;
dy = this.stageRender.dragObj.dy;
}
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", "CHANGE_WPV", null, (_w = this.stage) == null ? void 0 : _w.ddInstance, evt);
if (Math.abs(ex - dx) >= 10 || Math.abs(ey - dy) >= 10) {
this.stageRender.operateState = DDeiEnumOperateState.LINE_POINT_CHANGING;
}
break;
}
case DDeiEnumOperateState.LINE_POINT_CHANGING: {
if (!this.stageRender.currentOperateShape) {
let lineJson = DDeiUtil$1.getLineInitJSON(this.stage.ddInstance);
let editor = DDeiUtil$1.getEditorInsByDDei(this.stage.ddInstance);
let lineDefine = (_x = editor.controls) == null ? void 0 : _x.get(lineJson.modelCode ? lineJson.modelCode : lineJson.model ? lineJson.model : lineJson.id ? lineJson.id : lineJson.code);
let initJSON = clone(lineDefine);
initJSON.modelCode = initJSON.id;
initJSON.id = "line_" + ++this.stage.idIdx;
if (!lineJson.type) {
initJSON.type = 2;
} else {
initJSON.type = lineJson.type;
}
if (initJSON.img) {
initJSON.fill = { type: 2, image: initJSON.img };
delete initJSON.img;
}
if (initJSON.define) {
for (let i2 in initJSON == null ? void 0 : initJSON.define) {
initJSON[i2] = initJSON.define[i2];
}
delete initJSON.define;
}
delete initJSON.ovs;
delete initJSON.attrDefineMap;
delete initJSON.filters;
delete initJSON.icon;
delete initJSON.groups;
delete initJSON.name;
delete initJSON.def;
delete initJSON.code;
delete initJSON.desc;
(_y = initJSON.composes) == null ? void 0 : _y.forEach((comp) => {
if (comp) {
delete comp.attrs;
}
});
let dx, dy, opPoint;
if (this.stageRender.dragObj.opPoint) {
opPoint = this.stageRender.dragObj.opPoint;
dx = opPoint.x;
dy = opPoint.y;
} else {
dx = this.stageRender.dragObj.dx;
dy = this.stageRender.dragObj.dy;
}
let moveMatrix2 = new Matrix3(
1,
0,
dx,
0,
1,
dy,
0,
0,
1
);
initJSON.cpv = new Vector3(0, 0, 1);
if (initJSON.type == 1) {
initJSON.pvs = [initJSON.cpv, new Vector3(ex2 - dx, ey2 - dy, 1)];
} else {
initJSON.pvs = [initJSON.cpv, new Vector3((ex2 - dx) / 2, initJSON.cpv.y, 1), new Vector3((ex2 - dx) / 2, ey2 - dy, 1), new Vector3(ex2 - dx, ey2 - dy, 1)];
}
let ddeiLine = DDeiLine.initByJSON(initJSON, { currentStage: this.stage, currentLayer: this.model, currentContainer: this.model });
ddeiLine.transVectors(moveMatrix2);
let lineShadow = DDeiUtil$1.getShadowControl(ddeiLine);
this.model.shadowControls.push(lineShadow);
this.stageRender.currentOperateShape = lineShadow;
if (opPoint) {
this.stage.tempStartOPpoint = opPoint;
let smodel = opPoint.model;
let id = "_" + DDeiUtil$1.getUniqueCode();
smodel.exPvs[id] = new Vector3(opPoint.x, opPoint.y, opPoint.z);
smodel.exPvs[id].rate = opPoint.rate;
smodel.exPvs[id].sita = opPoint.sita;
smodel.exPvs[id].index = opPoint.index;
smodel.exPvs[id].id = id;
let link2 = new DDeiLink({
sm: smodel,
dm: lineShadow,
smpath: "exPvs." + id,
dmpath: "startPoint",
stage: this.stage
});
(_z = this.stage) == null ? void 0 : _z.addLink(link2);
smodel.updateLinkModels();
}
let dragObj = {
x: ex2,
y: ey2,
dragPoint: lineShadow.pvs[lineShadow.pvs.length - 1],
model: lineShadow,
passIndex: 1,
opvsIndex: ddeiLine.pvs.length - 1,
opvs: ddeiLine.pvs,
create: true
};
(_C = (_B = (_A = this.stage) == null ? void 0 : _A.ddInstance) == null ? void 0 : _B.bus) == null ? void 0 : _C.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj }, evt);
(_F = (_E = (_D = this.stage) == null ? void 0 : _D.ddInstance) == null ? void 0 : _E.bus) == null ? void 0 : _F.push(DDeiEnumBusCommandType.RefreshShape);
} else {
let lineModel = this.stageRender.dragObj.model;
let passIndex = this.stageRender.dragObj.passIndex;
let opvsIndex = this.stageRender.dragObj.opvsIndex;
let opvs = this.stageRender.dragObj.opvs;
if (passIndex == 1 && opvsIndex == 0) {
let endPoint = lineModel.endPoint;
if (Math.abs(endPoint.x - ex2) <= ((_G = this.stage) == null ? void 0 : _G.ddInstance.GLOBAL_ADV_WEIGHT)) {
ex2 = endPoint.x;
} else if (Math.abs(endPoint.y - ey2) <= ((_H = this.stage) == null ? void 0 : _H.ddInstance.GLOBAL_ADV_WEIGHT)) {
ey2 = endPoint.y;
}
} else if (passIndex == 1 && opvsIndex == opvs.length - 1) {
let startPoint = lineModel.startPoint;
if (Math.abs(startPoint.x - ex2) <= ((_I = this.stage) == null ? void 0 : _I.ddInstance.GLOBAL_ADV_WEIGHT)) {
ex2 = startPoint.x;
} else if (Math.abs(startPoint.y - ey2) <= ((_J = this.stage) == null ? void 0 : _J.ddInstance.GLOBAL_ADV_WEIGHT)) {
ey2 = startPoint.y;
}
}
(_M = (_L = (_K = this.stage) == null ? void 0 : _K.ddInstance) == null ? void 0 : _L.bus) == null ? void 0 : _M.push(DDeiEnumBusCommandType.ChangeLinePoint, { ex: ex2, ey: ey2 });
(_P = (_O = (_N = this.stage) == null ? void 0 : _N.ddInstance) == null ? void 0 : _O.bus) == null ? void 0 : _P.push(DDeiEnumBusCommandType.RefreshShape);
}
this.model.opPoints = [];
if ((_Q = this.model.opLine) == null ? void 0 : _Q.render) {
this.model.opLine.render.enableRefreshShape();
}
delete this.model.opLine;
delete this.stage.tempCursorOPpoint;
let operateControls = DDeiAbstractShape.findBottomModelsByArea(this.model, ex2, ey2, true, true);
if (operateControls != null && operateControls.length > 0) {
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", "LINE_POINT_CHANGING", { line: this.stageRender.currentOperateShape, model: operateControls[0] }, (_R = this.stage) == null ? void 0 : _R.ddInstance, evt);
operateControls[0].render.changeOpPoints(ex2, ey2, 1);
} else {
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", "LINE_POINT_CHANGING", { line: this.stageRender.currentOperateShape }, (_S = this.stage) == null ? void 0 : _S.ddInstance, evt);
}
break;
}
case DDeiEnumOperateState.CONTROL_DRAGING: {
if (!this.ddRender.inEdge) {
let pContainerModel = null;
if (this.stageRender.currentOperateShape.id.indexOf("_shadow") != -1) {
let id = this.stageRender.currentOperateShape.id.substring(this.stageRender.currentOperateShape.id, this.stageRender.currentOperateShape.id.lastIndexOf("_shadow"));
let model = (_T = this.stage) == null ? void 0 : _T.getModelById(id);
pContainerModel = model.pModel;
} else {
pContainerModel = this.stageRender.currentOperateShape.pModel;
}
if (pContainerModel) {
let pushData = { x: ex, y: ey, dragObj: this.stageRender.dragObj, models: this.model.shadowControls, changeContainer: isAlt };
pushData.oldContainer = pContainerModel;
if (isAlt) {
let mouseOnContainers = DDeiAbstractShape.findBottomContainersByArea(this.model, ex2, ey2);
let lastOnContainer = this.model;
if (mouseOnContainers && mouseOnContainers.length > 0) {
for (let k = mouseOnContainers.length - 1; k >= 0; k--) {
if (mouseOnContainers[k].id != this.stageRender.currentOperateShape.id) {
lastOnContainer = mouseOnContainers[k];
break;
}
}
}
pushData.isAlt = true;
pushData.newContainer = lastOnContainer;
} else {
if (!((_U = this.ddRender) == null ? void 0 : _U.model.EXT_STAGE_WIDTH) || !((_V = this.ddRender) == null ? void 0 : _V.model.EXT_STAGE_HEIGHT)) {
let dragObj = pushData.dragObj;
let outRect = DDeiAbstractShape.getOutRectByPV(this.model.shadowControls);
let nmodel = this.stageRender.currentOperateShape;
let dx = 0;
let dy = 0;
if (dragObj && dragObj[nmodel.id]) {
dx = ((_W = dragObj[nmodel.id]) == null ? void 0 : _W.dx) ? (_X = dragObj[nmodel.id]) == null ? void 0 : _X.dx : 0;
dy = ((_Y = dragObj[nmodel.id]) == null ? void 0 : _Y.dy) ? (_Z = dragObj[nmodel.id]) == null ? void 0 : _Z.dy : 0;
}
if (!((__ = this.ddRender) == null ? void 0 : __.model.EXT_STAGE_WIDTH)) {
let xm = ex - nmodel.cpv.x + dx;
if (outRect.x + xm < 0) {
pushData.x -= outRect.x + xm;
} else if (outRect.x1 + xm > this.stage.width) {
pushData.x -= outRect.x1 + xm - this.stage.width;
}
}
if (!((_$ = this.ddRender) == null ? void 0 : _$.model.EXT_STAGE_HEIGHT)) {
let ym = ey - nmodel.cpv.y + dy;
if (outRect.y + ym < 0) {
pushData.y -= outRect.y + ym;
} else if (outRect.y1 + ym > this.stage.height) {
pushData.y -= outRect.y1 + ym - this.stage.height;
}
}
}
}
(_ca = (_ba = (_aa = this.stage) == null ? void 0 : _aa.ddInstance) == null ? void 0 : _ba.bus) == null ? void 0 : _ca.push(DDeiEnumBusCommandType.SetHelpLine, { models: this.model.shadowControls }, evt);
(_fa = (_ea = (_da = this.stage) == null ? void 0 : _da.ddInstance) == null ? void 0 : _ea.bus) == null ? void 0 : _fa.push(DDeiEnumBusCommandType.ModelChangePosition, pushData, evt);
(_ia = (_ha = (_ga = this.stage) == null ? void 0 : _ga.ddInstance) == null ? void 0 : _ha.bus) == null ? void 0 : _ia.push(DDeiEnumBusCommandType.RefreshShape);
}
}
break;
}
case DDeiEnumOperateState.TABLE_INNER_DRAG: {
this.model.opPoints = [];
if ((_ja = this.model.opLine) == null ? void 0 : _ja.render) {
this.model.opLine.render.enableRefreshShape();
}
delete this.model.opLine;
let table2 = this.stageRender.currentOperateShape;
table2.render.mouseMove(evt);
(_ma = (_la = (_ka = this.stage) == null ? void 0 : _ka.ddInstance) == null ? void 0 : _la.bus) == null ? void 0 : _ma.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
break;
}
case DDeiEnumOperateState.CONTROL_CHANGING_BOUND: {
let points = [];
switch (this.stageRender.selector.passIndex) {
case 1:
{
points.push({ x: this.stageRender.selector.x + this.stageRender.selector.width / 2, y: this.stageRender.selector.y });
}
break;
case 2:
{
points.push({ x: this.stageRender.selector.x + this.stageRender.selector.width, y: this.stageRender.selector.y });
}
break;
case 3:
{
points.push({ x: this.stageRender.selector.x + this.stageRender.selector.width, y: this.stageRender.selector.y + this.stageRender.selector.height / 2 });
}
break;
case 4:
{
points.push({ x: this.stageRender.selector.x + this.stageRender.selector.width, y: this.stageRender.selector.y + this.stageRender.selector.height });
}
break;
case 5:
{
points.push({ x: this.stageRender.selector.x + this.stageRender.selector.width / 2, y: this.stageRender.selector.y + this.stageRender.selector.height });
}
break;
case 6:
{
points.push({ x: this.stageRender.selector.x, y: this.stageRender.selector.y + this.stageRender.selector.height });
}
break;
case 7:
{
points.push({ x: this.stageRender.selector.x, y: this.stageRender.selector.y + this.stageRender.selector.height / 2 });
}
break;
case 8:
{
points.push({ x: this.stageRender.selector.x, y: this.stageRender.selector.y });
}
break;
}
points.forEach((point2) => {
point2.x = point2.x * stageRatio2;
point2.y = point2.y * stageRatio2;
});
(_pa = (_oa = (_na = this.stage) == null ? void 0 : _na.ddInstance) == null ? void 0 : _oa.bus) == null ? void 0 : _pa.push(DDeiEnumBusCommandType.SetHelpLine, { models: this.model.shadowControls, points }, evt);
(_sa = (_ra = (_qa = this.stage) == null ? void 0 : _qa.ddInstance) == null ? void 0 : _ra.bus) == null ? void 0 : _sa.executeAll();
let movedBounds = this.stageRender.selector.render.getMovedBounds(ex2, ey2, isCtrl || this.stageRender.selector.eqrat);
if (movedBounds) {
let selector = this.stageRender.selector;
let pushData = { x: ex, y: ey, deltaX: movedBounds.x - selector.x * stageRatio2, deltaY: movedBounds.y - selector.y * stageRatio2, deltaWidth: movedBounds.width - selector.width * stageRatio2, deltaHeight: movedBounds.height - selector.height * stageRatio2, selector, models: this.model.shadowControls };
this.model.opPoints = [];
if ((_ta = this.model.opLine) == null ? void 0 : _ta.render) {
this.model.opLine.render.enableRefreshShape();
}
delete this.model.opLine;
Array.from(this.stage.selectedModels.values())[0];
(_wa = (_va = (_ua = this.stage) == null ? void 0 : _ua.ddInstance) == null ? void 0 : _va.bus) == null ? void 0 : _wa.push(DDeiEnumBusCommandType.ModelChangeBounds, pushData, evt);
(_za = (_ya = (_xa = this.stage) == null ? void 0 : _xa.ddInstance) == null ? void 0 : _ya.bus) == null ? void 0 : _za.push(DDeiEnumBusCommandType.RefreshShape);
}
break;
}
case DDeiEnumOperateState.CONTROL_ROTATE: {
let dragObj = this.stageRender.dragObj;
(_Ca = (_Ba = (_Aa = this.stage) == null ? void 0 : _Aa.ddInstance) == null ? void 0 : _Ba.bus) == null ? void 0 : _Ca.push(DDeiEnumBusCommandType.ModelChangeRotate, { ex: ex2, ey: ey2, container: dragObj.container, models: dragObj.models }, evt);
(_Fa = (_Ea = (_Da = this.stage) == null ? void 0 : _Da.ddInstance) == null ? void 0 : _Ea.bus) == null ? void 0 : _Fa.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
break;
}
case DDeiEnumOperateState.QUICK_EDITING: {
if (this.stageRender.editorShadowControl) {
this.model.opPoints = [];
if ((_Ga = this.model.opLine) == null ? void 0 : _Ga.render) {
this.model.opLine.render.enableRefreshShape();
}
delete this.model.opLine;
let shadowControl = this.stageRender.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.isInTextArea(ex, ey)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "text" }, evt);
} else {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "default" }, evt);
}
}
break;
}
case DDeiEnumOperateState.QUICK_EDITING_TEXT_SELECTING: {
let shadowControl = this.stageRender.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.isInTextArea(ex2, ey2)) {
let cx = (ex2 - shadowControl.cpv.x) * rat1 * stageRatio2;
let cy = (ey2 - shadowControl.cpv.y) * rat1 * stageRatio2;
let startIndex = 0;
let sx = 0;
let i2 = 0;
let scaleSize = 1;
for (; i2 < shadowControl.render.textUsedArea.length; i2++) {
let rowData = shadowControl.render.textUsedArea[i2];
let ry = rowData.y / scaleSize;
let rh = rowData.height / scaleSize;
let rx = rowData.x / scaleSize;
let rw = rowData.width / scaleSize;
if (cy >= ry && cy <= ry + rh) {
if (cx >= rx && cx <= rx + rw) {
let endI = startIndex + rowData.text.length;
for (let x2 = startIndex; x2 < endI; x2++) {
let fx = shadowControl.render.textUsedArea[0].textPosCache[x2].x / scaleSize;
let lx = x2 < endI - 1 ? shadowControl.render.textUsedArea[0].textPosCache[x2 + 1].x / scaleSize : rx + rw;
let halfW = (lx - fx) / 2;
if (cx >= fx && cx < lx) {
if (cx > fx + halfW) {
sx = x2 + 1;
} else {
sx = x2;
}
break;
}
}
}
if (!sx) {
if (ex2 < shadowControl.cpv.x) {
sx = startIndex;
} else {
sx = startIndex + rowData.text.length;
}
}
break;
}
startIndex += rowData.text.length;
}
if (!sx) {
if (ex2 < shadowControl.cpv.x) {
sx = 0;
} else {
sx = startIndex + shadowControl.render.textUsedArea[i2 - 1].text.length;
}
}
let editorText = DDeiUtil$1.getEditorText();
if (this.stageRender.tempTextStart > sx) {
editorText.selectionStart = sx;
editorText.selectionEnd = this.stageRender.tempTextStart;
} else {
editorText.selectionEnd = sx;
}
setTimeout(() => {
editorText.focus();
}, 10);
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "text" }, evt);
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.stage.ddInstance.bus.executeAll();
break;
}
break;
}
case DDeiEnumOperateState.OV_POINT_CHANGING: {
(_Ja = (_Ia = (_Ha = this.stage) == null ? void 0 : _Ha.ddInstance) == null ? void 0 : _Ia.bus) == null ? void 0 : _Ja.push(DDeiEnumBusCommandType.OVSChangePosition, { x: ex2, y: ey2 }, evt);
(_Ma = (_La = (_Ka = this.stage) == null ? void 0 : _Ka.ddInstance) == null ? void 0 : _La.bus) == null ? void 0 : _Ma.push(DDeiEnumBusCommandType.RefreshShape);
break;
}
default: {
this.model.opPoints = [];
if ((_Na = this.model.opLine) == null ? void 0 : _Na.render) {
this.model.opLine.render.enableRefreshShape();
}
delete this.model.opLine;
let inSelector = false;
if (this.stageRender.selector && this.stageRender.selector.isInAreaLoose(ex2, ey2, true)) {
this.stageRender.selector.render.mouseMove(evt);
inSelector = true;
}
let operateControls = DDeiAbstractShape.findBottomModelsByArea(this.model, ex2, ey2, true);
this.ddRender.inAreaControls = operateControls;
if (operateControls != null && operateControls.length > 0) {
let allowBackActive = DDeiUtil$1.isBackActive((_Oa = this.stage) == null ? void 0 : _Oa.ddInstance);
if (allowBackActive) {
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_MOVE_IN_CONTROL", "MOVE_IN_CONTROL", { models: operateControls }, this.ddRender.model, evt);
}
for (let li = 0; li < operateControls.length; li++) {
let control = operateControls[li];
control.render.mouseMove(evt);
if (control.baseModelType != "DDeiContainer") {
break;
}
}
} else if (!inSelector || this.stageRender.selector.passIndex == -1) {
if (((_Pa = this.stage.ddInstance) == null ? void 0 : _Pa.editMode) == 1) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "default" }, evt);
} else if (((_Qa = this.stage.ddInstance) == null ? void 0 : _Qa.editMode) == 2) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "grab" }, evt);
} else if (((_Ra = this.stage.ddInstance) == null ? void 0 : _Ra.editMode) == 4) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "default" }, evt);
}
let allowBackActive = DDeiUtil$1.isBackActive((_Sa = this.stage) == null ? void 0 : _Sa.ddInstance);
if (allowBackActive) {
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_MOVE_IN_LAYER", "MOVE_IN_LAYER", { layer: this.model, ex, ey }, this.ddRender.model, evt);
}
}
if ((_Ta = this.stage) == null ? void 0 : _Ta.brushData) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { image: "cursor-brush" }, evt);
}
(_Wa = (_Va = (_Ua = this.stage) == null ? void 0 : _Ua.ddInstance) == null ? void 0 : _Va.bus) == null ? void 0 : _Wa.push(DDeiEnumBusCommandType.RefreshShape);
break;
}
}
(_Za = (_Ya = (_Xa = this.stage) == null ? void 0 : _Xa.ddInstance) == null ? void 0 : _Ya.bus) == null ? void 0 : _Za.executeAll();
}
};
__publicField2(_DDeiLayerCanvasRender, "ClsName", "DDeiLayerCanvasRender");
let DDeiLayerCanvasRender = _DDeiLayerCanvasRender;
const __vite_glob_1_3$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiLayerCanvasRender,
default: DDeiLayerCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiLineCanvasRender = class _DDeiLineCanvasRender2 extends DDeiAbstractShapeRender {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "textUsedArea", []);
}
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiLineCanvasRender2(props);
}
// ============================== 方法 ===============================
/**
* 初始化
*/
init() {
this.ddRender = this.model.stage.ddInstance.render;
this.stage = this.model.stage;
this.stageRender = this.model.stage.render;
if (this.model.layer) {
this.layer = this.model.layer;
this.layerRender = this.model.layer.render;
}
}
createTempShape() {
var _a3;
let rat1 = this.ddRender.ratio;
if (!this.tempCanvas) {
this.tempCanvas = document.createElement("canvas");
this.tempCanvas.setAttribute("style", "pointer-events:none;position:absolute;-webkit-font-smoothing:antialiased;-moz-transform-origin:left top;-moz-transform:scale(" + 1 / rat1 + ");display:block;scale:" + 1 / rat1);
}
let stageRatio2 = (_a3 = this.stage) == null ? void 0 : _a3.getStageRatio();
let tempCanvas = this.tempCanvas;
let pvs2 = this.model.getOperatePVS(true);
let outRect = DDeiAbstractShape.pvsToOutRect(pvs2, stageRatio2);
let weight = 5 * stageRatio2 * rat1;
outRect.x -= weight;
outRect.x1 += weight;
outRect.y -= weight;
outRect.y1 += weight;
outRect.width += 2 * weight;
outRect.height += 2 * weight;
tempCanvas.setAttribute("width", outRect.width * rat1);
tempCanvas.setAttribute("height", outRect.height * rat1);
let tempCtx = tempCanvas.getContext("2d", { willReadFrequently: true });
tempCanvas.tx = -outRect.x * rat1;
tempCanvas.ty = -outRect.y * rat1;
tempCanvas.outRect = outRect;
tempCtx.translate(tempCanvas.tx, tempCanvas.ty);
}
/**
* 创建图形
*/
drawShape(tempShape, composeRender = false, inRect = null, zIndex = 0) {
var _a3;
if (!inRect || this.model.isInRect(inRect.x, inRect.y, inRect.x1, inRect.y1)) {
this.tempZIndex = zIndex;
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_BEFORE", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
if (rsState == 0 || rsState == 1) {
let rsState1 = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", DDeiEnumOperateType.VIEW, { models: [this.model], tempShape, composeRender }, this.ddRender.model, null);
if (rsState1 == 0 || rsState1 == 1) {
if (!this.viewer) {
let print = false;
if (!DDeiUtil$1.isModelHidden(this.model) && this.refreshShape) {
print = true;
this.createTempShape();
let rendList = DDeiUtil$1.sortRendList(this.model);
for (let ri = 0; ri < rendList.length; ri++) {
let c = rendList[ri];
if (c == this.model) {
this.tempZIndex = this.tempZIndex + ri;
let canvas = this.getCanvas();
let ctx = canvas.getContext("2d");
ctx.save();
if (this.inited && this.model.id.indexOf("_shadow") == -1 && (!this.upLineType || this.upLineType != this.model.type)) {
this.upLineType = this.model.type;
this.model.freeze = 0;
this.model.spvs = [];
this.model.refreshLinePoints();
this.model.updateOVS();
(_a3 = this.stageRender) == null ? void 0 : _a3.selector.updatePVSByModels();
} else if (!this.inited) {
this.inited = true;
this.upLineType = this.model.type;
}
this.drawLine(tempShape);
ctx.restore();
} else {
c.render.drawShape(tempShape, 1, null, this.tempZIndex + ri);
}
}
this.refreshShape = false;
}
this.drawSelfToCanvas(composeRender, print);
} else {
if (!DDeiUtil$1.isModelHidden(this.model) && this.refreshShape) {
DDeiUtil$1.createRenderViewer(this.model, "VIEW", tempShape, composeRender);
} else {
DDeiUtil$1.createRenderViewer(this.model, "VIEW-HIDDEN");
}
}
}
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_AFTER", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
}
} else {
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", "VIEW-HIDDEN", { models: [this.model] }, this.ddRender.model, null);
if (rsState == 0 || rsState == 1) {
if (!this.viewer) {
this.removeViewerCanvas();
} else {
DDeiUtil$1.createRenderViewer(this.model, "VIEW-HIDDEN");
}
}
}
}
drawSelfToCanvas(composeRender, print) {
var _a3;
if (this.viewer) {
if (!DDeiUtil$1.isModelHidden(this.model) && this.refreshShape) {
DDeiUtil$1.createRenderViewer(this.model, "VIEW", null, composeRender);
} else {
DDeiUtil$1.createRenderViewer(this.model, "VIEW-HIDDEN");
}
} else if (this.tempCanvas) {
if (!DDeiUtil$1.isModelHidden(this.model)) {
let outRect = this.tempCanvas.outRect;
let model = this.model;
let stage2 = model.stage;
let ruleWeight = 0;
if (stage2.render.tempRuleDisplay == 1 || stage2.render.tempRuleDisplay == "1") {
ruleWeight = 15;
}
if (!this.tempCanvas.parentElement) {
let viewerEle = this.model.layer.render.containerViewer;
viewerEle.appendChild(this.tempCanvas);
}
this.tempCanvas.style.zIndex = this.tempZIndex;
this.tempCanvas.style.left = (outRect.x + outRect.x1) / 2 + this.model.stage.wpv.x - this.tempCanvas.offsetWidth / 2 - ruleWeight + "px";
this.tempCanvas.style.top = (outRect.y + outRect.y1) / 2 + this.model.stage.wpv.y - this.tempCanvas.offsetHeight / 2 - ruleWeight + "px";
if (!print) {
(_a3 = this.model.composes) == null ? void 0 : _a3.forEach((comp) => {
comp.render.drawSelfToCanvas(composeRender + 1);
});
}
} else {
this.removeViewerCanvas();
}
}
}
getRenderCanvas(composeRender) {
var _a3;
if (composeRender) {
return this.model.pModel.render.getCanvas();
} else {
return (_a3 = this.ddRender) == null ? void 0 : _a3.getCanvas();
}
}
getCanvas() {
return this.tempCanvas;
}
/**
* 绘制线段
*/
drawLine(tempLine, tempCtx) {
var _a3, _b2, _c2, _d2, _e2;
let canvas = this.getCanvas();
if (!canvas) {
return;
}
let ctx = tempCtx ? tempCtx : canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let rat1 = (tempLine == null ? void 0 : tempLine.rat1) ? tempLine.rat1 : this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
rat1 = ratio;
let color = (tempLine == null ? void 0 : tempLine.color) ? tempLine.color : this.getCachedValue("color");
if (!color) {
color = DDeiUtil$1.getStyleValue("canvas-control-border", this.ddRender.model);
}
let weight = (tempLine == null ? void 0 : tempLine.weight) ? tempLine.weight : this.getCachedValue("weight");
let fillWeight = ((_a3 = tempLine == null ? void 0 : tempLine.fill) == null ? void 0 : _a3.weight) ? (_b2 = tempLine == null ? void 0 : tempLine.fill) == null ? void 0 : _b2.weight : this.getCachedValue("fill.weight");
weight = weight + fillWeight;
let fillColor = ((_c2 = tempLine == null ? void 0 : tempLine.fill) == null ? void 0 : _c2.color) ? (_d2 = tempLine == null ? void 0 : tempLine.fill) == null ? void 0 : _d2.color : this.getCachedValue("fill.color");
let dash = (tempLine == null ? void 0 : tempLine.dash) ? tempLine.dash : this.getCachedValue("dash");
let round = (tempLine == null ? void 0 : tempLine.round) ? tempLine.round : this.getCachedValue("round");
let type = this.getCachedValue("type");
let opacity = (tempLine == null ? void 0 : tempLine.opacity) ? tempLine.opacity : this.getCachedValue("opacity");
let pvs2 = this.model.pvs;
let jumpLine = DDeiModelArrtibuteValue.getAttrValueByState(this, "jumpline", true);
if (jumpLine == 0 || !jumpLine) {
if ((_e2 = this.stage.global) == null ? void 0 : _e2.jumpline) {
jumpLine = this.stage.global.jumpline;
} else if (this.stage.ddInstance.jumpline) {
jumpLine = this.stage.ddInstance.jumpline;
} else {
jumpLine = DDeiModelArrtibuteValue.getAttrValueByState(this.stage, "global.jumpline", true);
}
}
if ((pvs2 == null ? void 0 : pvs2.length) >= 2 && color && (!opacity || opacity > 0) && weight > 0) {
let { startDX, startDY, endDX, endDY } = this.getPointShapeSize();
ctx.save();
let lineWidth = weight * ratio;
let fillLineWidth = fillWeight * ratio;
ctx.lineWidth = lineWidth;
if (dash) {
ctx.setLineDash(dash);
}
if (opacity != null && opacity != void 0) {
ctx.globalAlpha = opacity;
}
ctx.strokeStyle = DDeiUtil$1.getColor(color);
let crossWeight = 4;
switch (type) {
case 1:
{
ctx.beginPath();
ctx.moveTo((pvs2[0].x + startDX) * rat1, (pvs2[0].y + startDY) * rat1);
if (this.model.clps[0] && jumpLine == 1) {
let clps = this.model.clps[0];
for (let c = 0; c < clps.length; c++) {
let cpi = clps[c].cp;
let r = clps[c].r;
ctx.arc(cpi.x * rat1, cpi.y * rat1, crossWeight * rat1, Math.PI / 180 * (r + 180), Math.PI / 180 * r, true);
}
}
ctx.lineTo((pvs2[pvs2.length - 1].x + endDX) * rat1, (pvs2[pvs2.length - 1].y + endDY) * rat1);
ctx.stroke();
if (fillLineWidth > 0) {
ctx.lineWidth = fillLineWidth;
ctx.strokeStyle = DDeiUtil$1.getColor(fillColor);
ctx.stroke();
}
ctx.closePath();
}
break;
case 2:
{
ctx.beginPath();
ctx.moveTo((pvs2[0].x + startDX) * rat1, (pvs2[0].y + startDY) * rat1);
for (let i2 = 1; i2 < pvs2.length; i2++) {
if (this.model.clps[i2 - 1] && jumpLine == 1) {
let clps = this.model.clps[i2 - 1];
for (let c = 0; c < clps.length; c++) {
let cpi = clps[c].cp;
let r = clps[c].r;
ctx.arc(cpi.x * rat1, cpi.y * rat1, crossWeight * rat1, Math.PI / 180 * (r + 180), Math.PI / 180 * r, true);
}
if (i2 == pvs2.length - 1) {
ctx.lineTo((pvs2[i2].x + endDX) * rat1, (pvs2[i2].y + endDY) * rat1);
} else {
ctx.arcTo(pvs2[i2].x * rat1, pvs2[i2].y * rat1, pvs2[i2 + 1].x * rat1, pvs2[i2 + 1].y * rat1, round * rat1);
}
} else {
if (i2 == pvs2.length - 1) {
ctx.lineTo((pvs2[i2].x + endDX) * rat1, (pvs2[i2].y + endDY) * rat1);
} else {
ctx.arcTo(pvs2[i2].x * rat1, pvs2[i2].y * rat1, pvs2[i2 + 1].x * rat1, pvs2[i2 + 1].y * rat1, round * rat1);
}
}
}
ctx.stroke();
if (fillLineWidth > 0) {
ctx.lineWidth = fillLineWidth;
ctx.strokeStyle = DDeiUtil$1.getColor(fillColor);
ctx.stroke();
}
ctx.closePath();
}
break;
case 3:
{
if (pvs2.length >= 4) {
for (let i2 = 4; i2 <= pvs2.length; i2 += 3) {
ctx.beginPath();
let i0 = i2 - 4;
let i1 = i2 - 3;
let i22 = i2 - 2;
let i3 = i2 - 1;
if (i2 == 4) {
ctx.moveTo((pvs2[i0].x + startDX) * rat1, (pvs2[i0].y + startDY) * rat1);
} else {
ctx.moveTo(pvs2[i0].x * rat1, pvs2[i0].y * rat1);
}
if (i2 == pvs2.length) {
ctx.bezierCurveTo(pvs2[i1].x * rat1, pvs2[i1].y * rat1, pvs2[i22].x * rat1, pvs2[i22].y * rat1, (pvs2[i3].x + endDX) * rat1, (pvs2[i3].y + endDY) * rat1);
} else {
ctx.bezierCurveTo(pvs2[i1].x * rat1, pvs2[i1].y * rat1, pvs2[i22].x * rat1, pvs2[i22].y * rat1, pvs2[i3].x * rat1, pvs2[i3].y * rat1);
}
ctx.stroke();
if (fillLineWidth > 0) {
ctx.lineWidth = fillLineWidth;
ctx.strokeStyle = DDeiUtil$1.getColor(fillColor);
ctx.stroke();
}
ctx.closePath();
}
} else {
ctx.beginPath();
ctx.moveTo((pvs2[0].x + startDX) * rat1, (pvs2[0].y + startDY) * rat1);
ctx.lineTo((pvs2[0].x + endDX) * rat1, pvs2[0].y * rat1, pvs2[1].x * rat1, (pvs2[1].y + endDY) * rat1);
ctx.stroke();
if (fillLineWidth > 0) {
ctx.lineWidth = fillLineWidth;
ctx.strokeStyle = DDeiUtil$1.getColor(fillColor);
ctx.stroke();
}
ctx.closePath();
}
}
break;
}
this.drawPoint(tempLine, tempCtx);
ctx.restore();
}
}
/**
* 获取点图形所占用的空间
* @returns
*/
getPointShapeSize() {
let stageRatio2 = this.model.getStageRatio();
let pvs2 = this.model.pvs;
let startDX = 0;
let endDX = 0;
let startDY = 0;
let endDY = 0;
let stype = this.getCachedValue("sp.type");
let etype = this.getCachedValue("ep.type");
let sweight = this.getCachedValue("sp.weight");
let eweight = this.getCachedValue("ep.weight");
let fillWeight = this.getCachedValue("fill.weight");
let lineWeight = this.getCachedValue("weight");
lineWeight = lineWeight * stageRatio2;
sweight += fillWeight;
eweight += fillWeight;
if (sweight <= 0) {
sweight = 1;
}
if (eweight <= 0) {
eweight = 1;
}
let startRotate = DDeiUtil$1.getLineAngle(pvs2[1].x, pvs2[1].y, pvs2[0].x, pvs2[0].y);
let endRotate = DDeiUtil$1.getLineAngle(pvs2[pvs2.length - 2].x, pvs2[pvs2.length - 2].y, pvs2[pvs2.length - 1].x, pvs2[pvs2.length - 1].y);
let startAngle = (startRotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let endAngle = (endRotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let startVectorUnit = new Vector3(1, 0, 1);
let endVectorUnit = new Vector3(1, 0, 1);
let startRotateMatrix = new Matrix3(
Math.cos(startAngle),
Math.sin(startAngle),
0,
-Math.sin(startAngle),
Math.cos(startAngle),
0,
0,
0,
1
);
startVectorUnit.applyMatrix3(startRotateMatrix);
let endRotateMatrix = new Matrix3(
Math.cos(endAngle),
Math.sin(endAngle),
0,
-Math.sin(endAngle),
Math.cos(endAngle),
0,
0,
0,
1
);
endVectorUnit.applyMatrix3(endRotateMatrix);
let wl = 0;
switch (stype) {
case 1:
break;
case 21:
case 2:
wl = sweight * stageRatio2;
break;
case 31:
case 3:
wl = sweight * stageRatio2;
break;
case 41:
case 4:
wl = 2 * sweight * stageRatio2 + lineWeight;
break;
case 51:
case 5:
wl = sweight * stageRatio2 + lineWeight;
break;
case 61:
case 6:
wl = sweight * stageRatio2 / 2;
break;
}
startDX = -startVectorUnit.x * wl;
startDY = startVectorUnit.y * wl;
wl = 0;
switch (etype) {
case 1:
break;
case 21:
case 2:
wl = eweight * stageRatio2;
break;
case 31:
case 3:
wl = eweight * stageRatio2;
break;
case 41:
case 4:
wl = 2 * eweight * stageRatio2 + lineWeight;
break;
case 51:
case 5:
wl = eweight * stageRatio2 + lineWeight;
break;
case 61:
case 6:
wl = eweight * stageRatio2 / 2;
break;
}
endDX = -endVectorUnit.x * wl;
endDY = endVectorUnit.y * wl;
return { startDX, startDY, endDX, endDY };
}
/**
* 绘制端点
*/
drawPoint(tempLine, tempCtx) {
let canvas = this.getCanvas();
if (!canvas) {
return;
}
let ctx = tempCtx ? tempCtx : canvas.getContext("2d");
let stype = this.getCachedValue("sp.type");
let etype = this.getCachedValue("ep.type");
let sweight = this.getCachedValue("sp.weight");
let eweight = this.getCachedValue("ep.weight");
this.drawOnePoint(1, stype, sweight, ctx, tempLine);
this.drawOnePoint(2, etype, eweight, ctx, tempLine);
}
/**
* 绘制单个端点
* @param type
* @param direct
*/
drawOnePoint(pointType, type, weight, ctx, tempLine) {
var _a3, _b2, _c2, _d2;
if (!type) {
return;
}
let stageRatio2 = this.model.getStageRatio();
let rat1 = (tempLine == null ? void 0 : tempLine.rat1) ? tempLine.rat1 : this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
rat1 = ratio;
let color = (tempLine == null ? void 0 : tempLine.color) ? tempLine.color : this.getCachedValue("color");
let opacity = (tempLine == null ? void 0 : tempLine.opacity) ? tempLine.opacity : this.getCachedValue("opacity");
ctx.save();
ctx.setLineDash([]);
let pvs2 = this.model.pvs;
let point2 = null;
let upPoint = null;
let lineWeight = (tempLine == null ? void 0 : tempLine.weight) ? tempLine.weight : this.getCachedValue("weight");
let fillColor = ((_a3 = tempLine == null ? void 0 : tempLine.fill) == null ? void 0 : _a3.color) ? (_b2 = tempLine == null ? void 0 : tempLine.fill) == null ? void 0 : _b2.color : this.getCachedValue("fill.color");
let fillWeight = ((_c2 = tempLine == null ? void 0 : tempLine.fill) == null ? void 0 : _c2.weight) ? (_d2 = tempLine == null ? void 0 : tempLine.fill) == null ? void 0 : _d2.weight : this.getCachedValue("fill.weight");
weight += fillWeight;
if (weight <= 0) {
weight = 1;
}
let lineWidth = lineWeight * ratio;
ctx.lineWidth = lineWidth;
if (pointType == 1) {
point2 = this.model.startPoint;
upPoint = pvs2[1];
} else if (pointType == 2) {
point2 = this.model.endPoint;
upPoint = pvs2[pvs2.length - 2];
}
point2 = new Vector3(point2.x, point2.y, 1);
if (opacity != null && opacity != void 0) {
ctx.globalAlpha = opacity;
}
ctx.fillStyle = DDeiUtil$1.getColor(color);
ctx.strokeStyle = DDeiUtil$1.getColor(color);
let rotate2 = DDeiUtil$1.getLineAngle(upPoint.x, upPoint.y, point2.x, point2.y);
if (rotate2 != 0) {
ctx.translate(point2.x * rat1, point2.y * rat1);
ctx.rotate(rotate2 * DDeiConfig$1.ROTATE_UNIT);
ctx.translate(-point2.x * rat1, -point2.y * rat1);
}
switch (type) {
case 1: {
let wl = weight * stageRatio2;
ctx.beginPath();
ctx.moveTo((point2.x - wl) * rat1, (point2.y - 0.8 * wl) * rat1);
ctx.lineTo(point2.x * rat1 - lineWidth / 2, point2.y * rat1);
ctx.lineTo((point2.x - wl) * rat1, (point2.y + 0.8 * wl) * rat1);
ctx.stroke();
ctx.closePath();
break;
}
case 21:
case 2: {
let wl = weight * stageRatio2;
ctx.beginPath();
ctx.ellipse((point2.x - wl / 2) * rat1 - lineWidth / 2, point2.y * rat1, wl / 2 * rat1, wl / 2 * rat1, 0, 0, Math.PI * 2);
ctx.closePath();
ctx.stroke();
if (fillWeight > 0 || type == 21 || tempLine) {
if (fillWeight > 0) {
ctx.fillStyle = DDeiUtil$1.getColor(fillColor);
}
ctx.fill();
}
break;
}
case 31:
case 3: {
let wl = weight * stageRatio2;
ctx.beginPath();
ctx.moveTo((point2.x - wl) * rat1 - lineWidth / 2, (point2.y - wl / 2) * rat1);
ctx.lineTo(point2.x * rat1 - lineWidth / 2, (point2.y - wl / 2) * rat1);
ctx.lineTo(point2.x * rat1 - lineWidth / 2, (point2.y + wl / 2) * rat1);
ctx.lineTo((point2.x - wl) * rat1 - lineWidth / 2, (point2.y + wl / 2) * rat1);
ctx.closePath();
ctx.stroke();
if (fillWeight > 0 || type == 31 || tempLine) {
if (fillWeight > 0) {
ctx.fillStyle = DDeiUtil$1.getColor(fillColor);
}
ctx.fill();
}
break;
}
case 41:
case 4: {
let wl = weight * stageRatio2;
ctx.beginPath();
ctx.moveTo(point2.x * rat1 - lineWidth, point2.y * rat1);
ctx.lineTo((point2.x - wl) * rat1 - lineWidth, (point2.y - wl / 2) * rat1);
ctx.lineTo((point2.x - 2 * wl) * rat1 - lineWidth, point2.y * rat1);
ctx.lineTo((point2.x - wl) * rat1 - lineWidth, (point2.y + wl / 2) * rat1);
ctx.lineTo(point2.x * rat1 - lineWidth, point2.y * rat1);
ctx.closePath();
ctx.stroke();
if (fillWeight > 0 || type == 41 || tempLine) {
if (fillWeight > 0) {
ctx.fillStyle = DDeiUtil$1.getColor(fillColor);
}
ctx.fill();
}
break;
}
case 51:
case 5: {
let wl = weight * stageRatio2;
ctx.beginPath();
ctx.moveTo(point2.x * rat1 - lineWidth, point2.y * rat1);
ctx.lineTo((point2.x - wl) * rat1 - lineWidth, (point2.y - wl / 2) * rat1);
ctx.lineTo((point2.x - wl) * rat1 - lineWidth, (point2.y + wl / 2) * rat1);
ctx.lineTo(point2.x * rat1 - lineWidth, point2.y * rat1);
ctx.closePath();
ctx.stroke();
if (fillWeight > 0 || type == 51 || tempLine) {
if (fillWeight > 0) {
ctx.fillStyle = DDeiUtil$1.getColor(fillColor);
}
ctx.fill();
}
break;
}
case 61:
case 6: {
let wl = weight * stageRatio2 / 2;
ctx.beginPath();
ctx.ellipse((point2.x - wl / 2) * rat1 - lineWidth / 2, point2.y * rat1, wl * rat1, wl * rat1, 0, 0.4 * Math.PI, Math.PI * 1.6);
ctx.stroke();
if (fillWeight > 0 || type == 61 || tempLine) {
if (fillWeight > 0) {
ctx.fillStyle = DDeiUtil$1.getColor(fillColor);
}
ctx.fill();
}
break;
}
}
ctx.restore();
}
// ============================== 事件 ===============================
/**
* 鼠标按下事件
*/
mouseDown(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j;
if (this.layer) {
let modeName = DDeiUtil$1.getConfigValue("MODE_NAME", (_a3 = this.ddRender) == null ? void 0 : _a3.model);
let accessLink = DDeiUtil$1.isAccess(
DDeiEnumOperateType.LINK,
[this.model],
null,
modeName,
(_b2 = this.ddRender) == null ? void 0 : _b2.model
);
if (accessLink) {
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= this.stage.wpv.x;
ey -= this.stage.wpv.y;
let stageRatio2 = this.stage.getStageRatio();
ex = ex / stageRatio2;
ey = ey / stageRatio2;
let tpdata;
let weight = DDeiConfig$1.SELECTOR.OPERATE_ICON.weight;
let halfWeigth = weight * 0.5;
for (let i2 = 0; i2 < this.opvs.length; i2++) {
let pv = this.opvs[i2];
if (DDeiAbstractShape.isInsidePolygon(
[
{ x: pv.x - halfWeigth, y: pv.y - halfWeigth },
{ x: pv.x + halfWeigth, y: pv.y - halfWeigth },
{ x: pv.x + halfWeigth, y: pv.y + halfWeigth },
{ x: pv.x - halfWeigth, y: pv.y + halfWeigth }
],
{ x: ex, y: ey }
)) {
tpdata = { type: this.opvsType[i2], index: i2 };
}
}
if (tpdata) {
let dragPoint = this.opvs[tpdata.index];
let lineShadow = DDeiUtil$1.getShadowControl(this.model);
this.layer.shadowControls.push(lineShadow);
this.stageRender.currentOperateShape = lineShadow;
this.stageRender.currentOperateShape.dragPoint = dragPoint;
let dragObj = {
x: ex,
y: ey,
dragPoint,
model: lineShadow,
opvsIndex: tpdata.index,
passIndex: tpdata.type,
opvs: this.opvs
};
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_LINE_DRAG_BEFORE", DDeiEnumOperateType.DRAG, dragObj, (_c2 = this.stage) == null ? void 0 : _c2.ddInstance, evt);
if (rsState == 0 || rsState == 1) {
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", DDeiEnumOperateType.LINK, null, (_d2 = this.stage) == null ? void 0 : _d2.ddInstance, evt);
(_g = (_f = (_e2 = this.stage) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.bus) == null ? void 0 : _g.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj }, evt);
(_j = (_i = (_h = this.stage) == null ? void 0 : _h.ddInstance) == null ? void 0 : _i.bus) == null ? void 0 : _j.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "grabbing" }, evt);
this.stageRender.operateState = DDeiEnumOperateState.LINE_POINT_CHANGING;
}
}
}
}
}
/**
* 绘制图形
*/
mouseUp(evt) {
super.mouseUp(evt);
}
/**
* 鼠标移动
*/
mouseMove(evt) {
var _a3, _b2, _c2;
if (this.layer) {
let modeName = DDeiUtil$1.getConfigValue("MODE_NAME", (_a3 = this.ddRender) == null ? void 0 : _a3.model);
let accessLink = DDeiUtil$1.isAccess(
DDeiEnumOperateType.LINK,
[this.model],
null,
modeName,
(_b2 = this.ddRender) == null ? void 0 : _b2.model
);
if (accessLink) {
this.layer.opLine = this.model;
let type = this.getCachedValue("type");
let pvs2 = this.model.pvs;
let { startDX, startDY, endDX, endDY } = this.getPointShapeSize();
let opvs = [];
let opvsType = [];
opvs.push(pvs2[0]);
opvsType.push(1);
switch (type) {
case 2: {
for (let i2 = 1; i2 < pvs2.length; i2++) {
let x2 = (pvs2[i2].x + pvs2[i2 - 1].x) / 2;
let y2 = (pvs2[i2].y + pvs2[i2 - 1].y) / 2;
opvs.push(new Vector3(x2, y2, 1));
opvsType.push(3);
if (i2 != pvs2.length - 1) {
opvs.push(pvs2[i2]);
opvsType.push(2);
}
}
break;
}
case 3: {
if (pvs2.length >= 4) {
for (let i2 = 4; i2 <= pvs2.length; i2 += 3) {
let i0 = i2 - 4;
let i1 = i2 - 3;
let i22 = i2 - 2;
let i3 = i2 - 1;
if (i0 != 0) {
opvs.push(new Vector3(pvs2[i0].x, pvs2[i0].y, 1));
opvsType.push(4);
}
let stratX = pvs2[i0].x;
let stratY = pvs2[i0].y;
let endX = pvs2[i3].x;
let endY = pvs2[i3].y;
if (i0 == 0) {
stratX = pvs2[i0].x + startDX;
stratY = pvs2[i0].y + startDY;
}
if (i2 == pvs2.length) {
endX = pvs2[i3].x + endDX;
endY = pvs2[i3].y + endDY;
}
let btx = stratX * DDeiUtil$1.p331t3 + DDeiUtil$1.p331t2t3 * pvs2[i1].x + DDeiUtil$1.p33t21t3 * pvs2[i22].x + DDeiUtil$1.p33t3 * endX;
let bty = stratY * DDeiUtil$1.p331t3 + DDeiUtil$1.p331t2t3 * pvs2[i1].y + DDeiUtil$1.p33t21t3 * pvs2[i22].y + DDeiUtil$1.p33t3 * endY;
opvs.push(new Vector3(btx, bty, 1));
opvsType.push(4);
btx = stratX * DDeiUtil$1.p661t3 + DDeiUtil$1.p661t2t3 * pvs2[i1].x + DDeiUtil$1.p66t21t3 * pvs2[i22].x + DDeiUtil$1.p66t3 * endX;
bty = stratY * DDeiUtil$1.p661t3 + DDeiUtil$1.p661t2t3 * pvs2[i1].y + DDeiUtil$1.p66t21t3 * pvs2[i22].y + DDeiUtil$1.p66t3 * endY;
opvs.push(new Vector3(btx, bty, 1));
opvsType.push(4);
}
}
break;
}
}
opvs.push(pvs2[pvs2.length - 1]);
opvsType.push(1);
this.opvs = opvs;
this.opvsType = opvsType;
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= this.stage.wpv.x;
ey -= this.stage.wpv.y;
let stageRatio2 = (_c2 = this.stage) == null ? void 0 : _c2.getStageRatio();
ex = ex / stageRatio2;
ey = ey / stageRatio2;
let tpdata;
let weight = DDeiConfig$1.SELECTOR.OPERATE_ICON.weight;
let halfWeigth = weight * 0.5;
for (let i2 = 0; i2 < this.opvs.length; i2++) {
let pv = this.opvs[i2];
if (DDeiAbstractShape.isInsidePolygon(
[
{ x: pv.x - halfWeigth, y: pv.y - halfWeigth },
{ x: pv.x + halfWeigth, y: pv.y - halfWeigth },
{ x: pv.x + halfWeigth, y: pv.y + halfWeigth },
{ x: pv.x - halfWeigth, y: pv.y + halfWeigth }
],
{ x: ex, y: ey }
)) {
tpdata = { type: this.opvsType[i2], index: i2 };
}
}
if (tpdata) {
let direct = null;
if (tpdata.type == 3) {
let beforeP = this.opvs[tpdata.index - 1];
let afterP = this.opvs[tpdata.index + 1];
if (Math.abs(beforeP.x - afterP.x) <= 1) {
direct = 2;
} else {
direct = 1;
}
}
this.stage.ddInstance.bus.insert(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { type: "line", passIndex: tpdata.type, direct, opvsIndex: tpdata.index }, evt, 1);
} else {
this.stage.ddInstance.bus.insert(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { type: "line", passIndex: -1, opvsIndex: -1 }, evt, 1);
}
}
}
}
/**
* 绘制操作图形
*/
drawOpShape() {
let canvas = this.tempCanvas;
let ctx = canvas.getContext("2d");
let stageRatio2 = this.stage.getStageRatio();
let rat1 = this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
rat1 = ratio;
let pvs2 = this.model.pvs;
let type = this.getCachedValue("type");
let weight = this.getCachedValue("weight");
let w10 = 1.3 * weight * ratio;
if (w10 > 5 * rat1) {
w10 = 5 * rat1;
} else if (w10 < 2 * rat1) {
w10 = 2 * rat1;
}
let w15 = 1.5 * w10;
let w20 = 2 * w10;
let w30 = 2 * w15;
let lineModel = this.model;
ctx.save();
switch (type) {
case 1: {
this.drawSEPoint(pvs2, w10, w20, ctx, rat1, ratio);
break;
}
case 2: {
this.drawSEPoint(pvs2, w10, w20, ctx, rat1, ratio);
ctx.strokeStyle = "#017fff";
ctx.fillStyle = "white";
for (let i2 = 1; i2 < pvs2.length; i2++) {
if (i2 != pvs2.length - 1) {
ctx.save();
let x1 = pvs2[i2].x * rat1;
let y1 = pvs2[i2].y * rat1;
if (lineModel.rotate) {
ctx.translate(x1, y1);
ctx.rotate(lineModel.rotate * DDeiConfig$1.ROTATE_UNIT);
ctx.translate(-x1, -y1);
}
ctx.fillRect(x1 - w15, y1 - w15, w30, w30);
ctx.strokeRect(x1 - w15, y1 - w15, w30, w30);
ctx.restore();
}
ctx.save();
let x2 = (pvs2[i2].x + pvs2[i2 - 1].x) / 2 * rat1;
let y2 = (pvs2[i2].y + pvs2[i2 - 1].y) / 2 * rat1;
ctx.translate(x2, y2);
ctx.rotate(((lineModel.rotate ? lineModel.rotate : 0) + 45) * DDeiConfig$1.ROTATE_UNIT);
ctx.translate(-x2, -y2);
ctx.fillRect(x2 - w10, y2 - w10, w20, w20);
ctx.strokeRect(x2 - w10, y2 - w10, w20, w20);
ctx.restore();
}
break;
}
case 3: {
this.drawSEPoint(pvs2, w10, w20, ctx, rat1, ratio);
if (pvs2.length >= 4) {
ctx.strokeStyle = "#017fff";
ctx.fillStyle = "white";
for (let i2 = 1; i2 < this.opvs.length - 1; i2++) {
let pv = this.opvs[i2];
ctx.beginPath();
ctx.ellipse(pv.x * rat1, pv.y * rat1, w20, w20, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.fill();
ctx.stroke();
}
}
break;
}
}
ctx.restore();
}
getOvPointByPos(x2 = 0, y2 = 0) {
var _a3, _b2;
if (x2 && y2 && ((_a3 = this.ovs) == null ? void 0 : _a3.length) > 0) {
for (let i2 = 0; i2 < ((_b2 = this.ovs) == null ? void 0 : _b2.length); i2++) {
let point2 = this.ovs[i2];
if (Math.abs(x2 - point2.x) <= 8 && Math.abs(y2 - point2.y) <= 8) {
return point2;
}
}
}
return null;
}
/**
* 绘制开始和结束操作点
*/
drawSEPoint(pvs2, w10, w20, ctx, rat1, ratio) {
ctx.strokeStyle = "red";
ctx.lineWidth = ratio;
ctx.fillStyle = "white";
ctx.beginPath();
ctx.ellipse(pvs2[0].x * rat1, pvs2[0].y * rat1, w20, w20, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.fill();
ctx.beginPath();
ctx.ellipse(pvs2[pvs2.length - 1].x * rat1, pvs2[pvs2.length - 1].y * rat1, w20, w20, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.fill();
ctx.fillStyle = "red";
ctx.beginPath();
ctx.ellipse(pvs2[0].x * rat1, pvs2[0].y * rat1, w10, w10, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.fill();
ctx.beginPath();
ctx.ellipse(pvs2[pvs2.length - 1].x * rat1, pvs2[pvs2.length - 1].y * rat1, w10, w10, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.fill();
ctx.beginPath();
ctx.ellipse(pvs2[0].x * rat1, pvs2[0].y * rat1, w20, w20, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.stroke();
ctx.beginPath();
ctx.ellipse(pvs2[pvs2.length - 1].x * rat1, pvs2[pvs2.length - 1].y * rat1, w20, w20, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.stroke();
}
};
__publicField2(_DDeiLineCanvasRender, "ClsName", "DDeiLineCanvasRender");
let DDeiLineCanvasRender = _DDeiLineCanvasRender;
const __vite_glob_1_4$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiLineCanvasRender,
default: DDeiLineCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiPolygonCanvasRender = class _DDeiPolygonCanvasRender2 extends DDeiAbstractShapeRender {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "textUsedArea", []);
}
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiPolygonCanvasRender2(props);
}
// ============================== 方法 ===============================
/**
* 初始化
*/
init() {
this.ddRender = this.model.stage.ddInstance.render;
this.stage = this.model.stage;
this.stageRender = this.model.stage.render;
if (this.model.layer) {
this.layer = this.model.layer;
this.layerRender = this.model.layer.render;
}
}
initImage() {
let that = this;
let bgImage = DDeiUtil$1.getReplacibleValue(this.model, "fill.image");
if ((this.model.imgBase64 || bgImage) && !this.imgObj) {
let img = new Image();
img.onload = function() {
that.imgObj = img;
that.upFillImage = bgImage;
that.clearCachedValue();
that.ddRender.model.bus.push(DDeiEnumBusCommandType.RefreshShape, null, null);
that.ddRender.model.bus.executeAll();
};
img.src = this.model.imgBase64 ? this.model.imgBase64 : bgImage;
}
}
createTempShape() {
let stageRatio2 = this.model.getStageRatio();
let rat1 = this.ddRender.ratio;
if (!this.tempCanvas) {
this.tempCanvas = document.createElement("canvas");
this.tempCanvas.setAttribute("style", "pointer-events:none;position:absolute;-webkit-font-smoothing:antialiased;-moz-transform-origin:left top;-moz-transform:scale(" + 1 / rat1 + ");display:block;scale:" + 1 / rat1);
}
let tempCanvas = this.tempCanvas;
let pvs2 = this.model.operatePVS ? this.model.operatePVS : this.model.pvs;
let outRect = DDeiAbstractShape.pvsToOutRect(pvs2, stageRatio2);
let weight = 5;
outRect.x -= weight;
outRect.x1 += weight;
outRect.y -= weight;
outRect.y1 += weight;
outRect.width += 2 * weight;
outRect.height += 2 * weight;
tempCanvas.style.width = outRect.width;
tempCanvas.style.height = outRect.height;
tempCanvas.setAttribute("width", outRect.width * rat1);
tempCanvas.setAttribute("height", outRect.height * rat1);
let tempCtx = tempCanvas.getContext("2d", { willReadFrequently: true });
tempCanvas.tx = -outRect.x * rat1;
tempCanvas.ty = -outRect.y * rat1;
tempCanvas.outRect = outRect;
tempCtx.translate(tempCanvas.tx, tempCanvas.ty);
}
/**
* 绘制图形
*/
drawShape(tempShape, composeRender = 0, inRect = null, zIndex = 0) {
if (!inRect || this.model.isInRect(inRect.x, inRect.y, inRect.x1, inRect.y1)) {
this.tempZIndex = zIndex;
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_BEFORE", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
if (composeRender || rsState == 0 || rsState == 1) {
let rsState1 = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", DDeiEnumOperateType.VIEW, { models: [this.model], tempShape, composeRender }, this.ddRender.model, null);
if (rsState1 == 0 || rsState1 == 1) {
if (!this.viewer) {
const isModelVisible = !DDeiUtil$1.isModelHidden(this.model);
const shouldRefresh = this.refreshShape || this.isEditoring;
if (isModelVisible && shouldRefresh) {
this.createAndPrepareShape(tempShape);
const rendList = this.getCachedRenderList();
for (let ri = 0; ri < rendList.length; ri++) {
let c = rendList[ri];
if (c == this.model) {
this.renderSelf(tempShape, composeRender);
} else {
this.renderCompose(c, tempShape, composeRender, ri);
}
}
if (!this.isEditoring) {
this.refreshShape = false;
}
}
this.drawSelfToCanvas(composeRender, isModelVisible && shouldRefresh);
} else {
this.renderWithViewer(tempShape, composeRender);
}
}
if (!composeRender) {
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_AFTER", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
}
}
} else {
this.handleHiddenState();
}
}
// 新增的辅助方法
createAndPrepareShape(tempShape) {
this.createTempShape();
this.calScaleType3Size(tempShape);
this.calPVSS(tempShape);
}
getCachedRenderList() {
var _a3;
if (!this._cachedRenderList) {
this._cachedRenderList = [];
if (((_a3 = this.model.composes) == null ? void 0 : _a3.length) > 0) {
this._cachedRenderList = this._cachedRenderList.concat(this.model.composes);
}
this._cachedRenderList.push(this.model);
this._cachedRenderList.sort((a, b) => (a.cIndex || 0) - (b.cIndex || 0));
}
return this._cachedRenderList;
}
renderSelf(tempShape, composeRender) {
const canvas = this.getCanvas();
const ctx = canvas.getContext("2d");
ctx.save();
this.createClip(tempShape);
this.drawFill(tempShape);
this.drawText(tempShape);
this.drawBorder(tempShape);
ctx.restore();
}
renderCompose(c, tempShape, composeRender, index) {
if (tempShape && (tempShape == null ? void 0 : tempShape.drawCompose) == false) {
c.render.drawShape(null, composeRender + 1, null, this.tempZIndex + index);
} else {
c.render.drawShape(tempShape, composeRender + 1, null, this.tempZIndex + index);
}
}
renderWithViewer(tempShape, composeRender) {
if (!DDeiUtil$1.isModelHidden(this.model) && (this.refreshShape || this.isEditoring)) {
DDeiUtil$1.createRenderViewer(this.model, "VIEW", tempShape, composeRender);
} else {
DDeiUtil$1.createRenderViewer(this.model, "VIEW-HIDDEN");
}
}
handleHiddenState() {
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", "VIEW-HIDDEN", { models: [this.model] }, this.ddRender.model, null);
if (rsState == 0 || rsState == 1) {
if (!this.viewer) {
this.removeViewerCanvas();
} else {
DDeiUtil$1.createRenderViewer(this.model, "VIEW-HIDDEN");
}
}
}
/**
* 绘制自身到最外层canvas
*/
drawSelfToCanvas(composeRender, print) {
var _a3;
if (this.viewer) {
if (!DDeiUtil$1.isModelHidden(this.model) && this.refreshShape) {
DDeiUtil$1.createRenderViewer(this.model, "VIEW", null, composeRender);
} else {
DDeiUtil$1.createRenderViewer(this.model, "VIEW-HIDDEN");
}
} else if (this.tempCanvas) {
let model = this.model;
if (!DDeiUtil$1.isModelHidden(this.model)) {
let stage2 = model.stage;
let ruleWeight = 0;
if (stage2.render.tempRuleDisplay == 1 || stage2.render.tempRuleDisplay == "1") {
ruleWeight = 15;
}
let stageRatio2 = this.model.getStageRatio();
if (!this.tempCanvas.parentElement) {
let viewerEle = this.model.layer.render.containerViewer;
viewerEle.appendChild(this.tempCanvas);
}
this.tempCanvas.style.zIndex = this.tempZIndex;
this.tempCanvas.style.left = this.model.cpv.x * stageRatio2 + this.model.stage.wpv.x - this.tempCanvas.offsetWidth / 2 - ruleWeight + "px";
this.tempCanvas.style.top = this.model.cpv.y * stageRatio2 + this.model.stage.wpv.y - this.tempCanvas.offsetHeight / 2 - ruleWeight + "px";
let transform = "";
if (this.model.mirrorX) {
transform += " rotateY(180deg)";
}
if (this.model.mirrorY) {
transform += " rotateX(180deg)";
}
this.tempCanvas.style.transform = transform;
if (!print) {
(_a3 = this.model.composes) == null ? void 0 : _a3.forEach((comp) => {
comp.render.drawSelfToCanvas(composeRender + 1);
});
}
} else {
this.removeViewerCanvas();
}
}
}
getRenderCanvas(composeRender) {
var _a3;
if (composeRender) {
return this.model.pModel.render.getCanvas();
} else if (this.model.pModel.baseModelType == "DDeiContainer") {
return this.model.pModel.render.getCanvas();
} else {
return (_a3 = this.ddRender) == null ? void 0 : _a3.getCanvas();
}
}
getCanvas() {
if (this.tempCanvas) {
return this.tempCanvas;
} else {
return this.getRenderCanvas();
}
}
/**
* 创建剪切区
* @param tempShape
*/
createClip(tempShape) {
var _a3, _b2, _c2, _d2, _e2;
let i2 = 0;
let createClip = false;
for (; i2 < this.borderPVSS.length; i2++) {
if (this.borderPVSS[i2][0].clip == 1) {
createClip = true;
break;
}
}
if (createClip) {
let type = ((_a3 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _a3.type) || ((_b2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _b2.type) == 0 ? (_c2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _c2.type : this.getCachedValue("border.type");
let width = ((_d2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _d2.width) ? (_e2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _e2.width : this.getCachedValue("border.width");
let pvs2 = this.borderPVSS[i2];
if ((type == 1 || type == "1") && width > 0) {
let stageRatio2 = this.model.getStageRatio();
width *= stageRatio2;
let rat1 = this.ddRender.ratio;
if (pvs2.length == 1) {
pvs2 = cloneDeep(pvs2);
pvs2[0].r = pvs2[0].r * (1 + rat1 * width / this.model.width);
} else {
pvs2 = DDeiUtil$1.pointsToZero(pvs2, this.model.cpv, this.model.rotate);
pvs2 = DDeiUtil$1.zeroToPoints(pvs2, this.model.cpv, this.model.rotate, 1 + rat1 * width / this.model.width, 1 + rat1 * width / this.model.height);
}
}
let canvas = this.getCanvas();
let ctx = canvas.getContext("2d");
this.createPath(pvs2, tempShape);
ctx.clip();
}
}
/**
* 生成边框的区域向量
*/
getBorderPVS(pvs2, tempShape) {
var _a3, _b2, _c2, _d2, _e2;
let stageRatio2 = this.model.getStageRatio();
let round = ((_a3 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _a3.round) ? (_b2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _b2.round : this.getCachedValue("border.round");
((_c2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _c2.type) || ((_d2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _d2.type) == 0 ? (_e2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _e2.type : this.getCachedValue("border.type");
if (!round) {
round = 0;
}
let borderPVS = [];
for (let s = 0; s < pvs2.length; s++) {
borderPVS[s] = clone(pvs2[s]);
}
for (let i2 = 1; i2 < borderPVS.length + 1; i2++) {
let rd = round;
let s = i2;
let e = s + 1;
let upI = s - 1;
if (s == borderPVS.length - 1) {
e = 0;
} else if (s == borderPVS.length) {
s = 0;
e = 1;
upI = borderPVS.length - 1;
}
if (borderPVS[s].rd || borderPVS[s].rd == 0) {
rd = borderPVS[s].rd;
}
if (rd && (borderPVS[s].stroke || borderPVS[s].fill)) {
let usx = borderPVS[upI].x;
let usy = borderPVS[upI].y;
let sx = borderPVS[s].x;
let sy = borderPVS[s].y;
let ex = borderPVS[e].x;
let ey = borderPVS[e].y;
let lineRadius = DDeiUtil$1.getLinesAngle(usx, usy, sx, sy, sx, sy, ex, ey, true) / 2;
let lineBCDistance = DDeiUtil$1.getPointDistance(sx, sy, ex, ey);
let lineABDistance = DDeiUtil$1.getPointDistance(usx, usy, sx, sy);
let tanRadis = Math.tan(lineRadius);
let maxR = Math.abs(tanRadis * lineBCDistance);
rd = Math.min(maxR, rd, lineBCDistance / 2, lineABDistance / 2);
rd *= stageRatio2;
let lineBC1Distance = Math.abs(rd / tanRadis);
let distLength = Math.min(lineBCDistance / 2, lineABDistance / 2, lineBC1Distance);
let bc1pv = DDeiUtil$1.getPathPoint(sx, sy, ex, ey, 1, distLength, -1, lineBCDistance);
borderPVS[s].roundDistLength = distLength;
borderPVS[s].roundVal = rd;
borderPVS[s].roundPV = bc1pv;
}
}
return borderPVS;
}
/**
* 取得边框的绘制区域
*/
getBorderRatPos() {
let stageRatio2 = this.model.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
let absBounds = this.model.getAbsBounds();
return DDeiUtil$1.getRatioPosition(absBounds, ratio);
}
/**
* 对pvs按group进行拆分,
*/
calPVSS(tempShape) {
let pvss = [];
let curPVS = null;
let curGroup = -1;
let len1 = this.model.pvs.length;
for (let i2 = 0; i2 < len1; i2++) {
if (curGroup != this.model.pvs[i2].group) {
curGroup = this.model.pvs[i2].group;
curPVS = [];
pvss.push(curPVS);
}
curPVS == null ? void 0 : curPVS.push(this.model.pvs[i2]);
}
let borderPVSS = [];
pvss.forEach((pvs2) => {
if (pvs2.length > 2) {
let borderPVS = this.getBorderPVS(pvs2, tempShape);
borderPVSS.push(borderPVS);
} else {
borderPVSS.push(pvs2);
}
});
this.pvss = pvss;
this.borderPVSS = borderPVSS;
}
/**
* 创建路径
*/
createPath(pvs2, tempShape, drawLine = false) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m;
let canvas = this.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let rat1 = this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
rat1 = ratio;
let type = ((_a3 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _a3.type) || ((_b2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _b2.type) == 0 ? (_c2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _c2.type : this.getCachedValue("border.type");
let color = ((_d2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _d2.color) ? (_e2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _e2.color : this.getCachedValue("border.color");
if (!color) {
color = DDeiUtil$1.getStyleValue("canvas-control-border", this.ddRender.model);
}
let opacity = ((_f = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _f.opacity) ? (_g = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _g.opacity : this.getCachedValue("border.opacity");
let width = ((_h = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _h.width) ? (_i = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _i.width : this.getCachedValue("border.width");
let dash = ((_j = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _j.dash) ? (_k = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _k.dash : this.getCachedValue("border.dash");
let lineWidth = width * ratio;
drawLine = drawLine && ((type == 1 || type == "1") && (!opacity || opacity > 0) && width > 0);
((_l = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _l.round) ? (_m = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _m.round : this.getCachedValue("border.round");
if (!pvs2 || (pvs2 == null ? void 0 : pvs2.length) < 1) {
return;
}
let rest = false;
if (drawLine) {
ctx.save();
ctx.lineWidth = lineWidth;
if (dash) {
ctx.setLineDash(dash);
}
if (opacity != null && opacity != void 0) {
ctx.globalAlpha = opacity;
}
ctx.strokeStyle = DDeiUtil$1.getColor(color);
if (pvs2[0].strokeClear) {
ctx.globalCompositeOperation = "destination-out";
}
}
if ((pvs2 == null ? void 0 : pvs2.length) > 2) {
let len = pvs2.length;
if (pvs2[0].begin) {
ctx.beginPath();
}
if (!pvs2[0].roundPV) {
ctx.moveTo(pvs2[0].x * rat1, pvs2[0].y * rat1);
} else {
ctx.moveTo(pvs2[0].roundPV.x * rat1, pvs2[0].roundPV.y * rat1);
}
for (let i2 = 1; i2 < len; i2++) {
let pv = pvs2[i2];
let s = i2;
let e = i2 + 1;
if (i2 == len - 1) {
e = 0;
}
let dx = pv.dx ? pv.dx : 0;
let dy = pv.dy ? pv.dy : 0;
if (pv.begin) {
ctx.beginPath();
}
if (pv.move) {
ctx.moveTo(pv.x * rat1, pv.y * rat1);
}
if (pv.type == 3 || drawLine && !pv.stroke) {
ctx.moveTo(pv.x * rat1, pv.y * rat1);
} else if (pv.type == 2 || pv.type == 4) {
let rotate2 = this.model.rotate;
if (!rotate2) {
rotate2 = 0;
}
let bpv2 = DDeiUtil$1.pointsToZero([this.model.bpv], this.model.cpv, rotate2)[0];
let scaleX2 = Math.abs(bpv2.x / 100);
let scaleY2 = Math.abs(bpv2.y / 100);
let upPV = pvs2[i2 - 1];
let wr = upPV.r;
let hr = upPV.r;
if (pv.type == 4) {
wr = pvs2[i2 + 1].r;
hr = pvs2[i2 + 2].r;
i2 = i2 + 2;
}
ctx.ellipse((this.model.cpv.x + dx) * rat1, (this.model.cpv.y + dy) * rat1, wr * rat1 * scaleX2, hr * rat1 * scaleY2, DDeiConfig$1.ROTATE_UNIT * rotate2, upPV.rad, pv.rad, !pv.direct);
} else if (pv.type == 5) {
let i1 = i2 + 1;
let i22 = i2 + 2;
let i3 = i2 + 3;
i2 = i2 + 3;
ctx.bezierCurveTo(pvs2[i1].x * rat1, pvs2[i1].y * rat1, pvs2[i22].x * rat1, pvs2[i22].y * rat1, pvs2[i3].x * rat1, pvs2[i3].y * rat1);
} else {
let sx = pvs2[s].x * rat1;
let sy = pvs2[s].y * rat1;
if (!pvs2[s].roundVal) {
let ex = pvs2[e].x * rat1;
let ey = pvs2[e].y * rat1;
ctx.lineTo(sx, sy, ex, ey);
} else {
let rd = pvs2[s].roundVal;
let ex = pvs2[s].roundPV.x * rat1;
let ey = pvs2[s].roundPV.y * rat1;
ctx.arcTo(sx, sy, ex, ey, rd);
}
}
if (i2 == len - 1 && pvs2[0].roundVal) {
let rd = pvs2[0].roundVal;
let ex = pvs2[0].roundPV.x * rat1;
let ey = pvs2[0].roundPV.y * rat1;
ctx.arcTo(pvs2[0].x * rat1, pvs2[0].y * rat1, ex, ey, rd);
}
if (pv.end) {
ctx.closePath();
}
if ((drawLine || pv.forceStroke) && pv.stroke) {
if (pv.forceStroke) {
ctx.strokeStyle = DDeiUtil$1.getColor(color);
}
rest = true;
ctx.stroke();
}
}
} else if (pvs2.length == 1) {
let pv = pvs2[0];
if (pv.begin) {
ctx.beginPath();
}
let rotate2 = this.model.rotate;
if (!rotate2) {
rotate2 = 0;
}
let bpv2 = DDeiUtil$1.pointsToZero([this.model.bpv], this.model.cpv, rotate2)[0];
let scaleX2 = Math.abs(bpv2.x / 100);
let scaleY2 = Math.abs(bpv2.y / 100);
let x2 = pv.cx || pv.cx == 0 ? this.model.cpv.x + pv.cx : this.model.cpv.x;
let y2 = pv.cy || pv.cy == 0 ? this.model.cpv.y + pv.cy : this.model.cpv.y;
ctx.ellipse(x2 * rat1, y2 * rat1, pv.r * rat1 * scaleX2, pv.r * rat1 * scaleY2, DDeiConfig$1.ROTATE_UNIT * rotate2, DDeiConfig$1.ROTATE_UNIT * 0, Math.PI * 2);
if (pv.end) {
ctx.closePath();
}
if (drawLine && pv.stroke) {
ctx.stroke();
}
} else if (pvs2.length == 2) {
if (pvs2[0].begin) {
ctx.beginPath();
}
if (pvs2[1].type == 1) {
ctx.moveTo(pvs2[0].x * rat1, pvs2[0].y * rat1);
ctx.lineTo(pvs2[1].x * rat1, pvs2[1].y * rat1);
} else {
let rotate2 = this.model.rotate;
if (!rotate2) {
rotate2 = 0;
}
let bpv2 = DDeiUtil$1.pointsToZero([this.model.bpv], this.model.cpv, rotate2)[0];
let scaleX2 = Math.abs(bpv2.x / 100);
let scaleY2 = Math.abs(bpv2.y / 100);
ctx.moveTo(this.model.cpv.x * rat1, this.model.cpv.y * rat1);
ctx.lineTo(pvs2[0].x * rat1, pvs2[0].y * rat1);
ctx.ellipse(this.model.cpv.x * rat1, this.model.cpv.y * rat1, pvs2[0].r * rat1 * scaleX2, pvs2[0].r * rat1 * scaleY2, DDeiConfig$1.ROTATE_UNIT * rotate2, pvs2[0].rad, pvs2[1].rad, !pvs2[1].direct);
ctx.lineTo(pvs2[1].x * rat1, pvs2[1].y * rat1);
}
if (pvs2[1].end) {
ctx.closePath();
}
if (drawLine && pvs2[1].stroke) {
ctx.stroke();
}
}
if (drawLine || rest) {
ctx.restore();
}
}
/**
* 绘制边框
* @param tempShape 临时图形,优先级最高
*/
drawBorder(tempShape) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j;
((_a3 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _a3.type) || ((_b2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _b2.type) == 0 ? (_c2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _c2.type : this.getCachedValue("border.type");
((_d2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _d2.opacity) || ((_e2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _e2.opacity) == 0 ? (_f = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _f.opacity : this.getCachedValue("border.opacity");
((_g = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _g.width) || ((_h = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _h.width) == 0 ? (_i = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _i.width : this.getCachedValue("border.width");
for (let i2 = 0; i2 < ((_j = this.borderPVSS) == null ? void 0 : _j.length); i2++) {
let pvs2 = this.borderPVSS[i2];
this.createPath(pvs2, tempShape, true);
}
}
/**
* 绘制边框以及Compose的边框
* @param tempShape 临时图形,优先级最高
*/
drawBorderAndComposesBorder(tempShape, drawCompose = true) {
let rsState1 = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", DDeiEnumOperateType.VIEW, { models: [this.model], tempShape, composeRender: drawCompose }, this.ddRender.model, null);
if (rsState1 == 0 || rsState1 == 1) {
let rendList = DDeiUtil$1.sortRendList(this.model);
this.createTempShape();
rendList.forEach((c) => {
if (c == this.model) {
this.drawBorder(tempShape);
} else if (drawCompose) {
c.render.drawBorder(tempShape, true);
c.render.drawSelfToCanvas(1);
}
});
this.drawSelfToCanvas(0);
}
}
/**
* 填充图片
*/
drawImage() {
var _a3;
let bgImage = DDeiUtil$1.getReplacibleValue(this.model, "fill.image");
if (!this.imgObj || bgImage != this.upFillImage) {
this.initImage();
} else {
let canvas = this.getCanvas();
let ctx = canvas.getContext("2d");
let rat1 = this.ddRender.oldRatio ? this.ddRender.oldRatio : this.ddRender.ratio;
let fillRect = this.model.essBounds;
ctx.save();
let imgFillInfo = this.getCachedValue("fill.opacity");
if (imgFillInfo) {
ctx.globalAlpha = imgFillInfo;
}
let lineOffset = 0;
ctx.translate(this.model.cpv.x * rat1, this.model.cpv.y * rat1);
ctx.rotate(this.model.rotate * DDeiConfig$1.ROTATE_UNIT);
ctx.translate(-this.model.cpv.x * rat1, -this.model.cpv.y * rat1);
ctx.imageSmoothingQuality = "high";
let ratio = rat1 * ((_a3 = this.stage) == null ? void 0 : _a3.getStageRatio());
ctx.drawImage(this.imgObj, 0, 0, this.imgObj.width, this.imgObj.height, (this.model.cpv.x - fillRect.width / 2) * ratio + lineOffset, (this.model.cpv.y - fillRect.height / 2) * ratio + lineOffset, fillRect.width * ratio, fillRect.height * ratio);
ctx.restore();
}
}
/**
* 绘制填充
*/
drawFill(tempShape) {
var _a3, _b2, _c2, _d2, _e2;
let canvas = this.getCanvas();
let ctx = canvas.getContext("2d");
let fillColor = ((_a3 = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _a3.color) ? tempShape.fill.color : this.getCachedValue("fill.color");
if (!fillColor) {
fillColor = DDeiUtil$1.getStyleValue("canvas-control-background", this.ddRender.model);
}
let fillOpacity = ((_b2 = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _b2.opacity) ? tempShape.fill.opacity : this.getCachedValue("fill.opacity");
let fillType = ((_c2 = tempShape == null ? void 0 : tempShape.fill) == null ? void 0 : _c2.type) ? tempShape.fill.type : this.getCachedValue("fill.type");
ctx.save();
let haveFilled = false;
for (let i2 = 0; i2 < this.borderPVSS.length; i2++) {
if (this.borderPVSS[i2][0].fill == 1) {
let hasOpacity = false;
haveFilled = true;
let pvs2 = this.borderPVSS[i2];
if (pvs2[0].fillColor) {
if (pvs2[0].fillColor == "none") {
ctx.save();
hasOpacity = true;
ctx.globalCompositeOperation = "destination-out";
fillColor = DDeiUtil$1.getColor("black");
} else if (pvs2[0].fillColor == "border") {
fillColor = ((_d2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _d2.color) ? (_e2 = tempShape == null ? void 0 : tempShape.border) == null ? void 0 : _e2.color : this.getCachedValue("border.color");
if (!fillColor) {
fillColor = DDeiUtil$1.getStyleValue("canvas-control-border", this.ddRender.model);
}
} else {
fillColor = DDeiUtil$1.getColor(pvs2[0].fillColor);
}
}
this.createPath(pvs2, tempShape);
if (this.isEditoring) {
if (!fillType || fillType == "0") {
fillType = 1;
}
}
if (fillType == 1) {
if (this.isEditoring) {
fillOpacity = 1;
}
if (fillColor && (!fillOpacity || fillOpacity > 0)) {
ctx.fillStyle = DDeiUtil$1.getColor(fillColor);
if (fillOpacity != null && !fillOpacity != void 0) {
ctx.globalAlpha = fillOpacity;
}
if (pvs2[0].fillClear) {
ctx.globalCompositeOperation = "destination-out";
}
ctx.fill();
}
} else if (fillType == 2) {
this.drawImage();
}
if (hasOpacity) {
ctx.restore();
}
}
}
if (!haveFilled && this.isEditoring) {
let pvs2 = this.model.textArea;
this.createPath(pvs2, tempShape);
ctx.globalAlpha = 1;
if (!fillColor) {
fillColor = "white";
}
ctx.fillStyle = DDeiUtil$1.getColor(fillColor);
ctx.fill();
}
ctx.restore();
}
/**
* 绘制文本
*/
drawText(tempShape) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L;
let align = this.getCachedValue("textStyle.align");
let valign = this.getCachedValue("textStyle.valign");
let scale = this.getCachedValue("textStyle.scale");
let feed = this.getCachedValue("textStyle.feed");
let hspace = this.getCachedValue("textStyle.hspace");
let vspace = this.getCachedValue("textStyle.vspace");
let fiFamily = this.getCachedValue("font.family");
let fiSize = this.getCachedValue("font.size");
let fiColor = this.getCachedValue("font.color");
if (!fiColor) {
fiColor = DDeiUtil$1.getStyleValue("canvas-control-title", this.ddRender.model);
}
let hollow = this.getCachedValue("textStyle.hollow");
let bold = this.getCachedValue("textStyle.bold");
let italic = this.getCachedValue("textStyle.italic");
let underline = this.getCachedValue("textStyle.underline");
let deleteline = this.getCachedValue("textStyle.deleteline");
let topline = this.getCachedValue("textStyle.topline");
let textBgColor = this.getCachedValue("textStyle.bgcolor");
if (!this.model.textArea || this.model.textArea.length < 4) {
return;
}
let fillRect = this.tempFillRect;
if (!fillRect || fillRect.width == -Infinity || fillRect == -Infinity) {
return;
}
let canvas = this.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let rat1 = this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
rat1 = ratio;
let ratPos = DDeiUtil$1.getRatioPosition(fillRect, rat1);
ctx.textAlign = "left";
ctx.textBaseline = "top";
let editorText = null;
if (this.isEditoring) {
editorText = DDeiUtil$1.getEditorText();
}
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
this.stageRender.editorShadowControl.tempCursorStart = curSIdx;
this.stageRender.editorShadowControl.tempCursorEnd = curEIdx;
}
if (!hspace) {
hspace = 0;
}
if (!vspace) {
vspace = 0;
}
hspace = hspace * ratio;
vspace = vspace * ratio;
ctx.save();
ctx.translate(this.model.cpv.x * rat1, this.model.cpv.y * rat1);
ctx.rotate(this.model.rotate * DDeiConfig$1.ROTATE_UNIT);
let textContainer = [];
let loop2 = true;
let fontSize = fiSize;
let cText = null;
let sptStyle = null;
if (this.isEditoring) {
sptStyle = this.model.sptStyle;
cText = this.getCachedValue("text");
} else {
cText = DDeiUtil$1.getReplacibleValue(this.model, "text", true, true);
sptStyle = this.tempSptStyle ? this.tempSptStyle : (tempShape == null ? void 0 : tempShape.sptStyle) ? tempShape.sptStyle : this.model.sptStyle;
}
if (!cText) {
cText = "";
}
let contentWidth = ratPos.width;
let subtractionFontSize = 0;
let isOutSize = false;
let dotRect = null;
if (scale == 3) {
textContainer = this.tempTextContainer;
} else {
while (loop2) {
let usedWidth = 0;
let usedHeight = 0;
let textRowContainer = { text: "", widths: [], heights: [], dHeights: [] };
textContainer.push(textRowContainer);
isOutSize = false;
let maxFontSize = 0;
if (fontSize + vspace > ratPos.height) {
if (scale == 1) {
textContainer = [];
let ds = fontSize < 50 ? 0.5 : Math.floor(fontSize / 50);
fontSize -= ds;
vspace -= ds;
if (vspace < 0) {
vspace = 0;
}
continue;
}
}
let baseFont = fontSize + "px " + fiFamily;
if (bold == "1") {
baseFont = "bold " + baseFont;
}
if (italic == "1") {
baseFont = "italic " + baseFont;
}
let rcIndex = 0;
let lastUnSubTypeFontSize2 = 0;
for (let ti = 0; ti < cText.length; ti++, rcIndex++) {
let te = cText[ti];
let font = null;
let fontHeight = null;
let isEnter = false;
let fontShapeRect = null;
if ((feed == 1 || feed == "1") && te == "\n") {
isEnter = true;
textRowContainer.text += te;
textRowContainer.widths[rcIndex] = 0;
textRowContainer.heights[rcIndex] = 0;
textRowContainer.width = Math.max(0, usedWidth);
textRowContainer.height = Math.max(0, textRowContainer.height ? textRowContainer.height : 0, lastUnSubTypeFontSize2 ? lastUnSubTypeFontSize2 * ratio + vspace : fontSize * ratio + vspace);
} else {
if (sptStyle[ti]) {
let ftsize = ((_b2 = (_a3 = sptStyle[ti]) == null ? void 0 : _a3.font) == null ? void 0 : _b2.size) ? ((_d2 = (_c2 = sptStyle[ti]) == null ? void 0 : _c2.font) == null ? void 0 : _d2.size) - subtractionFontSize : fontSize;
if ((_e2 = sptStyle[ti].textStyle) == null ? void 0 : _e2.subtype) {
if (!lastUnSubTypeFontSize2) {
lastUnSubTypeFontSize2 = ftsize;
}
ftsize = lastUnSubTypeFontSize2 / 2;
} else if (ftsize < 1) {
ftsize = 2;
}
let ftfamily = ((_g = (_f = sptStyle[ti]) == null ? void 0 : _f.font) == null ? void 0 : _g.family) ? (_i = (_h = sptStyle[ti]) == null ? void 0 : _h.font) == null ? void 0 : _i.family : fiFamily;
font = ftsize + "px " + ftfamily;
if (((_k = (_j = sptStyle[ti]) == null ? void 0 : _j.textStyle) == null ? void 0 : _k.bold) == "1") {
font = "bold " + font;
}
if (((_m = (_l = sptStyle[ti]) == null ? void 0 : _l.textStyle) == null ? void 0 : _m.italic) == "1") {
font = "italic " + font;
}
fontHeight = ftsize;
}
if (!font) {
font = baseFont;
fontHeight = fontSize;
}
if (!((_o = (_n = sptStyle[ti]) == null ? void 0 : _n.textStyle) == null ? void 0 : _o.subtype)) {
lastUnSubTypeFontSize2 = fontHeight;
}
maxFontSize = Math.max(maxFontSize, fontHeight);
let rc1 = DDeiUtil$1.measureText(te, font, ctx, fontHeight);
if (!dotRect) {
dotRect = DDeiUtil$1.measureText("...", font, ctx, fontHeight);
}
fontShapeRect = { width: rc1.width * ratio + hspace, height: rc1.height * ratio, dHeight: rc1.dHeight * ratio };
usedWidth += fontShapeRect.width;
textRowContainer.text += te;
textRowContainer.widths[rcIndex] = fontShapeRect.width;
textRowContainer.heights[rcIndex] = fontShapeRect.height + vspace;
textRowContainer.dHeights[rcIndex] = fontShapeRect.dHeight;
textRowContainer.width = usedWidth;
textRowContainer.height = Math.max(fontShapeRect.height + vspace, textRowContainer.height ? textRowContainer.height : 0, lastUnSubTypeFontSize2 ? lastUnSubTypeFontSize2 * ratio + vspace : fontSize * ratio + vspace);
}
if (feed == 0) {
if (usedWidth > contentWidth) {
if (scale == 1 || scale == 2) {
isOutSize = true;
break;
}
}
} else if (feed == 1 || feed == "1") {
if (isEnter) {
usedWidth = 0;
usedHeight += textRowContainer.height;
if (usedHeight + textRowContainer.height > ratPos.height) {
if (scale == 1 || scale == 2) {
isOutSize = true;
break;
}
break;
}
rcIndex = -1;
let lastRowHeight = textRowContainer.height;
textRowContainer = { text: "", widths: [], heights: [], dHeights: [] };
textRowContainer.width = usedWidth;
textRowContainer.height = lastRowHeight;
textContainer.push(textRowContainer);
} else if (usedWidth > contentWidth) {
textRowContainer.text = textRowContainer.text.substring(0, textRowContainer.text.length - 1);
textRowContainer.width -= fontShapeRect.width;
textRowContainer.widths.splice(rcIndex, 1);
textRowContainer.heights.splice(rcIndex, 1);
usedWidth = fontShapeRect.width;
usedHeight += textRowContainer.height;
if (usedHeight + textRowContainer.height > ratPos.height) {
if (scale == 1 || scale == 2) {
isOutSize = true;
break;
}
break;
}
rcIndex = 0;
textRowContainer = { text: te, widths: [], heights: [], dHeights: [] };
textRowContainer.widths[rcIndex] = fontShapeRect.width;
textRowContainer.heights[rcIndex] = fontShapeRect.height + vspace;
textRowContainer.dHeights[rcIndex] = fontShapeRect.dHeight;
textRowContainer.width = usedWidth;
textRowContainer.height = Math.max(fontShapeRect.height + vspace, lastUnSubTypeFontSize2 * ratio + vspace);
textContainer.push(textRowContainer);
}
}
}
if (!isOutSize) {
loop2 = false;
} else if (scale == 1) {
textContainer = [];
let ds = maxFontSize < 50 ? 0.5 : Math.floor(maxFontSize / 50);
fontSize -= ds;
vspace -= ds;
if (vspace < 0) {
vspace = 0;
}
subtractionFontSize += ds;
} else {
loop2 = false;
}
}
if (isOutSize) {
if (scale == 2) {
if (textContainer.length > 0) {
let lastText = textContainer[textContainer.length - 1].text;
let widths = textContainer[textContainer.length - 1].widths;
let heights = textContainer[textContainer.length - 1].heights;
let dHeights = textContainer[textContainer.length - 1].dHeights;
let dotWidth = dotRect.width / 3;
if (lastText.length > 0) {
textContainer[textContainer.length - 1].width = textContainer[textContainer.length - 1].width - widths[widths.length - 1] + dotRect.width;
lastText = lastText.substring(0, lastText.length - 1);
widths.splice(widths.length - 1, 1, dotWidth, dotWidth, dotWidth);
heights.splice(heights.length - 1, 1, heights[heights.length - 1], heights[heights.length - 1], heights[heights.length - 1]);
dHeights.splice(dHeights.length - 1, 1, dHeights[dHeights.length - 1], dHeights[dHeights.length - 1], dHeights[dHeights.length - 1]);
lastText += "...";
textContainer[textContainer.length - 1].text = lastText;
}
}
}
}
}
let containerRect = { width: 0, height: 0 };
for (let i2 = 0; i2 < textContainer.length; i2++) {
if (i2 == 0) {
containerRect.width += textContainer[i2].width;
}
containerRect.height += textContainer[i2].height;
}
let containerWidth = containerRect.width;
let containerHeight = containerRect.height;
let x2, y2;
if (align == 1) {
x2 = 0;
} else if (align == 2) {
x2 = (ratPos.width - containerWidth) * 0.5;
} else if (align == 3) {
x2 = ratPos.width - containerWidth;
}
x2 = x2 + ratPos.x;
if (valign == 1) {
y2 = 0;
} else if (valign == 2) {
y2 = (ratPos.height - containerHeight) * 0.5;
} else if (valign == 3) {
y2 = ratPos.height - containerHeight;
}
y2 = y2 + ratPos.y;
let cursorX = -Infinity;
let cursorY = -Infinity;
let cursorHeight = 0;
let tempIdx = 0;
let usedY = 0, usedX = 0;
let lastUsedX, lastUsedY, lastWidth, lastHeight;
let lastUnSubTypeFontSize = 0;
if (textContainer.length > 0) {
textContainer[0].textPosCache = [];
}
for (let tci = 0; tci < textContainer.length; tci++) {
lastUsedX = 0;
let rRect = textContainer[tci];
let x1, y1;
if (align == 1) {
x1 = x2;
y1 = y2 + usedY;
} else if (align == 2) {
x1 = ratPos.x + (ratPos.width - rRect.width) * 0.5;
y1 = y2 + usedY;
} else if (align == 3) {
x1 = ratPos.x + (ratPos.width - rRect.width);
y1 = y2 + usedY;
}
textContainer[tci].x = x1;
textContainer[tci].y = y1;
usedX = x1;
for (let tj = 0; tj < textContainer[tci].text.length; tj++, tempIdx++) {
let width = textContainer[tci].widths[tj];
let height = textContainer[tci].heights[tj];
lastWidth = width;
lastHeight = height;
ctx.save();
let font = fontSize * ratio + "px " + fiFamily;
if (bold == "1") {
font = "bold " + font;
}
if (italic == "1") {
font = "italic " + font;
}
let tHollow = hollow;
let tUnderline = underline;
let tDeleteline = deleteline;
let tTopline = topline;
let tFontColor = fiColor;
let tBgColor = textBgColor;
let ftsize = fontSize * ratio;
let subScriptOffY = 0;
if (sptStyle[tempIdx]) {
tBgColor = ((_p = sptStyle[tempIdx].textStyle) == null ? void 0 : _p.bgcolor) ? sptStyle[tempIdx].textStyle.bgcolor : textBgColor;
ftsize = ((_q = sptStyle[tempIdx].font) == null ? void 0 : _q.size) ? ((_r = sptStyle[tempIdx].font) == null ? void 0 : _r.size) - subtractionFontSize : fontSize;
ftsize *= ratio;
if ((_s = sptStyle[tempIdx].textStyle) == null ? void 0 : _s.subtype) {
if (!lastUnSubTypeFontSize) {
lastUnSubTypeFontSize = ftsize;
}
ftsize = lastUnSubTypeFontSize / 2;
switch ((_t = sptStyle[tempIdx].textStyle) == null ? void 0 : _t.subtype) {
case 1:
subScriptOffY = -(lastUnSubTypeFontSize - ftsize);
break;
case 2:
subScriptOffY = -(lastUnSubTypeFontSize - ftsize) / 2;
break;
}
} else if (ftsize < 1) {
ftsize = 2 * ratio;
}
let ftfamily = ((_u = sptStyle[tempIdx].font) == null ? void 0 : _u.family) ? (_v = sptStyle[tempIdx].font) == null ? void 0 : _v.family : fiFamily;
font = ftsize + "px " + ftfamily;
if (((_x = (_w = sptStyle[tempIdx]) == null ? void 0 : _w.textStyle) == null ? void 0 : _x.bold) == "1") {
font = "bold " + font;
}
if (((_z = (_y = sptStyle[tempIdx]) == null ? void 0 : _y.textStyle) == null ? void 0 : _z.italic) == "1") {
font = "italic " + font;
}
tHollow = ((_B = (_A = sptStyle[tempIdx]) == null ? void 0 : _A.textStyle) == null ? void 0 : _B.hollow) == "1" ? "1" : tHollow;
tUnderline = ((_D = (_C = sptStyle[tempIdx]) == null ? void 0 : _C.textStyle) == null ? void 0 : _D.underline) == "1" ? "1" : tUnderline;
tDeleteline = ((_F = (_E = sptStyle[tempIdx]) == null ? void 0 : _E.textStyle) == null ? void 0 : _F.deleteline) == "1" ? "1" : tDeleteline;
tTopline = ((_H = (_G = sptStyle[tempIdx]) == null ? void 0 : _G.textStyle) == null ? void 0 : _H.topline) == "1" ? "1" : tTopline;
tFontColor = ((_J = (_I = sptStyle[tempIdx]) == null ? void 0 : _I.font) == null ? void 0 : _J.color) ? sptStyle[tempIdx].font.color : tFontColor;
}
if (!((_L = (_K = sptStyle[tempIdx]) == null ? void 0 : _K.textStyle) == null ? void 0 : _L.subtype)) {
lastUnSubTypeFontSize = ftsize;
}
if (!textContainer[tci].tHollow) {
textContainer[tci].tHollow = [];
textContainer[tci].tUnderline = [];
textContainer[tci].tDeleteline = [];
textContainer[tci].tTopline = [];
textContainer[tci].tFontColor = [];
textContainer[tci].font = [];
textContainer[tci].subScriptOffY = [];
}
textContainer[tci].tHollow[tj] = tHollow;
textContainer[tci].tUnderline[tj] = tUnderline;
textContainer[tci].tDeleteline[tj] = tDeleteline;
textContainer[tci].tTopline[tj] = tTopline;
textContainer[tci].tFontColor[tj] = tFontColor;
textContainer[tci].font[tj] = font;
textContainer[tci].subScriptOffY[tj] = subScriptOffY;
let ofY = rRect.height - height + subScriptOffY;
if (tempIdx >= curSIdx && tempIdx < curEIdx) {
ctx.save();
ctx.fillStyle = DDeiUtil$1.getStyleValue("canvas-text-selection", this.ddRender.model);
ctx.globalAlpha = 1;
ctx.fillRect(usedX - 0.5, y1 + ofY, width + 1, height);
ctx.restore();
} else if (tBgColor) {
ctx.save();
ctx.fillStyle = DDeiUtil$1.getColor(tBgColor);
ctx.fillRect(usedX - 0.5, y1 + ofY, width + 1, height);
ctx.restore();
}
if (curSIdx == curEIdx && tempIdx == curEIdx) {
cursorX = usedX;
cursorHeight = tj > 1 ? textContainer[tci].heights[tj - 1] : height;
ofY = rRect.height - cursorHeight + (tj > 1 ? textContainer[tci].subScriptOffY[tj - 1] : subScriptOffY);
cursorY = y1 + ofY;
}
ctx.fillStyle = tFontColor;
ctx.font = font;
lastUsedY = y1 + ofY;
lastUsedX = usedX;
usedX += width;
ctx.restore();
}
usedX = x1;
for (let tj = 0; tj < textContainer[tci].text.length; tj++) {
let outputText = textContainer[tci].text[tj];
let width = textContainer[tci].widths[tj];
let height = textContainer[tci].heights[tj];
ctx.save();
let tHollow = textContainer[tci].tHollow[tj];
let tUnderline = textContainer[tci].tUnderline[tj];
let tDeleteline = textContainer[tci].tDeleteline[tj];
let tTopline = textContainer[tci].tTopline[tj];
let tFontColor = textContainer[tci].tFontColor[tj];
let font = textContainer[tci].font[tj];
let subScriptOffY = textContainer[tci].subScriptOffY[tj];
let dfh = textContainer[tci].dHeights[tj];
let ofY = rRect.height - height + subScriptOffY + dfh;
ctx.fillStyle = tFontColor;
ctx.font = font;
if (tHollow == "1") {
ctx.strokeStyle = tFontColor;
ctx.strokeText(outputText, usedX, y1 + ofY);
} else {
ctx.fillText(outputText, usedX, y1 + ofY);
}
if (curSIdx != -1 && curEIdx != -1) {
textContainer[0].textPosCache.push({ x: usedX, y: y1 + ofY });
}
if (tUnderline == "1") {
ctx.beginPath();
ctx.strokeStyle = tFontColor;
ctx.moveTo(usedX, y1 + ofY + height);
ctx.lineTo(usedX + width, y1 + ofY + height);
ctx.closePath();
ctx.stroke();
}
if (tDeleteline == "1") {
ctx.beginPath();
ctx.strokeStyle = tFontColor;
ctx.moveTo(usedX, y1 + ofY + height / 2);
ctx.lineTo(usedX + width, y1 + ofY + height / 2);
ctx.closePath();
ctx.stroke();
}
if (tTopline == "1") {
ctx.beginPath();
ctx.strokeStyle = tFontColor;
ctx.moveTo(usedX, y1 + ofY);
ctx.lineTo(usedX + width, y1 + ofY);
ctx.closePath();
ctx.stroke();
}
usedX += width;
ctx.restore();
}
usedY += rRect.height;
}
if (this.isEditoring && Date.now() % 1e3 >= 500) {
if (cursorX != -Infinity && cursorY != -Infinity && curSIdx == curEIdx) {
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-text-cursor", this.ddRender.model);
ctx.lineWidth = 1.5;
ctx.beginPath();
ctx.moveTo(cursorX, cursorY - 2);
ctx.lineTo(cursorX, cursorY + cursorHeight + 2);
ctx.closePath();
ctx.stroke();
} else if (cText == "") {
let weight = fontSize * ratio + vspace;
if (align == 1) {
x2 = 5;
} else if (align == 2) {
x2 = ratPos.width * 0.5;
} else if (align == 3) {
x2 = ratPos.width - 5;
}
x2 = x2 + ratPos.x;
if (valign == 1) {
y2 = 0;
} else if (valign == 2) {
y2 = (ratPos.height - weight) * 0.5;
} else if (valign == 3) {
y2 = ratPos.height;
}
y2 = y2 + ratPos.y;
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-text-cursor", this.ddRender.model);
ctx.lineWidth = 1.5;
ctx.beginPath();
ctx.moveTo(x2, y2 - 2);
ctx.lineTo(x2, y2 + weight + 2);
ctx.closePath();
ctx.stroke();
} else if ((editorText == null ? void 0 : editorText.selectionEnd) == cText.length) {
if (!lastHeight) {
for (let tci = textContainer.length - 1; tci >= 0; tci--) {
if (textContainer[tci].height) {
lastHeight = textContainer[tci].height;
break;
}
}
}
x2 = lastUsedX + lastWidth;
if (textContainer[textContainer.length - 1].text == "" || textContainer[textContainer.length - 1].text == "\n") {
if (align == 1) {
x2 = 5;
} else if (align == 2) {
x2 = ratPos.width * 0.5;
} else if (align == 3) {
x2 = ratPos.width - 5;
}
x2 = x2 + ratPos.x;
}
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-text-cursor", this.ddRender.model);
ctx.lineWidth = 1.5;
ctx.beginPath();
ctx.moveTo(x2, lastUsedY - 2);
ctx.lineTo(x2, lastUsedY + lastHeight + 2);
ctx.closePath();
ctx.stroke();
}
}
this.textUsedArea = textContainer;
ctx.restore();
}
/**
* 如果缩放类别为3,则自动计算并将计算的区域缓存到当前对象中,如果不为3则不会进行任何处理
*/
calScaleType3Size() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
let scale = this.getCachedValue("textStyle.scale");
let textArea2 = DDeiUtil$1.pointsToZero(this.model.textArea, this.model.cpv, this.model.rotate);
let fillRect = DDeiAbstractShape.pvsToOutRect(textArea2);
if (scale == 3) {
let lockExtWidth = this.getCachedValue("textStyle.lockWidth");
let paddingWeight = this.getCachedValue("textStyle.paddingWeight");
if (!paddingWeight) {
paddingWeight = 0;
}
let canvas = this.getCanvas();
let ctx = canvas.getContext("2d");
ctx.save();
ctx.textAlign = "left";
ctx.textBaseline = "top";
let stageRatio2 = this.model.getStageRatio();
let rat1 = this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
let ratPos = DDeiUtil$1.getRatioPosition(fillRect, rat1);
let feed = this.getCachedValue("textStyle.feed");
let hspace = this.getCachedValue("textStyle.hspace");
let vspace = this.getCachedValue("textStyle.vspace");
let fiFamily = this.getCachedValue("font.family");
let fiSize = this.getCachedValue("font.size");
let bold = this.getCachedValue("textStyle.bold");
let italic = this.getCachedValue("textStyle.italic");
let textContainer = [];
let fontSize = fiSize;
let cText = null;
let sptStyle = null;
if (this.isEditoring) {
sptStyle = this.model.sptStyle;
cText = this.getCachedValue("text");
} else {
cText = DDeiUtil$1.getReplacibleValue(this.model, "text", true, true);
sptStyle = this.tempSptStyle ? this.tempSptStyle : this.model.sptStyle;
}
if (!cText) {
cText = "";
}
let contentWidth = ratPos.width;
let usedWidth = 0;
let usedHeight = 0;
let textRowContainer = { text: "", widths: [], heights: [], dHeights: [] };
textContainer.push(textRowContainer);
let baseFont = fontSize + "px " + fiFamily;
if (bold == "1") {
baseFont = "bold " + baseFont;
}
if (italic == "1") {
baseFont = "italic " + baseFont;
}
let rcIndex = 0;
let lastUnSubTypeFontSize = 0;
for (let ti = 0; ti < cText.length; ti++, rcIndex++) {
let te = cText[ti];
let font = null;
let fontHeight = null;
let isEnter = false;
let fontShapeRect = null;
if ((feed == 1 || feed == "1") && te == "\n") {
isEnter = true;
textRowContainer.text += te;
textRowContainer.widths[rcIndex] = 0;
textRowContainer.heights[rcIndex] = 0;
textRowContainer.width = Math.max(0, usedWidth);
textRowContainer.height = Math.max(0, textRowContainer.height ? textRowContainer.height : 0, lastUnSubTypeFontSize ? lastUnSubTypeFontSize * ratio + vspace : fontSize * ratio + vspace);
} else {
if (sptStyle[ti]) {
let ftsize = ((_b2 = (_a3 = sptStyle[ti]) == null ? void 0 : _a3.font) == null ? void 0 : _b2.size) ? (_d2 = (_c2 = sptStyle[ti]) == null ? void 0 : _c2.font) == null ? void 0 : _d2.size : fontSize;
if ((_e2 = sptStyle[ti].textStyle) == null ? void 0 : _e2.subtype) {
if (!lastUnSubTypeFontSize) {
lastUnSubTypeFontSize = ftsize;
}
ftsize = lastUnSubTypeFontSize / 2;
} else if (ftsize < 1) {
ftsize = 2;
}
let ftfamily = ((_g = (_f = sptStyle[ti]) == null ? void 0 : _f.font) == null ? void 0 : _g.family) ? (_i = (_h = sptStyle[ti]) == null ? void 0 : _h.font) == null ? void 0 : _i.family : fiFamily;
font = ftsize + "px " + ftfamily;
if (((_k = (_j = sptStyle[ti]) == null ? void 0 : _j.textStyle) == null ? void 0 : _k.bold) == "1") {
font = "bold " + font;
}
if (((_m = (_l = sptStyle[ti]) == null ? void 0 : _l.textStyle) == null ? void 0 : _m.italic) == "1") {
font = "italic " + font;
}
fontHeight = ftsize;
}
if (!font) {
font = baseFont;
fontHeight = fontSize;
}
if (!((_o = (_n = sptStyle[ti]) == null ? void 0 : _n.textStyle) == null ? void 0 : _o.subtype)) {
lastUnSubTypeFontSize = fontHeight;
}
let rc1 = DDeiUtil$1.measureText(te, font, ctx, fontHeight);
fontShapeRect = { width: rc1.width * ratio + hspace, height: rc1.height * ratio, dHeight: rc1.dHeight * ratio };
usedWidth += fontShapeRect.width;
textRowContainer.text += te;
textRowContainer.widths[rcIndex] = fontShapeRect.width;
textRowContainer.heights[rcIndex] = fontShapeRect.height + vspace;
textRowContainer.dHeights[rcIndex] = fontShapeRect.dHeight;
textRowContainer.width = usedWidth;
textRowContainer.height = Math.max(fontShapeRect.height + vspace, textRowContainer.height ? textRowContainer.height : 0, lastUnSubTypeFontSize ? lastUnSubTypeFontSize * ratio + vspace : fontSize * ratio + vspace);
}
if (feed == 1 || feed == "1") {
if (isEnter) {
usedWidth = 0;
usedHeight += textRowContainer.height;
rcIndex = -1;
let lastRowHeight = textRowContainer.height;
textRowContainer = { text: "", widths: [], heights: [], dHeights: [] };
textRowContainer.width = usedWidth;
textRowContainer.height = lastRowHeight;
textContainer.push(textRowContainer);
} else if ((lockExtWidth == 1 || lockExtWidth == "1") && usedWidth > contentWidth) {
textRowContainer.text = textRowContainer.text.substring(0, textRowContainer.text.length - 1);
textRowContainer.width -= fontShapeRect.width;
textRowContainer.widths.splice(rcIndex, 1);
textRowContainer.heights.splice(rcIndex, 1);
usedWidth = fontShapeRect.width;
usedHeight += textRowContainer.height;
rcIndex = 0;
textRowContainer = { text: te, widths: [], heights: [], dHeights: [] };
textRowContainer.widths[rcIndex] = fontShapeRect.width;
textRowContainer.heights[rcIndex] = fontShapeRect.height + vspace;
textRowContainer.dHeights[rcIndex] = fontShapeRect.dHeight;
textRowContainer.width = usedWidth;
textRowContainer.height = Math.max(fontShapeRect.height + vspace, lastUnSubTypeFontSize * ratio + vspace);
textContainer.push(textRowContainer);
}
}
}
let textAreaWidth = 0, textAreaHeight = 0;
for (let ri = 0; ri < textContainer.length; ri++) {
textAreaWidth = Math.max(textAreaWidth, textContainer[ri].width);
textAreaHeight += textContainer[ri].height;
}
let textAreaOutRect = fillRect;
let nowOutRect = { width: textAreaWidth / ratio + paddingWeight * 2, height: textAreaHeight / ratio + paddingWeight * 2 };
if (nowOutRect.width > 40 && nowOutRect.height > fontSize) {
let scaleX2 = nowOutRect.width / textAreaOutRect.width;
let scaleY2 = nowOutRect.height / textAreaOutRect.height;
if (lockExtWidth == 1 || lockExtWidth == "1") {
scaleX2 = 1;
}
if (scaleX2.toFixed(4) != "1.0000" || scaleY2.toFixed(4) != "1.0000") {
let m12 = new Matrix3();
let moveMatrix2 = new Matrix3(
1,
0,
-this.model.cpv.x,
0,
1,
-this.model.cpv.y,
0,
0,
1
);
m12.premultiply(moveMatrix2);
if (this.model.rotate) {
let angle2 = DDeiUtil$1.preciseTimes(this.model.rotate, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let scaleMatrix2 = new Matrix3(
scaleX2,
0,
0,
0,
scaleY2,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
if (this.model.rotate) {
let angle2 = DDeiUtil$1.preciseTimes(-this.model.rotate, DDeiConfig$1.ROTATE_UNIT);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
let move1Matrix = new Matrix3(
1,
0,
this.model.cpv.x,
0,
1,
this.model.cpv.y,
0,
0,
1
);
m12.premultiply(move1Matrix);
this.model.transVectors(m12);
this.model.updateLinkModels();
fillRect = DDeiAbstractShape.pvsToOutRect(DDeiUtil$1.pointsToZero(this.model.textArea, this.model.cpv, this.model.rotate));
}
}
this.tempTextContainer = textContainer;
ctx.restore();
}
this.tempFillRect = fillRect;
}
// ============================== 事件 ===============================
/**
* 鼠标按下事件
*/
mouseDown(evt) {
super.mouseDown(evt);
}
/**
* 绘制图形
*/
mouseUp(evt) {
super.mouseUp(evt);
}
/**
* 鼠标移动
*/
mouseMove(evt) {
super.mouseMove(evt);
}
/**
* 鼠标双击
* @param evt
*/
dblClick(evt) {
}
};
__publicField2(_DDeiPolygonCanvasRender, "ClsName", "DDeiPolygonCanvasRender");
let DDeiPolygonCanvasRender = _DDeiPolygonCanvasRender;
const __vite_glob_1_6$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiPolygonCanvasRender,
default: DDeiPolygonCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiPolygonContainerCanvasRender = class _DDeiPolygonContainerCanvasRender2 extends DDeiPolygonCanvasRender {
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiPolygonContainerCanvasRender2(props);
}
// ============================== 方法 ===============================
enableRefreshShape() {
var _a3;
super.enableRefreshShape();
(_a3 = this.model.models) == null ? void 0 : _a3.forEach((model) => {
var _a22;
(_a22 = model.render) == null ? void 0 : _a22.enableRefreshShape();
});
}
clearCachedValue() {
super.clearCachedValue();
this.model.models.forEach((item) => {
var _a3;
(_a3 = item == null ? void 0 : item.render) == null ? void 0 : _a3.clearCachedValue();
});
}
/**
* 绘制图形
*/
drawShape(tempShape, composeRender = 0, inRect = null, zIndex = 0) {
var _a3, _b2, _c2, _d2, _e2;
if (!inRect || this.model.isInRect(inRect.x, inRect.y, inRect.x1, inRect.y1)) {
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_BEFORE", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
if (composeRender || rsState == 0 || rsState == 1) {
let rsState1 = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", DDeiEnumOperateType.VIEW, { models: [this.model], tempShape, composeRender }, this.ddRender.model, null);
if (rsState1 == 0 || rsState1 == 1) {
if (!DDeiUtil$1.isModelHidden(this.model) && (this.refreshShape || this.isEditoring)) {
this.createTempShape();
let rendList = [];
if (((_a3 = this.model.composes) == null ? void 0 : _a3.length) > 0) {
rendList = rendList.concat(this.model.composes);
}
rendList.push(this.model);
rendList.sort((a, b) => {
if ((a.cIndex || a.cIndex == 0) && (b.cIndex || b.cIndex == 0)) {
return a.cIndex - b.cIndex;
} else if ((a.cIndex || a.cIndex == 0) && !(b.cIndex || b.cIndex == 0)) {
return 1;
} else if (!(a.cIndex || a.cIndex == 0) && (b.cIndex || b.cIndex == 0)) {
return -1;
} else {
return 0;
}
});
for (let ri = 0; ri < rendList.length; ri++) {
let c = rendList[ri];
if (c == this.model) {
let canvas = this.getCanvas();
let ctx = canvas.getContext("2d");
if (!tempShape && this.stageRender.operateState == DDeiEnumOperateState.QUICK_EDITING || this.stageRender.operateState == DDeiEnumOperateState.QUICK_EDITING_TEXT_SELECTING) {
if (this.isEditoring)
;
else if ((_b2 = this.stage.render) == null ? void 0 : _b2.editorShadowControl) {
if (this.model.id + "_shadow" == this.stage.render.editorShadowControl.id) {
return;
}
}
} else if (!tempShape && ((_d2 = (_c2 = this.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) == 1 && Array.from((_e2 = this.stage) == null ? void 0 : _e2.selectedModels.values())[0].id == this.model.id) {
tempShape = { border: { type: 1, width: 1, color: "#017fff", dash: [10, 5] }, drawCompose: false };
}
this.calScaleType3Size(tempShape);
ctx.save();
this.calPVSS(tempShape);
this.createClip(tempShape);
this.drawFill(tempShape);
this.drawText(tempShape);
this.drawBorder(tempShape);
this.drawChildrenShapes(tempShape);
ctx.restore();
} else {
if (tempShape && (tempShape == null ? void 0 : tempShape.drawCompose) == false) {
c.render.drawShape(null, composeRender + 1, null, zIndex + ri);
} else {
c.render.drawShape(tempShape, composeRender + 1, null, zIndex + ri);
}
}
}
if (!this.isEditoring) {
this.refreshShape = false;
}
}
this.drawSelfToCanvas(composeRender);
}
if (!composeRender) {
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_AFTER", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
}
}
} else {
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", "VIEW-HIDDEN", { models: [this.model] }, this.ddRender.model, null);
if (rsState == 0 || rsState == 1) {
this.removeViewerCanvas();
}
}
}
/**
* 绘制自身到最外层canvas
*/
drawSelfToCanvas(composeRender) {
var _a3, _b2;
if (this.tempCanvas) {
let model = this.model;
let stage2 = model.stage;
let ruleWeight = 0;
if (stage2.render.tempRuleDisplay == 1 || stage2.render.tempRuleDisplay == "1") {
ruleWeight = 15;
}
let stageRatio2 = this.model.getStageRatio();
if (!this.tempCanvas.parentElement) {
let viewerEle = this.model.layer.render.containerViewer;
viewerEle.appendChild(this.tempCanvas);
}
this.tempCanvas.style.zIndex = this.tempZIndex;
this.tempCanvas.style.left = this.model.cpv.x * stageRatio2 + this.model.stage.wpv.x - this.tempCanvas.offsetWidth / 2 - ruleWeight + "px";
this.tempCanvas.style.top = this.model.cpv.y * stageRatio2 + this.model.stage.wpv.y - this.tempCanvas.offsetHeight / 2 - ruleWeight + "px";
for (let m = 0; m < ((_a3 = this.model.midList) == null ? void 0 : _a3.length); m++) {
let key = this.model.midList[m];
let item = this.model.models.get(key);
(_b2 = item.render) == null ? void 0 : _b2.drawSelfToCanvas(composeRender);
}
}
}
/**
* 绘制子元素
*/
drawChildrenShapes(tempShape, inRect = true, hidden = false) {
var _a3, _b2;
if (((_a3 = this.model.models) == null ? void 0 : _a3.size) > 0) {
let canvas = this.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.stage.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
let lineOffset = 0;
let areaPVS = this.model.layoutManager.getAreasPVS();
let usedMidIds = [];
for (let n = 0; n < areaPVS.length; n++) {
let pvs2 = areaPVS[n];
for (let m = 0; m < ((_b2 = this.model.midList) == null ? void 0 : _b2.length); m++) {
let key = this.model.midList[m];
let item = this.model.models.get(key);
usedMidIds.push(item.id);
ctx.save();
ctx.beginPath();
for (let i2 = 0; i2 < pvs2.length; i2++) {
if (i2 == pvs2.length - 1) {
ctx.lineTo(pvs2[0].x * ratio + lineOffset, pvs2[0].y * ratio + lineOffset);
} else if (i2 == 0) {
ctx.moveTo(pvs2[i2].x * ratio + lineOffset, pvs2[i2].y * ratio + lineOffset);
ctx.lineTo(pvs2[i2 + 1].x * ratio + lineOffset, pvs2[i2 + 1].y * ratio + lineOffset);
} else {
ctx.lineTo(pvs2[i2 + 1].x * ratio + lineOffset, pvs2[i2 + 1].y * ratio + lineOffset);
}
}
ctx.closePath();
item.render.tempZIndex = this.tempZIndex + (m + 1);
item.render.drawShape(tempShape);
ctx.restore();
}
}
}
}
};
__publicField2(_DDeiPolygonContainerCanvasRender, "ClsName", "DDeiPolygonContainerCanvasRender");
let DDeiPolygonContainerCanvasRender = _DDeiPolygonContainerCanvasRender;
const __vite_glob_1_5$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiPolygonContainerCanvasRender,
default: DDeiPolygonContainerCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiSelectorCanvasRender = class _DDeiSelectorCanvasRender2 extends DDeiRectangleCanvasRender {
constructor(props) {
super(props);
this.clip = false;
}
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiSelectorCanvasRender2(props);
}
/**
* 创建图形
*/
drawShape() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i;
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
ctx.save();
let models = null;
if (((_b2 = (_a3 = this.stage) == null ? void 0 : _a3.selectedModels) == null ? void 0 : _b2.size) > 0) {
models = Array.from(this.stage.selectedModels.values());
}
if (this.stageRender.operateState == DDeiEnumOperateState.SELECT_WORKING) {
(_e2 = (_d2 = (_c2 = this.stage) == null ? void 0 : _c2.layers[this.stage.layerIndex]) == null ? void 0 : _d2.render) == null ? void 0 : _e2.enableRefreshShape();
this.drawBorder();
} else if (this.stageRender.operateState != DDeiEnumOperateState.LINE_POINT_CHANGING) {
if ((models == null ? void 0 : models.length) == 1 && ((_f = models[0]) == null ? void 0 : _f.baseModelType) == "DDeiLine") {
this.drawLine();
this.drawOperatorShapeLine();
} else {
if ((models == null ? void 0 : models.length) == 1 && (models[0].mirrorX || models[0].mirrorY)) {
let model = models[0];
let oldRat1 = this.ddRender.ratio * ((_g = this.stage) == null ? void 0 : _g.getStageRatio());
ctx.translate(model.cpv.x * oldRat1, model.cpv.y * oldRat1);
if (model.mirrorX) {
ctx.scale(-1, 1);
}
if (model.mirrorY) {
ctx.scale(1, -1);
}
ctx.translate(-model.cpv.x * oldRat1, -model.cpv.y * oldRat1);
}
if (this.stageRender.operateState == DDeiEnumOperateState.QUICK_EDITING || this.stageRender.operateState == DDeiEnumOperateState.QUICK_EDITING_TEXT_SELECTING)
;
else {
if (((_i = (_h = this.stage) == null ? void 0 : _h.selectedModels) == null ? void 0 : _i.size) > 1) {
this.drawBorder();
}
this.drawOperatorShape();
}
}
this.drawOvsPoints();
}
this.drawIncludedStyle();
ctx.restore();
}
/**
* 绘制特殊操作点
*/
drawOvsPoints() {
var _a3, _b2, _c2, _d2, _e2, _f;
if (this.model.state == DDeiEnumControlState.SELECTED && ((_b2 = (_a3 = this.stage) == null ? void 0 : _a3.selectedModels) == null ? void 0 : _b2.size) == 1) {
let model = Array.from((_c2 = this.stage) == null ? void 0 : _c2.selectedModels.values())[0];
let ovs = model.ovs;
if ((ovs == null ? void 0 : ovs.length) > 0) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let ratio = this.ddRender.ratio * this.stage.getStageRatio();
let weight = 4;
ctx.save();
ctx.fillStyle = "yellow";
ctx.strokeStyle = "black";
let ovsDefine = (_e2 = (_d2 = DDeiUtil$1.getControlDefine(model)) == null ? void 0 : _d2.define) == null ? void 0 : _e2.ovs;
for (let i2 = 0; i2 < ovs.length; i2++) {
let point2 = ovs[i2];
let pointDefine2 = ovsDefine[i2];
if (((_f = pointDefine2 == null ? void 0 : pointDefine2.constraint) == null ? void 0 : _f.type) && pointDefine2.constraint.type != 5) {
ctx.beginPath();
ctx.moveTo((point2.x + weight) * ratio, point2.y * ratio);
ctx.lineTo(point2.x * ratio, (point2.y + weight) * ratio);
ctx.lineTo((point2.x - weight) * ratio, point2.y * ratio);
ctx.lineTo(point2.x * ratio, (point2.y - weight) * ratio);
ctx.closePath();
ctx.stroke();
ctx.fill();
}
}
ctx.restore();
}
}
}
/**
* 绘制编辑边框
* @param tempBorder 临时边框,优先级最高
* @param usePV 是否采用向量输出
*/
drawEditBorder() {
var _a3, _b2;
if (((_b2 = (_a3 = this.stageRender.editorShadowControl) == null ? void 0 : _a3.textArea) == null ? void 0 : _b2.length) > 3) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
ctx.save();
let stageRatio2 = this.model.getStageRatio();
let rat1 = this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
let lineOffset = 0;
let lineWidth = 1.25 * ratio;
ctx.lineWidth = lineWidth;
ctx.beginPath();
ctx.setLineDash([10, 10]);
ctx.strokeStyle = DDeiUtil$1.getColor("#017fff");
let pvs2 = this.stageRender.editorShadowControl.textArea;
if ((pvs2 == null ? void 0 : pvs2.length) > 0) {
ctx.moveTo(pvs2[0].x * rat1 + lineOffset, pvs2[0].y * rat1 + lineOffset);
ctx.lineTo(pvs2[1].x * rat1 + lineOffset, pvs2[1].y * rat1 + lineOffset);
ctx.lineTo(pvs2[2].x * rat1 + lineOffset, pvs2[2].y * rat1 + lineOffset);
ctx.lineTo(pvs2[3].x * rat1 + lineOffset, pvs2[3].y * rat1 + lineOffset);
}
ctx.closePath();
ctx.stroke();
ctx.restore();
}
}
/**
* 线模式下绘制线的效果
*/
drawLine() {
}
/**
* 线模式下绘制线的操作图形
*/
drawOperatorShapeLine() {
var _a3, _b2, _c2, _d2;
if (this.model.state != DDeiEnumControlState.SELECTED) {
return;
}
if (((_b2 = (_a3 = this.stage) == null ? void 0 : _a3.selectedModels) == null ? void 0 : _b2.size) > 0) {
let lineModel = Array.from((_d2 = (_c2 = this.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.values())[0];
if (lineModel.baseModelType == "DDeiLine") {
let modeName = DDeiUtil$1.getConfigValue("MODE_NAME", this.ddRender.model);
let accessLink = DDeiUtil$1.isAccess(
DDeiEnumOperateType.LINK,
[lineModel],
null,
modeName,
this.ddRender.model
);
if (accessLink) {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.stage.getStageRatio();
let rat1 = this.ddRender.ratio;
let ratio = rat1 * stageRatio2;
rat1 = ratio;
let pvs2 = lineModel.pvs;
let type = DDeiModelArrtibuteValue.getAttrValueByState(lineModel, "type", true);
let weight = DDeiModelArrtibuteValue.getAttrValueByState(lineModel, "weight", true);
let w10 = 1.3 * weight * ratio;
if (w10 > 5 * rat1) {
w10 = 5 * rat1;
} else if (w10 < 2 * rat1) {
w10 = 2 * rat1;
}
let w15 = 1.5 * w10;
let w20 = 2 * w10;
let w30 = 2 * w15;
ctx.save();
switch (type) {
case 1: {
this.drawSEPoint(pvs2, w10, w20, ctx, rat1, ratio);
break;
}
case 2: {
this.drawSEPoint(pvs2, w10, w20, ctx, rat1, ratio);
ctx.strokeStyle = "#017fff";
ctx.fillStyle = "white";
for (let i2 = 1; i2 < pvs2.length; i2++) {
if (i2 != pvs2.length - 1) {
ctx.save();
let x1 = pvs2[i2].x * rat1;
let y1 = pvs2[i2].y * rat1;
if (lineModel.rotate) {
ctx.translate(x1, y1);
ctx.rotate(lineModel.rotate * DDeiConfig$1.ROTATE_UNIT);
ctx.translate(-x1, -y1);
}
ctx.fillRect(x1 - w15, y1 - w15, w30, w30);
ctx.strokeRect(x1 - w15, y1 - w15, w30, w30);
ctx.restore();
}
ctx.save();
let x2 = (pvs2[i2].x + pvs2[i2 - 1].x) / 2 * rat1;
let y2 = (pvs2[i2].y + pvs2[i2 - 1].y) / 2 * rat1;
ctx.translate(x2, y2);
ctx.rotate(((lineModel.rotate ? lineModel.rotate : 0) + 45) * DDeiConfig$1.ROTATE_UNIT);
ctx.translate(-x2, -y2);
ctx.fillRect(x2 - w10, y2 - w10, w20, w20);
ctx.strokeRect(x2 - w10, y2 - w10, w20, w20);
ctx.restore();
}
break;
}
case 3: {
this.drawSEPoint(pvs2, w10, w20, ctx, rat1, ratio);
if (pvs2.length >= 4) {
ctx.strokeStyle = "#017fff";
ctx.fillStyle = "white";
for (let i2 = 1; i2 < this.model.opvs.length - 1; i2++) {
let pv = this.model.opvs[i2];
ctx.beginPath();
ctx.ellipse(pv.x * rat1, pv.y * rat1, w20, w20, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.fill();
ctx.stroke();
}
}
break;
}
}
ctx.restore();
}
}
}
}
/**
* 绘制开始和结束操作点
*/
drawSEPoint(pvs2, w10, w20, ctx, rat1, ratio) {
ctx.strokeStyle = "red";
ctx.lineWidth = ratio;
ctx.fillStyle = "white";
ctx.beginPath();
ctx.ellipse(pvs2[0].x * rat1, pvs2[0].y * rat1, w20, w20, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.fill();
ctx.beginPath();
ctx.ellipse(pvs2[pvs2.length - 1].x * rat1, pvs2[pvs2.length - 1].y * rat1, w20, w20, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.fill();
ctx.fillStyle = "red";
ctx.beginPath();
ctx.ellipse(pvs2[0].x * rat1, pvs2[0].y * rat1, w10, w10, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.fill();
ctx.beginPath();
ctx.ellipse(pvs2[pvs2.length - 1].x * rat1, pvs2[pvs2.length - 1].y * rat1, w10, w10, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.fill();
ctx.beginPath();
ctx.ellipse(pvs2[0].x * rat1, pvs2[0].y * rat1, w20, w20, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.stroke();
ctx.beginPath();
ctx.ellipse(pvs2[pvs2.length - 1].x * rat1, pvs2[pvs2.length - 1].y * rat1, w20, w20, 0, 0, DDeiUtil$1.PI2);
ctx.closePath();
ctx.stroke();
}
/**
* 获取边框上的操作图形
* @param tempBorder
*/
drawOperatorShape(tempBorder) {
var _a3, _b2;
if (this.model.state != DDeiEnumControlState.SELECTED) {
return;
}
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = (_a3 = this.stage) == null ? void 0 : _a3.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
ctx.save();
let width = DDeiConfig$1.SELECTOR.OPERATE_ICON.weight * ratio;
let halfWidth = width * 0.5;
let selectedModels = (_b2 = this.stage) == null ? void 0 : _b2.selectedModels;
if ((selectedModels == null ? void 0 : selectedModels.size) > 0) {
let firstModel = Array.from(selectedModels == null ? void 0 : selectedModels.values())[0];
for (let i2 = 1; i2 <= 10; i2++) {
let type = null;
let color = null;
let opacity = null;
let bWidth = null;
if (i2 <= 2 || i2 >= 9) {
type = this.getBorderInfo(tempBorder, 1, "type");
color = this.getBorderInfo(tempBorder, 1, "color");
opacity = this.getBorderInfo(tempBorder, 1, "opacity");
bWidth = this.getBorderInfo(tempBorder, 1, "width");
} else if (i2 <= 4) {
type = this.getBorderInfo(tempBorder, 2, "type");
color = this.getBorderInfo(tempBorder, 2, "color");
opacity = this.getBorderInfo(tempBorder, 2, "opacity");
bWidth = this.getBorderInfo(tempBorder, 2, "width");
} else if (i2 <= 6) {
type = this.getBorderInfo(tempBorder, 3, "type");
color = this.getBorderInfo(tempBorder, 3, "color");
opacity = this.getBorderInfo(tempBorder, 3, "opacity");
bWidth = this.getBorderInfo(tempBorder, 3, "width");
} else if (i2 <= 8) {
type = this.getBorderInfo(tempBorder, 4, "type");
color = this.getBorderInfo(tempBorder, 4, "color");
opacity = this.getBorderInfo(tempBorder, 4, "opacity");
bWidth = this.getBorderInfo(tempBorder, 4, "width");
}
if (!(type == 0 || type == "0") && color && (!opacity || opacity > 0) && bWidth > 0) {
let lineOffset = 0;
ctx.lineWidth = bWidth * ratio;
ctx.beginPath();
if (opacity != null && opacity != void 0) {
ctx.globalAlpha = opacity;
}
ctx.strokeStyle = DDeiUtil$1.getColor(color);
let defaultFillColor = DDeiUtil$1.getColor(DDeiConfig$1.SELECTOR.OPERATE_ICON.FILL.default);
ctx.fillStyle = defaultFillColor;
if (this.model.passIndex == i2) {
ctx.fillStyle = DDeiUtil$1.getColor(DDeiConfig$1.SELECTOR.OPERATE_ICON.FILL.pass);
}
let opvs = this.model.opvs;
if ((opvs == null ? void 0 : opvs.length) > 0) {
if (i2 >= 1 && i2 <= 8) {
if (opvs[i2]) {
ctx.ellipse(opvs[i2].x * ratio + lineOffset, opvs[i2].y * ratio + lineOffset, halfWidth, halfWidth, 0, 0, Math.PI * 2);
ctx.fill();
ctx.stroke();
}
} else if (i2 == 9) {
if (opvs[9]) {
if (this.model.passIndex == i2) {
ctx.ellipse(opvs[9].x * ratio + lineOffset, opvs[9].y * ratio + lineOffset, halfWidth, halfWidth, 0, 0, Math.PI * 2);
ctx.fill();
} else {
ctx.arc(opvs[9].x * ratio + lineOffset, opvs[9].y * ratio + lineOffset, halfWidth, 50, Math.PI * 1.6);
ctx.stroke();
}
}
} else if (i2 == 10 && selectedModels.size == 1 && firstModel.baseModelType == "DDeiTable") {
ctx.fillStyle = DDeiUtil$1.getColor(color);
ctx.ellipse(opvs[10].x * ratio + lineOffset, opvs[10].y * ratio + lineOffset, halfWidth, halfWidth, 0, 0, Math.PI * 2);
ctx.fill();
}
}
}
}
}
ctx.restore();
}
/**
* 获取边框信息
* @param tempBorder
*/
getBorderInfo(tempBorder, direct, path) {
let borderInfo = null;
if (tempBorder) {
try {
let returnJSON = DDeiUtil$1.getDataByPath(tempBorder, path.split("."));
borderInfo = returnJSON.data;
} catch (e) {
}
} else {
borderInfo = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "border." + path, true);
}
return borderInfo;
}
/**
* 计算除边框外的填充区域,用于填充颜色和字体
*/
getFillArea() {
let disabled = this.getBorderInfo(null, 1, "disabled");
let color = this.getBorderInfo(null, 1, "color");
let opacity = this.getBorderInfo(null, 1, "opacity");
let width = this.getBorderInfo(null, 1, "width");
if (!(!disabled && color && (!opacity || opacity > 0) && width > 0)) {
width = 0;
}
let absBounds = this.model.getAbsBounds();
let fillAreaE = {
x: absBounds.x - width,
y: absBounds.y - width,
width: absBounds.width + 2 * width,
height: absBounds.height + 2 * width
};
return fillAreaE;
}
/**
* 绘制选中图形特效
*/
drawIncludedStyle() {
var _a3, _b2;
let includedModels = null;
let selectNumber = 0;
if (this.model.state == DDeiEnumControlState.DEFAULT) {
includedModels = this.model.getIncludedModels();
} else if (this.model.state == DDeiEnumControlState.SELECTED) {
includedModels = (_a3 = this.stage) == null ? void 0 : _a3.selectedModels;
selectNumber = 1;
}
(_b2 = this.upIncludeModels) == null ? void 0 : _b2.forEach((im) => {
var _a22;
(_a22 = im == null ? void 0 : im.render) == null ? void 0 : _a22.enableRefreshShape();
});
if (includedModels && includedModels.size > selectNumber) {
includedModels.forEach((model, key) => {
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
ctx.save();
model.render.enableRefreshShape();
if (model.baseModelType == "DDeiLine") {
model.render.drawShape({ color: "red", dash: [] }, 0, null, 99999);
} else {
model.render.drawShape({ type: 1, width: 1, color: "red", border: { type: 1, dash: [], width: 1, color: "red" } }, 0, null, 99999);
}
ctx.restore();
});
}
this.upIncludeModels = includedModels;
}
/**
* 鼠标移动事件,经由上层容器分发
*/
mouseMove(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L, _M, _N, _O, _P, _Q, _R, _S, _T, _U, _V, _W, _X, _Y, _Z, __, _$, _aa, _ba, _ca, _da;
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= this.stage.wpv.x;
ey -= this.stage.wpv.y;
let stageRatio2 = (_a3 = this.stage) == null ? void 0 : _a3.getStageRatio();
ex = ex / stageRatio2;
ey = ey / stageRatio2;
let models = null;
if (((_c2 = (_b2 = this.stage) == null ? void 0 : _b2.selectedModels) == null ? void 0 : _c2.size) > 0) {
models = Array.from(this.stage.selectedModels.values());
}
let isOvPoint = false;
if ((models == null ? void 0 : models.length) == 1 && ((_d2 = models[0]) == null ? void 0 : _d2.ovs.length) > 0) {
let ovPoint = models[0].getOvPointByPos(ex, ey);
if (ovPoint) {
let ovsDefine = (_f = (_e2 = DDeiUtil$1.getControlDefine(models[0])) == null ? void 0 : _e2.define) == null ? void 0 : _f.ovs;
let ovd = ovsDefine[models[0].ovs.indexOf(ovPoint)];
if (((_g = ovd == null ? void 0 : ovd.constraint) == null ? void 0 : _g.type) && ovd.constraint.type != 5) {
isOvPoint = true;
(_j = (_i = (_h = this.stage) == null ? void 0 : _h.ddInstance) == null ? void 0 : _i.bus) == null ? void 0 : _j.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "pointer" }, evt);
}
}
}
if (!isOvPoint) {
if ((models == null ? void 0 : models.length) == 1 && ((_k = models[0]) == null ? void 0 : _k.baseModelType) == "DDeiLine") {
let modeName = DDeiUtil$1.getConfigValue("MODE_NAME", this.ddRender.model);
let accessLink = DDeiUtil$1.isAccess(
DDeiEnumOperateType.LINK,
[models[0]],
null,
modeName,
this.ddRender.model
);
if (accessLink) {
let tpdata = this.model.isOpvOnLine(ex, ey);
if (tpdata) {
let direct = null;
if (tpdata.type == 3) {
let beforeP = this.model.opvs[tpdata.index - 1];
let afterP = this.model.opvs[tpdata.index + 1];
if (Math.abs(beforeP.x - afterP.x) <= 1) {
direct = 2;
} else {
direct = 1;
}
}
(_n = (_m = (_l = this.stage) == null ? void 0 : _l.ddInstance) == null ? void 0 : _m.bus) == null ? void 0 : _n.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { type: "line", passIndex: tpdata.type, direct, opvsIndex: tpdata.index }, evt);
}
} else {
(_q = (_p = (_o = this.stage) == null ? void 0 : _o.ddInstance) == null ? void 0 : _p.bus) == null ? void 0 : _q.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { type: "line", passIndex: -1, opvsIndex: -1 }, evt);
}
} else {
if (this.model.isOpvOn(1, ex, ey)) {
(_t = (_s = (_r = this.stage) == null ? void 0 : _r.ddInstance) == null ? void 0 : _s.bus) == null ? void 0 : _t.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 1, opvsIndex: -1 }, evt);
} else if (this.model.isOpvOn(2, ex, ey)) {
(_w = (_v = (_u = this.stage) == null ? void 0 : _u.ddInstance) == null ? void 0 : _v.bus) == null ? void 0 : _w.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 2, opvsIndex: -1 }, evt);
} else if (this.model.isOpvOn(3, ex, ey)) {
(_z = (_y = (_x = this.stage) == null ? void 0 : _x.ddInstance) == null ? void 0 : _y.bus) == null ? void 0 : _z.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 3, opvsIndex: -1 }, evt);
} else if (this.model.isOpvOn(4, ex, ey)) {
(_C = (_B = (_A = this.stage) == null ? void 0 : _A.ddInstance) == null ? void 0 : _B.bus) == null ? void 0 : _C.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 4, opvsIndex: -1 }, evt);
} else if (this.model.isOpvOn(5, ex, ey)) {
(_F = (_E = (_D = this.stage) == null ? void 0 : _D.ddInstance) == null ? void 0 : _E.bus) == null ? void 0 : _F.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 5, opvsIndex: -1 }, evt);
} else if (this.model.isOpvOn(6, ex, ey)) {
(_I = (_H = (_G = this.stage) == null ? void 0 : _G.ddInstance) == null ? void 0 : _H.bus) == null ? void 0 : _I.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 6, opvsIndex: -1 }, evt);
} else if (this.model.isOpvOn(7, ex, ey)) {
(_L = (_K = (_J = this.stage) == null ? void 0 : _J.ddInstance) == null ? void 0 : _K.bus) == null ? void 0 : _L.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 7, opvsIndex: -1 }, evt);
} else if (this.model.isOpvOn(8, ex, ey)) {
(_O = (_N = (_M = this.stage) == null ? void 0 : _M.ddInstance) == null ? void 0 : _N.bus) == null ? void 0 : _O.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 8, opvsIndex: -1 }, evt);
} else if (this.model.isOpvOn(9, ex, ey)) {
(_R = (_Q = (_P = this.stage) == null ? void 0 : _P.ddInstance) == null ? void 0 : _Q.bus) == null ? void 0 : _R.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 9, opvsIndex: -1 }, evt);
} else if (this.model.isOpvOn(10, ex, ey)) {
(_U = (_T = (_S = this.stage) == null ? void 0 : _S.ddInstance) == null ? void 0 : _T.bus) == null ? void 0 : _U.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 13, opvsIndex: -1 }, evt);
} else {
let models2 = (_W = this.stage) == null ? void 0 : _W.layers[(_V = this.stage) == null ? void 0 : _V.layerIndex].findModelsByArea(ex, ey);
if (models2 && models2.length > 0) {
(_Z = (_Y = (_X = this.stage) == null ? void 0 : _X.ddInstance) == null ? void 0 : _Y.bus) == null ? void 0 : _Z.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 10, opvsIndex: -1 }, evt);
} else {
(_aa = (_$ = (__ = this.stage) == null ? void 0 : __.ddInstance) == null ? void 0 : _$.bus) == null ? void 0 : _aa.push(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: -1, opvsIndex: -1 }, evt);
}
}
}
}
(_da = (_ca = (_ba = this.stage) == null ? void 0 : _ba.ddInstance) == null ? void 0 : _ca.bus) == null ? void 0 : _da.push(DDeiEnumBusCommandType.RefreshShape);
}
/**
* 鼠标按下事件,经由上层容器分发
*/
mouseDown(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= this.stage.wpv.x;
ey -= this.stage.wpv.y;
let stageRatio2 = (_a3 = this.stage) == null ? void 0 : _a3.getStageRatio();
ex = ex / stageRatio2;
ey = ey / stageRatio2;
if (this.model.passType == "line") {
let lineModel = null;
if (((_c2 = (_b2 = this.stage) == null ? void 0 : _b2.selectedModels) == null ? void 0 : _c2.size) > 0) {
let layer2 = this.stage.layers[(_d2 = this.stage) == null ? void 0 : _d2.layerIndex];
lineModel = Array.from(this.stage.selectedModels.values())[0];
let modeName = DDeiUtil$1.getConfigValue("MODE_NAME", this.ddRender.model);
let accessLink = DDeiUtil$1.isAccess(
DDeiEnumOperateType.LINK,
[lineModel],
null,
modeName,
this.ddRender.model
);
if (accessLink) {
let dragPoint = this.model.opvs[this.model.opvsIndex];
let lineShadow = DDeiUtil$1.getShadowControl(lineModel);
layer2.shadowControls.push(lineShadow);
this.stageRender.currentOperateShape = lineShadow;
this.stageRender.currentOperateShape.dragPoint = dragPoint;
let dragObj = {
x: ex,
y: ey,
dragPoint,
model: lineShadow,
opvsIndex: this.model.opvsIndex,
passIndex: this.model.passIndex,
opvs: this.model.opvs
};
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_LINE_DRAG_BEFORE", DDeiEnumOperateType.DRAG, dragObj, (_e2 = this.stage) == null ? void 0 : _e2.ddInstance, evt);
if (rsState == 0 || rsState == 1) {
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", DDeiEnumOperateType.LINK, null, (_f = this.stage) == null ? void 0 : _f.ddInstance, evt);
(_i = (_h = (_g = this.stage) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.bus) == null ? void 0 : _i.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj }, evt);
(_l = (_k = (_j = this.stage) == null ? void 0 : _j.ddInstance) == null ? void 0 : _k.bus) == null ? void 0 : _l.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "grabbing" }, evt);
this.stageRender.operateState = DDeiEnumOperateState.LINE_POINT_CHANGING;
}
}
}
} else {
if (this.model.passIndex >= 1 && this.model.passIndex <= 8) {
let dragObj = {
x: ex,
y: ey,
originData: {
x: this.model.x,
y: this.model.y,
width: this.model.width,
height: this.model.height
}
};
let pContainerModel = this.stage.render.currentOperateContainer;
if (!pContainerModel) {
pContainerModel = this.stage.layers[this.stage.layerIndex];
}
let selectedModels = pContainerModel.getSelectedModels();
let layer2 = this.stage.layers[this.stage.layerIndex];
selectedModels.forEach((m) => {
let md = DDeiUtil$1.getShadowControl(m);
layer2.shadowControls.push(md);
});
(_o = (_n = (_m = this.stage) == null ? void 0 : _m.ddInstance) == null ? void 0 : _n.bus) == null ? void 0 : _o.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj }, evt);
this.stageRender.operateState = DDeiEnumOperateState.CONTROL_CHANGING_BOUND;
} else if (this.model.passIndex == 9) {
let pContainerModel = this.stageRender.currentOperateContainer;
if (!pContainerModel) {
pContainerModel = this.layer;
}
let selectedModels = pContainerModel.getSelectedModels();
if (selectedModels) {
if (selectedModels.set) {
selectedModels = Array.from(selectedModels.values());
}
let stop = false;
for (let i2 = 0; i2 < selectedModels.length; i2++) {
let parentContainer = selectedModels[i2].pModel;
if (parentContainer == null ? void 0 : parentContainer.layoutManager) {
if (!parentContainer.layoutManager.canChangeRotate()) {
stop = true;
break;
}
}
}
if (!stop) {
let dragObj = {
x: ex,
y: ey,
cx: this.model.cpv.x,
cy: this.model.cpv.y,
models: selectedModels,
container: pContainerModel
};
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_ROTATE_BEFORE", DDeiEnumOperateType.ROTATE, { models: dragObj.models }, this.stage.ddInstance, evt);
if (rsState == 0 || rsState == 1) {
(_r = (_q = (_p = this.stage) == null ? void 0 : _p.ddInstance) == null ? void 0 : _q.bus) == null ? void 0 : _r.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj }, evt);
this.stageRender.operateState = DDeiEnumOperateState.CONTROL_ROTATE;
}
}
}
} else if (this.model.passIndex == 13) {
let selectedModels = (_s = this.stage) == null ? void 0 : _s.selectedModels;
this.stageRender.operateState = DDeiEnumOperateState.CONTROL_DRAGING;
let layer2 = Array.from(selectedModels == null ? void 0 : selectedModels.values())[0].layer;
layer2.opPoints = [];
if ((_t = layer2.opLine) == null ? void 0 : _t.render) {
layer2.opLine.render.enableRefreshShape();
}
delete layer2.opLine;
let centerPointVector = this.model.cpv;
let dragObj = {
x: ex,
y: ey,
dx: centerPointVector.x - ex,
//鼠标在控件中心坐标的增量位置
dy: centerPointVector.y - ey
};
selectedModels.forEach((m) => {
let md = DDeiUtil$1.getShadowControl(m);
layer2.shadowControls.push(md);
if (!this.stageRender.currentOperateShape) {
this.stageRender.currentOperateShape = md;
}
});
(_w = (_v = (_u = this.stage) == null ? void 0 : _u.ddInstance) == null ? void 0 : _v.bus) == null ? void 0 : _w.push(DDeiEnumBusCommandType.ModelChangeSelect, [{ id: this.stageRender.currentOperateShape.id, value: DDeiEnumControlState.SELECTED }], evt);
(_z = (_y = (_x = this.stage) == null ? void 0 : _x.ddInstance) == null ? void 0 : _y.bus) == null ? void 0 : _z.push(DDeiEnumBusCommandType.UpdateDragObj, { dragObj }, evt);
}
if (this.model.passIndex != -1)
;
}
}
/**
* 计算移动后的坐标
* @param x
* @param y
* @param er 是否等比
*/
getMovedBounds(x2, y2, er = false) {
var _a3, _b2, _c2, _d2, _e2, _f, _g;
let stageRatio2 = (_a3 = this.stage) == null ? void 0 : _a3.getStageRatio();
let returnBounds = { x: this.model.x * stageRatio2, y: this.model.y * stageRatio2, width: this.model.width * stageRatio2, height: this.model.height * stageRatio2 };
let centerPointVector = this.model.cpv;
if (this.model.rotate) {
let tempPV = new Vector3(x2, y2, 1);
let move1Matrix = new Matrix3(
1,
0,
-centerPointVector.x,
0,
1,
-centerPointVector.y,
0,
0,
1
);
let angle2 = (this.model.rotate * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
let move2Matrix = new Matrix3(
1,
0,
centerPointVector.x,
0,
1,
centerPointVector.y,
0,
0,
1
);
let m12 = new Matrix3().premultiply(move1Matrix).premultiply(rotateMatrix).premultiply(move2Matrix);
tempPV.applyMatrix3(m12);
x2 = tempPV.x;
y2 = tempPV.y;
}
let wbh = returnBounds.width / returnBounds.height;
let stage2 = this.model.stage;
let hAds = ((_b2 = stage2.render.helpLines) == null ? void 0 : _b2.hAds) || ((_c2 = stage2.render.helpLines) == null ? void 0 : _c2.hAds) == 0 ? (_d2 = stage2.render.helpLines) == null ? void 0 : _d2.hAds : Infinity;
let vAds = ((_e2 = stage2.render.helpLines) == null ? void 0 : _e2.vAds) || ((_f = stage2.render.helpLines) == null ? void 0 : _f.vAds) == 0 ? (_g = stage2.render.helpLines) == null ? void 0 : _g.vAds : Infinity;
let hAdsValue = Infinity;
let vAdsValue = Infinity;
if (hAds != Infinity) {
if (stage2.render.isHAds && Math.abs(stage2.render.hAdsY - y2) > stage2.ddInstance.GLOBAL_ADV_WEIGHT) {
stage2.render.isHAds = false;
stage2.render.hAdsY = Infinity;
} else if (stage2.render.isHAds) {
hAdsValue = 0;
} else {
stage2.render.isHAds = true;
hAdsValue = -hAds;
stage2.render.hAdsY = y2;
}
}
if (vAds != Infinity) {
if (stage2.render.isVAds && Math.abs(stage2.render.vAdsX - x2) > stage2.ddInstance.GLOBAL_ADV_WEIGHT) {
stage2.render.isVAds = false;
stage2.render.vAdsX = Infinity;
} else if (stage2.render.isVAds) {
vAdsValue = 0;
} else {
stage2.render.isVAds = true;
vAdsValue = -vAds;
stage2.render.vAdsX = x2;
}
}
switch (this.model.passIndex) {
case 1: {
let dy = y2 - (centerPointVector.y - returnBounds.height / 2);
if (hAdsValue != Infinity) {
dy = hAdsValue;
}
returnBounds.y = returnBounds.y + dy;
returnBounds.height = returnBounds.height - dy;
if (er) {
returnBounds.x = returnBounds.x + dy * wbh / 2;
returnBounds.width = returnBounds.width - dy * wbh;
}
break;
}
case 2: {
let dy = y2 - (centerPointVector.y - returnBounds.height / 2);
let dx = x2 - centerPointVector.x - returnBounds.width / 2;
if (hAdsValue != Infinity) {
dy = hAdsValue;
}
if (vAdsValue != Infinity) {
dx = vAdsValue;
}
returnBounds.y = returnBounds.y + dy;
returnBounds.height = returnBounds.height - dy;
returnBounds.width = returnBounds.width + dx;
if (er) {
returnBounds.x = returnBounds.x + dy * wbh / 2;
returnBounds.width = returnBounds.width - dy * wbh;
returnBounds.y = returnBounds.y - dx / wbh / 2;
returnBounds.height = returnBounds.height + dx / wbh;
}
break;
}
case 3: {
let dx = x2 - centerPointVector.x - returnBounds.width / 2;
if (vAdsValue != Infinity) {
dx = vAdsValue;
}
returnBounds.width = returnBounds.width + dx;
if (er) {
returnBounds.y = returnBounds.y - dx / wbh / 2;
returnBounds.height = returnBounds.height + dx / wbh;
}
break;
}
case 4: {
let dx = x2 - centerPointVector.x - returnBounds.width / 2;
let dy = y2 - centerPointVector.y - returnBounds.height / 2;
if (hAdsValue != Infinity) {
dy = hAdsValue;
}
if (vAdsValue != Infinity) {
dx = vAdsValue;
}
returnBounds.width = returnBounds.width + dx;
returnBounds.height = returnBounds.height + dy;
if (er) {
returnBounds.y = returnBounds.y - dx / wbh / 2;
returnBounds.height = returnBounds.height + dx / wbh;
returnBounds.x = returnBounds.x - dy * wbh / 2;
returnBounds.width = returnBounds.width + dy * wbh;
}
break;
}
case 5: {
let dy = y2 - centerPointVector.y - returnBounds.height / 2;
if (hAdsValue != Infinity) {
dy = hAdsValue;
}
returnBounds.height = returnBounds.height + dy;
if (er) {
returnBounds.x = returnBounds.x - dy * wbh / 2;
returnBounds.width = returnBounds.width + dy * wbh;
}
break;
}
case 6: {
let dy = y2 - centerPointVector.y - returnBounds.height / 2;
let dx = -(centerPointVector.x - x2 - returnBounds.width / 2);
if (hAdsValue != Infinity) {
dy = hAdsValue;
}
if (vAdsValue != Infinity) {
dx = vAdsValue;
}
returnBounds.x = returnBounds.x + dx;
returnBounds.width = returnBounds.width - dx;
returnBounds.height = returnBounds.height + dy;
if (er) {
returnBounds.x = returnBounds.x - dy * wbh / 2;
returnBounds.width = returnBounds.width + dy * wbh;
returnBounds.y = returnBounds.y + dx / wbh / 2;
returnBounds.height = returnBounds.height - dx / wbh;
}
break;
}
case 7: {
let dx = -(centerPointVector.x - x2 - returnBounds.width / 2);
if (vAdsValue != Infinity) {
dx = vAdsValue;
}
returnBounds.x = returnBounds.x + dx;
returnBounds.width = returnBounds.width - dx;
if (er) {
returnBounds.y = returnBounds.y + dx / wbh / 2;
returnBounds.height = returnBounds.height - dx / wbh;
}
break;
}
case 8: {
let dy = y2 - (centerPointVector.y - returnBounds.height / 2);
let dx = -(centerPointVector.x - x2 - returnBounds.width / 2);
if (hAdsValue != Infinity) {
dy = hAdsValue;
}
if (vAdsValue != Infinity) {
dx = vAdsValue;
}
returnBounds.x = returnBounds.x + dx;
returnBounds.width = returnBounds.width - dx;
returnBounds.y = returnBounds.y + dy;
returnBounds.height = returnBounds.height - dy;
if (er) {
returnBounds.y = returnBounds.y + dx / wbh / 2;
returnBounds.height = returnBounds.height - dx / wbh;
returnBounds.x = returnBounds.x + dy * wbh / 2;
returnBounds.width = returnBounds.width - dy * wbh;
}
break;
}
}
return returnBounds;
}
};
__publicField2(_DDeiSelectorCanvasRender, "ClsName", "DDeiSelectorCanvasRender");
let DDeiSelectorCanvasRender = _DDeiSelectorCanvasRender;
const __vite_glob_1_8 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiSelectorCanvasRender,
default: DDeiSelectorCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiStageCanvasRender = class _DDeiStageCanvasRender2 {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "model");
__publicField2(this, "ddRender");
__publicField2(this, "currentOperateShape", null);
__publicField2(this, "operateState", DDeiEnumOperateState.NONE);
__publicField2(this, "selector");
__publicField2(this, "editorShadowControl", null);
__publicField2(this, "refresh", true);
__publicField2(this, "hScroll", null);
__publicField2(this, "vScroll", null);
__publicField2(this, "renderCacheData", /* @__PURE__ */ new Map());
this.model = props.model;
this.ddRender = null;
}
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiStageCanvasRender2(props);
}
// ============================== 方法 ===============================
/**
* 初始化
*/
init() {
this.ddRender = this.model.ddInstance.render;
this.initSelector();
}
/**
* 创建图形
*/
drawShape() {
var _a3, _b2, _c2, _d2;
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_BEFORE", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
if (rsState == 0 || rsState == 1) {
let rsState1 = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
let canvas = this.ddRender.getCanvas();
let rat1 = this.ddRender.ratio;
if (rsState1 == 0 || rsState1 == 1) {
this.clearStage();
if (this.model.disabled || !this.model.width || !this.model.height) {
return;
}
let ruleDisplay;
let ruleInit;
if (((_a3 = this.model.ruler) == null ? void 0 : _a3.display) || ((_b2 = this.model.ruler) == null ? void 0 : _b2.display) == 0 || ((_c2 = this.model.ruler) == null ? void 0 : _c2.display) == false) {
ruleDisplay = this.model.ruler.display;
} else if (this.model.ddInstance.ruler != null && this.model.ddInstance.ruler != void 0) {
if (typeof this.model.ddInstance.ruler == "boolean") {
ruleDisplay = this.model.ddInstance.ruler ? 1 : 0;
} else {
ruleInit = this.model.ddInstance.ruler;
ruleDisplay = ruleInit.display;
}
} else {
ruleDisplay = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "ruler.display", true);
}
this.tempRuleDisplay = ruleDisplay;
this.drawPaper();
this.calScroll();
let ctx = canvas.getContext("2d");
ctx.save();
ctx.translate(this.model.wpv.x * rat1, this.model.wpv.y * rat1);
let topDisplayIndex = -1;
let initI = this.model.layers.length - 1;
for (let i2 = initI; i2 >= 0; i2--) {
if (this.model.layers[i2].tempDisplay) {
topDisplayIndex = i2;
} else if (this.model.layers[i2].display == 1) {
this.model.layers[i2].render.tempZIndex = initI - i2 + 1;
this.model.layers[i2].render.drawShape();
} else if (this.model.layers[i2].display == 0) {
this.model.layers[i2].render.drawShape();
}
}
if (topDisplayIndex != -1) {
this.model.layers[topDisplayIndex].render.tempZIndex = initI + 2;
this.model.layers[topDisplayIndex].render.drawShape();
}
this.drawGrid(topDisplayIndex == -1 ? 0 : topDisplayIndex);
this.drawEditorShadowControl();
if (this.selector) {
this.selector.render.drawShape();
}
ctx.restore();
this.drawMark();
this.drawRuler();
this.drawHelpLines();
this.drawScroll();
this.helpLines = null;
}
DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_VIEW_AFTER", DDeiEnumOperateType.VIEW, { models: [this.model] }, this.ddRender.model, null);
let viewerEles = (_d2 = canvas.parentElement) == null ? void 0 : _d2.getElementsByClassName("ddei-editor-canvasview-contentlayer");
if (viewerEles) {
let ruleWeight = 0;
if (this.tempRuleDisplay == 1 || this.tempRuleDisplay == "1") {
ruleWeight = 15;
}
let hScrollWeight = 0, vScrollWeight = 0;
if (this.vScroll) {
vScrollWeight = 15;
}
if (this.hScroll) {
hScrollWeight = 15;
}
for (let ei = 0; ei < viewerEles.length; ei++) {
let viewerEle = viewerEles[ei];
viewerEle.style.marginLeft = ruleWeight + "px";
viewerEle.style.marginTop = ruleWeight + "px";
viewerEle.style.width = canvas.offsetWidth / rat1 - ruleWeight - vScrollWeight + "px";
viewerEle.style.height = canvas.offsetHeight / rat1 - ruleWeight - hScrollWeight + "px";
}
delete this.tempRuleDisplay;
}
}
}
/**
* 显示辅助对齐线以及文本
*/
drawHelpLines() {
var _a3, _b2, _c2;
if (this.helpLines) {
let ruleInit;
if (((_a3 = this.model.ruler) == null ? void 0 : _a3.display) || ((_b2 = this.model.ruler) == null ? void 0 : _b2.display) == 0 || ((_c2 = this.model.ruler) == null ? void 0 : _c2.display) == false)
;
else if (this.model.ddInstance.ruler != null && this.model.ddInstance.ruler != void 0) {
if (typeof this.model.ddInstance.ruler == "boolean")
;
else {
ruleInit = this.model.ddInstance.ruler;
}
} else
;
let hpoint = this.helpLines.hpoint;
let vpoint = this.helpLines.vpoint;
let rect = this.helpLines.rect;
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let rat1 = this.ddRender.ratio;
let stageRatio2 = this.model.getStageRatio();
let ratio = rat1 * stageRatio2;
ctx.save();
ctx.translate((this.model.wpv.x + 1) * rat1, (this.model.wpv.y + 1) * rat1);
if (rect) {
ctx.save();
ctx.textAlign = "left";
ctx.textBaseline = "top";
let fontSize = 12;
let font = "bold " + fontSize * rat1 + "px Microsoft YaHei";
ctx.font = font;
let xText = 0;
let yText = 0;
if (this.operateState == DDeiEnumOperateState.CONTROL_DRAGING || this.operateState == DDeiEnumOperateState.CONTROL_CREATING) {
xText = rect.x.toFixed(0);
yText = rect.y.toFixed(0);
} else if (this.operateState == DDeiEnumOperateState.CONTROL_CHANGING_BOUND) {
xText = rect.width.toFixed(0);
yText = rect.height.toFixed(0);
} else if (this.operateState == DDeiEnumOperateState.CONTROL_ROTATE) {
xText = rect.rotate.toFixed(0);
}
if ((this.tempRuleDisplay == 1 || this.tempRuleDisplay == "1") && this.operateState != DDeiEnumOperateState.CONTROL_ROTATE) {
let stageRatio22 = this.model.getStageRatio();
let xDPI = this.ddRender.model.dpi.x;
let unit = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "ruler.unit", true, ruleInit);
let rulerConfig = DDeiConfig$1.RULER[unit];
let unitWeight = DDeiUtil$1.unitToPix(rulerConfig.size, unit, xDPI) * rat1;
let marginWeight = unitWeight * stageRatio22;
if (this.operateState == DDeiEnumOperateState.CONTROL_DRAGING || this.operateState == DDeiEnumOperateState.CONTROL_CREATING) {
let startBaseX = this.model.spv.x * rat1;
let startBaseY = this.model.spv.y * rat1;
xText = (rect.x * rat1 - startBaseX) / marginWeight * rulerConfig.size;
yText = (rect.y * rat1 - startBaseY) / marginWeight * rulerConfig.size;
} else if (this.operateState == DDeiEnumOperateState.CONTROL_CHANGING_BOUND) {
xText = rect.width * rat1 / marginWeight * rulerConfig.size;
yText = rect.height * rat1 / marginWeight * rulerConfig.size;
}
if (xText) {
if (("" + xText).indexOf(".") != -1) {
xText = xText.toFixed(1);
}
xText += rulerConfig.title;
}
if (yText) {
if (("" + yText).indexOf(".") != -1) {
yText = yText.toFixed(1);
}
yText += rulerConfig.title;
}
}
let text2 = "";
if (xText || yText) {
if (this.operateState == DDeiEnumOperateState.CONTROL_DRAGING || this.operateState == DDeiEnumOperateState.CONTROL_CREATING) {
text2 = xText + " , " + yText;
} else if (this.operateState == DDeiEnumOperateState.CONTROL_CHANGING_BOUND) {
text2 = xText + " x " + yText;
} else if (this.operateState == DDeiEnumOperateState.CONTROL_ROTATE) {
text2 = xText + "°";
}
}
let textRect = DDeiUtil$1.measureText(text2, font, ctx, fontSize * rat1);
let width = textRect.width / rat1 + 10;
let height = fontSize + 4;
let x2, y2;
if (this.operateState == DDeiEnumOperateState.CONTROL_DRAGING || this.operateState == DDeiEnumOperateState.CONTROL_CREATING) {
x2 = (rect.x * stageRatio2 - width / 2) * rat1;
y2 = (rect.y * stageRatio2 - height - 5) * rat1;
} else if (this.operateState == DDeiEnumOperateState.CONTROL_CHANGING_BOUND) {
x2 = (rect.x * stageRatio2 + (rect.width - width) / 2) * rat1;
y2 = (rect.y * stageRatio2 + rect.height + height / 2) * rat1;
} else if (this.operateState == DDeiEnumOperateState.CONTROL_ROTATE) {
x2 = rect.x * ratio;
y2 = rect.y * ratio;
}
width *= rat1;
height *= rat1;
DDeiUtil$1.drawRectRound(ctx, x2, y2, width, height, 5, false, "", true, "#1F72FF");
ctx.fillStyle = "white";
ctx.fillText(text2, x2 + (width - textRect.width) / 2, y2 + (height - fontSize * rat1) / 2);
if (this.tempRuleDisplay == 1 || this.tempRuleDisplay == "1") {
ctx.strokeStyle = "red";
let weight = 16 * rat1;
ctx.lineWidth = 1.5 * rat1;
ctx.globalAlpha = 0.5;
let x1 = (rect.x * stageRatio2 + this.model.wpv.x) * rat1;
let y1 = (rect.y * stageRatio2 + this.model.wpv.y) * rat1;
ctx.translate(-this.model.wpv.x * rat1, -this.model.wpv.y * rat1);
ctx.beginPath();
ctx.moveTo(x1, 0);
ctx.lineTo(x1, weight);
ctx.closePath();
ctx.stroke();
ctx.beginPath();
ctx.moveTo(0, y1);
ctx.lineTo(weight, y1);
ctx.closePath();
ctx.stroke();
}
ctx.restore();
}
if (this.ddRender.model.GLOBAL_HELP_LINE_ENABLE) {
let lineOffset = 0;
ctx.lineWidth = 1 * ratio;
ctx.setLineDash([0, 1 * ratio, 1 * ratio]);
ctx.strokeStyle = DDeiUtil$1.getStyleValue("dot", this.ddRender.model);
if (hpoint) {
for (let y2 in hpoint) {
ctx.beginPath();
ctx.moveTo(hpoint[y2].sx * ratio - 100, y2 * ratio + lineOffset);
ctx.lineTo(hpoint[y2].ex * ratio + 100, y2 * ratio + lineOffset);
ctx.stroke();
}
}
if (vpoint) {
for (let x2 in vpoint) {
ctx.beginPath();
ctx.moveTo(x2 * ratio + lineOffset, vpoint[x2].sy * ratio - 100);
ctx.lineTo(x2 * ratio + lineOffset, vpoint[x2].ey * ratio + 100);
ctx.stroke();
}
}
}
ctx.beginPath();
ctx.restore();
}
}
/**
* 绘制编辑时的影子元素
*/
drawEditorShadowControl() {
if (this.editorShadowControl) {
let item = this.editorShadowControl;
item.render.drawShape(null, 0, null, 99999);
}
}
/**
* 清空画布
*/
clearStage() {
let canvas = this.ddRender.getCanvas();
canvas.width = canvas.width;
}
/**
* 绘制纸张
*/
drawPaper() {
var _a3, _b2, _c2, _d2, _e2, _f;
let paperType;
if ((_a3 = this.model.paper) == null ? void 0 : _a3.type) {
paperType = this.model.paper.type;
} else if ((_b2 = this.ddRender) == null ? void 0 : _b2.model.paper) {
if (typeof ((_c2 = this.ddRender) == null ? void 0 : _c2.model.paper) == "string") {
paperType = (_d2 = this.ddRender) == null ? void 0 : _d2.model.paper;
} else {
paperType = (_e2 = this.ddRender) == null ? void 0 : _e2.model.paper.type;
}
} else {
paperType = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "paper.type", true);
}
let paperConfig = DDeiConfig$1.PAPER[paperType];
if (paperConfig) {
let rat1 = this.ddRender.ratio;
let stageRatio2 = this.model.getStageRatio();
let ratio = rat1 * stageRatio2;
let wpv = this.model.wpv;
let wpvX = -wpv.x * rat1;
let wpvY = -wpv.y * rat1;
let offsetWidth = 1 * ratio / 2;
let paperSize = DDeiUtil$1.getPaperSize(this.model, paperType);
let paperWidth = paperSize.width;
let paperHeight = paperSize.height;
let startPaperX = this.model.spv.x * ratio + 1;
let startPaperY = this.model.spv.y * ratio + 1;
let posX = startPaperX - wpvX + offsetWidth;
let posY = startPaperY - wpvY + offsetWidth;
this.paperStartX = posX;
this.paperStartY = posY;
let maxOutRect = DDeiAbstractShape.getOutRectByPV(this.model.getLayerModels());
maxOutRect.x = maxOutRect.x * ratio;
maxOutRect.x1 = maxOutRect.x1 * ratio;
maxOutRect.y = maxOutRect.y * ratio;
maxOutRect.y1 = maxOutRect.y1 * ratio;
let leftExtNum = 0, rightExtNum = 0, topExtNum = 0, bottomExtNum = 0;
if (maxOutRect.width > 0 && maxOutRect.height > 0) {
if (maxOutRect.x < startPaperX) {
leftExtNum = parseInt((startPaperX - maxOutRect.x) / paperWidth);
if (Math.abs((startPaperX - maxOutRect.x) % paperWidth) > 1) {
leftExtNum++;
}
}
if (maxOutRect.x1 > startPaperX + paperWidth) {
rightExtNum = parseInt((maxOutRect.x1 - startPaperX - paperWidth) / paperWidth);
if (Math.abs((maxOutRect.x1 - startPaperX - paperWidth) % paperWidth) > 1) {
rightExtNum++;
}
}
if (maxOutRect.y < startPaperY) {
topExtNum = parseInt((startPaperY - maxOutRect.y) / paperHeight);
if (Math.abs((startPaperY - maxOutRect.y) % paperHeight) > 1) {
topExtNum++;
}
}
if (maxOutRect.y1 > startPaperY + paperHeight) {
bottomExtNum = parseInt((maxOutRect.y1 - startPaperY - paperHeight) / paperHeight);
if (Math.abs((maxOutRect.y1 - startPaperY - paperHeight) % paperHeight) > 1) {
bottomExtNum++;
}
}
}
let paperOutRect = {
x: posX + -leftExtNum * paperWidth,
y: posY + -topExtNum * paperHeight,
w: (rightExtNum + leftExtNum + 1) * paperWidth,
h: (bottomExtNum + topExtNum + 1) * paperHeight
};
this.paperOutRect = paperOutRect;
let topDisplayIndex = -1;
let isBottom = true;
for (let l = this.model.layers.length - 1; l >= 0; l--) {
if (this.model.layers[l].tempDisplay) {
topDisplayIndex = l;
} else if (this.model.layers[l].display == 1) {
this.model.layers[l].render.drawBackground(paperOutRect.x, paperOutRect.y, paperOutRect.w, paperOutRect.h, isBottom);
isBottom = false;
}
}
if (topDisplayIndex != -1) {
this.model.layers[topDisplayIndex].render.drawBackground(paperOutRect.x, paperOutRect.y, paperOutRect.w, paperOutRect.h, isBottom);
isBottom = false;
}
let canvas = (_f = this.model.layers[topDisplayIndex == -1 ? 0 : topDisplayIndex].render) == null ? void 0 : _f.bgCanvas;
if (canvas) {
let ctx = canvas.getContext("2d");
ctx.save();
let ruleWeight = 0;
if (this.tempRuleDisplay == 1 || this.tempRuleDisplay == "1") {
ruleWeight = 15;
}
ctx.translate(-ruleWeight * rat1, -ruleWeight * rat1);
ctx.lineWidth = 1;
ctx.fillStyle = "white";
ctx.strokeStyle = "grey";
ctx.setLineDash([5, 5]);
for (let i2 = -leftExtNum + 1; i2 <= rightExtNum; i2++) {
ctx.beginPath();
ctx.moveTo(posX + i2 * paperWidth, paperOutRect.y);
ctx.lineTo(posX + i2 * paperWidth, paperOutRect.y + paperOutRect.h);
ctx.stroke();
}
for (let i2 = -topExtNum + 1; i2 <= bottomExtNum; i2++) {
ctx.beginPath();
ctx.moveTo(paperOutRect.x, posY + i2 * paperHeight);
ctx.lineTo(paperOutRect.x + paperOutRect.w, posY + i2 * paperHeight);
ctx.stroke();
}
ctx.setLineDash([]);
let lineWidth = 1;
ctx.lineWidth = lineWidth;
ctx.strokeStyle = "black";
ctx.strokeRect(posX + -leftExtNum * paperWidth - lineWidth, posY + -topExtNum * paperHeight - lineWidth, (rightExtNum + leftExtNum + 1) * paperWidth + 2 * lineWidth, (bottomExtNum + topExtNum + 1) * paperHeight + 2 * lineWidth);
ctx.restore();
}
} else {
let canvas = this.ddRender.getCanvas();
let topDisplayIndex = -1;
for (let l = this.model.layers.length - 1; l >= 0; l--) {
if (this.model.layers[l].tempDisplay) {
topDisplayIndex = l;
} else if (this.model.layers[l].display == 1) {
this.model.layers[l].render.drawBackground(0, 0, canvas.width, canvas.height);
}
}
if (topDisplayIndex != -1) {
this.model.layers[topDisplayIndex].render.drawBackground(0, 0, canvas.width, canvas.height);
}
}
}
drawTest() {
let linePathData = this.linePathData;
if (linePathData) {
let corssPoints = linePathData.corssPoints;
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let rat1 = this.ddRender.ratio;
let stageRatio2 = this.model.getStageRatio();
let ratio = rat1 * stageRatio2;
ctx.save();
ctx.font = "bold " + 12 * ratio + "px Microsoft YaHei";
corssPoints.forEach((point2) => {
let weight = 3;
ctx.fillStyle = "grey";
ctx.strokeStyle = "green";
ctx.beginPath();
ctx.ellipse(point2.x * rat1, point2.y * rat1, weight * ratio, weight * ratio, 0, 0, Math.PI * 2);
ctx.fill();
ctx.stroke();
ctx.closePath();
});
let extLines = linePathData.extLines;
ctx.lineWidth = 1;
extLines.forEach((extLine) => {
ctx.strokeStyle = "red";
ctx.globalAlpha = 0.1;
ctx.beginPath();
ctx.moveTo(extLine[0].x * rat1, extLine[0].y * rat1);
if (extLine[0].color) {
ctx.strokeStyle = extLine[0].color;
ctx.globalAlpha = 0.3;
}
if (extLine[0].x == extLine[1].x) {
if (extLine[0].y >= extLine[1].y) {
ctx.lineTo(extLine[1].x * rat1, (extLine[1].y - 1e3) * rat1);
} else {
ctx.lineTo(extLine[1].x * rat1, (extLine[1].y + 1e3) * rat1);
}
} else if (extLine[0].y == extLine[1].y) {
if (extLine[0].x >= extLine[1].x) {
ctx.lineTo((extLine[1].x - 1e3) * rat1, extLine[1].y * rat1);
} else {
ctx.lineTo((extLine[1].x + 1e3) * rat1, extLine[1].y * rat1);
}
}
ctx.stroke();
ctx.closePath();
});
ctx.restore();
}
}
/**
* 标尺
*/
drawRuler() {
var _a3, _b2, _c2, _d2, _e2;
let ruleInit;
if (((_a3 = this.model.ruler) == null ? void 0 : _a3.display) || ((_b2 = this.model.ruler) == null ? void 0 : _b2.display) == 0 || ((_c2 = this.model.ruler) == null ? void 0 : _c2.display) == false)
;
else if (this.model.ddInstance.ruler != null && this.model.ddInstance.ruler != void 0) {
if (typeof this.model.ddInstance.ruler == "boolean")
;
else {
ruleInit = this.model.ddInstance.ruler;
}
} else
;
if (this.tempRuleDisplay == 1 || this.tempRuleDisplay == "1") {
let canvas = (_d2 = this.ddRender) == null ? void 0 : _d2.getCanvas();
let ctx = canvas.getContext("2d");
let rat1 = this.ddRender.ratio;
let stageRatio2 = this.model.getStageRatio();
let xDPI = this.ddRender.model.dpi.x;
let unit = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "ruler.unit", true, ruleInit);
let rulerConfig = DDeiConfig$1.RULER[unit];
let unitWeight = DDeiUtil$1.unitToPix(rulerConfig.size, unit, xDPI) * rat1;
let marginWeight = unitWeight * stageRatio2;
let timesNums = [0.25, 0.5, 1, 2, 4, 8];
let curTimes = 0.25;
for (let i2 = 1; i2 < timesNums.length; i2++) {
if (stageRatio2 >= timesNums[i2]) {
curTimes = timesNums[i2];
}
}
let standWeight = curTimes * unitWeight;
let passPercent = Math.round((marginWeight - standWeight) / standWeight * 100);
let splitNumber = rulerConfig.parts[0];
if (passPercent > 0) {
let p = Math.round(1 / rulerConfig.parts.length * 100);
for (let i2 = 1; i2 < rulerConfig.parts.length; i2++) {
if (passPercent >= i2 * p) {
splitNumber = rulerConfig.parts[i2];
}
}
}
let splitedWeight = marginWeight / splitNumber;
let weight = 16 * rat1;
ctx.save();
let fontSize = 9.5;
if (stageRatio2 <= 0.5) {
fontSize -= 1;
} else if (stageRatio2 <= 0.25) {
fontSize -= 3;
}
fontSize *= rat1;
ctx.font = fontSize + "px Microsoft YaHei";
ctx.lineWidth = 1;
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-rule-border", this.ddRender.model);
ctx.fillStyle = DDeiUtil$1.getStyleValue("canvas-rule-background", this.ddRender.model);
let cwidth = canvas.width;
let cheight = canvas.height;
let paperSize = DDeiUtil$1.getPaperSize(this.model);
let paperWidth = paperSize.width;
let paperHeight = paperSize.height;
if (!this.model.spv) {
let sx = this.model.width / 2 - paperWidth / 2 / rat1 / stageRatio2;
let sy = this.model.height / 2 - paperHeight / 2 / rat1 / stageRatio2;
this.model.spv = new Vector3(sx, sy, 1);
}
let startBaseX = this.model.spv.x * rat1 * stageRatio2;
let startBaseY = this.model.spv.y * rat1 * stageRatio2;
if (this.tempRuleDisplay == 1 || this.tempRuleDisplay == "1") {
ctx.beginPath();
ctx.fillRect(0, 0, cwidth, weight);
ctx.moveTo(cwidth, 0);
ctx.lineTo(cwidth, weight);
ctx.lineTo(0, weight);
ctx.stroke();
ctx.beginPath();
ctx.fillRect(0, 0, weight, cheight);
ctx.moveTo(0, cheight);
ctx.lineTo(weight, cheight);
ctx.lineTo(weight, 0);
ctx.stroke();
}
let textOffset = 1 * rat1;
ctx.fillStyle = "rgb(200,200,200)";
let wpvX = -this.model.wpv.x * rat1;
let wpvY = -this.model.wpv.y * rat1;
let x2 = 0;
let curX = startBaseX - wpvX;
while (curX <= cwidth) {
if (curX > weight) {
ctx.beginPath();
ctx.moveTo(curX, 0);
let nMod = x2 % splitNumber;
if (nMod != 0) {
ctx.moveTo(curX, 15);
}
if (nMod != 0) {
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-rule-border", this.ddRender.model);
} else {
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-rule-border", this.ddRender.model);
}
ctx.lineTo(curX, weight);
ctx.stroke();
}
curX += splitedWeight;
x2++;
}
x2 = 0;
curX = startBaseX - wpvX;
while (curX >= 0) {
if (curX > weight) {
ctx.beginPath();
ctx.moveTo(curX, 0);
let nMod = x2 % splitNumber;
if (nMod != 0) {
ctx.moveTo(curX, 15);
}
if (nMod != 0) {
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-rule-border", this.ddRender.model);
} else {
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-rule-border", this.ddRender.model);
}
ctx.lineTo(curX, weight);
ctx.stroke();
}
curX -= splitedWeight;
x2--;
}
let curY = startBaseY - wpvY;
let y2 = 0;
while (curY <= cheight) {
if (curY > weight) {
ctx.beginPath();
ctx.moveTo(0, curY);
let lineToNumber = 0;
let nMod = y2 % splitNumber;
if (nMod != 0) {
ctx.moveTo(15, curY);
}
lineToNumber = weight;
if (nMod != 0) {
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-rule-border", this.ddRender.model);
} else {
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-rule-border", this.ddRender.model);
}
ctx.lineTo(lineToNumber, curY);
ctx.stroke();
}
curY += splitedWeight;
y2++;
}
curY = startBaseY - wpvY;
y2 = 0;
while (curY >= 0) {
if (curY > weight) {
ctx.beginPath();
ctx.moveTo(0, curY);
let lineToNumber = 0;
let nMod = y2 % splitNumber;
if (nMod != 0) {
ctx.moveTo(15, curY);
}
lineToNumber = weight;
if (nMod != 0) {
ctx.strokeStyle = "rgb(230,230,230)";
} else {
ctx.strokeStyle = "rgb(220,220,220)";
}
ctx.lineTo(lineToNumber, curY);
ctx.stroke();
}
curY -= splitedWeight;
y2--;
}
ctx.fillStyle = DDeiUtil$1.getStyleValue("canvas-control-title", this.ddRender.model);
curX = startBaseX - wpvX;
x2 = 0;
let textTime = 1;
if (stageRatio2 > 0.25 && stageRatio2 <= 0.5) {
textTime = 2;
} else if (stageRatio2 > 0 && stageRatio2 <= 0.25) {
textTime = 4;
}
while (curX <= cwidth) {
if (x2 % textTime == 0) {
let posText = x2 * rulerConfig.size + "";
if (posText.indexOf(".") != -1) {
posText = parseFloat(posText).toFixed(2);
}
ctx.fillText(posText, curX + textOffset, fontSize);
}
x2++;
curX += marginWeight;
}
curX = startBaseX - wpvX;
x2 = 0;
while (curX >= 0) {
if (x2 % textTime == 0) {
let posText = x2 * rulerConfig.size + "";
if (posText.indexOf(".") != -1) {
posText = parseFloat(posText).toFixed(2);
}
ctx.fillText(posText, curX + textOffset, fontSize);
}
x2--;
curX -= marginWeight;
}
ctx.save();
ctx.scale(-1, 1);
ctx.rotate(90 * DDeiConfig$1.ROTATE_UNIT);
ctx.scale(-1, 1);
curY = startBaseY - wpvY;
y2 = 0;
let oneSize = DDeiUtil$1.measureTextSize((_e2 = this.ddRender) == null ? void 0 : _e2.model, "0", "Microsoft YaHei", fontSize).width;
while (curY <= cheight) {
if (y2 % textTime == 0) {
let posText = y2 * rulerConfig.size + "";
if (posText.indexOf(".") != -1) {
posText = parseFloat(posText).toFixed(2);
}
ctx.fillText(posText, -curY - textOffset - oneSize * posText.length, fontSize);
}
y2++;
curY += marginWeight;
}
curY = startBaseY - wpvY;
y2 = 0;
while (curY >= 0) {
if (y2 % textTime == 0) {
let posText = y2 * rulerConfig.size + "";
if (posText.indexOf(".") != -1) {
posText = parseFloat(posText).toFixed(2);
}
ctx.fillText(posText, -curY - textOffset - oneSize * posText.length, fontSize);
}
y2--;
curY -= marginWeight;
}
ctx.restore();
ctx.fillStyle = DDeiUtil$1.getStyleValue("canvas-rule-background", this.ddRender.model);
ctx.fillRect(0, 0, weight, weight);
ctx.moveTo(0, weight);
ctx.lineTo(weight, weight);
ctx.stroke();
ctx.moveTo(weight, 0);
ctx.lineTo(weight, weight);
ctx.stroke();
let selectedModels = this.model.selectedModels;
if ((selectedModels == null ? void 0 : selectedModels.size) > 0) {
let rect = DDeiAbstractShape.getOutRectByPV(Array.from(selectedModels == null ? void 0 : selectedModels.values()));
ctx.strokeStyle = "#1F72FF";
let weight2 = 16 * rat1;
ctx.lineWidth = 1.5 * rat1;
ctx.globalAlpha = 0.7;
let x1 = (rect.x * stageRatio2 + this.model.wpv.x) * rat1;
let y1 = (rect.y * stageRatio2 + this.model.wpv.y) * rat1;
ctx.beginPath();
ctx.moveTo(x1, 0);
ctx.lineTo(x1, weight2);
ctx.closePath();
ctx.stroke();
ctx.beginPath();
ctx.moveTo(0, y1);
ctx.lineTo(weight2, y1);
ctx.closePath();
ctx.stroke();
}
ctx.restore();
}
}
/**
* 绘制网格
*/
drawGrid(layerIndex) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k;
if (layerIndex == -1 || !this.model.layers[layerIndex].render.bgCanvas) {
return;
}
let paperType;
if ((_a3 = this.model.paper) == null ? void 0 : _a3.type) {
paperType = this.model.paper.type;
} else if ((_b2 = this.ddRender) == null ? void 0 : _b2.model.paper) {
if (typeof ((_c2 = this.ddRender) == null ? void 0 : _c2.model.paper) == "string") {
paperType = (_d2 = this.ddRender) == null ? void 0 : _d2.model.paper;
} else {
paperType = (_e2 = this.ddRender) == null ? void 0 : _e2.model.paper.type;
}
} else {
paperType = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "paper.type", true);
}
let paperConfig = DDeiConfig$1.PAPER[paperType];
if (paperConfig) {
let gridDisplay;
if (((_f = this.model.grid) == null ? void 0 : _f.display) || ((_g = this.model.grid) == null ? void 0 : _g.display) == 0) {
gridDisplay = (_h = this.model.grid) == null ? void 0 : _h.display;
} else if (((_i = this.ddRender) == null ? void 0 : _i.model.grid) || ((_j = this.ddRender) == null ? void 0 : _j.model.grid) == 0) {
gridDisplay = (_k = this.ddRender) == null ? void 0 : _k.model.grid;
} else {
gridDisplay = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "grid.display", true);
}
if (gridDisplay == 1 || gridDisplay == "1" || gridDisplay == 2 || gridDisplay == "2") {
let canvas = this.model.layers[layerIndex].render.bgCanvas;
let ctx = canvas.getContext("2d");
let rat1 = this.ddRender.ratio;
let stageRatio2 = this.model.getStageRatio();
let xDPI = this.ddRender.model.dpi.x;
let ruleInit;
if (this.model.ddInstance.ruler) {
if (typeof this.model.ddInstance.ruler == "object") {
ruleInit = this.model.ddInstance.ruler;
}
}
let unit = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "ruler.unit", true, ruleInit);
let rulerConfig = DDeiConfig$1.RULER[unit];
let unitWeight = DDeiUtil$1.unitToPix(rulerConfig.size, unit, xDPI) * rat1;
let marginWeight = unitWeight * stageRatio2;
let timesNums = [0.25, 0.5, 1, 2, 4, 8];
let curTimes = 0.25;
for (let i2 = 1; i2 < timesNums.length; i2++) {
if (stageRatio2 >= timesNums[i2]) {
curTimes = timesNums[i2];
}
}
let standWeight = curTimes * unitWeight;
let passPercent = Math.round((marginWeight - standWeight) / standWeight * 100);
let splitNumber = rulerConfig.parts[0];
if (passPercent > 0) {
let p = Math.round(1 / rulerConfig.parts.length * 100);
for (let i2 = 1; i2 < rulerConfig.parts.length; i2++) {
if (passPercent >= i2 * p) {
splitNumber = rulerConfig.parts[i2];
}
}
}
let paperOutRect = this.paperOutRect;
let splitedWeight = marginWeight / splitNumber;
ctx.save();
let ruleWeight = 0;
if (this.tempRuleDisplay == 1 || this.tempRuleDisplay == "1") {
ruleWeight = 15;
}
ctx.translate(-ruleWeight * rat1, -ruleWeight * rat1);
let fontSize = 11 * rat1;
ctx.font = fontSize + "px Microsoft YaHei";
ctx.lineWidth = 1;
ctx.strokeStyle = "rgb(190,190,190)";
ctx.fillStyle = "white";
let ex = paperOutRect.x + paperOutRect.w;
let ey = paperOutRect.y + paperOutRect.h;
if (gridDisplay == 2 || gridDisplay == "2") {
ctx.strokeStyle = DDeiUtil$1.getColorObj(DDeiUtil$1.getStyleValue("canvas-grid-dot", this.ddRender.model));
ctx.lineWidth = 2 * stageRatio2;
ctx.setLineDash([2 * stageRatio2, splitedWeight - stageRatio2]);
for (let sx = this.paperStartX; sx <= ex; sx = sx + splitedWeight) {
ctx.beginPath();
ctx.moveTo(sx, paperOutRect.y);
ctx.lineTo(sx, ey);
ctx.stroke();
}
for (let sx = this.paperStartX; sx >= paperOutRect.x; sx = sx - splitedWeight) {
ctx.beginPath();
ctx.moveTo(sx, paperOutRect.y);
ctx.lineTo(sx, ey);
ctx.stroke();
}
} else if (gridDisplay == 1 || gridDisplay == "1") {
let strokeColor = DDeiUtil$1.getColorObj(DDeiUtil$1.getStyleValue("canvas-grid-line", this.ddRender.model));
let strokeLighten = strokeColor == null ? void 0 : strokeColor.lighten(0.05);
for (let sx = this.paperStartX, n = 0; sx <= ex; sx = sx + splitedWeight, n++) {
let nMod = n % splitNumber;
if (nMod != 0) {
ctx.strokeStyle = strokeLighten == null ? void 0 : strokeLighten.toColor();
} else {
ctx.strokeStyle = strokeColor == null ? void 0 : strokeColor.toColor();
}
ctx.beginPath();
ctx.moveTo(sx, paperOutRect.y);
ctx.lineTo(sx, ey);
ctx.stroke();
}
for (let sx = this.paperStartX, n = 0; sx >= paperOutRect.x; sx = sx - splitedWeight, n++) {
let nMod = n % splitNumber;
if (nMod != 0) {
ctx.strokeStyle = strokeLighten == null ? void 0 : strokeLighten.toColor();
} else {
ctx.strokeStyle = strokeColor == null ? void 0 : strokeColor.toColor();
}
ctx.beginPath();
ctx.moveTo(sx, paperOutRect.y);
ctx.lineTo(sx, ey);
ctx.stroke();
}
for (let sy = this.paperStartY, n = 0; sy <= ey; sy = sy + splitedWeight, n++) {
let nMod = n % splitNumber;
if (nMod != 0) {
ctx.strokeStyle = strokeLighten == null ? void 0 : strokeLighten.toColor();
} else {
ctx.strokeStyle = strokeColor == null ? void 0 : strokeColor.toColor();
}
ctx.beginPath();
ctx.moveTo(paperOutRect.x, sy);
ctx.lineTo(ex, sy);
ctx.stroke();
}
for (let sy = this.paperStartY, n = 0; sy >= paperOutRect.y; sy = sy - splitedWeight, n++) {
let nMod = n % splitNumber;
if (nMod != 0) {
ctx.strokeStyle = strokeLighten == null ? void 0 : strokeLighten.toColor();
} else {
ctx.strokeStyle = strokeColor == null ? void 0 : strokeColor.toColor();
}
ctx.beginPath();
ctx.moveTo(paperOutRect.x, sy);
ctx.lineTo(ex, sy);
ctx.stroke();
}
}
ctx.restore();
}
}
}
/**
* 绘制水印
*/
drawMark() {
var _a3, _b2, _c2;
let ddInstance = (_a3 = this.ddRender) == null ? void 0 : _a3.model;
let markInit;
if (ddInstance.mark) {
if (typeof ddInstance.mark == "object") {
markInit = ddInstance.mark;
} else {
markInit = { data: ddInstance == null ? void 0 : ddInstance.mark, type: 1 };
}
}
let markType = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "mark.type", true, markInit);
if (markType == 1 || markType == "1") {
let text2 = DDeiUtil$1.getReplacibleValue(this.model, "mark.data", false, false, markInit);
if (text2) {
if (!this.markCanvas) {
this.markCanvas = document.createElement("canvas");
}
let markCanvas = this.markCanvas;
let canvas = (_b2 = this.ddRender) == null ? void 0 : _b2.getCanvas();
let ctx = canvas.getContext("2d");
let rat1 = this.ddRender.ratio;
let stageRatio2 = this.model.getStageRatio();
let ratio = rat1 * stageRatio2;
ctx.save();
let fiFamily = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "mark.font.family", true, markInit);
let fiSize = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "mark.font.size", true, markInit);
let fiColor = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "mark.font.color", true, markInit);
if (!fiColor) {
fiColor = DDeiUtil$1.getStyleValue("canvas-mark-title", this.ddRender.model);
}
let fontSize = fiSize * ratio;
let textSize = DDeiUtil$1.measureTextSize(this.model.ddInstance, text2, fiFamily, fontSize);
let weight = Math.max(textSize.width, textSize.height);
let direct = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "mark.direct", true, markInit);
let ps = [
new Vector3(-weight * 0.5, -weight * 0.5, 1),
new Vector3(weight * 0.5, -weight * 0.5, 1),
new Vector3(weight * 0.5, weight * 0.5, 1),
new Vector3(-weight * 0.5, weight * 0.5, 1)
];
if (direct == 1) {
let rotateMatrix = new Matrix3(
Math.cos(45 * DDeiConfig$1.ROTATE_UNIT),
Math.sin(45 * DDeiConfig$1.ROTATE_UNIT),
0,
-Math.sin(45 * DDeiConfig$1.ROTATE_UNIT),
Math.cos(45 * DDeiConfig$1.ROTATE_UNIT),
0,
0,
0,
1
);
ps.forEach((p) => {
p.applyMatrix3(rotateMatrix);
});
let outRect = DDeiAbstractShape.pvsToOutRect(ps);
markCanvas.setAttribute("width", outRect.width);
markCanvas.setAttribute("height", outRect.height);
} else if (direct == 2) {
let rotateMatrix = new Matrix3(
Math.cos(-45 * DDeiConfig$1.ROTATE_UNIT),
Math.sin(-45 * DDeiConfig$1.ROTATE_UNIT),
0,
-Math.sin(-45 * DDeiConfig$1.ROTATE_UNIT),
Math.cos(-45 * DDeiConfig$1.ROTATE_UNIT),
0,
0,
0,
1
);
ps.forEach((p) => {
p.applyMatrix3(rotateMatrix);
});
let outRect = DDeiAbstractShape.pvsToOutRect(ps);
markCanvas.setAttribute("width", outRect.width);
markCanvas.setAttribute("height", outRect.height);
} else {
markCanvas.setAttribute("width", weight);
markCanvas.setAttribute("height", weight);
}
let markCtx = markCanvas.getContext("2d");
markCtx.save();
markCtx.font = fontSize + "px " + fiFamily;
markCtx.fillStyle = fiColor;
let opac = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "mark.opacity", true, markInit);
if (opac) {
markCtx.globalAlpha = opac;
}
if (direct == 1) {
markCtx.translate(markCanvas.width * 0.5, markCanvas.height * 0.5);
markCtx.rotate(45 * DDeiConfig$1.ROTATE_UNIT);
markCtx.translate(-markCanvas.width * 0.5, -markCanvas.height * 0.5);
} else if (direct == 2) {
markCtx.translate(markCanvas.width * 0.5, markCanvas.height * 0.5);
markCtx.rotate(-45 * DDeiConfig$1.ROTATE_UNIT);
markCtx.translate(-markCanvas.width * 0.5, -markCanvas.height * 0.5);
}
markCtx.clearRect(0, 0, markCanvas.width, markCanvas.height);
markCtx == null ? void 0 : markCtx.fillText(text2, 0, (markCanvas.height - textSize.height) / 2);
let marginWidth = textSize.width + 50 * ratio;
let marginHeight = textSize.height + 100 * ratio;
this.paperOutRect;
let cwidth = this.model.width * rat1;
let cheight = this.model.height * rat1;
let startBaseX = this.model.spv.x * ratio;
let wpvX = -this.model.wpv.x * rat1;
let startBaseY = this.model.spv.y * ratio;
let wpvY = -this.model.wpv.y * rat1;
for (let x2 = startBaseX - wpvX; x2 <= cwidth; x2 += marginWidth) {
for (let y2 = startBaseY - wpvY; y2 <= cheight; y2 += marginHeight) {
ctx.drawImage(markCanvas, x2, y2);
}
for (let y2 = startBaseY - wpvY - marginHeight; y2 >= 0; y2 -= marginHeight) {
ctx.drawImage(markCanvas, x2, y2);
}
}
for (let x2 = startBaseX - wpvX - marginWidth; x2 >= 0; x2 -= marginWidth) {
for (let y2 = startBaseY - wpvY; y2 <= cheight; y2 += marginHeight) {
ctx.drawImage(markCanvas, x2, y2);
}
for (let y2 = startBaseY - wpvY - marginHeight; y2 >= 0; y2 -= marginHeight) {
ctx.drawImage(markCanvas, x2, y2);
}
}
ctx.restore();
markCtx.restore();
}
} else if (markType == 2 || markType == "2") {
let imgData = DDeiUtil$1.getReplacibleValue(this.model, "mark.data", false, false, markInit);
if (!((_c2 = this.mark) == null ? void 0 : _c2.imgObj) || this.mark.upMarkImg != imgData) {
this.initMarkImage();
} else {
if (!this.markCanvas) {
this.markCanvas = document.createElement("canvas");
}
let markCanvas = this.markCanvas;
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let rat1 = this.ddRender.ratio;
let stageRatio2 = this.model.getStageRatio();
let ratio = rat1 * stageRatio2;
ctx.save();
let weight = Math.max(this.mark.imgObj.width, this.mark.imgObj.height);
markCanvas.setAttribute("width", weight);
markCanvas.setAttribute("height", weight);
let markCtx = markCanvas.getContext("2d");
markCtx.save();
let opac = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "mark.opacity", true, markInit);
if (opac) {
markCtx.globalAlpha = opac;
}
let direct = DDeiModelArrtibuteValue.getAttrValueByState(this.model, "mark.direct", true, markInit);
if (direct == 1) {
markCtx.translate(markCanvas.width * 0.5, markCanvas.height * 0.5);
markCtx.rotate(45 * DDeiConfig$1.ROTATE_UNIT);
markCtx.translate(-markCanvas.width * 0.5, -markCanvas.height * 0.5);
} else if (direct == 2) {
markCtx.translate(markCanvas.width * 0.5, markCanvas.height * 0.5);
markCtx.rotate(-45 * DDeiConfig$1.ROTATE_UNIT);
markCtx.translate(-markCanvas.width * 0.5, -markCanvas.height * 0.5);
}
markCtx.clearRect(0, 0, markCanvas.width, markCanvas.height);
markCtx.drawImage(this.mark.imgObj, weight - this.mark.imgObj.width, (weight - this.mark.imgObj.height) / 2);
let marginWidth = markCanvas.width + 50 * ratio;
let marginHeight = markCanvas.height + 50 * ratio;
let cwidth = canvas.width + marginWidth;
let cheight = canvas.height + marginHeight;
let x2 = -marginWidth;
let xdr = this.model.wpv.x * rat1 % marginWidth;
let ydr = this.model.wpv.y * rat1 % marginHeight;
for (; x2 <= cwidth; x2 += marginWidth) {
let y2 = -marginHeight;
for (; y2 <= cheight; y2 += marginHeight) {
ctx.drawImage(markCanvas, x2 + xdr, y2 + ydr);
}
}
ctx.restore();
markCtx.restore();
}
}
}
/**
* 绘制滚动条
*/
drawScroll() {
var _a3, _b2;
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let rat1 = this.ddRender.ratio;
ctx.save();
let scrollWeight = rat1 * 15;
let cwidth = canvas.width - scrollWeight;
let cheight = canvas.height - scrollWeight;
if (this.hScroll) {
ctx.fillStyle = DDeiUtil$1.getStyleValue("canvas-scroll-background", this.ddRender.model);
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-scroll-border", this.ddRender.model);
ctx.fillRect(0, cheight, this.hScroll.width * rat1, scrollWeight);
ctx.strokeRect(0, cheight, this.hScroll.width * rat1, scrollWeight);
ctx.fillStyle = "rgb(210,210,210)";
if (this.operateState == DDeiEnumOperateState.STAGE_SCROLL_WORKING && ((_a3 = this.dragObj) == null ? void 0 : _a3.scroll) == 1) {
ctx.fillStyle = "rgb(200,200,200)";
}
ctx.fillRect(this.hScroll.x * rat1, cheight, this.hScroll.contentWidth * rat1, scrollWeight);
}
if (this.vScroll) {
ctx.fillStyle = DDeiUtil$1.getStyleValue("canvas-scroll-background", this.ddRender.model);
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-scroll-border", this.ddRender.model);
ctx.fillRect(cwidth, 0, scrollWeight, this.vScroll.height * rat1);
ctx.strokeRect(cwidth, 0, scrollWeight, this.vScroll.height * rat1);
ctx.fillStyle = "rgb(210,210,210)";
if (this.operateState == DDeiEnumOperateState.STAGE_SCROLL_WORKING && ((_b2 = this.dragObj) == null ? void 0 : _b2.scroll) == 2) {
ctx.fillStyle = "rgb(200,200,200)";
}
ctx.fillRect(cwidth, this.vScroll.y * rat1, scrollWeight, this.vScroll.contentHeight * rat1);
}
if (this.vScroll || this.hScroll) {
ctx.strokeStyle = DDeiUtil$1.getStyleValue("canvas-scroll-border", this.ddRender.model);
ctx.fillStyle = DDeiUtil$1.getStyleValue("canvas-scroll-background", this.ddRender.model);
ctx.fillRect(cwidth, cheight, scrollWeight, scrollWeight);
ctx.strokeRect(cwidth, cheight, scrollWeight, scrollWeight);
}
}
enableRefreshShape() {
}
/**
* 计算滚动条信息
*/
calScroll() {
let canvas = this.ddRender.getCanvas();
let rat1 = this.ddRender.ratio;
let canvasHeight = canvas.height / rat1;
let canvasWidth = canvas.width / rat1;
let curX = -this.model.wpv.x;
let curY = -this.model.wpv.y;
let scrollWeight = 15;
let maxWidth = this.model.width;
let maxHeight = this.model.height;
if (maxHeight > canvasHeight) {
let height = canvasHeight - scrollWeight;
this.vScroll = { height, contentHeight: height * height / maxHeight, y: height * curY / maxHeight, bn: curY / maxHeight };
} else {
this.vScroll = null;
this.model.wpv.y = 0;
}
if (maxWidth > canvasWidth) {
let width = canvasWidth - scrollWeight;
this.hScroll = { width, contentWidth: width * width / maxWidth, x: width * curX / maxWidth, bn: curX / maxWidth };
} else {
this.hScroll = null;
this.model.wpv.x = 0;
}
}
/**
* 获取缓存的渲染数据
*/
getCachedValue(attrPath) {
let returnValue = null;
if (!this.renderCacheData.has(attrPath)) {
returnValue = DDeiModelArrtibuteValue.getAttrValueByState(this.model, attrPath, true);
this.renderCacheData.set(attrPath, returnValue);
} else {
returnValue = this.renderCacheData.get(attrPath);
}
return returnValue;
}
/**
* 设置渲染缓存数据
*/
setCachedValue(attrPath, value) {
if (attrPath) {
if (Array.isArray(attrPath)) {
attrPath.forEach((item) => {
this.renderCacheData.set(item, value);
});
} else {
this.renderCacheData.set(attrPath, value);
}
}
}
clearCachedValue() {
this.renderCacheData.clear();
this.model.layers.forEach((layer2) => {
var _a3;
(_a3 = layer2 == null ? void 0 : layer2.render) == null ? void 0 : _a3.clearCachedValue();
});
}
/**
* 初始化选择器
*/
initSelector() {
if (!this.selector) {
this.selector = DDeiSelector.initByJSON({
id: this.model.id + "_inner_selector",
border: DDeiConfig$1.SELECTOR.BORDER,
fill: { default: {}, selected: {} }
});
this.selector.stage = this.model;
DDeiConfig$1.bindRender(this.selector);
this.selector.initRender();
}
this.selector.resetState();
}
/**
* 初始化水印图片
*/
initMarkImage() {
var _a3, _b2;
let that = this;
let markInit;
if (this.model.ddInstance.mark) {
if (typeof this.model.ddInstance.mark == "object") {
markInit = this.model.ddInstance.mark;
} else {
markInit = { data: this.model.ddInstance.mark, type: 1 };
}
}
let imgData = DDeiUtil$1.getReplacibleValue(this.model, "mark.data", false, false, markInit);
if (((_a3 = this.model.mark) == null ? void 0 : _a3.imgBase64) || imgData) {
let img = new Image();
img.onload = function() {
var _a22;
if (!that.mark) {
that.mark = {};
}
let imgData2 = DDeiUtil$1.getReplacibleValue(that.model, "mark.data", false, false, markInit);
that.mark.upMarkImg = ((_a22 = that.model.mark) == null ? void 0 : _a22.imgBase64) ? that.model.mark.imgBase64 : imgData2;
that.mark.imgObj = img;
that.model.ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape, null, null);
that.model.ddInstance.bus.executeAll();
};
img.src = ((_b2 = this.model.mark) == null ? void 0 : _b2.imgBase64) ? this.model.mark.imgBase64 : imgData;
}
}
/**
* 重置选择器状态
* @param evt 事件
*/
resetSelectorState(evt) {
this.selector.resetState(evt.offsetX - this.model.wpv.x, evt.offsetY - this.model.wpv.y);
}
// ============================== 事件 ===============================
/**
* 鼠标按下事件
*/
mouseDown(evt) {
if (this.model.disabled) {
return;
}
if (!this.model.ddInstance.eventCancel) {
let canvas = this.ddRender.getCanvas();
let rat1 = this.ddRender.ratio;
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
let scrollWeight = 15;
let cwidth = canvas.width / rat1 - scrollWeight;
let cheight = canvas.height / rat1 - scrollWeight;
if (this.vScroll && ex > cwidth && ey >= this.vScroll.y && ey <= this.vScroll.y + this.vScroll.contentHeight) {
this.dragObj = {
dy: ey - this.vScroll.y,
scroll: 2
};
this.operateState = DDeiEnumOperateState.STAGE_SCROLL_WORKING;
} else if (this.hScroll && ey > cheight && ex >= this.hScroll.x && ex <= this.hScroll.x + this.hScroll.contentWidth) {
this.dragObj = {
dx: ex - this.hScroll.x,
scroll: 1
};
this.operateState = DDeiEnumOperateState.STAGE_SCROLL_WORKING;
} else {
this.model.layers[this.model.layerIndex].render.mouseDown(evt);
}
}
}
mouseUp(evt) {
if (this.model.ddInstance.disabled) {
return;
}
if (!this.model.ddInstance.eventCancel) {
if (this.operateState == DDeiEnumOperateState.STAGE_SCROLL_WORKING) {
this.dragObj = null;
this.operateState = DDeiEnumOperateState.NONE;
} else {
this.model.layers[this.model.layerIndex].render.mouseUp(evt);
}
}
}
/**
* 鼠标移动
*/
mouseMove(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
if (this.model.ddInstance.disabled) {
return;
}
if (!this.model.ddInstance.eventCancel) {
if (this.operateState == DDeiEnumOperateState.STAGE_SCROLL_WORKING) {
let canvasPos = DDeiUtil$1.getDomAbsPosition((_b2 = (_a3 = this.ddRender) == null ? void 0 : _a3.canvas) == null ? void 0 : _b2.parentElement);
let ex = evt.pageX - canvasPos.left;
let ey = evt.pageY - canvasPos.top;
if (((_c2 = this.dragObj) == null ? void 0 : _c2.scroll) == 1) {
let width = this.hScroll.width;
let posRat = (ex / window.remRatio - this.dragObj.dx) / width;
this.model.wpv.x = -this.model.width * posRat;
let hScrollWidth = ((_d2 = this.hScroll) == null ? void 0 : _d2.width) ? (_e2 = this.hScroll) == null ? void 0 : _e2.width : 0;
if (this.model.wpv.x > 0) {
this.model.wpv.x = 0;
} else if (this.model.wpv.x < -this.model.width + hScrollWidth) {
this.model.wpv.x = -this.model.width + hScrollWidth;
}
} else if (((_f = this.dragObj) == null ? void 0 : _f.scroll) == 2) {
let height = this.vScroll.height;
let posRat = (ey / window.remRatio - this.dragObj.dy) / height;
this.model.wpv.y = -this.model.height * posRat;
let vScrollHeight = ((_g = this.vScroll) == null ? void 0 : _g.height) ? (_h = this.vScroll) == null ? void 0 : _h.height : 0;
if (this.model.wpv.y > 0) {
this.model.wpv.y = 0;
} else if (this.model.wpv.y < -this.model.height + vScrollHeight) {
this.model.wpv.y = -this.model.height + vScrollHeight;
}
}
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", "SCROLL_WORKING", null, this.model.ddInstance, evt);
(_j = (_i = this.model.ddInstance) == null ? void 0 : _i.bus) == null ? void 0 : _j.push(DDeiEnumBusCommandType.RefreshShape);
(_l = (_k = this.model.ddInstance) == null ? void 0 : _k.bus) == null ? void 0 : _l.executeAll();
} else {
this.model.layers[this.model.layerIndex].render.mouseMove(evt);
}
}
}
/**
* 鼠标悬停
* @param inEdge 悬停方位
* @param inEdgeTime 悬停时间
*/
mouseInEdge(inEdge, inEdgeTime) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i;
switch (this.operateState) {
case DDeiEnumOperateState.CONTROL_CREATING:
case DDeiEnumOperateState.CONTROL_DRAGING:
{
if (inEdge && inEdgeTime > 400) {
let pContainerModel = null;
if (this.currentOperateShape.id.indexOf("_shadow") != -1) {
let id = this.currentOperateShape.id.substring(this.currentOperateShape.id, this.currentOperateShape.id.lastIndexOf("_shadow"));
let model = this.model.getModelById(id);
pContainerModel = model.pModel;
} else {
pContainerModel = this.currentOperateShape.pModel;
}
if (pContainerModel) {
let dx = 0, dy = 0;
let deltaSize = 10 * this.model.getStageRatio();
switch (inEdge) {
case 1:
dy = -deltaSize;
break;
case 2:
dx = deltaSize;
break;
case 3:
dy = deltaSize;
break;
case 4:
dx = -deltaSize;
break;
}
if (dx || dy) {
let shadowControls = this.model.layers[this.model.layerIndex].shadowControls;
if (!((shadowControls == null ? void 0 : shadowControls.length) > 0)) {
shadowControls = [this.currentOperateShape];
}
let pushData = { dx, dy, dragObj: this.dragObj, models: shadowControls };
(_c2 = (_b2 = (_a3 = this.model) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.bus) == null ? void 0 : _c2.push(DDeiEnumBusCommandType.ModelEdgePosition, pushData);
(_f = (_e2 = (_d2 = this.model) == null ? void 0 : _d2.ddInstance) == null ? void 0 : _e2.bus) == null ? void 0 : _f.push(DDeiEnumBusCommandType.RefreshShape);
(_i = (_h = (_g = this.model) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.bus) == null ? void 0 : _i.executeAll();
}
}
}
}
break;
}
}
};
__publicField2(_DDeiStageCanvasRender, "ClsName", "DDeiStageCanvasRender");
let DDeiStageCanvasRender = _DDeiStageCanvasRender;
const __vite_glob_1_10 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiStageCanvasRender,
default: DDeiStageCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiTableCellCanvasRender = class _DDeiTableCellCanvasRender2 extends DDeiPolygonContainerCanvasRender {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
}
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiTableCellCanvasRender2(props);
}
// ============================== 方法 ===============================
getHTML() {
let cell = this.model;
if (cell.isMergedCell() && !cell.isMergeCell()) {
return "";
}
let fiFamily = this.getCachedValue("font.family");
let fiSize = this.getCachedValue("font.size");
let fiColor = this.getCachedValue("font.color");
let align = this.getCachedValue("textStyle.align");
let valign = this.getCachedValue("textStyle.valign");
let bold = this.getCachedValue("textStyle.bold");
let italic = this.getCachedValue("textStyle.italic");
let underline = this.getCachedValue("textStyle.underline");
let deleteline = this.getCachedValue("textStyle.deleteline");
let feed = this.getCachedValue("textStyle.feed");
let topDisabled = this.getCachedValue("border.top.disabled");
let topColor = this.getCachedValue("border.top.color");
let topOpac = this.getCachedValue("border.top.opacity");
let topWidth = this.getCachedValue("border.top.width");
let rightDisabled = this.getCachedValue("border.right.disabled");
let rightColor = this.getCachedValue("border.right.color");
let rightOpac = this.getCachedValue("border.right.opacity");
let rightWidth = this.getCachedValue("border.right.width");
let bottomDisabled = this.getCachedValue("border.bottom.disabled");
let bottomColor = this.getCachedValue("border.bottom.color");
let bottomOpac = this.getCachedValue("border.bottom.opacity");
let bottomWidth = this.getCachedValue("border.bottom.width");
let leftDisabled = this.getCachedValue("border.left.disabled");
let leftColor = this.getCachedValue("border.left.color");
let leftOpac = this.getCachedValue("border.left.opacity");
let leftWidth = this.getCachedValue("border.left.width");
let fillColor = this.getCachedValue("fill.color");
let fillOpacity = this.getCachedValue("fill.opacity");
let fillDisabled = this.getCachedValue("fill.disabled");
let topDash = this.getCachedValue("border.top.dash");
let bottomDash = this.getCachedValue("border.bottom.dash");
let leftDash = this.getCachedValue("border.left.dash");
let rightDash = this.getCachedValue("border.right.dash");
let html = "";
html += '
0) && topWidth > 0) {
let dash = "solid";
if (topDash && topDash.length > 0) {
dash = "dashed";
}
html += "border-top: " + topWidth + "px " + dash + " " + topColor + ";";
}
if (!bottomDisabled && bottomColor && (!bottomOpac || bottomOpac > 0) && bottomWidth > 0) {
let dash = "solid";
if (bottomDash && bottomDash.length > 0) {
dash = "dashed";
}
html += "border-bottom: " + bottomWidth + "px " + dash + " " + bottomColor + ";";
}
if (!leftDisabled && leftColor && (!leftOpac || leftOpac > 0) && leftWidth > 0) {
let dash = "solid";
if (leftDash && leftDash.length > 0) {
dash = "dashed";
}
html += "border-left: " + leftWidth + "px " + dash + " " + leftColor + ";";
}
if (!rightDisabled && rightColor && (!rightOpac || rightOpac > 0) && rightWidth > 0) {
let dash = "solid";
if (rightDash && rightDash.length > 0) {
dash = "dashed";
}
html += "border-right: " + rightWidth + "px " + dash + " " + rightColor + ";";
}
if (!fillDisabled && fillColor && (!fillOpacity || fillOpacity > 0)) {
html += "background-color: " + fillColor + ";";
}
html += "width: " + cell.width + "px;";
html += "height: " + cell.height + "px;";
html += '"';
if (cell.isMergeCell()) {
html += ' rowspan="' + cell.mergeRowNum + '"';
html += ' colspan="' + cell.mergeColNum + '"';
}
html += ' width="' + cell.width + '"';
html += ' height="' + cell.height + '"';
html += ">";
if (cell.text) {
html += cell.text;
}
html += " | ";
return html;
}
// ============================== 事件 ===============================
/**
* 鼠标按下事件
*/
mouseDown(e) {
if (!this.stage.ddInstance.eventCancel)
;
}
mouseUp(e) {
if (!this.stage.ddInstance.eventCancel)
;
}
/**
* 鼠标移动
*/
mouseMove(evt) {
if (!this.stage.ddInstance.eventCancel)
;
}
};
__publicField2(_DDeiTableCellCanvasRender, "ClsName", "DDeiTableCellCanvasRender");
let DDeiTableCellCanvasRender = _DDeiTableCellCanvasRender;
const __vite_glob_1_11 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiTableCellCanvasRender,
default: DDeiTableCellCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiTableCanvasRender = class _DDeiTableCanvasRender2 extends DDeiRectangleCanvasRender {
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiTableCanvasRender2(props);
}
// ============================== 方法 ===============================
/**
* 获取html
*/
getHTML() {
let selectedCells = this.model.getSelectedCells();
if ((selectedCells == null ? void 0 : selectedCells.length) > 0) {
let html = "";
html += "";
let minMax = this.model.getMinMaxRowAndCol(selectedCells);
for (let x2 = minMax.minRow; x2 <= minMax.maxRow; x2++) {
html += "";
for (let y2 = minMax.minCol; y2 <= minMax.maxCol; y2++) {
html += this.model.rows[x2][y2].render.getHTML();
}
html += "
";
}
html += "
";
return html;
} else {
return null;
}
}
/**
* 绘制图形
*/
drawShape() {
super.drawShape();
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
ctx.save();
let rat1 = this.ddRender.ratio;
this.model.getStageRatio();
let fillPVS = this.getFillAreaPVS();
ctx.beginPath();
let lineOffset = 0;
for (let i2 = 0; i2 < fillPVS.length; i2++) {
if (i2 == fillPVS.length - 1) {
ctx.lineTo(fillPVS[i2].x * rat1 + lineOffset, fillPVS[i2].y * rat1 + lineOffset);
ctx.lineTo(fillPVS[0].x * rat1 + lineOffset, fillPVS[0].y * rat1 + lineOffset);
} else if (i2 == 0) {
ctx.moveTo(fillPVS[i2].x * rat1 + lineOffset, fillPVS[i2].y * rat1 + lineOffset);
} else {
ctx.lineTo(fillPVS[i2].x * rat1 + lineOffset, fillPVS[i2].y * rat1 + lineOffset);
}
}
ctx.closePath();
ctx.clip();
this.drawCells();
this.model.selector.render.drawShape();
ctx.restore();
}
/**
* 绘制单元格
*/
drawCells() {
let mergeCells = [];
for (let i2 = 0; i2 < this.model.rows.length; i2++) {
let rowObj = this.model.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cellObj = rowObj[j2];
if (cellObj.isMergeCell()) {
mergeCells.push(cellObj);
} else if (!cellObj.isMergedCell()) {
cellObj.render.drawShape();
}
}
}
mergeCells.forEach((item) => {
item.render.drawShape();
});
}
// ============================== 事件 ===============================
/**
* 鼠标按下事件
*/
mouseDown(e) {
if (!this.stage.ddInstance.eventCancel) {
let table2 = this.model;
let isCtrl = DDei.KEY_DOWN_STATE.get("ctrl");
let isShift = DDei.KEY_DOWN_STATE.get("shift");
let currentCell = table2.tempDragCell;
if (e.button == 2) {
table2.curRow = currentCell.row;
table2.curCol = currentCell.col;
table2.dragChanging = false;
table2.specilDrag = false;
table2.tempDragCell = null;
table2.tempDragType = null;
table2.tempUpCel = null;
table2.dragCell = null;
table2.dragType = null;
} else if (table2.tempDragType) {
table2.dragType = table2.tempDragType;
table2.dragChanging = true;
table2.dragCell = table2.tempDragCell;
if (table2.dragType == "table-select-col") {
table2.clearSelectionCells();
for (let col = 0; col < table2.cols.length; col++) {
let colObj = table2.cols[col];
if (colObj[0].isBorderOn(1, e.offsetX, e.offsetY, 1, 5)) {
colObj.forEach((item) => {
item.selectCell();
});
break;
}
}
} else if (table2.dragType == "table-select-row") {
table2.clearSelectionCells();
for (let row = 0; row < table2.rows.length; row++) {
let rowObj = table2.rows[row];
if (rowObj[0].isBorderOn(4, e.offsetX, e.offsetY, 1, 5)) {
rowObj.forEach((item) => {
item.selectCell();
});
break;
}
}
} else if (table2.dragType == "cell") {
if (isShift) {
if (table2.curRow != -1 && table2.curCol != -1) {
let minMax = table2.getMinMaxRowAndCol([currentCell, table2.rows[table2.curRow][table2.curCol]]);
for (let x2 = minMax.minRow; x2 <= minMax.maxRow; x2++) {
for (let y2 = minMax.minCol; y2 <= minMax.maxCol; y2++) {
table2.rows[x2][y2].selectCell();
}
}
table2.curRow = currentCell.row;
table2.curCol = currentCell.col;
} else {
currentCell.selectOrCancelCell();
}
} else {
if (!isCtrl) {
table2.clearSelectionCells();
currentCell.selectCell();
} else {
currentCell.selectOrCancelCell();
}
currentCell.render.mouseDown(e);
}
}
if (!isCtrl) {
if (table2.dragType == "row-top") {
if (table2.dragCell.row > 0) {
table2.dragCell = table2.rows[table2.dragCell.row - 1][table2.dragCell.col];
table2.dragType = "row";
}
} else if (table2.dragType == "row-bottom") {
if (table2.dragCell.isMergeCell()) {
table2.dragCell = table2.rows[table2.dragCell.row + table2.dragCell.mergeRowNum - 1][table2.dragCell.col];
}
if (table2.dragCell.row < table2.rows.length - 1) {
table2.dragType = "row";
}
} else if (table2.dragType == "col-left") {
if (table2.dragCell.col > 0) {
table2.dragCell = table2.rows[table2.dragCell.row][table2.dragCell.col - 1];
table2.dragType = "col";
}
} else if (table2.dragType == "col-right") {
if (table2.dragCell.isMergeCell()) {
table2.dragCell = table2.rows[table2.dragCell.row][table2.dragCell.col + table2.dragCell.mergeColNum - 1];
}
if (table2.dragCell.col < table2.cols.length - 1) {
table2.dragType = "col";
}
}
}
} else {
table2.dragChanging = false;
table2.dragCell = null;
table2.dragType = null;
}
}
}
controlDragEnd(e) {
if (!this.stage.ddInstance.eventCancel) {
let table2 = this.model;
table2.dragChanging = false;
table2.specilDrag = false;
table2.tempDragCell = null;
table2.tempDragType = null;
table2.tempUpCel = null;
table2.dragCell = null;
table2.dragType = null;
}
}
/**
* 绘制图形
*/
mouseUp(e) {
var _a3, _b2;
if (!this.stage.ddInstance.eventCancel) {
let table2 = this.model;
if (table2.dragChanging) {
if (table2.dragType == "cell") {
(_b2 = (_a3 = table2.dragCell) == null ? void 0 : _a3.render) == null ? void 0 : _b2.mouseUp(e);
}
table2.dragChanging = false;
table2.specilDrag = false;
table2.tempUpCel = null;
table2.dragCell = null;
table2.dragType = null;
}
}
}
/**
* 鼠标移动
*/
mouseMove(e) {
if (!this.stage.ddInstance.eventCancel) {
super.mouseMove(e);
let table2 = this.model;
if (table2.dragChanging) {
table2.setState(DDeiEnumControlState.SELECTED);
if (table2.dragType == "col") {
table2.dragCol(e.offsetX, e.offsetY);
} else if (table2.dragType == "row") {
table2.dragRow(e.offsetX, e.offsetY);
} else if (table2.dragType == "cell") {
table2.dragAndSelectedCell(e.offsetX, e.offsetY);
} else if (table2.dragType == "table-size-right") {
table2.changeTableSizeToRight(e.offsetX, e.offsetY);
} else if (table2.dragType == "table-size-left") {
table2.changeTableSizeToLeft(e.offsetX, e.offsetY);
} else if (table2.dragType == "table-size-bottom") {
table2.changeTableSizeToBottom(e.offsetX, e.offsetY);
} else if (table2.dragType == "table-size-top") {
table2.changeTableSizeToTop(e.offsetX, e.offsetY);
}
} else {
if (table2.isBorderOn(1, e.offsetX, e.offsetY, 6, 10) || table2.isBorderOn(1, e.offsetX, e.offsetY, -3, 0)) {
table2.tempDragType = "table-size-top";
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "ns-resize" }, e);
} else if (table2.isBorderOn(1, e.offsetX, e.offsetY, 1, 5)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "s-resize" }, e);
table2.tempDragType = "table-select-col";
} else if (table2.isBorderOn(2, e.offsetX, e.offsetY, -5, 10)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "ew-resize" }, e);
table2.tempDragType = "table-size-right";
} else if (table2.isBorderOn(3, e.offsetX, e.offsetY, -5, 10)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "ns-resize" }, e);
table2.tempDragType = "table-size-bottom";
} else if (table2.isBorderOn(4, e.offsetX, e.offsetY, 6, 10) || table2.isBorderOn(4, e.offsetX, e.offsetY, -3, 0)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "ew-resize" }, e);
table2.tempDragType = "table-size-left";
} else if (table2.isBorderOn(4, e.offsetX, e.offsetY, 1, 5)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "e-resize" }, e);
table2.tempDragType = "table-select-row";
} else {
for (let i2 = 0; i2 < table2.rows.length; i2++) {
let rowObj = table2.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let cellObj = rowObj[j2];
let isDrag = false;
if (cellObj.width <= 0 || cellObj.height <= 0) {
continue;
}
if (cellObj.isBorderOn(1, e.offsetX, e.offsetY, -3, 0)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "ns-resize" }, e);
table2.tempDragType = "row-top";
isDrag = true;
} else if (cellObj.isBorderOn(2, e.offsetX, e.offsetY, -3, 0)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "ew-resize" }, e);
table2.tempDragType = "col-right";
isDrag = true;
} else if (cellObj.isBorderOn(3, e.offsetX, e.offsetY, -3, 0)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "ns-resize" }, e);
table2.tempDragType = "row-bottom";
isDrag = true;
} else if (cellObj.isBorderOn(4, e.offsetX, e.offsetY, -3, 0)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "ew-resize" }, e);
table2.tempDragType = "col-left";
isDrag = true;
} else if (cellObj.isInAreaLoose(e.offsetX, e.offsetY, 0)) {
this.stage.ddInstance.bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "all-scroll" }, e);
table2.tempDragType = "cell";
isDrag = true;
}
if (isDrag) {
table2.tempDragCell = cellObj;
cellObj.render.mouseMove(e);
return;
}
}
}
}
}
}
}
};
__publicField2(_DDeiTableCanvasRender, "ClsName", "DDeiTableCanvasRender");
let DDeiTableCanvasRender = _DDeiTableCanvasRender;
const __vite_glob_1_12 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiTableCanvasRender,
default: DDeiTableCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiTableSelectorCanvasRender = class _DDeiTableSelectorCanvasRender2 extends DDeiSelectorCanvasRender {
// ============================== 静态方法 ============================
// 通过一个JSON反向序列化成对象,模型数据与JSON完全一样
static newInstance(props) {
return new _DDeiTableSelectorCanvasRender2(props);
}
/**
* 创建图形
*/
drawShape() {
this.drawBorder();
this.fillSelectedCell();
}
/**
* 填充选中单元格
*/
fillSelectedCell() {
let table2 = this.model.table;
let canvas = this.ddRender.getCanvas();
let ctx = canvas.getContext("2d");
let stageRatio2 = this.model.getStageRatio();
let ratio = this.ddRender.ratio * stageRatio2;
ctx.save();
ctx.fillStyle = DDeiUtil$1.getColor("rgb(210,210,210)");
ctx.globalAlpha = 0.5;
let rect = this.model.getBounds();
({ x: rect.x, y: rect.y, width: rect.width, height: rect.height });
let ratPos = DDeiUtil$1.getRatioPosition(rect, ratio);
this.doRotate(ctx, ratPos);
let rect1 = null;
if (table2.curRow != -1 && table2.curCol != -1) {
let curCell = table2.rows[table2.curRow][table2.curCol];
if (curCell) {
let cellBounds = curCell.getAbsBounds();
if (rect.y - cellBounds.y == 0 && rect.x - cellBounds.x == 0) {
rect1 = {
x: rect.x,
y: rect.y + cellBounds.height - this.model.border.width,
width: rect.width,
height: rect.height - cellBounds.height + this.model.border.width
};
rect = {
x: rect.x + cellBounds.width,
y: rect.y,
width: rect.width - cellBounds.width,
height: cellBounds.height
};
} else if (rect.y - cellBounds.y == 0 && rect.x + rect.width - cellBounds.x - cellBounds.width == 0) {
rect1 = {
x: rect.x,
y: rect.y + cellBounds.height - this.model.border.width,
width: rect.width,
height: rect.height - cellBounds.height + this.model.border.width
};
rect = {
x: rect.x,
y: rect.y,
width: rect.width - cellBounds.width,
height: cellBounds.height
};
} else if (rect.y + rect.height - cellBounds.y - cellBounds.height == 0 && rect.x - cellBounds.x == 0) {
rect1 = {
x: rect.x + cellBounds.width,
y: cellBounds.y - this.model.border.width,
width: rect.width - cellBounds.width,
height: cellBounds.height + this.model.border.width
};
rect = {
x: rect.x,
y: rect.y,
width: rect.width,
height: rect.height - cellBounds.height
};
} else if (rect.y + rect.height - cellBounds.y - cellBounds.height == 0 && rect.x + rect.width - cellBounds.x - cellBounds.width == 0) {
rect1 = {
x: rect.x,
y: cellBounds.y - this.model.border.width,
width: rect.width - cellBounds.width,
height: cellBounds.height + this.model.border.width
};
rect = {
x: rect.x,
y: rect.y,
width: rect.width,
height: rect.height - cellBounds.height
};
}
}
}
rect.x += this.model.border.width;
rect.y += this.model.border.width;
rect.width -= this.model.border.width;
rect.height -= this.model.border.width;
ratPos = DDeiUtil$1.getRatioPosition(rect, ratio);
ctx.fillRect(ratPos.x, ratPos.y, ratPos.width, ratPos.height);
if ((rect1 == null ? void 0 : rect1.width) > 0 && (rect1 == null ? void 0 : rect1.height) > 0) {
rect1.x += this.model.border.width;
rect1.y += this.model.border.width;
rect1.width -= this.model.border.width;
rect1.height -= this.model.border.width;
ratPos = DDeiUtil$1.getRatioPosition(rect1, ratio);
ctx.fillRect(ratPos.x, ratPos.y, ratPos.width, ratPos.height);
}
ctx.restore();
}
// /**
// * 绘制边框
// * @param tempBorder 临时边框,优先级最高
// */
// drawBorder(tempBorder: object | null): void {
// //获得 2d 上下文对象
// let canvas = this.ddRender.getCanvas();
// let ctx = canvas.getContext('2d');
// //获取全局缩放比例
// let stageRatio = this.model.getStageRatio()
// let ratio = this.ddRender.ratio * stageRatio;
// //转换为缩放后的坐标
// let ratPos = this.getBorderRatPos();
// //1,2,3,4 上,右,下,左
// for (let i = 1; i <= 4; i++) {
// //如果被选中,使用选中的边框,否则使用缺省边框
// let disabled = this.getBorderInfo(tempBorder, i, "disabled");
// let color = this.getBorderInfo(tempBorder, i, "color");
// let opacity = this.getBorderInfo(tempBorder, i, "opacity");
// let width = this.getBorderInfo(tempBorder, i, "width");
// let dash = this.getBorderInfo(tempBorder, i, "dash");
// //绘制四个方向的边框
// //如果边框未被disabled,则绘制边框
// if (!disabled && color && (!opacity || opacity > 0) && width > 0) {
// //保存状态
// ctx.save();
// //设置旋转
// this.doRotate(ctx, ratPos);
// //偏移量,因为线是中线对齐,实际坐标应该加上偏移量
// let lineOffset = width * ratio / 2;
// ctx.lineWidth = width * ratio;
// ctx.beginPath();
// //线段、虚线样式
// if (dash) {
// ctx.setLineDash(dash);
// }
// //透明度
// if (opacity != null && opacity != undefined) {
// ctx.globalAlpha = opacity
// }
// //颜色
// ctx.strokeStyle = DDeiUtil.getColor(color);
// if (i == 1) {
// ctx.moveTo(ratPos.x + lineOffset, ratPos.y + lineOffset);
// ctx.lineTo(ratPos.x + ratPos.width + lineOffset, ratPos.y + lineOffset);
// } else if (i == 2) {
// ctx.moveTo(ratPos.x + ratPos.width + lineOffset, ratPos.y + lineOffset);
// ctx.lineTo(ratPos.x + ratPos.width + lineOffset, ratPos.y + ratPos.height + lineOffset);
// } else if (i == 3) {
// ctx.moveTo(ratPos.x + lineOffset, ratPos.y + ratPos.height + lineOffset);
// ctx.lineTo(ratPos.x + ratPos.width + lineOffset, ratPos.y + ratPos.height + lineOffset);
// } else if (i == 4) {
// ctx.moveTo(ratPos.x + lineOffset, ratPos.y + lineOffset);
// ctx.lineTo(ratPos.x + lineOffset, ratPos.y + ratPos.height + lineOffset);
// }
// ctx.stroke();
// //恢复状态
// ctx.restore();
// }
// }
// }
};
__publicField2(_DDeiTableSelectorCanvasRender, "ClsName", "DDeiTableSelectorCanvasRender");
let DDeiTableSelectorCanvasRender = _DDeiTableSelectorCanvasRender;
const __vite_glob_1_13 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiTableSelectorCanvasRender,
default: DDeiTableSelectorCanvasRender
}, Symbol.toStringTag, { value: "Module" }));
class DDeiPluginBase {
constructor(options) {
__publicField2(this, "name", "");
__publicField2(this, "type", "plugin");
__publicField2(this, "options");
__publicField2(this, "defaultOptions");
__publicField2(this, "plugins", []);
__publicField2(this, "order", 1);
__publicField2(this, "initConfig", null);
this.options = options;
}
installed(editor) {
}
getOptions() {
var _a3;
let options = {};
if (this.type == "package") {
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let pluginOptions;
let pluginName;
let pluginType;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
pluginOptions = plugin.defaultIns.getOptions();
pluginName = plugin.defaultIns.getName();
pluginType = plugin.defaultIns.type;
} else if (plugin instanceof DDeiPluginBase) {
pluginOptions = plugin.getOptions();
pluginName = plugin.getName();
pluginType = plugin.type;
}
if (pluginOptions) {
if (pluginType == "package") {
for (let i2 in pluginOptions) {
options[i2] = pluginOptions[i2];
}
} else {
options[pluginName] = pluginOptions;
}
}
});
} else if (this.type == "plugin") {
if (this.options) {
options = this.options;
} else if (this.defaultOptions) {
options = this.defaultOptions;
}
if (options && options.config instanceof Function) {
options = options.config(cloneDeep(this.defaultOptions));
}
}
return options;
}
init() {
}
/**
* 修改自身的方法,通过传入一个回调函数,让插件使用者可以更灵活的修改插件属性
* @param fn
* @returns
*/
modify(fn) {
let cloneThis = cloneDeep(this);
fn(cloneThis);
return cloneThis;
}
getInitConfig() {
return this.initConfig;
}
getName() {
return this.name;
}
getType() {
return this.type;
}
static isSubclass(a, b) {
return a.prototype && (Object.getPrototypeOf(a.prototype) === b.prototype || a.prototype instanceof b);
}
}
class DDeiKeyAction extends DDeiPluginBase {
// ============================ 构造函数 ============================
constructor(props) {
super(props);
__publicField2(this, "name");
__publicField2(this, "desc");
this.name = props == null ? void 0 : props.name;
this.desc = props == null ? void 0 : props.desc;
}
// ============================ 静态方法 ============================
/**
* 更新按键状态
*/
static updateKeyState(evt) {
let editor = DDeiEditor$1.ACTIVE_INSTANCE;
let ddInstance = editor == null ? void 0 : editor.ddInstance;
if (ddInstance == null ? void 0 : ddInstance.disabled) {
DDei.KEY_DOWN_STATE.clear();
return;
}
let ctrl = evt.ctrlKey || evt.metaKey;
let shift = evt.shiftKey;
let alt = evt.altKey;
if (ctrl == true) {
DDei.KEY_DOWN_STATE.set("ctrl", true);
} else {
DDei.KEY_DOWN_STATE.set("ctrl", false);
}
if (shift == true) {
DDei.KEY_DOWN_STATE.set("shift", true);
} else {
DDei.KEY_DOWN_STATE.set("shift", false);
}
if (alt == true) {
DDei.KEY_DOWN_STATE.set("alt", true);
} else {
DDei.KEY_DOWN_STATE.set("alt", false);
}
if (evt.keyCode != 93 && evt.keyCode != 18 && evt.keyCode != 16 && evt.keyCode != 17) {
DDei.KEY_DOWN_STATE.set("" + evt.keyCode, true);
}
}
/**
* 根据快捷键配置以及当前操作的上下文环境
* 路由到合理的键行为实例上
*/
static route(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
let editor = DDeiEditor$1.ACTIVE_INSTANCE;
let ddInstance = editor == null ? void 0 : editor.ddInstance;
if (ddInstance == null ? void 0 : ddInstance.disabled) {
return false;
}
let ctrl = evt.ctrlKey || evt.metaKey;
let shift = evt.shiftKey;
let alt = evt.altKey;
DDeiKeyAction.updateKeyState(evt);
let onlySelectModel = null;
let selectedModels = (_a3 = editor.ddInstance.stage) == null ? void 0 : _a3.selectedModels;
if ((selectedModels == null ? void 0 : selectedModels.size) == 1) {
onlySelectModel = Array.from(selectedModels.values())[0];
}
let m1Str = editor.state + "_";
m1Str += ((_d2 = (_c2 = (_b2 = editor.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.render) == null ? void 0 : _d2.operateState) + "_";
if (ctrl == true) {
m1Str += "ctrl_";
}
if (shift == true) {
m1Str += "shift_";
}
if (alt == true) {
m1Str += "alt_";
}
if (evt.keyCode != 93 && evt.keyCode != 18 && evt.keyCode != 16 && evt.keyCode != 17) {
m1Str += evt.keyCode;
}
let matched = false;
for (let it = 0; it < ((_e2 = editor.hotKeyMapping) == null ? void 0 : _e2.length); it++) {
let item = editor.hotKeyMapping[it];
let matchStr = null;
if (item.editorState) {
matchStr = item.editorState + "_";
} else {
matchStr = editor.state + "_";
}
if (item.operateState) {
matchStr += item.operateState + "_";
} else {
matchStr += ((_h = (_g = (_f = editor.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.render) == null ? void 0 : _h.operateState) + "_";
}
if (item.ctrl == 1) {
matchStr += "ctrl_";
} else if (item.ctrl == 2 && ctrl == true) {
matchStr += "ctrl_";
}
if (item.shift == 1) {
matchStr += "shift_";
} else if (item.shift == 2 && shift == true) {
matchStr += "shift_";
}
if (item.alt == 1) {
matchStr += "alt_";
} else if (item.alt == 2 && alt == true) {
matchStr += "alt_";
}
if (item.keys) {
matchStr += item.keys;
}
if (m1Str == matchStr) {
if (!item.modelType || item.modelType && item.modelType == (onlySelectModel == null ? void 0 : onlySelectModel.baseModelType)) {
if (item.times && item.times > 1 && item.interval && item.interval > 0) {
if (!DDeiConfig$1.KEY_DOWN_TIMES.has(m1Str)) {
DDeiConfig$1.KEY_DOWN_TIMES.set(m1Str, 1);
DDeiConfig$1.KEY_DOWN_INTERVAL.set(m1Str, Date.now());
} else {
let startTime = DDeiConfig$1.KEY_DOWN_INTERVAL.get(m1Str);
let nowTime = Date.now();
let times = DDeiConfig$1.KEY_DOWN_TIMES.get(m1Str);
if (nowTime - startTime <= item.interval && times + 1 >= item.times) {
item.action.action(evt, ddInstance, editor, item);
DDeiConfig$1.KEY_DOWN_TIMES.delete(m1Str);
DDeiConfig$1.KEY_DOWN_INTERVAL.delete(m1Str);
break;
} else {
DDeiConfig$1.KEY_DOWN_TIMES.set(m1Str, 1);
DDeiConfig$1.KEY_DOWN_INTERVAL.set(m1Str, nowTime);
}
}
} else {
let state = item.action.action(evt, ddInstance, editor, item);
if (state == void 0 || state === true) {
matched = true;
if (item.break == true || item.break == 1) {
break;
}
}
}
}
}
}
return matched;
}
// ============================ 方法 ===============================
/**
* 键行为
* @param evt 事件
*/
action(evt, ddInstance) {
}
}
var DDeiEditorState = /* @__PURE__ */ ((DDeiEditorState2) => {
DDeiEditorState2["DESIGNING"] = "designing";
DDeiEditorState2["PROPERTY_EDITING"] = "property_editing";
DDeiEditorState2["QUICK_EDITING"] = "quick_editing";
DDeiEditorState2["CONTROL_CREATING"] = "control_creating";
DDeiEditorState2["TOOLBOX_ACTIVE"] = "toolbox_active";
DDeiEditorState2["FRAME_CHANGING"] = "frame_changing";
DDeiEditorState2["TOP_MENU_OPERATING"] = "top_menu_operating";
DDeiEditorState2["BOTTOM_MENU_OPERATING"] = "bottom_menu_operating";
return DDeiEditorState2;
})(DDeiEditorState || {});
var DDeiActiveType = /* @__PURE__ */ ((DDeiActiveType2) => {
DDeiActiveType2[DDeiActiveType2["ACTIVE"] = 1] = "ACTIVE";
DDeiActiveType2[DDeiActiveType2["NONE"] = 0] = "NONE";
return DDeiActiveType2;
})(DDeiActiveType || {});
var DDeiFileState = /* @__PURE__ */ ((DDeiFileState2) => {
DDeiFileState2[DDeiFileState2["NEW"] = 1] = "NEW";
DDeiFileState2[DDeiFileState2["MODIFY"] = 2] = "MODIFY";
DDeiFileState2[DDeiFileState2["DELETE"] = 3] = "DELETE";
DDeiFileState2[DDeiFileState2["NONE"] = 0] = "NONE";
DDeiFileState2[DDeiFileState2["SAVING"] = 4] = "SAVING";
DDeiFileState2[DDeiFileState2["PUBLISHING"] = 5] = "PUBLISHING";
return DDeiFileState2;
})(DDeiFileState || {});
class DDeiSheet {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "name");
__publicField2(this, "desc");
__publicField2(this, "stage");
__publicField2(this, "active");
__publicField2(this, "modelType", "DDeiSheet");
__publicField2(this, "unicode", DDeiUtil$1.getUniqueCode());
this.name = props.name;
this.desc = props.desc;
this.stage = props.stage;
this.active = props.active ? props.active : DDeiActiveType.NONE;
}
// ============================ 静态变量 ============================
static loadFromJSON(json, tempData = {}) {
let sheet = new DDeiSheet(json);
let stage2 = DDeiStage.loadFromJSON(sheet.stage, tempData);
sheet.stage = stage2;
return sheet;
}
// ============================ 方法 ============================
/**
* 计算当前sheet的模型总数量
*/
calModelNumber() {
var _a3;
return (_a3 = this.stage) == null ? void 0 : _a3.calModelNumber();
}
/**
* 将模型转换为JSON
*/
toJSON() {
let json = new Object();
for (let i2 in this) {
if (this[i2] || this[i2] == 0) {
if (Array.isArray(this[i2])) {
let array = [];
this[i2].forEach((element) => {
if (element == null ? void 0 : element.toJSON) {
array.push(element.toJSON());
} else {
array.push(element);
}
});
json[i2] = array;
} else if (this[i2].set && this[i2].has) {
let map = {};
this[i2].forEach((element, key) => {
if (element == null ? void 0 : element.toJSON) {
map[key] = element.toJSON();
} else {
map[key] = element;
}
});
json[i2] = map;
} else if (this[i2].toJSON) {
json[i2] = this[i2].toJSON();
} else {
json[i2] = this[i2];
}
}
}
return json;
}
}
class DDeiFile {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "id");
__publicField2(this, "name");
__publicField2(this, "desc", "");
__publicField2(this, "extData");
__publicField2(this, "busiData");
__publicField2(this, "state");
__publicField2(this, "active");
__publicField2(this, "publish", "0");
__publicField2(this, "lastUpdateTime", (/* @__PURE__ */ new Date()).getTime());
__publicField2(this, "path");
__publicField2(this, "sheets");
__publicField2(this, "currentSheetIndex");
__publicField2(this, "modelType", "DDeiFile");
__publicField2(this, "histroy", []);
__publicField2(this, "modelNumber", 0);
__publicField2(this, "histroyIdx", -1);
__publicField2(this, "unicode", DDeiUtil$1.getUniqueCode());
this.id = props.id;
this.name = props.name;
this.path = props.path;
this.sheets = props.sheets ? props.sheets : [];
this.currentSheetIndex = props.currentSheetIndex || props.currentSheetIndex == 0 ? props.currentSheetIndex : -1;
this.state = props.state ? props.state : DDeiFileState.NONE;
this.active = props.active ? props.active : DDeiActiveType.NONE;
this.lastUpdateTime = props.lastUpdateTime ? props.lastUpdateTime : (/* @__PURE__ */ new Date()).getTime();
this.publish = props.publish ? props.publish : "0";
this.desc = props.desc ? props.desc : "";
this.extData = props.extData ? props.extData : {};
this.busiData = props.busiData;
this.closeLocalFile = debounce(this.closeLocalFile, 1e3);
}
// ============================ 静态变量 ============================
static loadFromJSON(json, tempData = {}) {
var _a3, _b2, _c2, _d2;
let model = new DDeiFile(json);
let sheets = [];
let dpi;
if (DDei.INSTANCE_POOL.size > 0) {
dpi = (_a3 = Array.from(DDei.INSTANCE_POOL.values())[0].dpi) == null ? void 0 : _a3.x;
}
if (!dpi) {
dpi = DDeiUtil$1.getDPI().x;
}
for (let i2 = 0; i2 < model.sheets.length; i2++) {
if (!model.sheets[i2].stage.ddInstance && !model.sheets[i2].stage.dpi) {
model.sheets[i2].stage.dpi = dpi;
}
let unit = model.sheets[i2].stage.unit;
if (dpi && unit && unit != "px") {
(_d2 = (_c2 = (_b2 = model.sheets[i2]) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.layers) == null ? void 0 : _d2.forEach((layer2) => {
var _a22;
DDeiUtil$1.convertChildrenJsonUnit(layer2, (_a22 = model.sheets[i2]) == null ? void 0 : _a22.stage, unit);
});
}
sheets[i2] = DDeiSheet.loadFromJSON(model.sheets[i2], tempData);
}
model.sheets = sheets;
model.calModelNumber();
return model;
}
// ============================ 方法 ============================
/**
* 计算当前文件的模型总数量
*/
calModelNumber() {
let num = 0;
this.sheets.forEach((sheet) => {
num += sheet.calModelNumber();
});
this.modelNumber = num;
return num;
}
/**
* 切换sheet
* @param index 下标
*/
changeSheet(index) {
if (index < 0) {
index = 0;
}
for (let i2 = 0; i2 < this.sheets.length; i2++) {
let sheet = this.sheets[i2];
if (i2 != index) {
sheet.active = DDeiActiveType.NONE;
} else {
sheet.active = DDeiActiveType.ACTIVE;
this.currentSheetIndex = index;
}
}
}
/**
* 初始化日志,记录初始化状态
*/
initHistroy() {
if (this.histroy.length == 0 && this.histroyIdx == -1) {
this.histroy.push({ time: (/* @__PURE__ */ new Date()).getTime(), data: JSON.stringify(this.toJSON()) });
this.histroyIdx = 0;
}
}
/**
* 记录日志
* @param layerIndex 图层下标
*/
addHistroy(data) {
if (this.histroyIdx == -1) {
this.histroy = this.histroy.slice(0, 1);
this.histroyIdx = 0;
} else {
this.histroy = this.histroy.slice(0, this.histroyIdx + 1);
}
this.histroy.push({ time: (/* @__PURE__ */ new Date()).getTime(), data });
this.histroyIdx = this.histroy.length - 1;
}
/**
* 返回上一个历史数据,并将下标-1
* @param layerIndex 图层下标
*/
revokeHistroyData() {
if (this.histroyIdx != -1) {
this.histroyIdx--;
if (this.histroyIdx == -1) {
this.histroyIdx = 0;
return this.histroy[0];
} else {
return this.histroy[this.histroyIdx];
}
}
}
/**
* 撤销上一次撤销并将下标+1
* @param layerIndex 图层下标
*/
reRevokeHistroyData() {
if (this.histroyIdx < this.histroy.length - 1) {
this.histroyIdx++;
return this.histroy[this.histroyIdx];
}
}
/**
* 写入本地文件
*/
async writeLocalFile(data) {
if (!this.writeLocalQueue) {
this.writeLocalQueue = [];
}
if (this.localWriteLock == 1) {
this.writeLocalQueue.push(data);
} else {
if (!this.localFileWriter) {
this.localFileWriter = await this.localFileHandler.createWritable();
}
await this.localFileWriter.write(data);
this.closeLocalFile();
}
}
async closeLocalFile() {
if (this.localFileWriter) {
this.localWriteLock = 1;
await this.localFileWriter.close();
delete this.localFileWriter;
this.localWriteLock = 0;
if (this.writeLocalQueue.length > 0) {
this.writeLocalFile(this.writeLocalQueue[this.writeLocalQueue.length - 1]);
this.writeLocalQueue = [];
}
}
}
/**
* 将模型转换为JSON
*/
toJSON() {
let json = new Object();
for (let i2 in this) {
if (i2 == "active" || i2 == "histroy" || i2 == "histroyIdx" || i2 == "busiData") {
continue;
}
if (this[i2] || this[i2] == 0) {
if (Array.isArray(this[i2])) {
let array = [];
this[i2].forEach((element) => {
if (element == null ? void 0 : element.toJSON) {
array.push(element.toJSON());
} else {
array.push(element);
}
});
json[i2] = array;
} else if (this[i2].set && this[i2].has) {
let map = {};
this[i2].forEach((element, key) => {
if (element == null ? void 0 : element.toJSON) {
map[key] = element.toJSON();
} else {
map[key] = element;
}
});
json[i2] = map;
} else if (this[i2].toJSON) {
json[i2] = this[i2].toJSON();
} else {
json[i2] = this[i2];
}
}
}
json.ddeiVersion = 1243;
return json;
}
/**
* 根据属性搜索控件
* @param keywords 关键字/正则表达式
* @param attr 搜索的属性
* @param isReg 是否正则表达式
* @param matchCase 区分大小写
* @param matchAll 全字匹配
*/
searchModels(keywords, attr, isReg = false, matchCase = false, matchAll = false) {
let resultArray = new Array();
if (keywords && attr) {
for (let i2 = 0; i2 < this.sheets.length; i2++) {
let rs = this.sheets[i2].stage.searchModels(keywords, attr, isReg, matchCase, matchAll);
rs == null ? void 0 : rs.forEach((r) => {
r.sheetIndex = i2;
resultArray.push(r);
});
}
}
return resultArray;
}
}
const config = {
HISTROY_LEVEL: "file",
//允许多图层编辑
GLOBAL_ALLOW_OPEN_MULT_LAYERS: true,
//允许全局缩放
GLOBAL_ALLOW_STAGE_RATIO: true,
//模式标识,模式标识对应以ac_开头的访问权限配置
MODE_NAME: "DESIGN",
/**
* 全局权限配置,按照配置自动读取规则
* 配置规则:ac_模式_操作_功能项
* 模式标识:可以自定义,模式只是用来区分权限分组,可以全局设置或由组件参数传入
* 操作:create(创建控件)、edit(编辑控件)、view(查看控件)、drag(拖拽控件)、link(建立连线)、del(删除控件)、select(选中控件)
* 功能项:ModelType < ModelCode < Code < Id
*/
AC_DESIGN_CREATE: true,
AC_DESIGN_EDIT: true,
AC_DESIGN_ROTATE: true,
AC_DESIGN_SCALE: true,
AC_DESIGN_COMPOSE: true,
AC_DESIGN_VIEW: true,
AC_DESIGN_DRAG: true,
AC_DESIGN_LINK: true,
AC_DESIGN_DEL: true,
AC_DESIGN_SELECT: true
};
const isSupportFontFamily = function(f) {
if (typeof f != "string") {
return false;
}
let h = "Arial";
if (f.toLowerCase() == h.toLowerCase()) {
return true;
}
let e = "a";
let d = 100;
let a = 100, i2 = 100;
let c = document.createElement("canvas");
let b = c.getContext("2d", { willReadFrequently: true });
c.width = a;
c.height = i2;
b.textAlign = "center";
b.fillStyle = "black";
b.textBaseline = "middle";
let g = function(j2) {
b.clearRect(0, 0, a, i2);
b.font = d + "px " + j2 + ", " + h;
b.fillText(e, a / 2, i2 / 2);
let k = b.getImageData(0, 0, a, i2).data;
return [].slice.call(k).filter(function(l) {
return l != 0;
});
};
return g(h).join("") !== g(f).join("");
};
const isSupportFontFamilySync = function(f) {
return new Promise((resolve, rejected) => {
resolve(isSupportFontFamily(f));
});
};
const fontTypes = {
windows: [
{ ch: "Arial", en: "Arial" },
{ ch: "Helvetica", en: "Helvetica" },
{ ch: "Arial Black", en: "Arial Black" },
{ ch: "Calibri", en: "Calibri" },
{ ch: "Constantia", en: "Constantia" },
{ ch: "Frutiger", en: "Frutiger" },
{ ch: "Futura", en: "Futura" },
{ ch: "Corbel", en: "Corbel" },
{ ch: "Roboto", en: "Roboto" },
{ ch: "Montserrat", en: "Montserrat" },
{ ch: "Bebas Neue", en: "Bebas Neue" },
{ ch: "Monument Extended", en: "Monument Extended" },
{ ch: "D-DIN", en: "D-DIN" },
{
ch: "宋体",
en: "SimSun"
},
{
ch: "黑体",
en: "SimHei"
},
{
ch: "微软雅黑",
en: "Microsoft Yahei"
},
{
ch: "微软正黑体",
en: "Microsoft JhengHei"
},
{
ch: "楷体",
en: "KaiTi"
},
{
ch: "新宋体",
en: "NSimSun"
},
{
ch: "仿宋",
en: "FangSong"
}
],
"OS X": [{
ch: "苹方",
en: "PingFang SC"
}, {
ch: "华文黑体",
en: "STHeiti"
}, {
ch: "华文楷体",
en: "STKaiti"
}, {
ch: "华文中宋",
en: "STZhongsong"
}, {
ch: "华文琥珀",
en: "STHupo"
}, {
ch: "华文新魏",
en: "STXinwei"
}, {
ch: "华文隶书",
en: "STLiti"
}, {
ch: "华文行楷",
en: "STXingkai"
}, {
ch: "冬青黑体简",
en: "Hiragino Sans GB"
}, {
ch: "兰亭黑-简",
en: "Lantinghei SC"
}, {
ch: "翩翩体-简",
en: "Hanzipen SC"
}, {
ch: "手札体-简",
en: "Hannotate SC"
}, {
ch: "宋体-简",
en: "Songti SC"
}, {
ch: "娃娃体-简",
en: "Wawati SC"
}, {
ch: "魏碑-简",
en: "Weibei SC"
}, {
ch: "行楷-简",
en: "Xingkai SC"
}, {
ch: "雅痞-简",
en: "Yapi SC"
}, {
ch: "圆体-简",
en: "Yuanti SC"
}],
"office": [{
ch: "幼圆",
en: "YouYuan"
}, {
ch: "隶书",
en: "LiSu"
}, {
ch: "华文细黑",
en: "STXihei"
}, {
ch: "华文宋体",
en: "STSong"
}, {
ch: "华文仿宋",
en: "STFangsong"
}, {
ch: "华文中宋",
en: "STZhongsong"
}, {
ch: "华文彩云",
en: "STCaiyun"
}, {
ch: "华文琥珀",
en: "STHupo"
}, {
ch: "华文新魏",
en: "STXinwei"
}, {
ch: "华文隶书",
en: "STLiti"
}, {
ch: "华文行楷",
en: "STXingkai"
}, {
ch: "方正舒体",
en: "FZShuTi"
}, {
ch: "方正姚体",
en: "FZYaoti"
}],
"open": [{
ch: "思源黑体",
en: "Source Han Sans CN"
}, {
ch: "思源宋体",
en: "Source Han Serif SC"
}, {
ch: "文泉驿微米黑",
en: "WenQuanYi Micro Hei"
}],
"hanyi": [{
ch: "汉仪旗黑",
en: "HYQihei 40S"
}, {
ch: "汉仪旗黑",
en: "HYQihei 50S"
}, {
ch: "汉仪旗黑",
en: "HYQihei 60S"
}, {
ch: "汉仪大宋简",
en: "HYDaSongJ"
}, {
ch: "汉仪楷体",
en: "HYKaiti"
}, {
ch: "汉仪家书简",
en: "HYJiaShuJ"
}, {
ch: "汉仪PP体简",
en: "HYPPTiJ"
}, {
ch: "汉仪乐喵体简",
en: "HYLeMiaoTi"
}, {
ch: "汉仪小麦体",
en: "HYXiaoMaiTiJ"
}, {
ch: "汉仪程行体",
en: "HYChengXingJ"
}, {
ch: "汉仪黑荔枝",
en: "HYHeiLiZhiTiJ"
}, {
ch: "汉仪雅酷黑W",
en: "HYYaKuHeiW"
}, {
ch: "汉仪大黑简",
en: "HYDaHeiJ"
}, {
ch: "汉仪尚魏手书W",
en: "HYShangWeiShouShuW"
}],
"fangzheng": [{
"ch": "方正粗雅宋简体",
"en": "FZYaSongS-B-GB"
}, {
"ch": "方正报宋简体",
"en": "FZBaoSong-Z04S"
}, {
"ch": "方正粗圆简体",
"en": "FZCuYuan-M03S"
}, {
"ch": "方正大标宋简体",
"en": "FZDaBiaoSong-B06S"
}, {
"ch": "方正大黑简体",
"en": "FZDaHei-B02S"
}, {
"ch": "方正仿宋简体",
"en": "FZFangSong-Z02S"
}, {
"ch": "方正黑体简体",
"en": "FZHei-B01S"
}, {
"ch": "方正琥珀简体",
"en": "FZHuPo-M04S"
}, {
"ch": "方正楷体简体",
"en": "FZKai-Z03S"
}, {
"ch": "方正隶变简体",
"en": "FZLiBian-S02S"
}, {
"ch": "方正隶书简体",
"en": "FZLiShu-S01S"
}, {
"ch": "方正美黑简体",
"en": "FZMeiHei-M07S"
}, {
"ch": "方正书宋简体",
"en": "FZShuSong-Z01S"
}, {
"ch": "方正舒体简体",
"en": "FZShuTi-S05S"
}, {
"ch": "方正水柱简体",
"en": "FZShuiZhu-M08S"
}, {
"ch": "方正宋黑简体",
"en": "FZSongHei-B07S"
}, {
"ch": "方正宋三简体",
"en": "FZSong"
}, {
"ch": "方正魏碑简体",
"en": "FZWeiBei-S03S"
}, {
"ch": "方正细等线简体",
"en": "FZXiDengXian-Z06S"
}, {
"ch": "方正细黑一简体",
"en": "FZXiHei I-Z08S"
}, {
"ch": "方正细圆简体",
"en": "FZXiYuan-M01S"
}, {
"ch": "方正小标宋简体",
"en": "FZXiaoBiaoSong-B05S"
}, {
"ch": "方正行楷简体",
"en": "FZXingKai-S04S"
}, {
"ch": "方正姚体简体",
"en": "FZYaoTi-M06S"
}, {
"ch": "方正中等线简体",
"en": "FZZhongDengXian-Z07S"
}, {
"ch": "方正准圆简体",
"en": "FZZhunYuan-M02S"
}, {
"ch": "方正综艺简体",
"en": "FZZongYi-M05S"
}, {
"ch": "方正彩云简体",
"en": "FZCaiYun-M09S"
}, {
"ch": "方正隶二简体",
"en": "FZLiShu II-S06S"
}, {
"ch": "方正康体简体",
"en": "FZKangTi-S07S"
}, {
"ch": "方正超粗黑简体",
"en": "FZChaoCuHei-M10S"
}, {
"ch": "方正新报宋简体",
"en": "FZNew BaoSong-Z12S"
}, {
"ch": "方正新舒体简体",
"en": "FZNew ShuTi-S08S"
}, {
"ch": "方正黄草简体",
"en": "FZHuangCao-S09S"
}, {
"ch": "方正少儿简体",
"en": "FZShaoEr-M11S"
}, {
"ch": "方正稚艺简体",
"en": "FZZhiYi-M12S"
}, {
"ch": "方正细珊瑚简体",
"en": "FZXiShanHu-M13S"
}, {
"ch": "方正粗宋简体",
"en": "FZCuSong-B09S"
}, {
"ch": "方正平和简体",
"en": "FZPingHe-S11S"
}, {
"ch": "方正华隶简体",
"en": "FZHuaLi-M14S"
}, {
"ch": "方正瘦金书简体",
"en": "FZShouJinShu-S10S"
}, {
"ch": "方正细倩简体",
"en": "FZXiQian-M15S"
}, {
"ch": "方正中倩简体",
"en": "FZZhongQian-M16S"
}, {
"ch": "方正粗倩简体",
"en": "FZCuQian-M17S"
}, {
"ch": "方正胖娃简体",
"en": "FZPangWa-M18S"
}, {
"ch": "方正宋一简体",
"en": "FZSongYi-Z13S"
}, {
"ch": "方正剪纸简体",
"en": "FZJianZhi-M23S"
}, {
"ch": "方正流行体简体",
"en": "FZLiuXingTi-M26S"
}, {
"ch": "方正祥隶简体",
"en": "FZXiangLi-S17S"
}, {
"ch": "方正粗活意简体",
"en": "FZCuHuoYi-M25S"
}, {
"ch": "方正胖头鱼简体",
"en": "FZPangTouYu-M24S"
}, {
"ch": "方正卡通简体",
"en": "FZKaTong-M19S"
}, {
"ch": "方正艺黑简体",
"en": "FZYiHei-M20S"
}, {
"ch": "方正水黑简体",
"en": "FZShuiHei-M21S"
}, {
"ch": "方正古隶简体",
"en": "FZGuLi-S12S"
}, {
"ch": "方正幼线简体",
"en": "FZYouXian-Z09S"
}, {
"ch": "方正启体简体",
"en": "FZQiTi-S14S"
}, {
"ch": "方正小篆体",
"en": "FZXiaoZhuanTi-S13T"
}, {
"ch": "方正硬笔楷书简体",
"en": "FZYingBiKaiShu-S15S"
}, {
"ch": "方正毡笔黑简体",
"en": "FZZhanBiHei-M22S"
}, {
"ch": "方正硬笔行书简体",
"en": "FZYingBiXingShu-S16S"
}]
};
const rootFontFamily = (document.documentElement.currentStyle ? document.documentElement.currentStyle : window.getComputedStyle(document.documentElement)).fontFamily;
const FONTS = [];
const loadFonts = function() {
let fontData = null;
let fontJSON = localStorage.getItem("DDEI-CACHE-FONT");
if (fontJSON) {
fontData = JSON.parse(fontJSON);
fontData.forEach((fd) => {
FONTS.push(fd);
});
}
if (FONTS.length == 0) {
for (let key in fontTypes) {
let fontType = fontTypes[key];
fontType.forEach((font) => {
let fontEn = font.en, fontCh = font.ch;
isSupportFontFamilySync(fontEn).then((support) => {
if (support) {
if (fontEn.toLowerCase() === rootFontFamily.toLowerCase() || ('"' + fontEn + '"').toLowerCase() === rootFontFamily.toLowerCase() || fontCh.toLowerCase() === rootFontFamily.toLowerCase() || ('"' + fontCh + '"').toLowerCase() === rootFontFamily.toLowerCase()) {
font.isSystemDefault = true;
}
FONTS.push(font);
localStorage.setItem("DDEI-CACHE-FONT", JSON.stringify(FONTS));
}
});
});
}
}
};
setTimeout(() => {
loadFonts();
}, 500);
class DDeiFuncData {
constructor(name, sort, func) {
__publicField2(this, "name", "");
__publicField2(this, "sort", null);
__publicField2(this, "func", null);
if (name) {
this.name = name;
}
if (sort) {
this.sort = sort;
}
if (func) {
this.func = func;
}
}
}
var DDeiEditorEnumBusCommandType = /* @__PURE__ */ ((DDeiEditorEnumBusCommandType2) => {
DDeiEditorEnumBusCommandType2["ClearTemplateUI"] = "clear-template-ui";
DDeiEditorEnumBusCommandType2["RefreshEditorParts"] = "refresh-editor-parts";
DDeiEditorEnumBusCommandType2["FileDirty"] = "file-dirty";
DDeiEditorEnumBusCommandType2["SaveFile"] = "save-file";
DDeiEditorEnumBusCommandType2["LoadFile"] = "load-file";
DDeiEditorEnumBusCommandType2["AddFileHistroy"] = "add-file-histroy";
DDeiEditorEnumBusCommandType2["ChangeEditMode"] = "editor-change-edit-mode";
return DDeiEditorEnumBusCommandType2;
})(DDeiEditorEnumBusCommandType || {});
const _DDeiEditor = class _DDeiEditor2 {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "theme", null);
__publicField2(this, "GLOBAL_LOCAL_CACHE_THEME", true);
__publicField2(this, "GLOBAL_KEYBOARD_ALIGN_ENABLE", true);
__publicField2(this, "GLOBAL_ALLOW_OPEN_MULT_LAYERS", true);
__publicField2(this, "EVENT_LOAD_FILE", null);
__publicField2(this, "EVENT_SAVE_FILE", null);
__publicField2(this, "EVENT_PUBLISH_FILE", null);
__publicField2(this, "EVENT_CONTROL_SELECT_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_SELECT_AFTER", null);
__publicField2(this, "EVENT_STAGE_CHANGE_WPV", null);
__publicField2(this, "EVENT_STAGE_CHANGE_RATIO", null);
__publicField2(this, "GLOBAL_ALLOW_BACK_ACTIVE", false);
__publicField2(this, "id");
__publicField2(this, "containerid");
__publicField2(this, "files");
__publicField2(this, "currentFileIndex");
__publicField2(this, "state");
__publicField2(this, "modelType", "DDeiEditor");
__publicField2(this, "ddInstance", null);
__publicField2(this, "leftWidth", 0);
__publicField2(this, "topHeight", 0);
__publicField2(this, "rightWidth", 0);
__publicField2(this, "bottomHeight", 0);
__publicField2(this, "middleWidth", 0);
__publicField2(this, "middleHeight", 0);
__publicField2(this, "bus", null);
__publicField2(this, "setCurrentMenu", null);
__publicField2(this, "editMode", 1);
__publicField2(this, "components", vue.markRaw({}));
__publicField2(this, "propeditors", vue.markRaw({}));
__publicField2(this, "panels", vue.markRaw({}));
__publicField2(this, "langs", vue.markRaw({}));
__publicField2(this, "lang", null);
__publicField2(this, "layouts", vue.markRaw({}));
__publicField2(this, "dialogs", vue.markRaw({}));
__publicField2(this, "hotkeys", vue.markRaw({}));
__publicField2(this, "hotKeyMapping", vue.markRaw([]));
__publicField2(this, "menus", vue.markRaw({}));
__publicField2(this, "fonts", FONTS);
__publicField2(this, "viewerMap", vue.markRaw(/* @__PURE__ */ new Map()));
__publicField2(this, "menuMapping", vue.markRaw({}));
__publicField2(this, "controls", vue.markRaw(/* @__PURE__ */ new Map()));
__publicField2(this, "groups", vue.markRaw([]));
__publicField2(this, "controlModelClasses", vue.markRaw({}));
__publicField2(this, "controlViewClasses", vue.markRaw({}));
__publicField2(this, "themes", vue.markRaw([]));
__publicField2(this, "currentTheme", "");
__publicField2(this, "currentLayout", "ddei-core-layout-standard");
__publicField2(this, "converters", vue.markRaw({}));
__publicField2(this, "lifecyclies", vue.markRaw([]));
__publicField2(this, "funcIndex", /* @__PURE__ */ new Map());
this.id = props.id;
this.containerid = props.containerid;
this.files = props.files ? props.files : [];
this.currentFileIndex = props.currentFileIndex ? props.currentFileIndex : -1;
this.state = DDeiEditorState.DESIGNING;
if (props.currentLayout) {
this.currentLayout = props.currentLayout;
}
}
// ============================ 静态方法 ============================
/**
* 给予container构建一个DDei实例
* 每一个DDei至少包含1个文件
* @param {id} id 文件id
* @param {containerid} containerid 容器id
* @param {active} active 是否设置为活动实例,缺省是
*/
static newInstance(id, containerid, active = true, options = {}) {
var _a3, _b2, _c2, _d2;
if (id && containerid) {
if (!_DDeiEditor2.INSTANCE_POOL.get(id)) {
let editorInitOptions = clone(options);
editorInitOptions.id = id;
editorInitOptions.containerid = containerid;
(_a3 = editorInitOptions.extensions) == null ? void 0 : _a3.sort((a, b) => {
return a.order - b.order;
});
for (let i2 = 0; i2 < ((_b2 = editorInitOptions.extensions) == null ? void 0 : _b2.length); i2++) {
if (editorInitOptions.extensions[i2].getInitConfig) {
let initConfigData = editorInitOptions.extensions[i2].getInitConfig();
if (initConfigData) {
_DDeiEditor2.changeInitConfigData(editorInitOptions, initConfigData);
}
}
}
let editorInstance2 = new _DDeiEditor2(editorInitOptions);
if (!DDeiUtil$1.getAttrValueByConfig) {
DDeiUtil$1.getAttrValueByConfig = DDeiEditorUtil$1.getAttrValueByConfig;
}
if (!DDeiUtil$1.getControlDefine) {
DDeiUtil$1.getControlDefine = DDeiEditorUtil$1.getControlDefine;
}
if (!DDeiUtil$1.getMenuConfig) {
DDeiUtil$1.getMenuConfig = DDeiEditorUtil$1.getMenuConfig;
}
if (!DDeiUtil$1.getMenuControlId) {
DDeiUtil$1.getMenuControlId = DDeiEditorUtil$1.getMenuControlId;
}
if (!DDeiUtil$1.showContextMenu) {
DDeiUtil$1.showContextMenu = DDeiEditorUtil$1.showContextMenu;
}
if (!DDeiUtil$1.getSubControlJSON) {
DDeiUtil$1.getSubControlJSON = DDeiEditorUtil$1.getSubControlJSON;
}
if (!DDeiUtil$1.getLineInitJSON) {
DDeiUtil$1.getLineInitJSON = DDeiEditorUtil$1.getLineInitJSON;
}
if (!DDeiUtil$1.getModelInitJSON) {
DDeiUtil$1.getModelInitJSON = DDeiEditorUtil$1.getModelInitJSON;
}
if (!DDeiUtil$1.getBusiData) {
DDeiUtil$1.getBusiData = DDeiEditorUtil$1.getBusiData;
}
if (!DDeiUtil$1.getEditorText) {
DDeiUtil$1.getEditorText = DDeiEditorUtil$1.getEditorText;
}
if (!DDeiUtil$1.getStyleValue) {
DDeiUtil$1.getStyleValue = DDeiEditorUtil$1.getStyleValue;
}
if (!DDeiUtil$1.getEditorId) {
DDeiUtil$1.getEditorId = DDeiEditorUtil$1.getEditorId;
}
if (!DDeiUtil$1.invokeCallbackFunc) {
DDeiUtil$1.invokeCallbackFunc = DDeiEditorUtil$1.invokeCallbackFunc;
}
if (!DDeiUtil$1.notifyChange) {
DDeiUtil$1.notifyChange = DDeiEditorUtil$1.notifyChange;
}
if (!DDeiUtil$1.isBackActive) {
DDeiUtil$1.isBackActive = DDeiEditorUtil$1.isBackActive;
}
if (!DDeiUtil$1.getEditorInsByDDei) {
DDeiUtil$1.getEditorInsByDDei = DDeiEditorUtil$1.getEditorInsByDDei;
}
if (!DDeiUtil$1.createControl) {
DDeiUtil$1.createControl = DDeiEditorUtil$1.createControl;
}
_DDeiEditor2.INSTANCE_POOL.set(id, editorInstance2);
if (active) {
_DDeiEditor2.ACTIVE_INSTANCE = editorInstance2;
}
let ddInstance = DDei.newInstance(
editorInstance2.id,
editorInstance2.id + "_canvas",
null,
editorInstance2
);
ddInstance.bus.invoker = editorInstance2;
editorInstance2.bus = ddInstance.bus;
ddInstance.controlModelClasses = editorInstance2.controlModelClasses;
ddInstance.controlViewClasses = editorInstance2.controlViewClasses;
let control_ctx2 = /* @__PURE__ */ Object.assign({
"../../framework/js/models/circle.ts": __vite_glob_0_0$2$1,
"../../framework/js/models/diamond.ts": __vite_glob_0_1$2$1,
"../../framework/js/models/layer.ts": __vite_glob_0_2$2,
"../../framework/js/models/line.ts": __vite_glob_0_3$3,
"../../framework/js/models/link.ts": __vite_glob_0_4$2,
"../../framework/js/models/modellink.ts": __vite_glob_0_5$2,
"../../framework/js/models/polygon-container.ts": __vite_glob_0_6$2,
"../../framework/js/models/polygon.ts": __vite_glob_0_7$1$1,
"../../framework/js/models/rectangle.ts": __vite_glob_0_8$1$1,
"../../framework/js/models/selector.ts": __vite_glob_0_9$1$1,
"../../framework/js/models/shape.ts": __vite_glob_0_10$1$1,
"../../framework/js/models/stage.ts": __vite_glob_0_11$1$1,
"../../framework/js/models/table-cell.ts": __vite_glob_0_12$1$1,
"../../framework/js/models/table-selector.ts": __vite_glob_0_13$1$1,
"../../framework/js/models/table.ts": __vite_glob_0_14$1$1
});
for (let path in control_ctx2) {
let cls = control_ctx2[path].default;
if (cls == null ? void 0 : cls.ClsName) {
editorInstance2.controlModelClasses[cls.ClsName] = cls;
}
}
let view_ctx = /* @__PURE__ */ Object.assign({
"../../framework/js/views/canvas/circle-render.ts": __vite_glob_1_0$2,
"../../framework/js/views/canvas/ddei-render.ts": __vite_glob_1_1$2,
"../../framework/js/views/canvas/diamond-render.ts": __vite_glob_1_2$2,
"../../framework/js/views/canvas/layer-render.ts": __vite_glob_1_3$1,
"../../framework/js/views/canvas/line-render.ts": __vite_glob_1_4$1,
"../../framework/js/views/canvas/polygon-container-render.ts": __vite_glob_1_5$1,
"../../framework/js/views/canvas/polygon-render.ts": __vite_glob_1_6$1,
"../../framework/js/views/canvas/rectangle-render.ts": __vite_glob_1_7$1,
"../../framework/js/views/canvas/selector-render.ts": __vite_glob_1_8,
"../../framework/js/views/canvas/shape-render-base.ts": __vite_glob_1_9,
"../../framework/js/views/canvas/stage-render.ts": __vite_glob_1_10,
"../../framework/js/views/canvas/table-cell-render.ts": __vite_glob_1_11,
"../../framework/js/views/canvas/table-render.ts": __vite_glob_1_12,
"../../framework/js/views/canvas/table-selector-render.ts": __vite_glob_1_13
});
for (let path in view_ctx) {
let cls = view_ctx[path].default;
if (cls == null ? void 0 : cls.ClsName) {
editorInstance2.controlViewClasses[cls.ClsName] = cls;
}
}
if (options) {
editorInstance2.options = editorInitOptions;
(_c2 = options.extensions) == null ? void 0 : _c2.forEach((item) => editorInstance2.registerExtension(item));
for (let i2 in editorInstance2.hotkeys) {
let hotkey = editorInstance2.hotkeys[i2];
let options2 = hotkey.getOptions();
if (options2 == null ? void 0 : options2.keys) {
let keys2 = cloneDeep(options2 == null ? void 0 : options2.keys);
keys2.forEach((key) => {
key.action = hotkey;
});
editorInstance2.hotKeyMapping = editorInstance2.hotKeyMapping.concat(keys2);
}
}
editorInstance2.hotKeyMapping.sort((a, b) => {
if (a.times && b.times) {
return 0;
} else if (a.times && !b.times) {
return -1;
} else if (!a.times && b.times) {
return 1;
} else if (!a.times && !b.times) {
return 0;
}
});
for (let i2 in editorInstance2.menus) {
let menu = editorInstance2.menus[i2];
let options2 = menu.getOptions();
menu.label = options2.label ? options2.label : "";
menu.icon = options2.icon ? options2.icon : "";
menu.disabled = options2.disabled ? options2.disabled : false;
(_d2 = options2 == null ? void 0 : options2.models) == null ? void 0 : _d2.forEach((model) => {
if (!editorInstance2.menuMapping[model]) {
editorInstance2.menuMapping[model] = [];
}
let menus2 = editorInstance2.menuMapping[model];
let finded = false;
for (let j2 = 0; j2 < menus2.length; j2++) {
if (menu.name == menus2[j2].name) {
finded = true;
break;
}
}
if (!finded) {
menus2.push(menu);
}
});
}
editorInstance2.lifecyclies.forEach((lifeCycle) => {
for (let i2 in lifeCycle) {
if (lifeCycle[i2] && lifeCycle[i2] instanceof DDeiFuncData) {
if (!editorInstance2.funcIndex.has(i2)) {
editorInstance2.funcIndex.set(i2, []);
}
let funcArray = editorInstance2.funcIndex.get(i2);
funcArray == null ? void 0 : funcArray.push(lifeCycle[i2]);
}
}
});
editorInstance2.funcIndex.forEach((funcArr) => {
funcArr.sort((a, b) => {
if (a.sort && b.sort) {
return a.sort - b.sort;
} else if (a.sort && !b.sort) {
return 1;
} else if (!a.sort && b.sort) {
return -1;
} else if (!a.sort && !b.sort) {
return 0;
}
});
});
}
return editorInstance2;
} else {
return _DDeiEditor2.INSTANCE_POOL.get(id);
}
}
return null;
}
/**
* 修改初始化数据,有append,rewrite,remove三种
* @param editor
* @param config
* @param initConfigData
*/
static changeInitConfigData(config2, initConfigData) {
var _a3, _b2;
if (initConfigData.remove) {
(_a3 = initConfigData.remove.extensions) == null ? void 0 : _a3.forEach((ext) => {
var _a22;
let findedNi = -1;
for (let ni = 0; ni < ((_a22 = config2.extensions) == null ? void 0 : _a22.length); ni++) {
let existsExt = config2.extensions[ni];
if (existsExt == ext || existsExt.name == ext.name || existsExt && ext && existsExt.name == ext || ext && existsExt && existsExt == ext.name) {
findedNi = ni;
break;
}
}
if (findedNi != -1) {
config2.extensions.splice(findedNi, 1);
}
});
}
if (initConfigData.append) {
if (!config2.extensions) {
config2.extensions = [];
}
(_b2 = initConfigData.append.extensions) == null ? void 0 : _b2.forEach((ext) => {
var _a22;
let finded = false;
for (let ni = 0; ni < ((_a22 = config2.extensions) == null ? void 0 : _a22.length); ni++) {
let existsExt = config2.extensions[ni];
if (existsExt == ext || existsExt.name == ext.name || existsExt && ext && existsExt.name == ext || ext && existsExt && existsExt == ext.name) {
finded = true;
break;
}
}
if (!finded) {
config2.extensions.push(ext);
}
});
}
if (initConfigData.rewrite) {
for (let k in initConfigData.rewrite) {
if (k != "config") {
config2[k] = initConfigData.rewrite[k];
}
}
if (initConfigData.rewrite.config) {
for (let k in initConfigData.rewrite.config) {
if (!config2.config) {
config2.config = {};
}
config2.config[k] = initConfigData.rewrite.config[k];
}
}
}
}
/**
* 将语言包添加进当前editor
* @param langs 语言包
*/
registerLangs(langs) {
if (langs) {
for (let n in langs) {
if (!this.langs[n]) {
this.langs[n] = langs[n];
} else {
this.langs[n] = defaultsDeep$1({}, langs[n], this.langs[n]);
}
}
}
}
setI18nLang(language) {
if (!language) {
language = navigator.language || navigator.userLanguage;
}
if (!language) {
language = "zh_CN";
} else {
language = language.replace("-", "_");
}
if (!this.langs[language]) {
this.lang = "zh_CN";
} else {
this.lang = language;
}
}
i18n(path) {
let lang = this.langs[this.lang];
let value = DDeiUtil$1.getDataByPathList(lang, path);
if (value) {
return value;
} else {
return path;
}
}
/**
* 注册外部插件
*/
registerExtension(plugin) {
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
plugin = plugin.defaultIns;
}
if (plugin.getLangs) {
let langs = plugin.getLangs(this);
this.registerLangs(langs);
}
if (plugin.getComponents) {
let components = plugin.getComponents(this);
components == null ? void 0 : components.forEach((component) => {
this.panels[component.name] = component;
});
}
if (plugin.getDialogs) {
let dialogs = plugin.getDialogs(this);
dialogs == null ? void 0 : dialogs.forEach((dialog) => {
this.dialogs[dialog.name] = cloneDeep(dialog);
});
}
if (plugin.getPanels) {
let panels = plugin.getPanels(this);
panels == null ? void 0 : panels.forEach((panel) => {
this.panels[panel.name] = panel;
});
}
if (plugin.getLayouts) {
let layouts = plugin.getLayouts(this);
layouts == null ? void 0 : layouts.forEach((layout) => {
this.layouts[layout.name] = layout;
});
}
if (plugin.getPropEditors) {
let propEditors = plugin.getPropEditors(this);
propEditors == null ? void 0 : propEditors.forEach((propEditor) => {
this.propeditors[propEditor.name] = propEditor;
});
}
if (plugin.getHotKeys) {
let hotKeys = plugin.getHotKeys(this);
hotKeys == null ? void 0 : hotKeys.forEach((hotkey) => {
this.hotkeys[hotkey.name] = hotkey;
});
}
if (plugin.getFonts) {
let fonts = plugin.getFonts(this);
fonts == null ? void 0 : fonts.forEach((font) => {
this.fonts.push(font);
let fontObj = new FontFace(font.ch, "url(" + font.font + ")");
fontObj.load().then((f) => {
document.fonts.add(f);
});
});
}
if (plugin.getThemes) {
let themes = plugin.getThemes(this);
themes == null ? void 0 : themes.forEach((theme) => {
var _a3;
let finded = false;
for (let i2 = 0; i2 < ((_a3 = this.themes) == null ? void 0 : _a3.length); i2++) {
if (this.themes[i2].name == theme.name) {
finded = true;
this.themes[i2] = theme;
break;
}
}
if (!finded) {
this.themes.push(theme);
}
});
}
if (plugin.getMenus) {
let menus2 = plugin.getMenus(this);
menus2 == null ? void 0 : menus2.forEach((menu) => {
this.menus[menu.name] = menu;
});
}
if (plugin.getControls) {
let controls2 = plugin.getControls(this);
controls2 == null ? void 0 : controls2.forEach((control) => {
this.controls.set(control.id, control);
});
}
if (plugin.getGroups) {
let groups = plugin.getGroups(this);
groups == null ? void 0 : groups.forEach((group2) => {
let finded = false;
for (let i2 = 0; i2 < this.groups.length; i2++) {
if (this.groups[i2].id == group2.id) {
this.groups[i2] = group2;
finded = true;
break;
}
}
if (!finded) {
this.groups.push(group2);
}
});
}
if (plugin.getModels) {
let models = plugin.getModels(this);
models == null ? void 0 : models.forEach((model) => {
this.controlModelClasses[model.ClsName] = model;
});
}
if (plugin.getViews) {
let views = plugin.getViews(this);
views == null ? void 0 : views.forEach((view) => {
this.controlViewClasses[view.ClsName] = view;
});
}
if (plugin.getConverters) {
let converters = plugin.getConverters(this);
converters == null ? void 0 : converters.forEach((converter) => {
this.converters[converter.name] = converter;
});
}
if (plugin.getLifeCyclies) {
let lifeCyclies = plugin.getLifeCyclies(this);
lifeCyclies == null ? void 0 : lifeCyclies.forEach((lifeCycle) => {
this.lifecyclies.push(lifeCycle);
});
}
if (plugin.installed) {
plugin.installed(this);
}
let options = null;
if (plugin.getOptions) {
options = plugin.getOptions();
}
if (options) {
let pluginType = plugin.getType();
if (pluginType == "plugin") {
let pluginName = plugin.getName();
if (pluginName) {
this.options[pluginName] = options;
}
} else if (pluginType == "package") {
this.options = Object.assign({}, this.options, options);
}
}
}
/**
* 应用外部配置文件
* @param custConfig
*/
applyConfig(custConfig) {
if (config) {
for (let i2 in config) {
this[i2] = config[i2];
}
if (this.ddInstance) {
this.ddInstance.applyConfig(config);
}
}
if (custConfig) {
for (let i2 in custConfig) {
this[i2] = custConfig[i2];
}
if (this.ddInstance) {
this.ddInstance.applyConfig(custConfig);
}
}
}
// ============================ 方法 ============================
/**
* 修改当前编辑模式
* @param mode 编辑模式
*/
changeEditMode(mode) {
if (this.editMode != mode) {
this.editMode = mode;
}
}
/**
* 加载文件到设计器中
* @param fileJson 文件json
* @param append 是否添加
*/
loadData(fileJson, append = false) {
var _a3;
if (fileJson) {
if (typeof fileJson == "string") {
fileJson = JSON.parse(fileJson);
}
let json = fileJson;
let file;
if (json == null ? void 0 : json.content) {
file = DDeiFile.loadFromJSON(json.content, {
currentDdInstance: this.ddInstance
});
file.id = json.id;
file.publish = json.publish;
file.name = json.name;
file.path = json.path;
file.desc = json.desc;
file.version = json.version;
file.extData = json.extData;
file.busiData = json.busiData;
} else {
file = DDeiFile.loadFromJSON(json, {
currentDdInstance: this.ddInstance
});
}
file.state = DDeiFileState.NONE;
if (append) {
this.addFile(file);
this.files.forEach((f) => {
f.active = DDeiActiveType.NONE;
});
this.currentFileIndex = this.files.indexOf(file);
} else {
this.files[this.currentFileIndex] = file;
}
if (file && ((_a3 = file.sheets) == null ? void 0 : _a3.length) > 0) {
file.active = DDeiActiveType.ACTIVE;
let sheets = file == null ? void 0 : file.sheets;
file.changeSheet(file.currentSheetIndex);
let stage2 = sheets[file.currentSheetIndex].stage;
stage2.ddInstance = this.ddInstance;
file.initHistroy();
this.ddInstance.stage = stage2;
stage2.initRender();
}
this.notifyChange();
}
}
/**
* 添加文件到列表中,默认添加到最后面
*/
addFile(file, index = null) {
if (index || index == 0) {
this.files.splice(index, 0, file);
} else {
this.files.push(file);
}
}
/**
* 移除文件
*/
removeFile(file, index) {
if (file) {
if (this.files.indexOf(file) != -1) {
this.files.splice(this.files.indexOf(file), 1);
}
} else if (index || index == 0) {
this.files.splice(index, 1);
}
}
/**
* 交换文件的位置
*/
exchangeFile(indexA, indexB) {
let fileA = this.files[indexA];
let fileB = this.files[indexB];
this.files[indexA] = fileB;
this.files[indexB] = fileA;
}
// ============================ 事件 ============================
/**
* 绑定事件
*/
bindEvent() {
window.removeEventListener("blur", this.blur);
document.removeEventListener("keydown", this.keyDown);
document.removeEventListener("keyup", this.keyUp);
document.addEventListener("keydown", this.keyDown);
document.addEventListener("keyup", this.keyUp);
window.addEventListener("blur", this.blur);
}
/**
* 改变编辑器状态
* @param state 新状态
*/
changeState(state) {
if (this.state != state) {
this.state = state;
}
}
/**
* 键盘按下
*/
keyDown(evt) {
var _a3;
let isActive = false;
if (((_a3 = document.activeElement) == null ? void 0 : _a3.tagName) == "BODY") {
isActive = true;
} else {
isActive = DDeiEditorUtil$1.isEditorSubElement(document.activeElement, _DDeiEditor2.ACTIVE_INSTANCE);
}
if (isActive && DDeiKeyAction.route(evt)) {
evt.preventDefault();
}
}
/**
* 键盘弹起
*/
keyUp(evt) {
var _a3;
let isActive = false;
if (((_a3 = document.activeElement) == null ? void 0 : _a3.tagName) == "BODY") {
isActive = true;
} else {
isActive = DDeiEditorUtil$1.isEditorSubElement(document.activeElement, this);
}
if (isActive) {
DDeiKeyAction.updateKeyState(evt);
}
}
/**
* 失去焦点
*/
blur() {
var _a3;
DDei.KEY_DOWN_STATE.clear();
if ((_a3 = this.ddInstance) == null ? void 0 : _a3.render) {
this.ddInstance.render.inEdge = 0;
}
}
/**
* 获取属性编辑器
*/
getPropEditor(controlType) {
if (controlType && this.propeditors && this.propeditors["pv-" + controlType]) {
return this.propeditors["pv-" + controlType];
}
}
/**
* 获取布局
*/
getLayout() {
return this.layouts[this.currentLayout];
}
/**
* 获取布局选项
*/
getLayoutOptions() {
return this.options[this.currentLayout];
}
/**
* 返回所有弹出框以及选项
*/
getDialogs() {
let returnArray = [];
for (let i2 in this.dialogs) {
let dialog = this.dialogs[i2];
if (dialog) {
let dialogOption = this.options[i2];
let options = null;
if (typeof dialogOption == "string") {
options = this.options[dialogOption];
} else if (dialogOption == null ? void 0 : dialogOption.getName) {
options = dialogOption.getOptions();
} else {
options = dialogOption;
}
returnArray.push({ dialog, options });
}
}
return returnArray;
}
/**
* 获取options中的各个部分的配置
*/
getPartPanels(options, part) {
let partOption = null;
if (options && options[part]) {
if (options[part]) {
partOption = options[part];
}
}
if (partOption && this.panels) {
let returnArray = [];
partOption.forEach((poption) => {
if (typeof poption == "string") {
if (this.panels[poption]) {
let comp = this.panels[poption];
let opts = this.options[poption];
returnArray.push({ comp, options: opts });
}
} else if (poption instanceof DDeiPluginBase) {
let name = poption.getName();
if (this.panels[name]) {
let comp = this.panels[name];
let opts = poption.getOptions();
returnArray.push({ comp, options: opts });
}
} else if (DDeiPluginBase.isSubclass(poption, DDeiPluginBase)) {
let name = poption.defaultIns.getName();
if (this.panels[name]) {
let comp = this.panels[name];
let opts = poption.defaultIns.getOptions();
returnArray.push({ comp, options: opts });
}
}
});
return returnArray;
}
}
/**
* 获取开启的转换器
* fileData 文件内容
*/
getEnabledConverters(fileData, sort = 1) {
let returnArray = [];
for (let i2 in this.converters) {
let converter = this.converters[i2];
if (converter.isEnable(fileData)) {
returnArray.push(converter);
}
}
if (sort == 1) {
returnArray.sort((c1, c2) => {
if (c1.sort && c2.sort) {
return (c1 == null ? void 0 : c1.sort) - (c2 == null ? void 0 : c2.sort);
} else if (c1.sort && !c2.sort) {
return 1;
} else if (!c1.sort && c2.sort) {
return -1;
} else {
return 0;
}
});
} else {
returnArray.sort((c1, c2) => {
if (c1.sort && c2.sort) {
return (c2 == null ? void 0 : c2.sort) - (c1 == null ? void 0 : c1.sort);
} else if (c1.sort && !c2.sort) {
return -1;
} else if (!c1.sort && c2.sort) {
return 1;
} else {
return 0;
}
});
}
return returnArray;
}
/**
* 设置当前主题
* @param themeName 主题名称
*/
changeTheme(themeName) {
var _a3;
if (!themeName) {
if (this.GLOBAL_LOCAL_CACHE_THEME) {
themeName = localStorage.getItem("ddei-theme-" + this.id);
}
}
let finded = false;
let defaultJSON = null;
for (let i2 = 0; i2 < ((_a3 = this.themes) == null ? void 0 : _a3.length); i2++) {
if (this.theme && this.themes[i2].name == this.theme) {
defaultJSON = this.themes[i2];
} else if (this.themes[i2].default == true) {
defaultJSON = this.themes[i2];
}
if (this.themes[i2].name == themeName) {
finded = true;
this.currentTheme = themeName;
let themeConfig = this.themes[i2];
this.changeStyle(this.currentTheme, themeConfig);
break;
}
}
if (!finded) {
this.currentTheme = defaultJSON.name;
let themeConfig = defaultJSON;
this.changeStyle(this.currentTheme, themeConfig);
}
}
changeStyle(name, obj) {
var _a3, _b2, _c2, _d2, _e2;
let container2 = document.getElementById(this.containerid);
container2 == null ? void 0 : container2.setAttribute("theme", name);
let removeProperties = [];
for (let i2 = 0; i2 < container2.style.length; i2++) {
if (container2.style[i2] && container2.style[i2].startsWith("--")) {
removeProperties.push(container2.style[i2]);
}
}
removeProperties.forEach((prop) => {
container2.style.removeProperty(prop);
});
for (let key in obj) {
if (obj[key]) {
container2.style.setProperty(`--${key}`, obj[key]);
}
}
if ((_b2 = (_a3 = this.ddInstance) == null ? void 0 : _a3.stage) == null ? void 0 : _b2.render) {
(_e2 = (_d2 = (_c2 = this.ddInstance) == null ? void 0 : _c2.stage) == null ? void 0 : _d2.render) == null ? void 0 : _e2.clearCachedValue();
this.ddInstance.stage.render.refresh = true;
}
if (this.GLOBAL_LOCAL_CACHE_THEME) {
let curInsTheme = localStorage.getItem("ddei-theme-" + this.id);
if (!curInsTheme || curInsTheme != name) {
localStorage.setItem("ddei-theme-" + this.id, name);
}
}
}
/**
* 向当前画布添加控件,缺省坐标为当前画布的中心
* @param controls 要添加的控件
* @param applyRatio 应用缩放
* @param notify 通知刷新
*/
addControls(controls2, applyRatio = true, notify = true, beforeInvoke = false) {
if ((controls2 == null ? void 0 : controls2.length) > 0) {
let stage2 = this.ddInstance.stage;
let layer2 = stage2 == null ? void 0 : stage2.layers[stage2 == null ? void 0 : stage2.layerIndex];
let shapes = [];
if (layer2) {
controls2.forEach((control) => {
var _a3, _b2;
let controlDefine = this.controls.get(control.model);
if (controlDefine) {
let controlModel = DDeiEditorUtil$1.createControl(controlDefine, this);
let valid = false;
if (!beforeInvoke) {
valid = true;
} else {
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_CREATE_BEFORE", "CREATE", { models: controlModel }, this.ddInstance);
if (rsState == 0 || rsState == 1) {
valid = true;
}
}
if (valid && (controlModel == null ? void 0 : controlModel.length) > 0) {
let cc = controlModel[0];
for (let i2 in control) {
if (i2 != "spv" && i2 != "hpv" && i2 != "cpv" && i2 != "x" && i2 != "y" && i2 != "width" && i2 != "height" && (control[i2] || control[i2] == 0 || control[i2] == false)) {
cc[i2] = control[i2];
}
}
let stageRatio1 = stage2.getStageRatio();
let stageRatio2 = !applyRatio ? 1 / stageRatio1 : 1;
let m12 = new Matrix3();
if (control.width || control.height) {
let width = (control.width ? control.width : 0) * stageRatio2;
let height = (control.height ? control.height : 0) * stageRatio2;
let scaleMatrix2 = new Matrix3(
width / cc.essBounds.width,
0,
0,
0,
height / cc.essBounds.height,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
}
let centerMoveX = (-stage2.wpv.x + this.ddInstance.render.canvas.width / this.ddInstance.render.ratio / 2) / stageRatio1;
let centerMoveY = (-stage2.wpv.y + this.ddInstance.render.canvas.height / this.ddInstance.render.ratio / 2) / stageRatio1;
let moveMatrix2 = new Matrix3(
1,
0,
centerMoveX,
0,
1,
centerMoveY,
0,
0,
1
);
m12.premultiply(moveMatrix2);
if (control.offsetX || control.offsetY) {
let move1Matrix = new Matrix3(
1,
0,
control.offsetX ? control.offsetX * stageRatio2 : 0,
0,
1,
control.offsetY ? control.offsetY * stageRatio2 : 0,
0,
0,
1
);
m12.premultiply(move1Matrix);
} else if ((control.x || control.x == 0) && (control.y || control.y == 0)) {
let move1Matrix = new Matrix3(
1,
0,
-centerMoveX + control.x * stageRatio2,
0,
1,
-centerMoveY + control.y * stageRatio2,
0,
0,
1
);
m12.premultiply(move1Matrix);
}
cc.transVectors(m12);
if ((_b2 = (_a3 = controlDefine == null ? void 0 : controlDefine.define) == null ? void 0 : _a3.sample) == null ? void 0 : _b2.depProps) {
let depProps = controlDefine.define.sample.depProps;
for (let type in depProps) {
let property = depProps[type];
let modelPropValue = cc[property];
if (modelPropValue) {
DDeiUtil$1.createDepLinkModel(cc, modelPropValue, type);
}
}
}
cc.updateLinkModels();
cc.refreshLinkModels();
layer2.addModel(cc, false);
cc.initRender();
shapes.push(cc);
}
}
});
if (notify) {
this.notifyChange();
}
}
return shapes;
}
}
/**
* 向特定图层添加控件,缺省坐标为当前画布的中心
* @param controls 要添加的控件
* @param layerIndex 图层下标
* @param applyRatio 应用缩放
* @param notify 通知刷新
*/
addControlsToLayer(controls2, layerIndex = -1, applyRatio = true, notify = true, beforeInvoke = false) {
var _a3;
let stage2 = this.ddInstance.stage;
if (layerIndex > -1 && layerIndex < ((_a3 = stage2 == null ? void 0 : stage2.layers) == null ? void 0 : _a3.length)) {
let layer2 = stage2 == null ? void 0 : stage2.layers[layerIndex];
let shapes = [];
if (layer2) {
controls2.forEach((control) => {
var _a22, _b2;
let controlDefine = this.controls.get(control.model);
if (controlDefine) {
let controlModel = DDeiEditorUtil$1.createControl(controlDefine, this);
let valid = false;
if (!beforeInvoke) {
valid = true;
} else {
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_CREATE_BEFORE", "CREATE", { models: controlModel }, this.ddInstance);
if (rsState == 0 || rsState == 1) {
valid = true;
}
}
if (valid && (controlModel == null ? void 0 : controlModel.length) > 0) {
let cc = controlModel[0];
for (let i2 in control) {
if (i2 != "spv" && i2 != "hpv" && i2 != "cpv" && i2 != "x" && i2 != "y" && i2 != "width" && i2 != "height" && (control[i2] || control[i2] == 0 || control[i2] == false)) {
cc[i2] = control[i2];
}
}
let stageRatio1 = stage2.getStageRatio();
let stageRatio2 = !applyRatio ? 1 / stageRatio1 : 1;
let m12 = new Matrix3();
if (control.width || control.height) {
let width = (control.width ? control.width : 0) * stageRatio2;
let height = (control.height ? control.height : 0) * stageRatio2;
let scaleMatrix2 = new Matrix3(
width / cc.essBounds.width,
0,
0,
0,
height / cc.essBounds.height,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
}
let centerMoveX = (-stage2.wpv.x + this.ddInstance.render.canvas.width / this.ddInstance.render.ratio / 2) / stageRatio1;
let centerMoveY = (-stage2.wpv.y + this.ddInstance.render.canvas.height / this.ddInstance.render.ratio / 2) / stageRatio1;
let moveMatrix2 = new Matrix3(
1,
0,
centerMoveX,
0,
1,
centerMoveY,
0,
0,
1
);
m12.premultiply(moveMatrix2);
if (control.offsetX || control.offsetY) {
let move1Matrix = new Matrix3(
1,
0,
control.offsetX ? control.offsetX * stageRatio2 : 0,
0,
1,
control.offsetY ? control.offsetY * stageRatio2 : 0,
0,
0,
1
);
m12.premultiply(move1Matrix);
} else if ((control.x || control.x == 0) && (control.y || control.y == 0)) {
let move1Matrix = new Matrix3(
1,
0,
-centerMoveX + control.x * stageRatio2,
0,
1,
-centerMoveY + control.y * stageRatio2,
0,
0,
1
);
m12.premultiply(move1Matrix);
}
cc.transVectors(m12);
if ((_b2 = (_a22 = controlDefine == null ? void 0 : controlDefine.define) == null ? void 0 : _a22.sample) == null ? void 0 : _b2.depProps) {
let depProps = controlDefine.define.sample.depProps;
for (let type in depProps) {
let property = depProps[type];
let modelPropValue = cc[property];
if (modelPropValue) {
DDeiUtil$1.createDepLinkModel(cc, modelPropValue, type);
}
}
}
cc.updateLinkModels();
cc.refreshLinkModels();
layer2.addModel(cc, false);
cc.initRender();
shapes.push(cc);
}
}
});
if (notify) {
this.notifyChange();
}
}
return shapes;
}
return null;
}
/**
* 向当前画布添加连线
* @param controls 要添加的控件
* @param applyRatio 应用缩放
* @param notify 通知刷新
*/
addLines(controls2, calPoints = true, applyRatio = true, notify = true) {
let stage2 = this.ddInstance.stage;
let layer2 = stage2 == null ? void 0 : stage2.layers[stage2 == null ? void 0 : stage2.layerIndex];
let shapes = [];
if (layer2) {
let stageRatio1 = stage2.getStageRatio();
let stageRatio2 = !applyRatio ? 1 / stageRatio1 : 1;
let moveX = (-stage2.wpv.x + this.ddInstance.render.canvas.width / this.ddInstance.render.ratio / 2) / stageRatio1;
let moveY = (-stage2.wpv.y + this.ddInstance.render.canvas.height / this.ddInstance.render.ratio / 2) / stageRatio1;
controls2.forEach((control) => {
var _a3, _b2, _c2, _d2, _e2, _f;
if (control.startPoint && control.endPoint) {
let lineJson = DDeiUtil$1.getLineInitJSON(this.ddInstance, control.smodel, control.emodel);
let lineDefine = (_a3 = this.controls) == null ? void 0 : _a3.get((control == null ? void 0 : control.model) ? control.model : lineJson.modelCode ? lineJson.modelCode : lineJson.model ? lineJson.model : lineJson.id ? lineJson.id : lineJson.code);
let initJSON = clone(lineDefine);
initJSON.modelCode = initJSON.id;
initJSON.id = "line_" + ++stage2.idIdx;
if (!lineJson.type) {
initJSON.type = 2;
} else {
initJSON.type = lineJson.type;
}
if (initJSON.img) {
initJSON.fill = { type: 2, image: initJSON.img };
delete initJSON.img;
}
if (initJSON.define) {
for (let i2 in initJSON == null ? void 0 : initJSON.define) {
initJSON[i2] = initJSON.define[i2];
}
delete initJSON.define;
}
delete initJSON.attrDefineMap;
delete initJSON.filters;
delete initJSON.icon;
delete initJSON.groups;
delete initJSON.name;
delete initJSON.def;
delete initJSON.code;
delete initJSON.desc;
delete initJSON.attrs;
(_b2 = initJSON.composes) == null ? void 0 : _b2.forEach((comp) => {
if (comp) {
delete comp.attrs;
}
});
let sx, sy, ex, ey;
if (control.startPoint.offsetX || control.startPoint.offsetX == 0) {
sx = moveX + control.startPoint.offsetX * stageRatio2;
} else if (control.startPoint.x || control.startPoint.x == 0) {
sx = control.startPoint.x * stageRatio2;
}
if (control.startPoint.offsetY || control.startPoint.offsetY == 0) {
sy = moveY + control.startPoint.offsetY * stageRatio2;
} else if (control.startPoint.y || control.startPoint.y == 0) {
sy = control.startPoint.y * stageRatio2;
}
if (control.endPoint.offsetX || control.endPoint.offsetX == 0) {
ex = moveX + control.endPoint.offsetX * stageRatio2;
} else if (control.endPoint.x || control.endPoint.x == 0) {
ex = control.endPoint.x * stageRatio2;
}
if (control.endPoint.offsetY || control.endPoint.offsetY == 0) {
ey = moveY + control.endPoint.offsetY * stageRatio2;
} else if (control.endPoint.y || control.endPoint.y == 0) {
ey = control.endPoint.y * stageRatio2;
}
if (!calPoints && ((_c2 = control.pvs) == null ? void 0 : _c2.length) >= 2) {
initJSON.pvs = [];
control.pvs.forEach((pv) => {
let pvx, pvy;
if (pv.offsetX || pv.offsetX == 0) {
pvx = moveX + pv.offsetX * stageRatio2;
} else if (pv.x || pv.x == 0) {
pvx = pv.x * stageRatio2;
}
if (pv.offsetY || pv.offsetY == 0) {
pvy = moveY + pv.offsetY * stageRatio2;
} else if (pv.y || pv.y == 0) {
pvy = pv.y * stageRatio2;
}
initJSON.pvs.push(new Vector3(pvx - sx, pvy - sy, 1));
});
} else {
initJSON.pvs = [new Vector3(0, 0, 1), new Vector3(ex - sx, ey - sx, 1)];
}
(_d2 = control.spvs) == null ? void 0 : _d2.forEach((spv) => {
spv.x = (spv.x - sx) * stageRatio2;
spv.y = (spv.y - sy) * stageRatio2;
});
initJSON.cpv = initJSON.pvs[0];
let moveMatrix2 = new Matrix3(
1,
0,
sx,
0,
1,
sy,
0,
0,
1
);
let cc = DDeiLine.initByJSON(initJSON, { currentStage: stage2, currentLayer: layer2, currentContainer: layer2 });
for (let i2 in control) {
if (i2 != "startPoint" && i2 != "endPoint" && i2 != "pvs" && i2 != "spv" && i2 != "hpv" && i2 != "cpv" && i2 != "x" && i2 != "y" && i2 != "width" && i2 != "height" && (control[i2] || control[i2] == 0 || control[i2] == false)) {
cc[i2] = control[i2];
}
}
cc.transVectors(moveMatrix2);
let smodel, emodel;
if (control.smodel) {
smodel = this.getControlById(control.smodel.id);
let id = "_" + DDeiUtil$1.getUniqueCode();
smodel.exPvs[id] = new Vector3(sx, sy, 1);
smodel.exPvs[id].rate = control.smodel.rate;
smodel.exPvs[id].sita = control.smodel.sita;
smodel.exPvs[id].index = control.smodel.index;
smodel.exPvs[id].id = id;
let link2 = new DDeiLink({
sm: smodel,
dm: cc,
smpath: "exPvs." + id,
dmpath: "startPoint",
stage: stage2
});
stage2.addLink(link2);
smodel.transVectors(new Matrix3());
}
if (control.emodel) {
emodel = this.getControlById(control.emodel.id);
let id = "_" + DDeiUtil$1.getUniqueCode();
emodel.exPvs[id] = new Vector3(ex, ey, 1);
emodel.exPvs[id].rate = control.emodel.rate;
emodel.exPvs[id].sita = control.emodel.sita;
emodel.exPvs[id].index = control.emodel.index;
emodel.exPvs[id].id = id;
let link2 = new DDeiLink({
sm: emodel,
dm: cc,
smpath: "exPvs." + id,
dmpath: "endPoint",
stage: stage2
});
stage2.addLink(link2);
emodel.transVectors(new Matrix3());
}
if (!control.isShadowControl) {
cc.refreshLinkModels();
layer2.addModel(cc, false);
cc.initRender();
} else {
layer2.shadowControls.push(cc);
cc.initRender();
}
if (calPoints) {
smodel == null ? void 0 : smodel.updateLinkModels();
emodel == null ? void 0 : emodel.updateLinkModels();
}
(_e2 = smodel == null ? void 0 : smodel.render) == null ? void 0 : _e2.enableRefreshShape();
(_f = emodel == null ? void 0 : emodel.render) == null ? void 0 : _f.enableRefreshShape();
shapes.push(cc);
}
});
if (notify) {
this.notifyChange();
}
}
return shapes;
}
notifyChange() {
this.bus.push(DDeiEnumBusCommandType.UpdatePaperArea);
this.bus.push(DDeiEnumBusCommandType.NodifyChange);
this.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.bus.push(DDeiEnumBusCommandType.AddHistroy);
this.changeState(DDeiEditorState.DESIGNING);
this.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts);
this.bus.push(DDeiEnumBusCommandType.StageChangeSelectModels);
this.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
this.bus.executeAll();
}
/**
* 移除当前画布控件
*/
removeControls(ids, notify = true) {
var _a3;
(_a3 = this.ddInstance.stage) == null ? void 0 : _a3.removeModelById(ids);
if (notify) {
this.notifyChange();
}
}
/**
* 清除当前画布所有控件
*/
clearModels(destroy = false, notify = true) {
var _a3;
(_a3 = this.ddInstance.stage) == null ? void 0 : _a3.clearModels(destroy);
if (notify) {
this.notifyChange();
}
}
/**
* 根据ID获取控件
*/
getControlById(id) {
var _a3;
return (_a3 = this.ddInstance.stage) == null ? void 0 : _a3.getModelById(id, true);
}
/**
* 设置是否可以编辑
*/
setEditable(editable) {
if (!editable) {
this.ddInstance["AC_DESIGN_CREATE"] = false;
this.ddInstance["AC_DESIGN_EDIT"] = false;
this.ddInstance["AC_DESIGN_DRAG"] = false;
this.ddInstance["AC_DESIGN_LINK"] = false;
this.ddInstance["AC_DESIGN_DEL"] = false;
this.ddInstance["AC_DESIGN_ROTATE"] = false;
this.ddInstance["AC_DESIGN_SCALE"] = false;
this.ddInstance["AC_DESIGN_COMPOSE"] = false;
} else {
this.ddInstance["AC_DESIGN_CREATE"] = true;
this.ddInstance["AC_DESIGN_EDIT"] = true;
this.ddInstance["AC_DESIGN_DRAG"] = true;
this.ddInstance["AC_DESIGN_SELECT"] = true;
this.ddInstance["AC_DESIGN_LINK"] = true;
this.ddInstance["AC_DESIGN_DEL"] = true;
this.ddInstance["AC_DESIGN_ROTATE"] = true;
this.ddInstance["AC_DESIGN_SCALE"] = true;
this.ddInstance["AC_DESIGN_COMPOSE"] = true;
}
}
setAccessInfo(config2) {
if (config2) {
for (let i2 in config2) {
if (config2[i2] == true || config2[i2] == false) {
this.ddInstance["AC_" + this.MODE_NAME + "_" + i2] = config2[i2];
}
}
}
}
/**
* 将模型转换为JSON
*/
toJSON() {
let jsonArray = new Array();
this.files.forEach((file) => {
jsonArray.push(file.toJSON());
});
return jsonArray;
}
/**
* 根据属性搜索控件
* @param keywords 关键字/正则表达式
* @param attr 搜索的属性
* @param isReg 是否正则表达式
* @param area 搜索范围,1本页/2本文档/3所有打开文件
* @param matchCase 区分大小写
* @param matchAll 全字匹配
*/
searchModels(keywords, attr, isReg = false, area = 1, matchCase = false, matchAll = false) {
let resultArray = new Array();
if (keywords && attr) {
switch (area) {
case 1: {
for (let i2 = 0; i2 < this.files.length; i2++) {
for (let j2 = 0; j2 < this.files[i2].sheets.length; j2++) {
if (this.files[i2].sheets[j2].stage == this.ddInstance.stage) {
let rs = this.ddInstance.stage.searchModels(keywords, attr, isReg, matchCase, matchAll);
rs == null ? void 0 : rs.forEach((r) => {
r.fileIndex = i2;
r.sheetIndex = j2;
resultArray.push(r);
});
return resultArray;
}
}
}
}
case 2: {
let rs = this.files[this.currentFileIndex].searchModels(keywords, attr, isReg, matchCase, matchAll);
rs == null ? void 0 : rs.forEach((r) => {
r.fileIndex = this.currentFileIndex;
resultArray.push(r);
});
}
case 3:
{
for (let i2 = 0; i2 < this.files.length; i2++) {
let rs = this.files[i2].searchModels(keywords, attr, isReg, matchCase, matchAll);
rs == null ? void 0 : rs.forEach((r) => {
r.fileIndex = i2;
resultArray.push(r);
});
}
}
break;
}
}
return resultArray;
}
/**
* 将舞台可视区域的中心点移动到控件的外接矩形中心
* @param modelIds
*/
centerModels(stage2, ...modelIds) {
if (!stage2) {
stage2 = this.ddInstance.stage;
}
if ((modelIds == null ? void 0 : modelIds.length) > 0) {
let models = new Array();
for (let i2 = 0; i2 < modelIds.length; i2++) {
if (modelIds[i2]) {
let model = stage2.getModelById(modelIds[i2], true);
if (model) {
models.push(model);
}
}
}
if (models.length > 0) {
let stageRatio2 = stage2.getStageRatio();
let outRect = DDeiAbstractShape.getOutRectByPV(models, stageRatio2);
stage2.wpv.x = -(outRect.x + outRect.width / 2) + stage2.ddInstance.render.canvas.width / stage2.ddInstance.render.ratio / 2;
stage2.wpv.y = -(outRect.y + outRect.height / 2) + stage2.ddInstance.render.canvas.height / stage2.ddInstance.render.ratio / 2;
}
}
}
/**
* 切换文件
* @param file
*/
changeFile(fileIndex, sheetIndex = -1) {
let ddInstance = this == null ? void 0 : this.ddInstance;
let file = null;
if (fileIndex || fileIndex == 0) {
file = this.files[fileIndex];
}
if (file) {
this.files.forEach((item) => {
item.active = DDeiActiveType.NONE;
});
file.active = DDeiActiveType.ACTIVE;
this.currentFileIndex = fileIndex;
let sheets = file == null ? void 0 : file.sheets;
if (file && sheets && ddInstance) {
if (sheetIndex >= 0) {
file.changeSheet(sheetIndex);
}
ddInstance.stage.destroyRender();
let stage2 = sheets[file.currentSheetIndex].stage;
stage2.ddInstance = ddInstance;
ddInstance.stage = stage2;
stage2.initRender();
}
}
}
/**
* 替换模型数据
* @param models 被替换的模型
* @param attr 属性
* @param sIdx 开始下标
* @param eIdx 结束下标
* @param data 数据
*/
replaceModelsData(models, attr, sIdx = -1, eIdx = -1, data = "", notify = true) {
if ((models == null ? void 0 : models.length) > 0 && attr && sIdx != -1 && eIdx != -1 && eIdx >= sIdx) {
models.forEach((model) => {
let oldValue = model[attr];
if (oldValue && typeof oldValue == "string") {
let sStr = oldValue.substring(0, sIdx);
let eStr = oldValue.substring(eIdx, oldValue.length);
let newValue = sStr + data + eStr;
model[attr] = newValue;
}
});
}
if (notify) {
this.notifyChange();
}
}
/**
* 返回画布图片
* @models 选中控件模型,如果不传入则返回整个画布
*/
toImageDataUrl(models = null) {
return this.ddInstance.stage.toImageDataUrl(models);
}
};
__publicField2(_DDeiEditor, "INSTANCE_POOL", /* @__PURE__ */ new Map());
__publicField2(_DDeiEditor, "HISTROY_LEVEL", "file");
__publicField2(_DDeiEditor, "ACTIVE_INSTANCE", null);
let DDeiEditor = _DDeiEditor;
const DDeiEditor$1 = DDeiEditor;
const _DDeiEditorUtil = class _DDeiEditorUtil2 {
/**
* 读取最近工具栏
*/
static readRecentlyToolGroups() {
let groups = localStorage.getItem("ddei-recently-tool-groups");
if (groups) {
try {
_DDeiEditorUtil2.recentlyToolGroups = JSON.parse(groups);
} catch (e) {
}
}
}
/**
* 写入最近工具栏
*/
static whiteRecentlyToolGroups(groups) {
_DDeiEditorUtil2.recentlyToolGroups = [];
groups.forEach((group2) => {
if (group2.display) {
_DDeiEditorUtil2.recentlyToolGroups.push({ id: group2.id, expand: group2.expand });
}
});
localStorage.setItem("ddei-recently-tool-groups", JSON.stringify(_DDeiEditorUtil2.recentlyToolGroups));
}
/**
* 获取线的初始化JSON定义
*/
static getLineInitJSON(ddInstance, smodel, emodel) {
if (!_DDeiEditorUtil2.lineInitJSON) {
_DDeiEditorUtil2.lineInitJSON = {
modelCode: "100401"
};
}
return _DDeiEditorUtil2.lineInitJSON;
}
/**
* 获取控件的初始化JSON定义
*/
static getModelInitJSON(ddInstance, beginModel, models) {
return models;
}
/**
* 获取业务数据
*/
static getBusiData(ddInstance) {
let editor = _DDeiEditorUtil2.getEditorInsByDDei(ddInstance);
if (editor) {
let file = editor.files[editor.currentFileIndex];
return file == null ? void 0 : file.busiData;
}
}
/**
* 获取快捷编辑文本框
*/
static getEditorText() {
let editor = DDeiEditor$1.ACTIVE_INSTANCE;
if (editor) {
if (!editor.quickEditorInput) {
let inputId = editor.id + "_quickeditor";
let inputEle = document.getElementById(inputId);
if (!inputEle) {
inputEle = document.createElement("textarea");
inputEle.setAttribute("id", inputId);
inputEle.setAttribute("style", "width:100px;filter: opacity(0);user-select: none;pointer-events: none;border:none;resize:none;padding:0;z-index:9999;position:fixed;left:0;top:0;display:none;outline:none;");
let editorEle = document.getElementById(editor.id);
editorEle.appendChild(inputEle);
editor.quickEditorInput = inputEle;
inputEle.enterValue = function() {
var _a3, _b2, _c2;
let editor2 = DDeiEditor$1.ACTIVE_INSTANCE;
let ddInstance = editor2 == null ? void 0 : editor2.ddInstance;
delete ddInstance.stage.brushDataText;
if (editor2.quickEditorModel) {
editor2.quickEditorModel.sptStyle = ddInstance.stage.render.editorShadowControl.sptStyle;
if ((_a3 = ddInstance.stage.render.editorShadowControl) == null ? void 0 : _a3.isShadowControl) {
ddInstance.stage.render.editorShadowControl.destroyed();
}
ddInstance.stage.render.editorShadowControl = null;
if ((_b2 = editor2.quickEditorModel) == null ? void 0 : _b2.depModel) {
let depModel = editor2.quickEditorModel.depModel;
setTimeout(() => {
var _a22;
depModel.refreshLinkModels();
editor2.bus.push(DDeiEnumBusCommandType.RefreshShape);
editor2.bus.push(DDeiEnumBusCommandType.AddHistroy);
(_a22 = editor2.bus) == null ? void 0 : _a22.executeAll();
}, 50);
editor2.bus.push(DDeiEnumBusCommandType.ModelChangeValue, { models: [editor2.quickEditorModel], paths: ["text"], value: inputEle.value }, null, true);
editor2.bus.push(DDeiEnumBusCommandType.NodifyChange);
editor2.bus.push(DDeiEnumBusCommandType.RefreshShape);
} else {
editor2.bus.push(DDeiEnumBusCommandType.ModelChangeValue, { models: [editor2.quickEditorModel], paths: ["text"], value: inputEle.value }, null, true);
editor2.bus.push(DDeiEnumBusCommandType.NodifyChange);
editor2.bus.push(DDeiEnumBusCommandType.RefreshShape);
editor2.bus.push(DDeiEnumBusCommandType.AddHistroy);
}
}
inputEle.value = "";
editor2.changeState(DDeiEditorState.DESIGNING);
editor2.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
editor2.bus.push(DDeiEnumBusCommandType.ClearTemplateVars);
editor2.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, { parts: ["topmenu"] });
editor2.bus.push(DDeiEnumBusCommandType.StageChangeSelectModels);
(_c2 = editor2.bus) == null ? void 0 : _c2.executeAll();
};
inputEle.onkeyup = function(evt) {
let editor2 = DDeiEditor$1.ACTIVE_INSTANCE;
editor2.bus.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
editor2.bus.push(DDeiEnumBusCommandType.RefreshShape);
editor2.bus.executeAll();
};
inputEle.addEventListener("compositionend", function() {
let editor2 = DDeiEditor$1.ACTIVE_INSTANCE;
let ddInstance = editor2 == null ? void 0 : editor2.ddInstance;
if (ddInstance.stage.render.editorShadowControl) {
_DDeiEditorUtil2.quickEditorToControl();
}
});
inputEle.addEventListener("input", () => {
let editor2 = DDeiEditor$1.ACTIVE_INSTANCE;
let ddInstance = editor2 == null ? void 0 : editor2.ddInstance;
if (ddInstance.stage.render.editorShadowControl) {
_DDeiEditorUtil2.quickEditorToControl();
}
});
}
}
return editor.quickEditorInput;
}
}
/**
* 获取样式属性值
* @param name 属性名称
* @param ddInstance ddei实例
*/
static getStyleValue(name, ddInstance) {
let editor = _DDeiEditorUtil2.getEditorInsByDDei(ddInstance);
let element = document.getElementById(editor.containerid);
let styles2 = getComputedStyle(element);
let cssVariable = styles2.getPropertyValue("--" + name);
return cssVariable;
}
static getEditorId(ddInstance) {
let editor = _DDeiEditorUtil2.getEditorInsByDDei(ddInstance);
return editor.id;
}
static getEditorInsByDDei(ddInstance) {
let editor;
if (ddInstance) {
DDeiEditor$1.INSTANCE_POOL.forEach((editorIns) => {
var _a3;
if (editorIns.ddInstance == ddInstance || ((_a3 = editorIns.ddInstance) == null ? void 0 : _a3.id) == (ddInstance == null ? void 0 : ddInstance.id)) {
editor = editorIns;
}
});
}
if (!editor) {
editor = DDeiEditor$1.ACTIVE_INSTANCE;
}
return editor;
}
static notifyChange(ddInstance) {
let editor = _DDeiEditorUtil2.getEditorInsByDDei(ddInstance);
editor == null ? void 0 : editor.notifyChange();
}
/**
* 判断element是否为editor的子控件
* @param element dom元素
* @param editor 编辑器
*/
static isEditorSubElement(element, editor) {
if (!editor || !element) {
return false;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return false;
}
if (element == editor.htmlElement) {
return true;
} else {
return _DDeiEditorUtil2.isEditorSubElement(element.parentElement, editor);
}
}
//钩子函数,判断当前实例是否可以在后台激活,允许后台激活的实例,在当前实例为非ACTIVE_INSTANCE时,依然能够执行部分后台操作
static isBackActive(ddInstance) {
if (!ddInstance) {
return false;
} else {
let editor = _DDeiEditorUtil2.getEditorInsByDDei(ddInstance);
if (!editor) {
return false;
} else {
return DDeiEditor$1.ACTIVE_INSTANCE && editor.id == DDeiEditor$1.ACTIVE_INSTANCE.id || editor.GLOBAL_ALLOW_BACK_ACTIVE;
}
}
}
/**
* 设置编辑器值到控件
*/
static quickEditorToControl(inputEle) {
let editorInput = _DDeiEditorUtil2.getEditorText();
if (!inputEle) {
inputEle = editorInput;
}
if (inputEle != editorInput) {
editorInput.value = inputEle.value;
editorInput.selectionStart = inputEle.selectionStart;
editorInput.selectionEnd = inputEle.selectionEnd;
}
let editor = DDeiEditor$1.ACTIVE_INSTANCE;
let ddInstance = editor == null ? void 0 : editor.ddInstance;
let oldStr = ddInstance.stage.render.editorShadowControl.text;
let newStr = inputEle.value;
let curstrIdx = Math.min(ddInstance.stage.render.editorShadowControl.tempCursorStart, inputEle.selectionStart);
let beforeStr = oldStr.substring(0, curstrIdx);
let beforeSPT = {};
for (let i2 = 0; i2 < curstrIdx; i2++) {
if (ddInstance.stage.render.editorShadowControl.sptStyle[i2]) {
beforeSPT[i2] = ddInstance.stage.render.editorShadowControl.sptStyle[i2];
}
}
let sptIndex = curstrIdx;
let afterStr = oldStr.substring(ddInstance.stage.render.editorShadowControl.tempCursorEnd);
let afterSPT = {};
for (let i2 = ddInstance.stage.render.editorShadowControl.tempCursorEnd; i2 < oldStr.length; i2++) {
if (ddInstance.stage.render.editorShadowControl.sptStyle[i2]) {
afterSPT[i2] = ddInstance.stage.render.editorShadowControl.sptStyle[i2];
}
}
let bIndex = newStr.indexOf(beforeStr) + beforeStr.length;
let appendStr = null;
if (afterStr) {
appendStr = newStr.substring(bIndex, newStr.lastIndexOf(afterStr));
} else {
appendStr = newStr.substring(bIndex);
}
let oriStyle = bIndex == 0 ? afterSPT[bIndex] : beforeSPT[bIndex - 1];
if (oriStyle && appendStr) {
let cloneSPTStr = JSON.stringify(oriStyle);
for (let i2 = 0; i2 < appendStr.length; i2++, sptIndex++) {
beforeSPT[sptIndex] = JSON.parse(cloneSPTStr);
}
}
let appendStrLen = newStr.length - oldStr.length;
for (let i2 in afterSPT) {
beforeSPT[parseInt(i2) + appendStrLen] = afterSPT[i2];
}
ddInstance.stage.render.editorShadowControl.sptStyle = beforeSPT;
ddInstance.stage.render.editorShadowControl.tempCursorStart = inputEle.selectionStart;
ddInstance.stage.render.editorShadowControl.tempCursorEnd = inputEle.selectionEnd;
ddInstance.stage.render.editorShadowControl.text = inputEle.value;
ddInstance.stage.render.editorShadowControl.render.setCachedValue("text", inputEle.value);
editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
editor.bus.executeAll();
}
/**
* 获取子元素定义的json信息
*/
static getSubControlJSON(modelCode, ddInstance) {
var _a3, _b2, _c2;
let editor = _DDeiEditorUtil2.getEditorInsByDDei(ddInstance);
let controlDefine = (_a3 = editor.controls) == null ? void 0 : _a3.get(modelCode);
if (controlDefine.subcontrol) {
let subControlDefine = (_b2 = editor.controls) == null ? void 0 : _b2.get(controlDefine.subcontrol);
let configAtrs = _DDeiEditorUtil2.getAttrValueByConfig(subControlDefine, [
"layout"
]);
if (subControlDefine) {
let subControlJSON = {
modelCode: subControlDefine.id,
layout: (_c2 = configAtrs.get("layout")) == null ? void 0 : _c2.data
};
return subControlJSON;
}
}
}
/**
* 获取菜单控件ID
* @returns 控件ID
*/
static getMenuControlId(editor) {
return editor.id + "_menu_dialog";
}
/**
* 显示菜单
*/
static showContextMenu(control, ddInstance, evt) {
let editor = _DDeiEditorUtil2.getEditorInsByDDei(ddInstance);
let menuJSON = DDeiUtil$1.getMenuConfig(control, editor);
if ((menuJSON == null ? void 0 : menuJSON.length) > 0 && (editor == null ? void 0 : editor.setCurrentMenu)) {
let stage2 = ddInstance.stage;
if (stage2) {
stage2.render.currentMenuShape = control;
editor.setCurrentMenu(menuJSON);
let menuDialogId = DDeiUtil$1.getMenuControlId(editor);
let menuEle = document.getElementById(menuDialogId);
let elePos = DDeiUtil$1.getDomAbsPosition(evt.currentTarget, editor);
if (menuEle) {
if (elePos.left + 200 > document.body.clientWidth) {
menuEle.style.left = document.body.clientWidth - 200 + "px";
} else {
menuEle.style.left = elePos.left + "px";
}
if (elePos.top + menuJSON.length * 40 > document.body.clientHeight) {
menuEle.style.top = document.body.clientHeight - menuJSON.length * 40 + "px";
} else {
menuEle.style.top = elePos.top + "px";
}
setTimeout(() => {
menuEle.style.display = "block";
}, 10);
}
}
}
}
/**
* 获取菜单配置
*/
static getMenuConfig(model, editor) {
if (editor == null ? void 0 : editor.menuMapping) {
let menus2 = editor == null ? void 0 : editor.menuMapping[model == null ? void 0 : model.modelType];
if ((menus2 == null ? void 0 : menus2.length) > 0) {
return menus2;
}
}
}
/**
* 从配置定义中获取属性值,优先从code中获取,其次从mapping获取
* @param configModel 配置模型,如果包含了attrDefineMap等数据,则直接获取数据,如果只包含id则通过id取原始数据
* @param paths 属性路径,支持传入多个
* @return 由构成的属性的实际路径和配置中对应的值组成的Map
*/
static getAttrValueByConfig(configModel, paths, editor) {
var _a3, _b2;
if (!editor) {
if (configModel.modelType == "DDeiStage") {
editor = _DDeiEditorUtil2.getEditorInsByDDei(configModel.ddInstance);
} else {
editor = _DDeiEditorUtil2.getEditorInsByDDei((_a3 = configModel.stage) == null ? void 0 : _a3.ddInstance);
}
}
let returnDatas = /* @__PURE__ */ new Map();
if (configModel && paths) {
let searchPaths = null;
if (typeof paths == "string") {
searchPaths = paths.split(",");
} else {
searchPaths = paths;
}
let searchMap = null;
if (configModel.attrDefineMap && configModel.attrDefineMap.size > 0) {
searchMap = configModel.attrDefineMap;
} else if (configModel.id || configModel.modelCode) {
let id = configModel.modelCode ? configModel.modelCode : configModel.id;
if (id.indexOf("_shadow") != -1) {
id = id.substring(id, id.lastIndexOf("_shadow"));
}
let control = (_b2 = editor.controls) == null ? void 0 : _b2.get(id);
if (control) {
searchMap = control.attrDefineMap;
}
}
if (searchMap) {
let noCodeMatchPaths = [];
searchPaths.forEach((searchPath) => {
if (searchMap.has(searchPath)) {
let attrDefine = searchMap.get(searchPath);
if (!attrDefine.mapping || attrDefine.mapping.length == 0) {
returnDatas.set(searchPath, { "overwrite": attrDefine.overwrite ? attrDefine.overwrite : false, "data": attrDefine.getParser().getDefaultValue() });
} else {
noCodeMatchPaths.push(searchPath);
}
} else {
noCodeMatchPaths.push(searchPath);
}
});
let hasMappingAttrs = Array.from(searchMap.values());
for (let i2 = 0; i2 < noCodeMatchPaths.length; i2++) {
let searchPath = noCodeMatchPaths[i2];
for (let j2 = 0; j2 < hasMappingAttrs.length; j2++) {
let attrDefine = hasMappingAttrs[j2];
if (attrDefine.mapping && attrDefine.mapping.indexOf(searchPath) != -1) {
returnDatas.set(searchPath, { "overwrite": attrDefine.overwrite ? attrDefine.overwrite : false, "data": attrDefine.getParser().getDefaultValue() });
break;
}
}
}
}
}
return returnDatas;
}
/**
* 返回控件原始定义
* @param modelCode model或id
*/
static getControlDefine(configModel) {
var _a3, _b2;
let editor = _DDeiEditorUtil2.getEditorInsByDDei((_a3 = configModel.stage) == null ? void 0 : _a3.ddInstance);
let id = configModel.modelCode ? configModel.modelCode : configModel.id;
return (_b2 = editor.controls) == null ? void 0 : _b2.get(id);
}
/**
* 获取数据源数据
*/
static getDataSource(editor, attrDefine, searchText = null) {
if (attrDefine.dataSource) {
let dsDefine = attrDefine.dataSource;
let dataSource = null;
if (Array.isArray(dsDefine)) {
dataSource = dsDefine;
} else {
let type = dsDefine.type;
if (!type || type == "static") {
dataSource = dsDefine.data;
} else if (type == "config") {
dataSource = [];
let configData = dsDefine.data;
let data = editor[configData];
if (!data) {
data = DDeiConfig$1[configData];
}
if (data) {
let textKey = dsDefine.text;
let valueKey = dsDefine.value;
let boldKey = dsDefine.bold;
let descKey = dsDefine.desc;
let underlineKey = dsDefine.underline;
let disabledKey = dsDefine.disabled;
let deletedKey = dsDefine.deleted;
let searchTextKey = dsDefine.searchText;
let fontFamilyKey = dsDefine.fontFamily;
data.forEach((item) => {
let text2 = item[textKey];
let value = item[valueKey];
let bold = item[boldKey];
let desc = item[descKey];
let underline = item[underlineKey];
let disabled = item[disabledKey];
let deleted = item[deletedKey];
let searchText2 = item[searchTextKey];
let fontFamily = item[fontFamilyKey];
let rowData = {
"text": text2,
"searchText": searchText2,
"value": value,
"bold": bold,
"desc": desc,
"underline": underline,
"disabled": disabled,
"deleted": deleted,
"fontFamily": fontFamily
};
dataSource.push(rowData);
});
dsDefine.type = "static";
dsDefine.data = dataSource;
}
}
}
let returnDatas = [];
if (dataSource) {
dataSource.forEach((item) => {
item.text = editor.i18n(item.text);
});
dataSource.forEach((item) => {
if (item.img) {
if (_DDeiEditorUtil2.ICONS && _DDeiEditorUtil2.ICONS[item.img]) {
item.img = _DDeiEditorUtil2.ICONS[item.img].default;
}
}
if (searchText) {
if (item.text.indexOf(searchText) != -1 || item.value.indexOf(searchText) != -1 || item.searchText && item.searchText.indexOf(searchText) != -1) {
returnDatas.push(item);
}
} else {
returnDatas.push(item);
}
});
}
return returnDatas;
}
return [];
}
/**
* 获取配置属性值
* @param key key
*/
static getConfigValue(key, editor) {
if (editor && (editor[key] || editor[key] == false || editor[key] == 0)) {
return editor[key];
} else {
return DDeiEditor$1[key];
}
}
/**
* 打开弹出框
* @param id 弹出框ID
* @param data 数据以及回调函数等选项
* @param pos 位置信息
* @param el 事件的元素
*/
static showDialog(editor, id, data, pos, el, isPop = false, keepState = false) {
var _a3, _b2;
if (!isPop && !editor.tempDialogData) {
editor.tempDialogData = {};
} else if (isPop && !editor.tempPopData) {
editor.tempPopData = {};
}
if (data.group) {
let loopData;
if (isPop) {
loopData = editor.tempPopData;
} else {
loopData = editor.tempDialogData;
}
for (let oid in loopData) {
if (oid != id) {
let otherDialogData = loopData[oid];
if (otherDialogData && otherDialogData.group == data.group) {
_DDeiEditorUtil2.closeDialog(editor, oid);
}
}
}
}
if (data) {
data.keepState = keepState;
}
if (isPop) {
editor.tempPopData[id] = data;
} else {
editor.tempDialogData[id] = data;
if (!keepState) {
editor.changeState(DDeiEditorState.PROPERTY_EDITING);
}
}
(_b2 = (_a3 = editor == null ? void 0 : editor.dialogs[id]) == null ? void 0 : _a3.viewer) == null ? void 0 : _b2.forceRefreshView();
setTimeout(() => {
if (!(pos == null ? void 0 : pos.hiddenMask)) {
let backEle = document.getElementById(editor.id + "_dialog_background_div");
if (data.background) {
backEle.style.background = data.background;
backEle.style.display = "block";
if (data.opacity) {
backEle.style.opacity = data.opacity;
}
}
if (data.event == -1) {
backEle.style.pointerEvents = "auto";
} else {
backEle.style.pointerEvents = "";
}
}
let dialog = document.getElementById(editor.id + "_" + id);
if (dialog) {
dialog.style.display = "block";
let msgEle = dialog.getElementsByClassName("msg")[0];
if (msgEle) {
msgEle.innerHTML = "";
if (data.msg) {
msgEle.innerHTML = data.msg;
}
}
if (pos == null ? void 0 : pos.type) {
let left, top;
switch (pos.type) {
case 99:
{
left = pos.left;
top = pos.top;
}
break;
case 2:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) - scrollData.left;
top = absPos.top - (dialog == null ? void 0 : dialog.clientHeight) + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 3:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left - (dialog.clientWidth / 2 - el.clientWidth / 2) + (pos.dx ? pos.dx : 0) - scrollData.left;
top = absPos.top - (dialog == null ? void 0 : dialog.clientHeight) + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 4:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) - scrollData.left;
top = absPos.top + el.clientHeight + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 5:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left - (dialog.clientWidth / 2 - el.clientWidth / 2) + (pos.dx ? pos.dx : 0) - scrollData.left;
top = absPos.top + el.clientHeight + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 6:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) - dialog.clientWidth - scrollData.left;
top = absPos.top + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 7:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) - dialog.clientWidth - scrollData.left;
top = absPos.top - (dialog.clientHeight - el.clientHeight) / 2 + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 8:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) + el.clientWidth - scrollData.left;
top = absPos.top + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 9:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) + el.clientWidth - scrollData.left;
top = absPos.top - (dialog.clientHeight - el.clientHeight) / 2 + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
}
if (!pos || pos.ignoreOutSide != 1) {
if (left + (dialog == null ? void 0 : dialog.clientWidth) > document.body.scrollWidth) {
left = document.body.scrollWidth - (dialog == null ? void 0 : dialog.clientWidth) - 10;
}
if (top + (dialog == null ? void 0 : dialog.clientHeight) > document.body.scrollHeight) {
top = document.body.scrollHeight - (dialog == null ? void 0 : dialog.clientHeight) - 10;
}
}
dialog.style.left = left + "px";
dialog.style.top = top + "px";
}
}
}, 50);
}
/**
* 初始化弹出框,但不显示
* @param id 弹出框ID
* @param data 数据以及回调函数等选项
* @param el 事件的元素
*/
static initDialog(editor, id, data, isPop = false, keepState = false) {
var _a3, _b2;
if (!isPop && !editor.tempDialogData) {
editor.tempDialogData = {};
} else if (isPop && !editor.tempPopData) {
editor.tempPopData = {};
}
if (data.group) {
let loopData;
if (isPop) {
loopData = editor.tempPopData;
} else {
loopData = editor.tempDialogData;
}
for (let oid in loopData) {
if (oid != id) {
let otherDialogData = loopData[oid];
if (otherDialogData && otherDialogData.group == data.group) {
_DDeiEditorUtil2.closeDialog(editor, oid);
}
}
}
}
if (data) {
data.keepState = keepState;
}
if (isPop) {
editor.tempPopData[id] = data;
} else {
editor.tempDialogData[id] = data;
if (!keepState) {
editor.changeState(DDeiEditorState.PROPERTY_EDITING);
}
}
(_b2 = (_a3 = editor == null ? void 0 : editor.dialogs[id]) == null ? void 0 : _a3.viewer) == null ? void 0 : _b2.forceRefreshView();
}
/**
* 显示弹出框
* @param id 弹出框ID
* @param pos 位置信息
* @param el 事件的元素
*/
static displayDialog(editor, id, data, pos, el) {
if (!(pos == null ? void 0 : pos.hiddenMask)) {
let backEle = document.getElementById(editor.id + "_dialog_background_div");
if (data.background) {
backEle.style.background = data.background;
backEle.style.display = "block";
if (data.opacity) {
backEle.style.opacity = data.opacity;
}
}
if (data.event == -1) {
backEle.style.pointerEvents = "auto";
} else {
backEle.style.pointerEvents = "";
}
}
let dialog = document.getElementById(editor.id + "_" + id);
if (dialog) {
dialog.style.display = "block";
if (pos == null ? void 0 : pos.type) {
let left, top;
switch (pos.type) {
case 99:
{
left = pos.left;
top = pos.top;
}
break;
case 2:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) - scrollData.left;
top = absPos.top - (dialog == null ? void 0 : dialog.clientHeight) + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 3:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left - (dialog.clientWidth / 2 - el.clientWidth / 2) + (pos.dx ? pos.dx : 0) - scrollData.left;
top = absPos.top - (dialog == null ? void 0 : dialog.clientHeight) + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 4:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) - scrollData.left;
top = absPos.top + el.clientHeight + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 5:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left - (dialog.clientWidth / 2 - el.clientWidth / 2) + (pos.dx ? pos.dx : 0) - scrollData.left;
top = absPos.top + el.clientHeight + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 6:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) - dialog.clientWidth - scrollData.left;
top = absPos.top + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 7:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) - dialog.clientWidth - scrollData.left;
top = absPos.top - (dialog.clientHeight - el.clientHeight) / 2 + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 8:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) + el.clientWidth - scrollData.left;
top = absPos.top + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
case 9:
{
let absPos = DDeiUtil$1.getDomAbsPosition(el, editor);
let scrollData = DDeiUtil$1.getDomScroll(el, editor);
left = absPos.left + (pos.dx ? pos.dx : 0) + el.clientWidth - scrollData.left;
top = absPos.top - (dialog.clientHeight - el.clientHeight) / 2 + (pos.dy ? pos.dy : 0) - scrollData.top;
}
break;
}
if (!pos || pos.ignoreOutSide != 1) {
if (left + (dialog == null ? void 0 : dialog.clientWidth) > document.body.scrollWidth) {
left = document.body.scrollWidth - (dialog == null ? void 0 : dialog.clientWidth) - 10;
}
if (top + (dialog == null ? void 0 : dialog.clientHeight) > document.body.scrollHeight) {
top = document.body.scrollHeight - (dialog == null ? void 0 : dialog.clientHeight) - 10;
}
}
dialog.style.left = left + "px";
dialog.style.top = top + "px";
}
}
}
/**
* 隐藏弹出框
* @param id 弹出框ID
*/
static hiddenDialog(editor, id) {
let backEle = document.getElementById(editor.id + "_dialog_background_div");
if (backEle) {
backEle.style.display = "none";
}
let dialogEle = document.getElementById(editor.id + "_" + id);
if (dialogEle) {
dialogEle.style.display = "none";
}
}
/**
* 关闭弹出框
* @param id
*/
static closeDialog(editor, id, isPop = false) {
let dialog = document.getElementById(editor.id + "_" + id);
if (dialog) {
dialog.style.display = "none";
}
let dialogData;
if (!isPop && editor.tempDialogData) {
dialogData = editor.tempDialogData[id];
editor.tempDialogData[id] = null;
} else if (isPop && editor.tempPopData) {
dialogData = editor.tempPopData[id];
editor.tempPopData[id] = null;
}
let backEle = document.getElementById(editor.id + "_dialog_background_div");
if (backEle) {
backEle.style.background = "none";
backEle.style.display = "none";
}
if (!dialogData || !dialogData.keepState) {
editor.changeState(DDeiEditorState.DESIGNING);
}
}
static closeDialogs(editor, groups, isPop = false) {
if (isPop) {
for (let oid in editor.tempPopData) {
let otherDialogData = editor.tempPopData[oid];
if (otherDialogData && (groups && groups.indexOf(otherDialogData.group) != -1 || !groups || groups.length == 0)) {
_DDeiEditorUtil2.closeDialog(editor, oid, isPop);
}
}
} else {
for (let oid in editor.tempDialogData) {
let otherDialogData = editor.tempDialogData[oid];
if (otherDialogData && (groups && groups.indexOf(otherDialogData.group) != -1 || !groups || groups.length == 0)) {
_DDeiEditorUtil2.closeDialog(editor, oid, isPop);
}
}
}
}
/**
* 打开或关闭弹出框
* @param id
* @param data
* @param pos
* @param el
*/
static showOrCloseDialog(editor, id, data, pos, el, isPop = false, keepState = false) {
if (!isPop && editor.tempDialogData && editor.tempDialogData[id]) {
_DDeiEditorUtil2.closeDialog(editor, id, isPop);
} else if (isPop && editor.tempPopData && editor.tempPopData[id]) {
_DDeiEditorUtil2.closeDialog(editor, id, isPop);
} else {
_DDeiEditorUtil2.showDialog(editor, id, data, pos, el, isPop, keepState);
}
}
/**
* 获取控件的小图标
*/
static getControlIcons(editor) {
return new Promise((resolve, reject) => {
if (editor.icons && JSON.stringify(editor.icons) != "{}") {
resolve(editor.icons);
} else {
if (editor.ddInstance) {
let promiseArr = [];
let ddInstance = editor.ddInstance;
editor.icons = {};
editor == null ? void 0 : editor.controls.forEach((controlDefine) => {
let cacheData = localStorage.getItem("ICON-CACHE-" + controlDefine.id);
if (cacheData) {
editor.icons[controlDefine.id] = cacheData;
return;
} else {
promiseArr.push(new Promise((resolve2, reject2) => {
var _a3;
let models = null;
try {
models = _DDeiEditorUtil2.createControl(controlDefine, editor);
let iconPos = (_a3 = controlDefine == null ? void 0 : controlDefine.define) == null ? void 0 : _a3.iconPos;
let outRect = DDeiAbstractShape.getOutRectByPV(models);
outRect.width += (iconPos == null ? void 0 : iconPos.dw) ? iconPos.dw : 0;
outRect.height += (iconPos == null ? void 0 : iconPos.dh) ? iconPos.dh : 0;
let baseWidth = 50;
let baseHeight = 50;
if (outRect.width > 0 && outRect.height > 0) {
if (outRect.width > outRect.height) {
baseWidth *= outRect.width / outRect.height;
} else {
baseHeight *= outRect.height / outRect.width;
}
let scaleMatrix2 = new Matrix3(
baseWidth / outRect.width,
0,
0,
0,
baseHeight / outRect.height,
0,
0,
0,
1
);
models.forEach((model) => {
model.transVectors(scaleMatrix2);
});
outRect = DDeiAbstractShape.getOutRectByPV(models);
}
if (!outRect.height) {
outRect.height = baseHeight;
}
if (!outRect.width) {
outRect.width = baseWidth;
}
outRect.width += (iconPos == null ? void 0 : iconPos.dw) ? iconPos.dw : 0;
outRect.height += (iconPos == null ? void 0 : iconPos.dh) ? iconPos.dh : 0;
models.forEach((model) => {
model.initRender();
model.render.drawShape({ weight: 3, border: { width: 1.5 } });
});
let canvas = document.createElement("canvas");
_DDeiEditorUtil2.drawModelsToCanvas(models, outRect, canvas);
let dataURL = canvas.toDataURL("image/png");
localStorage.setItem("ICON-CACHE-" + controlDefine.id, dataURL);
editor.icons[controlDefine.id] = dataURL;
} catch (e) {
if (editor.debug) {
console.error(e);
}
}
models == null ? void 0 : models.forEach((md) => {
md == null ? void 0 : md.destroyed();
});
resolve2();
}));
}
});
Promise.all(promiseArr).then((all) => {
ddInstance.render.tempCanvas = null;
resolve(editor.icons);
});
}
}
});
}
/**
* 将多个元素绘制到canvas上
*/
static drawModelsToCanvas(models, outRect, canvas, level = 0) {
var _a3;
if ((models == null ? void 0 : models.length) > 0) {
let stage2 = models[0].stage;
let rat1 = (_a3 = stage2.ddInstance) == null ? void 0 : _a3.render.ratio;
canvas.setAttribute("style", "-webkit-font-smoothing:antialiased;-moz-transform-origin:left top;-moz-transform:scale(" + 1 / rat1 + ");display:block;zoom:" + 1 / rat1);
let ctx = canvas.getContext("2d", { willReadFrequently: true });
let width = (outRect.width + 4) * rat1;
let height = (outRect.height + 4) * rat1;
if (level == 0) {
canvas.setAttribute("width", width);
canvas.setAttribute("height", height);
canvas.style.width = width + "px";
canvas.style.height = height + "px";
}
models.forEach((model) => {
var _a22;
let rendList = [];
if (((_a22 = model.composes) == null ? void 0 : _a22.length) > 0) {
rendList = rendList.concat(model.composes);
}
rendList.push(model);
rendList.sort((a, b) => {
if ((a.cIndex || a.cIndex == 0) && (b.cIndex || b.cIndex == 0)) {
return a.cIndex - b.cIndex;
} else if ((a.cIndex || a.cIndex == 0) && !(b.cIndex || b.cIndex == 0)) {
return 1;
} else if (!(a.cIndex || a.cIndex == 0) && (b.cIndex || b.cIndex == 0)) {
return -1;
} else {
return 0;
}
});
rendList == null ? void 0 : rendList.forEach((mc) => {
if (mc == model) {
if (mc.render.tempCanvas) {
if (mc.baseModelType != "DDeiLine") {
ctx.drawImage(mc.render.tempCanvas, 0, 0, mc.render.tempCanvas.width, mc.render.tempCanvas.height, ((mc.essBounds ? mc.essBounds.x : mc.cpv.x) - outRect.x) * rat1, ((mc.essBounds ? mc.essBounds.y : mc.cpv.y) - outRect.y - 2) * rat1, mc.essBounds.width * rat1, mc.essBounds.height * rat1);
} else {
ctx.drawImage(mc.render.tempCanvas, 0, 0, mc.render.tempCanvas.width, mc.render.tempCanvas.height, (mc.cpv.x - outRect.x) * rat1, (mc.cpv.y - outRect.y) * rat1, outRect.width * rat1, outRect.height * rat1);
}
}
if (model.baseModelType == "DDeiContainer") {
_DDeiEditorUtil2.drawModelsToCanvas(Array.from(model.models.values()), outRect, canvas, level + 1);
}
} else {
_DDeiEditorUtil2.drawModelsToCanvas([mc], outRect, canvas, level + 1);
}
});
});
}
}
/**
* 清空控件小图标
*/
static clearControlIcons(editor) {
editor.icons = {};
editor == null ? void 0 : editor.controls.forEach((controlDefine) => {
localStorage.removeItem("ICON-CACHE-" + controlDefine.id);
});
}
/**
* 创建控件
*/
static createControl(control, editor) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j;
let ddInstance = editor.ddInstance;
ddInstance.render.inEdge = 0;
let stage2 = ddInstance.stage;
let layer2 = stage2.layers[stage2.layerIndex];
let models = [];
let cc = control;
let searchPaths = [
"width",
"height",
"text",
"subcontrol",
"layout"
];
let configAtrs = _DDeiEditorUtil2.getAttrValueByConfig(
cc,
searchPaths
);
stage2.idIdx++;
let dataJson = {
id: cc.code + "_" + stage2.idIdx,
modelCode: cc.id
};
searchPaths.forEach((key) => {
if (configAtrs.get(key)) {
dataJson[key] = configAtrs.get(key).data;
}
if (cc[key] != void 0 && cc[key] != null) {
dataJson[key] = cc[key];
}
});
if (cc.img) {
dataJson.fill = { type: 2, image: cc.img };
}
for (let i2 in cc == null ? void 0 : cc.define) {
dataJson[i2] = cloneDeep(cc.define[i2]);
}
for (let i2 in dataJson) {
let value = dataJson[i2];
if (typeof value == "string") {
dataJson[i2] = editor.i18n(value);
}
}
(_a3 = dataJson.composes) == null ? void 0 : _a3.forEach((compose) => {
for (let i2 in compose) {
let value = compose[i2];
if (typeof value == "string") {
compose[i2] = editor.i18n(value);
}
}
});
delete dataJson.ovs;
let model = editor.controlModelClasses[cc.type].initByJSON(
dataJson,
{ currentStage: stage2, currentLayer: layer2, currentDdInstance: ddInstance }
);
models.push(model);
(_b2 = control.others) == null ? void 0 : _b2.forEach((oc) => {
for (let i2 in oc) {
let value = oc[i2];
if (typeof value == "string") {
oc[i2] = editor.i18n(value);
}
}
let otherModels = _DDeiEditorUtil2.createControl(oc, editor);
if ((otherModels == null ? void 0 : otherModels.length) > 0) {
models = models.concat(otherModels);
}
});
if (((_c2 = control == null ? void 0 : control.define) == null ? void 0 : _c2.create) == false) {
models.splice(0, 1);
}
if ((_d2 = control == null ? void 0 : control.define) == null ? void 0 : _d2.iLinkModels) {
for (let ilk in (_e2 = control == null ? void 0 : control.define) == null ? void 0 : _e2.iLinkModels) {
let linkData = (_f = control == null ? void 0 : control.define) == null ? void 0 : _f.iLinkModels[ilk];
let cIndex = parseInt(ilk);
if (cIndex != -1) {
cIndex++;
let linkControl = models[cIndex];
let lineLink = new DDeiModelLink({
depModel: cc,
type: linkData.type,
dm: linkControl,
dx: linkData.dx,
dy: linkData.dy
});
linkControl.depModel = cc;
models[0].linkModels.set(linkControl.id, lineLink);
}
}
}
if ((_g = control == null ? void 0 : control.define) == null ? void 0 : _g.initMerges) {
let mergeControls = [models[0]];
for (let m in (_h = control == null ? void 0 : control.define) == null ? void 0 : _h.initMerges) {
let mIndex = (_i = control == null ? void 0 : control.define) == null ? void 0 : _i.initMerges[m];
if (mIndex != -1) {
mIndex++;
let mControl = models[mIndex];
if (mergeControls.indexOf(mControl) == -1) {
mergeControls.push(mControl);
}
}
}
if (mergeControls.length > 1) {
ddInstance.stage.layers[ddInstance.stage.layerIndex];
(_j = ddInstance.stage) == null ? void 0 : _j.getStageRatio();
let outRect = DDeiAbstractShape.getOutRectByPV(mergeControls);
let controlDefine = DDeiUtil$1.getControlDefine({ modelCode: "100202" });
let container2 = DDeiUtil$1.createControl(controlDefine, DDeiUtil$1.getEditorInsByDDei(ddInstance))[0];
container2.layout = "compose";
container2.layoutManager = DDeiLayoutManagerFactory.getLayoutInstance("compose");
container2.layoutManager.container = container2;
container2.fill = { type: 0 };
container2.border = { type: 0 };
let m12 = new Matrix3();
let scaleMatrix2 = new Matrix3(
outRect.width / container2.essBounds.width,
0,
0,
0,
outRect.height / container2.essBounds.height,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
let moveMatrix2 = new Matrix3(
1,
0,
outRect.x + outRect.width / 2,
0,
1,
outRect.y + outRect.height / 2,
0,
0,
1
);
m12.premultiply(moveMatrix2);
container2.transVectors(m12);
mergeControls.forEach((mc) => {
if (mc) {
container2.addModel(mc, false);
mc.pModel = container2;
}
});
container2 == null ? void 0 : container2.changeParentsBounds();
ddInstance.stage.idIdx++;
models.splice(0, mergeControls.length, container2);
}
}
return models;
}
/**
* 执行调用回调函数
* @param ddInstance ddeis实例
* @param editor 设计器对象实例
*/
static invokeCallbackFunc(name, operate, data, ddInstance, evt) {
let result = 0;
let editor = _DDeiEditorUtil2.getEditorInsByDDei(ddInstance);
let selectAfter = DDeiUtil$1.getConfigValue(name, ddInstance);
let funcArr = editor.funcIndex.get(name);
let callResult = new DDeiFuncCallResult();
if (selectAfter) {
let cr = selectAfter(operate, data, ddInstance, evt);
callResult = cr ? cr : callResult;
}
if ((callResult == null ? void 0 : callResult.state) > 0) {
result = 1;
} else if ((callResult == null ? void 0 : callResult.state) < 0) {
result = -1;
}
if (callResult.state == 0 || callResult.state == 1 || callResult.state == -1) {
if ((funcArr == null ? void 0 : funcArr.length) > 0) {
for (let fa = 0; fa < funcArr.length; fa++) {
let func = funcArr[fa]["func"];
if (func) {
callResult = func(operate, data, ddInstance, evt);
if (callResult) {
if (callResult.state > 0) {
result = 1;
} else if (callResult.state < 0) {
result = -1;
}
if (!(callResult.state == 0 || callResult.state == 1 || callResult.state == -1)) {
break;
}
}
}
}
}
}
return result;
}
};
__publicField2(_DDeiEditorUtil, "recentlyToolGroups", null);
__publicField2(_DDeiEditorUtil, "ICONS", null);
let DDeiEditorUtil = _DDeiEditorUtil;
const DDeiEditorUtil$1 = DDeiEditorUtil;
class DDeiBusCommandChangeCursor extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
if ((data == null ? void 0 : data.passIndex) || (data == null ? void 0 : data.cursor) || (data == null ? void 0 : data.image)) {
if (data.image) {
document.body.style.cursor = "url(" + DDeiEditorUtil$1.ICONS[data.image] + "),auto";
}
if (data.cursor) {
document.body.style.cursor = data.cursor;
} else if (data.passIndex) {
if (bus.ddInstance.state != DDeiEnumState.IN_ACTIVITY) {
let type = data == null ? void 0 : data.type;
switch (type) {
case "line":
{
switch (data.passIndex) {
case 1:
document.body.style.cursor = "grab";
break;
case 2:
document.body.style.cursor = "grab";
break;
case 3:
document.body.style.cursor = (data == null ? void 0 : data.direct) == 1 ? "ns-resize" : "ew-resize";
break;
case 4:
document.body.style.cursor = "grab";
break;
default:
document.body.style.cursor = "all-scroll";
break;
}
}
break;
default: {
switch (data.passIndex) {
case 1:
document.body.style.cursor = "ns-resize";
break;
case 2:
document.body.style.cursor = "nesw-resize";
break;
case 3:
document.body.style.cursor = "ew-resize";
break;
case 4:
document.body.style.cursor = "nwse-resize";
break;
case 5:
document.body.style.cursor = "ns-resize";
break;
case 6:
document.body.style.cursor = "nesw-resize";
break;
case 7:
document.body.style.cursor = "ew-resize";
break;
case 8:
document.body.style.cursor = "nwse-resize";
break;
case 9:
document.body.style.cursor = "alias";
break;
case 10:
document.body.style.cursor = "all-scroll";
break;
case 11:
document.body.style.cursor = "alias";
break;
case 13:
document.body.style.cursor = "all-scroll";
break;
default:
document.body.style.cursor = "default";
break;
}
}
}
}
}
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandChangeCursor({ code: DDeiEnumBusCommandType.ChangeCursor, name: "", desc: "" });
}
}
const __vite_glob_0_3$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandChangeCursor,
default: DDeiBusCommandChangeCursor
}, Symbol.toStringTag, { value: "Module" }));
class DDeiCommandChangeEditMode extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let ddInstance = bus.ddInstance;
if (ddInstance && (data == null ? void 0 : data.mode)) {
ddInstance.changeEditMode(data.mode);
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiCommandChangeEditMode({ code: DDeiEnumBusCommandType.ChangeEditMode, name: "", desc: "" });
}
}
const __vite_glob_0_4$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiCommandChangeEditMode,
default: DDeiCommandChangeEditMode
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandChangeLayout extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
var _a3;
let stage2 = bus.ddInstance.stage;
if (stage2 && ((_a3 = data == null ? void 0 : data.mids) == null ? void 0 : _a3.length) > 0) {
let mids = data.mids;
let value = data.value;
let attrDefine = data.attrDefine;
if (attrDefine.modelCode == "DDeiTableCell") {
let modelId = mids[0];
let table2 = stage2 == null ? void 0 : stage2.getModelById(modelId);
if (table2) {
let cells = table2.getSelectedCells();
for (let i2 = 0; i2 < cells.length; i2++) {
let cell = cells[i2];
let oldLayout = cell.layout;
if (value != oldLayout) {
let newLayoutManager = DDeiLayoutManagerFactory.getLayoutInstance(value);
newLayoutManager.container = cell;
let canConvert = newLayoutManager.canConvertLayout(oldLayout);
if (!canConvert) {
return false;
}
}
}
}
} else {
for (let i2 = 0; i2 < mids.length; i2++) {
let modelId = mids[i2];
if (modelId) {
let model = stage2 == null ? void 0 : stage2.getModelById(modelId);
if (model) {
let oldLayout = model.layout;
if (value != oldLayout) {
let newLayoutManager = DDeiLayoutManagerFactory.getLayoutInstance(value);
newLayoutManager.container = model;
let canConvert = newLayoutManager.canConvertLayout(oldLayout);
if (!canConvert) {
return false;
}
}
}
}
}
}
return true;
}
}
/**
* 具体行为,设置属性值
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2, _c2;
let stage2 = bus.ddInstance.stage;
if (stage2 && ((_a3 = data == null ? void 0 : data.mids) == null ? void 0 : _a3.length) > 0 && ((_b2 = data == null ? void 0 : data.paths) == null ? void 0 : _b2.length) > 0) {
let mids = data.mids;
let value = data.value;
let attrDefine = data.attrDefine;
if (attrDefine.modelCode == "DDeiTableCell") {
let modelId = mids[0];
let table2 = stage2 == null ? void 0 : stage2.getModelById(modelId);
if (table2) {
let cells = table2.getSelectedCells();
for (let i2 = 0; i2 < cells.length; i2++) {
let cell = cells[i2];
let oldLayout = cell.layout;
cell.layout = value;
(_c2 = cell.render) == null ? void 0 : _c2.setCachedValue("layout", value);
cell.layoutManager = DDeiLayoutManagerFactory.getLayoutInstance(value);
cell.layoutManager.container = cell;
cell.layoutManager.convertLayout(oldLayout);
cell.layoutManager.changeSubModelBounds();
}
bus.insert(DDeiEnumBusCommandType.NodifyChange, null, evt, 0);
bus.insert(DDeiEnumBusCommandType.AddHistroy, null, evt, 1);
}
} else {
mids.forEach((modelId) => {
var _a22;
if (modelId) {
let model = stage2 == null ? void 0 : stage2.getModelById(modelId);
if (model) {
let oldLayout = model.layout;
model.layout = value;
(_a22 = model.render) == null ? void 0 : _a22.setCachedValue("layout", value);
model.layoutManager = DDeiLayoutManagerFactory.getLayoutInstance(value);
model.layoutManager.container = model;
model.layoutManager.convertLayout(oldLayout);
model.layoutManager.changeSubModelBounds();
}
}
});
bus.insert(DDeiEnumBusCommandType.NodifyChange, null, evt, 0);
bus.insert(DDeiEnumBusCommandType.AddHistroy, null, evt, 1);
}
return true;
}
return false;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandChangeLayout({ code: DDeiEnumBusCommandType.ChangeLayout, name: "", desc: "" });
}
}
const __vite_glob_0_5$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandChangeLayout,
default: DDeiBusCommandChangeLayout
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandChangeLinePoint extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,重绘所有图形
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3;
let stage2 = bus.ddInstance.stage;
let stageRender = stage2 == null ? void 0 : stage2.render;
let ex = (data == null ? void 0 : data.ex) ? data.ex : 0;
let ey = (data == null ? void 0 : data.ey) ? data.ey : 0;
if ((stageRender == null ? void 0 : stageRender.dragObj) && ((_a3 = stageRender.dragObj) == null ? void 0 : _a3.model) && (ex || ey)) {
let lineModel = stageRender.dragObj.model;
let passIndex = stageRender.dragObj.passIndex;
let opvsIndex = stageRender.dragObj.opvsIndex;
let opvs = stageRender.dragObj.opvs;
let pvs2 = lineModel.pvs;
let create = stageRender.dragObj.create;
switch (lineModel.type) {
case 1:
{
if (passIndex == 1 && opvsIndex == 0) {
lineModel.setLineType1PointPosition(0, ex, ey);
} else if (passIndex == 1 && opvsIndex == opvs.length - 1) {
lineModel.setLineType1PointPosition(1, ex, ey);
}
}
break;
case 2:
{
if (passIndex == 1 && opvsIndex == 0) {
if (pvs2.length > 2) {
let otherP = pvs2[1];
if (Math.abs(pvs2[0].x - otherP.x) <= 1) {
otherP.x = ex;
} else {
otherP.y = ey;
}
}
pvs2[0].x = ex;
pvs2[0].y = ey;
} else if (passIndex == 1 && opvsIndex == opvs.length - 1) {
if (create) {
pvs2[pvs2.length - 1].x = ex;
pvs2[pvs2.length - 1].y = ey;
} else {
if (pvs2.length > 2) {
let otherP = pvs2[pvs2.length - 2];
if (Math.abs(pvs2[pvs2.length - 1].x - otherP.x) <= 1) {
otherP.x = ex;
} else {
otherP.y = ey;
}
}
pvs2[pvs2.length - 1].x = ex;
pvs2[pvs2.length - 1].y = ey;
}
} else if (passIndex == 2) {
let cIndex = parseInt(opvsIndex / 2);
let cp = pvs2[cIndex];
let bp = pvs2[cIndex - 1];
let ap = pvs2[cIndex + 1];
let startPoint = lineModel.startPoint;
if (Math.abs(cp.x - bp.x) <= 1) {
bp.x = ex;
bp.x = ex;
lineModel.spvs[cIndex] = { x: ex - startPoint.x, y: 0 };
} else {
bp.y = ey;
bp.y = ey;
lineModel.spvs[cIndex] = { x: 0, y: ey - startPoint.y };
}
if (Math.abs(cp.x - ap.x) <= 1) {
ap.x = ex;
ap.x = ex;
lineModel.spvs[cIndex + 1] = { x: ex - startPoint.x, y: 0 };
} else {
ap.y = ey;
ap.y = ey;
lineModel.spvs[cIndex + 1] = { x: 0, y: ey - startPoint.y };
}
cp.x = ex;
cp.y = ey;
} else if (passIndex == 3) {
let startPoint = lineModel.startPoint;
let sIndex = parseInt(opvsIndex / 2);
let sp = pvs2[sIndex];
let ep = pvs2[sIndex + 1];
if (sp && ep) {
if (Math.abs(sp.x - ep.x) <= 1) {
sp.x = ex;
ep.x = ex;
lineModel.spvs[sIndex + 1] = { x: ex - startPoint.x, y: 0 };
} else {
sp.y = ey;
ep.y = ey;
lineModel.spvs[sIndex + 1] = { x: 0, y: ey - startPoint.y };
}
}
}
}
break;
case 3:
{
if (passIndex == 1) {
if (opvsIndex == 0) {
pvs2[0].x = ex;
pvs2[0].y = ey;
} else {
pvs2[pvs2.length - 1].x = ex;
pvs2[pvs2.length - 1].y = ey;
}
lineModel.freeze = 0;
} else if (passIndex == 4) {
let lineIndex = parseInt(opvsIndex / 3);
let oitype = opvsIndex % 2;
let i0 = lineIndex * 3;
let i1 = i0 + 1;
let i2 = i0 + 2;
let i3 = i0 + 3;
if (opvs.length > 4) {
if (opvsIndex % 3 == 0) {
oitype = 2;
} else {
oitype = opvsIndex % 3 % 2;
}
}
if (oitype == 1) {
pvs2[i1].x = -(pvs2[i0].x * DDeiUtil$1.p331t3 + DDeiUtil$1.p33t21t3 * pvs2[i2].x + DDeiUtil$1.p33t3 * pvs2[i3].x - ex) / DDeiUtil$1.p331t2t3;
pvs2[i1].y = -(pvs2[i0].y * DDeiUtil$1.p331t3 + DDeiUtil$1.p33t21t3 * pvs2[i2].y + DDeiUtil$1.p33t3 * pvs2[i3].y - ey) / DDeiUtil$1.p331t2t3;
lineModel.spvs[i1] = true;
} else if (oitype == 2) {
let dx = ex - pvs2[opvsIndex].x;
let dy = ey - pvs2[opvsIndex].y;
pvs2[opvsIndex].x = ex;
pvs2[opvsIndex].y = ey;
pvs2[opvsIndex - 1].x += dx;
pvs2[opvsIndex - 1].y += dy;
pvs2[opvsIndex + 1].x += dx;
pvs2[opvsIndex + 1].y += dy;
} else {
pvs2[i2].x = -(pvs2[i0].x * DDeiUtil$1.p661t3 + DDeiUtil$1.p661t2t3 * pvs2[i1].x + DDeiUtil$1.p66t3 * pvs2[i3].x - ex) / DDeiUtil$1.p66t21t3;
pvs2[i2].y = -(pvs2[i0].y * DDeiUtil$1.p661t3 + DDeiUtil$1.p661t2t3 * pvs2[i1].y + DDeiUtil$1.p66t3 * pvs2[i3].y - ey) / DDeiUtil$1.p66t21t3;
lineModel.spvs[i2] = true;
}
lineModel.freeze = 1;
}
}
break;
}
lineModel.calPoints();
return true;
}
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
var _a3, _b2;
(_b2 = (_a3 = bus.ddInstance) == null ? void 0 : _a3.bus) == null ? void 0 : _b2.insert(DDeiEnumBusCommandType.ChangeCursor, { cursor: "default" }, evt);
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandChangeLinePoint({ code: DDeiEnumBusCommandType.ChangeLinePoint, name: "", desc: "" });
}
}
const __vite_glob_0_6$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandChangeLinePoint,
default: DDeiBusCommandChangeLinePoint
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandChangeSelectorPassIndex extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let stage2 = bus.ddInstance.stage;
if (stage2 && stage2.render.selector && (data == null ? void 0 : data.passIndex)) {
stage2.render.selector.setPassIndex(data == null ? void 0 : data.type, data == null ? void 0 : data.passIndex, data == null ? void 0 : data.opvsIndex);
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
bus == null ? void 0 : bus.insert(DDeiEnumBusCommandType.ChangeCursor, { type: data == null ? void 0 : data.type, passIndex: data == null ? void 0 : data.passIndex, direct: data == null ? void 0 : data.direct }, evt);
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandChangeSelectorPassIndex({ code: DDeiEnumBusCommandType.ChangeSelectorPassIndex, name: "", desc: "" });
}
}
const __vite_glob_0_7$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandChangeSelectorPassIndex,
default: DDeiBusCommandChangeSelectorPassIndex
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiBusCommandChangeStageRatio = class _DDeiBusCommandChangeStageRatio2 extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,重绘所有图形
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3;
if (DDeiUtil$1.getConfigValue("GLOBAL_ALLOW_STAGE_RATIO", bus.ddInstance)) {
let stage2 = bus.ddInstance.stage;
if (stage2 && data.oldValue && data.newValue && data.oldValue != data.newValue) {
let scaleSize = data.newValue / data.oldValue;
(/* @__PURE__ */ new Date()).getTime();
stage2.layers.forEach((layer2) => {
var _a22;
layer2.opPoints = [];
delete layer2.opLine;
(_a22 = layer2.shadowControls) == null ? void 0 : _a22.forEach((c) => {
c.destroyed();
});
layer2.shadowControls = [];
layer2.midList.forEach((mid) => {
var _a32, _b2, _c2;
let model = layer2.models.get(mid);
if (model.baseModelType == "DDeiLine") {
model.updateLooseCanvas();
}
(_b2 = (_a32 = model.getTopContainer()) == null ? void 0 : _a32.render) == null ? void 0 : _b2.enableRefreshShape();
(_c2 = model.render) == null ? void 0 : _c2.enableRefreshShape();
});
(/* @__PURE__ */ new Date()).getTime();
});
let oldWidth = stage2.width;
let oldHeight = stage2.height;
stage2.width = stage2.width * scaleSize;
stage2.height = stage2.height * scaleSize;
let dw = stage2.width - oldWidth;
let dh = stage2.height - oldHeight;
let wpvX = -stage2.wpv.x;
let wpvY = -stage2.wpv.y;
let ex = null, ey = null;
if (((_a3 = window.event) == null ? void 0 : _a3.type) == "wheel") {
let evt2 = window.event;
ex = evt2.offsetX;
ey = evt2.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= stage2.wpv.x;
ey -= stage2.wpv.y;
}
let ox = dw / 2;
let oy = dh / 2;
if (ex && ey) {
ox = dw * ex / oldWidth;
oy = dh * ey / oldHeight;
}
let w = stage2.ddInstance.render.canvas.width / stage2.ddInstance.render.ratio;
let h = stage2.ddInstance.render.canvas.height / stage2.ddInstance.render.ratio;
if (w < stage2.width) {
stage2.wpv.x = -wpvX - ox;
} else {
stage2.wpv.x = 0;
}
if (h < stage2.height) {
stage2.wpv.y = -wpvY - oy;
} else {
stage2.wpv.y = 0;
}
DDeiEditorUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", "CHANGE_RATIO", null, stage2.ddInstance, evt);
DDeiEditorUtil$1.invokeCallbackFunc("EVENT_STAGE_CHANGE_RATIO", "CHANGE_RATIO", data, stage2.ddInstance, evt);
return true;
}
}
return false;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
bus.insert(DDeiEnumBusCommandType.UpdateSelectorBounds, null, evt, 0);
bus.insert(DDeiEnumBusCommandType.RefreshShape, null, evt, 1);
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new _DDeiBusCommandChangeStageRatio2({ code: DDeiEnumBusCommandType.ChangeStageRatio, name: "", desc: "" });
}
};
_DDeiBusCommandChangeStageRatio.calLineCross = debounce(DDeiLine.calLineCross, 30);
let DDeiBusCommandChangeStageRatio = _DDeiBusCommandChangeStageRatio;
const __vite_glob_0_8$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandChangeStageRatio,
default: DDeiBusCommandChangeStageRatio
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandChangeStageWPV extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,重绘所有图形
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2, _c2, _d2;
let stage2 = bus.ddInstance.stage;
if (stage2) {
let rat1 = stage2.ddInstance.render.ratio;
let stageRatio2 = stage2.getStageRatio();
let ratio = rat1 * stageRatio2;
let hScrollWidth = ((_a3 = stage2.render.hScroll) == null ? void 0 : _a3.width) ? (_b2 = stage2.render.hScroll) == null ? void 0 : _b2.width : 0;
let vScrollHeight = ((_c2 = stage2.render.vScroll) == null ? void 0 : _c2.height) ? (_d2 = stage2.render.vScroll) == null ? void 0 : _d2.height : 0;
let oldWPV = clone(stage2.wpv);
let x2 = data.x;
let y2 = data.y;
let dragObj = data.dragObj;
if (hScrollWidth) {
stage2.wpv.x += (x2 - dragObj.dx) / ratio;
}
if (vScrollHeight) {
stage2.wpv.y += (y2 - dragObj.dy) / ratio;
}
if (stage2.wpv.x > 0) {
stage2.wpv.x = 0;
} else if (stage2.wpv.x < -stage2.width + hScrollWidth) {
stage2.wpv.x = -stage2.width + hScrollWidth;
}
if (stage2.wpv.y > 0) {
stage2.wpv.y = 0;
} else if (stage2.wpv.y < -stage2.height + vScrollHeight) {
stage2.wpv.y = -stage2.height + vScrollHeight;
}
DDeiEditorUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", "CHANGE_WPV", null, stage2.ddInstance, evt);
DDeiEditorUtil$1.invokeCallbackFunc("EVENT_STAGE_CHANGE_WPV", "CHANGE_WPV", { oldWPV, wpv: stage2.wpv }, stage2.ddInstance, evt);
return true;
} else {
return false;
}
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
bus.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "grabbing" });
bus.push(DDeiEnumBusCommandType.RefreshShape);
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandChangeStageWPV({ code: DDeiEnumBusCommandType.ChangeStageWPV, name: "", desc: "" });
}
}
const __vite_glob_0_9$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandChangeStageWPV,
default: DDeiBusCommandChangeStageWPV
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandClearTemplateVars extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let stage2 = bus.ddInstance.stage;
if (stage2) {
stage2.render.currentOperateShape = null;
stage2.render.operateState = DDeiEnumOperateState.NONE;
stage2.render.dragObj = null;
stage2.render.isHAds = false;
stage2.render.isVAds = false;
stage2.render.vAdsX = Infinity;
stage2.render.hAdsY = Infinity;
stage2.render.tempSX = null;
stage2.render.tempSY = null;
stage2.ddInstance.render.inEdge = 0;
stage2.render.selector.setPassIndex("", -1, -1);
delete stage2.tempStartOPpoint;
delete stage2.tempCursorOPpoint;
delete stage2.render.linePathData;
delete stage2.ddInstance.render.inAreaControls;
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandClearTemplateVars({ code: DDeiEnumBusCommandType.ClearTemplateVars, name: "", desc: "" });
}
}
const __vite_glob_0_10$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandClearTemplateVars,
default: DDeiBusCommandClearTemplateVars
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandCreateDepLinkModel extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,重绘所有图形
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let ddInstance = bus.ddInstance;
let stage2 = ddInstance.stage;
let text2 = data.text;
let model = data.model ? data.model : stage2.selectedModels.size == 1 ? Array.from(stage2.selectedModels.values())[0] : null;
DDeiUtil$1.createDepLinkModel(model, text2);
return true;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandCreateDepLinkModel({ code: DDeiEnumBusCommandType.CreateDepLinkModel, name: "", desc: "" });
}
}
const __vite_glob_0_11$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandCreateDepLinkModel,
default: DDeiBusCommandCreateDepLinkModel
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelAlign extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置属性值
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3;
let stage2 = bus.ddInstance.stage;
if (stage2 && ((_a3 = data == null ? void 0 : data.models) == null ? void 0 : _a3.length) > 0 && (data == null ? void 0 : data.value)) {
let models = data.models;
let filtedModels = [];
models.forEach((m) => {
if (m.baseModelType != "DDeiLine") {
filtedModels.push(m);
}
});
if ((filtedModels == null ? void 0 : filtedModels.length) > 1) {
let baseModel = filtedModels[0];
let baseOutRect = DDeiAbstractShape.getOutRectByPV([baseModel]);
let hasChange = false;
for (let i2 = 1; i2 < filtedModels.length; i2++) {
let model = filtedModels[i2];
let moveMatrix2 = null;
let outRect = DDeiAbstractShape.getOutRectByPV([model]);
if (data.value == "left") {
moveMatrix2 = new Matrix3(
1,
0,
baseOutRect.x - outRect.x,
0,
1,
0,
0,
0,
1
);
} else if (data.value == "center") {
moveMatrix2 = new Matrix3(
1,
0,
baseOutRect.x + baseOutRect.width / 2 - outRect.x - outRect.width / 2,
0,
1,
0,
0,
0,
1
);
} else if (data.value == "right") {
moveMatrix2 = new Matrix3(
1,
0,
baseOutRect.x + baseOutRect.width - outRect.x - outRect.width,
0,
1,
0,
0,
0,
1
);
} else if (data.value == "top") {
moveMatrix2 = new Matrix3(
1,
0,
0,
0,
1,
baseOutRect.y - outRect.y,
0,
0,
1
);
} else if (data.value == "middle") {
moveMatrix2 = new Matrix3(
1,
0,
0,
0,
1,
baseOutRect.y + baseOutRect.height / 2 - outRect.y - outRect.height / 2,
0,
0,
1
);
} else if (data.value == "bottom") {
moveMatrix2 = new Matrix3(
1,
0,
0,
0,
1,
baseOutRect.y + baseOutRect.height - outRect.y - outRect.height,
0,
0,
1
);
}
if (moveMatrix2) {
model.transVectors(moveMatrix2);
model.updateLinkModels();
hasChange = true;
}
}
if (hasChange) {
bus.push(DDeiEnumBusCommandType.NodifyChange);
bus.insert(DDeiEnumBusCommandType.AddHistroy);
}
bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
bus.push(DDeiEnumBusCommandType.RefreshShape);
return true;
}
}
return false;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelAlign({ code: DDeiEnumBusCommandType.ModelAlign, name: "", desc: "" });
}
}
const __vite_glob_0_12$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelAlign,
default: DDeiBusCommandModelAlign
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelAutoPos extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置属性值
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3;
let stage2 = bus.ddInstance.stage;
if (stage2 && ((_a3 = data == null ? void 0 : data.models) == null ? void 0 : _a3.length) > 0 && (data == null ? void 0 : data.value)) {
let models = data.models;
let filtedModels = [];
models.forEach((m) => {
if (m.baseModelType != "DDeiLine") {
filtedModels.push(m);
}
});
if ((filtedModels == null ? void 0 : filtedModels.length) > 1) {
let weight = 0;
let hasChange = false;
let startValue = -Infinity;
let ourRects = [];
for (let i2 = 0; i2 < filtedModels.length; i2++) {
let model = filtedModels[i2];
let outRect = DDeiAbstractShape.getOutRectByPV([model]);
outRect.model = model;
ourRects.push(outRect);
}
if (data.value == 1) {
ourRects.sort((m12, m2) => {
return m12.model.x - m2.model.x;
});
} else if (data.value == 2) {
ourRects.sort((m12, m2) => {
return m12.model.y - m2.model.y;
});
}
let sumWeight = 0;
for (let i2 = 0; i2 < ourRects.length - 1; i2++) {
let m12 = ourRects[i2];
let m2 = ourRects[i2 + 1];
if (data.value == 1) {
sumWeight += m2.x - (m12.x + m12.width);
} else if (data.value == 2) {
sumWeight += m2.y - (m12.y + m12.height);
}
}
weight = sumWeight / (ourRects.length - 1);
for (let i2 = 1; i2 < ourRects.length; i2++) {
let outRect = ourRects[i2];
let model = outRect.model;
if (data.value == 1) {
if (startValue == -Infinity) {
startValue = ourRects[0].x1;
}
startValue += weight;
if (outRect.x != startValue) {
let dx = startValue - outRect.x;
let moveMatrix2 = new Matrix3(
1,
0,
dx,
0,
1,
0,
0,
0,
1
);
model.transVectors(moveMatrix2);
model.updateLinkModels();
hasChange = true;
}
startValue += outRect.width;
} else if (data.value == 2) {
if (startValue == -Infinity) {
startValue = ourRects[0].y1;
}
startValue += weight;
if (outRect.y != startValue) {
let dy = startValue - outRect.y;
let moveMatrix2 = new Matrix3(
1,
0,
0,
0,
1,
dy,
0,
0,
1
);
model.transVectors(moveMatrix2);
model.updateLinkModels();
hasChange = true;
}
startValue += outRect.height;
}
}
if (hasChange) {
bus.push(DDeiEnumBusCommandType.NodifyChange);
bus.insert(DDeiEnumBusCommandType.AddHistroy);
}
bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
bus.push(DDeiEnumBusCommandType.RefreshShape);
return true;
}
}
return false;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelAutoPos({ code: DDeiEnumBusCommandType.ModelAutoPos, name: "", desc: "" });
}
}
const __vite_glob_0_13$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelAutoPos,
default: DDeiBusCommandModelAutoPos
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelCancelMerge extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置属性值
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let ddInstance = bus.ddInstance;
if (ddInstance && ddInstance.stage) {
let layer2 = ddInstance.stage.layers[ddInstance.stage.layerIndex];
let selectedModels = layer2.getSelectedModels();
if (selectedModels.size > 0) {
let models = Array.from(selectedModels.values());
let insertIndex = 0;
models.forEach((item) => {
if (item.baseModelType == "DDeiContainer") {
if (item.models && item.models.size > 0) {
ddInstance.bus.insert(DDeiEnumBusCommandType.ModelChangeContainer, { oldContainer: layer2, models: [item], skpiValid: true }, evt, insertIndex);
insertIndex++;
ddInstance.bus.insert(DDeiEnumBusCommandType.ModelChangeSelect, { models: [item], value: DDeiEnumControlState.DEFAULT }, evt, insertIndex);
insertIndex++;
let models2 = Array.from(item.models.values());
ddInstance.bus.insert(DDeiEnumBusCommandType.ModelChangeContainer, { newContainer: layer2, oldContainer: item, models: models2, skpiValid: true }, evt, insertIndex);
insertIndex++;
ddInstance.bus.insert(DDeiEnumBusCommandType.ModelChangeSelect, { models: models2, value: DDeiEnumControlState.SELECTED }, evt, insertIndex);
insertIndex++;
ddInstance.bus.insert(DDeiEnumBusCommandType.StageChangeSelectModels, null, evt, insertIndex);
insertIndex++;
ddInstance.bus.insert(DDeiEnumBusCommandType.ModelRemove, { models: [item], destroy: true }, evt, insertIndex);
insertIndex++;
}
}
});
ddInstance.bus.insert(DDeiEnumBusCommandType.ClearTemplateVars, null, evt, insertIndex);
insertIndex++;
ddInstance.bus.insert(DDeiEnumBusCommandType.AddHistroy, null, evt, insertIndex);
ddInstance.bus.insert(DDeiEnumBusCommandType.NodifyChange, null, evt, insertIndex);
insertIndex++;
ddInstance.bus.insert(DDeiEnumBusCommandType.RefreshShape, null, evt, insertIndex);
return true;
}
}
return false;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelCancelMerge({ code: DDeiEnumBusCommandType.ModelCancelMerge, name: "", desc: "" });
}
}
const __vite_glob_0_14$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelCancelMerge,
default: DDeiBusCommandModelCancelMerge
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelChangeBounds extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3;
if (((_a3 = data == null ? void 0 : data.models) == null ? void 0 : _a3.length) > 0) {
DDeiEditorUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", "CHANGE_BOUNDS", data, bus.ddInstance, evt);
DDeiAbstractShape.changeModelBoundByRect(data.models, data.selector, data);
return true;
}
return false;
}
/**
* 后置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
var _a3;
let stage2 = bus.ddInstance.stage;
bus == null ? void 0 : bus.insert(DDeiEnumBusCommandType.UpdateSelectorBounds, { models: (_a3 = stage2 == null ? void 0 : stage2.layers[stage2 == null ? void 0 : stage2.layerIndex]) == null ? void 0 : _a3.shadowControls }, evt);
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelChangeBounds({ code: DDeiEnumBusCommandType.ModelChangeBounds, name: "", desc: "" });
}
}
const __vite_glob_0_15$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelChangeBounds,
default: DDeiBusCommandModelChangeBounds
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelChangeContainer extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2, _c2;
if (data == null ? void 0 : data.models) {
let oldContainer = data.oldContainer;
let newContainer = data.newContainer;
if (newContainer) {
let models = data.models;
let operateModels = [];
models.forEach((item, key) => {
if (item.id.lastIndexOf("_shadow") != -1) {
let id = item.id.substring(item.id, item.id.lastIndexOf("_shadow"));
item = bus.ddInstance.stage.getModelById(id);
}
operateModels.push(item);
});
if (operateModels.length > 0) {
if (!oldContainer && operateModels[0].pModel) {
oldContainer = operateModels[0].pModel;
}
if (oldContainer) {
let sortOperateModels = [];
let appendTailModels = [];
operateModels.forEach((md) => {
let index = oldContainer == null ? void 0 : oldContainer.midList.indexOf(md.id);
if (index != -1) {
sortOperateModels[index] = md;
} else {
appendTailModels.push(md);
}
});
appendTailModels.forEach((m) => {
sortOperateModels.push(m);
});
operateModels = sortOperateModels;
}
if (newContainer.baseModelType == "DDeiLayer" && !newContainer.layoutManager) {
let freeLayoutManager = DDeiLayoutManagerFactory.getLayoutInstance("free");
freeLayoutManager.container = newContainer;
newContainer.layoutManager = freeLayoutManager;
}
if (data.skipValid || ((_a3 = newContainer.layoutManager) == null ? void 0 : _a3.canAppend(evt == null ? void 0 : evt.offsetX, evt == null ? void 0 : evt.offsetY, operateModels))) {
let successAppend = (_b2 = newContainer.layoutManager) == null ? void 0 : _b2.append(evt == null ? void 0 : evt.offsetX, evt == null ? void 0 : evt.offsetY, operateModels);
if (successAppend) {
if (oldContainer) {
oldContainer.changeParentsBounds();
}
newContainer == null ? void 0 : newContainer.changeParentsBounds();
(_c2 = newContainer == null ? void 0 : newContainer.layoutManager) == null ? void 0 : _c2.updateLayout(evt == null ? void 0 : evt.offsetX, evt == null ? void 0 : evt.offsetY, operateModels);
}
}
}
}
return true;
}
return false;
}
/**
* 后置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
bus == null ? void 0 : bus.insert(DDeiEnumBusCommandType.UpdateSelectorBounds, null, evt);
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelChangeContainer({ code: DDeiEnumBusCommandType.ModelChangeContainer, name: "", desc: "" });
}
}
const __vite_glob_0_16$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelChangeContainer,
default: DDeiBusCommandModelChangeContainer
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelChangePosition extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
var _a3;
if (((_a3 = data == null ? void 0 : data.models) == null ? void 0 : _a3.length) > 0) {
let models = data.models;
for (let i2 = 0; i2 < models.length; i2++) {
let parentContainer = data == null ? void 0 : data.models[i2].pModel;
if (parentContainer == null ? void 0 : parentContainer.layoutManager) {
if (!parentContainer.layoutManager.canChangePosition(data.x, data.y, models, data.isAlt)) {
bus == null ? void 0 : bus.insert(DDeiEnumBusCommandType.ChangeCursor, { cursor: "not-allowed" }, evt);
return false;
}
}
}
}
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
if (((_a3 = data == null ? void 0 : data.models) == null ? void 0 : _a3.length) > 0) {
let x2 = data.x ? data.x : 0;
let y2 = data.y ? data.y : 0;
let dragObj = data.dragObj;
let changeContainer = data.changeContainer ? data.changeContainer : false;
let newContainer = data.newContainer;
let oldContainer = data.oldContainer;
let sample = data.sample;
let models = data.models;
let stage2 = bus.ddInstance.stage;
let stageRatio2 = stage2 == null ? void 0 : stage2.getStageRatio();
let fModel = null;
if (models[0].id.lastIndexOf("_shadow") != -1) {
fModel = stage2 == null ? void 0 : stage2.getModelById(models[0].id.substring(models[0].id, models[0].id.lastIndexOf("_shadow")));
} else {
fModel = models[0];
}
let hAds = ((_b2 = fModel.stage.render.helpLines) == null ? void 0 : _b2.hAds) || ((_c2 = fModel.stage.render.helpLines) == null ? void 0 : _c2.hAds) == 0 ? (_d2 = fModel.stage.render.helpLines) == null ? void 0 : _d2.hAds : Infinity;
let vAds = ((_e2 = fModel.stage.render.helpLines) == null ? void 0 : _e2.vAds) || ((_f = fModel.stage.render.helpLines) == null ? void 0 : _f.vAds) == 0 ? (_g = fModel.stage.render.helpLines) == null ? void 0 : _g.vAds : Infinity;
let hAdsValue = Infinity;
let vAdsValue = Infinity;
if (hAds != Infinity) {
if (stage2.render.isHAds && Math.abs(stage2.render.hAdsY - y2) > bus.ddInstance.GLOBAL_ADV_WEIGHT) {
stage2.render.isHAds = false;
stage2.render.hAdsY = Infinity;
} else if (stage2.render.isHAds) {
hAdsValue = 0;
} else {
stage2.render.isHAds = true;
hAdsValue = -hAds;
stage2.render.hAdsY = y2;
}
}
if (vAds != Infinity) {
if (stage2.render.isVAds && Math.abs(stage2.render.vAdsX - x2) > bus.ddInstance.GLOBAL_ADV_WEIGHT) {
stage2.render.isVAds = false;
stage2.render.vAdsX = Infinity;
} else if (stage2.render.isVAds) {
vAdsValue = 0;
} else {
stage2.render.isVAds = true;
vAdsValue = -vAds;
stage2.render.vAdsX = x2;
}
}
let ignoreModelIds = [];
models.forEach((model) => {
var _a22, _b22, _c22, _d22, _e22, _f2;
ignoreModelIds.push(model.id);
let dx = 0;
let dy = 0;
if (dragObj && dragObj[model.id]) {
dx = ((_a22 = dragObj[model.id]) == null ? void 0 : _a22.dx) ? (_b22 = dragObj[model.id]) == null ? void 0 : _b22.dx : 0;
dy = ((_c22 = dragObj[model.id]) == null ? void 0 : _c22.dy) ? (_d22 = dragObj[model.id]) == null ? void 0 : _d22.dy : 0;
}
let xm = x2 / stageRatio2 - model.cpv.x + dx;
let ym = y2 / stageRatio2 - model.cpv.y + dy;
if (hAdsValue != Infinity) {
ym = hAdsValue;
}
if (vAdsValue != Infinity) {
xm = vAdsValue;
}
let moveMatrix2 = new Matrix3(
1,
0,
xm,
0,
1,
ym,
0,
0,
1
);
model.transVectors(moveMatrix2, { skipSample: sample == 1 ? false : true });
(_f2 = (_e22 = model.pModel) == null ? void 0 : _e22.render) == null ? void 0 : _f2.enableRefreshShape();
});
let rsState = DDeiUtil$1.invokeCallbackFunc("EVENT_CONTROL_DRAGING", DDeiEnumOperateType.DRAG, { models }, stage2.ddInstance, evt);
if (rsState == 0 || rsState == 1) {
DDeiUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", "DRAG", { models }, stage2.ddInstance, evt);
models[0].layer.dragInPoints = [];
models[0].layer.dragOutPoints = [];
if (oldContainer && newContainer && oldContainer != newContainer) {
(_h = oldContainer == null ? void 0 : oldContainer.layoutManager) == null ? void 0 : _h.calDragOutPVS(data.x, data.y, models);
(_i = newContainer == null ? void 0 : newContainer.layoutManager) == null ? void 0 : _i.calDragInPVS(data.x, data.y, models);
} else if (oldContainer) {
(_j = oldContainer == null ? void 0 : oldContainer.layoutManager) == null ? void 0 : _j.calDragOutPVS(data.x, data.y, models);
(_k = oldContainer == null ? void 0 : oldContainer.layoutManager) == null ? void 0 : _k.calDragInPVS(data.x, data.y, models);
}
if (stage2.render.selector.passIndex == 10 || stage2.render.selector.passIndex == 13 || stage2.render.selector.passIndex == 11) {
if (changeContainer) {
if (newContainer.baseModelType == "DDeiLayer" && !newContainer.layoutManager) {
let freeLayoutManager = DDeiLayoutManagerFactory.getLayoutInstance("free");
freeLayoutManager.container = newContainer;
newContainer.layoutManager = freeLayoutManager;
}
if (newContainer.id != oldContainer.id) {
if ((_l = newContainer == null ? void 0 : newContainer.layoutManager) == null ? void 0 : _l.canAppend(data.x, data.y, models)) {
bus == null ? void 0 : bus.insert(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 11 }, evt);
} else {
bus == null ? void 0 : bus.insert(DDeiEnumBusCommandType.ChangeCursor, { cursor: "not-allowed" }, evt);
}
} else {
bus == null ? void 0 : bus.insert(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: 10 }, evt);
}
} else {
bus == null ? void 0 : bus.insert(DDeiEnumBusCommandType.ChangeSelectorPassIndex, { passIndex: stage2.render.selector.passIndex }, evt);
}
}
}
return true;
}
return false;
}
/**
* 后置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelChangePosition({ code: DDeiEnumBusCommandType.ModelChangePosition, name: "", desc: "" });
}
}
const __vite_glob_0_17$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelChangePosition,
default: DDeiBusCommandModelChangePosition
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelChangeRotate extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
var _a3;
if ((data.ex || data.ey) && ((_a3 = data.models) == null ? void 0 : _a3.length) > 0) {
return true;
}
return false;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2, _c2;
let stage2 = bus.ddInstance.stage;
let selector = stage2.render.selector;
let x2 = data.ex ? data.ex : 0, y2 = data.ey ? data.ey : 0;
let pContainerModel = data.container;
let ratio = stage2 == null ? void 0 : stage2.getStageRatio();
let models = data.models;
DDeiEditorUtil$1.invokeCallbackFunc("EVENT_MOUSE_OPERATING", "CHANGE_ROTATE", { models }, bus.ddInstance, evt);
let scx = selector.x * ratio + selector.width / 2 * ratio;
let scy = selector.y * ratio + selector.height / 2 * ratio;
let selectorAngle = Math.round(DDeiUtil$1.getLineAngle(scx, scy, x2, y2));
let rotate2 = selectorAngle + 90;
let selectorRotate = selector.rotate;
let angle2 = -DDeiUtil$1.preciseTimes(rotate2 - selectorRotate, DDeiConfig$1.ROTATE_UNIT);
let move1Matrix = new Matrix3(
1,
0,
-scx,
0,
1,
-scy,
0,
0,
1
);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
let move2Matrix = new Matrix3(
1,
0,
scx,
0,
1,
scy,
0,
0,
1
);
let m12 = new Matrix3().premultiply(move1Matrix).premultiply(rotateMatrix).premultiply(move2Matrix);
for (let i2 = 0; i2 < models.length; i2++) {
let item = models[i2];
item.transVectors(m12);
item.updateLinkModels();
(_b2 = (_a3 = item.getTopContainer()) == null ? void 0 : _a3.render) == null ? void 0 : _b2.enableRefreshShape();
(_c2 = item.render) == null ? void 0 : _c2.enableRefreshShape();
}
selector.transVectors(m12);
pContainerModel.changeParentsBounds();
stage2.render.helpLines = { rect: { x: scx, y: scy, rotate: rotate2 < 0 ? 360 + rotate2 : rotate2 } };
return true;
}
/**
* 后置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelChangeRotate({ code: DDeiEnumBusCommandType.ModelChangeRotate, name: "", desc: "" });
}
}
const __vite_glob_0_18$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelChangeRotate,
default: DDeiBusCommandModelChangeRotate
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelChangeSelect extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置当前控件的选中状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2, _c2;
if (Array.isArray(data)) {
let models = data;
let stage2 = bus.ddInstance.stage;
for (let i2 = 0; i2 < models.length; i2++) {
if (models[i2]) {
let newData = models[i2];
let newValue = newData.value;
let model = stage2 == null ? void 0 : stage2.getModelById(newData.id);
if (model) {
if (model.state != newValue) {
model.state = newValue;
(_b2 = (_a3 = model.getTopContainer()) == null ? void 0 : _a3.render) == null ? void 0 : _b2.enableRefreshShape();
(_c2 = model.render) == null ? void 0 : _c2.enableRefreshShape();
}
}
}
}
return true;
} else if (typeof data == "object") {
let models = data.models;
let state = data.value;
if (models) {
models.forEach((item) => {
var _a22, _b22, _c22;
item.state = state;
(_b22 = (_a22 = item.getTopContainer()) == null ? void 0 : _a22.render) == null ? void 0 : _b22.enableRefreshShape();
(_c22 = item.render) == null ? void 0 : _c22.enableRefreshShape();
});
}
return true;
} else {
return false;
}
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
bus.insert(DDeiEnumBusCommandType.UpdateSelectorBounds, {}, evt, 1);
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelChangeSelect({ code: DDeiEnumBusCommandType.ModelChangeSelect, name: "", desc: "" });
}
}
const __vite_glob_0_19$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelChangeSelect,
default: DDeiBusCommandModelChangeSelect
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelChangeValue extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
var _a3, _b2, _c2;
let stage2 = bus.ddInstance.stage;
if (stage2 && (((_a3 = data == null ? void 0 : data.mids) == null ? void 0 : _a3.length) > 0 || ((_b2 = data == null ? void 0 : data.models) == null ? void 0 : _b2.length) > 0) && ((_c2 = data == null ? void 0 : data.paths) == null ? void 0 : _c2.length) > 0) {
let attrDefine = data.attrDefine;
if (attrDefine == null ? void 0 : attrDefine.readonly) {
return false;
}
}
return true;
}
/**
* 具体行为,设置属性值
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2, _c2, _d2;
let stage2 = bus.ddInstance.stage;
if (stage2 && (((_a3 = data == null ? void 0 : data.mids) == null ? void 0 : _a3.length) > 0 || ((_b2 = data == null ? void 0 : data.models) == null ? void 0 : _b2.length) > 0) && ((_c2 = data == null ? void 0 : data.paths) == null ? void 0 : _c2.length) > 0) {
let mids = data.mids;
let models = data.models;
let paths = data.paths;
let value = data.value;
let attrDefine = data.attrDefine;
if (((_d2 = data == null ? void 0 : data.paths) == null ? void 0 : _d2.indexOf("layout")) != -1)
;
else {
if ((mids == null ? void 0 : mids.length) > 0) {
models = [];
mids.forEach((modelId) => {
if (modelId) {
if (modelId == "DDeiStage") {
models.push(stage2);
} else if (modelId == "DDeiLayer") {
models.push(stage2 == null ? void 0 : stage2.layers[stage2 == null ? void 0 : stage2.layerIndex]);
} else {
let model = stage2 == null ? void 0 : stage2.getModelById(modelId);
if (model) {
models.push(model);
}
}
}
});
}
if ((models == null ? void 0 : models.length) > 0) {
models.forEach((model) => {
var _a22, _b22, _c22, _d22, _e2, _f, _g, _h, _i, _j, _k;
if (model) {
if (model.baseModelType == "DDeiTable") {
if ((attrDefine == null ? void 0 : attrDefine.modelCode) == "DDeiTable") {
DDeiUtil$1.setAttrValueByPath(model, paths, value);
} else {
let cells = model.getSelectedCells();
cells.forEach((cell) => {
paths.forEach((path) => {
var _a32;
DDeiUtil$1.setAttrValueByPath(cell, [path], value);
(_a32 = cell.render) == null ? void 0 : _a32.setCachedValue(path, value);
});
});
}
} else if (model.baseModelType == "DDeiLine") {
model.clps = [];
model.stage.render.refreshJumpLine = false;
DDeiUtil$1.setAttrValueByPath(model, paths, value);
(_a22 = model.render) == null ? void 0 : _a22.setCachedValue(paths, value);
} else {
DDeiUtil$1.setAttrValueByPath(model, paths, value);
(_b22 = model.render) == null ? void 0 : _b22.setCachedValue(paths, value);
}
let modelDefine = DDeiUtil$1.getControlDefine(model);
if ((_d22 = (_c22 = modelDefine == null ? void 0 : modelDefine.define) == null ? void 0 : _c22.sample) == null ? void 0 : _d22.depProps) {
let depProps = modelDefine.define.sample.depProps;
for (let type in depProps) {
let property = depProps[type];
let rmdms = [];
let hasTypeModel = false;
let modelPropValue = model[property];
(_e2 = model.linkModels) == null ? void 0 : _e2.forEach((lm) => {
var _a32, _b3;
if (lm.type == type && lm.dm) {
hasTypeModel = true;
if (modelPropValue) {
DDeiUtil$1.setAttrValueByPath(lm.dm, "text", modelPropValue);
(_a32 = lm.dm.render) == null ? void 0 : _a32.setCachedValue("text", modelPropValue);
(_b3 = lm.dm.render) == null ? void 0 : _b3.enableRefreshShape();
} else {
rmdms.push(lm);
}
}
});
if (hasTypeModel) {
rmdms.forEach((lm) => {
model.removeLinkModel(lm.dm.id, true, false);
});
} else if (modelPropValue) {
bus.insert(DDeiEnumBusCommandType.CreateDepLinkModel, { model, text: modelPropValue }, null, 0);
}
}
model.refreshLinkModels();
}
if (model.depModel) {
let modelDefine2 = DDeiUtil$1.getControlDefine(model.depModel);
if ((_g = (_f = modelDefine2 == null ? void 0 : modelDefine2.define) == null ? void 0 : _f.sample) == null ? void 0 : _g.depProps) {
let depProps = modelDefine2.define.sample.depProps;
let depLinkModel = (_h = model.depModel.linkModels) == null ? void 0 : _h.get(model.id);
let property = depProps[depLinkModel.type];
if (property && depLinkModel) {
DDeiUtil$1.setAttrValueByPath(model.depModel, property, model.text);
(_i = model.depModel.render) == null ? void 0 : _i.setCachedValue(property, model.text);
(_j = model.depModel.render) == null ? void 0 : _j.enableRefreshShape();
}
}
}
(_k = model.render) == null ? void 0 : _k.enableRefreshShape();
}
});
bus.executeAll();
}
}
return true;
}
return false;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
var _a3;
if (((_a3 = data == null ? void 0 : data.paths) == null ? void 0 : _a3.indexOf("layout")) != -1) {
bus == null ? void 0 : bus.insert(DDeiEnumBusCommandType.ChangeLayout, data, evt);
} else {
bus.push(DDeiEnumBusCommandType.NodifyChange);
bus.insert(DDeiEnumBusCommandType.AddHistroy);
}
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelChangeValue({ code: DDeiEnumBusCommandType.ModelChangeValue, name: "", desc: "" });
}
}
const __vite_glob_0_20$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelChangeValue,
default: DDeiBusCommandModelChangeValue
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelCopyStyle extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置属性值
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3;
let stage2 = bus.ddInstance.stage;
if (stage2 && ((_a3 = data == null ? void 0 : data.models) == null ? void 0 : _a3.length) > 0 && (data == null ? void 0 : data.brushData)) {
let models = data.models;
if ((models == null ? void 0 : models.length) > 0) {
models.forEach((model) => {
if (model) {
let hasChange = false;
if (model.baseModelType == "DDeiTable") {
if (Array.isArray(data.brushData) && !Array.isArray(data.brushData[0]) && data.brushData.length == 1) {
let cells = model.getSelectedCells();
cells.forEach((cell) => {
var _a22;
this.cloneStyle(cell, data.brushData[0]);
(_a22 = cell.render) == null ? void 0 : _a22.renderCacheData.clear();
hasChange = true;
});
} else if (Array.isArray(data.brushData) && Array.isArray(data.brushData[0])) {
this.copyTableStyleToTableCell(model, data.brushData);
hasChange = true;
}
} else {
if (Array.isArray(data.brushData) && !Array.isArray(data.brushData[0]) && data.brushData.length == 1) {
this.cloneStyle(model, data.brushData[0]);
hasChange = true;
} else if (Array.isArray(data.brushData) && Array.isArray(data.brushData[0])) {
this.cloneStyle(model, data.brushData[0][0]);
hasChange = true;
}
}
if (hasChange) {
bus.push(DDeiEnumBusCommandType.NodifyChange);
bus.insert(DDeiEnumBusCommandType.AddHistroy, null, evt);
}
}
});
}
return true;
}
return false;
}
/**
* 复制表格样式到另外一个表格的单元格中
* @param table 表格
* @param tableJson 单元格样式
*/
copyTableStyleToTableCell(table2, tableJson) {
let distCells = table2.getSelectedCells();
if (distCells && distCells.length > 0 && tableJson) {
let sourceTable = tableJson;
let distTable = table2;
let sourceMinMaxRow = { minRow: 0, minCol: 0, maxRow: sourceTable.length - 1, maxCol: sourceTable[0].length - 1 };
let distMinMaxRow = distTable.getMinMaxRowAndCol(distCells);
let distAreaAllSelected = distTable.isAllSelected(distMinMaxRow.minRow, distMinMaxRow.minCol, distMinMaxRow.maxRow, distMinMaxRow.maxCol);
if (!distAreaAllSelected) {
console.log("表格粘贴目标不是一个有效的连续区域");
return;
}
let rowNum = 1;
let colNum = 1;
let sourceRowNum = sourceMinMaxRow.maxRow - sourceMinMaxRow.minRow + 1;
let distRowNum = distMinMaxRow.maxRow - distMinMaxRow.minRow + 1;
let sourceColNum = sourceMinMaxRow.maxCol - sourceMinMaxRow.minCol + 1;
let distColNum = distMinMaxRow.maxCol - distMinMaxRow.minCol + 1;
if (distRowNum == sourceRowNum) {
rowNum = sourceRowNum;
} else if (distRowNum > sourceRowNum) {
rowNum = distRowNum - distRowNum % sourceRowNum;
} else if (distRowNum < sourceRowNum) {
rowNum = sourceRowNum;
}
if (distColNum == sourceColNum) {
colNum = sourceColNum;
} else if (distColNum > sourceColNum) {
colNum = distColNum - distColNum % sourceColNum;
} else if (distColNum < sourceColNum) {
colNum = sourceColNum;
}
if (distTable.hasMergeCell(distMinMaxRow.minRow, distMinMaxRow.minCol, distMinMaxRow.minRow + rowNum - 1, distMinMaxRow.minCol + colNum - 1)) {
console.log("表格复制样式区域存在合并单元格");
return;
}
if (distTable.rows.length <= distMinMaxRow.minRow + rowNum - 1 || distTable.cols.length <= distMinMaxRow.minCol + colNum - 1) {
console.log("表格复制样式区域超出表格所在最大区域");
return;
}
for (let i2 = 0; i2 < rowNum && distMinMaxRow.minRow + i2 < distTable.rows.length; i2++) {
let offsetI = i2 % sourceRowNum;
for (let j2 = 0; j2 < colNum && distMinMaxRow.minCol + j2 < distTable.cols.length; j2++) {
let offsetJ = j2 % sourceColNum;
let sourceCell = sourceTable[sourceMinMaxRow.minRow + offsetI][sourceMinMaxRow.minCol + offsetJ];
let targetCell = distTable.rows[distMinMaxRow.minRow + i2][distMinMaxRow.minCol + j2];
this.cloneStyle(targetCell, sourceCell);
}
}
}
}
/**
* 复制控件样式
* @param model
* @param sourceModel
*/
cloneStyle(model, sourceModel) {
var _a3;
if (model.baseModelType == "DDeiLine") {
if (sourceModel.fill) {
model.fill = cloneDeep(sourceModel.fill);
} else {
delete model.fill;
}
if (sourceModel.color) {
model.color = sourceModel.color;
} else {
delete model.color;
}
if (sourceModel.dash) {
model.dash = sourceModel.dash;
} else {
delete model.dash;
}
if (sourceModel.opacity) {
model.opacity = sourceModel.opacity;
} else {
delete model.opacity;
}
if (sourceModel.weight) {
model.weight = sourceModel.weight;
} else {
delete model.weight;
}
} else {
if (sourceModel.font) {
model.font = cloneDeep(sourceModel.font);
} else {
delete model.font;
}
if (sourceModel.textStyle) {
model.textStyle = cloneDeep(sourceModel.textStyle);
} else {
delete model.textStyle;
}
if (sourceModel.fill) {
model.fill = cloneDeep(sourceModel.fill);
} else {
delete model.fill;
}
if (sourceModel.border) {
model.border = cloneDeep(sourceModel.border);
} else {
delete model.border;
}
}
(_a3 = model.render) == null ? void 0 : _a3.renderCacheData.clear();
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelCopyStyle({ code: DDeiEnumBusCommandType.CopyStyle, name: "", desc: "" });
}
}
const __vite_glob_0_21$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelCopyStyle,
default: DDeiBusCommandModelCopyStyle
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelEdgePosition extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2, _c2, _d2, _e2, _f;
if (((_a3 = data == null ? void 0 : data.models) == null ? void 0 : _a3.length) > 0) {
let dx = data.dx ? data.dx : 0;
let dy = data.dy ? data.dy : 0;
let models = data.models;
let stage2 = bus.ddInstance.stage;
let ddInstance = stage2 == null ? void 0 : stage2.ddInstance;
if (models[0].id.lastIndexOf("_shadow") != -1) {
stage2 == null ? void 0 : stage2.getModelById(models[0].id.substring(models[0].id, models[0].id.lastIndexOf("_shadow")));
} else {
models[0];
}
if (dx || dy) {
stage2.wpv.x -= dx;
stage2.wpv.y -= dy;
let extW = 0;
let moveW = 0;
let hScrollWidth = ((_b2 = stage2.render.hScroll) == null ? void 0 : _b2.width) ? (_c2 = stage2.render.hScroll) == null ? void 0 : _c2.width : 0;
let vScrollHeight = ((_d2 = stage2.render.vScroll) == null ? void 0 : _d2.height) ? (_e2 = stage2.render.vScroll) == null ? void 0 : _e2.height : 0;
if (stage2.wpv.x > 0) {
if (ddInstance.EXT_STAGE_WIDTH) {
extW = stage2.wpv.x;
moveW = extW;
} else {
dx = 0;
}
stage2.wpv.x = 0;
} else if (stage2.wpv.x < -stage2.width + hScrollWidth) {
if (ddInstance.EXT_STAGE_WIDTH) {
extW = -stage2.width + hScrollWidth - stage2.wpv.x;
} else {
dx = 0;
stage2.wpv.x = -stage2.width + hScrollWidth;
}
} else if (!ddInstance.EXT_STAGE_WIDTH && hScrollWidth == 0) {
dx = 0;
}
let extH = 0;
let moveH = 0;
if (stage2.wpv.y > 0) {
if (ddInstance.EXT_STAGE_HEIGHT) {
extH = stage2.wpv.y;
moveH = extH;
} else {
dy = 0;
}
stage2.wpv.y = 0;
} else if (stage2.wpv.y < -stage2.height + vScrollHeight) {
if (ddInstance.EXT_STAGE_HEIGHT) {
extH = -stage2.height + vScrollHeight - stage2.wpv.y;
} else {
dy = 0;
stage2.wpv.y = -stage2.height + vScrollHeight;
}
} else if (!ddInstance.EXT_STAGE_HEIGHT && vScrollHeight == 0) {
dy = 0;
}
let ignoreModelIds = [];
let stageRatio2 = stage2 == null ? void 0 : stage2.getStageRatio();
if (dx || dy) {
models.forEach((model) => {
ignoreModelIds.push(model.id);
let moveMatrix2 = new Matrix3(
1,
0,
dx / stageRatio2,
0,
1,
dy / stageRatio2,
0,
0,
1
);
model.transVectors(moveMatrix2);
});
}
if (extW || extH) {
stage2.width += extW;
stage2.height += extH;
if (moveW || moveH) {
let moveMatrix2 = new Matrix3(
1,
0,
extW / stageRatio2,
0,
1,
extH / stageRatio2,
0,
0,
1
);
stage2 == null ? void 0 : stage2.spv.applyMatrix3(moveMatrix2);
let mds = stage2.getLayerModels(ignoreModelIds);
mds.forEach((item) => {
item.transVectors(moveMatrix2);
});
models.forEach((item) => {
item.transVectors(moveMatrix2);
});
(_f = stage2.render.selector) == null ? void 0 : _f.transVectors(moveMatrix2);
}
}
}
return true;
}
return false;
}
/**
* 后置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelEdgePosition({ code: DDeiEnumBusCommandType.ModelEdgePosition, name: "", desc: "" });
}
}
const __vite_glob_0_22$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelEdgePosition,
default: DDeiBusCommandModelEdgePosition
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelMerge extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
let ddInstance = bus.ddInstance;
if (ddInstance && ddInstance.stage) {
let layer2 = ddInstance.stage.layers[ddInstance.stage.layerIndex];
let selectedModels = layer2.getSelectedModels();
if (selectedModels.size > 1) {
return true;
}
}
return false;
}
/**
* 具体行为,设置属性值
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let ddInstance = bus.ddInstance;
if (ddInstance && ddInstance.stage) {
ddInstance.stage.getStageRatio();
let layer2 = ddInstance.stage.layers[ddInstance.stage.layerIndex];
let selectedModels = layer2.getSelectedModels();
if (selectedModels.size > 1) {
let models = Array.from(selectedModels.values());
let outRect = DDeiAbstractShape.getOutRectByPV(models);
let controlDefine = DDeiUtil$1.getControlDefine({ modelCode: "100202" });
let container2 = DDeiUtil$1.createControl(controlDefine, DDeiUtil$1.getEditorInsByDDei(ddInstance))[0];
container2.layout = "compose";
container2.layoutManager = DDeiLayoutManagerFactory.getLayoutInstance("compose");
container2.layoutManager.container = container2;
container2.fill = { type: 0 };
container2.border = { type: 0 };
let m12 = new Matrix3();
let scaleMatrix2 = new Matrix3(
outRect.width / container2.essBounds.width,
0,
0,
0,
outRect.height / container2.essBounds.height,
0,
0,
0,
1
);
m12.premultiply(scaleMatrix2);
let moveMatrix2 = new Matrix3(
1,
0,
outRect.x + outRect.width / 2,
0,
1,
outRect.y + outRect.height / 2,
0,
0,
1
);
m12.premultiply(moveMatrix2);
container2.transVectors(m12);
ddInstance.bus.insert(DDeiEnumBusCommandType.ModelChangeContainer, { newContainer: ddInstance.stage.layers[ddInstance.stage.layerIndex], models: [container2], skipValid: true }, evt, 0);
ddInstance.bus.insert(DDeiEnumBusCommandType.ModelChangeContainer, { newContainer: container2, oldContainer: layer2, models, skipValid: true }, evt, 1);
ddInstance.bus.insert(DDeiEnumBusCommandType.ModelChangeSelect, { models: [container2], value: DDeiEnumControlState.SELECTED }, evt, 2);
ddInstance.bus.insert(DDeiEnumBusCommandType.ClearTemplateVars, null, evt, 3);
ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
ddInstance.bus.insert(DDeiEnumBusCommandType.AddHistroy, null, evt, 4);
ddInstance.bus.insert(DDeiEnumBusCommandType.StageChangeSelectModels, null, evt, 5);
ddInstance.bus.insert(DDeiEnumBusCommandType.RefreshShape, null, evt, 6);
return true;
}
}
return false;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelMerge({ code: DDeiEnumBusCommandType.ModelMerge, name: "", desc: "" });
}
}
const __vite_glob_0_23$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelMerge,
default: DDeiBusCommandModelMerge
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelPush extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
if ((data == null ? void 0 : data.container) && (data == null ? void 0 : data.type)) {
if ((data == null ? void 0 : data.type) == "top" || (data == null ? void 0 : data.type) == "bottom" || (data == null ? void 0 : data.type) == "up" || (data == null ? void 0 : data.type) == "down") {
let selectedModels = data == null ? void 0 : data.container.getSelectedModels();
if ((selectedModels == null ? void 0 : selectedModels.size) > 0) {
return true;
}
}
}
return false;
}
/**
* 具体行为,重绘所有图形
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let selectedModels = data == null ? void 0 : data.container.getSelectedModels();
let hasChange = false;
if ((data == null ? void 0 : data.type) == "top") {
data.container.pushTop(Array.from(selectedModels.values()));
hasChange = true;
} else if ((data == null ? void 0 : data.type) == "bottom") {
data.container.pushBottom(Array.from(selectedModels.values()));
hasChange = true;
} else if ((data == null ? void 0 : data.type) == "up") {
data.container.pushUp(Array.from(selectedModels.values()));
hasChange = true;
} else if ((data == null ? void 0 : data.type) == "down") {
data.container.pushDown(Array.from(selectedModels.values()));
hasChange = true;
}
if (hasChange) {
bus.push(DDeiEnumBusCommandType.NodifyChange);
bus.insert(DDeiEnumBusCommandType.AddHistroy, null, evt);
}
return true;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelPush({ code: DDeiEnumBusCommandType.ModelPush, name: "", desc: "" });
}
}
const __vite_glob_0_24$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelPush,
default: DDeiBusCommandModelPush
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandModelRemove extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let models = data == null ? void 0 : data.models;
let destroy = (data == null ? void 0 : data.destroy) || (data == null ? void 0 : data.destroy) == false ? data.destroy : true;
if ((models == null ? void 0 : models.length) > 0) {
models.forEach((model) => {
model.pModel.removeModel(model, destroy);
});
return true;
}
return false;
}
/**
* 后置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandModelRemove({ code: DDeiEnumBusCommandType.ModelRemove, name: "", desc: "" });
}
}
const __vite_glob_0_25$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandModelRemove,
default: DDeiBusCommandModelRemove
}, Symbol.toStringTag, { value: "Module" }));
class DDeiCommandChangeNodifyChange extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiCommandChangeNodifyChange({ code: DDeiEnumBusCommandType.NodifyChange, name: "", desc: "" });
}
}
const __vite_glob_0_26$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiCommandChangeNodifyChange,
default: DDeiCommandChangeNodifyChange
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandNodifyControlCreated extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置当前控件的选中状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
if (data == null ? void 0 : data.models) {
DDeiEditorUtil$1.invokeCallbackFunc("EVENT_CONTROL_CREATE_AFTER", DDeiEnumOperateType.CREATE, data, bus.ddInstance, evt);
}
return true;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandNodifyControlCreated({ code: DDeiEnumBusCommandType.NodifyControlCreated, name: "", desc: "" });
}
}
const __vite_glob_0_27$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandNodifyControlCreated,
default: DDeiBusCommandNodifyControlCreated
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandOVSChangePosition extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2, _c2;
let stage2 = bus.ddInstance.stage;
let stageRender = stage2 == null ? void 0 : stage2.render;
let x2 = (data == null ? void 0 : data.x) ? data.x : 0;
let y2 = (data == null ? void 0 : data.y) ? data.y : 0;
if ((x2 || y2) && stageRender.dragObj) {
let dragObj = stageRender.dragObj;
let model = dragObj.model;
let opPoint = dragObj.opPoint;
let modelPointIdx = model.ovs.indexOf(opPoint);
let ovsDefine = (_b2 = (_a3 = DDeiUtil$1.getControlDefine(model)) == null ? void 0 : _a3.define) == null ? void 0 : _b2.ovs;
let point2 = null;
if ((ovsDefine == null ? void 0 : ovsDefine.length) > modelPointIdx) {
point2 = ovsDefine[modelPointIdx];
}
if (point2) {
let m12 = new Matrix3();
let mr = null;
let dx = x2 - opPoint.x, dy = y2 - opPoint.y;
if (point2.constraint) {
switch (point2.constraint.type) {
case 0: {
return true;
}
case 1: {
let pathPvs = [];
let pvsStr = point2.constraint.pvs;
if ((pvsStr == null ? void 0 : pvsStr.length) > 0) {
pvsStr.forEach((pvsS) => {
let pvsData = DDeiUtil$1.getDataByPathList(model, pvsS);
if (Array.isArray(pvsData)) {
pvsData.forEach((pvsD) => {
pathPvs.push(pvsD);
});
} else {
pathPvs.push(pvsData);
}
});
}
if (pathPvs.length > 1) {
let proPoints = DDeiAbstractShape.getProjPointDists(pathPvs, x2, y2, false, 1);
if ((proPoints == null ? void 0 : proPoints.length) > 0) {
opPoint.index = proPoints[0].index;
let distance = DDeiUtil$1.getPointDistance(pathPvs[proPoints[0].index].x, pathPvs[proPoints[0].index].y, pathPvs[proPoints[0].index + 1].x, pathPvs[proPoints[0].index + 1].y);
let sita = DDeiUtil$1.getLineAngle(pathPvs[proPoints[0].index].x, pathPvs[proPoints[0].index].y, pathPvs[proPoints[0].index + 1].x, pathPvs[proPoints[0].index + 1].y);
let pointDistance = DDeiUtil$1.getPointDistance(pathPvs[proPoints[0].index].x, pathPvs[proPoints[0].index].y, proPoints[0].x, proPoints[0].y);
let rate = pointDistance / distance;
let ovSita = opPoint.sita;
if (!ovSita) {
ovSita = 0;
}
opPoint.rate = rate > 1 ? rate : rate;
opPoint.sita = sita;
dx = proPoints[0].x - opPoint.x;
dy = proPoints[0].y - opPoint.y;
if (sita != ovSita) {
mr = new Matrix3();
let move1Matrix = new Matrix3(
1,
0,
-proPoints[0].x,
0,
1,
-proPoints[0].y,
0,
0,
1
);
let angle2 = (-(sita - ovSita) * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
let move2Matrix = new Matrix3(
1,
0,
proPoints[0].x,
0,
1,
proPoints[0].y,
0,
0,
1
);
mr.premultiply(move1Matrix).premultiply(rotateMatrix).premultiply(move2Matrix);
}
} else {
dx = 0;
dy = 0;
}
}
break;
}
case 2: {
let rotate2 = model.rotate;
if (!rotate2) {
rotate2 = 0;
}
let angle2 = (-rotate2 * DDeiConfig$1.ROTATE_UNIT).toFixed(4);
let moveMatrix22 = new Matrix3(
1,
0,
model.cpv.x,
0,
1,
model.cpv.y,
0,
0,
1
);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
let bpv2 = DDeiUtil$1.pointsToZero([model.bpv], model.cpv, rotate2)[0];
let scaleX2 = Math.abs(bpv2.x / 100);
let scaleY2 = Math.abs(bpv2.y / 100);
let scaleMatrix2 = new Matrix3(
scaleX2,
0,
0,
0,
scaleY2,
0,
0,
0,
1
);
let pv1 = new Vector3(point2.constraint.x0, point2.constraint.y0, 1);
let pv2 = new Vector3(point2.constraint.x1, point2.constraint.y1, 1);
let outPVS = DDeiAbstractShape.outRectToPV(DDeiAbstractShape.pvsToOutRect([pv1, pv2]));
let m122 = new Matrix3().premultiply(scaleMatrix2).premultiply(rotateMatrix).premultiply(moveMatrix22);
outPVS.forEach((pv) => {
pv.applyMatrix3(m122);
});
if (!DDeiAbstractShape.isInsidePolygon(outPVS, { x: x2, y: y2 })) {
let proPoints = DDeiAbstractShape.getProjPointDists(outPVS, x2, y2, false, 1);
if ((proPoints == null ? void 0 : proPoints.length) > 0) {
dx = proPoints[0].x - opPoint.x;
dy = proPoints[0].y - opPoint.y;
} else {
dx = 0;
dy = 0;
}
}
break;
}
case 3: {
let distance = DDeiUtil$1.getPointDistance(x2, y2, model.cpv.x, model.cpv.y);
let rotate2 = model.rotate;
if (!rotate2) {
rotate2 = 0;
}
let bpv2 = DDeiUtil$1.pointsToZero([model.bpv], model.cpv, rotate2)[0];
let scaleX2 = Math.abs(bpv2.x / 100);
let r = point2.constraint.r * scaleX2;
if (Math.abs(distance) > r) {
let pointAngle = DDeiUtil$1.getLineAngle(model.cpv.x, model.cpv.y, x2, y2);
let pointRad = pointAngle * DDeiConfig$1.ROTATE_UNIT;
let fx = model.cpv.x + r * Math.cos(pointRad);
let fy = model.cpv.y + r * Math.sin(pointRad);
dx = fx - opPoint.x, dy = fy - opPoint.y;
}
break;
}
}
}
let moveMatrix2 = new Matrix3(
1,
0,
dx,
0,
1,
dy,
0,
0,
1
);
m12.premultiply(moveMatrix2);
if (mr) {
m12.premultiply(mr);
}
opPoint.applyMatrix3(moveMatrix2);
model.updateOVSLink(opPoint, point2, m12);
model.initPVS();
(_c2 = model.render) == null ? void 0 : _c2.enableRefreshShape();
return true;
}
}
return false;
}
/**
* 后置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds, data, evt);
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandOVSChangePosition({ code: DDeiEnumBusCommandType.OVSChangePosition, name: "", desc: "" });
}
}
const __vite_glob_0_28$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandOVSChangePosition,
default: DDeiBusCommandOVSChangePosition
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandRefreshShape extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,重绘所有图形
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let stage2 = bus.ddInstance.stage;
if (stage2) {
stage2.render.refresh = true;
return true;
} else {
return false;
}
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandRefreshShape({ code: DDeiEnumBusCommandType.RefreshShape, name: "", desc: "" });
}
}
const __vite_glob_0_29$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandRefreshShape,
default: DDeiBusCommandRefreshShape
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandResetSelectorState extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let stage2 = bus.ddInstance.stage;
if (stage2 && stage2.render.selector) {
stage2.render.selector.resetState(data == null ? void 0 : data.x, data == null ? void 0 : data.y);
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandResetSelectorState({ code: DDeiEnumBusCommandType.ResetSelectorState, name: "", desc: "" });
}
}
const __vite_glob_0_30$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandResetSelectorState,
default: DDeiBusCommandResetSelectorState
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandSetHelpLine extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2;
let stage2 = bus.ddInstance.stage;
if (stage2) {
let layer2 = data.layer;
if (!layer2) {
layer2 = stage2.layers[stage2.layerIndex];
}
if (((_a3 = data == null ? void 0 : data.models) == null ? void 0 : _a3.length) > 0 || ((_b2 = data == null ? void 0 : data.models) == null ? void 0 : _b2.size) > 0 || (data == null ? void 0 : data.container)) {
let models = data == null ? void 0 : data.models;
if (!models && (data == null ? void 0 : data.container)) {
models = data == null ? void 0 : data.container.getSelectedModels();
}
if (models.set) {
models = Array.from(models.values());
}
if ((models == null ? void 0 : models.length) > 0) {
let outRect = null;
let rotate2 = null;
let apvs2 = [];
models.forEach((model) => {
let modelAPVS = model.getAPVS();
if ((modelAPVS == null ? void 0 : modelAPVS.length) > 0) {
apvs2 = apvs2.concat(modelAPVS);
}
});
if (models.length == 1) {
rotate2 = models[0].rotate;
} else {
rotate2 = stage2.render.selector.rotate;
}
outRect = DDeiAbstractShape.getOutRectByPV(models);
let { hpoint, vpoint, hAds, vAds } = stage2.getAlignData({ pvs: apvs2, rotate: rotate2 }, data == null ? void 0 : data.models, data == null ? void 0 : data.points);
stage2.render.helpLines = {
hpoint,
vpoint,
rect: outRect,
hAds,
vAds
};
return true;
} else {
stage2.render.helpLines = null;
return true;
}
} else {
stage2.render.helpLines = null;
return true;
}
}
return false;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandSetHelpLine({ code: DDeiEnumBusCommandType.SetHelpLine, name: "", desc: "" });
}
}
const __vite_glob_0_31$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandSetHelpLine,
default: DDeiBusCommandSetHelpLine
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandStageChangeSelectModels extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
if (bus.ddInstance.disabled) {
return false;
}
return true;
}
/**
* 具体行为,设置当前控件的选中状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3;
let stage2 = bus.ddInstance.stage;
let editor = bus.invoker;
if (stage2) {
let optContainer = stage2.render.currentOperateContainer;
if (!optContainer) {
optContainer = stage2.layers[stage2.layerIndex];
}
let selectedModels = optContainer.getSelectedModels();
let oldSelectModels = stage2.selectedModels;
stage2.changeSelecetdModels(selectedModels);
let hasChange = false;
let newSelectModels = stage2.selectedModels;
if ((oldSelectModels == null ? void 0 : oldSelectModels.size) !== (newSelectModels == null ? void 0 : newSelectModels.size)) {
hasChange = true;
}
if (!hasChange) {
for (let key of oldSelectModels == null ? void 0 : oldSelectModels.keys()) {
if ((oldSelectModels == null ? void 0 : oldSelectModels.get(key)) !== (newSelectModels == null ? void 0 : newSelectModels.get(key))) {
hasChange = false;
break;
}
}
}
if ((selectedModels == null ? void 0 : selectedModels.size) > 0) {
let models = Array.from(selectedModels.values());
let firstModel = models[0];
let firstControlDefine = cloneDeep(
editor.controls.get(firstModel == null ? void 0 : firstModel.modelCode)
);
if (firstControlDefine) {
let removeKeys = [];
for (let i2 = 0; i2 < models.length; i2++) {
let curModel = models[i2];
let curDefine = editor.controls.get(curModel.modelCode);
firstControlDefine.attrDefineMap.forEach(
(firstAttrDefine, attrKey) => {
if (!curDefine.attrDefineMap.has(attrKey)) {
removeKeys.push(attrKey);
firstAttrDefine.model = curModel;
} else if (!firstAttrDefine.visiable) {
removeKeys.push(attrKey);
firstAttrDefine.model = curModel;
} else {
let curAttrDefine = curDefine.attrDefineMap.get(attrKey);
if (i2 == 0) {
firstAttrDefine.value = DDeiUtil$1.getDataByPathList(
firstModel,
curAttrDefine.code,
curAttrDefine.mapping
);
firstAttrDefine.model = firstModel;
}
let curAttrValue = DDeiUtil$1.getDataByPathList(
curModel,
curAttrDefine.code,
curAttrDefine.mapping
);
if (firstAttrDefine.value != curAttrValue) {
firstAttrDefine.diffValues.push(curAttrValue);
}
}
}
);
}
this.deleteAttrDefineByKeys(firstControlDefine, removeKeys);
if (((_a3 = firstControlDefine.groups) == null ? void 0 : _a3.length) > 0) {
editor.currentControlDefine = firstControlDefine;
} else {
editor.currentControlDefine = null;
}
}
} else {
editor.currentControlDefine = null;
}
selectedModels == null ? void 0 : selectedModels.forEach((model) => {
var _a22;
(_a22 = model.render) == null ? void 0 : _a22.clearCachedValue();
});
oldSelectModels == null ? void 0 : oldSelectModels.forEach((model) => {
var _a22;
(_a22 = model.render) == null ? void 0 : _a22.clearCachedValue();
});
DDeiEditorUtil$1.invokeCallbackFunc("EVENT_CONTROL_SELECT_AFTER", DDeiEnumOperateType.SELECT, { models: Array.from(selectedModels.values()) }, bus.ddInstance, evt);
return true;
}
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
return true;
}
/**
* 移除属性定义中的属性
* @param firstControlDefine
* @param removeKeys
*/
deleteAttrDefineByKeys(firstControlDefine, removeKeys) {
removeKeys.forEach((item) => {
var _a3;
firstControlDefine.attrDefineMap.delete(item);
(_a3 = firstControlDefine.groups) == null ? void 0 : _a3.forEach((group2) => {
this.deleteGroupAttrsByKey(group2, item);
});
});
}
deleteGroupAttrsByKey(pData, key) {
let rmglist = [];
pData.subGroups.forEach((group2) => {
let rmlist = [];
for (let gci = 0; gci < group2.children.length; gci++) {
if (group2.children[gci].code == key) {
rmlist.push(group2.children[gci]);
}
}
rmlist.forEach((rm) => {
let index = group2.children.indexOf(rm);
if (index > -1) {
group2.children.splice(index, 1);
}
});
if (group2.children.length == 0) {
rmglist.push(group2);
}
});
rmglist.forEach((rmg) => {
let index = pData.subGroups.indexOf(rmg);
if (index > -1) {
pData.subGroups.splice(index, 1);
}
});
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandStageChangeSelectModels({ code: DDeiEnumBusCommandType.StageChangeSelectModels, name: "", desc: "" });
}
}
const __vite_glob_0_32$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandStageChangeSelectModels,
default: DDeiBusCommandStageChangeSelectModels
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandTextEditorChangeSelectPos extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置当前控件的选中状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
return true;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandTextEditorChangeSelectPos({ code: DDeiEnumBusCommandType.TextEditorChangeSelectPos, name: "", desc: "" });
}
}
const __vite_glob_0_33$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandTextEditorChangeSelectPos,
default: DDeiBusCommandTextEditorChangeSelectPos
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandUpdateDragObj extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let stage2 = bus.ddInstance.stage;
if (stage2) {
if (data == null ? void 0 : data.dragObj) {
stage2.render.dragObj = data.dragObj;
} else {
if (data.deltaX) {
stage2.render.dragObj.x += data.deltaX;
}
if (data.deltaY) {
stage2.render.dragObj.y += data.deltaY;
}
}
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandUpdateDragObj({ code: DDeiEnumBusCommandType.UpdateDragObj, name: "", desc: "" });
}
}
const __vite_glob_0_34$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandUpdateDragObj,
default: DDeiBusCommandUpdateDragObj
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandUpdatePaperArea extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 更新纸张,确保有效纸张位置在整个画布的正中央
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2;
let stage2 = bus.ddInstance.stage;
let paperType;
if ((_a3 = stage2.paper) == null ? void 0 : _a3.type) {
paperType = stage2.paper.type;
} else if (stage2.ddInstance.paper) {
if (typeof stage2.ddInstance.paper == "string") {
paperType = stage2.ddInstance.paper;
} else {
paperType = stage2.ddInstance.paper.type;
}
} else {
paperType = DDeiModelArrtibuteValue.getAttrValueByState(stage2, "paper.type", true);
}
let paperConfig = DDeiConfig$1.PAPER[paperType];
let stageRatio2 = stage2 == null ? void 0 : stage2.getStageRatio();
let paperWidth, paperHeight;
let mds;
if (paperConfig) {
let paperSize = DDeiUtil$1.getPaperSize(stage2, paperType, false);
paperWidth = paperSize.width;
paperHeight = paperSize.height;
} else {
mds = stage2 == null ? void 0 : stage2.getLayerModels(null, 100);
let outRect = DDeiAbstractShape.getOutRectByPV(mds);
paperWidth = outRect.width * stageRatio2;
paperHeight = outRect.height * stageRatio2;
}
let wpv = stage2.wpv;
if (!stage2.spv) {
let sx = stage2.width / 2 - paperWidth / stageRatio2 / 2;
let sy = stage2.height / 2 - paperHeight / stageRatio2 / 2;
stage2.spv = new Vector3(sx, sy, 1);
}
let startPaperX = stage2.spv.x * stageRatio2;
let startPaperY = stage2.spv.y * stageRatio2;
let maxOutRect = DDeiAbstractShape.getOutRectByPV(stage2.getLayerModels());
maxOutRect.x = maxOutRect.x * stageRatio2;
maxOutRect.x1 = maxOutRect.x1 * stageRatio2;
maxOutRect.y = maxOutRect.y * stageRatio2;
maxOutRect.y1 = maxOutRect.y1 * stageRatio2;
maxOutRect.width = maxOutRect.width * stageRatio2;
maxOutRect.height = maxOutRect.height * stageRatio2;
let leftExtNum = 0, rightExtNum = 0, topExtNum = 0, bottomExtNum = 0;
if (maxOutRect.width > 0 && maxOutRect.height > 0) {
if (maxOutRect.x < startPaperX) {
leftExtNum = parseInt((startPaperX - maxOutRect.x) / paperWidth);
if (Math.abs((startPaperX - maxOutRect.x) % paperWidth) > 1) {
leftExtNum++;
}
}
if (maxOutRect.x1 > startPaperX + paperWidth) {
rightExtNum = parseInt((maxOutRect.x1 - startPaperX - paperWidth) / paperWidth);
if (Math.abs((maxOutRect.x1 - startPaperX - paperWidth) % paperWidth) > 1) {
rightExtNum++;
}
}
if (maxOutRect.y < startPaperY) {
topExtNum = parseInt((startPaperY - maxOutRect.y) / paperHeight);
if (Math.abs((startPaperY - maxOutRect.y) % paperHeight) > 1) {
topExtNum++;
}
}
if (maxOutRect.y1 > startPaperY + paperHeight) {
bottomExtNum = parseInt((maxOutRect.y1 - startPaperY - paperHeight) / paperHeight);
if (Math.abs((maxOutRect.y1 - startPaperY - paperHeight) % paperHeight) > 1) {
bottomExtNum++;
}
}
}
let leftPaperWidth = (leftExtNum + 0.5) * paperWidth;
let rightPaperWidth = (rightExtNum + 1.5) * paperWidth;
let leftSpace = stage2.spv.x * stageRatio2;
let rightSpace = stage2.width - stage2.spv.x * stageRatio2;
let topPaperWidth = (topExtNum + 0.5) * paperHeight;
let bottomPaperWidth = (bottomExtNum + 1.5) * paperHeight;
let topSpace = stage2.spv.y * stageRatio2;
let bottomSpace = stage2.height - stage2.spv.y * stageRatio2;
let extW = 0, extH = 0;
let needMoveX = false, needMoveY = false;
if (rightPaperWidth > rightSpace) {
extW = rightPaperWidth - rightSpace;
} else if (rightSpace - rightPaperWidth >= paperWidth) {
extW = -parseInt((rightSpace - rightPaperWidth) / paperWidth) * paperWidth;
}
if (leftPaperWidth > leftSpace) {
extW = leftPaperWidth - leftSpace;
needMoveX = true;
} else if (parseFloat((leftSpace - leftPaperWidth).toFixed(2)) > parseFloat(paperWidth.toFixed(2))) {
extW = -parseInt((leftSpace - leftPaperWidth) / paperWidth) * paperWidth;
needMoveX = true;
}
if (bottomPaperWidth > bottomSpace) {
extH = bottomPaperWidth - bottomSpace;
} else if (bottomSpace - bottomPaperWidth >= paperHeight) {
extH = -parseInt((bottomSpace - bottomPaperWidth) / paperHeight) * paperHeight;
}
if (topPaperWidth > topSpace) {
extH = topPaperWidth - topSpace;
needMoveY = true;
} else if (parseFloat((topSpace - topPaperWidth).toFixed(2)) > parseFloat(paperHeight.toFixed(2))) {
extH = -parseInt((topSpace - topPaperWidth) / paperHeight) * paperHeight;
needMoveY = true;
}
if (!bus.ddInstance.EXT_STAGE_WIDTH) {
extW = 0;
}
if (!bus.ddInstance.EXT_STAGE_HEIGHT) {
extH = 0;
}
if (extW || extH) {
stage2.width += extW;
stage2.height += extH;
let mx = 0, my = 0;
if (needMoveX) {
mx = extW;
}
if (needMoveY) {
my = extH;
}
if (mx || my) {
let moveMatrix2 = new Matrix3(
1,
0,
mx / stageRatio2,
0,
1,
my / stageRatio2,
0,
0,
1
);
stage2.spv.x += mx / stageRatio2;
stage2.spv.y += my / stageRatio2;
if (!mds) {
mds = stage2.getLayerModels();
}
mds.forEach((item) => {
item.transVectors(moveMatrix2);
});
(_b2 = stage2.render.selector) == null ? void 0 : _b2.transVectors(moveMatrix2);
wpv.x -= mx;
wpv.y -= my;
}
}
return true;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandUpdatePaperArea({ code: DDeiEnumBusCommandType.UpdatePaperArea, name: "", desc: "" });
}
}
const __vite_glob_0_35$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandUpdatePaperArea,
default: DDeiBusCommandUpdatePaperArea
}, Symbol.toStringTag, { value: "Module" }));
class DDeiBusCommandUpdateSelectorBounds extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置当前控件的选中状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let stage2 = bus.ddInstance.stage;
if (stage2) {
let optContainer = stage2.render.currentOperateContainer;
if (!optContainer) {
optContainer = stage2.layers[stage2.layerIndex];
}
if (optContainer) {
let selector = stage2.render.selector;
if (selector) {
if ((data == null ? void 0 : data.operateState) == DDeiEnumOperateState.SELECT_WORKING) {
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= stage2.wpv.x;
ey -= stage2.wpv.y;
let stageRatio2 = stage2.getStageRatio();
ex = ex / stageRatio2;
ey = ey / stageRatio2;
let x2 = selector.startX;
let y2 = selector.startY;
let width, height;
if (ex < x2) {
width = x2 - ex;
x2 = ex;
} else {
width = ex - x2;
}
if (ey < y2) {
height = y2 - ey;
y2 = ey;
} else {
height = ey - y2;
}
selector.updatePVSByRect(x2, y2, width, height);
} else {
let models = data == null ? void 0 : data.models;
if (!(models == null ? void 0 : models.length) > 0 && !(models == null ? void 0 : models.size) > 0) {
models = stage2.selectedModels;
}
if (!(models == null ? void 0 : models.length) > 0 && !(models == null ? void 0 : models.size) > 0) {
models = optContainer.getSelectedModels();
}
selector.updatePVSByModels(models);
}
}
}
}
return true;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiBusCommandUpdateSelectorBounds({ code: DDeiEnumBusCommandType.UpdateSelectorBounds, name: "", desc: "" });
}
}
const __vite_glob_0_36$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiBusCommandUpdateSelectorBounds,
default: DDeiBusCommandUpdateSelectorBounds
}, Symbol.toStringTag, { value: "Module" }));
const COMMANDS = /* @__PURE__ */ new Map();
const addCommand = function(code, command) {
COMMANDS.set(code, command);
};
const control_ctx$2 = /* @__PURE__ */ Object.assign({ "./bus/commands/add-histroy.ts": __vite_glob_0_0$3$1, "./bus/commands/cancel-curlevel-selected-models.ts": __vite_glob_0_1$3$1, "./bus/commands/center-stage-wpv.ts": __vite_glob_0_2$3, "./bus/commands/change-cursor.ts": __vite_glob_0_3$1$1, "./bus/commands/change-edit-mode.ts": __vite_glob_0_4$1$1, "./bus/commands/change-layout.ts": __vite_glob_0_5$1$1, "./bus/commands/change-line-point.ts": __vite_glob_0_6$1$1, "./bus/commands/change-selector-passindex.ts": __vite_glob_0_7$2, "./bus/commands/change-stage-ratio.ts": __vite_glob_0_8$2, "./bus/commands/change-stage-wpv.ts": __vite_glob_0_9$2, "./bus/commands/clear-template-vars.ts": __vite_glob_0_10$2, "./bus/commands/create-dep-linkmodel.ts": __vite_glob_0_11$2, "./bus/commands/model-align.ts": __vite_glob_0_12$2, "./bus/commands/model-auto-pos.ts": __vite_glob_0_13$2, "./bus/commands/model-cancel-merge.ts": __vite_glob_0_14$2, "./bus/commands/model-change-bounds.ts": __vite_glob_0_15$2, "./bus/commands/model-change-container.ts": __vite_glob_0_16$2, "./bus/commands/model-change-position.ts": __vite_glob_0_17$2, "./bus/commands/model-change-rotate.ts": __vite_glob_0_18$2, "./bus/commands/model-change-select.ts": __vite_glob_0_19$2, "./bus/commands/model-change-value.ts": __vite_glob_0_20$2, "./bus/commands/model-copy-style.ts": __vite_glob_0_21$2, "./bus/commands/model-edge-position.ts": __vite_glob_0_22$2, "./bus/commands/model-merge.ts": __vite_glob_0_23$2, "./bus/commands/model-push.ts": __vite_glob_0_24$2, "./bus/commands/model-remove.ts": __vite_glob_0_25$2, "./bus/commands/nodify-change.ts": __vite_glob_0_26$2, "./bus/commands/nodify-control-created.ts": __vite_glob_0_27$2, "./bus/commands/ovs-change-position.ts": __vite_glob_0_28$2, "./bus/commands/refresh-shape.ts": __vite_glob_0_29$2, "./bus/commands/reset-selector-state.ts": __vite_glob_0_30$2, "./bus/commands/set-helpline.ts": __vite_glob_0_31$2, "./bus/commands/stage-change-select-models.ts": __vite_glob_0_32$2, "./bus/commands/texteditor-change-select-pos.ts": __vite_glob_0_33$2, "./bus/commands/update-drawobj.ts": __vite_glob_0_34$2, "./bus/commands/update-paper-area.ts": __vite_glob_0_35$2, "./bus/commands/update-selector-bounds.ts": __vite_glob_0_36$2 });
let loadArray = [];
for (const path in control_ctx$2) {
loadArray.push(control_ctx$2[path]);
}
loadArray.forEach((item) => {
let command = item.default;
if (command) {
let cmdInst = command.newInstance();
if (cmdInst == null ? void 0 : cmdInst.code) {
addCommand(cmdInst.code, cmdInst);
}
}
});
class DDeiBus {
// ============================ 构造函数 ============================
constructor(props) {
__publicField2(this, "ddInstance");
__publicField2(this, "invoker");
__publicField2(this, "drawQueue", []);
__publicField2(this, "queue", []);
__publicField2(this, "interceptor", {});
this.ddInstance = props.ddInstance;
this.invoker = props.invoker;
}
// ============================ 方法 ============================
/**
* 插入事件进入总线指定位置,默认最前方
* @param actionType 类型
* @param data 承载数据
* @param evt 事件
*/
insert(actionType, data, evt, index = 0, parallel = false) {
if (actionType) {
this.queue.splice(index, 0, { type: actionType, data, evt, parallel });
}
}
/**
* 推送事件进入总线
* @param actionType 类型
* @param data 承载数据
* @param evt 事件
*/
push(actionType, data, evt, parallel = false) {
parallel = false;
if (actionType) {
this.queue.push({ type: actionType, data, evt, parallel });
}
}
/**
* 推送多个事件进入总线
* @param actions 多个action
* @param evt 事件
*/
pushMulit(actions, evt) {
if (actions) {
actions.forEach((item) => {
this.push(item.actionType, item.data, evt);
});
}
}
/**
* 延迟执行
* @param time 延迟执行时间
*/
executeAllDelay(time) {
setTimeout(() => {
this.executeAll();
}, time);
}
/**
* 按照先进先出的顺序执行所有action
*/
executeAll() {
var _a3, _b2;
let result = true;
this.tempExecQueue = clone(this.queue);
while (((_a3 = this == null ? void 0 : this.queue) == null ? void 0 : _a3.length) > 0 && result) {
let paralCommands = [];
let firstActionData = this.queue[0];
if (firstActionData.parallel == true) {
for (let i2 = 0; i2 < this.queue.length; i2++) {
let command = this.queue[i2];
if (command.parallel == true) {
let commandAction = new Promise((resolve, reject) => {
this.execute(command);
});
paralCommands.push(commandAction);
} else {
break;
}
}
this.queue.splice(0, paralCommands.length);
Promise.all(paralCommands);
} else {
result = this.execute();
}
}
if (((_b2 = this == null ? void 0 : this.drawQueue) == null ? void 0 : _b2.length) > 0 && result) {
result = this.executeDraw();
this.drawQueue = [];
}
}
restoreQueue() {
var _a3;
if (((_a3 = this.tempExecQueue) == null ? void 0 : _a3.length) > 0) {
this.queue = this.tempExecQueue;
}
}
/**
* 取出队列并执行
*/
execute(command) {
var _a3, _b2, _c2, _d2, _e2, _f;
if (this.queue && this.queue.length > 0) {
let firstActionData = null;
if (!command) {
firstActionData = this.queue[0];
this.queue.splice(0, 1);
} else {
firstActionData = command;
}
let action = null;
if (firstActionData) {
if (firstActionData.type == DDeiEnumBusCommandType.RefreshShape) {
this.drawQueue.push(firstActionData);
return true;
}
action = COMMANDS.get(firstActionData.type);
if (action) {
if ((_a3 = this.interceptor[firstActionData.type]) == null ? void 0 : _a3.before) {
let interActions = (_b2 = this.interceptor[firstActionData.type]) == null ? void 0 : _b2.before;
for (let ii = 0; ii < interActions.length; ii++) {
let result = interActions[ii](firstActionData.data, this, firstActionData.evt);
if (!result) {
return false;
}
}
}
let validResult = action.before(firstActionData.data, this, firstActionData.evt);
if (validResult) {
if ((_c2 = this.interceptor[firstActionData.type]) == null ? void 0 : _c2.execute) {
let interActions = (_d2 = this.interceptor[firstActionData.type]) == null ? void 0 : _d2.execute;
for (let ii = 0; ii < interActions.length; ii++) {
let result = interActions[ii](firstActionData.data, this, firstActionData.evt);
if (!result) {
return false;
}
}
}
let actionResult = action.action(firstActionData.data, this, firstActionData.evt);
if (actionResult) {
if ((_e2 = this.interceptor[firstActionData.type]) == null ? void 0 : _e2.after) {
let interActions = (_f = this.interceptor[firstActionData.type]) == null ? void 0 : _f.after;
for (let ii = 0; ii < interActions.length; ii++) {
let result = interActions[ii](firstActionData.data, this, firstActionData.evt);
if (!result) {
return false;
}
}
}
return action.after(firstActionData.data, this, firstActionData.evt);
} else {
return false;
}
} else {
return false;
}
}
}
}
return true;
}
/**
* 执行绘图队列
* @param command
* @returns
*/
executeDraw(command) {
var _a3, _b2, _c2, _d2, _e2, _f;
if (this.drawQueue && this.drawQueue.length > 0) {
let firstActionData = null;
if (!command) {
firstActionData = this.drawQueue[0];
this.drawQueue.splice(0, 1);
} else {
firstActionData = command;
}
let action = null;
if (firstActionData) {
action = COMMANDS.get(firstActionData.type);
if (action) {
if ((_a3 = this.interceptor[firstActionData.type]) == null ? void 0 : _a3.before) {
let interActions = (_b2 = this.interceptor[firstActionData.type]) == null ? void 0 : _b2.before;
for (let ii = 0; ii < interActions.length; ii++) {
let result = interActions[ii](firstActionData.data, this, firstActionData.evt);
if (!result) {
return false;
}
}
}
let validResult = action.before(firstActionData.data, this, firstActionData.evt);
if (validResult) {
if ((_c2 = this.interceptor[firstActionData.type]) == null ? void 0 : _c2.execute) {
let interActions = (_d2 = this.interceptor[firstActionData.type]) == null ? void 0 : _d2.execute;
for (let ii = 0; ii < interActions.length; ii++) {
let result = interActions[ii](firstActionData.data, this, firstActionData.evt);
if (!result) {
return false;
}
}
}
let actionResult = action.action(firstActionData.data, this, firstActionData.evt);
if (actionResult) {
if ((_e2 = this.interceptor[firstActionData.type]) == null ? void 0 : _e2.after) {
let interActions = (_f = this.interceptor[firstActionData.type]) == null ? void 0 : _f.after;
for (let ii = 0; ii < interActions.length; ii++) {
let result = interActions[ii](firstActionData.data, this, firstActionData.evt);
if (!result) {
return false;
}
}
}
return action.after(firstActionData.data, this, firstActionData.evt);
} else {
return false;
}
} else {
return false;
}
}
}
}
return true;
}
}
const DDeiBus$1 = DDeiBus;
var DDeiEnumAttributeType = /* @__PURE__ */ ((DDeiEnumAttributeType2) => {
DDeiEnumAttributeType2[DDeiEnumAttributeType2["GRAPHICS"] = 1] = "GRAPHICS";
DDeiEnumAttributeType2[DDeiEnumAttributeType2["EVENT"] = 3] = "EVENT";
DDeiEnumAttributeType2[DDeiEnumAttributeType2["BUSINESS"] = 2] = "BUSINESS";
return DDeiEnumAttributeType2;
})(DDeiEnumAttributeType || {});
var DDeiEnumStoreType = /* @__PURE__ */ ((DDeiEnumStoreType2) => {
DDeiEnumStoreType2[DDeiEnumStoreType2["LOCAL"] = 1] = "LOCAL";
DDeiEnumStoreType2[DDeiEnumStoreType2["URL"] = 2] = "URL";
DDeiEnumStoreType2[DDeiEnumStoreType2["FILE"] = 3] = "FILE";
return DDeiEnumStoreType2;
})(DDeiEnumStoreType || {});
class DDeiStore {
}
class DDeiAbstractArrtibuteParser {
// ============================ 构造函数 ===============================
constructor(model, define2) {
__publicField2(this, "model");
__publicField2(this, "define");
this.model = model;
this.define = define2;
}
}
class DDeiArrtibuteParserString extends DDeiAbstractArrtibuteParser {
// ============================ 构造函数 ===============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 转换一个外部值到正确的值
* 根据dataType返回不同的结果
*/
parseValue(value) {
if (value) {
if (this.define.isArray) {
if (Array.isArray(value)) {
return value;
}
} else {
return value.toString();
}
} else {
return null;
}
}
/**
* 获取缺省值
* 根据dataType返回不同的结果
*/
getDefaultValue() {
let value = this.define.defaultValue;
if (value) {
if (this.define.isArray) {
if (Array.isArray(value)) {
return value;
}
} else {
return value.toString();
}
} else {
return null;
}
}
}
class DDeiArrtibuteParserNumber extends DDeiAbstractArrtibuteParser {
// ============================ 构造函数 ===============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 转换一个外部值到正确的值
* 根据dataType返回不同的结果
*/
parseValue(value) {
if (value != null && value != void 0) {
if (this.define.isArray) {
if (Array.isArray(value)) {
for (let i2 = 0; i2 < value.length; i2++) {
try {
value[i2] = parseFloat(value[i2]);
} catch (e) {
}
}
return value;
}
} else {
try {
return parseFloat(value);
} catch (e) {
return null;
}
}
} else {
return null;
}
}
/**
* 获取缺省值
* 根据dataType返回不同的结果
*/
getDefaultValue() {
let value = this.define.defaultValue;
if (value) {
if (this.define.isArray) {
if (Array.isArray(value)) {
for (let i2 = 0; i2 < value.length; i2++) {
try {
value[i2] = parseFloat(value[i2]);
} catch (e) {
}
}
return value;
}
} else {
try {
return parseFloat(value);
} catch (e) {
return null;
}
}
} else {
return null;
}
}
}
class DDeiArrtibuteParserBool extends DDeiAbstractArrtibuteParser {
// ============================ 构造函数 ===============================
// ============================ 属性 ===============================
/**
* 转换一个外部值到正确的值
* 根据dataType返回不同的结果
*/
parseValue(value) {
if (value) {
if (this.define.isArray) {
if (Array.isArray(value)) {
return value;
}
} else if (value == true || value.toLocaleLowerCase() == "true") {
return true;
} else {
return false;
}
} else {
return null;
}
}
/**
* 获取缺省值
* 根据dataType返回不同的结果
*/
getDefaultValue() {
let value = this.define.defaultValue;
if (value) {
if (this.define.isArray) {
if (Array.isArray(value)) {
return value;
}
} else if (value == true || value.toLocaleLowerCase() == "true") {
return true;
} else {
return false;
}
} else {
return false;
}
}
}
class DDeiArrtibuteDefine {
// ============================ 构造函数 ===============================
constructor(props) {
__publicField2(this, "id");
__publicField2(this, "mapping");
__publicField2(this, "type");
__publicField2(this, "code");
__publicField2(this, "name");
__publicField2(this, "desc");
__publicField2(this, "dataType");
__publicField2(this, "dataSource");
__publicField2(this, "defaultValue");
__publicField2(this, "notNull");
__publicField2(this, "readonly");
__publicField2(this, "isArray");
__publicField2(this, "overwrite");
__publicField2(this, "min");
__publicField2(this, "max");
this.id = props.id;
this.mapping = props.mapping;
this.type = props.type;
this.code = props.code;
this.name = props.name;
this.desc = props.desc;
this.dataType = props.dataType ? props.dataType : "string";
this.dataSource = props.dataSource;
this.defaultValue = props.defaultValue;
this.notNull = props.notNull ? props.notNull : false;
this.readonly = props.readonly ? props.readonly : false;
this.isArray = props.isArray ? props.isArray : false;
this.overwrite = props.overwrite ? props.overwrite : false;
this.min = props.min ? props.min : 0;
this.max = props.max ? props.max : 100;
}
// ============================ 方法 ===============================
/**
* 初始化解析器
*/
getParser() {
if (!this.dataType || this.dataType.toLocaleLowerCase() == "string") {
return new DDeiArrtibuteParserString(null, this);
} else if (this.dataType.toLocaleLowerCase() == "integer" || this.dataType.toLocaleLowerCase() == "float" || this.dataType.toLocaleLowerCase() == "number") {
return new DDeiArrtibuteParserNumber(null, this);
} else if (this.dataType.toLocaleLowerCase() == "boolean" || this.dataType.toLocaleLowerCase() == "bool") {
return new DDeiArrtibuteParserBool(null, this);
}
return null;
}
}
class DDeiConverterBase extends DDeiPluginBase {
// ============================ 方法 ===============================
/**
* 判定是否生效
*/
isEnable(fileData) {
return true;
}
/**
* 输入
*/
input(fileData) {
return fileData;
}
/**
* 输出
*/
output(fileData) {
return fileData;
}
getConverters(editor) {
return [this];
}
}
class DDeiMenuBase extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField2(this, "label");
__publicField2(this, "icon");
__publicField2(this, "disabled");
}
getMenus(editor) {
let option = this.getOptions();
if (option) {
for (let i2 in option) {
if (i2 != "name") {
this[i2] = option[i2];
}
}
}
return [this];
}
}
const ov_link_v_split_point = `(model, ov, ovd,link){
//根据ov与圆心基准控件的大小,计算控件位置
//获取Y轴的缩放比例
let bpv = DDeiUtil.pointsToZero([model.bpv], model.cpv, model.rotate)[0]
let scaleY = Math.abs(bpv.y / 100)
let scaleX = Math.abs(bpv.x / 100)
//获取当前ov的index,当前index与compose的index必须对应
let ovs = DDeiUtil.getOVSByType(model,1);
let ovIndex = ovs.indexOf(ov);
let novIndex = ovIndex + 1
//得到当前控制点,还原到基准坐标的大小
let oar = [ov]
//如果是第一个点,则开始点为-50
if(novIndex < ovs.length){
oar.push(ovs[novIndex])
}
let opv = DDeiUtil.pointsToZero(oar, model.cpv, model.rotate)
let opvY0 = opv[0].y / scaleY
let sy,ey
if(ovIndex == 0){
sy = -50
}else{
let bopv = DDeiUtil.pointsToZero([ovs[ovIndex-1]], model.cpv, model.rotate)
sy = bopv[0].y/scaleY
}
if(novIndex < ovs.length){
let opvY1 = opv[1].y / scaleY
ey = opvY1
}else{
ey = 50
}
let comp0HeightBase = opvY0-sy
let comp1HeightBase = ey - opvY0
let comp0CY = sy + comp0HeightBase / 2
let comp1CY = sy + comp0HeightBase + comp1HeightBase / 2
let models = link.models
let comps0 = []
let compsCPVS0 = []
models?.forEach(comp0Path => {
let comp0 = DDeiUtil.getDataByPathList(model, comp0Path)
compsCPVS0.push(comp0.cpv)
comps0.push(comp0)
});
let compCPVS0 = DDeiUtil.pointsToZero(compsCPVS0, model.cpv, model.rotate)
let vs0 = []
compCPVS0?.forEach(vs => {
vs0.push(new Vector3(vs.x/scaleX, comp0CY, 1))
});
let cpvs = DDeiUtil.zeroToPoints(vs0, model.cpv, model.rotate, scaleX, scaleY)
for(let i = 0;i < comps0.length;i++){
let comp0 = comps0[i]
//composes的cpv归零0坐标,如果compse的X坐标不为0,则需要考虑旋转后X增量带来的Y变化
//实际位移量=中心点位移量 X 2
let comp0DeltaBPVX = (cpvs[i].x - comp0.cpv.x) * 2
let comp0DeltaBPVY = (cpvs[i].y - comp0.cpv.y) * 2
//计算位移量在原始大小中的比例
let comp0DeltaBPVXRate = comp0DeltaBPVX / (comp0.bpv.x - comp0.cpv.x)
let comp0DeltaBPVYRate = comp0DeltaBPVY / (comp0.bpv.y - comp0.cpv.y)
comp0.bpv.x = (comp0.bpv.x - comp0.cpv.x) * (1 + comp0DeltaBPVXRate) + cpvs[i].x
comp0.bpv.y = (comp0.bpv.y - comp0.cpv.y) * (1 + comp0DeltaBPVYRate) + cpvs[i].y
comp0.cpv.x = cpvs[i].x
comp0.cpv.y = cpvs[i].y
//重新初始化并采样
comp0.initPVS();
}
let nextModels = link.nextModels
let comps1 = []
let compsCPVS1 = []
nextModels?.forEach(comp1Path => {
let comp1 = DDeiUtil.getDataByPathList(model, comp1Path)
compsCPVS1.push(comp1.cpv)
comps1.push(comp1)
});
let compCPVS1 = DDeiUtil.pointsToZero(compsCPVS1, model.cpv, model.rotate)
let vs1 = []
compCPVS1?.forEach(vs => {
vs1.push(new Vector3(vs.x/scaleX, comp1CY, 1))
});
cpvs = DDeiUtil.zeroToPoints(vs1, model.cpv, model.rotate, scaleX, scaleY)
for(let i = 0;i < comps1.length;i++){
let comp1 = comps1[i]
//composes的cpv归零0坐标,如果compse的X坐标不为0,则需要考虑旋转后X增量带来的Y变化
let compCPVS = DDeiUtil.pointsToZero([comp1.cpv], model.cpv, model.rotate)
let comp1DeltaBPVX = (cpvs[i].x - comp1.cpv.x) * 2
let comp1DeltaBPVY = (cpvs[i].y - comp1.cpv.y) * 2
//计算位移量在原始大小中的比例
let comp1DeltaBPVXRate = comp1DeltaBPVX / (comp1.bpv.x - comp1.cpv.x)
let comp1DeltaBPVYRate = comp1DeltaBPVY / (comp1.bpv.y - comp1.cpv.y)
comp1.bpv.x = (comp1.bpv.x - comp1.cpv.x) * (1 - comp1DeltaBPVXRate) + cpvs[i].x
comp1.bpv.y = (comp1.bpv.y - comp1.cpv.y) * (1 - comp1DeltaBPVYRate) + cpvs[i].y
comp1.cpv.x = cpvs[i].x
comp1.cpv.y = cpvs[i].y
//重新初始化并采样
comp1.initPVS();
}
}`;
const ov_link_h_split_point = `(model, ov, ovd, link){
//根据ov与圆心基准控件的大小,计算控件位置
//获取Y轴的缩放比例
let bpv = DDeiUtil.pointsToZero([model.bpv], model.cpv, model.rotate)[0]
let scaleY = Math.abs(bpv.y / 100)
let scaleX = Math.abs(bpv.x / 100)
//获取当前ov的index,当前index与compose的index必须对应
let ovs = DDeiUtil.getOVSByType(model,2);
let ovIndex = ovs.indexOf(ov);
let novIndex = ovIndex + 1
//得到当前控制点,还原到基准坐标的大小
let oar = [ov]
//如果是第一个点,则开始点为-50
if(novIndex < ovs.length){
oar.push(ovs[novIndex])
}
let opv = DDeiUtil.pointsToZero(oar, model.cpv, model.rotate)
let opvX0 = opv[0].x / scaleX
let sx,ex
if(ovIndex == 0){
sx = -50
}else{
let bopv = DDeiUtil.pointsToZero([ovs[ovIndex-1]], model.cpv, model.rotate)
sx = bopv[0].x/scaleX
}
if(novIndex < ovs.length){
let opvX1 = opv[1].x / scaleX
ex = opvX1
}else{
ex = 50
}
let comp0Base = opvX0-sx
let comp1Base = ex - opvX0
let comp0CX = sx + comp0Base / 2
let comp1CX = sx + comp0Base + comp1Base / 2
let models = link.models
let comps0 = []
let compsCPVS0 = []
models?.forEach(comp0Path => {
let comp0 = DDeiUtil.getDataByPathList(model, comp0Path)
compsCPVS0.push(comp0.cpv)
comps0.push(comp0)
});
let compCPVS0 = DDeiUtil.pointsToZero(compsCPVS0, model.cpv, model.rotate)
let vs0 = []
compCPVS0?.forEach(vs => {
vs0.push(new Vector3(comp0CX, vs.y/scaleY , 1))
});
let cpvs = DDeiUtil.zeroToPoints(vs0, model.cpv, model.rotate, scaleX, scaleY)
for(let i = 0;i < comps0.length;i++){
let comp0 = comps0[i]
//composes的cpv归零0坐标,如果compse的X坐标不为0,则需要考虑旋转后X增量带来的Y变化
//实际位移量=中心点位移量 X 2
let comp0DeltaBPVX = (cpvs[i].x - comp0.cpv.x) * 2
let comp0DeltaBPVY = (cpvs[i].y - comp0.cpv.y) * 2
//计算位移量在原始大小中的比例
let comp0DeltaBPVXRate = comp0DeltaBPVX / (comp0.bpv.x - comp0.cpv.x)
let comp0DeltaBPVYRate = comp0DeltaBPVY / (comp0.bpv.y - comp0.cpv.y)
comp0.bpv.x = (comp0.bpv.x - comp0.cpv.x) * (1 + comp0DeltaBPVXRate) + cpvs[i].x
comp0.bpv.y = (comp0.bpv.y - comp0.cpv.y) * (1 + comp0DeltaBPVYRate) + cpvs[i].y
comp0.cpv.x = cpvs[i].x
comp0.cpv.y = cpvs[i].y
//重新初始化并采样
comp0.initPVS();
}
let nextModels = link.nextModels
let comps1 = []
let compsCPVS1 = []
nextModels?.forEach(comp1Path => {
let comp1 = DDeiUtil.getDataByPathList(model, comp1Path)
compsCPVS1.push(comp1.cpv)
comps1.push(comp1)
});
let compCPVS1 = DDeiUtil.pointsToZero(compsCPVS1, model.cpv, model.rotate)
let vs1 = []
compCPVS1?.forEach(vs => {
vs1.push(new Vector3(comp1CX,vs.y/scaleY, 1))
});
cpvs = DDeiUtil.zeroToPoints(vs1, model.cpv, model.rotate, scaleX, scaleY)
for(let i = 0;i < comps1.length;i++){
let comp1 = comps1[i]
//composes的cpv归零0坐标,如果compse的X坐标不为0,则需要考虑旋转后X增量带来的Y变化
let compCPVS = DDeiUtil.pointsToZero([comp1.cpv], model.cpv, model.rotate)
let comp1DeltaBPVX = (cpvs[i].x - comp1.cpv.x) * 2
let comp1DeltaBPVY = (cpvs[i].y - comp1.cpv.y) * 2
//计算位移量在原始大小中的比例
let comp1DeltaBPVXRate = comp1DeltaBPVX / (comp1.bpv.x - comp1.cpv.x)
let comp1DeltaBPVYRate = comp1DeltaBPVY / (comp1.bpv.y - comp1.cpv.y)
comp1.bpv.x = (comp1.bpv.x - comp1.cpv.x) * (1 - comp1DeltaBPVXRate) + cpvs[i].x
comp1.bpv.y = (comp1.bpv.y - comp1.cpv.y) * (1 - comp1DeltaBPVYRate) + cpvs[i].y
comp1.cpv.x = cpvs[i].x
comp1.cpv.y = cpvs[i].y
//重新初始化并采样
comp1.initPVS();
}
}`;
class DDeiThemeBase extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField2(this, "label");
__publicField2(this, "icon");
__publicField2(this, "css");
}
// ============================ 方法 ===============================
getThemes(editor) {
let option = this.getOptions();
if (option) {
for (let i2 in option) {
if (i2 != "name") {
this[i2] = option[i2];
}
}
}
return [this];
}
}
const _DDeiEditorCommandAddHistroy = class _DDeiEditorCommandAddHistroy2 extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置当前控件的选中状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let editor = bus.invoker;
if ((editor == null ? void 0 : editor.files.length) > 0 && (editor.currentFileIndex == 0 || editor.currentFileIndex)) {
let file = editor == null ? void 0 : editor.files[editor.currentFileIndex];
if ((file == null ? void 0 : file.active) == DDeiActiveType.ACTIVE) {
let data2 = JSON.stringify(file.toJSON());
let lastData = null;
if (file.histroyIdx != -1) {
lastData = file.histroy[file.histroyIdx];
}
if (data2 != lastData) {
_DDeiEditorCommandAddHistroy2.addHistroy(file, data2);
}
}
}
return true;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new _DDeiEditorCommandAddHistroy2({ code: DDeiEditorEnumBusCommandType.AddFileHistroy, name: "", desc: "" });
}
static addHistroy(file, data) {
file.addHistroy(data);
}
};
_DDeiEditorCommandAddHistroy.addHistroy = debounce(_DDeiEditorCommandAddHistroy.addHistroy, 200, { trailing: true, leading: false });
let DDeiEditorCommandAddHistroy = _DDeiEditorCommandAddHistroy;
const __vite_glob_0_0$7 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiEditorCommandAddHistroy,
default: DDeiEditorCommandAddHistroy
}, Symbol.toStringTag, { value: "Module" }));
class DDeiEditorCommandChangeEditMode extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let editor = bus.invoker;
if (data == null ? void 0 : data.mode) {
editor.changeEditMode(data.mode);
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
bus.insert(DDeiEnumBusCommandType.ChangeEditMode, data, evt);
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiEditorCommandChangeEditMode({ code: DDeiEditorEnumBusCommandType.ChangeEditMode, name: "", desc: "" });
}
}
const __vite_glob_0_1$4 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiEditorCommandChangeEditMode,
default: DDeiEditorCommandChangeEditMode
}, Symbol.toStringTag, { value: "Module" }));
class DDeiEditorCommandClearTemplateUI extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
{
let ele = document.getElementById(bus.invoker.containerid);
let dialogs = [];
for (let i2 = 0; i2 < ele.children.length; i2++) {
if (ele.children[i2].className == "ddei-combox-show-dialog") {
dialogs.push(ele.children[i2]);
}
}
dialogs.forEach((dialog) => {
dialog.style.display = "none";
});
}
{
DDeiEditorUtil$1.closeDialogs(bus.invoker, ["bottom-dialog", "property-dialog", "top-dialog", "toolbox-dialog"]);
}
{
let menuDialogId = DDeiUtil$1.getMenuControlId(bus.invoker);
let menuEle = document.getElementById(menuDialogId);
if (menuEle) {
menuEle.style.display = "none";
}
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiEditorCommandClearTemplateUI({ code: DDeiEditorEnumBusCommandType.ClearTemplateUI, name: "", desc: "" });
}
}
const __vite_glob_0_2$4 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiEditorCommandClearTemplateUI,
default: DDeiEditorCommandClearTemplateUI
}, Symbol.toStringTag, { value: "Module" }));
class DDeiEditorCommandFileDirty extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let editor = bus.invoker;
if ((data == null ? void 0 : data.state) && (editor == null ? void 0 : editor.files.length) > 0 && (editor.currentFileIndex == 0 || editor.currentFileIndex)) {
let file = editor == null ? void 0 : editor.files[editor.currentFileIndex];
if ((file == null ? void 0 : file.active) == DDeiActiveType.ACTIVE) {
file.modelNumber = file.calModelNumber();
file.state = data == null ? void 0 : data.state;
}
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiEditorCommandFileDirty({ code: DDeiEditorEnumBusCommandType.RefreshEditorParts, name: "", desc: "" });
}
}
const __vite_glob_0_3$4 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiEditorCommandFileDirty,
default: DDeiEditorCommandFileDirty
}, Symbol.toStringTag, { value: "Module" }));
class DDeiEditorCommandLoadFile extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let editor = bus.invoker;
let ddInstance = editor.ddInstance;
let loadFile = DDeiEditorUtil$1.getConfigValue(
"EVENT_LOAD_FILE",
editor
);
if (loadFile) {
loadFile().then((fileData) => {
let converters = editor.getEnabledConverters(fileData, 1);
converters == null ? void 0 : converters.forEach((converter) => {
fileData = converter.input(fileData);
});
if (fileData) {
let file = null;
for (let x2 = 0; x2 < editor.files.length; x2++) {
if (editor.files[x2].id == fileData.id) {
file = editor.files[x2];
}
editor.files[x2].active = DDeiActiveType.NONE;
}
if (!file) {
if (fileData == null ? void 0 : fileData.content) {
file = DDeiFile.loadFromJSON(JSON.parse(fileData == null ? void 0 : fileData.content), {
currentDdInstance: editor.ddInstance
});
file.id = fileData.id;
file.publish = fileData.publish;
file.name = fileData.name;
file.path = fileData.path;
file.desc = fileData.desc;
file.version = fileData.version;
file.extData = fileData.extData;
file.busiData = fileData.busiData;
} else {
file = new DDeiFile({
id: fileData.id,
publish: fileData.publish,
name: fileData.name,
path: fileData.path,
desc: fileData.desc,
version: fileData.version,
extData: fileData.extData,
busiData: fileData.busiData,
sheets: [
new DDeiSheet({
name: "新建页面",
desc: "新建页面",
stage: DDeiStage.initByJSON(
{ id: "stage_1" },
{ currentDdInstance: ddInstance }
),
active: DDeiActiveType.ACTIVE
})
],
currentSheetIndex: 0,
state: DDeiFileState.NEW,
active: DDeiActiveType.ACTIVE
});
}
editor.addFile(file);
file.state = DDeiFileState.NONE;
}
editor.currentFileIndex = editor.files.indexOf(file);
file.active = DDeiActiveType.ACTIVE;
let sheets = file == null ? void 0 : file.sheets;
if (file && sheets && ddInstance) {
file.changeSheet(file.currentSheetIndex);
let stage2 = sheets[file.currentSheetIndex].stage;
stage2.ddInstance = ddInstance;
file.initHistroy();
ddInstance.stage = stage2;
stage2.initRender();
editor.changeState(DDeiEditorState.DESIGNING);
ddInstance.bus.insert(DDeiEditorEnumBusCommandType.ClearTemplateUI, 0);
ddInstance.bus.insert(DDeiEnumBusCommandType.RefreshShape, 1);
ddInstance.bus.insert(DDeiEditorEnumBusCommandType.RefreshEditorParts, 2);
ddInstance.bus.executeAll();
}
}
});
} else {
let fileText = editor.i18n("ddei.file");
let newText = editor.i18n("ddei.new");
let pageText = editor.i18n("ddei.page");
let file = DDeiFile.loadFromJSON(
{
name: newText + fileText + "_NEW",
path: "/" + newText + fileText + "_NEW",
sheets: [
new DDeiSheet({
name: pageText + "-1",
desc: pageText + "-1",
stage: DDeiStage.initByJSON({ id: "stage_1" }, { currentDdInstance: ddInstance }),
active: DDeiActiveType.ACTIVE
})
],
currentSheetIndex: 0,
state: DDeiFileState.NEW,
active: DDeiActiveType.ACTIVE
},
{ currentDdInstance: ddInstance }
);
if (editor.currentFileIndex != -1) {
editor.files[editor.currentFileIndex].active = DDeiActiveType.NONE;
}
editor.addFile(file);
editor.currentFileIndex = editor.files.indexOf(file);
file.active = DDeiActiveType.ACTIVE;
let sheets = file == null ? void 0 : file.sheets;
if (file && sheets && ddInstance) {
file.changeSheet(file.currentSheetIndex);
let stage2 = sheets[file.currentSheetIndex].stage;
stage2.ddInstance = ddInstance;
file.initHistroy();
ddInstance.stage = stage2;
stage2.initRender();
editor.changeState(DDeiEditorState.DESIGNING);
ddInstance.bus.insert(DDeiEditorEnumBusCommandType.ClearTemplateUI, 0);
ddInstance.bus.insert(DDeiEnumBusCommandType.RefreshShape, 1);
ddInstance.bus.insert(DDeiEditorEnumBusCommandType.RefreshEditorParts, 2);
ddInstance.bus.executeAll();
}
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiEditorCommandLoadFile({ code: DDeiEditorEnumBusCommandType.LoadFile, name: "", desc: "" });
}
}
const __vite_glob_0_4$3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiEditorCommandLoadFile,
default: DDeiEditorCommandLoadFile
}, Symbol.toStringTag, { value: "Module" }));
class DDeiEditorCommandRefreshEditorParts extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
var _a3, _b2, _c2;
let editor = bus.invoker;
if (((_a3 = data == null ? void 0 : data.parts) == null ? void 0 : _a3.length) > 0) {
(_b2 = editor.layoutViewer) == null ? void 0 : _b2.forceRefreshParts(data == null ? void 0 : data.parts);
} else {
(_c2 = editor.layoutViewer) == null ? void 0 : _c2.forceRefreshParts();
}
return true;
}
/**
* 后置行为,分发
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiEditorCommandRefreshEditorParts({ code: DDeiEditorEnumBusCommandType.RefreshEditorParts, name: "", desc: "" });
}
}
const __vite_glob_0_5$3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiEditorCommandRefreshEditorParts,
default: DDeiEditorCommandRefreshEditorParts
}, Symbol.toStringTag, { value: "Module" }));
class DDeiEditorCommandSaveFile extends DDeiBusCommand {
// ============================ 构造函数 ============================
// ============================ 静态方法 ============================
// ============================ 属性 ===============================
// ============================ 方法 ===============================
/**
* 前置行为,用于校验,本Command无需校验
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
before(data, bus, evt) {
return true;
}
/**
* 具体行为,设置当前控件的选中状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
action(data, bus, evt) {
let editor = bus.invoker;
if ((editor == null ? void 0 : editor.files.length) > 0 && (editor.currentFileIndex == 0 || editor.currentFileIndex)) {
let file = editor == null ? void 0 : editor.files[editor.currentFileIndex];
if ((file == null ? void 0 : file.active) == DDeiActiveType.ACTIVE) {
if ((file == null ? void 0 : file.state) == DDeiFileState.NEW || (file == null ? void 0 : file.state) == DDeiFileState.MODIFY || data.publish == 1) {
let oldState = file.state;
file.lastUpdateTime = (/* @__PURE__ */ new Date()).getTime();
let json = file.toJSON();
if (json) {
let converters = editor.getEnabledConverters(json, 2);
converters == null ? void 0 : converters.forEach((converter) => {
json = converter.output(json);
});
json.state = DDeiFileState.NONE;
if (data.publish == 1) {
file.state = DDeiFileState.PUBLISHING;
let publishFile = DDeiEditorUtil$1.getConfigValue(
"EVENT_PUBLISH_FILE",
editor
);
if (publishFile) {
DDeiUtil$1.stageScreenToImage(bus.ddInstance, 400, 240).then((thumbBase64) => {
if (thumbBase64) {
json.thumb = thumbBase64;
}
publishFile(json).then((data2) => {
if (data2.result == 1) {
file.state = DDeiFileState.NONE;
file.histroy.forEach((his) => {
if (his.isNew == true) {
delete his.isNew;
}
});
file.histroy[file.histroyIdx].isNew = true;
} else if (data2.result != 4) {
file.state = oldState;
}
});
});
}
} else {
file.state = DDeiFileState.SAVING;
let saveFile = DDeiEditorUtil$1.getConfigValue(
"EVENT_SAVE_FILE",
editor
);
if (saveFile) {
DDeiUtil$1.stageScreenToImage(bus.ddInstance, 400, 240).then((thumbBase64) => {
if (thumbBase64) {
json.thumb = thumbBase64;
}
saveFile(json, file).then((data2) => {
if (data2.result == 1) {
file.state = DDeiFileState.NONE;
file.histroy.forEach((his) => {
if (his.isNew == true) {
delete his.isNew;
}
});
file.histroy[file.histroyIdx].isNew = true;
bus == null ? void 0 : bus.insert(DDeiEditorEnumBusCommandType.RefreshEditorParts, { parts: ["openfiles"] }, evt);
bus.executeAll();
} else if (data2.result != 4) {
file.state = oldState;
}
});
});
}
}
}
}
}
}
return true;
}
/**
* 后置行为,分发,修改当前editor的状态
* @param data bus分发后,当前承载的数据
* @param bus 总线对象引用
* @param evt 事件对象引用
*/
after(data, bus, evt) {
return true;
}
/**
* 返回当前实例
* @returns
*/
static newInstance() {
return new DDeiEditorCommandSaveFile({ code: DDeiEditorEnumBusCommandType.SaveFile, name: "", desc: "" });
}
}
const __vite_glob_0_6$3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
DDeiEditorCommandSaveFile,
default: DDeiEditorCommandSaveFile
}, Symbol.toStringTag, { value: "Module" }));
const autoLoadCommand = function() {
const control_ctx2 = /* @__PURE__ */ Object.assign({ "./bus/commands/add-histroy.ts": __vite_glob_0_0$7, "./bus/commands/change-edit-mode.ts": __vite_glob_0_1$4, "./bus/commands/clear-template-ui.ts": __vite_glob_0_2$4, "./bus/commands/file-dirty.ts": __vite_glob_0_3$4, "./bus/commands/load-file.ts": __vite_glob_0_4$3, "./bus/commands/refresh-editor-parts.ts": __vite_glob_0_5$3, "./bus/commands/save-file.ts": __vite_glob_0_6$3 });
let loadArray2 = [];
for (const path in control_ctx2) {
loadArray2.push(control_ctx2[path]);
}
loadArray2.forEach((item) => {
let command = item.default;
if (command) {
let cmdInst = command.newInstance();
if (cmdInst == null ? void 0 : cmdInst.code) {
addCommand(cmdInst.code, cmdInst);
}
}
});
};
class DDeiEditorArrtibute extends DDeiArrtibuteDefine {
// ============================ 构造函数 ===============================
constructor(props) {
super(props);
__publicField2(this, "group");
__publicField2(this, "controlType");
__publicField2(this, "orderNo");
__publicField2(this, "visiable");
__publicField2(this, "diffValues", []);
__publicField2(this, "hiddenTitle");
__publicField2(this, "display");
__publicField2(this, "value", null);
__publicField2(this, "exmapping");
__publicField2(this, "itemStyle", null);
__publicField2(this, "canSearch", false);
__publicField2(this, "step", 1);
__publicField2(this, "cascadeDisplay", null);
this.group = props.group;
this.controlType = props.controlType ? props.controlType : "text";
this.orderNo = props.orderNo;
this.visiable = props.visiable == false ? false : true;
this.value = props.value ? props.value : null;
this.display = props.display ? props.display : "row";
this.hiddenTitle = props.hiddenTitle ? props.hiddenTitle : false;
this.step = props.step ? props.step : 1;
this.itemStyle = props.itemStyle ? props.itemStyle : null;
this.canSearch = props.canSearch ? props.canSearch : false;
this.exmapping = props.exmapping;
this.cascadeDisplay = props.cascadeDisplay;
}
// ============================ 方法 ===============================
/**
* 根据当前的值,更新配置信息
*/
doCascadeDisplayByValue() {
var _a3, _b2;
let cascadeDisplayConfig = null;
if (this.cascadeDisplay) {
if (this.cascadeDisplay[this.value]) {
cascadeDisplayConfig = this.cascadeDisplay[this.value];
} else {
if (this.value && this.value != "" && this.value != "0" && this.value != 0) {
cascadeDisplayConfig = this.cascadeDisplay["notempty"];
} else if (this.value == null && this.defaultValue) {
cascadeDisplayConfig = this.cascadeDisplay["default"];
} else {
cascadeDisplayConfig = this.cascadeDisplay["empty"];
}
}
}
if (((_a3 = cascadeDisplayConfig == null ? void 0 : cascadeDisplayConfig.show) == null ? void 0 : _a3.length) > 0) {
DDeiEditorArrtibute.showAttributesByCode(
this.topGroup,
cascadeDisplayConfig.show
);
}
if (((_b2 = cascadeDisplayConfig == null ? void 0 : cascadeDisplayConfig.hidden) == null ? void 0 : _b2.length) > 0) {
DDeiEditorArrtibute.hiddenAttributesByCode(
this.topGroup,
cascadeDisplayConfig.hidden
);
}
}
/**
*
* @param propTopGroup 隐藏属性
* @param paths
*/
static hiddenAttributesByCode(propTopGroup, ...paths) {
var _a3;
if (((_a3 = propTopGroup == null ? void 0 : propTopGroup.subGroups) == null ? void 0 : _a3.length) > 0 && paths) {
propTopGroup.subGroups.forEach((group2) => {
var _a22;
if (((_a22 = group2 == null ? void 0 : group2.children) == null ? void 0 : _a22.length) > 0) {
group2.children.forEach((item) => {
paths.forEach((path) => {
if (path.indexOf(item.code) != -1) {
item.visiable = false;
}
});
});
}
});
}
}
/**
* 显示属性
* @param propTopGroup
* @param paths
*/
static showAttributesByCode(propTopGroup, ...paths) {
var _a3;
if (((_a3 = propTopGroup == null ? void 0 : propTopGroup.subGroups) == null ? void 0 : _a3.length) > 0 && paths) {
propTopGroup.subGroups.forEach((group2) => {
var _a22;
if (((_a22 = group2 == null ? void 0 : group2.children) == null ? void 0 : _a22.length) > 0) {
group2.children.forEach((item) => {
paths.forEach((path) => {
if (path.indexOf(item.code) != -1) {
item.visiable = true;
}
});
});
}
});
}
}
}
class DDeiLifeCycle extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField2(this, "EVENT_CONTROL_SELECT_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_DBL_CLICK", null);
__publicField2(this, "EVENT_CONTROL_SELECT_AFTER", null);
__publicField2(this, "EVENT_CONTROL_CREATE_BEFORE", null);
__publicField2(this, "EVENT_MOUSE_OPERATING", null);
__publicField2(this, "EVENT_CONTROL_CREATE_AFTER", null);
__publicField2(this, "EVENT_CONTROL_DRAG_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_DRAGING", null);
__publicField2(this, "EVENT_CONTROL_DRAG_AFTER", null);
__publicField2(this, "EVENT_LINE_DRAG_BEFORE", null);
__publicField2(this, "EVENT_LINE_DRAG_AFTER", null);
__publicField2(this, "EVENT_CONTROL_DEL_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_DEL_AFTER", null);
__publicField2(this, "EVENT_CONTROL_EDIT_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_EDIT_AFTER", null);
__publicField2(this, "EVENT_CONTROL_VIEW_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_VIEW", null);
__publicField2(this, "EVENT_CONTROL_VIEW_AFTER", null);
__publicField2(this, "EVENT_STAGE_CHANGE_WPV", null);
__publicField2(this, "EVENT_STAGE_CHANGE_RATIO", null);
__publicField2(this, "EVENT_MOUSE_MOVE_IN_CONTROL", null);
__publicField2(this, "EVENT_MOUSE_MOVE_IN_LAYER", null);
__publicField2(this, "EVENT_MOUSE_IN_AREA", null);
__publicField2(this, "EVENT_CLOSE_FILE_AFTER", null);
__publicField2(this, "EVENT_CHANGE_FILE_AFTER", null);
__publicField2(this, "EVENT_CHANGE_SHEET_AFTER", null);
__publicField2(this, "EVENT_DEL_SHEET_AFTER", null);
__publicField2(this, "EVENT_CLOSE_FILE_BEFORE", null);
__publicField2(this, "EVENT_CHANGE_FILE_BEFORE", null);
__publicField2(this, "EVENT_CHANGE_SHEET_BEFORE", null);
__publicField2(this, "EVENT_DEL_SHEET_BEFORE", null);
__publicField2(this, "EVENT_ADD_FILE_AFTER", null);
__publicField2(this, "EVENT_ADD_SHEET_AFTER", null);
__publicField2(this, "EVENT_ADD_FILE_BEFORE", null);
__publicField2(this, "EVENT_ADD_SHEET_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_ROTATE_BEFORE", null);
__publicField2(this, "EVENT_CONTROL_ROTATE_AFTER", null);
}
// ============================ 方法 ===============================
getLifeCyclies(editor) {
let option = this.getOptions();
if (option) {
for (let i2 in option) {
if (i2 != "name") {
this[i2] = option[i2];
}
}
}
return [this];
}
}
const _sfc_main$1g = {
name: "DDei-Editor-Menu-Dialog",
extends: null,
mixins: [],
props: {
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
},
methods: {
/**
* 执行菜单的Action
*/
execMenuAction(menu, evt) {
var _a3, _b2, _c2;
let stage2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage;
let menuAction = this.editor.menus[menu.name];
if (menuAction && stage2) {
let menuShape = (_c2 = stage2.render) == null ? void 0 : _c2.currentMenuShape;
menuAction.action(menuShape, evt);
}
this.$refs.menuDialog.style.display = "none";
stage2.render.operateState = DDeiEnumOperateState.NONE;
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
this.editor.bus.executeAll();
},
/**
* 判断菜单是否显示
*/
isVisiable(menu) {
var _a3, _b2, _c2;
try {
let stage2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage;
let menuAction = this.editor.menus[menu.name];
if (menuAction && stage2) {
let menuShape = (_c2 = stage2.render) == null ? void 0 : _c2.currentMenuShape;
return menuAction.isVisiable(menuShape);
}
} catch (e) {
console.error(e);
}
return false;
}
}
};
const MenuDialog_vue_vue_type_style_index_0_scoped_1cde0d47_lang = "";
const _export_sfc = (sfc, props) => {
const target = sfc.__vccOpts || sfc;
for (const [key, val] of props) {
target[key] = val;
}
return target;
};
const _hoisted_1$1e = ["id"];
const _hoisted_2$V = ["onClick"];
const _hoisted_3$R = {
key: 0,
class: "ddei-editor-menu-dialog-item-icon"
};
const _hoisted_4$G = {
key: 0,
class: "icon",
"aria-hidden": "true"
};
const _hoisted_5$y = ["xlink:href"];
const _hoisted_6$s = {
key: 1,
class: "ddei-editor-menu-dialog-item-content"
};
const _hoisted_7$p = {
key: 2,
class: "ddei-editor-menu-dialog-item-desc"
};
function _sfc_render$1g(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2;
return vue.openBlock(), vue.createElementBlock("div", {
id: ((_a3 = $props.editor) == null ? void 0 : _a3.id) + "_menu_dialog",
ref: "menuDialog",
class: "ddei-editor-menu-dialog"
}, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_b2 = $props.editor) == null ? void 0 : _b2.currentMenuData, (menu) => {
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-editor-menu-dialog-hr": menu.code == "split", "ddei-editor-menu-dialog-item": menu.code != "split" }),
onClick: ($event) => $options.execMenuAction(menu, $event)
}, [
menu.code != "split" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3$R, [
menu.icon ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_4$G, [
vue.createElementVNode("use", {
"xlink:href": menu.icon
}, null, 8, _hoisted_5$y)
])) : vue.createCommentVNode("", true)
])) : vue.createCommentVNode("", true),
menu.code != "split" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6$s, vue.toDisplayString($props.editor.i18n(menu.label)), 1)) : vue.createCommentVNode("", true),
menu.code != "split" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_7$p, vue.toDisplayString($props.editor.i18n(menu.desc)), 1)) : vue.createCommentVNode("", true)
], 10, _hoisted_2$V)), [
[vue.vShow, $options.isVisiable(menu)]
]);
}), 256))
], 8, _hoisted_1$1e);
}
const MenuDialog = /* @__PURE__ */ _export_sfc(_sfc_main$1g, [["render", _sfc_render$1g], ["__scopeId", "data-v-1cde0d47"]]);
const en_US$1 = {
ddei: {
file: "File",
new: "New",
open: "Open",
save: "Save",
abort: "Abort",
publish: "Publish",
download: "Download",
export: "Export",
import: "Import",
clear: "Clear",
close: "Close",
collection: "Collection",
confirm: "Confirm",
cancel: "Cancel",
cutBoard: "CutBoard",
textEdit: "TextEdit",
tools: "Tools",
sortAndAlign: "Sort",
scale: "Scale",
style: "Style",
fill: "Fill",
border: "Border",
line: "Line",
layout: "Layout",
text: "Text",
code: "Code",
name: "Name",
desc: "Description",
format: "Format",
data: "Data",
database: "DataBase",
setting: "Setting",
cut: "Cut",
copy: "Copy",
delete: "Delete",
paste: "Paste",
more: "More",
page: "Page",
shapesCount: "Shapes:",
shapes: "Shapes:",
layerName: "Layer",
newLayer: "New",
background: "Back Ground",
backgroundColor: "BGColor",
position: "Position",
align: "Align",
combina: "Combina",
cancelCombina: "Spread",
sort: "Sort",
flip: "Flap",
rotate: "Rotate",
mirror: "Mirror",
choose: "Choose",
moveStage: "Move",
linkLine: "Line",
search: "Search",
replace: "Replace",
fileDescription: "DDei Design File",
wholePage: "Whole Page",
precent: "Pre",
chooseShapeGroups: "Choose Shapes",
basicSubject: "Basic",
umlSubject: "UML",
brush: "Brush",
startPoint: "Start",
endPoint: "End",
lineType: "Type",
lineColor: "Color",
lineWeight: "Weight",
lineDash: "Dash",
pushUp: "Up",
pushDown: "Down",
pushTop: "Top",
pushBottom: "Bottom",
assistant: "Assistant",
mark: "Mark",
paper: "Paper",
propertyName: "Property",
searchResult: "Search Result",
property: {
id: "id",
code: "Code",
text: "Text",
format: "Format",
width: "Width",
height: "Height",
weight: "Weight",
borderType: "Border Type",
fillType: "Fill Type",
startPointType: "Start",
endPointType: "End",
type: "Type",
color: "Color",
opacity: "Opacity",
dash: "Dash",
round: "Round",
image: "Image",
font: "Font",
size: "Size",
align: "Align",
feed: "Wrap",
outSize: "Out of Range",
lockWidth: "Lock Width",
paddingWeight: "Padding",
hollow: "Hollow",
bold: "Bold",
italic: "Italic",
underline: "Underline",
deleteline: "Strike Through",
topline: "Top Line",
textbg: "Text Background",
subtype: "Annotation Type",
textAlign: "Text Align",
textValign: "Vertical Align",
hspace: "Horizontal Space",
vspace: "Vertical Space",
dateType: "Date Type",
nscale: "Decimal",
tmark: "Thousands Separator",
mmark: "Currency Symbol",
moneyUnit: "Currency Unit",
moneyUpCase: "Currency in Uppercase",
paperType: "Paper",
unit: "Unit",
direct: "Direction",
markType: "Watermark",
mark: "Watermark",
markDirect: "Direction",
ruler: "Ruler",
grid: "Grid",
jumpline: "JumpLine",
background: "Back Ground",
backgroundColor: "BG Color",
backgroundImage: "BG Image",
bgImageMode: "Mode",
bgImageScale: "Scale",
bgImagePosition: "Position",
code001: "code001",
linePointType: "Point Type",
ds: {
none: "None",
color: "Color",
image: "Image",
yes: "Yes",
no: "No",
global: "Global",
hidden: "Hidden",
ellipsis: "Ellipsis",
narrow: "Narrow",
ext: "Extend",
subType: "Normal",
subType1: "Superscript",
subType2: "Subscript",
subType3: "Strike",
text: "Text",
decimal: "Decimal",
money: "Currency",
time: "Time",
custom: "Custom",
money1: "CNY",
money2: "USD",
money3: "EUR",
money4: "GBP",
money5: "JPY",
money6: "RUB",
money7: "CHF",
line: "Solid Line",
point: "Dotted",
pos1: "TLeft",
pos2: "TCenter",
pos3: "TRight",
pos4: "MLeft",
pos5: "Center",
pos6: "MRight",
pos7: "BLeft",
pos8: "BCenter",
pos9: "BRight",
mm: "mm",
cm: "cm",
m: "m",
inch: "in",
px: "px",
transverse: "Landscape",
portrait: "Portrait",
ltrd: "Left-Right",
rtld: "Right-Left",
horizontal: "Horizontal",
fill: "Fill",
scale: "Scale",
original: "Original",
lineType1: "Straight",
lineType2: "Broken",
lineType3: "Curve",
pointType1: "Arrow",
pointType2: "Circle",
pointType21: "FillCir",
pointType3: "Rect",
pointType31: "FillRect",
pointType4: "Diamond",
pointType41: "FillDiam",
pointType5: "Triangle",
pointType51: "FillTria",
pointType6: "HalfCir",
pointType61: "FillHalfCir"
},
description: {}
},
control: {
groups: {
basic: "Basic Shapes",
flow: "Flow Shapes"
},
controltran: "CtrlTran",
pageref: "PageRef",
display: "Display",
delay: "Delay",
prepare: "Prepare",
card: "Card",
manualoperate: "Manual",
manualinput: "ManualIn",
looparea: "LoopArea",
"store-data": "StoreData",
"seq-data": "SeqData",
"direct-data": "DictData",
"defined-flow": "DefFlow",
"small-bracket": "Parenthes",
"middle-bracket": "Square",
"big-bracket": "Curly",
comment: "Comment",
document: "Document",
polygon: "Polygon",
stage: "Stage",
text: "Text",
square: "Square",
rectangle: "Rectangle",
circle: "Circle",
squareRound: "Square",
rectangleRound: "Rectangle",
ellipse: "Ellipse",
cube: "Cube",
line: "Line",
triangle: "Triangle",
hexstar: "Hexstar",
"triangle-left-90": "Triangle",
"triangle-right-90": "Triangle",
fivestar: "Fivestar",
diamond: "Diamond",
paralgram: "Paralgram",
"triangle-left-90-round": "Triangle",
hexagon: "Hexagon",
"half-circle": "HalfCir",
"rectangle-split": "SplitRect",
"circle-split": "SplitCir",
trapezoid: "Trapezoid",
"arrow-left": "ArrowLeft",
"arrow-right": "ArrowRight",
pentagon: "Pentagon",
angle: "Angle",
bidfunnel: "BidFunnel",
ptap: "PaperTape",
human: "Human",
start: "Start",
end: "End",
task: "Task",
"start-or-end": "StartEnd",
switch: "Switch",
subflow: "SubFlow",
description: {}
},
selectColor: {
"standard": "Standard",
"recently": "Recent",
"choosed": "Selected"
}
}
};
const __vite_glob_0_0$6 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: en_US$1
}, Symbol.toStringTag, { value: "Module" }));
const zh_CN$1 = {
ddei: {
file: "文件",
new: "新建",
open: "打开",
save: "保存",
abort: "放弃",
publish: "发布",
download: "下载",
export: "导出",
import: "导入",
clear: "清空",
close: "关闭",
collection: "收藏",
confirm: "确定",
cancel: "取消",
cutBoard: "剪切板",
textEdit: "文本编辑",
tools: "工具",
sortAndAlign: "排列与对齐",
sort: "排列",
scale: "缩放",
style: "样式",
fill: "填充",
border: "边框",
line: "线条",
layout: "布局",
text: "文本",
code: "编码",
name: "名称",
desc: "备注",
format: "格式",
data: "数据",
database: "数据库",
setting: "设置",
cut: "剪切",
copy: "复制",
delete: "删除",
paste: "粘贴",
more: "更多",
page: "页面",
shapesCount: "形状数:",
shapes: "形状",
layerName: "图层",
newLayer: "新建图层",
background: "背景",
backgroundColor: "背景颜色",
position: "位置",
align: "对齐",
combina: "组合",
cancelCombina: "取消组合",
flip: "翻转",
rotate: "旋转",
mirror: "镜像",
choose: "选择",
moveStage: "移动画布",
linkLine: "连接线",
search: "搜索",
replace: "替换",
fileDescription: "DDei设计文件",
wholePage: "整页",
precent: "百分比",
chooseShapeGroups: "选择图形",
basicSubject: "基本",
umlSubject: "UML",
brush: "格式刷",
startPoint: "起点",
endPoint: "终点",
lineType: "类型",
lineColor: "颜色",
lineWeight: "粗细",
lineDash: "虚线",
pushUp: "上移一层",
pushDown: "下移一层",
pushTop: "置于顶层",
pushBottom: "置于底层",
assistant: "辅助功能",
mark: "水印",
paper: "纸张",
propertyName: "属性",
searchResult: "搜索结果",
property: {
id: "id",
code: "编码",
text: "文本",
format: "格式化",
width: "宽度",
weight: "大小",
height: "高度",
borderType: "边框类型",
fillType: "填充类型",
startPointType: "起点",
endPointType: "终点",
type: "类型",
color: "颜色",
opacity: "透明度",
dash: "虚线",
round: "圆角",
image: "图片",
font: "字体",
size: "大小",
align: "对齐",
feed: "换行",
outSize: "超出范围",
lockWidth: "锁定宽度",
paddingWeight: "间隔大小",
hollow: "镂空",
bold: "加粗",
italic: "倾斜",
underline: "下划线",
deleteline: "删除线",
topline: "顶部线",
textbg: "文字背景",
subtype: "标注类型",
textAlign: "水平对齐",
textValign: "垂直对齐",
hspace: "水平间距",
vspace: "垂直间距",
dateType: "日期类型",
nscale: "小数",
tmark: "千分符",
mmark: "货币符号",
moneyUnit: "货币单位",
moneyUpCase: "人民币大写",
paperType: "纸张类型",
unit: "单位",
direct: "方向",
markType: "水印类型",
mark: "水印",
markDirect: "水印方向",
ruler: "标尺",
grid: "网格",
jumpline: "自动跳线",
background: "背景",
backgroundColor: "背景颜色",
backgroundImage: "背景图片",
bgImageMode: "图片模式",
bgImageScale: "缩放",
bgImagePosition: "位置",
code001: "编码001",
linePointType: "端点类型",
ds: {
none: "无",
color: "纯色",
image: "图片",
yes: "是",
no: "否",
global: "全局",
hidden: "隐藏",
ellipsis: "省略",
narrow: "缩小",
ext: "扩展",
subType: "正常",
subType1: "上标",
subType2: "中标",
subType3: "下标",
text: "文本",
decimal: "数字",
money: "金额",
time: "时间",
custom: "自定义",
money1: "人民币",
money2: "美元",
money3: "欧元",
money4: "英镑",
money5: "日元",
money6: "卢布",
money7: "法郎",
line: "实线",
point: "点阵",
pos1: "左上",
pos2: "中上",
pos3: "右上",
pos4: "左中",
pos5: "正中",
pos6: "右中",
pos7: "左下",
pos8: "中下",
pos9: "右下",
mm: "毫米",
cm: "厘米",
m: "米",
inch: "英寸",
px: "像素",
transverse: "横向",
portrait: "纵向",
ltrd: "左上右下",
rtld: "右上左下",
horizontal: "水平显示",
fill: "填充",
scale: "缩放",
original: "原始",
lineType1: "直线",
lineType2: "折线",
lineType3: "曲线",
pointType1: "箭头",
pointType2: "圆",
pointType21: "实心圆",
pointType3: "方形",
pointType31: "实心方形",
pointType4: "菱形",
pointType41: "实心菱形",
pointType5: "三角",
pointType51: "实心三角",
pointType6: "半圆",
pointType61: "实心半圆"
},
description: {}
},
control: {
groups: {
basic: "基础图形",
flow: "流程图形"
},
controltran: "控制传递",
pageref: "跨页引用",
display: "显示内容",
delay: "推迟",
prepare: "准备",
card: "卡片",
manualoperate: "手动操作",
manualinput: "手动输入",
looparea: "循环界限",
"store-data": "存储数据",
"seq-data": "顺序数据",
"direct-data": "直接数据",
"defined-flow": "预定义流程",
"small-bracket": "小括号",
"middle-bracket": "中括号",
"big-bracket": "大括号",
comment: "注释",
document: "文档",
polygon: "多边形",
stage: "画布",
text: "文本",
square: "正方形",
rectangle: "长方形",
circle: "圆",
ellipse: "椭圆",
cube: "正方体",
line: "连接线",
triangle: "三角形",
hexstar: "六角形",
"triangle-left-90": "直角三角形",
"triangle-right-90": "直角三角形",
fivestar: "五角星",
diamond: "菱形",
paralgram: "平行四边形",
hexagon: "六边形",
"half-circle": "半圆",
"rectangle-split": "长方形-切割",
"circle-split": "圆-切割",
trapezoid: "梯形",
"arrow-left": "左箭头",
"arrow-right": "右箭头",
pentagon: "五边形",
angle: "角",
bidfunnel: "双向漏斗",
ptap: "纸带",
human: "人",
start: "开始",
end: "结束",
task: "任务",
"start-or-end": "开始/结束",
switch: "分支",
subflow: "子流程",
description: {}
},
selectColor: {
"standard": "标准颜色",
"recently": "最近使用",
"choosed": "已选颜色"
},
"confirm-save-file": "是否保存文件?"
}
};
const __vite_glob_0_1$3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: zh_CN$1
}, Symbol.toStringTag, { value: "Module" }));
const _sfc_main$1f = {
name: "ddei-core-panel-topmenu",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
file: null,
forceRefresh: true
};
},
//注册组件
components: {},
computed: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
//强制刷新当前以及下层组件
forceRefreshParts(parts) {
if (!parts || parts == "topmenu" || parts.indexOf("topmenu") != -1) {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
}
});
}
},
refreshData() {
var _a3, _b2;
this.editor.topMenuViewer = this;
let file = (_b2 = this.editor) == null ? void 0 : _b2.files[(_a3 = this.editor) == null ? void 0 : _a3.currentFileIndex];
this.file = file;
},
/**
* 焦点进入当前区域
*/
changeEditorFocus() {
if (this.editor.state != DDeiEditorState.TOP_MENU_OPERATING && this.editor.state != DDeiEditorState.QUICK_EDITING) {
this.editor.changeState(DDeiEditorState.TOP_MENU_OPERATING);
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.executeAll();
}
}
};
const TopMenu_vue_vue_type_style_index_0_scoped_fefbc1f9_lang = "";
const _hoisted_1$1d = { class: "ddei-core-panel-topmenu-quickbox" };
function _sfc_render$1f(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return $data.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
class: "ddei-core-panel-topmenu",
onMousedown: _cache[0] || (_cache[0] = (...args) => $options.changeEditorFocus && $options.changeEditorFocus(...args))
}, [
vue.createElementVNode("div", _hoisted_1$1d, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_a3 = $props.editor) == null ? void 0 : _a3.getPartPanels($props.options, "panels"), (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
options: item.options,
ref_for: true
}, item.options), null, 16, ["editor", "controlDefine", "options"]);
}), 256))
])
], 32)) : vue.createCommentVNode("", true);
}
const TopMenu = /* @__PURE__ */ _export_sfc(_sfc_main$1f, [["render", _sfc_render$1f], ["__scopeId", "data-v-fefbc1f9"]]);
const _DDeiCoreTopMenuPanel = class _DDeiCoreTopMenuPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", TopMenu.name);
__publicField3(this, "defaultOptions", {
"panels": [
"ddei-core-panel-fileinfo",
"ddei-core-panel-operate",
"ddei-core-panel-fontandtext",
"ddei-core-panel-tool",
"ddei-core-panel-sort"
]
});
__publicField3(this, "plugins", [TopMenu]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[TopMenu.name]) {
for (let i2 in options[TopMenu.name]) {
newOptions[i2] = options[TopMenu.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreTopMenuPanel(newOptions);
return panels;
}
}
return _DDeiCoreTopMenuPanel;
}
static modify(fn) {
return _DDeiCoreTopMenuPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreTopMenuPanel, "defaultIns", new _DDeiCoreTopMenuPanel());
let DDeiCoreTopMenuPanel = _DDeiCoreTopMenuPanel;
const _sfc_main$1e = {
name: "ddei-core-panel-toolbox",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
//是否允许自定义控件工具箱
custom: {
type: Boolean,
default: true
},
//是否允许搜索控件
search: {
type: Boolean,
default: true
},
//定义分组
customGroups: {
type: Array,
default: null
},
//是否允许展开收折
expand: {
type: Boolean,
default: true
}
},
data() {
return {
//分组数据
groups: [],
//用于搜索时保存原始的groups
searchOriginGroups: null,
//搜索控件时用的文本
searchText: "",
forceRefresh: true
};
},
computed: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
//强制刷新当前以及下层组件
forceRefreshParts(parts) {
if (!parts || parts == "toolbox" || parts.indexOf("toolbox") != -1) {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
}
});
}
},
refreshData() {
var _a3;
this.editor.needControlIcon = true;
this.editor.toolBarViewer = this;
if (this.editor.ddInstance && !this.editor.ddInstance.render) {
this.editor.ddInstance.initRender();
}
DDeiEditorUtil.readRecentlyToolGroups();
let hisGroups = DDeiEditorUtil.recentlyToolGroups;
if ((hisGroups == null ? void 0 : hisGroups.length) > 0) {
let groups = [];
hisGroups.forEach((hg) => {
let group2 = null;
for (let i2 = 0; i2 < this.editor.groups.length; i2++) {
if (this.editor.groups[i2].id == hg.id) {
group2 = this.editor.groups[i2];
break;
}
}
if (group2) {
group2.expand = hg.expand;
groups.push(group2);
}
});
this.groups = groups;
} else {
this.groups = clone(this.editor.groups);
DDeiEditorUtil.whiteRecentlyToolGroups(this.groups);
}
if (this.customGroups) {
let newGroups = [];
(_a3 = this.customGroups) == null ? void 0 : _a3.forEach((cg) => {
for (let i2 = 0; i2 < this.groups.length; i2++) {
if (this.groups[i2].id == cg) {
newGroups.push(this.groups[i2]);
break;
}
}
});
this.groups = newGroups;
}
this.searchOriginGroups = this.groups;
},
mouseWheel(evt) {
if (evt.currentTarget.clientHeight < evt.currentTarget.scrollHeight) {
evt.cancelBubble = true;
return false;
}
},
cancelCreateControl(e) {
if (this.editor.state == DDeiEditorState.CONTROL_CREATING) {
if (this.editor.creatingControls) {
let ddInstance = this.editor.ddInstance;
let layer2 = ddInstance.stage.layers[ddInstance.stage.layerIndex];
layer2.removeModels(this.editor.creatingControls, true, false);
this.editor.bus.push(DDeiEnumBusCommandType.ClearTemplateVars);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape, null, e);
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.changeState(DDeiEditorState.TOOLBOX_ACTIVE);
this.editor.bus.executeAll();
e.preventDefault();
e.cancelBubble = true;
}
},
/**
* 弹出选择控件Dialog
*/
showChooseDialog(evt) {
let srcElement = evt.currentTarget;
let selectGroups = [];
this.groups.forEach((group2) => {
if (group2.display) {
selectGroups.push(group2.id);
}
});
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-choosecontrolgroup", {
selectGroups,
callback: {
select: this.groupBoxChoose
},
group: "toolbox-dialog"
}, { type: 4 }, srcElement);
},
/**
* 隐藏工具栏
*/
hiddenToolBox() {
window.leftWidth = this.editor.leftWidth;
this.editor.leftWidth = 0;
this.editor.changeState(DDeiEditorState.DESIGNING);
},
/**
* 展开或收折groupbox
*/
groupBoxExpand(group2) {
if (group2) {
group2.expand = !group2.expand;
DDeiEditorUtil.whiteRecentlyToolGroups(this.groups);
}
},
/**
* 关闭groupbox
*/
groupBoxClose(group2) {
if (group2) {
group2.display = false;
if (this.groups.indexOf(group2) != -1) {
this.groups.splice(this.groups.indexOf(group2), 1);
}
DDeiEditorUtil.whiteRecentlyToolGroups(this.groups);
}
},
/**
* 关闭groupbox
*/
groupBoxOpen(group2) {
if (group2) {
group2.display = true;
if (this.groups.indexOf(group2) == -1) {
this.groups.push(group2);
}
DDeiEditorUtil.whiteRecentlyToolGroups(this.groups);
}
},
/**
* 选择groupBox
*/
groupBoxChoose(groupid, choose) {
let group2 = null;
for (let i2 = 0; i2 < this.editor.groups.length; i2++) {
if (this.editor.groups[i2].id == groupid) {
group2 = this.editor.groups[i2];
break;
}
}
if (choose) {
this.groupBoxOpen(group2);
} else {
this.groupBoxClose(group2);
}
},
/**
* 搜索按钮按下时,检测是否按下enter,按下后执行搜索
* @param evt
*/
searchInputEnter(evt) {
if (evt.keyCode == 13) {
this.searchControl();
}
},
/**
* 焦点进入当前区域
*/
changeEditorFocus() {
this.editor.changeState(DDeiEditorState.TOOLBOX_ACTIVE);
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.executeAll();
},
/**
* 准备创建
*/
createControlPrepare(control, e) {
var _a3, _b2, _c2, _d2, _e2;
let ddInstance = this.editor.ddInstance;
ddInstance.render.inEdge = 0;
let stage2 = ddInstance.stage;
let layer2 = stage2.layers[stage2.layerIndex];
if (layer2.display == 0 && !layer2.tempDisplay || layer2.lock) {
return;
}
let controlInitJSON = DDeiEditorUtil.getModelInitJSON(this.editor.ddInstance, null, [control]);
if (!controlInitJSON) {
return;
}
let models = DDeiEditorUtil.createControl(controlInitJSON[0], this.editor);
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_CREATE_BEFORE", DDeiEnumOperateType.CREATE, { models }, ddInstance, e);
if (rsState == 0 || rsState == 1) {
DDeiUtil.invokeCallbackFunc("EVENT_MOUSE_OPERATING", DDeiEnumOperateType.CREATE, null, ddInstance, e);
let stageRatio2 = stage2.getStageRatio();
let moveMatrix2 = new Matrix3(
1,
0,
-stage2.wpv.x * stageRatio2,
0,
1,
-stage2.wpv.y * stageRatio2,
0,
0,
1
);
models.forEach((model) => {
model.transVectors(moveMatrix2);
model.setState(DDeiEnumControlState.CREATING);
});
if ((models == null ? void 0 : models.length) > 0) {
let ddInstance2 = this.editor.ddInstance;
let stage22 = ddInstance2.stage;
if (((_a3 = stage22 == null ? void 0 : stage22.render) == null ? void 0 : _a3.operateState) == DDeiEnumOperateState.QUICK_EDITING && ((_b2 = stage22 == null ? void 0 : stage22.render) == null ? void 0 : _b2.editorShadowControl)) {
(_c2 = DDeiUtil.getEditorText()) == null ? void 0 : _c2.enterValue();
}
this.editor.changeState(DDeiEditorState.CONTROL_CREATING);
this.editor.creatingControls = models;
(_d2 = this.editor.bus) == null ? void 0 : _d2.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
(_e2 = this.editor.bus) == null ? void 0 : _e2.executeAll();
}
e.preventDefault();
e.cancelBubble = true;
}
},
/**
* 搜索控件
*/
searchControl() {
let text2 = trim(this.searchText);
if (text2 == "") {
this.groups = this.searchOriginGroups;
} else {
let searchControls = [];
let gp = {};
gp.name = this.editor.i18n("ddei.searchResult");
this.searchOriginGroups.forEach((group2) => {
if (group2.controls) {
group2.controls.forEach((control) => {
if (control.code.indexOf(text2) != -1 || this.editor.i18n(control.name).indexOf(text2) != -1) {
searchControls.push(control);
}
});
}
});
gp.controls = cloneDeep(searchControls);
gp.display = true;
gp.expand = true;
gp.cannotClose = true;
this.groups = [gp];
}
}
}
};
const Toolbox_vue_vue_type_style_index_0_scoped_ea668126_lang = "";
const _hoisted_1$1c = { class: "ddei-core-panel-toolbox-header" };
const _hoisted_2$U = {
key: 0,
class: "icon icon1",
"aria-hidden": "true"
};
const _hoisted_3$Q = {
key: 1,
class: "header-3"
};
const _hoisted_4$F = { class: "header-4" };
const _hoisted_5$x = {
key: 0,
class: "ddei-core-panel-toolbox-searchbox"
};
const _hoisted_6$r = { class: "ddei-core-panel-toolbox-searchbox-group" };
const _hoisted_7$o = ["title"];
const _hoisted_8$k = ["placeholder"];
const _hoisted_9$i = { class: "ddei-core-panel-toolbox-groups-group" };
const _hoisted_10$c = ["onClick"];
const _hoisted_11$c = { class: "title" };
const _hoisted_12$9 = ["onClick", "title"];
const _hoisted_13$8 = {
key: 0,
class: "ddei-core-panel-toolbox-groups-group-itempanel"
};
const _hoisted_14$7 = ["title", "onMousedown"];
const _hoisted_15$6 = ["src"];
const _hoisted_16$4 = ["innerHTML"];
const _hoisted_17$3 = { class: "text" };
function _sfc_render$1e(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2;
return $data.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
onMousedown: _cache[6] || (_cache[6] = (...args) => $options.changeEditorFocus && $options.changeEditorFocus(...args)),
onMouseup: _cache[7] || (_cache[7] = ($event) => $options.cancelCreateControl($event)),
ref: "toolbox",
class: "ddei-core-panel-toolbox"
}, [
vue.createElementVNode("div", _hoisted_1$1c, [
_cache[12] || (_cache[12] = vue.createElementVNode("div", { class: "header-1" }, null, -1)),
$props.custom ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$U, _cache[8] || (_cache[8] = [
vue.createElementVNode("use", { "xlink:href": "#icon-control-icon" }, null, -1)
]))) : vue.createCommentVNode("", true),
$props.custom ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3$Q)) : vue.createCommentVNode("", true),
$props.custom ? (vue.openBlock(), vue.createElementBlock("div", {
key: 2,
class: "ddei-core-panel-toolbox-header-morecontrol",
onClick: _cache[0] || (_cache[0] = ($event) => $options.showChooseDialog($event))
}, [
vue.createElementVNode("div", _hoisted_4$F, vue.toDisplayString($props.editor.i18n("ddei.more")), 1),
_cache[9] || (_cache[9] = vue.createElementVNode("div", { class: "header-3" }, null, -1)),
_cache[10] || (_cache[10] = vue.createElementVNode("svg", {
class: "icon icon2",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
], -1))
])) : vue.createCommentVNode("", true),
_cache[13] || (_cache[13] = vue.createElementVNode("div", { style: { "flex": "1" } }, null, -1)),
$props.expand ? (vue.openBlock(), vue.createElementBlock("svg", {
key: 3,
class: "icon header-7",
"aria-hidden": "true",
onClick: _cache[1] || (_cache[1] = (...args) => $options.hiddenToolBox && $options.hiddenToolBox(...args))
}, _cache[11] || (_cache[11] = [
vue.createElementVNode("use", { "xlink:href": "#icon-expand3" }, null, -1)
]))) : vue.createCommentVNode("", true)
]),
$props.search ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_5$x, [
vue.createElementVNode("div", _hoisted_6$r, [
(vue.openBlock(), vue.createElementBlock("svg", {
class: "icon",
"aria-hidden": "true",
onClick: _cache[2] || (_cache[2] = (...args) => $options.searchControl && $options.searchControl(...args)),
title: $props.editor.i18n("ddei.search")
}, _cache[14] || (_cache[14] = [
vue.createElementVNode("use", { "xlink:href": "#icon-search" }, null, -1)
]), 8, _hoisted_7$o)),
vue.withDirectives(vue.createElementVNode("input", {
"onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => $data.searchText = $event),
class: "input",
onKeypress: _cache[4] || (_cache[4] = (...args) => $options.searchInputEnter && $options.searchInputEnter(...args)),
placeholder: $props.editor.i18n("ddei.search"),
autocomplete: "off",
name: "ddei_toolbox_search_input"
}, null, 40, _hoisted_8$k), [
[vue.vModelText, $data.searchText]
])
])
])) : vue.createCommentVNode("", true),
vue.createElementVNode("div", {
class: "ddei-core-panel-toolbox-groups",
onMousewheel: _cache[5] || (_cache[5] = ($event) => $options.mouseWheel($event)),
style: vue.normalizeStyle({ height: "calc(100vh - " + (((_a3 = $props.editor) == null ? void 0 : _a3.topHeight) + ((_b2 = $props.editor) == null ? void 0 : _b2.bottomHeight) + 90) + "px" })
}, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.groups, (group2) => {
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", _hoisted_9$i, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-core-panel-toolbox-groups-group-box": true, "ddei-core-panel-toolbox-groups-group--expanded": group2.expand }),
onClick: ($event) => $options.groupBoxExpand(group2)
}, [
vue.createElementVNode("span", _hoisted_11$c, vue.toDisplayString($props.editor.i18n(group2.name)), 1),
$props.custom && !group2.cannotClose ? (vue.openBlock(), vue.createElementBlock("svg", {
key: 0,
class: "icon close",
"aria-hidden": "true",
onClick: ($event) => $options.groupBoxClose(group2),
title: $props.editor.i18n("ddei.close")
}, _cache[15] || (_cache[15] = [
vue.createElementVNode("use", { "xlink:href": "#icon-close" }, null, -1)
]), 8, _hoisted_12$9)) : vue.createCommentVNode("", true)
], 10, _hoisted_10$c),
group2.expand == true ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_13$8, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(group2.controls, (control) => {
var _a4;
return vue.openBlock(), vue.createElementBlock("div", {
class: "ddei-core-panel-toolbox-groups-group-itempanel-item",
title: control.desc,
onMousedown: ($event) => $options.createControlPrepare(control, $event)
}, [
!control.icon ? (vue.openBlock(), vue.createElementBlock("img", {
key: 0,
class: "icon",
src: (_a4 = $props.editor) == null ? void 0 : _a4.icons[control.id]
}, null, 8, _hoisted_15$6)) : vue.createCommentVNode("", true),
control.icon ? (vue.openBlock(), vue.createElementBlock("div", {
key: 1,
innerHTML: control.icon
}, null, 8, _hoisted_16$4)) : vue.createCommentVNode("", true),
vue.createElementVNode("div", _hoisted_17$3, vue.toDisplayString($props.editor.i18n(control.name)), 1)
], 40, _hoisted_14$7);
}), 256))
])) : vue.createCommentVNode("", true)
], 512)), [
[vue.vShow, group2.display == true]
]);
}), 256))
], 36)
], 544)) : vue.createCommentVNode("", true);
}
const Toolbox = /* @__PURE__ */ _export_sfc(_sfc_main$1e, [["render", _sfc_render$1e], ["__scopeId", "data-v-ea668126"]]);
const _DDeiCoreToolboxPanel = class _DDeiCoreToolboxPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", Toolbox.name);
__publicField3(this, "plugins", [Toolbox]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[Toolbox.name]) {
for (let i2 in options[Toolbox.name]) {
newOptions[i2] = options[Toolbox.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreToolboxPanel(newOptions);
return panels;
}
}
return _DDeiCoreToolboxPanel;
}
static modify(fn) {
return _DDeiCoreToolboxPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreToolboxPanel, "defaultIns", new _DDeiCoreToolboxPanel());
let DDeiCoreToolboxPanel = _DDeiCoreToolboxPanel;
const _DDeiCoreToolboxPanels = class _DDeiCoreToolboxPanels extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [DDeiCoreToolboxPanel]);
}
getPanels(editor) {
var _a3;
let panels = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getPanels(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getPanels(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
panels = panels.concat(ls);
}
});
return panels;
}
static configuration(options) {
var _a3;
if (options) {
let panels = new _DDeiCoreToolboxPanels(options);
for (let i2 = 0; i2 < ((_a3 = panels.plugins) == null ? void 0 : _a3.length); i2++) {
panels.plugins[i2] = panels.plugins[i2].configuration(options, true);
}
return panels;
}
return _DDeiCoreToolboxPanels;
}
static modify(fn) {
return _DDeiCoreToolboxPanels.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreToolboxPanels, "defaultIns", new _DDeiCoreToolboxPanels(null));
let DDeiCoreToolboxPanels = _DDeiCoreToolboxPanels;
const _sfc_main$1d = {
name: "ddei-core-panel-quickcolorview",
extends: null,
mixins: [],
props: {
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
colors: [],
//当前编辑的模式,1填充,2边框,3字体
mode: 1,
dataSource: [
{ value: 1, text: "填充", img: "#icon-fill" },
{ value: 2, text: "边框", img: "#icon-border-pencil" },
{ value: 3, text: "字体", img: "#icon-font" }
]
};
},
computed: {},
watch: {},
created() {
},
mounted() {
this.colors = [
"#FFB6C1",
"#FFC0CB",
"#DC143C",
"#FF0F55",
"#DB7093",
"#FF69B4",
"#FF1493",
"#C71585",
"#DA70D6",
"#D8BFD8",
"#DDA0DD",
"#EE82EE",
"#FF00FF",
"#FF00FF",
"#8B008B",
"#800080",
"#BA55D3",
"#9400D3",
"#9932CC",
"#4B0082",
"#8A2BE2",
"#9370DB",
"#7B68EE",
"#6A5ACD",
"#483D8B",
"#E6E6FA",
"#F8F8FF",
"#0000FF",
"#0000FF",
"#0000CD",
"#191970",
"#00008B",
"#000080",
"#4169E1",
"#6495ED",
"#B0C4DE",
"#778899",
"#708090",
"#1E90FF",
"#F0F8FF",
"#4682B4",
"#87CEFA",
"#87CEEB",
"#00BFFF",
"#ADD8E6",
"#B0E0E6",
"#5F9EA0",
"#F0FFFF",
"#E1FFFF",
"#AFEEEE",
"#00FFFF",
"#00FFFF",
"#00CED1",
"#2F4F4F",
"#008B8B",
"#008080",
"#48D1CC",
"#20B2AA",
"#40E0D0",
"#7FFFAA",
"#00FA9A",
"#00FF7F",
"#F5FFFA",
"#3CB371",
"#2E8B57",
"#F0FFF0",
"#90EE90",
"#98FB98",
"#8FBC8F",
"#32CD32",
"#00FF00",
"#228B22",
"#008000",
"#006400",
"#7FFF00",
"#7CFC00",
"#ADFF2F",
"#556B2F",
"#F5F5DC",
"#FAFAD2",
"#FFFFF0",
"#FFFFE0",
"#FFFF00",
"#808000",
"#BDB76B",
"#FFFACD",
"#EEE8AA",
"#F0E68C",
"#FFD700",
"#FFF8DC"
];
},
methods: {
changeMode(m) {
this.mode = m.value;
},
//打开弹出框
showDialog(evt) {
let dataSource = [];
this.dataSource.forEach((ds) => {
if (ds.value != this.mode) {
dataSource.push(ds);
}
});
let el = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(
this.editor,
"ddei-core-dialog-qcview",
{
dataSource,
callback: {
ok: this.changeMode
}
},
{ type: 2 },
el
);
},
/**
* 改变模型颜色
*/
changeModelColor(color, evt) {
let stage2 = this.editor.ddInstance.stage;
if (stage2 && color) {
let selectedModels = stage2.selectedModels;
if ((selectedModels == null ? void 0 : selectedModels.size) > 0) {
let mds = Array.from(selectedModels.values());
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds }, this.editor.ddInstance);
if (rsState != -1) {
switch (this.mode) {
case 1:
selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [element.id], paths: ["fill.color"], value: color },
evt,
true
);
});
break;
case 2:
selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths: [
"border.color",
"border.top.color",
"border.bottom.color",
"border.left.color",
"border.right.color"
],
value: color
},
evt,
true
);
});
break;
case 3:
selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [element.id], paths: ["font.color"], value: color },
evt,
true
);
});
break;
}
this.editor.bus.push(
DDeiEnumBusCommandType.StageChangeSelectModels,
null,
evt
);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
this.editor.bus.executeAll();
}
}
}
}
}
};
const QuickColorView_vue_vue_type_style_index_0_scoped_f305cac8_lang = "";
const _hoisted_1$1b = { class: "ddei-editor-qcview" };
const _hoisted_2$T = ["title"];
const _hoisted_3$P = {
class: "icon",
"aria-hidden": "true"
};
const _hoisted_4$E = ["xlink:href"];
const _hoisted_5$w = ["onClick"];
function _sfc_render$1d(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$1b, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (item) => {
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
class: "ddei-editor-qcview-type",
onClick: _cache[0] || (_cache[0] = ($event) => $options.showDialog($event)),
title: item.text
}, [
(vue.openBlock(), vue.createElementBlock("svg", _hoisted_3$P, [
vue.createElementVNode("use", {
"xlink:href": item.img
}, null, 8, _hoisted_4$E)
])),
_cache[1] || (_cache[1] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
], -1))
], 8, _hoisted_2$T)), [
[vue.vShow, item.value == $data.mode]
]);
}), 256)),
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.colors, (color) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-editor-qcview-color": true }),
style: vue.normalizeStyle({ "background-color": "" + color }),
onClick: ($event) => {
var _a3, _b2, _c2, _d2;
return ((_d2 = (_c2 = (_b2 = (_a3 = $props.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0 && $options.changeModelColor(color, $event);
}
}, null, 12, _hoisted_5$w);
}), 256))
]);
}
const QuickColorView = /* @__PURE__ */ _export_sfc(_sfc_main$1d, [["render", _sfc_render$1d], ["__scopeId", "data-v-f305cac8"]]);
const _DDeiCoreQuickColorViewPanel = class _DDeiCoreQuickColorViewPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QuickColorView.name);
__publicField3(this, "plugins", [QuickColorView]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QuickColorView.name]) {
for (let i2 in options[QuickColorView.name]) {
newOptions[i2] = options[QuickColorView.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreQuickColorViewPanel(newOptions);
return panels;
}
}
return _DDeiCoreQuickColorViewPanel;
}
static modify(fn) {
return _DDeiCoreQuickColorViewPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreQuickColorViewPanel, "defaultIns", new _DDeiCoreQuickColorViewPanel(null));
let DDeiCoreQuickColorViewPanel = _DDeiCoreQuickColorViewPanel;
const _sfc_main$1c = {
name: "ddei-core-panel-propertyview",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
//是否允许展开收折
expand: {
type: Boolean,
default: true
}
},
data() {
return {
//当前被选中控件的引用
selectedModels: null,
//属性定义的引用
controlDefine: null,
//当前的顶级group
topGroups: null,
currentTopGroup: null,
currentSubGroup: null,
reFresh: true,
propertyDisabled: false,
propertyViewShow: true,
pvGroupWidth: 0,
rightRate: 0,
//右边部分所占的比例
forceRefresh: true
};
},
computed: {},
watch: {
currentSubGroup() {
this.forceRefreshSub();
}
},
components: {},
created() {
this.$watch("editor.ddInstance.stage.selectedModels", this.refreshAttrs);
this.$watch("editor.maxWidth", function(newVal, oldVal) {
if (this.rightRate == 0) {
this.rightRate = this.editor.rightWidth / document.body.clientWidth;
}
});
},
mounted() {
},
methods: {
//强制刷新当前以及下层组件
forceRefreshParts(parts) {
if (!parts || parts == "property" || parts.indexOf("property") != -1) {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
}
});
}
},
refreshData() {
this.editor.properyViewer = this;
this.refreshAttrs();
},
mouseWheel(evt) {
if (evt.currentTarget.clientHeight < evt.currentTarget.scrollHeight) {
evt.cancelBubble = true;
return false;
}
},
forceRefreshSub() {
this.reFresh = false;
this.propertyDisabled = false;
this.$nextTick(() => {
this.propertyDisabled = this.editor.state == DDeiEditorState.QUICK_EDITING;
this.reFresh = true;
});
},
refreshAttrs(newVal, oldVal) {
var _a3, _b2, _c2, _d2, _e2, _f;
let firstControlDefine;
let firstModel;
if (!this.editor.currentControlDefine) {
let models = [this.editor.ddInstance.stage];
firstModel = models[0];
this.selectedModels = models;
firstControlDefine = cloneDeep(
this.editor.controls.get(firstModel == null ? void 0 : firstModel.modelCode)
);
} else {
this.selectedModels = this.editor.ddInstance.stage.selectedModels;
if (((_a3 = this.selectedModels) == null ? void 0 : _a3.size) > 0) {
firstModel = Array.from(this.selectedModels.values());
firstControlDefine = this.editor.currentControlDefine;
}
}
if (firstControlDefine) {
let topGroups = null;
if (firstControlDefine.type == "DDeiStage") {
firstControlDefine.attrDefineMap.forEach((attrDefine, attrKey) => {
attrDefine.value = DDeiUtil.getDataByPathList(
firstModel,
attrDefine.code,
attrDefine.mapping
);
attrDefine.model = firstModel;
});
let layerControlDefine = cloneDeep(
this.editor.controls.get("DDeiLayer")
);
let layer2 = firstModel.layers[firstModel.layerIndex];
layerControlDefine.attrDefineMap.forEach((attrDefine, attrKey) => {
attrDefine.value = DDeiUtil.getDataByPathList(
layer2,
attrDefine.code,
attrDefine.mapping
);
attrDefine.model = layer2;
});
firstControlDefine.groups.forEach((topGroup) => {
topGroup.img = topGroup.icon;
});
layerControlDefine.groups.forEach((topGroup) => {
topGroup.img = topGroup.icon;
});
topGroups = layerControlDefine.groups.concat(firstControlDefine.groups);
} else {
firstControlDefine.groups.forEach((topGroup) => {
topGroup.img = topGroup.icon;
});
topGroups = firstControlDefine.groups;
}
if ((topGroups == null ? void 0 : topGroups.length) > 0) {
let upName = (_b2 = this.currentTopGroup) == null ? void 0 : _b2.name;
let currentTopGroup = null;
if (upName) {
for (let x2 = 0; x2 < firstControlDefine.groups.length; x2++) {
let topGroup = topGroups[x2];
if (!topGroup.empty && upName == topGroup.name) {
topGroup.selected = true;
currentTopGroup = topGroup;
break;
}
}
}
if (!currentTopGroup) {
topGroups[0].selected = true;
currentTopGroup = topGroups[0];
}
this.currentTopGroup = currentTopGroup;
this.controlDefine = firstControlDefine;
this.topGroups = topGroups;
let upSubGroupName = (_c2 = this.currentSubGroup) == null ? void 0 : _c2.name;
let currentSubGroup = null;
if (upSubGroupName) {
for (let sgi = 0; sgi < (currentTopGroup == null ? void 0 : currentTopGroup.subGroups.length); sgi++) {
if (!((_d2 = currentTopGroup == null ? void 0 : currentTopGroup.subGroups[sgi]) == null ? void 0 : _d2.empty) && upSubGroupName == ((_e2 = currentTopGroup == null ? void 0 : currentTopGroup.subGroups[sgi]) == null ? void 0 : _e2.name)) {
currentSubGroup = currentTopGroup == null ? void 0 : currentTopGroup.subGroups[sgi];
break;
}
}
}
if (!currentSubGroup) {
for (let sgi = 0; sgi < (currentTopGroup == null ? void 0 : currentTopGroup.subGroups.length); sgi++) {
if (!((_f = currentTopGroup == null ? void 0 : currentTopGroup.subGroups[sgi]) == null ? void 0 : _f.empty)) {
currentSubGroup = currentTopGroup == null ? void 0 : currentTopGroup.subGroups[sgi];
break;
}
}
}
this.changeSubGroup(currentSubGroup);
} else {
this.controlDefine = null;
this.topGroups = null;
if (this.currentTopGroup) {
this.currentTopGroup.subGroups = null;
}
if (this.currentSubGroup) {
this.currentSubGroup.children = null;
}
this.editor.currentControlDefine = null;
}
}
},
getFirstChildAttrsGroup(control) {
var _a3, _b2;
if (((_a3 = control.models) == null ? void 0 : _a3.size) > 0) {
let firstControl = control.models.get(control.midList[0]);
let curDefine = this.editor.controls.get(firstControl.modelCode);
if (((_b2 = curDefine.groups) == null ? void 0 : _b2.length) > 0) {
let returnGroups = curDefine.groups;
returnGroups.forEach((group2) => {
group2 == null ? void 0 : group2.subGroups.forEach((subGroup) => {
var _a4;
(_a4 = subGroup.children) == null ? void 0 : _a4.forEach((attrDefine) => {
attrDefine.value = DDeiUtil.getDataByPathList(
firstControl,
attrDefine.code,
attrDefine.mapping
);
attrDefine.model = firstControl;
});
});
});
return returnGroups;
} else if (firstControl.baseModelType == "DDeiContainer" && firstControl.layout == "compose") {
return this.getFirstChildAttrsGroup(firstControl);
}
}
return null;
},
/**
* 展开顶级属性,收起其他顶级层级
*/
changeTopGroup(pData) {
var _a3, _b2, _c2, _d2;
if (this.currentTopGroup != pData) {
this.topGroups.forEach((group2) => {
if (group2 != pData) {
group2.selected = false;
}
});
pData.selected = true;
this.currentTopGroup = pData;
let upSubGroupName = (_a3 = this.currentSubGroup) == null ? void 0 : _a3.name;
let currentSubGroup = null;
if (upSubGroupName) {
for (let sgi = 0; sgi < (pData == null ? void 0 : pData.subGroups.length); sgi++) {
if (!((_b2 = pData == null ? void 0 : pData.subGroups[sgi]) == null ? void 0 : _b2.empty) && upSubGroupName == ((_c2 = pData == null ? void 0 : pData.subGroups[sgi]) == null ? void 0 : _c2.name)) {
currentSubGroup = pData == null ? void 0 : pData.subGroups[sgi];
break;
}
}
}
if (!currentSubGroup) {
for (let sgi = 0; sgi < (pData == null ? void 0 : pData.subGroups.length); sgi++) {
if (!((_d2 = pData == null ? void 0 : pData.subGroups[sgi]) == null ? void 0 : _d2.empty)) {
currentSubGroup = pData == null ? void 0 : pData.subGroups[sgi];
break;
}
}
}
this.changeSubGroup(currentSubGroup);
}
},
/**
* 展开次级属性,收起其他次级层级
*/
changeSubGroup(pData) {
var _a3, _b2;
if (this.currentSubGroup != pData) {
this.currentTopGroup.subGroups.forEach((group2) => {
if (group2 != pData) {
group2.selected = false;
}
});
pData.selected = true;
this.selectedModels = this.editor.ddInstance.stage.selectedModels;
let models = null;
if (((_a3 = this.selectedModels) == null ? void 0 : _a3.size) > 0) {
models = Array.from(this.selectedModels.values());
} else {
models = [this.editor.ddInstance.stage];
}
(_b2 = pData == null ? void 0 : pData.children) == null ? void 0 : _b2.forEach((attd) => {
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_VIEW_BEFORE", DDeiEnumOperateType.VIEW, { models, propName: attd == null ? void 0 : attd.code }, this.editor.ddInstance, null);
if (rsState == 0 || rsState == 1) {
attd.forceHidden = false;
} else {
attd.forceHidden = true;
}
});
this.currentSubGroup = pData;
}
setTimeout(() => {
this.$forceUpdate();
}, 100);
},
syncAttrsToGroup(firstControlDefine, pData) {
var _a3, _b2;
let newChildren = [];
if (((_a3 = pData == null ? void 0 : pData.groups) == null ? void 0 : _a3.length) > 0) {
(_b2 = pData == null ? void 0 : pData.groups) == null ? void 0 : _b2.forEach((group2) => {
var _a4;
let newGroupChildren = [];
(_a4 = group2.children) == null ? void 0 : _a4.forEach((curAttr) => {
var _a5;
let mapObj = (_a5 = firstControlDefine == null ? void 0 : firstControlDefine.attrDefineMap) == null ? void 0 : _a5.get(curAttr.code);
if (mapObj && mapObj.visiable != false) {
mapObj.topGroup = pData;
mapObj.modelCode = firstControlDefine.type;
newGroupChildren.push(mapObj);
newChildren.push(mapObj);
}
});
group2.children = newGroupChildren;
if (newGroupChildren.length == 0) {
group2.empty = true;
}
});
}
pData.children = newChildren;
if (newChildren.length == 0) {
pData.empty = true;
}
},
/**
* 隐藏or展示属性编辑器
*/
hidOrShowPV() {
this.propertyViewShow = !this.propertyViewShow;
let pvFullWidth = document.body.clientWidth * this.rightRate;
let pvGroupViewEle = this.$refs.propertyviewGroupview;
this.pvGroupWidth = pvGroupViewEle.clientWidth;
if (this.editor.rightWidth > this.pvGroupWidth) {
let deltaX = pvFullWidth - this.pvGroupWidth;
this.editor.rightWidth = this.pvGroupWidth;
this.editor.middleWidth += deltaX;
} else {
let deltaX = pvFullWidth - this.pvGroupWidth;
this.editor.rightWidth = pvFullWidth;
this.editor.middleWidth -= deltaX;
}
this.editor.changeState(DDeiEditorState.DESIGNING);
},
/**
* 焦点进入当前区域
*/
changeEditorFocus() {
if (this.editor.state != DDeiEditorState.PROPERTY_EDITING && this.editor.state != DDeiEditorState.QUICK_EDITING) {
this.editor.changeState(DDeiEditorState.PROPERTY_EDITING);
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.executeAll();
}
}
};
const PropertyView_vue_vue_type_style_index_0_scoped_156d5ed6_lang = "";
const _hoisted_1$1a = { class: "propertyview-header" };
const _hoisted_2$S = {
key: 0,
"xlink:href": "#icon-expand4"
};
const _hoisted_3$O = {
key: 1,
"xlink:href": "#icon-expand3"
};
const _hoisted_4$D = {
key: 1,
class: "icon ding",
"aria-hidden": "true"
};
const _hoisted_5$v = { class: "content" };
const _hoisted_6$q = { class: "propertyview-subgroup" };
const _hoisted_7$n = { class: "propertyview-subgroup-tabtitle" };
const _hoisted_8$j = ["title", "onMouseup"];
const _hoisted_9$h = ["title"];
const _hoisted_10$b = {
key: 0,
class: "title"
};
const _hoisted_11$b = { key: 0 };
const _hoisted_12$8 = {
key: 1,
class: "editor"
};
const _hoisted_13$7 = {
class: "propertyview-groupview",
ref: "propertyviewGroupview"
};
const _hoisted_14$6 = { class: "propertyview-groupview-items" };
const _hoisted_15$5 = ["onClick", "title"];
const _hoisted_16$3 = {
class: "icon img",
"aria-hidden": "true"
};
const _hoisted_17$2 = ["xlink:href"];
function _sfc_render$1c(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2;
return $data.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
ref: "propertyView",
class: vue.normalizeClass({ "propertyview": true, "propertyview--disabled": $data.propertyDisabled }),
onMousedown: _cache[2] || (_cache[2] = (...args) => $options.changeEditorFocus && $options.changeEditorFocus(...args))
}, [
vue.createElementVNode("div", _hoisted_1$1a, [
$props.expand ? (vue.openBlock(), vue.createElementBlock("svg", {
key: 0,
"aria-hidden": "true",
class: vue.normalizeClass({ "icon": true, "header-7": $data.propertyViewShow, "header-7-expand": !$data.propertyViewShow }),
onClick: _cache[0] || (_cache[0] = (...args) => $options.hidOrShowPV && $options.hidOrShowPV(...args))
}, [
$data.propertyViewShow ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_2$S)) : vue.createCommentVNode("", true),
!$data.propertyViewShow ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_3$O)) : vue.createCommentVNode("", true)
], 2)) : vue.createCommentVNode("", true),
_cache[4] || (_cache[4] = vue.createElementVNode("div", { style: { "flex": "1" } }, null, -1)),
$data.propertyViewShow ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_4$D, _cache[3] || (_cache[3] = [
vue.createElementVNode("use", { "xlink:href": "#icon-ding" }, null, -1)
]))) : vue.createCommentVNode("", true)
]),
vue.createElementVNode("div", _hoisted_5$v, [
vue.withDirectives(vue.createElementVNode("div", _hoisted_6$q, [
vue.createElementVNode("div", _hoisted_7$n, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_a3 = $data.currentTopGroup) == null ? void 0 : _a3.subGroups, (subGroup) => {
var _a4;
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass(((_a4 = $data.currentTopGroup) == null ? void 0 : _a4.subGroups.length) > 1 && subGroup.selected ? "propertyview-subgroup-tabtitle-item--selected" : "propertyview-subgroup-tabtitle-item"),
title: subGroup.name,
onMouseup: ($event) => $options.changeSubGroup(subGroup)
}, vue.toDisplayString($props.editor.i18n(subGroup.name)), 43, _hoisted_8$j)), [
[vue.vShow, !subGroup.empty]
]);
}), 256))
]),
vue.createElementVNode("div", {
class: "propertyview-subgroup-tabpanel",
onMousewheel: _cache[1] || (_cache[1] = ($event) => $options.mouseWheel($event))
}, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_b2 = $data.currentSubGroup) == null ? void 0 : _b2.children, (attrDefine) => {
var _a4;
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "propertyview-subgroup-tabpanel-editors-column": attrDefine.display == "column", "propertyview-subgroup-tabpanel-editors-row": attrDefine.display != "column", "empty-value": attrDefine.value ? false : true }),
title: attrDefine.desc
}, [
!attrDefine.hiddenTitle && (attrDefine == null ? void 0 : attrDefine.visiable) != false ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_10$b, [
vue.createTextVNode(vue.toDisplayString($props.editor.i18n(attrDefine.name)), 1),
attrDefine.notNull ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_11$b, "*")) : vue.createCommentVNode("", true),
_cache[5] || (_cache[5] = vue.createTextVNode(": "))
])) : vue.createCommentVNode("", true),
attrDefine.visiable != false ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_12$8, [
$data.reFresh && (attrDefine == null ? void 0 : attrDefine.visiable) != false ? (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_a4 = $props.editor) == null ? void 0 : _a4.getPropEditor(attrDefine.controlType)), {
key: 0,
editor: $props.editor,
controlDefine: $data.controlDefine,
attrDefine
}, null, 8, ["editor", "controlDefine", "attrDefine"])) : vue.createCommentVNode("", true)
])) : vue.createCommentVNode("", true)
], 10, _hoisted_9$h)), [
[vue.vShow, (attrDefine == null ? void 0 : attrDefine.visiable) && !(attrDefine == null ? void 0 : attrDefine.forceHidden)]
]);
}), 256))
], 32)
], 512), [
[vue.vShow, ((_c2 = $props.editor) == null ? void 0 : _c2.rightWidth) > $data.pvGroupWidth]
]),
vue.createElementVNode("div", _hoisted_13$7, [
vue.createElementVNode("div", _hoisted_14$6, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.topGroups, (topGroup) => {
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass(topGroup.selected ? "propertyview-groupview-items-item--selected" : "propertyview-groupview-items-item"),
onClick: ($event) => $options.changeTopGroup(topGroup),
title: topGroup.name
}, [
(vue.openBlock(), vue.createElementBlock("svg", _hoisted_16$3, [
vue.createElementVNode("use", {
"xlink:href": "#" + topGroup.img
}, null, 8, _hoisted_17$2)
]))
], 10, _hoisted_15$5)), [
[vue.vShow, !(topGroup == null ? void 0 : topGroup.empty)]
]);
}), 256))
])
], 512)
])
], 34)) : vue.createCommentVNode("", true);
}
const PropertyView = /* @__PURE__ */ _export_sfc(_sfc_main$1c, [["render", _sfc_render$1c], ["__scopeId", "data-v-156d5ed6"]]);
const _DDeiCorePropertyViewPanel = class _DDeiCorePropertyViewPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", PropertyView.name);
__publicField3(this, "plugins", [PropertyView]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[PropertyView.name]) {
for (let i2 in options[PropertyView.name]) {
newOptions[i2] = options[PropertyView.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCorePropertyViewPanel(newOptions);
return panels;
}
}
return _DDeiCorePropertyViewPanel;
}
static modify(fn) {
return _DDeiCorePropertyViewPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCorePropertyViewPanel, "defaultIns", new _DDeiCorePropertyViewPanel());
let DDeiCorePropertyViewPanel = _DDeiCorePropertyViewPanel;
const _sfc_main$1b = {
name: "ddei-core-panel-openfilesview",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
//是否允许展开收折
expand: {
type: Boolean,
default: false
},
create: {
type: Boolean,
default: true
},
close: {
type: Boolean,
default: true
},
rename: {
type: Boolean,
default: true
},
drag: {
type: Boolean,
default: true
},
max: {
type: Number,
default: 0
},
beforeCloseFile: {
type: Function,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
//当前打开的页的开始下标
openIndex: 0,
//最大可以打开的数量
maxOpenSize: 1,
// tempFile: null,
unitFileWidth: 160,
// user: null,
forceRefresh: true
};
},
computed: {},
watch: {},
created() {
this.$watch("editor.files.length", function(newVal, oldVal) {
setTimeout(() => {
let activeIndex = -1;
for (let i2 = 0; i2 < this.editor.files.length; i2++) {
if (this.editor.files[i2].active == DDeiActiveType.ACTIVE) {
activeIndex = i2;
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["toolbox", "property"]
});
this.editor.bus.executeAll();
break;
}
}
this.openIndex = activeIndex + 1 - this.maxOpenSize;
if (this.openIndex < 0) {
this.openIndex = 0;
}
}, 10);
});
},
mounted() {
const resizeObserver = new ResizeObserver((entries) => {
for (const entry of entries) {
let { width, height } = entry.contentRect;
if (width == 0 || height == 0) {
width = this.$refs.openFilesView.clientWidth;
height = this.$refs.openFilesView.clientHeight;
}
if (width != 0 && height != 0) {
let fileEles = this.$refs.openFilesView.getElementsByClassName("ddei-core-panel-openfilesview-item");
let fileWidth = 0;
if (fileEles.length > 0) {
fileWidth = fileEles[0].clientWidth;
}
if (!fileWidth) {
fileWidth = 160;
}
this.unitFileWidth = fileWidth;
let size = parseInt((width - 120) / fileWidth);
if (size > this.maxOpenSize && this.openIndex > 0) {
this.openIndex--;
}
this.maxOpenSize = size;
this.width = width;
}
}
});
resizeObserver.observe(this.$refs.openFilesView);
this.refreshData();
},
methods: {
//强制刷新当前以及下层组件
forceRefreshParts(parts) {
if (!parts || parts == "openfiles" || parts.indexOf("openfiles") != -1) {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
}
});
}
},
refreshData() {
this.editor.openFilesViewer = this;
},
/**
* 新建文件
* @param evt
*/
newFile(evt) {
var _a3, _b2;
if ((_a3 = this.editor) == null ? void 0 : _a3.ddInstance) {
let rsState = DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_FILE_BEFORE", "ADD_FILE", null, this.editor.ddInstance, null);
if (rsState != -1) {
let ddInstance = this.editor.ddInstance;
let fileText = this.editor.i18n("ddei.file");
let newText = this.editor.i18n("ddei.new");
let pageText = this.editor.i18n("ddei.page");
let file = DDeiFile.loadFromJSON(
{
name: newText + fileText + "_NEW",
path: "/" + newText + fileText + "_NEW",
sheets: [
new DDeiSheet({
name: pageText + "-1",
desc: pageText + "-1",
stage: DDeiStage.initByJSON({ id: "stage_1" }, { currentDdInstance: ddInstance }),
active: DDeiActiveType.ACTIVE
})
],
currentSheetIndex: 0,
state: DDeiFileState.NEW,
active: DDeiActiveType.ACTIVE
},
{ currentDdInstance: ddInstance }
);
file.local = 1;
if (this.editor.currentFileIndex != -1) {
this.editor.files[this.editor.currentFileIndex].active = DDeiActiveType.NONE;
}
this.editor.addFile(file);
this.editor.currentFileIndex = this.editor.files.length - 1;
let sheets = file == null ? void 0 : file.sheets;
if (file && sheets && ddInstance) {
ddInstance.stage.destroyRender();
let stage2 = sheets[0].stage;
stage2.ddInstance = ddInstance;
ddInstance.stage = stage2;
file.initHistroy();
if (!stage2.wpv) {
stage2.wpv = {
x: -(stage2.width - ddInstance.render.canvas.width / ddInstance.render.ratio) / 2,
y: -(stage2.height - ddInstance.render.canvas.height / ddInstance.render.ratio) / 2,
z: 0
};
}
stage2.initRender();
ddInstance.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["bottommenu", "topmenu"]
});
this.editor.changeState(DDeiEditorState.DESIGNING);
(_b2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _b2.executeAll();
}
DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_FILE_AFTER", "ADD_FILE", null, this.editor.ddInstance, null);
if (this.editor.files.length == 0) {
ddInstance.disabled = true;
} else {
ddInstance.disabled = false;
}
}
}
},
/**
* 修改文件标题
*/
startChangeFileName(file, evt) {
let ele = evt.target;
let domPos = DDeiUtil.getDomAbsPosition(ele);
let editor = DDeiEditor.ACTIVE_INSTANCE;
let editorEle = document.getElementById(editor.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let input = document.getElementById(editor.id + "_change_file_name_input");
if (!input) {
input = document.createElement("input");
input.setAttribute("id", editor.id + "_change_file_name_input");
input.style.position = "absolute";
input.style.fontSize = "16px";
editorEle.appendChild(input);
input.onblur = function() {
var _a3;
if (input.value) {
let editor2 = DDeiEditor.ACTIVE_INSTANCE;
let file2 = editor2 == null ? void 0 : editor2.files[editor2 == null ? void 0 : editor2.currentFileIndex];
if (input.value != file2.name) {
file2.name = input.value;
if (file2.path) {
if (file2.path.indexOf("/") != -1) {
file2.path = file2.path.substring(0, file2.path.lastIndexOf("/")) + "/" + file2.name;
} else {
file2.path = file2.name;
}
}
(_a3 = editor2.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
editor2.bus.push(DDeiEditorEnumBusCommandType.AddFileHistroy);
editor2.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["openfiles"]
});
editor2.bus.executeAll();
editor2.changeState(DDeiEditorState.DESIGNING);
}
input.style.display = "none";
input.style.left = "0px";
input.style.top = "0px";
input.value = "";
}
};
input.onkeydown = function(e) {
var _a3;
if (e.keyCode == 13) {
let editor2 = DDeiEditor.ACTIVE_INSTANCE;
let file2 = editor2 == null ? void 0 : editor2.files[editor2 == null ? void 0 : editor2.currentFileIndex];
if (input.value != file2.name) {
file2.name = input.value;
if (file2.path) {
if (file2.path.indexOf("/") != -1) {
file2.path = file2.path.substring(0, file2.path.lastIndexOf("/")) + "/" + file2.name;
} else {
file2.path = file2.name;
}
}
(_a3 = editor2.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
editor2.bus.push(DDeiEditorEnumBusCommandType.AddFileHistroy);
editor2.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["openfiles"]
});
editor2.bus.executeAll();
editor2.changeState(DDeiEditorState.DESIGNING);
}
input.style.display = "none";
input.style.left = "0px";
input.style.top = "0px";
input.value = "";
} else if (e.keyCode == 27) {
let editor2 = DDeiEditor.ACTIVE_INSTANCE;
input.style.display = "none";
input.style.left = "0px";
input.style.top = "0px";
input.value = "";
editor2.changeState(DDeiEditorState.DESIGNING);
}
};
}
input.style.width = ele.offsetWidth + "px";
input.style.height = ele.offsetHeight - 3 + "px";
input.style.left = domPos.left - editorDomPos.left + "px";
input.style.top = domPos.top + 2 - editorDomPos.top + "px";
input.style.border = "none";
input.style.outline = "none";
input.style.borderBottom = "1px solid #1F72FF";
input.style.borderRadius = "1px";
input.value = file.name;
input.style.display = "block";
input.selectionStart = 0;
input.selectionEnd = input.value.length;
input.style.background = "var(--background)";
input.style.color = "var(--text)";
input.focus();
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.executeAll();
if (this.editor.state != DDeiEditorState.PROPERTY_EDITING && this.editor.state != DDeiEditorState.QUICK_EDITING) {
this.editor.changeState(DDeiEditorState.PROPERTY_EDITING);
}
},
/**
* file开始拖拽移动
*/
fileDragStart(fileEle, evt) {
this.dragFileEle = evt.currentTarget;
},
/**
* 拖拽元素移动
*/
fileDragOver(e) {
if (this.dragFileEle) {
if (e.currentTarget.className.indexOf("ddei-core-panel-openfilesview-item") != -1) {
let parentDiv = this.dragFileEle.parentElement;
let sourceIndex = -1;
let targetIndex = -1;
let children = parentDiv.children;
for (let i2 = 1; i2 < children.length - 4; i2++) {
children[i2].style.borderLeft = "";
children[i2].style.borderRight = "";
if (children[i2] == this.dragFileEle) {
sourceIndex = i2;
} else if (e.currentTarget == children[i2]) {
targetIndex = i2;
}
}
if (sourceIndex != -1 && targetIndex != -1) {
this.sourceFileIndex = sourceIndex - 1;
if (targetIndex == children.length - 5) {
let pos = DDeiUtil.getDomAbsPosition(children[targetIndex]);
let halfPos = pos.left + children[targetIndex].offsetWidth / 2;
if (halfPos <= e.clientX && e.clientX <= pos.left + children[targetIndex].offsetWidth) {
this.changeFileIndex = targetIndex;
children[targetIndex].style.borderRight = "2px solid #1F72FF";
} else {
this.changeFileIndex = targetIndex - 1;
children[targetIndex].style.borderLeft = "2px solid #1F72FF";
}
} else {
this.changeFileIndex = targetIndex - 1;
children[targetIndex].style.borderLeft = "2px solid #1F72FF";
}
}
e.preventDefault();
}
}
},
/**
* 拖拽元素放开
*/
fileDragDrop(e) {
if ((this.sourceFileIndex || this.sourceFileIndex == 0) && (this.changeFileIndex || this.changeFileIndex == 0)) {
let files = this.editor.files;
let sourceFile = this.editor.files[this.sourceFileIndex];
let currentFile = this.editor.files[this.editor.currentFileIndex];
files[this.sourceFileIndex] = null;
files.splice(this.changeFileIndex, 0, sourceFile);
for (let j2 = files.length; j2 >= 0; j2--) {
if (files[j2] == null) {
files.splice(j2, 1);
}
}
for (let j2 = files.length; j2 >= 0; j2--) {
if (currentFile == files[j2]) {
this.editor.currentFileIndex = j2;
}
}
let parentDiv = this.dragFileEle.parentElement;
let children = parentDiv.children;
for (let i2 = 1; i2 < children.length - 4; i2++) {
children[i2].style.borderLeft = "";
children[i2].style.borderRight = "";
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["openfiles"]
});
this.editor.bus.executeAll();
}
this.dragFileEle = null;
this.sourceFileIndex = null;
this.changeFileIndex = null;
},
/**
* 变更实例
* @param instance
*/
changeFile(file) {
var _a3;
let ddInstance = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance;
if (!file) {
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {});
ddInstance.bus.executeAll();
} else {
if (this.editor.files.indexOf(file) != this.editor.currentFileIndex) {
let rsState = DDeiEditorUtil.invokeCallbackFunc("EVENT_CHANGE_FILE_BEFORE", "CHANGE_FILE", null, ddInstance, null);
if (rsState != -1) {
this.editor.changeFile(this.editor.files.indexOf(file));
DDeiEditorUtil.invokeCallbackFunc("EVENT_CHANGE_FILE_AFTER", "CHANGE_FILE", null, ddInstance, null);
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {});
ddInstance.bus.executeAll();
}
}
}
if (this.editor.files.length == 0) {
ddInstance.disabled = true;
} else {
ddInstance.disabled = false;
}
},
// /**
// * 放弃并关闭确认弹框
// */
// abortAndCloseFileConfirmDialog() {
// this.tempFile.state = DDeiFileState.NONE;
// this.closeFile(this.tempFile);
// },
// /**
// * 保存
// * @param evt
// */
// saveAndCloseFileConfirmDialog() {
// if (this.tempFile) {
// //获取json信息
// let file = this.tempFile;
// if (file) {
// let json = file.toJSON();
// if (json) {
// //执行保存
// let storeIns = new DDeiStoreLocal();
// json.state = DDeiFileState.NONE;
// storeIns.save(file.id, json).then((data) => {
// //回写ID
// file.id = data;
// file.state = DDeiFileState.NONE;
// this.closeFile(this.tempFile);
// });
// }
// }
// }
// },
/**
* 关闭文件
* @param instance
*/
closeFile(file, evt) {
var _a3;
let canClose = true;
if (this.beforeCloseFile) {
canClose = this.beforeCloseFile(file);
}
if (canClose) {
let ddInstance = this.editor.ddInstance;
let rsState = DDeiEditorUtil.invokeCallbackFunc("EVENT_CLOSE_FILE_BEFORE", "CLOSE_FILE", null, ddInstance, evt);
if (rsState != -1) {
let index = this.editor.files.indexOf(file);
this.editor.removeFile(file);
if (index < this.editor.currentFileIndex) {
this.editor.currentFileIndex--;
} else if (index == this.editor.currentFileIndex) {
if (index > 0) {
this.changeFile(
this.editor.files[this.editor.currentFileIndex - 1]
);
} else if (this.editor.files.length > 0) {
this.changeFile(this.editor.files[0]);
}
}
if (this.editor.files.length == 0) {
this.changeFile(null);
this.editor.currentFileIndex = -1;
}
if (index > this.openIndex) {
this.openIndex--;
if (this.openIndex < 0) {
this.openIndex = 0;
}
}
DDeiEditorUtil.invokeCallbackFunc("EVENT_CLOSE_FILE_AFTER", "CLOSE_FILE", null, ddInstance, evt);
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["bottommenu", "topmenu"]
});
this.editor.changeState(DDeiEditorState.DESIGNING);
(_a3 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _a3.executeAll();
}
}
},
/**
* 在存在显示隐藏的情况下移动tab
*/
moveItem(index = 0) {
if (index != 0) {
this.openIndex += index;
if (this.openIndex > this.editor.files.length - this.maxOpenSize) {
this.openIndex = this.editor.files.length - this.maxOpenSize;
} else if (this.openIndex < 0) {
this.openIndex = 0;
}
}
},
/**
* 展开工具栏
*/
expandToolBox() {
this.editor.leftWidth = window.leftWidth;
this.editor.middleWidth -= window.leftWidth;
delete window.leftWidth;
this.editor.changeState(DDeiEditorState.DESIGNING);
},
/**
* 焦点进入当前区域
*/
changeEditorFocus() {
this.editor.changeState(DDeiEditorState.DESIGNING);
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.executeAll();
}
}
};
const OpenFilesView_vue_vue_type_style_index_0_scoped_cf0859cc_lang = "";
const _hoisted_1$19 = {
key: 0,
class: "ddei-core-panel-openfilesview-item"
};
const _hoisted_2$R = ["onClick", "title"];
const _hoisted_3$N = { class: "textcontent" };
const _hoisted_4$C = ["onDblclick"];
const _hoisted_5$u = { class: "dirty" };
const _hoisted_6$p = ["onClick"];
function _sfc_render$1b(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i;
return $data.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
onMousedown: _cache[6] || (_cache[6] = ($event) => $options.changeEditorFocus()),
onMouseup: _cache[7] || (_cache[7] = ($event) => $props.drag && $options.fileDragDrop($event)),
ref: "openFilesView",
class: "ddei-core-panel-openfilesview"
}, [
vue.withDirectives(vue.createElementVNode("div", {
class: "ddei-core-panel-openfilesview-expandbox",
onClick: _cache[0] || (_cache[0] = (...args) => $options.expandToolBox && $options.expandToolBox(...args))
}, _cache[8] || (_cache[8] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-expand4" })
], -1)
]), 512), [
[vue.vShow, ((_a3 = this.editor) == null ? void 0 : _a3.leftWidth) == 0]
]),
!((_b2 = $props.editor) == null ? void 0 : _b2.files) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_1$19)) : vue.createCommentVNode("", true),
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_c2 = $props.editor) == null ? void 0 : _c2.files, (item, i2) => {
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass(item.active == 1 ? "ddei-core-panel-openfilesview-item ddei-core-panel-openfilesview-item--selected" : "ddei-core-panel-openfilesview-item"),
onClick: ($event) => $options.changeFile(item),
onMousedown: _cache[1] || (_cache[1] = ($event) => $props.drag && $options.fileDragStart(_ctx.index, $event)),
onMousemove: _cache[2] || (_cache[2] = ($event) => $props.drag && $options.fileDragOver($event)),
title: item.name
}, [
_cache[10] || (_cache[10] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-file" })
], -1)),
vue.createElementVNode("span", _hoisted_3$N, [
vue.createElementVNode("div", {
class: "text",
onDblclick: ($event) => $props.rename && $options.startChangeFileName(item, $event)
}, vue.toDisplayString(item.name), 41, _hoisted_4$C),
vue.withDirectives(vue.createElementVNode("div", _hoisted_5$u, "ꔷ", 512), [
[vue.vShow, item.state != 0]
])
]),
$props.close ? (vue.openBlock(), vue.createElementBlock("svg", {
key: 0,
onClick: vue.withModifiers(($event) => $options.closeFile(item, $event), ["prevent", "stop"]),
class: "icon close",
"aria-hidden": "true"
}, _cache[9] || (_cache[9] = [
vue.createElementVNode("use", { "xlink:href": "#icon-close" }, null, -1)
]), 8, _hoisted_6$p)) : vue.createCommentVNode("", true)
], 42, _hoisted_2$R)), [
[vue.vShow, i2 >= $data.openIndex && (i2 - $data.openIndex + 1) * $data.unitFileWidth + 120 <= _ctx.width]
]);
}), 256)),
$props.create && (!$props.max || ((_e2 = (_d2 = $props.editor) == null ? void 0 : _d2.files) == null ? void 0 : _e2.length) < $props.max) ? (vue.openBlock(), vue.createElementBlock("svg", {
key: 1,
class: "icon addfile",
"aria-hidden": "true",
onClick: _cache[3] || (_cache[3] = (...args) => $options.newFile && $options.newFile(...args))
}, _cache[11] || (_cache[11] = [
vue.createElementVNode("use", { "xlink:href": "#icon-add" }, null, -1)
]))) : vue.createCommentVNode("", true),
_cache[14] || (_cache[14] = vue.createElementVNode("div", { style: { "flex": "1 1 1px" } }, null, -1)),
vue.withDirectives(vue.createElementVNode("div", {
class: "ddei-core-panel-openfilesview-movebox",
onClick: _cache[4] || (_cache[4] = ($event) => $options.moveItem(-1))
}, _cache[12] || (_cache[12] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-left" })
], -1)
]), 512), [
[vue.vShow, ((_g = (_f = $props.editor) == null ? void 0 : _f.files) == null ? void 0 : _g.length) > $data.maxOpenSize]
]),
vue.withDirectives(vue.createElementVNode("div", {
class: "ddei-core-panel-openfilesview-movebox",
onClick: _cache[5] || (_cache[5] = ($event) => $options.moveItem(1))
}, _cache[13] || (_cache[13] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-right" })
], -1)
]), 512), [
[vue.vShow, ((_i = (_h = $props.editor) == null ? void 0 : _h.files) == null ? void 0 : _i.length) > $data.maxOpenSize]
])
], 544)) : vue.createCommentVNode("", true);
}
const OpenFilesView = /* @__PURE__ */ _export_sfc(_sfc_main$1b, [["render", _sfc_render$1b], ["__scopeId", "data-v-cf0859cc"]]);
const _DDeiCoreOpenFilesViewPanel = class _DDeiCoreOpenFilesViewPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", OpenFilesView.name);
__publicField3(this, "plugins", [OpenFilesView]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[OpenFilesView.name]) {
for (let i2 in options[OpenFilesView.name]) {
newOptions[i2] = options[OpenFilesView.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreOpenFilesViewPanel(newOptions);
return panels;
}
}
return _DDeiCoreOpenFilesViewPanel;
}
static modify(fn) {
return _DDeiCoreOpenFilesViewPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreOpenFilesViewPanel, "defaultIns", new _DDeiCoreOpenFilesViewPanel(null));
let DDeiCoreOpenFilesViewPanel = _DDeiCoreOpenFilesViewPanel;
const _sfc_main$1a = {
name: "ddei-core-panel-canvasview",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
computed: {},
watch: {},
created() {
this.mouseWheelThrottle = throttle(this.mouseWheelThrottle, 10);
this.mouseMove = throttle(this.mouseMove, 20);
},
mounted() {
let ddInstance = this.editor.ddInstance;
ddInstance.initRender();
if (!ddInstance.stage.wpv) {
ddInstance.stage.wpv = {
x: -(ddInstance.stage.width - ddInstance.render.container.clientWidth) / 2,
y: -(ddInstance.stage.height - ddInstance.render.container.clientHeight) / 2,
z: 0
};
}
ddInstance.render.drawShape();
ddInstance.bus.push(DDeiEditorEnumBusCommandType.LoadFile);
ddInstance.bus.executeAll();
},
methods: {
/**
* 画布双击
*/
canvasDBClick(evt) {
var _a3, _b2;
let middleCanvas = this.$refs.middleCanvas;
let middleCanvasPos = DDeiUtil.getDomAbsPosition(middleCanvas);
if (middleCanvasPos.left + 5 <= evt.clientX && middleCanvasPos.left + middleCanvas.offsetWidth - 5 >= evt.clientX) {
let ddInstance = this.editor.ddInstance;
let stage2 = ddInstance.stage;
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= stage2.wpv.x;
ey -= stage2.wpv.y;
let stageRatio2 = stage2.getStageRatio();
let ex2 = ex / stageRatio2;
let ey2 = ey / stageRatio2;
let operateControls = DDeiAbstractShape.findBottomModelsByArea(stage2.layers[stage2.layerIndex], ex2, ey2, true, true);
if (operateControls != null && operateControls.length > 0) {
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_DBL_CLICK", "DBL_CLICK", { models: operateControls, ex, ey }, ddInstance, null);
if (rsState == 0 || rsState == 1) {
(_b2 = (_a3 = this.editor) == null ? void 0 : _a3.hotkeys["ddei-core-keyaction-quickedit-start"]) == null ? void 0 : _b2.action(evt, this.editor.ddInstance);
}
}
}
},
/**
* 焦点进入当前区域
*/
changeEditorFocus() {
this.editor.changeState(DDeiEditorState.DESIGNING);
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.executeAll();
return true;
},
/**
* 触控板滑动事件
*/
mouseWheel(evt) {
if (this.editor.state == DDeiEditorState.DESIGNING) {
this.mouseWheelThrottle(evt);
evt.preventDefault();
evt.cancelBubble = true;
return false;
}
},
mouseWheelThrottle(evt) {
this.editor.ddInstance.render.mouseWheel(evt);
},
mouseDown(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j;
let middleCanvas = this.$refs.middleCanvas;
let middleCanvasPos = DDeiUtil.getDomAbsPosition(middleCanvas);
if (middleCanvasPos.left + 5 <= evt.clientX && middleCanvasPos.left + middleCanvas.offsetWidth - 5 >= evt.clientX) {
if (this.editor.state == DDeiEditorState.QUICK_EDITING) {
if ((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.render) == null ? void 0 : _d2.editorShadowControl) {
let stage2 = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage;
let rat1 = stage2.ddInstance.render.ratio;
let stageRatio2 = stage2.getStageRatio();
let scaleSize = DDeiUtil.DRAW_TEMP_CANVAS && rat1 < 2 ? 2 / rat1 : 1;
let ex = evt.offsetX;
let ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= stage2.wpv.x;
ey -= stage2.wpv.y;
let ex2 = ex / stageRatio2;
let ey2 = ey / stageRatio2;
let shadowControl = (_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.render) == null ? void 0 : _j.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.isInTextArea(ex2, ey2)) {
let cx = (ex2 - shadowControl.cpv.x) * rat1 * stageRatio2;
let cy = (ey2 - shadowControl.cpv.y) * rat1 * stageRatio2;
let startIndex = 0;
let sx = 0;
let i2 = 0;
for (; i2 < shadowControl.render.textUsedArea.length; i2++) {
let rowData = shadowControl.render.textUsedArea[i2];
let ry = rowData.y / scaleSize;
let rh = rowData.height / scaleSize;
let rx = rowData.x / scaleSize;
let rw = rowData.width / scaleSize;
if (cy >= ry && cy <= ry + rh) {
if (cx >= rx && cx <= rx + rw) {
let endI = startIndex + rowData.text.length;
for (let x2 = startIndex; x2 < endI; x2++) {
let fx = shadowControl.render.textUsedArea[0].textPosCache[x2].x / scaleSize;
let lx = x2 < endI - 1 ? shadowControl.render.textUsedArea[0].textPosCache[x2 + 1].x / scaleSize : rx + rw;
let halfW = (lx - fx) / 2;
if (cx >= fx && cx < lx) {
if (cx > fx + halfW) {
sx = x2 + 1;
} else {
sx = x2;
}
break;
}
}
}
if (!sx) {
if (ex < shadowControl.cpv.x) {
sx = startIndex;
} else {
sx = startIndex + rowData.text.length;
}
}
break;
}
startIndex += rowData.text.length;
}
if (!sx) {
if (ex < shadowControl.cpv.x) {
sx = 0;
} else {
sx = startIndex + shadowControl.render.textUsedArea[i2 - 1].text.length;
}
}
let editorText = DDeiUtil.getEditorText();
editorText.selectionStart = sx;
editorText.selectionEnd = sx;
setTimeout(() => {
editorText.focus();
}, 10);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
this.editor.ddInstance.stage.render.tempTextStart = editorText.selectionStart;
this.editor.ddInstance.stage.render.operateState = DDeiEnumOperateState.QUICK_EDITING_TEXT_SELECTING;
return;
}
}
}
let isDialogOpen = false;
for (let oid in DDeiEditor.ACTIVE_INSTANCE.tempDialogData) {
if (DDeiEditor.ACTIVE_INSTANCE.tempDialogData[oid]) {
isDialogOpen = true;
break;
}
}
this.changeEditorFocus();
this.editor.ddInstance.state = DDeiEnumState.NONE;
if (!isDialogOpen) {
this.editor.ddInstance.render.mouseDown(evt);
}
}
},
/**
* 拖拽元素移动
*/
mouseMove(e) {
var _a3, _b2, _c2, _d2, _e2;
if (this.editor.state == DDeiEditorState.CONTROL_CREATING) {
DDeiKeyAction.updateKeyState(e);
let ddInstance = this.editor.ddInstance;
let stage2 = ddInstance.stage;
let ex = e.offsetX;
let ey = e.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= stage2.wpv.x;
ey -= stage2.wpv.y;
if (this.editor.creatingControls) {
let layer2 = stage2.layers[stage2.layerIndex];
if (layer2) {
stage2.render.currentOperateContainer = layer2;
stage2.render.operateState = DDeiEnumOperateState.CONTROL_CREATING;
let controls2 = this.editor.creatingControls;
stage2.render.currentOperateShape = controls2[0];
if (!layer2.models.has(controls2[0].id)) {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeContainer,
{ newContainer: layer2, models: controls2 },
e
);
let dragObj = {
x: ex,
y: ey,
model: controls2[0],
num: 0
};
controls2.forEach((c) => {
dragObj[c.id] = {
dx: c.cpv.x - controls2[0].cpv.x,
//鼠标在控件中心坐标的增量位置
dy: c.cpv.y - controls2[0].cpv.y
};
});
this.editor.bus.push(
DDeiEnumBusCommandType.UpdateDragObj,
{ dragObj },
e
);
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangePosition,
{
models: controls2,
x: ex,
y: ey,
sample: 1,
dragObj
},
e
);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
} else {
let ex1 = e.offsetX / window.remRatio;
let ey1 = e.offsetY / window.remRatio;
let rat1 = (_a3 = ddInstance.render) == null ? void 0 : _a3.ratio;
let canvasWidth = ddInstance.render.canvas.width / rat1;
let canvasHeight = ddInstance.render.canvas.height / rat1;
let edgeWeight = 25;
if (ex1 < edgeWeight) {
ddInstance.render.inEdge = 4;
} else if (ex1 > canvasWidth - edgeWeight) {
ddInstance.render.inEdge = 2;
} else if (ey1 < edgeWeight) {
ddInstance.render.inEdge = 1;
} else if (ey1 > canvasHeight - edgeWeight) {
ddInstance.render.inEdge = 3;
} else {
ddInstance.render.inEdge = 0;
}
if (!ddInstance.render.inEdge) {
let selectedModels = /* @__PURE__ */ new Map();
controls2.forEach((control) => {
selectedModels.set(control.id, control);
});
(_c2 = (_b2 = this.editor) == null ? void 0 : _b2.bus) == null ? void 0 : _c2.push(
DDeiEnumBusCommandType.SetHelpLine,
{ models: selectedModels },
e
);
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangePosition,
{
models: controls2,
x: ex,
y: ey,
dx: 0,
dy: 0,
sample: 1,
dragObj: ddInstance.stage.render.dragObj
},
e
);
let isAlt = DDei.KEY_DOWN_STATE.get("alt");
this.editor.bus.push(
DDeiEnumBusCommandType.ChangeSelectorPassIndex,
{ passIndex: 10 },
e
);
let lastOnContainer = layer2;
if (isAlt) {
let stageRatio2 = stage2.getStageRatio();
let ex2 = ex / stageRatio2;
let ey2 = ey / stageRatio2;
let mouseOnContainers = DDeiAbstractShape.findBottomContainersByArea(
layer2,
ex2,
ey2
);
if (mouseOnContainers && mouseOnContainers.length > 0) {
lastOnContainer = mouseOnContainers[mouseOnContainers.length - 1];
}
if (lastOnContainer != layer2) {
this.editor.bus.push(
DDeiEnumBusCommandType.ChangeSelectorPassIndex,
{ passIndex: 11 },
e
);
}
}
(_e2 = (_d2 = this.editor) == null ? void 0 : _d2.bus) == null ? void 0 : _e2.push(DDeiEnumBusCommandType.RefreshShape);
}
}
this.editor.bus.executeAll();
e.preventDefault();
}
}
} else if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.STAGE_SCROLL_WORKING) {
this.editor.ddInstance.render.mouseMove(e);
} else if (this.editor.dragPart) {
this.editor.dragPart.boxDraging(e);
} else {
this.editor.ddInstance.render.mouseMove(e);
}
},
/**
* 拖拽元素放开
*/
mouseUp(e) {
if (this.editor.state == DDeiEditorState.CONTROL_CREATING) {
let ddInstance = this.editor.ddInstance;
let stage2 = ddInstance.stage;
let ex = e.offsetX / window.remRatio;
let ey = e.offsetY / window.remRatio;
ex -= stage2.wpv.x;
ey -= stage2.wpv.y;
let stageRatio2 = stage2.getStageRatio();
ex /= stageRatio2;
ey /= stageRatio2;
if (this.editor.creatingControls) {
let ddInstance2 = this.editor.ddInstance;
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_DRAG_AFTER", DDeiEnumOperateType.CREATE, { models: this.editor.creatingControls, ex, ey }, ddInstance2, null);
if (rsState == 0 || rsState == 1) {
let isAlt = DDei.KEY_DOWN_STATE.get("alt");
ddInstance2.stage.idIdx++;
let layer2 = ddInstance2.stage.layers[ddInstance2.stage.layerIndex];
if (isAlt) {
let mouseOnContainers = DDeiAbstractShape.findBottomContainersByArea(layer2, ex, ey);
let lastOnContainer = layer2;
if (mouseOnContainers && mouseOnContainers.length > 0) {
lastOnContainer = mouseOnContainers[mouseOnContainers.length - 1];
}
if (lastOnContainer != layer2) {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeContainer,
{
newContainer: lastOnContainer,
oldContainer: layer2,
models: this.editor.creatingControls
}
);
}
}
this.editor.creatingControls.forEach((model) => {
var _a3, _b2;
let controlDefine = this.editor.controls.get(model.modelCode);
if ((_b2 = (_a3 = controlDefine == null ? void 0 : controlDefine.define) == null ? void 0 : _a3.sample) == null ? void 0 : _b2.depProps) {
let depProps = controlDefine.define.sample.depProps;
for (let type in depProps) {
let property = depProps[type];
let modelPropValue = model[property];
if (modelPropValue) {
DDeiUtil.createDepLinkModel(model, modelPropValue, type);
}
}
}
model.refreshLinkModels();
});
this.editor.bus.push(
DDeiEnumBusCommandType.CancelCurLevelSelectedModels,
{ container: layer2, curLevel: true }
);
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeSelect,
[{
id: this.editor.creatingControls[0].id,
value: DDeiEnumControlState.SELECTED
}]
);
this.editor.bus.push(DDeiEnumBusCommandType.StageChangeSelectModels);
this.editor.bus.push(DDeiEnumBusCommandType.UpdatePaperArea);
let mds = {
models: this.editor.creatingControls
};
this.editor.bus.push(DDeiEnumBusCommandType.NodifyControlCreated, mds);
this.editor.bus.push(DDeiEnumBusCommandType.ClearTemplateVars);
this.editor.bus.push(DDeiEnumBusCommandType.NodifyChange);
this.editor.bus.push(DDeiEnumBusCommandType.AddHistroy);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.creatingControls = null;
this.editor.state = DDeiEditorState.DESIGNING;
this.editor.bus.executeAll();
}
}
e.preventDefault();
} else if (this.editor.dragPart) {
this.editor.dragPart.boxDragEnd(e);
this.editor.changeState(DDeiEditorState.DESIGNING);
} else if (this.editor.state == DDeiEditorState.DESIGNING || this.editor.state == DDeiEditorState.QUICK_EDITING) {
this.editor.ddInstance.render.mouseUp(e);
}
}
}
};
const CanvasView_vue_vue_type_style_index_0_lang = "";
const _hoisted_1$18 = ["id"];
function _sfc_render$1a(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return vue.openBlock(), vue.createElementBlock("div", {
id: ((_a3 = $props.editor) == null ? void 0 : _a3.id) + "_canvas",
ref: "middleCanvas",
class: "ddei-editor-canvasview",
onMousedown: _cache[0] || (_cache[0] = ($event) => $options.mouseDown($event)),
ondragstart: "return false;",
onWheel: _cache[1] || (_cache[1] = ($event) => $options.mouseWheel($event)),
onMousemove: _cache[2] || (_cache[2] = ($event) => $options.mouseMove($event)),
onMouseup: _cache[3] || (_cache[3] = ($event) => $options.mouseUp($event)),
onDblclick: _cache[4] || (_cache[4] = (...args) => $options.canvasDBClick && $options.canvasDBClick(...args)),
onContextmenu: _cache[5] || (_cache[5] = vue.withModifiers(() => {
}, ["prevent"]))
}, null, 40, _hoisted_1$18);
}
const CanvasView = /* @__PURE__ */ _export_sfc(_sfc_main$1a, [["render", _sfc_render$1a]]);
const _DDeiCoreCanvasViewPanel = class _DDeiCoreCanvasViewPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", CanvasView.name);
__publicField3(this, "plugins", [CanvasView]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[CanvasView.name]) {
for (let i2 in options[CanvasView.name]) {
newOptions[i2] = options[CanvasView.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreCanvasViewPanel(newOptions);
return panels;
}
}
return _DDeiCoreCanvasViewPanel;
}
static modify(fn) {
return _DDeiCoreCanvasViewPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreCanvasViewPanel, "defaultIns", new _DDeiCoreCanvasViewPanel(null));
let DDeiCoreCanvasViewPanel = _DDeiCoreCanvasViewPanel;
const _sfc_main$19 = {
name: "ddei-core-panel-bottommenu",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
forceRefresh: true
};
},
computed: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
//强制刷新当前以及下层组件
forceRefreshParts(parts) {
if (!parts || parts == "bottommenu" || parts.indexOf("bottommenu") != -1) {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
}
});
}
},
refreshData() {
this.editor.bottomMenuViewer = this;
},
/**
* 焦点进入当前区域
*/
changeEditorFocus() {
if (this.editor.state != DDeiEditorState.BOTTOM_MENU_OPERATING && this.editor.state != DDeiEditorState.QUICK_EDITING) {
this.editor.changeState(DDeiEditorState.BOTTOM_MENU_OPERATING);
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.executeAll();
}
}
};
const BottomMenu_vue_vue_type_style_index_0_scoped_5ec138cc_lang = "";
function _sfc_render$19(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return $data.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
class: "ddei-core-panel-bottommenu",
onMousedown: _cache[0] || (_cache[0] = (...args) => $options.changeEditorFocus && $options.changeEditorFocus(...args))
}, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_a3 = $props.editor) == null ? void 0 : _a3.getPartPanels($props.options, "panels"), (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
editor: $props.editor,
options: item.options,
ref_for: true
}, item.options), null, 16, ["editor", "options"]);
}), 256))
], 32)) : vue.createCommentVNode("", true);
}
const BottomMenu = /* @__PURE__ */ _export_sfc(_sfc_main$19, [["render", _sfc_render$19], ["__scopeId", "data-v-5ec138cc"]]);
const _DDeiCoreBottomMenuPanel = class _DDeiCoreBottomMenuPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", BottomMenu.name);
__publicField3(this, "defaultOptions", {
"panels": [
"ddei-core-panel-bottom-sheets",
"ddei-core-panel-bottom-shapecount",
"ddei-core-panel-bottom-managelayers",
"ddei-core-panel-bottom-changeratio",
"ddei-core-panel-bottom-suitratio"
]
});
__publicField3(this, "plugins", [BottomMenu]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[BottomMenu.name]) {
for (let i2 in options[BottomMenu.name]) {
newOptions[i2] = options[BottomMenu.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreBottomMenuPanel(newOptions);
return panels;
}
}
return _DDeiCoreBottomMenuPanel;
}
static modify(fn) {
return _DDeiCoreBottomMenuPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreBottomMenuPanel, "defaultIns", new _DDeiCoreBottomMenuPanel());
let DDeiCoreBottomMenuPanel = _DDeiCoreBottomMenuPanel;
const _sfc_main$18 = {
name: "ddei-core-panel-eimport",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
file: null
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3, _b2;
this.file = (_b2 = this.editor) == null ? void 0 : _b2.files[(_a3 = this.editor) == null ? void 0 : _a3.currentFileIndex];
},
methods: {
// showExportDialog(evt: Event) {
// let srcElement = evt.currentTarget;
// DDeiEditorUtil.showOrCloseDialog("ddei-core-dialog-exportoption", {
// callback: {
// },
// mode: 2,
// group: "top-dialog",
// background: "white",
// opacity: "1%",
// event: -1
// }, {}, srcElement)
// if (this.editor.tempDialogData && this.editor.tempDialogData["ddei-core-dialog-exportoption"]) {
// this.editor.changeState(DDeiEditorState.PROPERTY_EDITING);
// } else {
// this.editor.changeState(DDeiEditorState.DESIGNING);
// }
// },
/**
* 下载文件
*/
download(evt) {
var _a3, _b2, _c2, _d2;
if ((_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) {
let file = (_d2 = this.editor) == null ? void 0 : _d2.files[(_c2 = this.editor) == null ? void 0 : _c2.currentFileIndex];
if (file) {
let json = file.toJSON();
if (json) {
let eleLink = document.createElement("a");
eleLink.download = file.name + ".dei";
eleLink.style.display = "none";
let blob = new Blob([JSON.stringify(json)]);
eleLink.href = URL.createObjectURL(blob);
document.body.appendChild(eleLink);
eleLink.click();
document.body.removeChild(eleLink);
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
}
}
}
};
const ExportAndImport_vue_vue_type_style_index_0_scoped_9c97ea48_lang = "";
const _hoisted_1$17 = { class: "ddei-core-panel-eimport" };
const _hoisted_2$Q = { class: "content" };
const _hoisted_3$M = { class: "part" };
const _hoisted_4$B = { class: "text" };
function _sfc_render$18(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$17, [
_cache[2] || (_cache[2] = vue.createElementVNode("div", { class: "header" }, null, -1)),
vue.createElementVNode("div", _hoisted_2$Q, [
vue.createElementVNode("div", _hoisted_3$M, [
vue.createElementVNode("div", {
class: "button-v",
onClick: _cache[0] || (_cache[0] = (...args) => $options.download && $options.download(...args))
}, [
_cache[1] || (_cache[1] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-download" })
], -1)),
vue.createElementVNode("div", _hoisted_4$B, vue.toDisplayString($props.editor.i18n("ddei.download")), 1)
])
])
]),
_cache[3] || (_cache[3] = vue.createElementVNode("div", { class: "tail" }, null, -1))
]);
}
const ExportAndImport = /* @__PURE__ */ _export_sfc(_sfc_main$18, [["render", _sfc_render$18], ["__scopeId", "data-v-9c97ea48"]]);
const _DDeiCoreExportAndImportPanel = class _DDeiCoreExportAndImportPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", ExportAndImport.name);
__publicField3(this, "plugins", [ExportAndImport]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ExportAndImport.name]) {
for (let i2 in options[ExportAndImport.name]) {
newOptions[i2] = options[ExportAndImport.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreExportAndImportPanel(newOptions);
return panels;
}
}
return _DDeiCoreExportAndImportPanel;
}
static modify(fn) {
return _DDeiCoreExportAndImportPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreExportAndImportPanel, "defaultIns", new _DDeiCoreExportAndImportPanel(null));
let DDeiCoreExportAndImportPanel = _DDeiCoreExportAndImportPanel;
const _sfc_main$17 = {
name: "ddei-core-panel-fileinfo",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
file: {},
fileNameEditing: false,
fileDescEditing: false
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3, _b2;
this.file = (_b2 = this.editor) == null ? void 0 : _b2.files[(_a3 = this.editor) == null ? void 0 : _a3.currentFileIndex];
},
methods: {
/**
* 保存
* @param evt
*/
save(evt) {
this.editor.changeState(DDeiEditorState.DESIGNING);
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.push(DDeiEditorEnumBusCommandType.SaveFile, {}, evt);
this.editor.bus.executeAll();
},
/**
* 下载文件
*/
download(evt) {
var _a3, _b2, _c2, _d2;
if ((_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) {
let file = (_d2 = this.editor) == null ? void 0 : _d2.files[(_c2 = this.editor) == null ? void 0 : _c2.currentFileIndex];
if (file) {
let json = file.toJSON();
if (json) {
let eleLink = document.createElement("a");
eleLink.download = file.name + ".dei";
eleLink.style.display = "none";
let blob = new Blob([JSON.stringify(json)]);
eleLink.href = URL.createObjectURL(blob);
document.body.appendChild(eleLink);
eleLink.click();
document.body.removeChild(eleLink);
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
}
},
/**
* 打开文件
* @param evt
*/
async openFile(evt) {
let rsState = DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_FILE_BEFORE", "LOAD_FILE", null, this.editor.ddInstance, evt);
if (rsState != -1) {
let openFileHandle = await showOpenFilePicker({
description: this.editor.i18n("ddei.fileDescription"),
types: [{
accept: {
"text/plain": [".dei"]
}
}]
});
let openFile = await openFileHandle[0].getFile();
let read = new FileReader();
read.readAsText(openFile);
read.onload = async () => {
var _a3, _b2, _c2, _d2, _e2;
let result = read.result;
let resultJSON = JSON.parse(result);
let ddInstance = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance;
let file = DDeiFile.loadFromJSON(resultJSON, {
currentDdInstance: ddInstance
});
let openedFiles = this.editor.files;
let openedFileIndex = -1;
if (!file.id) {
file.id = DDeiUtil.getUniqueCode();
}
for (let fi = 0; fi < openedFiles.length; fi++) {
if (openedFiles[fi].id && openedFiles[fi].id == file.id) {
openedFileIndex = fi;
break;
}
}
ddInstance.stage.destroyRender();
if (openedFileIndex == -1) {
file.localFileHandler = openFileHandle[0];
file.local = 1;
this.editor.addFile(file);
for (let x2 = 0; x2 < this.editor.files.length; x2++) {
this.editor.files[x2].active = DDeiActiveType.NONE;
}
this.editor.currentFileIndex = this.editor.files.length - 1;
file.state = DDeiFileState.NONE;
file.active = DDeiActiveType.ACTIVE;
let sheets = file == null ? void 0 : file.sheets;
if (file && sheets && ddInstance) {
file.changeSheet(file.currentSheetIndex);
let stage2 = sheets[file.currentSheetIndex].stage;
stage2.ddInstance = ddInstance;
ddInstance.disabled = false;
file.initHistroy();
file.histroy[0].isNew = true;
ddInstance.stage = stage2;
stage2.initRender();
if (!stage2.wpv) {
stage2.wpv = {
x: -(stage2.width - ddInstance.render.container.clientWidth) / 2,
y: -(stage2.height - ddInstance.render.container.clientHeight) / 2,
z: 0
};
}
this.editor.changeState(DDeiEditorState.DESIGNING);
ddInstance.bus.push(
DDeiEditorEnumBusCommandType.ClearTemplateUI
);
ddInstance.bus.push(
DDeiEditorEnumBusCommandType.RefreshEditorParts,
{ parts: ["bottommenu", "topmenu"] }
);
(_b2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _b2.push(DDeiEnumBusCommandType.RefreshShape);
(_c2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _c2.executeAll();
}
} else {
file = this.editor.files[openedFileIndex];
if (file && ddInstance) {
for (let x2 = 0; x2 < this.editor.files.length; x2++) {
this.editor.files[x2].active = DDeiActiveType.NONE;
}
file.active = DDeiActiveType.ACTIVE;
this.editor.currentFileIndex = openedFileIndex;
let stage2 = file.sheets[file.currentSheetIndex].stage;
stage2.ddInstance = ddInstance;
ddInstance.stage = stage2;
ddInstance.disabled = false;
stage2.initRender();
this.editor.changeState(DDeiEditorState.DESIGNING);
ddInstance.bus.push(
DDeiEditorEnumBusCommandType.ClearTemplateUI
);
ddInstance.bus.push(
DDeiEditorEnumBusCommandType.RefreshEditorParts,
{ parts: ["bottommenu", "topmenu"] }
);
(_d2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _d2.push(DDeiEnumBusCommandType.RefreshShape);
(_e2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _e2.executeAll();
}
}
DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_FILE_AFTER", "LOAD_FILE", { file }, this.editor.ddInstance, evt);
};
}
},
/**
* 新建文件
* @param evt
*/
newFile(evt) {
var _a3, _b2;
if ((_a3 = this.editor) == null ? void 0 : _a3.ddInstance) {
let ddInstance = this.editor.ddInstance;
let fileText = this.editor.i18n("ddei.file");
let newText = this.editor.i18n("ddei.new");
let pageText = this.editor.i18n("ddei.page");
let file = DDeiFile.loadFromJSON(
{
name: newText + fileText + "_NEW",
path: "/" + newText + fileText + "_NEW",
sheets: [
new DDeiSheet({
name: pageText + "-1",
desc: pageText + "-1",
stage: DDeiStage.initByJSON({ id: "stage_1" }, { currentDdInstance: ddInstance }),
active: DDeiActiveType.ACTIVE
})
],
currentSheetIndex: 0,
state: DDeiFileState.NEW,
active: DDeiActiveType.ACTIVE
},
{ currentDdInstance: ddInstance }
);
if (this.editor.currentFileIndex != -1) {
this.editor.files[this.editor.currentFileIndex].active = DDeiActiveType.NONE;
}
this.editor.addFile(file);
this.editor.currentFileIndex = this.editor.files.length - 1;
let sheets = file == null ? void 0 : file.sheets;
if (file && sheets && ddInstance) {
ddInstance.stage.destroyRender();
let stage2 = sheets[0].stage;
stage2.ddInstance = ddInstance;
ddInstance.stage = stage2;
file.initHistroy();
if (!stage2.wpv) {
stage2.wpv = {
x: -(stage2.width - ddInstance.render.container.clientWidth) / 2,
y: -(stage2.height - ddInstance.render.container.clientHeight) / 2,
z: 0
};
}
stage2.initRender();
ddInstance.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["bottommenu", "topmenu"]
});
this.editor.changeState(DDeiEditorState.DESIGNING);
(_b2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _b2.executeAll();
}
}
}
}
};
const FileInfo_vue_vue_type_style_index_0_scoped_b1753b91_lang = "";
const _hoisted_1$16 = { class: "ddei-core-panel-fileinfo" };
const _hoisted_2$P = { class: "content" };
const _hoisted_3$L = { class: "part" };
const _hoisted_4$A = ["title"];
const _hoisted_5$t = { class: "text" };
const _hoisted_6$o = { class: "part" };
const _hoisted_7$m = ["title"];
const _hoisted_8$i = { class: "text" };
const _hoisted_9$g = { class: "part" };
const _hoisted_10$a = ["title"];
const _hoisted_11$a = { class: "text" };
const _hoisted_12$7 = { class: "part" };
const _hoisted_13$6 = ["title"];
const _hoisted_14$5 = { class: "text" };
const _hoisted_15$4 = { class: "tail" };
function _sfc_render$17(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$16, [
_cache[8] || (_cache[8] = vue.createElementVNode("div", { class: "header" }, null, -1)),
vue.createElementVNode("div", _hoisted_2$P, [
vue.createElementVNode("div", _hoisted_3$L, [
vue.createElementVNode("div", {
class: "button-v",
onClick: _cache[0] || (_cache[0] = (...args) => $options.newFile && $options.newFile(...args)),
title: $props.editor.i18n("ddei.new")
}, [
_cache[4] || (_cache[4] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-new-file" })
], -1)),
vue.createElementVNode("div", _hoisted_5$t, vue.toDisplayString($props.editor.i18n("ddei.new")), 1)
], 8, _hoisted_4$A)
]),
vue.createElementVNode("div", _hoisted_6$o, [
vue.createElementVNode("div", {
class: "button-v",
onClick: _cache[1] || (_cache[1] = (...args) => $options.openFile && $options.openFile(...args)),
title: $props.editor.i18n("ddei.open")
}, [
_cache[5] || (_cache[5] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-folder" })
], -1)),
vue.createElementVNode("div", _hoisted_8$i, vue.toDisplayString($props.editor.i18n("ddei.open")), 1)
], 8, _hoisted_7$m)
]),
vue.createElementVNode("div", _hoisted_9$g, [
vue.createElementVNode("div", {
class: "button-v",
onClick: _cache[2] || (_cache[2] = (...args) => $options.save && $options.save(...args)),
title: $props.editor.i18n("ddei.save")
}, [
_cache[6] || (_cache[6] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-save" })
], -1)),
vue.createElementVNode("div", _hoisted_11$a, vue.toDisplayString($props.editor.i18n("ddei.save")), 1)
], 8, _hoisted_10$a)
]),
vue.createElementVNode("div", _hoisted_12$7, [
vue.createElementVNode("div", {
class: "button-v",
onClick: _cache[3] || (_cache[3] = (...args) => $options.download && $options.download(...args)),
title: $props.editor.i18n("ddei.download")
}, [
_cache[7] || (_cache[7] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-download" })
], -1)),
vue.createElementVNode("div", _hoisted_14$5, vue.toDisplayString($props.editor.i18n("ddei.download")), 1)
], 8, _hoisted_13$6)
])
]),
vue.createElementVNode("div", _hoisted_15$4, vue.toDisplayString($props.editor.i18n("ddei.file")), 1)
]);
}
const FileInfo = /* @__PURE__ */ _export_sfc(_sfc_main$17, [["render", _sfc_render$17], ["__scopeId", "data-v-b1753b91"]]);
const _DDeiCoreFileInfoPanel = class _DDeiCoreFileInfoPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", FileInfo.name);
__publicField3(this, "plugins", [FileInfo]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[FileInfo.name]) {
for (let i2 in options[FileInfo.name]) {
newOptions[i2] = options[FileInfo.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreFileInfoPanel(newOptions);
return panels;
}
}
return _DDeiCoreFileInfoPanel;
}
static modify(fn) {
return _DDeiCoreFileInfoPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreFileInfoPanel, "defaultIns", new _DDeiCoreFileInfoPanel(null));
let DDeiCoreFileInfoPanel = _DDeiCoreFileInfoPanel;
const _sfc_main$16 = {
name: "ddei-core-panel-fileoperate",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
icons: null
};
},
computed: {},
watch: {},
created() {
},
mounted() {
},
methods: {
/**
* 新建文件
* @param evt
*/
newFile(evt) {
var _a3;
if ((_a3 = this.editor) == null ? void 0 : _a3.ddInstance) {
let ddInstance = this.editor.ddInstance;
let file = DDeiFile.loadFromJSON(
{
name: "新建文件_NEW",
path: "/新建文件_NEW",
sheets: [
new DDeiSheet({
name: "页面-1",
desc: "页面-1",
stage: DDeiStage.initByJSON({ id: "stage_1" }),
active: DDeiActiveType.ACTIVE
})
],
currentSheetIndex: 0,
state: DDeiFileState.NEW,
active: DDeiActiveType.ACTIVE
},
{ currentDdInstance: ddInstance }
);
if (this.editor.currentFileIndex != -1) {
this.editor.files[this.editor.currentFileIndex].active = DDeiActiveType.NONE;
}
this.editor.addFile(file);
this.editor.currentFileIndex = this.editor.files.length - 1;
let sheets = file == null ? void 0 : file.sheets;
if (file && sheets && ddInstance) {
let stage2 = sheets[0].stage;
stage2.ddInstance = ddInstance;
ddInstance.stage = stage2;
file.initHistroy();
if (!stage2.wpv) {
stage2.wpv = {
x: -(stage2.width - ddInstance.render.container.clientWidth) / 2,
y: -(stage2.height - ddInstance.render.container.clientHeight) / 2,
z: 0
};
}
stage2.initRender();
ddInstance.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["bottommenu"]
});
this.editor.changeState(DDeiEditorState.DESIGNING);
ddInstance.bus.executeAll();
}
}
},
/**
* 保存
* @param evt
*/
save(evt) {
this.editor.changeState(DDeiEditorState.DESIGNING);
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.push(DDeiEditorEnumBusCommandType.SaveFile, {}, evt);
this.editor.bus.executeAll();
},
/**
* 下载文件
*/
download(evt) {
var _a3, _b2, _c2, _d2;
if ((_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) {
let file = (_d2 = this.editor) == null ? void 0 : _d2.files[(_c2 = this.editor) == null ? void 0 : _c2.currentFileIndex];
if (file) {
let json = file.toJSON();
if (json) {
let eleLink = document.createElement("a");
eleLink.download = file.name + ".dei";
eleLink.style.display = "none";
let blob = new Blob([JSON.stringify(json)]);
eleLink.href = URL.createObjectURL(blob);
document.body.appendChild(eleLink);
eleLink.click();
document.body.removeChild(eleLink);
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
}
},
/**
* 打开文件
* @param evt
*/
openFile(evt) {
}
}
};
const FileOperate_vue_vue_type_style_index_0_scoped_891d9231_lang = "";
const _hoisted_1$15 = { class: "ddei-core-panel-fileoperate" };
const _hoisted_2$O = {
class: "ddei-core-panel-fileoperate-item",
style: { "grid-row": "1/3" }
};
const _hoisted_3$K = ["src"];
const _hoisted_4$z = ["src"];
const _hoisted_5$s = ["src"];
const _hoisted_6$n = ["src"];
const _hoisted_7$l = { class: "ddei-core-panel-fileoperate-item" };
const _hoisted_8$h = { class: "ddei-core-panel-fileoperate-item-text" };
function _sfc_render$16(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$15, [
vue.createElementVNode("div", _hoisted_2$O, [
vue.createElementVNode("div", {
class: "ddei-core-panel-fileoperate-item-box",
onClick: _cache[0] || (_cache[0] = (...args) => $options.newFile && $options.newFile(...args))
}, [
vue.createElementVNode("img", {
width: "16px",
height: "16px",
src: $data.icons["icon-file"]
}, null, 8, _hoisted_3$K),
vue.createElementVNode("div", null, vue.toDisplayString($props.editor.i18n("ddei.new")), 1)
]),
vue.createElementVNode("div", {
class: "ddei-core-panel-fileoperate-item-box",
onClick: _cache[1] || (_cache[1] = (...args) => $options.save && $options.save(...args))
}, [
vue.createElementVNode("img", {
width: "16px",
height: "16px",
src: $data.icons["icon-save"]
}, null, 8, _hoisted_4$z),
vue.createElementVNode("div", null, vue.toDisplayString($props.editor.i18n("ddei.save")), 1)
]),
vue.createElementVNode("div", {
class: "ddei-core-panel-fileoperate-item-box",
onClick: _cache[2] || (_cache[2] = (...args) => $options.openFile && $options.openFile(...args))
}, [
vue.createElementVNode("img", {
width: "16px",
height: "16px",
src: $data.icons["icon-open"]
}, null, 8, _hoisted_5$s),
vue.createElementVNode("div", null, vue.toDisplayString($props.editor.i18n("ddei.open")), 1)
]),
vue.createElementVNode("div", {
class: "ddei-core-panel-fileoperate-item-box",
onClick: _cache[3] || (_cache[3] = (...args) => $options.download && $options.download(...args))
}, [
vue.createElementVNode("img", {
width: "16px",
height: "16px",
src: $data.icons["icon-download"]
}, null, 8, _hoisted_6$n),
vue.createElementVNode("div", null, vue.toDisplayString($props.editor.i18n("ddei.download")), 1)
])
]),
vue.createElementVNode("div", _hoisted_7$l, [
vue.createElementVNode("div", _hoisted_8$h, vue.toDisplayString($props.editor.i18n("ddei.save")), 1)
])
]);
}
const FileOperate = /* @__PURE__ */ _export_sfc(_sfc_main$16, [["render", _sfc_render$16], ["__scopeId", "data-v-891d9231"]]);
const _DDeiCoreFileOperatePanel = class _DDeiCoreFileOperatePanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", FileOperate.name);
__publicField3(this, "plugins", [FileOperate]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[FileOperate.name]) {
for (let i2 in options[FileOperate.name]) {
newOptions[i2] = options[FileOperate.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreFileOperatePanel(newOptions);
return panels;
}
}
return _DDeiCoreFileOperatePanel;
}
static modify(fn) {
return _DDeiCoreFileOperatePanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreFileOperatePanel, "defaultIns", new _DDeiCoreFileOperatePanel(null));
let DDeiCoreFileOperatePanel = _DDeiCoreFileOperatePanel;
const _sfc_main$15 = {
name: "ddei-core-panel-fontandtext",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
}
};
const FontAndText_vue_vue_type_style_index_0_scoped_84f4d012_lang = "";
const _hoisted_1$14 = { class: "ddei-core-panel-fontandtext" };
const _hoisted_2$N = { class: "content" };
const _hoisted_3$J = { class: "buttons" };
const _hoisted_4$y = { class: "b1" };
const _hoisted_5$r = { class: "b2" };
const _hoisted_6$m = { class: "buttons" };
const _hoisted_7$k = { class: "mg14" };
const _hoisted_8$g = { class: "mg16" };
const _hoisted_9$f = { class: "mg16" };
const _hoisted_10$9 = { class: "mg165" };
const _hoisted_11$9 = { class: "mg17" };
const _hoisted_12$6 = { class: "mg17" };
const _hoisted_13$5 = { class: "b4" };
const _hoisted_14$4 = { class: "b5" };
const _hoisted_15$3 = { class: "b6" };
const _hoisted_16$2 = { class: "tail" };
function _sfc_render$15(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s;
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$14, [
_cache[0] || (_cache[0] = vue.createElementVNode("div", { class: "header" }, null, -1)),
vue.createElementVNode("div", _hoisted_2$N, [
vue.createElementVNode("div", _hoisted_3$J, [
vue.createElementVNode("div", _hoisted_4$y, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_a3 = $props.editor) == null ? void 0 : _a3.panels["ddei-core-btn-fontfamily"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_5$r, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_b2 = $props.editor) == null ? void 0 : _b2.panels["ddei-core-btn-fontsize"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", null, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_c2 = $props.editor) == null ? void 0 : _c2.panels["ddei-core-btn-addfontsize"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
addValue: 1,
attrCode: "font.size",
img: "icon-add-fontsize",
extcls: "magtop-2"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", null, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_d2 = $props.editor) == null ? void 0 : _d2.panels["ddei-core-btn-addfontsize"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
addValue: -1,
attrCode: "font.size",
img: "icon-reduce-fontsize",
extcls: "magtop-1"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", null, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_e2 = $props.editor) == null ? void 0 : _e2.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
supportQuickEdit: false,
attrCode: "textStyle.align",
img: "icon-text-align-left",
extcls: "magtop-1",
unSelectValue: 2
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", null, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_f = $props.editor) == null ? void 0 : _f.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "2",
supportQuickEdit: false,
attrCode: "textStyle.align",
img: "icon-font-align",
extcls: "magtop-1",
unSelectValue: 2
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", null, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_g = $props.editor) == null ? void 0 : _g.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "3",
supportQuickEdit: false,
attrCode: "textStyle.align",
img: "icon-text-align-right",
extcls: "magtop-1",
unSelectValue: 2
}, null, 8, ["editor", "controlDefine"]))
])
]),
vue.createElementVNode("div", _hoisted_6$m, [
vue.createElementVNode("div", _hoisted_7$k, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_h = $props.editor) == null ? void 0 : _h.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
attrCode: "textStyle.bold",
img: "icon-bold"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_8$g, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_i = $props.editor) == null ? void 0 : _i.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
attrCode: "textStyle.italic",
img: "icon-font-italic"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_9$f, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_j = $props.editor) == null ? void 0 : _j.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
attrCode: "textStyle.underline",
img: "icon-text-underline",
extcls: "ext-underline"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_10$9, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_k = $props.editor) == null ? void 0 : _k.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
electedValue: "1",
attrCode: "textStyle.deleteline",
img: "icon-font-deleteline"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_11$9, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_l = $props.editor) == null ? void 0 : _l.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
onlyQuickEdit: true,
attrCode: "textStyle.subtype",
img: "icon-text-subtype-1",
extcls: "magtop-1"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_12$6, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_m = $props.editor) == null ? void 0 : _m.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "2",
onlyQuickEdit: true,
attrCode: "textStyle.subtype",
img: "icon-text-subtype-2",
extcls: "magtop-1"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_13$5, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_n = $props.editor) == null ? void 0 : _n.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "3",
onlyQuickEdit: true,
attrCode: "textStyle.subtype",
img: "icon-text-subtype-3",
extcls: "magtop-1"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_14$4, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_o = $props.editor) == null ? void 0 : _o.panels["ddei-core-btn-color"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "textStyle.bgcolor",
img: "icon-fill"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_15$3, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_p = $props.editor) == null ? void 0 : _p.panels["ddei-core-btn-color"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "font.color",
img: "icon-font"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", null, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_q = $props.editor) == null ? void 0 : _q.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
supportQuickEdit: false,
attrCode: "textStyle.valign",
img: "icon-text-align-left",
extcls: "rotate-90",
unSelectValue: 2
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", null, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_r = $props.editor) == null ? void 0 : _r.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "2",
supportQuickEdit: false,
attrCode: "textStyle.valign",
img: "icon-font-align",
extcls: "rotate-90",
unSelectValue: 2
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", null, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_s = $props.editor) == null ? void 0 : _s.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "3",
supportQuickEdit: false,
attrCode: "textStyle.valign",
img: "icon-text-align-right",
extcls: "rotate-90",
unSelectValue: 2
}, null, 8, ["editor", "controlDefine"]))
])
])
]),
vue.createElementVNode("div", _hoisted_16$2, vue.toDisplayString($props.editor.i18n("ddei.textEdit")), 1)
]);
}
const FontAndText = /* @__PURE__ */ _export_sfc(_sfc_main$15, [["render", _sfc_render$15], ["__scopeId", "data-v-84f4d012"]]);
const _DDeiCoreFontAndTextPanel = class _DDeiCoreFontAndTextPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", FontAndText.name);
__publicField3(this, "plugins", [FontAndText]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[FontAndText.name]) {
for (let i2 in options[FontAndText.name]) {
newOptions[i2] = options[FontAndText.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreFontAndTextPanel(newOptions);
return panels;
}
}
return _DDeiCoreFontAndTextPanel;
}
static modify(fn) {
return _DDeiCoreFontAndTextPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreFontAndTextPanel, "defaultIns", new _DDeiCoreFontAndTextPanel(null));
let DDeiCoreFontAndTextPanel = _DDeiCoreFontAndTextPanel;
const _sfc_main$14 = {
name: "ddei-core-panel-operate",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
hasClipData: false,
displayBrush: false,
canEdit: true
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3;
let mds = [];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds }, this.editor.ddInstance);
if (rsState == -1) {
this.canEdit = false;
}
this.hasClipboard();
this.isDisplayBrush();
},
methods: {
/**
* 执行剪切
*/
execShearAction(evt) {
var _a3, _b2;
(_b2 = (_a3 = this.editor) == null ? void 0 : _a3.hotkeys["ddei-core-keyaction-cut"]) == null ? void 0 : _b2.action(evt, this.editor.ddInstance, this.editor);
},
/**
* 执行复制
*/
execCopyAction(evt) {
var _a3, _b2;
(_b2 = (_a3 = this.editor) == null ? void 0 : _a3.hotkeys["ddei-core-keyaction-copy"]) == null ? void 0 : _b2.action(evt, this.editor.ddInstance, this.editor);
},
/**
* 执行格式刷
*/
execBrushAction(evt) {
var _a3, _b2;
(_b2 = (_a3 = this.editor) == null ? void 0 : _a3.hotkeys["ddei-core-keyaction-brush-data"]) == null ? void 0 : _b2.action(evt, this.editor.ddInstance, this.editor);
},
/**
* 判定是否显示格式刷
*/
isDisplayBrush() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
this.displayBrush = false;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) == 1) {
let model = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
)[0];
if (model.baseModelType == "DDeiTable") {
let selectedCells = model.getSelectedCells();
if ((selectedCells == null ? void 0 : selectedCells.length) > 0) {
this.displayBrush = true;
}
} else {
this.displayBrush = true;
}
}
},
/**
* 检查剪切板中是否有内容
*/
async hasClipboard() {
var _a3, _b2, _c2;
this.hasClipData = false;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.copyMode) {
this.hasClipData = true;
} else {
let hasFocus = document.hasFocus();
if (hasFocus) {
try {
if (!DDeiUtil.isSafari()) {
if (DDeiConfig.ALLOW_CLIPBOARD) {
let items = await navigator.clipboard.read();
if ((items == null ? void 0 : items.length) > 0) {
this.hasClipData = true;
}
}
}
} catch (e) {
}
}
}
}
}
};
const Operate_vue_vue_type_style_index_0_scoped_fc2f1000_lang = "";
const _hoisted_1$13 = { class: "ddei-core-panel-operate" };
const _hoisted_2$M = { class: "content" };
const _hoisted_3$I = { class: "part" };
const _hoisted_4$x = ["title"];
const _hoisted_5$q = { class: "text" };
const _hoisted_6$l = { class: "part" };
const _hoisted_7$j = ["title"];
const _hoisted_8$f = { class: "text" };
const _hoisted_9$e = { class: "part" };
const _hoisted_10$8 = ["title"];
const _hoisted_11$8 = { class: "text" };
const _hoisted_12$5 = { class: "part" };
const _hoisted_13$4 = ["title"];
const _hoisted_14$3 = { class: "text" };
const _hoisted_15$2 = { class: "tail" };
function _sfc_render$14(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E;
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$13, [
_cache[7] || (_cache[7] = vue.createElementVNode("div", { class: "header" }, null, -1)),
vue.createElementVNode("div", _hoisted_2$M, [
vue.createElementVNode("div", _hoisted_3$I, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v--selected": ((_c2 = (_b2 = (_a3 = $props.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.copyMode) == "cut", "button-v": ((_g = (_f = (_e2 = (_d2 = $props.editor) == null ? void 0 : _d2.ddInstance) == null ? void 0 : _e2.stage) == null ? void 0 : _f.selectedModels) == null ? void 0 : _g.size) > 0, "button-v--disabled": !$data.canEdit || ((_k = (_j = (_i = (_h = $props.editor) == null ? void 0 : _h.ddInstance) == null ? void 0 : _i.stage) == null ? void 0 : _j.selectedModels) == null ? void 0 : _k.size) == 0 || !((_n = (_m = (_l = $props.editor) == null ? void 0 : _l.ddInstance) == null ? void 0 : _m.stage) == null ? void 0 : _n.selectedModels) }),
title: $props.editor.i18n("ddei.cut"),
onClick: _cache[0] || (_cache[0] = ($event) => {
var _a4, _b3, _c3, _d3;
return $data.canEdit && ((_d3 = (_c3 = (_b3 = (_a4 = $props.editor) == null ? void 0 : _a4.ddInstance) == null ? void 0 : _b3.stage) == null ? void 0 : _c3.selectedModels) == null ? void 0 : _d3.size) > 0 && $options.execShearAction($event);
})
}, [
_cache[3] || (_cache[3] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-cut" })
], -1)),
vue.createElementVNode("div", _hoisted_5$q, vue.toDisplayString($props.editor.i18n("ddei.cut")), 1)
], 10, _hoisted_4$x)
]),
vue.createElementVNode("div", _hoisted_6$l, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v--selected": ((_q = (_p = (_o = $props.editor) == null ? void 0 : _o.ddInstance) == null ? void 0 : _p.stage) == null ? void 0 : _q.copyMode) == "copy", "button-v": ((_u = (_t = (_s = (_r = $props.editor) == null ? void 0 : _r.ddInstance) == null ? void 0 : _s.stage) == null ? void 0 : _t.selectedModels) == null ? void 0 : _u.size) > 0, "button-v--disabled": ((_y = (_x = (_w = (_v = $props.editor) == null ? void 0 : _v.ddInstance) == null ? void 0 : _w.stage) == null ? void 0 : _x.selectedModels) == null ? void 0 : _y.size) == 0 || !((_B = (_A = (_z = $props.editor) == null ? void 0 : _z.ddInstance) == null ? void 0 : _A.stage) == null ? void 0 : _B.selectedModels) }),
title: $props.editor.i18n("ddei.new"),
onClick: _cache[1] || (_cache[1] = ($event) => {
var _a4, _b3, _c3, _d3;
return ((_d3 = (_c3 = (_b3 = (_a4 = $props.editor) == null ? void 0 : _a4.ddInstance) == null ? void 0 : _b3.stage) == null ? void 0 : _c3.selectedModels) == null ? void 0 : _d3.size) > 0 && $options.execCopyAction($event);
})
}, [
_cache[4] || (_cache[4] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-copy-file" })
], -1)),
vue.createElementVNode("div", _hoisted_8$f, vue.toDisplayString($props.editor.i18n("ddei.copy")), 1)
], 10, _hoisted_7$j)
]),
vue.createElementVNode("div", _hoisted_9$e, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v": $data.hasClipData, "button-v--disabled": !$data.canEdit || !$data.hasClipData }),
title: $props.editor.i18n("ddei.paste")
}, [
_cache[5] || (_cache[5] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-paste" })
], -1)),
vue.createElementVNode("div", _hoisted_11$8, vue.toDisplayString($props.editor.i18n("ddei.paste")), 1)
], 10, _hoisted_10$8)
]),
vue.createElementVNode("div", _hoisted_12$5, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v--selected": $data.canEdit && ((_E = (_D = (_C = $props.editor) == null ? void 0 : _C.ddInstance) == null ? void 0 : _D.stage) == null ? void 0 : _E.brushData), "button-v": $data.canEdit && $data.displayBrush, "button-v--disabled": !$data.canEdit || !$data.displayBrush }),
title: $props.editor.i18n("ddei.brush"),
onClick: _cache[2] || (_cache[2] = ($event) => {
var _a4, _b3, _c3, _d3;
return $data.canEdit && ((_d3 = (_c3 = (_b3 = (_a4 = $props.editor) == null ? void 0 : _a4.ddInstance) == null ? void 0 : _b3.stage) == null ? void 0 : _c3.selectedModels) == null ? void 0 : _d3.size) == 1 && $options.execBrushAction($event);
})
}, [
_cache[6] || (_cache[6] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-brush" })
], -1)),
vue.createElementVNode("div", _hoisted_14$3, vue.toDisplayString($props.editor.i18n("ddei.brush")), 1)
], 10, _hoisted_13$4)
])
]),
vue.createElementVNode("div", _hoisted_15$2, vue.toDisplayString($props.editor.i18n("ddei.cutBoard")), 1)
]);
}
const Operate = /* @__PURE__ */ _export_sfc(_sfc_main$14, [["render", _sfc_render$14], ["__scopeId", "data-v-fc2f1000"]]);
const _DDeiCoreOperatePanel = class _DDeiCoreOperatePanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", Operate.name);
__publicField3(this, "plugins", [Operate]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[Operate.name]) {
for (let i2 in options[Operate.name]) {
newOptions[i2] = options[Operate.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreOperatePanel(newOptions);
return panels;
}
}
return _DDeiCoreOperatePanel;
}
static modify(fn) {
return _DDeiCoreOperatePanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreOperatePanel, "defaultIns", new _DDeiCoreOperatePanel(null));
let DDeiCoreOperatePanel = _DDeiCoreOperatePanel;
const _sfc_main$13 = {
name: "ddei-core-panel-sort",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
dialogShow: "",
canEdit: true
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3;
let mds = [this.editor.currentStage];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds }, this.editor.ddInstance);
if (rsState == -1) {
this.canEdit = false;
}
},
methods: {
/**
* 显示弹出框
*/
showPositionDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-changeposition", {
group: "top-dialog"
}, { type: 5 }, srcElement);
},
showAlignDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-align", {
group: "top-dialog"
}, { type: 5 }, srcElement);
},
showMergeDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-mergecompose", {
group: "top-dialog"
}, { type: 5 }, srcElement);
},
showRotateDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-changerotate", {
group: "top-dialog"
}, { type: 5 }, srcElement);
},
/**
* 对齐按钮是否显示
*/
isButtonEnable(num = 1) {
var _a3, _b2;
let file = (_a3 = this.editor) == null ? void 0 : _a3.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_b2 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _b2.size) >= num) {
return true;
}
return false;
}
}
};
const Sort_vue_vue_type_style_index_0_scoped_9f739241_lang = "";
const _hoisted_1$12 = { class: "ddei-core-panel-sort" };
const _hoisted_2$L = { class: "content" };
const _hoisted_3$H = { class: "part" };
const _hoisted_4$w = { class: "text" };
const _hoisted_5$p = { class: "part" };
const _hoisted_6$k = { class: "text" };
const _hoisted_7$i = { class: "part" };
const _hoisted_8$e = { class: "text" };
const _hoisted_9$d = { class: "part" };
const _hoisted_10$7 = { class: "text" };
const _hoisted_11$7 = { class: "tail" };
function _sfc_render$13(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$12, [
_cache[12] || (_cache[12] = vue.createElementVNode("div", { class: "header" }, null, -1)),
vue.createElementVNode("div", _hoisted_2$L, [
vue.createElementVNode("div", _hoisted_3$H, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v--disabled": !$data.canEdit || !$options.isButtonEnable(), "button-v--selected": $data.canEdit && $options.isButtonEnable() && $data.dialogShow == "ddei-core-panel-sort-ddei-core-dialog-changeposition", "button-v": $data.canEdit && $options.isButtonEnable() }),
onClick: _cache[0] || (_cache[0] = ($event) => $data.canEdit && $options.isButtonEnable() && $options.showPositionDialog($event))
}, [
_cache[4] || (_cache[4] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-position" })
], -1)),
vue.createElementVNode("div", _hoisted_4$w, vue.toDisplayString($props.editor.i18n("ddei.position")), 1),
_cache[5] || (_cache[5] = vue.createElementVNode("svg", {
class: "icon extbtn",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
], -1))
], 2)
]),
vue.createElementVNode("div", _hoisted_5$p, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v--disabled": !$data.canEdit || !$options.isButtonEnable(2), "button-v--selected": $data.canEdit && $options.isButtonEnable(2) && $data.dialogShow == "ddei-core-panel-sort-align-dialog", "button-v": $data.canEdit && $options.isButtonEnable(2) }),
onClick: _cache[1] || (_cache[1] = ($event) => $data.canEdit && $options.isButtonEnable(2) && $options.showAlignDialog($event))
}, [
_cache[6] || (_cache[6] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-align" })
], -1)),
vue.createElementVNode("div", _hoisted_6$k, vue.toDisplayString($props.editor.i18n("ddei.align")), 1),
_cache[7] || (_cache[7] = vue.createElementVNode("svg", {
class: "icon extbtn",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
], -1))
], 2)
]),
vue.createElementVNode("div", _hoisted_7$i, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v--disabled": !$data.canEdit || !$options.isButtonEnable(), "button-v--selected": $data.canEdit && $options.isButtonEnable() && $data.dialogShow == "ddei-core-panel-sort-merge-dialog", "button-v": $data.canEdit && $options.isButtonEnable() }),
onClick: _cache[2] || (_cache[2] = ($event) => $data.canEdit && $options.isButtonEnable() && $options.showMergeDialog($event))
}, [
_cache[8] || (_cache[8] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-merge1" })
], -1)),
vue.createElementVNode("div", _hoisted_8$e, vue.toDisplayString($props.editor.i18n("ddei.combina")), 1),
_cache[9] || (_cache[9] = vue.createElementVNode("svg", {
class: "icon extbtn",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
], -1))
], 2)
]),
vue.createElementVNode("div", _hoisted_9$d, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v--disabled": !$data.canEdit || !$options.isButtonEnable(), "button-v--selected": $data.canEdit && $options.isButtonEnable() && $data.dialogShow == "ddei-core-panel-sort-ddei-core-dialog-changerotate", "button-v": $data.canEdit && $options.isButtonEnable() }),
onClick: _cache[3] || (_cache[3] = ($event) => $data.canEdit && $options.isButtonEnable() && $options.showRotateDialog($event))
}, [
_cache[10] || (_cache[10] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-flip" })
], -1)),
vue.createElementVNode("div", _hoisted_10$7, vue.toDisplayString($props.editor.i18n("ddei.flip")), 1),
_cache[11] || (_cache[11] = vue.createElementVNode("svg", {
class: "icon extbtn",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
], -1))
], 2)
])
]),
vue.createElementVNode("div", _hoisted_11$7, vue.toDisplayString($props.editor.i18n("ddei.sortAndAlign")), 1)
]);
}
const Sort = /* @__PURE__ */ _export_sfc(_sfc_main$13, [["render", _sfc_render$13], ["__scopeId", "data-v-9f739241"]]);
const _DDeiCoreSortPanel = class _DDeiCoreSortPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", Sort.name);
__publicField3(this, "plugins", [Sort]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[Sort.name]) {
for (let i2 in options[Sort.name]) {
newOptions[i2] = options[Sort.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreSortPanel(newOptions);
return panels;
}
}
return _DDeiCoreSortPanel;
}
static modify(fn) {
return _DDeiCoreSortPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSortPanel, "defaultIns", new _DDeiCoreSortPanel(null));
let DDeiCoreSortPanel = _DDeiCoreSortPanel;
const _sfc_main$12 = {
name: "ddei-core-panel-quickstyle",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {};
},
computed: {},
watch: {},
created() {
},
mounted() {
}
};
const Style_vue_vue_type_style_index_0_scoped_109430c5_lang = "";
const _hoisted_1$11 = { class: "ddei-core-panel-quickstyle" };
const _hoisted_2$K = {
class: "ddei-core-panel-quickstyle-item",
style: { "grid-column": "1/16" }
};
const _hoisted_3$G = { class: "ddei-core-panel-quickstyle-item-text" };
function _sfc_render$12(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$11, [
_cache[0] || (_cache[0] = vue.createStaticVNode(' Abc
Abc
Abc
Abc
Abc
Abc
Abc
Abc
', 4)),
vue.createElementVNode("div", _hoisted_2$K, [
vue.createElementVNode("div", _hoisted_3$G, vue.toDisplayString(_ctx.editor.i18n("ddei.style")), 1)
])
]);
}
const Style = /* @__PURE__ */ _export_sfc(_sfc_main$12, [["render", _sfc_render$12], ["__scopeId", "data-v-109430c5"]]);
const _DDeiCoreStylePanel = class _DDeiCoreStylePanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", Style.name);
__publicField3(this, "plugins", [Style]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[Style.name]) {
for (let i2 in options[Style.name]) {
newOptions[i2] = options[Style.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreStylePanel(newOptions);
return panels;
}
}
return _DDeiCoreStylePanel;
}
static modify(fn) {
return _DDeiCoreStylePanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreStylePanel, "defaultIns", new _DDeiCoreStylePanel(null));
let DDeiCoreStylePanel = _DDeiCoreStylePanel;
const _sfc_main$11 = {
name: "ddei-core-panel-tool",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
canEdit: true
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3;
let mds = [this.editor.currentStage];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds }, this.editor.ddInstance);
if (rsState == -1) {
this.canEdit = false;
}
},
methods: {
/**
* 修改当前编辑器的编辑模式
*/
changeEditMode(mode) {
this.editor.bus.push(DDeiEditorEnumBusCommandType.ChangeEditMode, {
mode
});
this.editor.bus.executeAll();
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
};
const Tool_vue_vue_type_style_index_0_scoped_d02823f2_lang = "";
const _hoisted_1$10 = { class: "ddei-core-panel-tool" };
const _hoisted_2$J = { class: "content" };
const _hoisted_3$F = { class: "part" };
const _hoisted_4$v = ["title"];
const _hoisted_5$o = { class: "text" };
const _hoisted_6$j = { class: "part" };
const _hoisted_7$h = ["title"];
const _hoisted_8$d = { class: "text" };
const _hoisted_9$c = { class: "part" };
const _hoisted_10$6 = ["title"];
const _hoisted_11$6 = { class: "text" };
const _hoisted_12$4 = { class: "tail" };
function _sfc_render$11(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2, _f;
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$10, [
_cache[6] || (_cache[6] = vue.createElementVNode("div", { class: "header" }, null, -1)),
vue.createElementVNode("div", _hoisted_2$J, [
vue.createElementVNode("div", _hoisted_3$F, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v--selected": ((_a3 = $props.editor) == null ? void 0 : _a3.editMode) == 1, "button-v": ((_b2 = $props.editor) == null ? void 0 : _b2.editMode) != 1 }),
title: $props.editor.i18n("ddei.choose"),
onClick: _cache[0] || (_cache[0] = ($event) => $options.changeEditMode(1))
}, [
_cache[3] || (_cache[3] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-selector" })
], -1)),
vue.createElementVNode("div", _hoisted_5$o, vue.toDisplayString($props.editor.i18n("ddei.choose")), 1)
], 10, _hoisted_4$v)
]),
vue.createElementVNode("div", _hoisted_6$j, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v--selected": ((_c2 = $props.editor) == null ? void 0 : _c2.editMode) == 2, "button-v": ((_d2 = $props.editor) == null ? void 0 : _d2.editMode) != 2 }),
title: $props.editor.i18n("ddei.moveStage"),
onClick: _cache[1] || (_cache[1] = ($event) => $options.changeEditMode(2))
}, [
_cache[4] || (_cache[4] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-hand" })
], -1)),
vue.createElementVNode("div", _hoisted_8$d, vue.toDisplayString($props.editor.i18n("ddei.moveStage")), 1)
], 10, _hoisted_7$h)
]),
vue.createElementVNode("div", _hoisted_9$c, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "button-v--selected": $data.canEdit && ((_e2 = $props.editor) == null ? void 0 : _e2.editMode) == 4, "button-v": $data.canEdit && ((_f = $props.editor) == null ? void 0 : _f.editMode) != 4, "button-v--disabled": !$data.canEdit }),
title: $props.editor.i18n("ddei.linkLine"),
onClick: _cache[2] || (_cache[2] = ($event) => $data.canEdit && $options.changeEditMode(4))
}, [
_cache[5] || (_cache[5] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-link-line" })
], -1)),
vue.createElementVNode("div", _hoisted_11$6, vue.toDisplayString($props.editor.i18n("ddei.linkLine")), 1)
], 10, _hoisted_10$6)
])
]),
vue.createElementVNode("div", _hoisted_12$4, vue.toDisplayString($props.editor.i18n("ddei.tools")), 1)
]);
}
const Tool = /* @__PURE__ */ _export_sfc(_sfc_main$11, [["render", _sfc_render$11], ["__scopeId", "data-v-d02823f2"]]);
const _DDeiCoreToolPanel = class _DDeiCoreToolPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", Tool.name);
__publicField3(this, "plugins", [Tool]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[Tool.name]) {
for (let i2 in options[Tool.name]) {
newOptions[i2] = options[Tool.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreToolPanel(newOptions);
return panels;
}
}
return _DDeiCoreToolPanel;
}
static modify(fn) {
return _DDeiCoreToolPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreToolPanel, "defaultIns", new _DDeiCoreToolPanel(null));
let DDeiCoreToolPanel = _DDeiCoreToolPanel;
const _DDeiCoreCommonPanels = class _DDeiCoreCommonPanels extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [
DDeiCoreExportAndImportPanel,
DDeiCoreFileInfoPanel,
DDeiCoreFileOperatePanel,
DDeiCoreFontAndTextPanel,
DDeiCoreOperatePanel,
DDeiCoreOperatePanel,
DDeiCoreSortPanel,
DDeiCoreStylePanel,
DDeiCoreToolPanel
]);
}
getPanels(editor) {
var _a3;
let panels = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getPanels(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getPanels(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
panels = panels.concat(ls);
}
});
return panels;
}
static configuration(options) {
var _a3;
if (options) {
let panels = new _DDeiCoreCommonPanels(options);
for (let i2 = 0; i2 < ((_a3 = panels.plugins) == null ? void 0 : _a3.length); i2++) {
panels.plugins[i2] = panels.plugins[i2].configuration(options, true);
}
return panels;
}
return _DDeiCoreCommonPanels;
}
static modify(fn) {
return _DDeiCoreCommonPanels.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreCommonPanels, "defaultIns", new _DDeiCoreCommonPanels(null));
let DDeiCoreCommonPanels = _DDeiCoreCommonPanels;
const _sfc_main$10 = {
name: "ddei-core-panel-bottom-shapecount",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
watch: {},
created() {
},
mounted() {
}
};
const ShapeCount_vue_vue_type_style_index_0_scoped_91252de3_lang = "";
const _hoisted_1$$ = { class: "ddei-core-panel-bottom-shapecount" };
function _sfc_render$10(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2;
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$$, vue.toDisplayString($props.editor.i18n("ddei.shapesCount")) + " " + vue.toDisplayString((_c2 = (_b2 = $props.editor) == null ? void 0 : _b2.files[(_a3 = $props.editor) == null ? void 0 : _a3.currentFileIndex]) == null ? void 0 : _c2.modelNumber), 1);
}
const ShapeCount = /* @__PURE__ */ _export_sfc(_sfc_main$10, [["render", _sfc_render$10], ["__scopeId", "data-v-91252de3"]]);
const _DDeiCoreShapeCountPanel = class _DDeiCoreShapeCountPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", ShapeCount.name);
__publicField3(this, "plugins", [ShapeCount]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ShapeCount.name]) {
for (let i2 in options[ShapeCount.name]) {
newOptions[i2] = options[ShapeCount.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreShapeCountPanel(newOptions);
return panels;
}
}
return _DDeiCoreShapeCountPanel;
}
static modify(fn) {
return _DDeiCoreShapeCountPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreShapeCountPanel, "defaultIns", new _DDeiCoreShapeCountPanel(null));
let DDeiCoreShapeCountPanel = _DDeiCoreShapeCountPanel;
const _sfc_main$$ = {
name: "ddei-core-panel-bottom-managelayers",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
allowOpenMultLayers: true
};
},
computed: {},
watch: {},
created() {
},
mounted() {
this.allowOpenMultLayers = DDeiEditorUtil.getConfigValue(
"GLOBAL_ALLOW_OPEN_MULT_LAYERS",
this.editor
);
},
methods: {
showLayersDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-managerlayers", {
group: "bottom-dialog"
}, { type: 3 }, srcElement);
if (DDeiEditor.ACTIVE_INSTANCE.tempDialogData && DDeiEditor.ACTIVE_INSTANCE.tempDialogData["ddei-core-dialog-managerlayers"]) {
this.editor.changeState(DDeiEditorState.PROPERTY_EDITING);
} else {
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
}
};
const ManageLayers_vue_vue_type_style_index_0_scoped_e3adc5da_lang = "";
function _sfc_render$$(_ctx, _cache, $props, $setup, $data, $options) {
return $data.allowOpenMultLayers ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
class: "ddei-core-panel-bottom-managelayers",
onClick: _cache[0] || (_cache[0] = ($event) => $options.showLayersDialog($event))
}, _cache[1] || (_cache[1] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-layers" })
], -1)
]))) : vue.createCommentVNode("", true);
}
const ManageLayers = /* @__PURE__ */ _export_sfc(_sfc_main$$, [["render", _sfc_render$$], ["__scopeId", "data-v-e3adc5da"]]);
const _DDeiCoreManageLayersPanel = class _DDeiCoreManageLayersPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", ManageLayers.name);
__publicField3(this, "plugins", [ManageLayers]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ManageLayers.name]) {
for (let i2 in options[ManageLayers.name]) {
newOptions[i2] = options[ManageLayers.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreManageLayersPanel(newOptions);
return panels;
}
}
return _DDeiCoreManageLayersPanel;
}
static modify(fn) {
return _DDeiCoreManageLayersPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreManageLayersPanel, "defaultIns", new _DDeiCoreManageLayersPanel(null));
let DDeiCoreManageLayersPanel = _DDeiCoreManageLayersPanel;
const _sfc_main$_ = {
name: "ddei-core-panel-bottom-play",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
watch: {},
created() {
},
mounted() {
},
methods: {}
};
const Play_vue_vue_type_style_index_0_scoped_7e2fc5b7_lang = "";
const _hoisted_1$_ = { class: "ddei-core-panel-bottom-play" };
function _sfc_render$_(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$_, _cache[0] || (_cache[0] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-play" })
], -1)
]));
}
const Play = /* @__PURE__ */ _export_sfc(_sfc_main$_, [["render", _sfc_render$_], ["__scopeId", "data-v-7e2fc5b7"]]);
const _DDeiCorePlayPanel = class _DDeiCorePlayPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", Play.name);
__publicField3(this, "plugins", [Play]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[Play.name]) {
for (let i2 in options[Play.name]) {
newOptions[i2] = options[Play.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCorePlayPanel(newOptions);
return panels;
}
}
return _DDeiCorePlayPanel;
}
static modify(fn) {
return _DDeiCorePlayPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCorePlayPanel, "defaultIns", new _DDeiCorePlayPanel(null));
let DDeiCorePlayPanel = _DDeiCorePlayPanel;
const stage = {
"id": "DDeiStage",
"name": "ddei.control.stage",
"code": "stage",
"desc": "整体画布的属性",
"type": "DDeiStage",
/**
* 定义组件属性
* 样式属性会影响图形的显示,修改样式属性也会刷新图形
* 数据属性一般用于业务计算,数据属性一般不会刷新图形,除非数据属性和样式属性产生联动关系
* 事件属性一般用来作为扩展用
* 属性采用三层结构:组---子分组---属性,在基础json中先定义而后使用(可以复写)
* 特殊属性:
* code属性编码在统一个组中,code唯一
* mapping建立与模型中属性的映射关系,为null时为默认,采用code指向的属性映射;mapping为[]时交由控件编辑器处理值映射
* hiddenTitle隐藏标题,为true时不会显示属性标题,默认false不隐藏标题
* display控件显示模式,有row(横向排列)和column(纵向排列)两个选项,默认row
*/
attrs: [
{
"code": "paper.type",
"name": "ddei.property.paperType",
"desc": "用来快速选择纸张的类型,以便于套用相关的样式",
"controlType": "combox",
"dataType": "string",
"dataSource": {
"type": "config",
"data": "PAPER_DATASOURCE",
"text": "name",
"value": "code",
"desc": "desc"
},
"canSearch": false,
"itemStyle": { width: 170, align: "left", paddingLeft: "10px", height: 25, col: 1, row: 8, imgWidth: 20, imgHeight: 20 },
"defaultValue": "A4",
"cascadeDisplay": { "ddei.property.ds.none": { hidden: ["paper.direct", "paper.width", "paper.height", "paper.unit"] }, "ddei.property.ds.custom": { show: ["paper.direct", "paper.width", "paper.height", "paper.unit"] }, notempty: { show: ["paper.direct"], hidden: ["paper.width", "paper.height", "paper.unit"] }, empty: { hidden: ["paper.width", "paper.height", "paper.unit"] }, default: { hidden: ["paper.width", "paper.height", "paper.unit"] } },
"type": 1
},
{
"code": "paper.width",
"name": "ddei.property.width",
"desc": "用来设置纸张的宽度,以便于套用相关的样式",
"controlType": "text",
"dataType": "integer",
"defaultValue": 210,
"type": 1
},
{
"code": "paper.height",
"name": "ddei.property.height",
"desc": "用来设置纸张的高度,以便于套用相关的样式",
"controlType": "text",
"dataType": "integer",
"defaultValue": 297,
"type": 1
},
{
"code": "paper.unit",
"name": "ddei.property.unit",
"desc": "用来设置纸张的宽高单位,以便于套用相关的样式",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.mm", "value": "mm" }, { "text": "ddei.property.ds.cm", "value": "cm" }, { "text": "ddei.property.ds.m", "value": "m" }, { "text": "ddei.property.ds.inch", "value": "inch" }, { "text": "ddei.property.ds.px", "value": "px" }],
"defaultValue": "mm"
},
{
"code": "paper.direct",
"name": "ddei.property.direct",
"desc": "用来设置纸张的方向,以便于套用相关的样式",
"controlType": "radio",
"dataSource": [{ "text": "ddei.property.ds.transverse", "value": 1 }, { "text": "ddei.property.ds.portrait", "value": 2 }],
"dataType": "integer",
"defaultValue": 2,
"type": 1
},
{
"code": "mark.type",
"name": "ddei.property.markType",
"desc": "用来快速选择水印的类型,以便于套用相关的样式",
"controlType": "radio",
"dataSource": [{ "text": "ddei.property.ds.none", "value": 0 }, { "text": "ddei.property.ds.text", "value": 1 }, { "text": "ddei.property.ds.image", "value": 2 }],
"dataType": "integer",
"defaultValue": 0,
"hiddenTitle": true,
"display": "column",
"cascadeDisplay": { 1: { show: ["mark.data", "mark.direct", "mark.opacity", "mark.font.family", "mark.font.size", "mark.font.color"] }, 2: { show: ["mark.data", "mark.direct", "mark.opacity"], hidden: ["mark.font.family", "mark.font.size", "mark.font.color"] }, empty: { hidden: ["mark.data", "mark.direct", "mark.opacity", "mark.font.family", "mark.font.size", "mark.font.color"] } },
"mapping": [],
"type": 1
},
{
"code": "mark.data",
"name": "ddei.property.mark",
"desc": "当水印类型为1时,此字段将显示文本,当类行为2时,此字段显示为图片",
"controlType": "image",
"dataType": "string",
"defaultValue": "",
"type": 1
},
{
"code": "mark.direct",
"name": "ddei.property.markDirect",
"desc": "水印的显示方向",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.ltrd", "value": "1" }, { "text": "ddei.property.ds.rtld", "value": "2" }, { "text": "ddei.property.ds.horizontal", "value": "3" }],
"defaultValue": "1",
"type": 1
},
{
"code": "mark.opacity",
"name": "ddei.property.opacity",
"desc": "透明度,0完全透明~1完全不透明",
"controlType": "range",
"min": 0,
"max": 1,
"step": 0.01,
"dataType": "float",
"defaultValue": 0.25,
"display": "column"
},
{
"code": "mark.font.family",
"name": "ddei.property.font",
"desc": "文本的字体名称",
"controlType": "combox",
"dataType": "string",
"dataSource": {
"type": "config",
"data": "fonts",
"text": "ch",
"value": "en",
"bold": "isSystemDefault",
"fontFamily": "en"
},
"itemStyle": { width: 80, height: 25, col: 2, row: 0, imgWidth: 20, imgHeight: 20 },
"canSearch": true,
"defaultValue": ""
},
{
"code": "mark.font.size",
"name": "ddei.property.size",
"desc": "文本的字体大小",
"max": 50,
"min": 5,
"step": 0.5,
"controlType": "font-size",
"dataType": "float",
"defaultValue": 14
},
{
"code": "mark.font.color",
"name": "ddei.property.color",
"desc": "文本的颜色",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": ""
},
{
"code": "ruler.display",
"name": "ddei.property.ruler",
"desc": "是否显示标尺",
"controlType": "switch-checkbox",
"dataType": "integer",
"defaultValue": 1,
"display": "column",
"hiddenTitle": true,
"type": 1,
"cascadeDisplay": { 1: { show: ["ruler.unit"] }, default: { show: ["ruler.unit"] }, empty: { hidden: ["ruler.unit"] } }
},
{
"code": "ruler.unit",
"name": "ddei.property.unit",
"desc": "用来设置标尺单位样式",
"controlType": "combox",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.mm", "value": "mm" }, { "text": "ddei.property.ds.cm", "value": "cm" }, { "text": "ddei.property.ds.m", "value": "m" }, { "text": "ddei.property.ds.inch", "value": "inch" }, { "text": "ddei.property.ds.px", "value": "px" }],
"itemStyle": { width: 80, height: 25, col: 2, row: 0, imgWidth: 20, imgHeight: 20 },
"defaultValue": "mm",
"type": 1
},
{
"code": "grid.display",
"name": "ddei.property.grid",
"desc": "设置网格线样式",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.none", "value": "0" }, { "text": "ddei.property.ds.line", "value": "1" }, { "text": "ddei.property.ds.point", "value": "2" }],
"defaultValue": "1",
"type": 1
},
{
"code": "global.jumpline",
"name": "ddei.property.jumpline",
"desc": "遇到线交叉时,展示跳线",
"controlType": "switch-checkbox",
"dataType": "integer",
"defaultValue": 1,
"type": 1,
"display": "column",
"hiddenTitle": true
}
],
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-setting",
subGroups: [
{
name: "ddei.paper",
attrs: ["paper.type", "paper.width", "paper.height", "paper.unit", "paper.direct"]
},
{
name: "ddei.mark",
attrs: ["mark.type", "mark.data", "mark.direct", "mark.opacity", "mark.font.family", "mark.font.size", "mark.font.color"]
},
{
name: "ddei.assistant",
attrs: ["ruler.display", "ruler.unit", "grid.display", "global.jumpline"]
}
]
}
]
};
const __vite_glob_0_99$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: stage
}, Symbol.toStringTag, { value: "Module" }));
const _sfc_main$Z = {
name: "ddei-core-panel-bottom-suitratio",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
allowStageRatio: true,
currentStage: null
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3, _b2;
this.allowStageRatio = DDeiEditorUtil.getConfigValue(
"GLOBAL_ALLOW_STAGE_RATIO",
this.editor
);
let file = (_b2 = this.editor) == null ? void 0 : _b2.files[(_a3 = this.editor) == null ? void 0 : _a3.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
this.currentStage = sheet == null ? void 0 : sheet.stage;
},
methods: {
/**
* 自动设置页面模式,
*/
autoRatio(type) {
if (type == 1) {
let maxOutRect = DDeiAbstractShape.getOutRectByPV(
this.editor.ddInstance.stage.getLayerModels()
);
if (maxOutRect.width > 0 && maxOutRect.height > 0) {
let canvas = this.editor.ddInstance.render.canvas;
let rat1 = this.editor.ddInstance.render.ratio;
let stageRatio2 = this.currentStage.getStageRatio();
let hscrollWeight = 0;
let vscrollWeight = 0;
if (this.editor.ddInstance.stage.render.hScroll) {
hscrollWeight = 15;
}
if (this.editor.ddInstance.stage.render.vScroll) {
vscrollWeight = 15;
}
let ruleDisplay = DDeiModelArrtibuteValue.getAttrValueByState(
this.editor.ddInstance.stage,
"ruler.display",
true
);
let ruleWeight = 0;
if (ruleDisplay == 1 || ruleDisplay == "1") {
ruleWeight = 16;
}
let cWidth = canvas.width / rat1 - ruleWeight - vscrollWeight;
let cHeight = canvas.height / rat1 - ruleWeight - hscrollWeight;
let wScale = maxOutRect.width * stageRatio2 / cWidth;
let hScale = maxOutRect.height * stageRatio2 / cHeight;
let scale = wScale;
if (wScale < hScale) {
scale = hScale;
}
let sc = stageRatio2 / scale;
this.setRatio(sc);
setTimeout(() => {
var _a3, _b2, _c2, _d2;
(_b2 = (_a3 = this.editor) == null ? void 0 : _a3.bus) == null ? void 0 : _b2.push(DDeiEnumBusCommandType.CenterStageWPV);
this.editor.changeState(DDeiEditorState.DESIGNING);
(_d2 = (_c2 = this.editor) == null ? void 0 : _c2.bus) == null ? void 0 : _d2.executeAll(100);
}, 10);
}
}
},
/**
* 设置缩放比率
*/
setRatio(ratio) {
var _a3;
if (ratio < this.min) {
ratio = this.min;
} else if (ratio > this.max) {
ratio = this.max;
}
(_a3 = this.currentStage) == null ? void 0 : _a3.setStageRatio(ratio);
}
}
};
const SuitRatio_vue_vue_type_style_index_0_scoped_4eeb5012_lang = "";
const _hoisted_1$Z = ["title"];
function _sfc_render$Z(_ctx, _cache, $props, $setup, $data, $options) {
return $data.allowStageRatio ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
class: "ddei-core-panel-bottom-suitratio",
onClick: _cache[0] || (_cache[0] = ($event) => $options.autoRatio(1)),
title: $props.editor.i18n("ddei.wholePage")
}, _cache[1] || (_cache[1] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-suit-ratio" })
], -1)
]), 8, _hoisted_1$Z)) : vue.createCommentVNode("", true);
}
const SuitRatio = /* @__PURE__ */ _export_sfc(_sfc_main$Z, [["render", _sfc_render$Z], ["__scopeId", "data-v-4eeb5012"]]);
const _DDeiCoreSuitRatioPanel = class _DDeiCoreSuitRatioPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", SuitRatio.name);
__publicField3(this, "plugins", [SuitRatio]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[SuitRatio.name]) {
for (let i2 in options[SuitRatio.name]) {
newOptions[i2] = options[SuitRatio.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreSuitRatioPanel(newOptions);
return panels;
}
}
return _DDeiCoreSuitRatioPanel;
}
static modify(fn) {
return _DDeiCoreSuitRatioPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSuitRatioPanel, "defaultIns", new _DDeiCoreSuitRatioPanel(null));
let DDeiCoreSuitRatioPanel = _DDeiCoreSuitRatioPanel;
const _sfc_main$Y = {
name: "ddei-core-panel-bottom-changeratio",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
delta: {
type: Number,
default: 0.05
},
min: {
type: Number,
default: 0.1
},
max: {
type: Number,
default: 4
},
dialog: {
type: Boolean,
default: true
},
range: {
type: Boolean,
default: true
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
ratioInputValue: 0,
stageRatio: 1,
allowStageRatio: true,
currentStage: null
};
},
computed: {},
watch: {},
created() {
this.$watch("currentStage.ratio", function(newVal, oldVal) {
if (DDeiEditorUtil.getConfigValue("GLOBAL_ALLOW_STAGE_RATIO", this.editor)) {
if (oldVal && oldVal != newVal) {
if (!this.changeCurrentStage) {
this.ratioInputValue = parseFloat(newVal) * 100;
this.stageRatio = newVal;
if (!this.tempSheetChange) {
this.changeRatio();
} else {
delete this.tempSheetChange;
}
} else {
this.changeCurrentStage = false;
}
}
}
});
this.$watch("stageRatio", function(newVal, oldVal) {
if (DDeiEditorUtil.getConfigValue("GLOBAL_ALLOW_STAGE_RATIO", this.editor)) {
this.setRatio(newVal);
}
});
},
mounted() {
var _a3, _b2;
this.editor.ddInstance.ratioWatch = true;
let file = (_b2 = this.editor) == null ? void 0 : _b2.files[(_a3 = this.editor) == null ? void 0 : _a3.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
this.currentStage = sheet == null ? void 0 : sheet.stage;
this.allowStageRatio = DDeiEditorUtil.getConfigValue(
"GLOBAL_ALLOW_STAGE_RATIO",
this.editor
);
},
methods: {
showChangeRatioDialog(evt) {
var _a3;
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-changeratio", {
ratio: (_a3 = this.currentStage) == null ? void 0 : _a3.ratio,
min: this.min,
max: this.max,
callback: {
ok: this.setRatio
},
group: "bottom-dialog"
}, { type: 2 }, srcElement);
if (DDeiEditor.ACTIVE_INSTANCE.tempDialogData && DDeiEditor.ACTIVE_INSTANCE.tempDialogData["ddei-core-dialog-changeratio"]) {
this.editor.changeState(DDeiEditorState.PROPERTY_EDITING);
} else {
this.editor.changeState(DDeiEditorState.DESIGNING);
}
},
/**
* 增加缩放比率
*/
addRatio(deltaRatio) {
var _a3, _b2, _c2;
let ratio = (_a3 = this.currentStage) == null ? void 0 : _a3.getStageRatio();
let newRatio = parseFloat((ratio + deltaRatio).toFixed(2));
if (newRatio < this.min) {
newRatio = this.min;
} else if (newRatio > this.max) {
newRatio = this.max;
}
(_b2 = this.currentStage) == null ? void 0 : _b2.setStageRatio(newRatio);
this.stageRatio = (_c2 = this.currentStage) == null ? void 0 : _c2.ratio;
this.editor.changeState(DDeiEditorState.DESIGNING);
},
/**
* 设置缩放比率
*/
setRatio(ratio) {
var _a3, _b2;
if (ratio < this.min) {
ratio = this.min;
} else if (ratio > this.max) {
ratio = this.max;
}
(_a3 = this.currentStage) == null ? void 0 : _a3.setStageRatio(ratio);
this.stageRatio = (_b2 = this.currentStage) == null ? void 0 : _b2.ratio;
},
/**
* 修改当前的全局缩放比率
*/
changeRatio() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
if (((_a3 = this.currentStage) == null ? void 0 : _a3.ratio) || ((_b2 = this.currentStage) == null ? void 0 : _b2.ratio) == 0) {
if (((_c2 = this.currentStage) == null ? void 0 : _c2.oldRatio) || ((_d2 = this.currentStage) == null ? void 0 : _d2.oldRatio) == 0) {
(_f = (_e2 = this.editor) == null ? void 0 : _e2.bus) == null ? void 0 : _f.push(
DDeiEnumBusCommandType.ChangeStageRatio,
{
oldValue: this.currentStage.oldRatio,
newValue: this.currentStage.ratio
},
null
);
(_h = (_g = this.editor) == null ? void 0 : _g.bus) == null ? void 0 : _h.executeAll();
}
}
}
}
};
const ChangeRatio_vue_vue_type_style_index_0_scoped_f8d489b0_lang = "";
const _hoisted_1$Y = {
key: 0,
class: "ddei-core-panel-bottom-changeratio"
};
const _hoisted_2$I = {
key: 0,
class: "icon expbtn",
"aria-hidden": "true"
};
const _hoisted_3$E = {
key: 0,
class: "icon expbtn",
"aria-hidden": "true"
};
const _hoisted_4$u = ["min", "max", "step"];
function _sfc_render$Y(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2;
return $data.allowStageRatio ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_1$Y, [
$props.range ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
class: vue.normalizeClass({ "ddei-core-panel-bottom-changeratio__combox": true, "ddei-core-panel-bottom-changeratio__combox__dialog": $props.dialog }),
onClick: _cache[0] || (_cache[0] = ($event) => $props.dialog && $options.showChangeRatioDialog($event))
}, [
vue.createElementVNode("span", null, vue.toDisplayString(parseInt(((_a3 = $data.currentStage) == null ? void 0 : _a3.ratio) * 100)) + "% ", 1),
$props.dialog ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$I, _cache[5] || (_cache[5] = [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" }, null, -1)
]))) : vue.createCommentVNode("", true)
], 2)) : vue.createCommentVNode("", true),
vue.createElementVNode("div", {
onClick: _cache[1] || (_cache[1] = ($event) => $options.addRatio(-$props.delta))
}, _cache[6] || (_cache[6] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-reduce" })
], -1)
])),
!$props.range ? (vue.openBlock(), vue.createElementBlock("div", {
key: 1,
class: vue.normalizeClass({ "ddei-core-panel-bottom-changeratio__combox": true, "ddei-core-panel-bottom-changeratio__combox__dialog": $props.dialog }),
onClick: _cache[2] || (_cache[2] = ($event) => $props.dialog && $options.showChangeRatioDialog($event))
}, [
vue.createElementVNode("span", null, vue.toDisplayString(parseInt(((_b2 = $data.currentStage) == null ? void 0 : _b2.ratio) * 100)) + "% ", 1),
$props.dialog ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_3$E, _cache[7] || (_cache[7] = [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" }, null, -1)
]))) : vue.createCommentVNode("", true)
], 2)) : vue.createCommentVNode("", true),
vue.withDirectives(vue.createElementVNode("input", {
type: "range",
min: $props.min,
max: $props.max,
step: $props.delta,
"onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => $data.stageRatio = $event),
autocomplete: "off",
name: "ddei-core-panel-bottom-changeratio__range"
}, null, 8, _hoisted_4$u), [
[vue.vShow, $props.range],
[vue.vModelText, $data.stageRatio]
]),
vue.createElementVNode("div", {
onClick: _cache[4] || (_cache[4] = ($event) => $options.addRatio($props.delta))
}, _cache[8] || (_cache[8] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-add" })
], -1)
]))
])) : vue.createCommentVNode("", true);
}
const ChangeRatio$1 = /* @__PURE__ */ _export_sfc(_sfc_main$Y, [["render", _sfc_render$Y], ["__scopeId", "data-v-f8d489b0"]]);
const _DDeiCoreChangeRatioPanel = class _DDeiCoreChangeRatioPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", ChangeRatio$1.name);
__publicField3(this, "plugins", [ChangeRatio$1]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ChangeRatio$1.name]) {
for (let i2 in options[ChangeRatio$1.name]) {
newOptions[i2] = options[ChangeRatio$1.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreChangeRatioPanel(newOptions);
return panels;
}
}
return _DDeiCoreChangeRatioPanel;
}
static modify(fn) {
return _DDeiCoreChangeRatioPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreChangeRatioPanel, "defaultIns", new _DDeiCoreChangeRatioPanel(null));
let DDeiCoreChangeRatioPanel = _DDeiCoreChangeRatioPanel;
const _sfc_main$X = {
name: "ddei-core-panel-bottom-sheets",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
max: {
type: Number,
default: 0
},
drag: {
type: Boolean,
default: true
},
create: {
type: Boolean,
default: true
},
rename: {
type: Boolean,
default: true
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
file: null,
maxOpenSize: 0,
openIndex: 0,
allowEditSheet: true
//是否允许编辑页签
// sslink: null,
// user: null,
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3, _b2, _c2;
const resizeObserver = new ResizeObserver((entries) => {
for (const entry of entries) {
const { width, height } = entry.contentRect;
if (width != 0 && height != 0) {
let pagesEles = document.getElementsByClassName("ddei-core-panel-bottom-pages");
let pageEles = document.getElementsByClassName("ddei-core-panel-bottom-pages-page");
let divWidth = 0;
let pagesWidth = 1e3;
if (pageEles.length > 0) {
divWidth = pageEles[0].clientWidth;
}
if (!divWidth) {
divWidth = 70;
}
if (pagesEles.length > 0) {
pagesWidth = pagesEles[0].clientWidth;
}
let size = parseInt(pagesWidth / divWidth);
if (size > this.maxOpenSize && this.openIndex > 0) {
this.openIndex--;
}
this.maxOpenSize = size - 1;
}
}
});
resizeObserver.observe(this.$refs.bottomSheets);
let file = (_b2 = this.editor) == null ? void 0 : _b2.files[(_a3 = this.editor) == null ? void 0 : _a3.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
this.changeCurrentStage = true;
this.editor.currentStage = sheet == null ? void 0 : sheet.stage;
this.allowEditSheet = ((_c2 = this.editor.ddInstance) == null ? void 0 : _c2.AC_DESIGN_EDIT) != false ? true : false;
this.file = file;
},
methods: {
/**
* 在存在显示隐藏的情况下移动tab
*/
moveItem(index = 0) {
var _a3, _b2;
if (index != 0) {
let file = (_b2 = this.editor) == null ? void 0 : _b2.files[(_a3 = this.editor) == null ? void 0 : _a3.currentFileIndex];
let sheets = file == null ? void 0 : file.sheets;
this.openIndex += index;
if (this.openIndex > sheets.length - this.maxOpenSize) {
this.openIndex = sheets.length - this.maxOpenSize;
} else if (this.openIndex < 0) {
this.openIndex = 0;
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.executeAll();
}
},
/**
* sheet开始拖拽移动
*/
sheetDragStart(sheetEle, evt) {
this.dragSheetEle = evt.currentTarget;
},
/**
* 拖拽元素移动
*/
sheetDragOver(e) {
if (this.dragSheetEle) {
let parentDiv = this.dragSheetEle.parentElement;
let sourceIndex = -1;
let targetIndex = -1;
let children = parentDiv.children;
for (let i2 = 0; i2 < children.length - 2; i2++) {
children[i2].style.borderLeft = "";
children[i2].style.borderRight = "";
if (children[i2] == this.dragSheetEle) {
sourceIndex = i2;
} else if (e.target == children[i2]) {
targetIndex = i2;
}
}
if (sourceIndex != -1 && targetIndex != -1) {
this.sourceSheetIndex = sourceIndex;
if (targetIndex == children.length - 3) {
let pos = DDeiUtil.getDomAbsPosition(children[targetIndex]);
let halfPos = pos.left + children[targetIndex].offsetWidth / 2;
if (halfPos <= e.clientX && e.clientX <= pos.left + children[targetIndex].offsetWidth) {
this.changeSheetIndex = targetIndex;
children[targetIndex].style.borderRight = "2px solid #017fff";
} else {
this.changeSheetIndex = targetIndex - 1;
children[targetIndex].style.borderLeft = "2px solid #017fff";
}
} else {
this.changeSheetIndex = targetIndex - 1;
children[targetIndex].style.borderLeft = "2px solid #017fff";
}
}
e.preventDefault();
}
},
/**
* 拖拽元素放开
*/
sheetDragDrop(e) {
var _a3;
if ((this.sourceSheetIndex || this.sourceSheetIndex == 0) && (this.changeSheetIndex || this.changeSheetIndex == 0)) {
let file = this.editor.files[this.editor.currentFileIndex];
let sheet = file.sheets[this.sourceSheetIndex];
let currentSheet = file.sheets[file.currentSheetIndex];
file.sheets[this.sourceSheetIndex] = null;
file.sheets.splice(this.changeSheetIndex + 1, 0, sheet);
for (let j2 = file.sheets.length; j2 >= 0; j2--) {
if (file.sheets[j2] == null) {
file.sheets.splice(j2, 1);
}
}
for (let j2 = file.sheets.length; j2 >= 0; j2--) {
if (currentSheet == file.sheets[j2]) {
file.currentSheetIndex = j2;
}
}
(_a3 = this.editor.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
this.editor.bus.push(DDeiEditorEnumBusCommandType.AddFileHistroy);
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["bottommenu"]
});
this.editor.bus.executeAll();
this.editor.changeState(DDeiEditorState.DESIGNING);
}
this.dragSheetEle = null;
this.sourceSheetIndex = null;
this.changeSheetIndex = null;
},
/**
* 开始修改页标题
*/
startChangeSheetName(sheet, evt) {
let ele = evt.target;
let domPos = DDeiUtil.getDomAbsPosition(ele);
let editor = DDeiEditor.ACTIVE_INSTANCE;
let editorEle = document.getElementById(editor.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let input = document.getElementById(editor.id + "_change_sheet_name_input");
if (!input) {
input = document.createElement("input");
input.setAttribute("id", editor.id + "_change_sheet_name_input");
input.style.position = "absolute";
input.style.fontSize = "16px";
editorEle.appendChild(input);
input.onblur = function() {
var _a3;
if (input.value) {
let editor2 = DDeiEditor.ACTIVE_INSTANCE;
let file = editor2 == null ? void 0 : editor2.files[editor2 == null ? void 0 : editor2.currentFileIndex];
let sheet2 = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
if (input.value != sheet2.name) {
sheet2.name = input.value;
(_a3 = editor2.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
editor2.bus.push(DDeiEditorEnumBusCommandType.AddFileHistroy);
editor2.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["bottommenu"]
});
editor2.bus.executeAll();
editor2.changeState(DDeiEditorState.DESIGNING);
}
input.style.display = "none";
input.style.left = "0px";
input.style.top = "0px";
input.value = "";
}
};
input.onkeydown = function(e) {
var _a3;
if (e.keyCode == 13) {
let editor2 = DDeiEditor.ACTIVE_INSTANCE;
let file = editor2 == null ? void 0 : editor2.files[editor2 == null ? void 0 : editor2.currentFileIndex];
let sheet2 = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
if (input.value != sheet2.name) {
sheet2.name = input.value;
(_a3 = editor2.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
editor2.bus.push(DDeiEditorEnumBusCommandType.AddFileHistroy);
editor2.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["bottommenu"]
});
editor2.bus.executeAll();
editor2.changeState(DDeiEditorState.DESIGNING);
}
input.style.display = "none";
input.style.left = "0px";
input.style.top = "0px";
input.value = "";
} else if (e.keyCode == 27) {
let editor2 = DDeiEditor.ACTIVE_INSTANCE;
input.style.display = "none";
input.style.left = "0px";
input.style.top = "0px";
input.value = "";
editor2.changeState(DDeiEditorState.DESIGNING);
}
};
}
input.style.width = ele.offsetWidth + "px";
input.style.height = ele.offsetHeight + "px";
input.style.left = domPos.left - editorDomPos.left + "px";
input.style.top = domPos.top - editorDomPos.top + "px";
input.style.outline = "1px solid #017fff";
input.style.border = "none";
input.style.borderRadius = "1px";
input.value = sheet.name;
input.style.display = "block";
input.style.background = "var(--background)";
input.style.color = "var(--text)";
input.selectionStart = 0;
input.selectionEnd = input.value.length;
input.focus();
this.editor.changeState(DDeiEditorState.PROPERTY_EDITING);
},
/**
* 创建一个sheet
*/
newSheet() {
var _a3, _b2, _c2, _d2, _e2, _f, _g;
let file = (_b2 = this.editor) == null ? void 0 : _b2.files[(_a3 = this.editor) == null ? void 0 : _a3.currentFileIndex];
let sheets = file == null ? void 0 : file.sheets;
if (this.max && sheets.length >= this.max) {
return;
}
let ddInstance = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance;
if (file && sheets && ddInstance) {
let rsState = DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_SHEET_BEFORE", "ADD_SHEET", null, ddInstance, null);
if (rsState != -1) {
let i2 = sheets.length + 1;
let stage2 = DDeiStage.initByJSON(
{ id: "stage" },
{ currentDdInstance: ddInstance }
);
let pageText = this.editor.i18n("ddei.page");
sheets.push(
new DDeiSheet({
name: pageText + "-" + i2,
desc: pageText + "-" + i2,
stage: stage2
})
);
file.changeSheet(sheets.length - 1);
ddInstance.stage.destroyRender();
ddInstance.stage = stage2;
this.editor.currentStage = stage2;
stage2.initRender();
if (!stage2.wpv) {
stage2.wpv = {
x: -(stage2.width - ddInstance.render.container.clientWidth) / 2,
y: -(stage2.height - ddInstance.render.container.clientHeight) / 2,
z: 0
};
}
DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_SHEET_AFTER", "ADD_SHEET", null, ddInstance, null);
this.editor.changeState(DDeiEditorState.DESIGNING);
(_d2 = this.editor.editorViewer) == null ? void 0 : _d2.changeFileModifyDirty();
(_e2 = ddInstance.bus) == null ? void 0 : _e2.push(DDeiEditorEnumBusCommandType.AddFileHistroy);
(_f = ddInstance.bus) == null ? void 0 : _f.push(DDeiEnumBusCommandType.RefreshShape);
(_g = ddInstance.bus) == null ? void 0 : _g.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {});
ddInstance.bus.executeAll();
DDeiEditorUtil.closeDialogs(this.editor, null, true);
DDeiEditorUtil.closeDialogs(this.editor, null, false);
let activeIndex = sheets.length - 1;
this.openIndex = activeIndex + 1 - this.maxOpenSize;
if (this.openIndex < 0) {
this.openIndex = 0;
}
}
}
},
/**
* 切换sheet
*/
changeSheet(index) {
var _a3, _b2, _c2;
let file = (_b2 = this.editor) == null ? void 0 : _b2.files[(_a3 = this.editor) == null ? void 0 : _a3.currentFileIndex];
let sheets = file == null ? void 0 : file.sheets;
let ddInstance = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance;
if (file && sheets && ddInstance && (index >= 0 || index < sheets.length)) {
if (index != file.currentSheetIndex) {
let rsState = DDeiEditorUtil.invokeCallbackFunc("EVENT_CHANGE_SHEET_BEFORE", "CHANGE_SHEET", null, ddInstance, null);
if (rsState != -1) {
this.tempSheetChange = true;
file.changeSheet(index);
let stage2 = sheets[index].stage;
stage2.ddInstance = ddInstance;
ddInstance.stage.destroyRender();
ddInstance.stage = stage2;
this.editor.currentStage = stage2;
stage2.initRender();
DDeiEditorUtil.invokeCallbackFunc("EVENT_CHANGE_SHEET_AFTER", "CHANGE_SHEET", null, ddInstance, null);
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {});
ddInstance.bus.executeAll();
DDeiEditorUtil.closeDialogs(this.editor, null, true);
DDeiEditorUtil.closeDialogs(this.editor, null, false);
this.showPopPicker(stage2);
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
}
},
showPopPicker(stage2) {
var _a3;
if (((_a3 = stage2.selectedModels) == null ? void 0 : _a3.size) > 0) {
let models = Array.from(stage2.selectedModels.values());
if ((models == null ? void 0 : models.length) > 0) {
let height = 100;
let modelPos = DDeiUtil.getModelsDomAbsPosition(models);
let left = modelPos.left + modelPos.width / 2;
let top = modelPos.top + modelPos.height / 2;
if (modelPos.top - height <= modelPos.cTop) {
if (modelPos.height > 400) {
top = top + height + 20;
} else {
top = top + modelPos.height / 2 + 20;
}
} else {
top = top - height;
}
if (top < 0) {
top = modelPos.cTop + modelPos.cHeight / 2;
}
if (left < 0) {
left = 0;
}
DDeiEditorUtil.showDialog(this.editor, "ddei-core-dialog-quickpop", {
group: "canvas-pop"
}, { type: 99, left, top, hiddenMask: true }, null, true, true);
}
}
},
/**
* 显示右键菜单
*/
showMenu(sheet, evt) {
DDeiUtil.showContextMenu(sheet, this.editor.ddInstance, evt);
evt.preventDefault();
return false;
}
}
};
const Sheets_vue_vue_type_style_index_0_scoped_d059d47d_lang = "";
const _hoisted_1$X = {
key: 0,
class: "ddei-core-panel-bottom-pages-page"
};
const _hoisted_2$H = ["onClick", "onContextmenu", "onDblclick", "title"];
function _sfc_render$X(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
return vue.openBlock(), vue.createElementBlock(vue.Fragment, null, [
$data.allowEditSheet && $props.create && (!$props.max || ((_d2 = (_c2 = (_b2 = $props.editor) == null ? void 0 : _b2.files[(_a3 = $props.editor) == null ? void 0 : _a3.currentFileIndex]) == null ? void 0 : _c2.sheets) == null ? void 0 : _d2.length) < $props.max) ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
class: "ddei-core-panel-bottom-addpage",
onClick: _cache[0] || (_cache[0] = (...args) => $options.newSheet && $options.newSheet(...args))
}, _cache[6] || (_cache[6] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-add" })
], -1)
]))) : vue.createCommentVNode("", true),
vue.createElementVNode("div", {
class: "ddei-core-panel-bottom-pages",
ref: "bottomSheets",
onMouseup: _cache[5] || (_cache[5] = ($event) => $props.drag && $options.sheetDragDrop($event))
}, [
$data.maxOpenSize == 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_1$X, _cache[7] || (_cache[7] = [
vue.createElementVNode("span", null, null, -1)
]))) : vue.createCommentVNode("", true),
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_g = (_f = $props.editor) == null ? void 0 : _f.files[(_e2 = $props.editor) == null ? void 0 : _e2.currentFileIndex]) == null ? void 0 : _g.sheets, (sheet, index) => {
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
onMousedown: _cache[1] || (_cache[1] = ($event) => $data.allowEditSheet && $props.drag && $options.sheetDragStart(null, $event)),
onClick: vue.withModifiers(($event) => $options.changeSheet(index), ["left"]),
onContextmenu: vue.withModifiers(($event) => $options.showMenu(sheet, $event), ["right"]),
onMousemove: _cache[2] || (_cache[2] = ($event) => $props.drag && $options.sheetDragOver($event)),
onDblclick: ($event) => $data.allowEditSheet && $props.rename && $options.startChangeSheetName(sheet, $event),
class: vue.normalizeClass({ "ddei-core-panel-bottom-pages-page": sheet.active == 0, "ddei-core-panel-bottom-pages-page--selected": sheet.active == 1 }),
title: sheet.name
}, [
vue.createElementVNode("span", null, vue.toDisplayString(sheet.name), 1)
], 42, _hoisted_2$H)), [
[vue.vShow, index >= $data.openIndex && index < $data.openIndex + $data.maxOpenSize]
]);
}), 256)),
vue.withDirectives(vue.createElementVNode("div", {
class: "ddei-core-panel-bottom-pages-movebox",
onClick: _cache[3] || (_cache[3] = ($event) => $options.moveItem(-1))
}, _cache[8] || (_cache[8] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-left" })
], -1)
]), 512), [
[vue.vShow, ((_k = (_j = (_i = $props.editor) == null ? void 0 : _i.files[(_h = $props.editor) == null ? void 0 : _h.currentFileIndex]) == null ? void 0 : _j.sheets) == null ? void 0 : _k.length) > $data.maxOpenSize]
]),
vue.withDirectives(vue.createElementVNode("div", {
class: "ddei-core-panel-bottom-pages-movebox",
onClick: _cache[4] || (_cache[4] = ($event) => $options.moveItem(1))
}, _cache[9] || (_cache[9] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-right" })
], -1)
]), 512), [
[vue.vShow, ((_o = (_n = (_m = $props.editor) == null ? void 0 : _m.files[(_l = $props.editor) == null ? void 0 : _l.currentFileIndex]) == null ? void 0 : _n.sheets) == null ? void 0 : _o.length) > $data.maxOpenSize]
])
], 544)
], 64);
}
const Sheets = /* @__PURE__ */ _export_sfc(_sfc_main$X, [["render", _sfc_render$X], ["__scopeId", "data-v-d059d47d"]]);
const _DDeiCoreSheetsPanel = class _DDeiCoreSheetsPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", Sheets.name);
__publicField3(this, "plugins", [Sheets]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[Sheets.name]) {
for (let i2 in options[Sheets.name]) {
newOptions[i2] = options[Sheets.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreSheetsPanel(newOptions);
return panels;
}
}
return _DDeiCoreSheetsPanel;
}
static modify(fn) {
return _DDeiCoreSheetsPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSheetsPanel, "defaultIns", new _DDeiCoreSheetsPanel(null));
let DDeiCoreSheetsPanel = _DDeiCoreSheetsPanel;
const _DDeiCoreBottomPanels = class _DDeiCoreBottomPanels extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [
DDeiCoreShapeCountPanel,
DDeiCoreManageLayersPanel,
DDeiCorePlayPanel,
DDeiCoreSuitRatioPanel,
DDeiCoreChangeRatioPanel,
DDeiCoreSheetsPanel
]);
}
getPanels(editor) {
var _a3;
let panels = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getPanels(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getPanels(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
panels = panels.concat(ls);
}
});
return panels;
}
static configuration(options) {
var _a3;
if (options) {
let panels = new _DDeiCoreBottomPanels(options);
for (let i2 = 0; i2 < ((_a3 = panels.plugins) == null ? void 0 : _a3.length); i2++) {
panels.plugins[i2] = panels.plugins[i2].configuration(options, true);
}
return panels;
}
return _DDeiCoreBottomPanels;
}
static modify(fn) {
return _DDeiCoreBottomPanels.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreBottomPanels, "defaultIns", new _DDeiCoreBottomPanels(null));
let DDeiCoreBottomPanels = _DDeiCoreBottomPanels;
const _sfc_main$W = {
name: "ddei-core-panel-toolbox-simple",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
groups: null,
forceRefresh: true,
forceRefreshGroup: true
};
},
computed: {},
watch: {},
created() {
},
mounted() {
let middleCanvas = document.getElementById(this.editor.id + "_canvas");
const resizeObserver = new ResizeObserver((entries) => {
for (const entry of entries) {
const { width, height } = entry.contentRect;
if (width != 0 && height != 0) {
this.width = width;
this.height = height;
this.resetPosition(width, height);
}
}
});
resizeObserver.observe(middleCanvas);
this.refreshData();
},
methods: {
resetPosition(width, height) {
var _a3, _b2, _c2, _d2, _e2, _f, _g;
if (((_a3 = this.options) == null ? void 0 : _a3.direct) == 2) {
this.$refs["toolbox"].style.maxWidth = width - 80 + "px";
this.$refs["toolbox"].style.flexDirection = "";
if ((_b2 = this.options) == null ? void 0 : _b2.width) {
this.$refs["toolbox"].style.width = this.options.width;
} else {
this.$refs["toolbox"].style.width = "";
}
if ((_c2 = this.options) == null ? void 0 : _c2.height) {
this.$refs["toolbox"].style.height = this.options.height;
} else {
this.$refs["toolbox"].style.height = "40px";
}
} else {
this.$refs["toolbox"].style.flexDirection = "column";
this.$refs["toolbox"].style.maxHeight = height - 80 + "px";
if ((_d2 = this.options) == null ? void 0 : _d2.width) {
this.$refs["toolbox"].style.width = this.options.width;
} else {
this.$refs["toolbox"].style.width = "40px";
}
if ((_e2 = this.options) == null ? void 0 : _e2.height) {
this.$refs["toolbox"].style.height = this.options.height;
} else {
this.$refs["toolbox"].style.height = "";
}
}
let cachePos = null;
if (((_f = this.options) == null ? void 0 : _f.drag) == 1) {
cachePos = localStorage.getItem("pos-" + this.editor.id + "-ddei-core-panel-toolbox-simple");
}
if (!cachePos) {
switch ((_g = this.options) == null ? void 0 : _g.position) {
case 2:
this.$refs["toolbox"].style.left = (width - this.$refs["toolbox"].clientWidth) / 2 + "px";
this.$refs["toolbox"].style.top = "30px";
break;
case 3:
this.$refs["toolbox"].style.left = width - this.$refs["toolbox"].clientWidth - 30 + "px";
this.$refs["toolbox"].style.top = "30px";
break;
case 4:
this.$refs["toolbox"].style.left = width - this.$refs["toolbox"].clientWidth - 30 + "px";
this.$refs["toolbox"].style.top = (height - this.$refs["toolbox"].clientHeight) / 2 + "px";
break;
case 5:
this.$refs["toolbox"].style.left = width - this.$refs["toolbox"].clientWidth - 30 + "px";
this.$refs["toolbox"].style.top = height - this.$refs["toolbox"].clientHeight - 30 + "px";
break;
case 6:
this.$refs["toolbox"].style.left = (width - this.$refs["toolbox"].clientWidth) / 2 + "px";
this.$refs["toolbox"].style.top = height - this.$refs["toolbox"].clientHeight - 30 + "px";
break;
case 7:
this.$refs["toolbox"].style.left = "30px";
this.$refs["toolbox"].style.top = height - this.$refs["toolbox"].clientHeight - 30 + "px";
break;
case 8:
this.$refs["toolbox"].style.left = "30px";
this.$refs["toolbox"].style.top = (height - this.$refs["toolbox"].clientHeight) / 2 + "px";
break;
case 9:
this.$refs["toolbox"].style.left = (width - this.$refs["toolbox"].clientWidth) / 2 + "px";
this.$refs["toolbox"].style.top = (height - this.$refs["toolbox"].clientHeight) / 2 + "px";
break;
default:
this.$refs["toolbox"].style.left = "30px";
this.$refs["toolbox"].style.top = "30px";
break;
}
} else {
let posJson = JSON.parse(cachePos);
this.$refs["toolbox"].style.left = posJson.left + "px";
this.$refs["toolbox"].style.top = posJson.top + "px";
}
this.$refs["toolbox"].style.display = "flex";
},
refreshData() {
var _a3, _b2, _c2;
this.editor.needControlIcon = true;
this.editor.toolBarViewer = this;
if (this.editor.ddInstance && !this.editor.ddInstance.render) {
this.editor.ddInstance.initRender();
}
if (!this.groups) {
let groups = [];
for (let i2 = 0; i2 < ((_b2 = (_a3 = this.options) == null ? void 0 : _a3.groups) == null ? void 0 : _b2.length); i2++) {
let group2 = clone(this.options.groups[i2]);
let controls2 = [];
(_c2 = group2.controls) == null ? void 0 : _c2.forEach((controlid) => {
let control = this.editor.controls.get(controlid);
if (control) {
controls2.push(control);
}
});
if (controls2.length > 0) {
group2.controls = controls2;
}
groups.push(group2);
}
this.groups = groups;
}
},
//强制刷新当前以及下层组件
forceRefreshParts(parts) {
if (!parts || parts == "toolbox" || parts.indexOf("toolbox") != -1) {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.$nextTick(() => {
this.resetPosition(this.width, this.height);
});
}
});
}
},
changeEditMode(editMode) {
if (!editMode) {
this.editor.bus.push(DDeiEditorEnumBusCommandType.ChangeEditMode, {
mode: 1
});
} else {
this.editor.bus.push(DDeiEditorEnumBusCommandType.ChangeEditMode, {
mode: editMode
});
}
this.editor.bus.executeAll();
return true;
},
/**
* 准备创建
*/
createControlPrepare(group2, e) {
var _a3, _b2, _c2, _d2, _e2, _f;
let control = group2.currentControl ? group2.currentControl : ((_a3 = group2.controls) == null ? void 0 : _a3.length) > 0 ? group2.controls[0] : null;
let editMode = group2.editMode;
let ddInstance = this.editor.ddInstance;
ddInstance.render.inEdge = 0;
let stage2 = ddInstance.stage;
let layer2 = stage2.layers[stage2.layerIndex];
if (layer2.display == 0 && !layer2.tempDisplay || layer2.lock) {
return;
}
if (control) {
if (editMode != 4) {
let controlInitJSON = DDeiEditorUtil.getModelInitJSON(this.editor.ddInstance, null, [control]);
if (!controlInitJSON) {
return;
}
let models = DDeiEditorUtil.createControl(controlInitJSON[0], this.editor);
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_CREATE_BEFORE", DDeiEnumOperateType.CREATE, { models }, ddInstance, e);
if (rsState == 0 || rsState == 1) {
DDeiUtil.invokeCallbackFunc("EVENT_MOUSE_OPERATING", DDeiEnumOperateType.CREATE, null, ddInstance, e);
let stageRatio2 = stage2.getStageRatio();
let moveMatrix2 = new Matrix3(
1,
0,
-stage2.wpv.x * stageRatio2,
0,
1,
-stage2.wpv.y * stageRatio2,
0,
0,
1
);
models.forEach((model) => {
model.transVectors(moveMatrix2);
model.setState(DDeiEnumControlState.CREATING);
});
if ((models == null ? void 0 : models.length) > 0) {
let ddInstance2 = this.editor.ddInstance;
let stage22 = ddInstance2.stage;
if (((_b2 = stage22 == null ? void 0 : stage22.render) == null ? void 0 : _b2.operateState) == DDeiEnumOperateState.QUICK_EDITING && ((_c2 = stage22 == null ? void 0 : stage22.render) == null ? void 0 : _c2.editorShadowControl)) {
(_d2 = DDeiUtil.getEditorText()) == null ? void 0 : _d2.enterValue();
}
this.editor.changeState(DDeiEditorState.CONTROL_CREATING);
this.editor.creatingControls = models;
(_e2 = this.editor.bus) == null ? void 0 : _e2.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
(_f = this.editor.bus) == null ? void 0 : _f.executeAll();
}
e.preventDefault();
e.cancelBubble = true;
}
} else {
DDeiEditorUtil.lineInitJSON = {
modelCode: control.id
};
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
DDeiEditorUtil.hiddenDialog(this.editor, "ddei-core-dialog-choosecontrol");
},
/**
* 显示组控件列表
* @param group 组
* @param e
*/
showGroupControlBox(group2, evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x;
DDeiEditorUtil.hiddenDialog(this.editor, "ddei-core-dialog-choosecontrol");
if (this.editor.state != DDeiEditorState.CONTROL_CREATING) {
if (((_a3 = group2.controls) == null ? void 0 : _a3.length) > 1) {
let el = evt.srcElement;
let type = 99;
if (((_b2 = this.options) == null ? void 0 : _b2.direct) == 2) {
if (((_c2 = this.options) == null ? void 0 : _c2.position) == 1 || ((_d2 = this.options) == null ? void 0 : _d2.position) == 2 || ((_e2 = this.options) == null ? void 0 : _e2.position) == 3 || ((_f = this.options) == null ? void 0 : _f.position) == 4 || ((_g = this.options) == null ? void 0 : _g.position) == 8 || ((_h = this.options) == null ? void 0 : _h.position) == 9 || !((_i = this.options) == null ? void 0 : _i.position)) {
type = 5;
} else if (((_j = this.options) == null ? void 0 : _j.position) == 5 || ((_k = this.options) == null ? void 0 : _k.position) == 6 || ((_l = this.options) == null ? void 0 : _l.position) == 7) {
type = 3;
}
} else if (((_m = this.options) == null ? void 0 : _m.direct) == 1) {
if (((_n = this.options) == null ? void 0 : _n.position) == 1 || ((_o = this.options) == null ? void 0 : _o.position) == 7 || ((_p = this.options) == null ? void 0 : _p.position) == 8 || ((_q = this.options) == null ? void 0 : _q.position) == 2 || ((_r = this.options) == null ? void 0 : _r.position) == 6 || !((_s = this.options) == null ? void 0 : _s.position) || ((_t = this.options) == null ? void 0 : _t.position) == 9) {
type = 9;
} else if (((_u = this.options) == null ? void 0 : _u.position) == 3 || ((_v = this.options) == null ? void 0 : _v.position) == 4 || ((_w = this.options) == null ? void 0 : _w.position) == 5) {
type = 7;
}
}
DDeiEditorUtil.showDialog(this.editor, "ddei-core-dialog-choosecontrol", {
controlGroup: group2,
callback: {
ok: this.changeGroupControl,
drag: ((_x = this.options) == null ? void 0 : _x.dragCreate) == 1 ? this.dragCreateControlPrepare : null
}
}, { type, hiddenMask: true }, el, true, true);
}
}
},
changeGroupControl(group2, control, evt) {
var _a3;
this.changeEditMode(group2 == null ? void 0 : group2.editMode);
if ((group2 == null ? void 0 : group2.editMode) == 4) {
DDeiEditorUtil.lineInitJSON = {
modelCode: control.id
};
}
group2.currentControl = control;
if ((_a3 = this.options) == null ? void 0 : _a3.chooseCreate) {
this.createControlCenter(group2);
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-choosecontrol");
this.forceRefreshGroup = false;
this.$nextTick(() => {
this.forceRefreshGroup = true;
});
},
dragCreateControlPrepare(group2, control, evt) {
var _a3;
this.changeEditMode(group2 == null ? void 0 : group2.editMode);
group2.currentControl = control;
if ((_a3 = this.options) == null ? void 0 : _a3.dragCreate) {
this.createControlPrepare(group2, evt);
}
this.forceRefreshGroup = false;
this.$nextTick(() => {
this.forceRefreshGroup = true;
});
},
/**
* 准备拖拽
*/
prepareDragBox(e) {
this.editor.dragPart = this;
this.$refs["toolbox"].style.userSelect = "none";
this.$refs["toolbox"].children[0].style.backgroundColor = "var(--dot)";
this.$refs["toolbox"].style.pointerEvents = "none";
},
/**
* 拖拽中
*/
boxDraging(e) {
var _a3;
if (this.editor.dragPart) {
let middleCanvas = document.getElementById(this.editor.id + "_canvas");
let posLeft = e.offsetX - 15;
let posTop = e.offsetY - 5;
if (((_a3 = this.options) == null ? void 0 : _a3.direct) == 2) {
posLeft = e.offsetX - 5;
posTop = e.offsetY - 15;
}
if (posLeft < 0) {
posLeft = 0;
}
if (posLeft < 0) {
posTop = 0;
}
if (posLeft + this.$refs["toolbox"].offsetWidth > middleCanvas.offsetWidth) {
posLeft = middleCanvas.offsetWidth - this.$refs["toolbox"].offsetWidth;
}
if (posTop + this.$refs["toolbox"].offsetHeight > middleCanvas.offsetHeight) {
posTop = middleCanvas.offsetHeight - this.$refs["toolbox"].offsetHeight;
}
this.$refs["toolbox"].style.left = posLeft + "px";
this.$refs["toolbox"].style.top = posTop + "px";
}
},
/**
* 拖拽完毕
*/
boxDragEnd(e) {
if (this.editor.dragPart) {
let posJson = { left: this.$refs["toolbox"].offsetLeft, top: this.$refs["toolbox"].offsetTop };
localStorage.setItem("pos-" + this.editor.id + "-ddei-core-panel-toolbox-simple", JSON.stringify(posJson));
this.$refs["toolbox"].style.userSelect = "";
this.$refs["toolbox"].style.pointerEvents = "";
this.$refs["toolbox"].children[0].style.backgroundColor = "";
delete this.editor.dragPart;
}
},
/**
* 创建控件在中心点处
*/
createControlCenter(group2, e) {
var _a3, _b2, _c2, _d2, _e2, _f, _g;
if ((group2 == null ? void 0 : group2.editMode) != 4) {
let control = group2.currentControl ? group2.currentControl : ((_a3 = group2.controls) == null ? void 0 : _a3.length) > 0 ? group2.controls[0] : null;
this.editor.changeState(DDeiEditorState.DESIGNING);
this.editor.creatingControls = null;
if (control) {
let ddInstance = this.editor.ddInstance;
ddInstance.render.inEdge = 0;
let stage2 = ddInstance.stage;
let layer2 = stage2.layers[stage2.layerIndex];
if (layer2.display == 0 && !layer2.tempDisplay || layer2.lock) {
return;
}
let controlInitJSON = DDeiEditorUtil.getModelInitJSON(this.editor.ddInstance, null, [{ model: control.id }]);
if (controlInitJSON) {
let models = this.editor.addControls(controlInitJSON);
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_CREATE_BEFORE", DDeiEnumOperateType.CREATE, { models }, ddInstance, e);
if (rsState == 0 || rsState == 1) {
let pushDatas = [];
models.forEach((model, key) => {
pushDatas.push({ id: model.id, value: DDeiEnumControlState.SELECTED });
});
(_c2 = (_b2 = this.editor.ddInstance) == null ? void 0 : _b2.bus) == null ? void 0 : _c2.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, null, e);
(_e2 = (_d2 = this.editor.ddInstance) == null ? void 0 : _d2.bus) == null ? void 0 : _e2.push(DDeiEnumBusCommandType.ModelChangeSelect, pushDatas, e);
(_g = (_f = this.editor.ddInstance) == null ? void 0 : _f.bus) == null ? void 0 : _g.push(DDeiEnumBusCommandType.StageChangeSelectModels);
this.editor.bus.executeAll();
this.editor.changeState(DDeiEditorState.DESIGNING);
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_CREATE_AFTER", DDeiEnumOperateType.CREATE, { models }, ddInstance, e);
}
}
}
}
},
/**
* 焦点进入当前区域
*/
changeEditorFocus() {
this.editor.changeState(DDeiEditorState.TOOLBOX_ACTIVE);
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.executeAll();
}
}
};
const ToolboxSimple_vue_vue_type_style_index_0_scoped_bd214554_lang = "";
const _hoisted_1$W = ["title", "onMouseenter", "onMousedown", "onClick"];
const _hoisted_2$G = ["innerHTML"];
const _hoisted_3$D = ["src"];
const _hoisted_4$t = ["innerHTML"];
function _sfc_render$W(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2;
return $data.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
onMousedown: _cache[1] || (_cache[1] = (...args) => $options.changeEditorFocus && $options.changeEditorFocus(...args)),
ref: "toolbox",
class: "ddei-core-panel-toolbox-simple"
}, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item-drag": ((_a3 = $props.options) == null ? void 0 : _a3.drag) == 1 && ((_b2 = $props.options) == null ? void 0 : _b2.direct) != 2, "item-drag-2": ((_c2 = $props.options) == null ? void 0 : _c2.drag) == 1 && ((_d2 = $props.options) == null ? void 0 : _d2.direct) == 2, "item-block": ((_e2 = $props.options) == null ? void 0 : _e2.drag) != 1 }),
onMousedown: _cache[0] || (_cache[0] = ($event) => {
var _a4;
return ((_a4 = $props.options) == null ? void 0 : _a4.drag) == 1 && $options.prepareDragBox();
})
}, null, 34),
$data.forceRefreshGroup ? (vue.openBlock(true), vue.createElementBlock(vue.Fragment, { key: 0 }, vue.renderList($data.groups, (group2) => {
var _a4, _b3, _c3, _d3, _e3, _f, _g, _h, _i, _j, _k;
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "item": true, "item-selected": group2.editMode == $props.editor.editMode }),
title: ((_a4 = group2.currentControl) == null ? void 0 : _a4.desc) ? group2.currentControl.desc : ((_b3 = group2.controls) == null ? void 0 : _b3.length) > 0 && ((_c3 = group2.controls[0]) == null ? void 0 : _c3.desc) ? group2.controls[0].desc : group2.desc ? group2.desc : "",
onMouseenter: ($event) => $options.showGroupControlBox(group2, $event),
onMousedown: ($event) => $options.changeEditMode(group2 == null ? void 0 : group2.editMode) && $options.createControlPrepare(group2, $event),
onClick: ($event) => {
var _a5;
return ((_a5 = group2.controls) == null ? void 0 : _a5.length) > 0 && $options.changeEditMode(group2 == null ? void 0 : group2.editMode) && $options.createControlCenter(group2, $event);
}
}, [
(group2 == null ? void 0 : group2.editMode) == 1 || (group2 == null ? void 0 : group2.editMode) == 2 ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
innerHTML: group2.icon
}, null, 8, _hoisted_2$G)) : vue.createCommentVNode("", true),
group2.currentControl && !group2.currentControl.icon || !group2.currentControl && ((_d3 = group2.controls) == null ? void 0 : _d3.length) > 0 && !((_e3 = group2.controls[0]) == null ? void 0 : _e3.icon) ? (vue.openBlock(), vue.createElementBlock("img", {
key: 1,
class: "icon",
src: (_f = $props.editor) == null ? void 0 : _f.icons[group2.currentControl ? group2.currentControl.id : group2.controls[0].id]
}, null, 8, _hoisted_3$D)) : vue.createCommentVNode("", true),
group2.currentControl && group2.currentControl.icon || !group2.currentControl && ((_g = group2.controls) == null ? void 0 : _g.length) > 0 && ((_h = group2.controls[0]) == null ? void 0 : _h.icon) ? (vue.openBlock(), vue.createElementBlock("div", {
key: 2,
class: "item-icon-html",
innerHTML: ((_i = group2.currentControl) == null ? void 0 : _i.icon) ? group2.currentControl.icon : ((_j = group2.controls) == null ? void 0 : _j.length) > 0 ? (_k = group2.controls[0]) == null ? void 0 : _k.icon : ""
}, null, 8, _hoisted_4$t)) : vue.createCommentVNode("", true)
], 42, _hoisted_1$W);
}), 256)) : vue.createCommentVNode("", true),
_cache[2] || (_cache[2] = vue.createElementVNode("div", { class: "item-block" }, null, -1))
], 544)) : vue.createCommentVNode("", true);
}
const ToolboxSimple = /* @__PURE__ */ _export_sfc(_sfc_main$W, [["render", _sfc_render$W], ["__scopeId", "data-v-bd214554"]]);
const _DDeiCoreToolboxSimplePanel = class _DDeiCoreToolboxSimplePanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", ToolboxSimple.name);
__publicField3(this, "plugins", [ToolboxSimple]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ToolboxSimple.name]) {
for (let i2 in options[ToolboxSimple.name]) {
newOptions[i2] = options[ToolboxSimple.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreToolboxSimplePanel(newOptions);
return panels;
}
}
return _DDeiCoreToolboxSimplePanel;
}
static modify(fn) {
return _DDeiCoreToolboxSimplePanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreToolboxSimplePanel, "defaultIns", new _DDeiCoreToolboxSimplePanel({
direct: 1,
//方向,1纵向,2横向
position: 8,
//位置1-9顺时针,1为左上角,9为中心
drag: 1,
//是否允许拖拽位置
chooseCreate: 0,
//是否在选择控件时创建一个控件
dragCreate: 0,
//是否在拖拽时创建控件
groups: [
{
editMode: 1,
desc: "选择",
icon: ``
},
{
editMode: 2,
desc: "平移画布",
icon: ``
},
{
controls: [
"100103"
]
},
{
controls: [
"100001",
"100002",
"100003",
"100004",
"100005",
"100006",
"100007"
]
},
{
controls: [
"100040",
"100041",
"100050",
"100051"
]
},
{
editMode: 4,
desc: "连线",
controls: [
"100401"
]
}
]
}));
let DDeiCoreToolboxSimplePanel = _DDeiCoreToolboxSimplePanel;
const _sfc_main$V = {
name: "ddei-core-panel-topmenu-simple",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
forceRefresh: true
};
},
computed: {},
watch: {},
created() {
},
mounted() {
let middleCanvas = document.getElementById(this.editor.id + "_canvas");
const resizeObserver = new ResizeObserver((entries) => {
for (const entry of entries) {
const { width, height } = entry.contentRect;
if (width != 0 && height != 0) {
this.width = width;
this.height = height;
this.resetPosition(width, height);
}
}
});
resizeObserver.observe(middleCanvas);
this.refreshData();
},
methods: {
internalAction(id, evt) {
if (id == "ddei-core-save") {
this.save(evt);
} else if (id == "ddei-core-open") {
this.openFile(evt);
} else if (id == "ddei-core-new") {
this.newFile(evt);
} else if (id == "ddei-core-download") {
this.download(evt);
}
},
/**
* 保存
* @param evt
*/
save(evt) {
this.editor.changeState(DDeiEditorState.DESIGNING);
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.push(DDeiEditorEnumBusCommandType.SaveFile, {}, evt);
this.editor.bus.executeAll();
},
/**
* 下载文件
*/
download(evt) {
var _a3, _b2, _c2, _d2;
if ((_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) {
let file = (_d2 = this.editor) == null ? void 0 : _d2.files[(_c2 = this.editor) == null ? void 0 : _c2.currentFileIndex];
if (file) {
let json = file.toJSON();
if (json) {
let eleLink = document.createElement("a");
eleLink.download = file.name + ".dei";
eleLink.style.display = "none";
let blob = new Blob([JSON.stringify(json)]);
eleLink.href = URL.createObjectURL(blob);
document.body.appendChild(eleLink);
eleLink.click();
document.body.removeChild(eleLink);
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
}
},
/**
* 打开文件
* @param evt
*/
async openFile(evt) {
let rsState = DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_FILE_BEFORE", "LOAD_FILE", null, this.editor.ddInstance, evt);
if (rsState != -1) {
let openFileHandle = await showOpenFilePicker({
description: "DDei Design File",
types: [{
accept: {
"text/plain": [".dei"]
}
}]
});
let openFile = await openFileHandle[0].getFile();
let read = new FileReader();
read.readAsText(openFile);
read.onload = async () => {
var _a3, _b2, _c2, _d2, _e2;
let result = read.result;
let resultJSON = JSON.parse(result);
let ddInstance = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance;
let file = DDeiFile.loadFromJSON(resultJSON, {
currentDdInstance: ddInstance
});
let openedFiles = this.editor.files;
let openedFileIndex = -1;
if (!file.id) {
file.id = DDeiUtil.getUniqueCode();
}
for (let fi = 0; fi < openedFiles.length; fi++) {
if (openedFiles[fi].id && openedFiles[fi].id == file.id) {
openedFileIndex = fi;
break;
}
}
ddInstance.stage.destroyRender();
if (openedFileIndex == -1) {
file.localFileHandler = openFileHandle[0];
file.local = 1;
this.editor.addFile(file);
for (let x2 = 0; x2 < this.editor.files.length; x2++) {
this.editor.files[x2].active = DDeiActiveType.NONE;
}
this.editor.currentFileIndex = this.editor.files.length - 1;
file.state = DDeiFileState.NONE;
file.active = DDeiActiveType.ACTIVE;
let sheets = file == null ? void 0 : file.sheets;
if (file && sheets && ddInstance) {
file.changeSheet(file.currentSheetIndex);
let stage2 = sheets[file.currentSheetIndex].stage;
stage2.ddInstance = ddInstance;
ddInstance.disabled = false;
file.initHistroy();
file.histroy[0].isNew = true;
ddInstance.stage = stage2;
stage2.initRender();
if (!stage2.wpv) {
stage2.wpv = {
x: -(stage2.width - ddInstance.render.container.clientWidth) / 2,
y: -(stage2.height - ddInstance.render.container.clientHeight) / 2,
z: 0
};
}
this.editor.changeState(DDeiEditorState.DESIGNING);
ddInstance.bus.push(
DDeiEditorEnumBusCommandType.ClearTemplateUI
);
ddInstance.bus.push(
DDeiEditorEnumBusCommandType.RefreshEditorParts,
{ parts: ["bottommenu", "topmenu"] }
);
(_b2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _b2.push(DDeiEnumBusCommandType.RefreshShape);
(_c2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _c2.executeAll();
}
} else {
file = this.editor.files[openedFileIndex];
if (file && ddInstance) {
for (let x2 = 0; x2 < this.editor.files.length; x2++) {
this.editor.files[x2].active = DDeiActiveType.NONE;
}
file.active = DDeiActiveType.ACTIVE;
this.editor.currentFileIndex = openedFileIndex;
let stage2 = file.sheets[file.currentSheetIndex].stage;
stage2.ddInstance = ddInstance;
ddInstance.stage = stage2;
ddInstance.disabled = false;
stage2.initRender();
this.editor.changeState(DDeiEditorState.DESIGNING);
ddInstance.bus.push(
DDeiEditorEnumBusCommandType.ClearTemplateUI
);
ddInstance.bus.push(
DDeiEditorEnumBusCommandType.RefreshEditorParts,
{ parts: ["bottommenu", "topmenu"] }
);
(_d2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _d2.push(DDeiEnumBusCommandType.RefreshShape);
(_e2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _e2.executeAll();
}
}
DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_FILE_AFTER", "LOAD_FILE", { file }, this.editor.ddInstance, evt);
};
}
},
/**
* 新建文件
* @param evt
*/
newFile(evt) {
var _a3, _b2;
if ((_a3 = this.editor) == null ? void 0 : _a3.ddInstance) {
let ddInstance = this.editor.ddInstance;
let file = DDeiFile.loadFromJSON(
{
name: "新建文件_NEW",
path: "/新建文件_NEW",
sheets: [
new DDeiSheet({
name: "页面-1",
desc: "页面-1",
stage: DDeiStage.initByJSON({ id: "stage_1" }, { currentDdInstance: ddInstance }),
active: DDeiActiveType.ACTIVE
})
],
currentSheetIndex: 0,
state: DDeiFileState.NEW,
active: DDeiActiveType.ACTIVE
},
{ currentDdInstance: ddInstance }
);
if (this.editor.currentFileIndex != -1) {
this.editor.files[this.editor.currentFileIndex].active = DDeiActiveType.NONE;
}
this.editor.addFile(file);
this.editor.currentFileIndex = this.editor.files.length - 1;
let sheets = file == null ? void 0 : file.sheets;
if (file && sheets && ddInstance) {
ddInstance.stage.destroyRender();
let stage2 = sheets[0].stage;
stage2.ddInstance = ddInstance;
ddInstance.stage = stage2;
file.initHistroy();
if (!stage2.wpv) {
stage2.wpv = {
x: -(stage2.width - ddInstance.render.container.clientWidth) / 2,
y: -(stage2.height - ddInstance.render.container.clientHeight) / 2,
z: 0
};
}
stage2.initRender();
ddInstance.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["bottommenu", "topmenu"]
});
this.editor.changeState(DDeiEditorState.DESIGNING);
(_b2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _b2.executeAll();
}
}
},
resetPosition(width, height) {
var _a3, _b2, _c2, _d2, _e2, _f, _g;
if (((_a3 = this.options) == null ? void 0 : _a3.direct) == 2) {
this.$refs["topmenu"].style.maxWidth = width - 80 + "px";
this.$refs["topmenu"].style.flexDirection = "";
if ((_b2 = this.options) == null ? void 0 : _b2.width) {
this.$refs["topmenu"].style.width = this.options.width;
} else {
this.$refs["topmenu"].style.width = "";
}
if ((_c2 = this.options) == null ? void 0 : _c2.height) {
this.$refs["topmenu"].style.height = this.options.height;
} else {
this.$refs["topmenu"].style.height = "32px";
}
} else {
this.$refs["topmenu"].style.flexDirection = "column";
this.$refs["topmenu"].style.maxHeight = height - 80 + "px";
if ((_d2 = this.options) == null ? void 0 : _d2.width) {
this.$refs["topmenu"].style.width = this.options.width;
} else {
this.$refs["topmenu"].style.width = "32px";
}
if ((_e2 = this.options) == null ? void 0 : _e2.height) {
this.$refs["topmenu"].style.height = this.options.height;
} else {
this.$refs["topmenu"].style.height = "";
}
}
let cachePos = null;
if (((_f = this.options) == null ? void 0 : _f.drag) == 1) {
cachePos = localStorage.getItem("pos-" + this.editor.id + "-ddei-core-panel-topmenu-simple");
}
if (!cachePos) {
switch ((_g = this.options) == null ? void 0 : _g.position) {
case 2:
this.$refs["topmenu"].style.left = (width - this.$refs["topmenu"].clientWidth) / 2 + "px";
this.$refs["topmenu"].style.top = "30px";
break;
case 3:
this.$refs["topmenu"].style.left = width - this.$refs["topmenu"].clientWidth - 30 + "px";
this.$refs["topmenu"].style.top = "30px";
break;
case 4:
this.$refs["topmenu"].style.left = width - this.$refs["topmenu"].clientWidth - 30 + "px";
this.$refs["topmenu"].style.top = (height - this.$refs["topmenu"].clientHeight) / 2 + "px";
break;
case 5:
this.$refs["topmenu"].style.left = width - this.$refs["topmenu"].clientWidth - 30 + "px";
this.$refs["topmenu"].style.top = height - this.$refs["topmenu"].clientHeight - 30 + "px";
break;
case 6:
this.$refs["topmenu"].style.left = (width - this.$refs["topmenu"].clientWidth) / 2 + "px";
this.$refs["topmenu"].style.top = height - this.$refs["topmenu"].clientHeight - 30 + "px";
break;
case 7:
this.$refs["topmenu"].style.left = "30px";
this.$refs["topmenu"].style.top = height - this.$refs["topmenu"].clientHeight - 30 + "px";
break;
case 8:
this.$refs["topmenu"].style.left = "30px";
this.$refs["topmenu"].style.top = (height - this.$refs["topmenu"].clientHeight) / 2 + "px";
break;
case 9:
this.$refs["topmenu"].style.left = (width - this.$refs["topmenu"].clientWidth) / 2 + "px";
this.$refs["topmenu"].style.top = (height - this.$refs["topmenu"].clientHeight) / 2 + "px";
break;
default:
this.$refs["topmenu"].style.left = "30px";
this.$refs["topmenu"].style.top = "30px";
break;
}
} else {
let posJson = JSON.parse(cachePos);
this.$refs["topmenu"].style.left = posJson.left + "px";
this.$refs["topmenu"].style.top = posJson.top + "px";
}
this.$refs["topmenu"].style.display = "flex";
},
refreshData() {
},
//强制刷新当前以及下层组件
forceRefreshParts(parts) {
if (!parts || parts == "topmenu" || parts.indexOf("topmenu") != -1) {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
this.$nextTick(() => {
this.resetPosition(this.width, this.height);
});
}
});
}
},
/**
* 准备拖拽
*/
prepareDragBox(e) {
this.editor.dragPart = this;
this.$refs["topmenu"].style.userSelect = "none";
this.$refs["topmenu"].children[0].style.backgroundColor = "var(--dot)";
this.$refs["topmenu"].style.pointerEvents = "none";
},
/**
* 拖拽中
*/
boxDraging(e) {
var _a3;
if (this.editor.dragPart) {
let middleCanvas = document.getElementById(this.editor.id + "_canvas");
let posLeft = e.offsetX - 15;
let posTop = e.offsetY - 5;
if (((_a3 = this.options) == null ? void 0 : _a3.direct) == 2) {
posLeft = e.offsetX - 5;
posTop = e.offsetY - 15;
}
if (posLeft < 0) {
posLeft = 0;
}
if (posLeft < 0) {
posTop = 0;
}
if (posLeft + this.$refs["topmenu"].offsetWidth > middleCanvas.offsetWidth) {
posLeft = middleCanvas.offsetWidth - this.$refs["topmenu"].offsetWidth;
}
if (posTop + this.$refs["topmenu"].offsetHeight > middleCanvas.offsetHeight) {
posTop = middleCanvas.offsetHeight - this.$refs["topmenu"].offsetHeight;
}
this.$refs["topmenu"].style.left = posLeft + "px";
this.$refs["topmenu"].style.top = posTop + "px";
}
},
/**
* 拖拽完毕
*/
boxDragEnd(e) {
if (this.editor.dragPart) {
let posJson = { left: this.$refs["topmenu"].offsetLeft, top: this.$refs["topmenu"].offsetTop };
localStorage.setItem("pos-" + this.editor.id + "-ddei-core-panel-topmenu-simple", JSON.stringify(posJson));
this.$refs["topmenu"].style.userSelect = "";
this.$refs["topmenu"].style.pointerEvents = "";
this.$refs["topmenu"].children[0].style.backgroundColor = "";
delete this.editor.dragPart;
}
},
/**
* 焦点进入当前区域
*/
changeEditorFocus() {
this.editor.changeState(DDeiEditorState.TOP_MENU_OPERATING);
this.editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
this.editor.bus.executeAll();
}
}
};
const TopMenuSimple_vue_vue_type_style_index_0_scoped_52f75ccc_lang = "";
const _hoisted_1$V = { class: "item" };
const _hoisted_2$F = ["onClick"];
const _hoisted_3$C = ["onClick"];
function _sfc_render$V(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j;
return $data.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
onMousedown: _cache[5] || (_cache[5] = (...args) => $options.changeEditorFocus && $options.changeEditorFocus(...args)),
ref: "topmenu",
class: "ddei-core-panel-topmenu-simple"
}, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item-drag": ((_a3 = $props.options) == null ? void 0 : _a3.drag) == 1 && ((_b2 = $props.options) == null ? void 0 : _b2.direct) != 2, "item-drag-2": ((_c2 = $props.options) == null ? void 0 : _c2.drag) == 1 && ((_d2 = $props.options) == null ? void 0 : _d2.direct) == 2, "item-block": ((_e2 = $props.options) == null ? void 0 : _e2.drag) != 1 }),
onMousedown: _cache[0] || (_cache[0] = ($event) => {
var _a4;
return ((_a4 = $props.options) == null ? void 0 : _a4.drag) == 1 && $options.prepareDragBox();
})
}, null, 34),
!((_f = $props.options) == null ? void 0 : _f.items) ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
class: "item",
onClick: _cache[1] || (_cache[1] = (...args) => $options.newFile && $options.newFile(...args))
}, vue.toDisplayString($props.editor.i18n("ddei.new")), 1)) : vue.createCommentVNode("", true),
!((_g = $props.options) == null ? void 0 : _g.items) ? (vue.openBlock(), vue.createElementBlock("div", {
key: 1,
class: "item",
onClick: _cache[2] || (_cache[2] = (...args) => $options.openFile && $options.openFile(...args))
}, vue.toDisplayString($props.editor.i18n("ddei.open")), 1)) : vue.createCommentVNode("", true),
!((_h = $props.options) == null ? void 0 : _h.items) ? (vue.openBlock(), vue.createElementBlock("div", {
key: 2,
class: "item",
onClick: _cache[3] || (_cache[3] = (...args) => $options.save && $options.save(...args))
}, vue.toDisplayString($props.editor.i18n("ddei.save")), 1)) : vue.createCommentVNode("", true),
!((_i = $props.options) == null ? void 0 : _i.items) ? (vue.openBlock(), vue.createElementBlock("div", {
key: 3,
class: "item",
onClick: _cache[4] || (_cache[4] = (...args) => $options.download && $options.download(...args))
}, vue.toDisplayString($props.editor.i18n("ddei.download")), 1)) : vue.createCommentVNode("", true),
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_j = $props.options) == null ? void 0 : _j.items, (menu) => {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$V, [
menu && !menu.viewer && menu.id ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
onClick: ($event) => $options.internalAction(menu.id, $event)
}, vue.toDisplayString($props.editor.i18n(menu.name)), 9, _hoisted_2$F)) : vue.createCommentVNode("", true),
menu && !menu.viewer && !menu.id ? (vue.openBlock(), vue.createElementBlock("div", {
key: 1,
onClick: ($event) => menu.action($props.editor, $event)
}, vue.toDisplayString($props.editor.i18n(menu.name)), 9, _hoisted_3$C)) : vue.createCommentVNode("", true),
menu && menu.viewer ? (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(menu.viewer), {
key: 2,
options: $props.options,
editor: $props.editor
}, null, 8, ["options", "editor"])) : vue.createCommentVNode("", true)
]);
}), 256)),
_cache[6] || (_cache[6] = vue.createElementVNode("div", { class: "item-block" }, null, -1))
], 544)) : vue.createCommentVNode("", true);
}
const TopMenuSimple = /* @__PURE__ */ _export_sfc(_sfc_main$V, [["render", _sfc_render$V], ["__scopeId", "data-v-52f75ccc"]]);
const _DDeiCoreTopMenuSimplePanel = class _DDeiCoreTopMenuSimplePanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", TopMenuSimple.name);
__publicField3(this, "plugins", [TopMenuSimple]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[TopMenuSimple.name]) {
for (let i2 in options[TopMenuSimple.name]) {
newOptions[i2] = options[TopMenuSimple.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreTopMenuSimplePanel(newOptions);
return panels;
}
}
return _DDeiCoreTopMenuSimplePanel;
}
static modify(fn) {
return DDeiCoreToolboxSimplePanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreTopMenuSimplePanel, "defaultIns", new _DDeiCoreTopMenuSimplePanel({
direct: 2,
//方向,1纵向,2横向
position: 2,
//位置1-9顺时针,1为左上角,9为中心
drag: 1
//是否允许拖拽位置
}));
let DDeiCoreTopMenuSimplePanel = _DDeiCoreTopMenuSimplePanel;
const _DDeiCoreSimplePanels = class _DDeiCoreSimplePanels extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [DDeiCoreToolboxSimplePanel, DDeiCoreTopMenuSimplePanel]);
}
getPanels(editor) {
var _a3;
let panels = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getPanels(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getPanels(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
panels = panels.concat(ls);
}
});
return panels;
}
static configuration(options) {
var _a3;
if (options) {
let panels = new _DDeiCoreSimplePanels(options);
for (let i2 = 0; i2 < ((_a3 = panels.plugins) == null ? void 0 : _a3.length); i2++) {
panels.plugins[i2] = panels.plugins[i2].configuration(options, true);
}
return panels;
}
return _DDeiCoreSimplePanels;
}
static modify(fn) {
return _DDeiCoreSimplePanels.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSimplePanels, "defaultIns", new _DDeiCoreSimplePanels(null));
let DDeiCoreSimplePanels = _DDeiCoreSimplePanels;
const _DDeiCorePanels = class _DDeiCorePanels extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [
DDeiCoreTopMenuPanel,
DDeiCoreToolboxPanels,
DDeiCoreQuickColorViewPanel,
DDeiCorePropertyViewPanel,
DDeiCoreOpenFilesViewPanel,
DDeiCoreCanvasViewPanel,
DDeiCoreBottomMenuPanel,
DDeiCoreCommonPanels,
DDeiCoreBottomPanels,
DDeiCoreSimplePanels
]);
}
getPanels(editor) {
var _a3;
let panels = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getPanels(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getPanels(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
panels = panels.concat(ls);
}
});
return panels;
}
static configuration(options) {
var _a3;
if (options) {
let panels = new _DDeiCorePanels(options);
for (let i2 = 0; i2 < ((_a3 = panels.plugins) == null ? void 0 : _a3.length); i2++) {
panels.plugins[i2] = panels.plugins[i2].configuration(options, true);
}
return panels;
}
return _DDeiCorePanels;
}
static modify(fn) {
return _DDeiCorePanels.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCorePanels, "defaultIns", new _DDeiCorePanels(null));
let DDeiCorePanels = _DDeiCorePanels;
const _sfc_main$U = {
name: "ddei-core-btn-addfontsize",
extends: null,
mixins: [],
components: {},
props: {
attrCode: {
type: String,
default: null
},
addValue: {
type: Number,
default: null
},
img: {
type: String,
default: null
},
extcls: {
type: String,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
controlDefine: {
type: Object,
default: null
}
},
data() {
return {
attrDefine: null,
value: 0
};
},
computed: {},
watch: {},
created() {
this.$watch("editor.textEditorSelectedChange", function(newVal, oldVal) {
if (newVal) {
this.refreshEditor();
}
});
},
mounted() {
this.refreshEditor();
},
methods: {
refreshEditor() {
var _a3;
this.value = 0;
if (this.controlDefine) {
let attrD = this.controlDefine.attrDefineMap.get(this.attrCode);
let mds = [];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: attrD == null ? void 0 : attrD.code }, this.editor.ddInstance);
if (rsState != -1) {
this.attrDefine = attrD;
let valueDefine = this.getDataValue();
if (valueDefine) {
this.value = valueDefine.value;
}
}
} else {
this.attrDefine = null;
}
},
//获取数据值
getDataValue() {
var _a3, _b2, _c2;
if (this.attrDefine) {
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let value = shadowControl.getSptStyle(curSIdx, curEIdx, paths);
if (value === void 0) {
value = DDeiModelArrtibuteValue.getAttrValueByState(shadowControl, paths[0], true);
}
return { value };
}
}
}
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(this.attrDefine.model, this.attrDefine.code, this.attrDefine.mapping);
}
if (dataValue) {
return { value: dataValue };
}
}
return { isDefault: true, value: (_c2 = this.attrDefine) == null ? void 0 : _c2.getParser().getDefaultValue() };
},
valueChange(evt) {
var _a3, _b2;
let value = this.value + this.addValue;
this.value = value;
this.attrDefine.value = value;
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(value);
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, parsedValue);
this.editor.bus.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
setTimeout(() => {
editorText.focus();
}, 20);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(DDeiEnumBusCommandType.ModelChangeValue, { mids: [element.id], paths, value: parsedValue }, evt, true);
});
}
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.executeAll();
if (this.editor.state != DDeiEditorState.QUICK_EDITING) {
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
}
};
const QBTEditAddFontSize_vue_vue_type_style_index_0_scoped_4ef00c85_lang = "";
const _hoisted_1$U = ["xlink:href"];
function _sfc_render$U(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-editor-quickifat-item-box": true, "ddei-editor-quickifat-item-box--disabled": !$data.attrDefine }),
onClick: _cache[0] || (_cache[0] = ($event) => $data.attrDefine && $options.valueChange($event))
}, [
(vue.openBlock(), vue.createElementBlock("svg", {
class: vue.normalizeClass("icon " + ($props.extcls ? $props.extcls : "")),
"aria-hidden": "true"
}, [
vue.createElementVNode("use", {
"xlink:href": "#" + $props.img
}, null, 8, _hoisted_1$U)
], 2))
], 2);
}
const QBTEditAddFontSize = /* @__PURE__ */ _export_sfc(_sfc_main$U, [["render", _sfc_render$U], ["__scopeId", "data-v-4ef00c85"]]);
const _DDeiCoreAddFontSizeButton = class _DDeiCoreAddFontSizeButton extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QBTEditAddFontSize.name);
__publicField3(this, "plugins", [QBTEditAddFontSize]);
}
getComponents(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QBTEditAddFontSize.name]) {
for (let i2 in options[QBTEditAddFontSize.name]) {
newOptions[i2] = options[QBTEditAddFontSize.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreAddFontSizeButton(newOptions);
return panels;
}
}
return _DDeiCoreAddFontSizeButton;
}
static modify(fn) {
return _DDeiCoreAddFontSizeButton.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreAddFontSizeButton, "defaultIns", new _DDeiCoreAddFontSizeButton(null));
let DDeiCoreAddFontSizeButton = _DDeiCoreAddFontSizeButton;
const _sfc_main$T = {
name: "ddei-core-btn-borderdash",
extends: null,
mixins: [],
components: {},
props: {
attrCode: {
type: String,
default: null
},
hiddenCombo: {
type: String,
default: "0"
},
extcls: {
type: String,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
controlDefine: {
type: Object,
default: null
}
},
data() {
return {
attrDefine: null,
value: null
};
},
computed: {},
watch: {},
created() {
},
mounted() {
this.refreshEditor();
},
methods: {
refreshEditor() {
var _a3;
if (this.controlDefine) {
let attrD = this.controlDefine.attrDefineMap.get(this.attrCode);
let mds = [];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: attrD == null ? void 0 : attrD.code }, this.editor.ddInstance);
if (rsState != -1) {
this.attrDefine = attrD;
let valueDefine = this.getDataValue();
if (valueDefine && !valueDefine.isDefault) {
this.value = valueDefine.value;
}
}
} else {
this.attrDefine = null;
}
},
//打开弹出框
showDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-selectborderdash", {
value: this.attrDefine.value,
dataSource: this.attrDefine.dataSource,
callback: {
ok: this.valueChange
},
group: "property-dialog"
}, { type: 5 }, srcElement, false, true);
},
//获取数据值
getDataValue() {
var _a3, _b2, _c2;
if (this.attrDefine) {
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let value = shadowControl.getSptStyle(curSIdx, curEIdx, paths);
if (value === void 0) {
value = DDeiModelArrtibuteValue.getAttrValueByState(shadowControl, paths[0], true);
}
return { value };
}
}
}
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(this.attrDefine.model, this.attrDefine.code, this.attrDefine.mapping);
}
if (dataValue) {
return { value: dataValue };
}
}
return { isDefault: true, value: (_c2 = this.attrDefine) == null ? void 0 : _c2.getParser().getDefaultValue() };
},
valueChange(value) {
var _a3, _b2;
this.value = value;
this.attrDefine.value = value;
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(value);
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, parsedValue);
this.editor.bus.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
setTimeout(() => {
editorText.focus();
}, 20);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(DDeiEnumBusCommandType.ModelChangeValue, { mids: [element.id], paths, value: parsedValue }, null, true);
});
}
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
}
};
const QBTBorderDash_vue_vue_type_style_index_0_scoped_8ff63c75_lang = "";
const _hoisted_1$T = { class: "div_input" };
const _hoisted_2$E = ["stroke-dasharray"];
const _hoisted_3$B = {
key: 0,
style: { "display": "flex", "justify-content": "center", "align-items": "center" }
};
function _sfc_render$T(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-border-dash-combox": true, "ddei-pv-border-dash-combox--disabled": !$data.attrDefine || $data.attrDefine.readonly })
}, [
vue.createElementVNode("div", {
class: "textinput",
onClick: _cache[0] || (_cache[0] = ($event) => $data.attrDefine && !$data.attrDefine.readonly && $options.showDialog($event))
}, [
(vue.openBlock(), vue.createElementBlock("svg", _hoisted_1$T, [
vue.createElementVNode("line", {
x1: "0",
y1: "0",
x2: "100%",
y2: "0",
stroke: "black",
fill: "white",
"stroke-width": "3",
"stroke-dasharray": (_a3 = $data.attrDefine) == null ? void 0 : _a3.value
}, null, 8, _hoisted_2$E)
])),
$props.hiddenCombo != "1" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3$B, _cache[1] || (_cache[1] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
], -1)
]))) : vue.createCommentVNode("", true)
])
], 2);
}
const QBTBorderDash = /* @__PURE__ */ _export_sfc(_sfc_main$T, [["render", _sfc_render$T], ["__scopeId", "data-v-8ff63c75"]]);
const _DDeiCoreBorderDashButton = class _DDeiCoreBorderDashButton extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QBTBorderDash.name);
__publicField3(this, "plugins", [QBTBorderDash]);
}
getComponents(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QBTBorderDash.name]) {
for (let i2 in options[QBTBorderDash.name]) {
newOptions[i2] = options[QBTBorderDash.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreBorderDashButton(newOptions);
return panels;
}
}
return _DDeiCoreBorderDashButton;
}
static modify(fn) {
return _DDeiCoreBorderDashButton.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreBorderDashButton, "defaultIns", new _DDeiCoreBorderDashButton(null));
let DDeiCoreBorderDashButton = _DDeiCoreBorderDashButton;
const _sfc_main$S = {
name: "ddei-core-btn-borderweight",
extends: null,
mixins: [],
components: {},
props: {
attrCode: {
type: String,
default: null
},
hiddenCombo: {
type: String,
default: "0"
},
extcls: {
type: String,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
controlDefine: {
type: Object,
default: null
}
},
data() {
return {
attrDefine: null,
value: null
};
},
computed: {},
watch: {},
created() {
},
mounted() {
this.refreshEditor();
},
methods: {
refreshEditor() {
var _a3;
if (this.controlDefine) {
let attrD = this.controlDefine.attrDefineMap.get(this.attrCode);
let mds = [];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: attrD == null ? void 0 : attrD.code }, this.editor.ddInstance);
if (rsState != -1) {
this.attrDefine = attrD;
let valueDefine = this.getDataValue();
if (valueDefine && !valueDefine.isDefault) {
this.value = valueDefine.value;
}
}
} else {
this.attrDefine = null;
}
},
//打开弹出框
showDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-selectboderweight", {
value: this.attrDefine.value,
dataSource: [
{ value: "0.1" },
{ value: "0.5" },
{ value: "1" },
{ value: "2" },
{ value: "3" },
{ value: "4" },
{ value: "5" },
{ value: "6" },
{ value: "8" },
{ value: "10" },
{ value: "12" }
],
callback: {
ok: this.valueChange
},
group: "property-dialog"
}, { type: 5 }, srcElement, false, true);
},
//获取数据值
getDataValue() {
var _a3;
if (this.attrDefine) {
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(this.attrDefine.model, this.attrDefine.code, this.attrDefine.mapping);
}
if (dataValue) {
return { value: dataValue };
}
}
return { isDefault: true, value: (_a3 = this.attrDefine) == null ? void 0 : _a3.getParser().getDefaultValue() };
},
valueChange(value) {
var _a3, _b2;
this.value = value;
this.attrDefine.value = value;
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(value);
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, parsedValue);
this.editor.bus.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
setTimeout(() => {
editorText.focus();
}, 20);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(DDeiEnumBusCommandType.ModelChangeValue, { mids: [element.id], paths, value: parsedValue }, null, true);
});
}
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
}
};
const QBTBorderWeight_vue_vue_type_style_index_0_scoped_e7c6034b_lang = "";
const _hoisted_1$S = { class: "div_input" };
const _hoisted_2$D = ["stroke-width"];
const _hoisted_3$A = {
key: 0,
style: { "display": "flex", "justify-content": "center", "align-items": "center" }
};
function _sfc_render$S(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei_pv_border_weight_combox": true, "ddei_pv_border_weight_combox_disabled": !$data.attrDefine || $data.attrDefine.readonly })
}, [
vue.createElementVNode("div", {
class: "textinput",
onClick: _cache[0] || (_cache[0] = ($event) => $data.attrDefine && !$data.attrDefine.readonly && $options.showDialog($event))
}, [
(vue.openBlock(), vue.createElementBlock("svg", _hoisted_1$S, [
vue.createElementVNode("line", {
x1: "0",
y1: "0",
x2: "100%",
y2: "0",
stroke: "black",
fill: "white",
"stroke-width": (_a3 = $data.attrDefine) == null ? void 0 : _a3.value
}, null, 8, _hoisted_2$D)
])),
$props.hiddenCombo != "1" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3$A, _cache[1] || (_cache[1] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
], -1)
]))) : vue.createCommentVNode("", true)
])
], 2);
}
const QBTBorderWeight = /* @__PURE__ */ _export_sfc(_sfc_main$S, [["render", _sfc_render$S], ["__scopeId", "data-v-e7c6034b"]]);
const _DDeiCoreBorderWeightButton = class _DDeiCoreBorderWeightButton extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QBTBorderWeight.name);
__publicField3(this, "plugins", [QBTBorderWeight]);
}
getComponents(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QBTBorderWeight.name]) {
for (let i2 in options[QBTBorderWeight.name]) {
newOptions[i2] = options[QBTBorderWeight.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreBorderWeightButton(newOptions);
return panels;
}
}
return _DDeiCoreBorderWeightButton;
}
static modify(fn) {
return _DDeiCoreBorderWeightButton.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreBorderWeightButton, "defaultIns", new _DDeiCoreBorderWeightButton(null));
let DDeiCoreBorderWeightButton = _DDeiCoreBorderWeightButton;
const _sfc_main$R = {
name: "ddei-core-btn-editbox",
extends: null,
mixins: [],
components: {},
props: {
attrCode: {
type: String,
default: null
},
unSelectValue: {
default: null
},
supportQuickEdit: {
type: Boolean,
default: true
},
onlyQuickEdit: {
type: Boolean,
default: false
},
selectedValue: {
default: null
},
img: {
type: String,
default: null
},
extcls: {
type: String,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
controlDefine: {
type: Object,
default: null
}
},
data() {
return {
attrDefine: null,
value: false
};
},
computed: {},
watch: {},
created() {
this.$watch("editor.textEditorSelectedChange", function(newVal, oldVal) {
if (newVal) {
this.refreshEditor();
}
});
},
mounted() {
this.refreshEditor();
},
methods: {
refreshEditor() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i;
if (!this.supportQuickEdit && ((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.render) == null ? void 0 : _d2.operateState) == DDeiEnumOperateState.QUICK_EDITING) {
this.attrDefine = null;
return;
}
if (this.onlyQuickEdit && ((_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.render) == null ? void 0 : _h.operateState) != DDeiEnumOperateState.QUICK_EDITING) {
this.attrDefine = null;
return;
}
this.value = false;
if (this.controlDefine) {
let attrD = this.controlDefine.attrDefineMap.get(this.attrCode);
let mds = [];
if (((_i = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _i.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: attrD == null ? void 0 : attrD.code }, this.editor.ddInstance);
if (rsState != -1) {
this.attrDefine = attrD;
let valueDefine = this.getDataValue();
if (valueDefine && !valueDefine.isDefault && valueDefine.value + "" == this.selectedValue + "") {
this.value = true;
}
}
} else {
this.attrDefine = null;
}
},
//获取数据值
getDataValue() {
var _a3, _b2, _c2;
if (this.attrDefine) {
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let value = shadowControl.getSptStyle(curSIdx, curEIdx, paths);
if (value === void 0) {
value = DDeiModelArrtibuteValue.getAttrValueByState(shadowControl, paths[0], true);
}
return { value };
}
}
}
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(
this.attrDefine.model,
this.attrDefine.code,
this.attrDefine.mapping
);
}
if (dataValue) {
return { value: dataValue };
}
}
return {
isDefault: true,
value: (_c2 = this.attrDefine) == null ? void 0 : _c2.getParser().getDefaultValue()
};
},
valueChange(evt) {
var _a3, _b2;
if (this.value == true) {
this.value = false;
} else {
this.value = true;
}
let value = this.unSelectValue;
if (this.value == true) {
value = this.selectedValue;
}
this.attrDefine.value = value;
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(value);
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, parsedValue);
this.editor.bus.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
setTimeout(() => {
editorText.focus();
}, 20);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [element.id], paths, value: parsedValue },
evt,
true
);
});
}
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.executeAll();
if (this.editor.state != DDeiEditorState.QUICK_EDITING) {
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
}
};
const QBTEditBox_vue_vue_type_style_index_0_scoped_b43b0371_lang = "";
const _hoisted_1$R = ["xlink:href"];
function _sfc_render$R(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-editor-quick-fat-item-box": true, "ddei-editor-quick-fat-item-box--selected": $data.value, "ddei-editor-quick-fat-item-box--disabled": !$data.attrDefine }),
onClick: _cache[0] || (_cache[0] = ($event) => $data.attrDefine && $options.valueChange($event))
}, [
(vue.openBlock(), vue.createElementBlock("svg", {
class: vue.normalizeClass("icon " + ($props.extcls ? $props.extcls : "")),
"aria-hidden": "true"
}, [
vue.createElementVNode("use", {
"xlink:href": "#" + $props.img
}, null, 8, _hoisted_1$R)
], 2))
], 2);
}
const QBTEditBox = /* @__PURE__ */ _export_sfc(_sfc_main$R, [["render", _sfc_render$R], ["__scopeId", "data-v-b43b0371"]]);
const _DDeiCoreEditBoxButton = class _DDeiCoreEditBoxButton extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QBTEditBox.name);
__publicField3(this, "plugins", [QBTEditBox]);
}
getComponents(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QBTEditBox.name]) {
for (let i2 in options[QBTEditBox.name]) {
newOptions[i2] = options[QBTEditBox.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreEditBoxButton(newOptions);
return panels;
}
}
return _DDeiCoreEditBoxButton;
}
static modify(fn) {
return _DDeiCoreEditBoxButton.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreEditBoxButton, "defaultIns", new _DDeiCoreEditBoxButton(null));
let DDeiCoreEditBoxButton = _DDeiCoreEditBoxButton;
const _sfc_main$Q = {
name: "ddei-core-btn-color",
extends: null,
mixins: [],
components: {},
props: {
attrCode: {
type: String,
default: null
},
img: {
type: String,
default: null
},
extcls: {
type: String,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
controlDefine: {
type: Object,
default: null
}
},
data() {
return {
attrDefine: null,
value: null
};
},
computed: {},
watch: {},
created() {
this.$watch("editor.textEditorSelectedChange", function(newVal, oldVal) {
if (newVal) {
this.refreshEditor();
}
});
},
mounted() {
this.refreshEditor();
},
methods: {
refreshEditor() {
var _a3;
if (this.controlDefine) {
let attrD = this.controlDefine.attrDefineMap.get(this.attrCode);
let mds = [];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: attrD == null ? void 0 : attrD.code }, this.editor.ddInstance);
if (rsState != -1) {
this.attrDefine = attrD;
let valueDefine = this.getDataValue();
if (valueDefine && !valueDefine.isDefault) {
this.value = valueDefine.value;
}
}
} else {
this.attrDefine = null;
}
},
showColor(evt) {
let editorState = this.editor.state;
let colorInput = this.$refs.colorInput;
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-selectcolor", {
value: colorInput.value,
callback: {
ok: this.valueChange
},
group: "property-dialog"
}, { type: 5 }, srcElement, false, true);
this.editor.state = editorState;
},
//获取数据值
getDataValue() {
var _a3, _b2, _c2;
if (this.attrDefine) {
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let value = shadowControl.getSptStyle(curSIdx, curEIdx, paths);
if (value === void 0) {
value = DDeiModelArrtibuteValue.getAttrValueByState(shadowControl, paths[0], true);
}
return { value };
}
}
}
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(this.attrDefine.model, this.attrDefine.code, this.attrDefine.mapping);
}
if (dataValue) {
return { value: dataValue };
}
}
return { isDefault: true, value: (_c2 = this.attrDefine) == null ? void 0 : _c2.getParser().getDefaultValue() };
},
valueChange(value) {
var _a3, _b2;
this.value = value;
this.attrDefine.value = value;
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(value);
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, parsedValue);
this.editor.bus.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
setTimeout(() => {
editorText.focus();
}, 20);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(DDeiEnumBusCommandType.ModelChangeValue, { mids: [element.id], paths, value: parsedValue }, null, true);
});
}
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
}
};
const QBTEditColor_vue_vue_type_style_index_0_scoped_019ae087_lang = "";
const _hoisted_1$Q = ["xlink:href"];
function _sfc_render$Q(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-editor-quick-fat-item-box": true, "ddei-editor-quick-fat-item-box--disabled": !$data.attrDefine }),
onClick: _cache[1] || (_cache[1] = ($event) => $data.attrDefine && $options.showColor($event))
}, [
(vue.openBlock(), vue.createElementBlock("svg", {
class: vue.normalizeClass("icon " + ($props.extcls ? $props.extcls : "")),
"aria-hidden": "true"
}, [
vue.createElementVNode("use", {
"xlink:href": "#" + $props.img
}, null, 8, _hoisted_1$Q)
], 2)),
vue.createElementVNode("div", {
class: "colorbar",
style: vue.normalizeStyle({ "background-color": $data.value ? $data.value : "black" })
}, null, 4),
vue.withDirectives(vue.createElementVNode("input", {
ref: "colorInput",
type: "color",
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $data.value = $event),
class: "colinput",
autocomplete: "off"
}, null, 512), [
[vue.vModelText, $data.value]
])
], 2);
}
const QBTEditColor = /* @__PURE__ */ _export_sfc(_sfc_main$Q, [["render", _sfc_render$Q], ["__scopeId", "data-v-019ae087"]]);
const _DDeiCoreEditColorButton = class _DDeiCoreEditColorButton extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QBTEditColor.name);
__publicField3(this, "plugins", [QBTEditColor]);
}
getComponents(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QBTEditColor.name]) {
for (let i2 in options[QBTEditColor.name]) {
newOptions[i2] = options[QBTEditColor.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreEditColorButton(newOptions);
return panels;
}
}
return _DDeiCoreEditColorButton;
}
static modify(fn) {
return _DDeiCoreEditColorButton.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreEditColorButton, "defaultIns", new _DDeiCoreEditColorButton(null));
let DDeiCoreEditColorButton = _DDeiCoreEditColorButton;
const _sfc_main$P = {
name: "ddei-core-btn-fontfamily",
extends: null,
mixins: [],
components: {},
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
controlDefine: {
type: Object,
default: null
}
},
data() {
return {
attrDefine: null,
dataSource: null,
value: null,
text: null,
defaultText: null,
expanded: false,
canSearch: true
};
},
computed: {},
watch: {},
created() {
this.search = debounce(this.search, 200);
this.$watch("editor.textEditorSelectedChange", function(newVal, oldVal) {
if (newVal) {
this.refreshEditor();
}
});
},
mounted() {
this.refreshEditor();
},
methods: {
refreshEditor() {
var _a3;
if (this.controlDefine) {
let attrD = this.controlDefine.attrDefineMap.get("font.family");
let mds = [];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: attrD == null ? void 0 : attrD.code }, this.editor.ddInstance);
if (rsState != -1) {
this.attrDefine = attrD;
}
} else {
this.attrDefine = null;
}
this.getDataSource(this.attrDefine);
let type = this.getDataValue();
let define2 = this.getDataDefine(type.value);
if (!type.isDefault) {
this.attrDefine.value = type.value;
this.text = define2.text;
if (define2.img) {
this.$refs.combox.img = define2.img;
}
} else {
this.defaultText = define2.text;
}
this.value = type.value;
},
search() {
this.searchText = this.text;
this.getDataSource(this.attrDefine);
this.showDialog();
},
//打开弹出框
showDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-selectfont", {
dataSource: this.dataSource,
value: this.attrDefine.value,
group: "property-dialog",
callback: {
ok: this.valueChange
}
}, { type: 5 }, srcElement, false, true);
},
/**
* 根据值获取选项定义
* @param value 值
*/
getDataDefine(value) {
if (this.dataSource && value) {
for (let i2 = 0; i2 < this.dataSource.length; i2++) {
if (this.dataSource[i2].value.toString() == value.toString()) {
return this.dataSource[i2];
}
}
}
return { text: "" };
},
//获取数据值
getDataValue() {
var _a3, _b2, _c2;
if (this.attrDefine) {
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let value = shadowControl.getSptStyle(curSIdx, curEIdx, paths);
if (value === void 0) {
value = DDeiModelArrtibuteValue.getAttrValueByState(shadowControl, paths[0], true);
}
return { value };
}
}
}
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(
this.attrDefine.model,
this.attrDefine.code,
this.attrDefine.mapping
);
}
if (dataValue) {
return { value: dataValue };
}
}
return {
isDefault: true,
value: (_c2 = this.attrDefine) == null ? void 0 : _c2.getParser().getDefaultValue()
};
},
/**
* 获取数据源数据
*/
getDataSource(attrDefine) {
if (this.attrDefine) {
let dataSources = DDeiEditorUtil.getDataSource(
this.editor,
this.attrDefine,
this.searchText
);
this.dataSource = dataSources;
return this.dataSource;
}
},
valueChange(value, evt) {
var _a3, _b2;
this.attrDefine.value = value;
let itemDefine = this.getDataDefine(value);
let text2 = itemDefine.text;
this.text = text2;
this.value = value;
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(value);
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, parsedValue);
this.editor.bus.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
setTimeout(() => {
editorText.focus();
}, 20);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [element.id], paths, value: parsedValue },
evt,
true
);
});
}
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
this.editor.bus.executeAll();
}
}
};
const QBTFontFamily_vue_vue_type_style_index_0_scoped_ec936992_lang = "";
const _hoisted_1$P = ["readonly", "placeholder"];
function _sfc_render$P(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", null, [
vue.createElementVNode("div", {
id: "ddei-editor-quick-fat-item-fontfamily",
class: vue.normalizeClass({ "ddei-editor-quick-fat-item-fontfamily": true, "ddei-editor-quick-fat-item-fontfamily--disabled": !$data.attrDefine })
}, [
vue.withDirectives(vue.createElementVNode("input", {
class: "ddei-editor-quick-fat-item-fontfamily_input",
readonly: !$data.attrDefine || $data.attrDefine && ($data.attrDefine.readonly || !$data.canSearch),
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $data.text = $event),
placeholder: $data.defaultText,
onClick: _cache[1] || (_cache[1] = ($event) => $data.attrDefine && !$data.attrDefine.readonly && !$data.canSearch && $options.showDialog($event)),
onKeydown: _cache[2] || (_cache[2] = ($event) => $options.search($event)),
autocomplete: "off"
}, null, 40, _hoisted_1$P), [
[vue.vModelText, $data.text]
]),
vue.createElementVNode("div", {
class: "ddei-editor-quick-fat-item-fontfamily_combox",
onClick: _cache[3] || (_cache[3] = ($event) => $data.attrDefine && !$data.attrDefine.readonly && $options.showDialog($event))
}, _cache[4] || (_cache[4] = [
vue.createElementVNode("svg", {
class: "icon iconfont-45",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-expand2" })
], -1)
]))
], 2)
]);
}
const QBTFontFamily = /* @__PURE__ */ _export_sfc(_sfc_main$P, [["render", _sfc_render$P], ["__scopeId", "data-v-ec936992"]]);
const _DDeiCoreEditFontFamilyButton = class _DDeiCoreEditFontFamilyButton extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QBTFontFamily.name);
__publicField3(this, "plugins", [QBTFontFamily]);
}
getComponents(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QBTFontFamily.name]) {
for (let i2 in options[QBTFontFamily.name]) {
newOptions[i2] = options[QBTFontFamily.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreEditFontFamilyButton(newOptions);
return panels;
}
}
return _DDeiCoreEditFontFamilyButton;
}
static modify(fn) {
return _DDeiCoreEditFontFamilyButton.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreEditFontFamilyButton, "defaultIns", new _DDeiCoreEditFontFamilyButton(null));
let DDeiCoreEditFontFamilyButton = _DDeiCoreEditFontFamilyButton;
const _sfc_main$O = {
name: "ddei-core-btn-fontsize",
extends: null,
mixins: [],
components: {},
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
controlDefine: {
type: Object,
default: null
}
},
data() {
return {
attrDefine: null,
dataSource: null,
value: null,
text: null,
defaultText: null,
expanded: false,
canSearch: true
};
},
computed: {},
watch: {},
created() {
this.$watch("editor.textEditorSelectedChange", function(newVal, oldVal) {
if (newVal) {
this.refreshEditor();
}
});
},
mounted() {
this.refreshEditor();
},
methods: {
refreshEditor() {
var _a3;
if (this.controlDefine) {
let attrD = this.controlDefine.attrDefineMap.get("font.size");
let mds = [];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: attrD == null ? void 0 : attrD.code }, this.editor.ddInstance);
if (rsState != -1) {
this.attrDefine = attrD;
}
} else {
this.attrDefine = null;
}
if (this.attrDefine) {
this.getDataSource(this.attrDefine);
let type = this.getDataValue();
let define2 = this.getDataDefine(type.value);
if (!type.isDefault) {
this.attrDefine.value = type.value;
this.text = define2.text;
} else {
this.defaultText = define2.text;
}
if (this.attrDefine.value) {
this.value = this.attrDefine.value;
this.text = this.attrDefine.value;
} else {
this.value = type.value;
}
}
},
inputValue(value) {
var _a3, _b2;
let dialogSet = false;
if (value) {
dialogSet = true;
this.attrDefine.value = value;
let itemDefine = this.getDataDefine(value);
let text2 = itemDefine.text;
this.text = text2;
this.value = value;
} else {
value = this.text;
this.attrDefine.value = value;
this.value = value;
let itemDefine = this.getDataDefine(value);
if (itemDefine == null ? void 0 : itemDefine.text) {
this.text = itemDefine.text;
}
}
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(value);
parsedValue = isNaN(parsedValue) || parsedValue <= 0 ? null : parsedValue;
parsedValue = parsedValue > 300 ? 300 : parsedValue;
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, parsedValue);
this.editor.bus.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
if (dialogSet) {
setTimeout(() => {
editorText.focus();
}, 20);
}
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [element.id], paths, value: parsedValue },
null,
true
);
});
}
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
},
//打开弹出框
showDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-selectfontsize", {
dataSource: this.dataSource,
value: this.attrDefine.value,
group: "property-dialog",
callback: {
ok: this.inputValue
}
}, { type: 5 }, srcElement, false, true);
},
/**
* 根据值获取选项定义
* @param value 值
*/
getDataDefine(value) {
if (this.dataSource && value) {
for (let i2 = 0; i2 < this.dataSource.length; i2++) {
if (this.dataSource[i2].value.toString() == value.toString()) {
return this.dataSource[i2];
}
}
}
return { text: "" };
},
//获取数据值
getDataValue() {
var _a3, _b2, _c2;
if (this.attrDefine) {
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let value = shadowControl.getSptStyle(curSIdx, curEIdx, paths);
if (value === void 0) {
value = DDeiModelArrtibuteValue.getAttrValueByState(shadowControl, paths[0], true);
return { isDefault: true, value };
} else {
return { value };
}
}
}
}
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(
this.attrDefine.model,
this.attrDefine.code,
this.attrDefine.mapping
);
}
if (dataValue) {
return { value: dataValue };
}
}
return {
isDefault: true,
value: (_c2 = this.attrDefine) == null ? void 0 : _c2.getParser().getDefaultValue()
};
},
/**
* 获取数据源数据
*/
getDataSource(attrDefine) {
if (this.attrDefine) {
this.attrDefine.dataSource = [
{ text: "9", value: 9 },
{ text: "10", value: 10 },
{ text: "10.5", value: 10.5 },
{ text: "11", value: 11 },
{ text: "12", value: 12 },
{ text: "13", value: 13 },
{ text: "14", value: 14 },
{ text: "18", value: 18 },
{ text: "24", value: 24 },
{ text: "36", value: 36 },
{ text: "48", value: 48 },
{ text: "64", value: 64 },
{ text: "72", value: 72 },
{ text: "96", value: 96 },
{ text: "144", value: 144 },
{ text: "288", value: 288 }
];
let dataSources = DDeiEditorUtil.getDataSource(
this.editor,
this.attrDefine,
this.searchText
);
this.dataSource = dataSources;
return this.dataSource;
}
}
}
};
const QBTFontSize_vue_vue_type_style_index_0_scoped_4fcf2a95_lang = "";
const _hoisted_1$O = ["readonly", "placeholder"];
function _sfc_render$O(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", null, [
vue.createElementVNode("div", {
id: "ddei-editor-quick-fat-item-fontsize",
class: vue.normalizeClass({ "ddei-editor-quick-fat-item-fontsize": true, "ddei-editor-quick-fat-item-fontsize--disabled": !$data.attrDefine })
}, [
vue.withDirectives(vue.createElementVNode("input", {
class: "ddei-editor-quick-fat-item-fontsize_input",
readonly: !$data.attrDefine || $data.attrDefine && $data.attrDefine.readonly,
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $data.text = $event),
onInput: _cache[1] || (_cache[1] = ($event) => $options.inputValue()),
placeholder: $data.defaultText,
autocomplete: "off"
}, null, 40, _hoisted_1$O), [
[vue.vModelText, $data.text]
]),
vue.createElementVNode("div", {
class: "ddei-editor-quick-fat-item-fontsize_combox",
onClick: _cache[2] || (_cache[2] = ($event) => $data.attrDefine && !$data.attrDefine.readonly && $options.showDialog($event))
}, _cache[3] || (_cache[3] = [
vue.createElementVNode("svg", {
class: "icon iconfont-45",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-expand2" })
], -1)
]))
], 2)
]);
}
const QBTFontSize = /* @__PURE__ */ _export_sfc(_sfc_main$O, [["render", _sfc_render$O], ["__scopeId", "data-v-4fcf2a95"]]);
const _DDeiCoreEditFontSizeButton = class _DDeiCoreEditFontSizeButton extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QBTFontSize.name);
__publicField3(this, "plugins", [QBTFontSize]);
}
getComponents(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QBTFontSize.name]) {
for (let i2 in options[QBTFontSize.name]) {
newOptions[i2] = options[QBTFontSize.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreEditFontSizeButton(newOptions);
return panels;
}
}
return _DDeiCoreEditFontSizeButton;
}
static modify(fn) {
return _DDeiCoreEditFontSizeButton.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreEditFontSizeButton, "defaultIns", new _DDeiCoreEditFontSizeButton(null));
let DDeiCoreEditFontSizeButton = _DDeiCoreEditFontSizeButton;
const _sfc_main$N = {
name: "ddei-core-btn-linepointtype",
extends: null,
mixins: [],
components: {},
props: {
attrCode: {
type: String,
default: null
},
extcls: {
type: String,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
controlDefine: {
type: Object,
default: null
}
},
data() {
return {
attrDefine: null,
value: null,
text: ""
};
},
computed: {},
watch: {},
created() {
},
mounted() {
this.refreshEditor();
},
methods: {
refreshText() {
var _a3;
let text2 = "";
if ((_a3 = this.attrDefine) == null ? void 0 : _a3.dataSource) {
for (let i2 = 0; i2 < this.attrDefine.dataSource.length; i2++) {
if (this.attrDefine.dataSource[i2].value == this.value) {
text2 = this.attrDefine.dataSource[i2].text;
break;
}
}
}
this.text = text2;
},
refreshEditor() {
var _a3;
if (this.controlDefine) {
let attrD = this.controlDefine.attrDefineMap.get(this.attrCode);
let mds = [];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: attrD == null ? void 0 : attrD.code }, this.editor.ddInstance);
if (rsState != -1) {
this.attrDefine = attrD;
let valueDefine = this.getDataValue();
if (valueDefine && !valueDefine.isDefault) {
this.value = valueDefine.value;
}
}
} else {
this.attrDefine = null;
}
this.refreshText();
},
//打开弹出框
showDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-linepointtype", {
value: this.attrDefine.value,
dataSource: this.attrDefine.dataSource,
callback: {
ok: this.valueChange
},
group: "property-dialog"
}, { type: 5 }, srcElement, false, true);
},
//获取数据值
getDataValue() {
var _a3;
if (this.attrDefine) {
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(this.attrDefine.model, this.attrDefine.code, this.attrDefine.mapping);
}
if (dataValue) {
return { value: dataValue };
}
}
return { isDefault: true, value: (_a3 = this.attrDefine) == null ? void 0 : _a3.getParser().getDefaultValue() };
},
valueChange(value) {
var _a3, _b2;
this.value = value;
this.attrDefine.value = value;
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(value);
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
{
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(DDeiEnumBusCommandType.ModelChangeValue, { mids: [element.id], paths, value: parsedValue }, null, true);
});
}
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
this.refreshText();
}
}
};
const QBTLinePointType_vue_vue_type_style_index_0_scoped_5b25a083_lang = "";
const _hoisted_1$N = { class: "div_input" };
function _sfc_render$N(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei_pv_line_point_combox": true, "ddei_pv_line_point_combox_disabled": !$data.attrDefine || $data.attrDefine.readonly })
}, [
vue.createElementVNode("div", {
class: "textinput",
onClick: _cache[0] || (_cache[0] = ($event) => $data.attrDefine && !$data.attrDefine.readonly && $options.showDialog($event))
}, [
vue.createElementVNode("div", _hoisted_1$N, vue.toDisplayString($data.text), 1),
_cache[1] || (_cache[1] = vue.createElementVNode("div", { style: { "display": "flex", "justify-content": "center", "align-items": "center" } }, [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
])
], -1))
])
], 2);
}
const QBTLinePointType = /* @__PURE__ */ _export_sfc(_sfc_main$N, [["render", _sfc_render$N], ["__scopeId", "data-v-5b25a083"]]);
const _DDeiCoreEditLinePointTypeButton = class _DDeiCoreEditLinePointTypeButton extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QBTLinePointType.name);
__publicField3(this, "plugins", [QBTLinePointType]);
}
getComponents(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QBTLinePointType.name]) {
for (let i2 in options[QBTLinePointType.name]) {
newOptions[i2] = options[QBTLinePointType.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreEditLinePointTypeButton(newOptions);
return panels;
}
}
return _DDeiCoreEditLinePointTypeButton;
}
static modify(fn) {
return _DDeiCoreEditLinePointTypeButton.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreEditLinePointTypeButton, "defaultIns", new _DDeiCoreEditLinePointTypeButton(null));
let DDeiCoreEditLinePointTypeButton = _DDeiCoreEditLinePointTypeButton;
const _sfc_main$M = {
name: "ddei-core-btn-linetype",
extends: null,
mixins: [],
components: {},
props: {
attrCode: {
type: String,
default: null
},
extcls: {
type: String,
default: null
},
img: {
type: String,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
controlDefine: {
type: Object,
default: null
}
},
data() {
return {
attrDefine: null,
value: null
};
},
computed: {},
watch: {},
created() {
},
mounted() {
this.refreshEditor();
},
methods: {
refreshEditor() {
var _a3;
if (this.controlDefine) {
let attrD = this.controlDefine.attrDefineMap.get(this.attrCode);
let mds = [];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: attrD == null ? void 0 : attrD.code }, this.editor.ddInstance);
if (rsState != -1) {
this.attrDefine = attrD;
let valueDefine = this.getDataValue();
if (valueDefine && !valueDefine.isDefault) {
this.value = valueDefine.value;
}
}
} else {
this.attrDefine = null;
}
},
//打开弹出框
showDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-linetype", {
value: this.attrDefine.value,
dataSource: this.attrDefine.dataSource,
callback: {
ok: this.valueChange
},
group: "property-dialog"
}, { type: 5 }, srcElement, false, true);
},
//获取数据值
getDataValue() {
var _a3, _b2, _c2;
if (this.attrDefine) {
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let value = shadowControl.getSptStyle(curSIdx, curEIdx, paths);
if (value === void 0) {
value = DDeiModelArrtibuteValue.getAttrValueByState(shadowControl, paths[0], true);
}
return { value };
}
}
}
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(this.attrDefine.model, this.attrDefine.code, this.attrDefine.mapping);
}
if (dataValue) {
return { value: dataValue };
}
}
return { isDefault: true, value: (_c2 = this.attrDefine) == null ? void 0 : _c2.getParser().getDefaultValue() };
},
valueChange(value) {
var _a3, _b2;
this.value = value;
this.attrDefine.value = value;
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(value);
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, parsedValue);
this.editor.bus.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
setTimeout(() => {
editorText.focus();
}, 20);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(DDeiEnumBusCommandType.ModelChangeValue, { mids: [element.id], paths, value: parsedValue }, null, true);
});
}
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
}
};
const QBTLineType_vue_vue_type_style_index_0_scoped_739c83c3_lang = "";
const _hoisted_1$M = ["xlink:href"];
function _sfc_render$M(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
onClick: _cache[0] || (_cache[0] = ($event) => $data.attrDefine && $options.showDialog($event)),
class: vue.normalizeClass({ "ddei-pv-line-type-combox": true, "ddei-pv-line-type-combox--disabled": !$data.attrDefine || $data.attrDefine.readonly })
}, [
(vue.openBlock(), vue.createElementBlock("svg", {
class: vue.normalizeClass("icon " + ($props.extcls ? $props.extcls : "")),
"aria-hidden": "true"
}, [
vue.createElementVNode("use", {
"xlink:href": "#" + $props.img
}, null, 8, _hoisted_1$M)
], 2))
], 2);
}
const QBTLineType = /* @__PURE__ */ _export_sfc(_sfc_main$M, [["render", _sfc_render$M], ["__scopeId", "data-v-739c83c3"]]);
const _DDeiCoreEditLineTypeButton = class _DDeiCoreEditLineTypeButton extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QBTLineType.name);
__publicField3(this, "plugins", [QBTLineType]);
}
getComponents(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QBTLineType.name]) {
for (let i2 in options[QBTLineType.name]) {
newOptions[i2] = options[QBTLineType.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreEditLineTypeButton(newOptions);
return panels;
}
}
return _DDeiCoreEditLineTypeButton;
}
static modify(fn) {
return _DDeiCoreEditLineTypeButton.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreEditLineTypeButton, "defaultIns", new _DDeiCoreEditLineTypeButton(null));
let DDeiCoreEditLineTypeButton = _DDeiCoreEditLineTypeButton;
const _sfc_main$L = {
name: "ddei-core-btn-textalign",
extends: null,
mixins: [],
components: {},
props: {
img: {
type: String,
default: null
},
extcls: {
type: String,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
},
controlDefine: {
type: Object,
default: null
}
},
data() {
return {
attrDefine: null,
valignAttrDefine: null,
value: false
};
},
computed: {},
watch: {},
created() {
},
mounted() {
this.refreshEditor();
},
methods: {
showTextAlignDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-textalign", {
group: "top-dialog",
align: this.attrDefine.value,
valign: this.valignAttrDefine.value,
callback: {
ok: this.valueChange
}
}, { type: 5 }, srcElement, false, true);
},
refreshEditor() {
var _a3;
if (this.controlDefine) {
let attrD = this.controlDefine.attrDefineMap.get("textStyle.align");
let mds = [];
if (((_a3 = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
mds = Array.from(this.editor.ddInstance.stage.selectedModels.values());
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: attrD == null ? void 0 : attrD.code }, this.editor.ddInstance);
if (rsState != -1) {
this.attrDefine = attrD;
this.valignAttrDefine = this.controlDefine.attrDefineMap.get(
"textStyle.valign"
);
}
} else {
this.attrDefine = null;
this.valignAttrDefine = null;
}
},
valueChange(value = 5) {
switch (value) {
case 1:
this.attrDefine.value = 1;
this.valignAttrDefine.value = 1;
break;
case 2:
this.attrDefine.value = 2;
this.valignAttrDefine.value = 1;
break;
case 3:
this.attrDefine.value = 3;
this.valignAttrDefine.value = 1;
break;
case 4:
this.attrDefine.value = 1;
this.valignAttrDefine.value = 2;
break;
case 5:
this.attrDefine.value = 2;
this.valignAttrDefine.value = 2;
break;
case 6:
this.attrDefine.value = 3;
this.valignAttrDefine.value = 2;
break;
case 7:
this.attrDefine.value = 1;
this.valignAttrDefine.value = 3;
break;
case 8:
this.attrDefine.value = 2;
this.valignAttrDefine.value = 3;
break;
case 9:
this.attrDefine.value = 3;
this.valignAttrDefine.value = 3;
break;
}
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
var _a3, _b2, _c2, _d2;
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.mapping) == null ? void 0 : _b2.forEach((element2) => {
paths.push(element2);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let paths1 = [];
(_d2 = (_c2 = this.valignAttrDefine) == null ? void 0 : _c2.mapping) == null ? void 0 : _d2.forEach((element2) => {
paths1.push(element2);
});
if (!((paths1 == null ? void 0 : paths1.length) > 0)) {
paths1 = [this.valignAttrDefine.code];
}
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [element.id], paths, value: this.attrDefine.value },
null,
true
);
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [element.id], paths: paths1, value: this.valignAttrDefine.value },
null,
true
);
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.executeAll();
}
}
};
const QBTEditTextAlign_vue_vue_type_style_index_0_scoped_781d8566_lang = "";
const _hoisted_1$L = ["xlink:href"];
function _sfc_render$L(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-editor-quick-fat-item-box": true, "ddei-editor-quick-fat-item-box--disabled": !($data.attrDefine || $data.valignAttrDefine) }),
onClick: _cache[0] || (_cache[0] = ($event) => ($data.attrDefine || $data.valignAttrDefine) && $options.showTextAlignDialog($event))
}, [
(vue.openBlock(), vue.createElementBlock("svg", {
class: vue.normalizeClass("icon " + ($props.extcls ? $props.extcls : "")),
"aria-hidden": "true"
}, [
vue.createElementVNode("use", {
"xlink:href": "#" + $props.img
}, null, 8, _hoisted_1$L)
], 2))
], 2);
}
const QBTEditTextAlign = /* @__PURE__ */ _export_sfc(_sfc_main$L, [["render", _sfc_render$L], ["__scopeId", "data-v-781d8566"]]);
const _DDeiCoreEditTextAlignButton = class _DDeiCoreEditTextAlignButton extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QBTEditTextAlign.name);
__publicField3(this, "plugins", [QBTEditTextAlign]);
}
getComponents(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QBTEditTextAlign.name]) {
for (let i2 in options[QBTEditTextAlign.name]) {
newOptions[i2] = options[QBTEditTextAlign.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreEditTextAlignButton(newOptions);
return panels;
}
}
return _DDeiCoreEditTextAlignButton;
}
static modify(fn) {
return _DDeiCoreEditTextAlignButton.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreEditTextAlignButton, "defaultIns", new _DDeiCoreEditTextAlignButton(null));
let DDeiCoreEditTextAlignButton = _DDeiCoreEditTextAlignButton;
const _DDeiCoreComponents = class _DDeiCoreComponents extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [
DDeiCoreAddFontSizeButton,
DDeiCoreBorderDashButton,
DDeiCoreBorderWeightButton,
DDeiCoreEditBoxButton,
DDeiCoreEditColorButton,
DDeiCoreEditFontFamilyButton,
DDeiCoreEditFontSizeButton,
DDeiCoreEditLinePointTypeButton,
DDeiCoreEditLineTypeButton,
DDeiCoreEditTextAlignButton
]);
}
getComponents(editor) {
var _a3;
let components = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getComponents(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getComponents(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
components = components.concat(ls);
}
});
return components;
}
static configuration(options) {
var _a3;
if (options) {
let components = new _DDeiCoreComponents(options);
for (let i2 = 0; i2 < ((_a3 = components.plugins) == null ? void 0 : _a3.length); i2++) {
components.plugins[i2] = components.plugins[i2].configuration(options, true);
}
return components;
}
return _DDeiCoreComponents;
}
static modify(fn) {
return _DDeiCoreComponents.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreComponents, "defaultIns", new _DDeiCoreComponents(null));
let DDeiCoreComponents = _DDeiCoreComponents;
const _sfc_main$K = {
name: "ddei-core-layout-standard",
extends: null,
mixins: [],
props: {
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
dragObj: null,
changeIndex: -1,
allowOpenMultFiles: true,
allowQuickColor: true,
initLeftWidth: 0,
initRightWidth: 0,
toolboxShow: true,
propertyViewShow: true,
leftComponents: [],
rightComponents: [],
topComponents: [],
bottomComponents: [],
middleComponents: []
};
},
//注册组件
components: {},
computed: {},
watch: {},
created() {
this.$watch("editor.leftWidth", function(newVal, oldVal) {
this.$refs.left.style.flexBasis = newVal + "px";
});
this.$watch("editor.rightWidth", function(newVal, oldVal) {
this.$refs.right.style.flexBasis = newVal + "px";
});
this.$watch("editor.topHeight", function(newVal, oldVal) {
this.$refs.top.style.flexBasis = newVal + "px";
});
this.$watch("editor.bottomHeight", function(newVal, oldVal) {
this.$refs.bottom.style.flexBasis = newVal + "px";
});
this.leftComponents = vue.markRaw(this.editor.getPartPanels(this.options, "left"));
this.rightComponents = vue.markRaw(this.editor.getPartPanels(this.options, "right"));
this.topComponents = vue.markRaw(this.editor.getPartPanels(this.options, "top"));
this.bottomComponents = vue.markRaw(this.editor.getPartPanels(this.options, "bottom"));
this.middleComponents = vue.markRaw(this.editor.getPartPanels(this.options, "middle"));
},
mounted() {
this.editor.layoutViewer = this;
let middleCanvas = document.getElementById(this.editor.id + "_canvas");
const resizeObserver = new ResizeObserver((entries) => {
for (const entry of entries) {
const { width, height } = entry.contentRect;
if (width != 0 && height != 0) {
this.editor.ddInstance.render.setSize(
width,
height,
0,
0
);
this.editor.ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.ddInstance.bus.executeAll();
}
}
});
resizeObserver.observe(middleCanvas);
this.editor.leftWidth = this.$refs.left.offsetWidth;
this.editor.rightWidth = this.$refs.right.offsetWidth;
this.editor.topHeight = this.$refs.top.offsetHeight;
this.editor.bottomHeight = this.$refs.bottom.offsetHeight;
this.editor.middleWidth = this.$refs.middle.offsetWidth;
this.editor.middleHeight = this.$refs.middle.offsetHeight;
this.initLeftWidth = this.$refs.left.offsetWidth;
this.initRightWidth = this.$refs.right.offsetWidth;
this.editor.maxWidth = this.editor.leftWidth + this.editor.rightWidth + this.editor.middleWidth;
let ddInstance = this.editor.ddInstance;
if (ddInstance) {
let modeName = DDeiUtil.getConfigValue("MODE_NAME", ddInstance);
let accessCreate = DDeiUtil.isAccess(
DDeiEnumOperateType.CREATE,
null,
null,
modeName,
ddInstance
);
this.toolboxShow = accessCreate;
let accessEdit = DDeiUtil.isAccess(
DDeiEnumOperateType.EDIT,
null,
null,
modeName,
ddInstance
);
this.propertyViewShow = accessEdit;
}
},
methods: {
//强制刷新下层组件
forceRefreshParts(parts) {
let arr = [this.$refs.topComponents, this.$refs.leftComponents, this.$refs.middleComponents, this.$refs.rightComponents, this.$refs.bottomComponents];
arr.forEach((comps) => {
if (comps) {
if (Array.isArray(comps)) {
comps.forEach((comp) => {
if (comp && comp.forceRefreshParts) {
comp.forceRefreshParts(parts);
}
});
} else if (comps.forceRefreshParts) {
comps.forceRefreshParts(parts);
}
}
});
}
// resetSize() {
// let layoutRoot = this.$refs.layoutRoot;
// let width = layoutRoot.scrollWidth
// let height = layoutRoot.scrollHeight
// if (!window.upSizeWidth || !window.upSizeHeight) {
// window.upSizeWidth = width;
// window.upSizeHeight = height;
// } else {
// let deltaWidth = width - window.upSizeWidth;
// let deltaHeight = height - window.upSizeHeight;
// if (this.editor.middleWidth + deltaWidth >= 305) {
// window.upSizeWidth = width;
// this.editor.middleWidth += deltaWidth;
// this.editor.maxWidth =
// this.editor.leftWidth +
// this.editor.rightWidth +
// this.editor.middleWidth;
// }
// if (this.editor.middleHeight + deltaHeight >= 305) {
// window.upSizeHeight = height;
// this.editor.middleHeight += deltaHeight;
// this.editor.maxHeight =
// this.editor.leftHeight +
// this.editor.rightHeight +
// this.editor.middleHeight;
// }
// this.editor.ddInstance.render.setSize(
// this.editor.middleWidth,
// this.editor.middleHeight,
// 0,
// 0
// );
// this.editor.ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
// this.editor.ddInstance.bus.executeAll();
// }
// },
}
};
const StandardLayout_vue_vue_type_style_index_0_scoped_43088579_lang = "";
const StandardLayout_vue_vue_type_style_index_1_lang = "";
const _hoisted_1$K = {
class: "ddei-editor-layout-standrad",
ref: "layoutRoot"
};
const _hoisted_2$C = {
class: "top",
ref: "top"
};
const _hoisted_3$z = { class: "body" };
const _hoisted_4$s = {
class: "left",
ref: "left"
};
const _hoisted_5$n = {
class: "middle",
ref: "middle"
};
const _hoisted_6$i = {
class: "right",
ref: "right"
};
const _hoisted_7$g = {
class: "bottom",
ref: "bottom"
};
function _sfc_render$K(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2;
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$K, [
vue.withDirectives(vue.createElementVNode("div", _hoisted_2$C, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.topComponents, (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
ref_for: true,
ref: "topComponents",
editor: $props.editor
}, item.options, {
options: item.options
}), null, 16, ["editor", "options"]);
}), 256))
], 512), [
[vue.vShow, ((_a3 = $data.topComponents) == null ? void 0 : _a3.length) > 0]
]),
vue.createElementVNode("div", _hoisted_3$z, [
vue.withDirectives(vue.createElementVNode("div", _hoisted_4$s, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.leftComponents, (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
ref_for: true,
ref: "leftComponents",
editor: $props.editor,
options: item.options
}, item.options), null, 16, ["editor", "options"]);
}), 256))
], 512), [
[vue.vShow, $data.toolboxShow && ((_b2 = $data.leftComponents) == null ? void 0 : _b2.length) > 0]
]),
vue.withDirectives(vue.createElementVNode("div", _hoisted_5$n, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.middleComponents, (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
ref_for: true,
ref: "middleComponents",
editor: $props.editor,
options: item.options
}, item.options), null, 16, ["editor", "options"]);
}), 256))
], 512), [
[vue.vShow, ((_c2 = $data.middleComponents) == null ? void 0 : _c2.length) > 0]
]),
vue.withDirectives(vue.createElementVNode("div", _hoisted_6$i, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.rightComponents, (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
ref_for: true,
ref: "rightComponents",
editor: $props.editor,
options: item.options
}, item.options), null, 16, ["editor", "options"]);
}), 256))
], 512), [
[vue.vShow, $data.propertyViewShow && ((_d2 = $data.rightComponents) == null ? void 0 : _d2.length) > 0]
])
]),
vue.withDirectives(vue.createElementVNode("div", _hoisted_7$g, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.bottomComponents, (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
ref_for: true,
ref: "bottomComponents",
editor: $props.editor,
options: item.options
}, item.options), null, 16, ["editor", "options"]);
}), 256))
], 512), [
[vue.vShow, ((_e2 = $data.bottomComponents) == null ? void 0 : _e2.length) > 0]
])
], 512);
}
const Layout$1 = /* @__PURE__ */ _export_sfc(_sfc_main$K, [["render", _sfc_render$K], ["__scopeId", "data-v-43088579"]]);
const _DDeiCoreStandLayout = class _DDeiCoreStandLayout extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", Layout$1.name);
__publicField3(this, "defaultOptions", {
top: ["ddei-core-panel-topmenu"],
left: ["ddei-core-panel-toolbox"],
middle: ["ddei-core-panel-canvasview"],
right: ["ddei-core-panel-propertyview"],
bottom: ["ddei-core-panel-bottommenu"]
});
__publicField3(this, "plugins", [Layout$1]);
}
getLayouts(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreStandLayout.defaultIns.defaultOptions);
if (fullConfig) {
if (fullConfig) {
if (options[Layout$1.name]) {
for (let i2 in options[Layout$1.name]) {
newOptions[i2] = options[Layout$1.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreStandLayout(newOptions);
return layouts;
}
}
return _DDeiCoreStandLayout;
}
static modify(fn) {
return _DDeiCoreStandLayout.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreStandLayout, "defaultIns", new _DDeiCoreStandLayout());
let DDeiCoreStandLayout = _DDeiCoreStandLayout;
const _sfc_main$J = {
name: "ddei-core-layout-simple",
extends: null,
mixins: [],
props: {
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
otherComponents: [],
topComponents: [],
bottomComponents: [],
middleComponents: []
};
},
//注册组件
components: {},
computed: {},
watch: {},
created() {
this.otherComponents = vue.markRaw(this.editor.getPartPanels(this.options, "other"));
this.topComponents = vue.markRaw(this.editor.getPartPanels(this.options, "top"));
this.bottomComponents = vue.markRaw(this.editor.getPartPanels(this.options, "bottom"));
this.middleComponents = vue.markRaw(this.editor.getPartPanels(this.options, "middle"));
},
mounted() {
this.editor.layoutViewer = this;
let middleCanvas = document.getElementById(this.editor.id + "_canvas");
const resizeObserver = new ResizeObserver((entries) => {
for (const entry of entries) {
const { width, height } = entry.contentRect;
if (width != 0 && height != 0) {
this.editor.ddInstance.render.setSize(
width,
height,
0,
0
);
this.editor.ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.ddInstance.bus.executeAll();
}
}
});
resizeObserver.observe(middleCanvas);
this.editor.topHeight = this.$refs.top.offsetHeight;
this.editor.bottomHeight = this.$refs.bottom.offsetHeight;
this.editor.middleWidth = this.$refs.middle.offsetWidth;
this.editor.middleHeight = this.$refs.middle.offsetHeight;
let ddInstance = this.editor.ddInstance;
if (ddInstance) {
let modeName = DDeiUtil.getConfigValue("MODE_NAME", ddInstance);
let accessCreate = DDeiUtil.isAccess(
DDeiEnumOperateType.CREATE,
null,
null,
modeName,
ddInstance
);
this.toolboxShow = accessCreate;
let accessEdit = DDeiUtil.isAccess(
DDeiEnumOperateType.EDIT,
null,
null,
modeName,
ddInstance
);
this.propertyViewShow = accessEdit;
}
},
methods: {
//强制刷新下层组件
forceRefreshParts(parts) {
let arr = [this.$refs.topComponents, this.$refs.middleComponents, this.$refs.otherComponents, this.$refs.bottomComponents];
arr.forEach((comps) => {
if (comps) {
if (Array.isArray(comps)) {
comps.forEach((comp) => {
if (comp && comp.forceRefreshParts) {
comp.forceRefreshParts(parts);
}
});
} else if (comps.forceRefreshParts) {
comps.forceRefreshParts(parts);
}
}
});
}
}
};
const SimpleLayout_vue_vue_type_style_index_0_scoped_4920d2e1_lang = "";
const SimpleLayout_vue_vue_type_style_index_1_lang = "";
const _hoisted_1$J = {
class: "ddei-editor-layout-simple",
ref: "layoutRoot"
};
const _hoisted_2$B = {
class: "top",
ref: "top"
};
const _hoisted_3$y = {
class: "middle",
ref: "middle"
};
const _hoisted_4$r = {
class: "bottom",
ref: "bottom"
};
function _sfc_render$J(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$J, [
vue.createElementVNode("div", _hoisted_2$B, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.topComponents, (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
ref_for: true,
ref: "topComponents",
editor: $props.editor
}, item.options, {
options: item.options
}), null, 16, ["editor", "options"]);
}), 256))
], 512),
vue.createElementVNode("div", _hoisted_3$y, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.middleComponents, (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
ref_for: true,
ref: "middleComponents",
editor: $props.editor,
options: item.options
}, item.options), null, 16, ["editor", "options"]);
}), 256)),
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.otherComponents, (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
ref_for: true,
ref: "otherComponents",
editor: $props.editor,
options: item.options
}, item.options), null, 16, ["editor", "options"]);
}), 256))
], 512),
vue.createElementVNode("div", _hoisted_4$r, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.bottomComponents, (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.comp), vue.mergeProps({
ref_for: true,
ref: "bottomComponents",
editor: $props.editor,
options: item.options
}, item.options), null, 16, ["editor", "options"]);
}), 256))
], 512)
], 512);
}
const Layout = /* @__PURE__ */ _export_sfc(_sfc_main$J, [["render", _sfc_render$J], ["__scopeId", "data-v-4920d2e1"]]);
const _DDeiCoreSimpleLayout = class _DDeiCoreSimpleLayout extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", Layout.name);
__publicField3(this, "defaultOptions", {
other: ["ddei-core-panel-toolbox-simple", "ddei-core-panel-topmenu-simple"],
middle: ["ddei-core-panel-canvasview"],
top: [],
bottom: []
});
__publicField3(this, "plugins", [Layout]);
}
getLayouts(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreSimpleLayout.defaultIns.defaultOptions);
if (fullConfig) {
if (fullConfig) {
if (options[Layout.name]) {
for (let i2 in options[Layout.name]) {
newOptions[i2] = options[Layout.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreSimpleLayout(newOptions);
return layouts;
}
}
return _DDeiCoreSimpleLayout;
}
static modify(fn) {
return _DDeiCoreSimpleLayout.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSimpleLayout, "defaultIns", new _DDeiCoreSimpleLayout());
let DDeiCoreSimpleLayout = _DDeiCoreSimpleLayout;
const _DDeiCoreLayouts = class _DDeiCoreLayouts extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [DDeiCoreStandLayout, DDeiCoreSimpleLayout]);
}
getLayouts(editor) {
var _a3;
let layouts = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getLayouts(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getLayouts(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
layouts = layouts.concat(ls);
}
});
return layouts;
}
static configuration(options) {
var _a3;
let layouts = new _DDeiCoreLayouts(options);
for (let i2 = 0; i2 < ((_a3 = layouts.plugins) == null ? void 0 : _a3.length); i2++) {
layouts.plugins[i2] = layouts.plugins[i2].configuration(options, true);
}
return layouts;
}
static modify(fn) {
return _DDeiCoreLayouts.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreLayouts, "defaultIns", new _DDeiCoreLayouts(null));
let DDeiCoreLayouts = _DDeiCoreLayouts;
const DialogBase$2 = {
props: {
editor: {
type: DDeiEditor,
default: null
}
},
data: function() {
return {
forceRefresh: false
};
},
methods: {
forceRefreshView: function() {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
}
});
}
},
mounted() {
this.editor.dialogs[this.dialogId].viewer = this;
}
};
const _sfc_main$I = {
name: "ddei-core-dialog-align",
extends: null,
mixins: [DialogBase$2],
props: {
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-align"
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
},
methods: {
/**
* 修改对齐方式
*/
changeAlign(v) {
var _a3;
let file = this.editor.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_a3 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _a3.size) > 0) {
this.editor.bus.push(DDeiEnumBusCommandType.ModelAlign, {
models: Array.from(stage2.selectedModels.values()),
value: v
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
},
/**
* 自动分布
*/
doAutoPos(type) {
var _a3;
let file = this.editor.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_a3 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _a3.size) > 0) {
this.editor.bus.push(DDeiEnumBusCommandType.ModelAutoPos, {
models: Array.from(stage2.selectedModels.values()),
value: type
});
this.editor.bus.executeAll();
}
}
}
};
const AlignDialog_vue_vue_type_style_index_0_scoped_6574182d_lang = "";
const _hoisted_1$I = ["id"];
const _hoisted_2$A = { class: "content" };
const _hoisted_3$x = { class: "title" };
const _hoisted_4$q = { class: "group" };
const _hoisted_5$m = { class: "title" };
const _hoisted_6$h = { class: "group_content" };
const _hoisted_7$f = { class: "group" };
const _hoisted_8$c = { class: "title" };
const _hoisted_9$b = { class: "group_content" };
function _sfc_render$I(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-align"
}, [
vue.createElementVNode("div", _hoisted_2$A, [
vue.createElementVNode("div", _hoisted_3$x, vue.toDisplayString(_ctx.editor.i18n("ddei.align")), 1),
vue.createElementVNode("div", _hoisted_4$q, [
vue.createElementVNode("div", _hoisted_5$m, vue.toDisplayString(_ctx.editor.i18n("ddei.align")) + ":", 1),
vue.createElementVNode("div", _hoisted_6$h, [
vue.createElementVNode("div", {
class: "item",
onClick: _cache[0] || (_cache[0] = ($event) => $options.changeAlign("left"))
}, _cache[8] || (_cache[8] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shape-align-left" })
], -1)
])),
vue.createElementVNode("div", {
class: "item",
onClick: _cache[1] || (_cache[1] = ($event) => $options.changeAlign("center"))
}, _cache[9] || (_cache[9] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shape-align-v" })
], -1)
])),
vue.createElementVNode("div", {
class: "item",
onClick: _cache[2] || (_cache[2] = ($event) => $options.changeAlign("right"))
}, _cache[10] || (_cache[10] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shape-align-right" })
], -1)
])),
vue.createElementVNode("div", {
class: "item",
onClick: _cache[3] || (_cache[3] = ($event) => $options.changeAlign("top"))
}, _cache[11] || (_cache[11] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shape-align-top" })
], -1)
])),
vue.createElementVNode("div", {
class: "item",
onClick: _cache[4] || (_cache[4] = ($event) => $options.changeAlign("middle"))
}, _cache[12] || (_cache[12] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shape-align-h" })
], -1)
])),
vue.createElementVNode("div", {
class: "item",
onClick: _cache[5] || (_cache[5] = ($event) => $options.changeAlign("bottom"))
}, _cache[13] || (_cache[13] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shape-align-bottom" })
], -1)
]))
])
]),
vue.createElementVNode("div", _hoisted_7$f, [
vue.createElementVNode("div", _hoisted_8$c, vue.toDisplayString(_ctx.editor.i18n("ddei.sort")) + ":", 1),
vue.createElementVNode("div", _hoisted_9$b, [
vue.createElementVNode("div", {
class: "item",
onClick: _cache[6] || (_cache[6] = ($event) => $options.doAutoPos(2))
}, _cache[14] || (_cache[14] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shape-equ-dist-v" })
], -1)
])),
vue.createElementVNode("div", {
class: "item",
onClick: _cache[7] || (_cache[7] = ($event) => $options.doAutoPos(1))
}, _cache[15] || (_cache[15] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shape-equ-dist-h" })
], -1)
]))
])
])
])
], 8, _hoisted_1$I)) : vue.createCommentVNode("", true);
}
const AlignDialog$1 = /* @__PURE__ */ _export_sfc(_sfc_main$I, [["render", _sfc_render$I], ["__scopeId", "data-v-6574182d"]]);
const _DDeiCoreAlignDialog = class _DDeiCoreAlignDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", AlignDialog$1.name);
__publicField3(this, "plugins", [AlignDialog$1]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[AlignDialog$1.name]) {
for (let i2 in options[AlignDialog$1.name]) {
newOptions[i2] = options[AlignDialog$1.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreAlignDialog(newOptions);
return panels;
}
}
return _DDeiCoreAlignDialog;
}
static modify(fn) {
return _DDeiCoreAlignDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreAlignDialog, "defaultIns", new _DDeiCoreAlignDialog(null));
let DDeiCoreAlignDialog = _DDeiCoreAlignDialog;
const _sfc_main$H = {
name: "ddei-core-dialog-changeratio",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
input: {
type: Boolean,
default: true
},
min: {
type: Number,
default: 0.1
},
max: {
type: Number,
default: 10
},
dataSource: {
type: Array,
default: [
{ text: "400%", value: 4 },
{ text: "200%", value: 2 },
{ text: "150%", value: 1.5 },
{ text: "125%", value: 1.25 },
{ text: "100%", value: 1 },
{ text: "75%", value: 0.75 },
{ text: "50%", value: 0.5 },
{ text: "25%", value: 0.25 }
]
}
},
data() {
return {
dialogId: "ddei-core-dialog-changeratio",
ratioInputValue: 100,
iMin: 0.1,
iMax: 10
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId])) {
if (this.editor.tempDialogData[this.dialogId].min || this.editor.tempDialogData[this.dialogId].min == 0) {
this.iMin = this.editor.tempDialogData[this.dialogId].min;
} else if (this.min || this.min == 0) {
this.iMin = this.min;
}
if (this.editor.tempDialogData[this.dialogId].max || this.editor.tempDialogData[this.dialogId].max == 0) {
this.iMax = this.editor.tempDialogData[this.dialogId].max;
} else if (this.max || this.max == 0) {
this.iMax = this.max;
}
if (this.editor.tempDialogData[this.dialogId].ratio > this.iMax) {
this.ratioInputValue = this.iMax * 100;
} else if (this.editor.tempDialogData[this.dialogId].ratio < this.iMin) {
this.ratioInputValue = this.iMin * 100;
} else {
this.ratioInputValue = this.editor.tempDialogData[this.dialogId].ratio * 100;
}
}
},
ok(data) {
var _a3, _b2, _c2, _d2, _e2, _f;
if (!data) {
data = 1;
}
this.ratioInputValue = data * 100;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(data);
}
},
ratioInputChange(evt) {
var _a3, _b2, _c2, _d2, _e2, _f;
if (!evt || evt.keyCode == 13) {
if (this.ratioInputValue > this.max * 100) {
this.ratioInputValue = this.max * 100;
} else if (this.ratioInputValue < this.min * 100) {
this.ratioInputValue = this.min * 100;
}
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(this.ratioInputValue / 100);
}
}
}
}
};
const ChangeRatioDialog_vue_vue_type_style_index_0_scoped_561a0908_lang = "";
const _hoisted_1$H = ["id"];
const _hoisted_2$z = { class: "content" };
const _hoisted_3$w = { class: "title" };
const _hoisted_4$p = { class: "group" };
const _hoisted_5$l = { class: "group_content" };
const _hoisted_6$g = ["onClick"];
const _hoisted_7$e = {
key: 0,
class: "item",
style: { "flex": "1", "border-top": "1px solid var(--panel-border)" }
};
const _hoisted_8$b = ["min", "max"];
function _sfc_render$H(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-changeratio"
}, [
vue.createElementVNode("div", _hoisted_2$z, [
vue.createElementVNode("div", _hoisted_3$w, vue.toDisplayString(_ctx.editor.i18n("ddei.scale")), 1),
vue.createElementVNode("div", _hoisted_4$p, [
vue.createElementVNode("div", _hoisted_5$l, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($props.dataSource, (data) => {
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "item": true, "item_selected": $data.ratioInputValue / 100 == data.value }),
onClick: ($event) => $options.ok(data.value)
}, vue.toDisplayString(data.text), 11, _hoisted_6$g)), [
[vue.vShow, (data == null ? void 0 : data.value) >= $data.iMin && (data == null ? void 0 : data.value) <= $data.iMax]
]);
}), 256)),
$props.input ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_7$e, [
vue.createTextVNode(vue.toDisplayString(_ctx.editor.i18n("ddei.precent")) + ":", 1),
vue.withDirectives(vue.createElementVNode("input", {
type: "number",
min: $data.iMin * 100,
max: $data.iMax * 100,
onKeydown: _cache[0] || (_cache[0] = ($event) => $options.ratioInputChange($event)),
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => $data.ratioInputValue = $event),
onBlur: _cache[2] || (_cache[2] = ($event) => $options.ratioInputChange()),
autocomplete: "off",
name: "ddei_bottom_input"
}, null, 40, _hoisted_8$b), [
[vue.vModelText, $data.ratioInputValue]
]),
_cache[3] || (_cache[3] = vue.createTextVNode("% "))
])) : vue.createCommentVNode("", true)
])
])
])
], 8, _hoisted_1$H)) : vue.createCommentVNode("", true);
}
const ChangeRatioDialog = /* @__PURE__ */ _export_sfc(_sfc_main$H, [["render", _sfc_render$H], ["__scopeId", "data-v-561a0908"]]);
const _DDeiCoreChangeRatioDialog = class _DDeiCoreChangeRatioDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", ChangeRatioDialog.name);
__publicField3(this, "plugins", [ChangeRatioDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ChangeRatioDialog.name]) {
for (let i2 in options[ChangeRatioDialog.name]) {
newOptions[i2] = options[ChangeRatioDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreChangeRatioDialog(newOptions);
return panels;
}
}
return _DDeiCoreChangeRatioDialog;
}
static modify(fn) {
return _DDeiCoreChangeRatioDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreChangeRatioDialog, "defaultIns", new _DDeiCoreChangeRatioDialog(null));
let DDeiCoreChangeRatioDialog = _DDeiCoreChangeRatioDialog;
const _sfc_main$G = {
name: "ddei-core-dialog-choosecontrolgroup",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-choosecontrolgroup",
subGroups: null,
menuId: null,
selectGroups: []
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2, _d2;
this.menuId = null;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_c2 = (_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId]) == null ? void 0 : _c2.selectGroups)) {
this.selectGroups = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId].selectGroups;
}
},
expandSubMenu(menuid, evt) {
if (this.menuId != menuid) {
let groups = [];
this.editor.groups.forEach((group2) => {
if (group2.subject == menuid) {
let ginfo = { id: group2.id, name: group2.name };
if (this.selectGroups.indexOf(group2.id) != -1) {
ginfo.selected = true;
} else {
ginfo.selected = false;
}
groups.push(ginfo);
}
});
this.subGroups = groups;
this.menuId = menuid;
let srcElement = evt.currentTarget;
setTimeout(() => {
let dialogEle = document.getElementById(this.editor.id + "_ddei-core-dialog-choosecontrolgroup");
let subContentEle = document.getElementById(this.editor.id + "_ddei-core-dialog-choosecontrolgroup_subcontent");
subContentEle.style.display = "block";
let dialogDomPos = DDeiUtil.getDomAbsPosition(dialogEle);
let domPos = DDeiUtil.getDomAbsPosition(srcElement);
subContentEle.style.left = domPos.left - dialogDomPos.left + srcElement.clientWidth + "px";
subContentEle.style.top = domPos.top - dialogDomPos.top + "px";
}, 50);
}
},
chooseGroup(groupid) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
let ginfo = null;
for (let i2 = 0; i2 < this.subGroups.length; i2++) {
if (this.subGroups[i2].id == groupid) {
ginfo = this.subGroups[i2];
break;
}
}
if (ginfo) {
ginfo.selected = !ginfo.selected;
if (ginfo.selected) {
if (this.selectGroups.indexOf(ginfo.id) == -1) {
this.selectGroups.push(ginfo.id);
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.select) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.select(ginfo.id, true);
}
}
} else {
if (this.selectGroups.indexOf(ginfo.id) != -1) {
this.selectGroups.splice(this.selectGroups.indexOf(ginfo.id), 1);
if ((_i = (_h = (_g = this.editor) == null ? void 0 : _g.tempDialogData[this.dialogId]) == null ? void 0 : _h.callback) == null ? void 0 : _i.select) {
(_l = (_k = (_j = this.editor) == null ? void 0 : _j.tempDialogData[this.dialogId]) == null ? void 0 : _k.callback) == null ? void 0 : _l.select(ginfo.id, false);
}
}
}
}
}
}
};
const ChooseControlGroupDialog_vue_vue_type_style_index_0_scoped_d0e0cfd9_lang = "";
const _hoisted_1$G = ["id"];
const _hoisted_2$y = { class: "content" };
const _hoisted_3$v = { class: "title" };
const _hoisted_4$o = { class: "group" };
const _hoisted_5$k = { class: "groupname" };
const _hoisted_6$f = { class: "groupname" };
const _hoisted_7$d = ["id"];
const _hoisted_8$a = { class: "group" };
const _hoisted_9$a = ["onClick"];
const _hoisted_10$5 = ["onUpdate:modelValue", "name"];
const _hoisted_11$5 = { class: "groupname" };
function _sfc_render$G(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-choosecontrolgroup"
}, [
vue.createElementVNode("div", _hoisted_2$y, [
vue.createElementVNode("div", _hoisted_3$v, vue.toDisplayString(_ctx.editor.i18n("ddei.chooseShapeGroups")), 1),
vue.createElementVNode("div", _hoisted_4$o, [
vue.createElementVNode("div", {
class: "item",
onMousemove: _cache[0] || (_cache[0] = ($event) => $options.expandSubMenu("basic", $event))
}, [
_cache[2] || (_cache[2] = vue.createElementVNode("svg", {
class: "icon groupicon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shapes-catalogy" })
], -1)),
vue.createElementVNode("div", _hoisted_5$k, vue.toDisplayString(_ctx.editor.i18n("ddei.basicSubject")), 1),
_cache[3] || (_cache[3] = vue.createElementVNode("svg", {
class: "icon expand",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-right" })
], -1))
], 32),
vue.createElementVNode("div", {
class: "item",
onMousemove: _cache[1] || (_cache[1] = ($event) => $options.expandSubMenu("uml", $event))
}, [
_cache[4] || (_cache[4] = vue.createElementVNode("svg", {
class: "icon groupicon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-groups" })
], -1)),
vue.createElementVNode("div", _hoisted_6$f, vue.toDisplayString(_ctx.editor.i18n("ddei.umlSubject")), 1),
_cache[5] || (_cache[5] = vue.createElementVNode("svg", {
class: "icon expand",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-right" })
], -1))
], 32)
])
]),
vue.withDirectives(vue.createElementVNode("div", {
class: "subcontent",
id: ((_b2 = _ctx.editor) == null ? void 0 : _b2.id) + "_ddei-core-dialog-choosecontrolgroup_subcontent"
}, [
vue.createElementVNode("div", _hoisted_8$a, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.subGroups, (group2) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: "item",
onClick: ($event) => $options.chooseGroup(group2.id)
}, [
vue.withDirectives(vue.createElementVNode("input", {
type: "checkbox",
"onUpdate:modelValue": ($event) => group2.selected = $event,
style: { "pointer-events": "none" },
name: group2.id,
autocomplete: "off"
}, null, 8, _hoisted_10$5), [
[vue.vModelCheckbox, group2.selected]
]),
vue.createElementVNode("div", _hoisted_11$5, vue.toDisplayString(_ctx.editor.i18n(group2.name)), 1)
], 8, _hoisted_9$a);
}), 256))
])
], 8, _hoisted_7$d), [
[vue.vShow, ((_c2 = $data.subGroups) == null ? void 0 : _c2.length) > 0]
])
], 8, _hoisted_1$G)) : vue.createCommentVNode("", true);
}
const ChooseControlGroupDialog = /* @__PURE__ */ _export_sfc(_sfc_main$G, [["render", _sfc_render$G], ["__scopeId", "data-v-d0e0cfd9"]]);
const _DDeiCoreChooseControlGroupDialog = class _DDeiCoreChooseControlGroupDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", ChooseControlGroupDialog.name);
__publicField3(this, "plugins", [ChooseControlGroupDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ChooseControlGroupDialog.name]) {
for (let i2 in options[ChooseControlGroupDialog.name]) {
newOptions[i2] = options[ChooseControlGroupDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreChooseControlGroupDialog(newOptions);
return panels;
}
}
return _DDeiCoreChooseControlGroupDialog;
}
static modify(fn) {
return _DDeiCoreChooseControlGroupDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreChooseControlGroupDialog, "defaultIns", new _DDeiCoreChooseControlGroupDialog(null));
let DDeiCoreChooseControlGroupDialog = _DDeiCoreChooseControlGroupDialog;
const _sfc_main$F = {
name: "ddei-core-dialog-closefile",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-closefile"
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
},
methods: {
ok() {
var _a3, _b2, _c2, _d2, _e2, _f;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok();
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-closefile");
},
cancel() {
var _a3, _b2, _c2;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.cancel) {
this.editor.tempDialogData[this.dialogId].callback.cancel();
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-closefile");
},
abort() {
var _a3, _b2, _c2;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.abort) {
this.editor.tempDialogData[this.dialogId].callback.abort();
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-closefile");
}
}
};
const CloseFileConfirmDialog_vue_vue_type_style_index_0_scoped_929ef917_lang = "";
const _hoisted_1$F = ["id"];
const _hoisted_2$x = { class: "content" };
const _hoisted_3$u = { class: "header" };
const _hoisted_4$n = { class: "tail" };
function _sfc_render$F(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-closefile"
}, [
vue.createElementVNode("div", _hoisted_2$x, [
vue.createElementVNode("div", _hoisted_3$u, [
_cache[5] || (_cache[5] = vue.createElementVNode("svg", {
class: "icon warn",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-warn" })
], -1)),
vue.createElementVNode("span", null, vue.toDisplayString(_ctx.editor.i18n("ddei.confirm-save-file")), 1),
_cache[6] || (_cache[6] = vue.createElementVNode("div", { style: { "flex": "1" } }, null, -1)),
(vue.openBlock(), vue.createElementBlock("svg", {
class: "icon close",
"aria-hidden": "true",
onClick: _cache[0] || (_cache[0] = (...args) => $options.cancel && $options.cancel(...args))
}, _cache[4] || (_cache[4] = [
vue.createElementVNode("use", { "xlink:href": "#icon-close" }, null, -1)
])))
]),
_cache[7] || (_cache[7] = vue.createElementVNode("div", { class: "msg" }, null, -1)),
vue.createElementVNode("div", _hoisted_4$n, [
vue.createElementVNode("div", {
class: "button button-main",
onClick: _cache[1] || (_cache[1] = (...args) => $options.ok && $options.ok(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.save")), 1),
vue.createElementVNode("div", {
class: "button",
onClick: _cache[2] || (_cache[2] = (...args) => $options.abort && $options.abort(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.abort")), 1),
vue.createElementVNode("div", {
class: "button",
onClick: _cache[3] || (_cache[3] = (...args) => $options.cancel && $options.cancel(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.cancel")), 1)
])
])
], 8, _hoisted_1$F)) : vue.createCommentVNode("", true);
}
const CloseFileConfirmDialog = /* @__PURE__ */ _export_sfc(_sfc_main$F, [["render", _sfc_render$F], ["__scopeId", "data-v-929ef917"]]);
const _DDeiCoreCloseFileConfirmDialog = class _DDeiCoreCloseFileConfirmDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", CloseFileConfirmDialog.name);
__publicField3(this, "plugins", [CloseFileConfirmDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[CloseFileConfirmDialog.name]) {
for (let i2 in options[CloseFileConfirmDialog.name]) {
newOptions[i2] = options[CloseFileConfirmDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreCloseFileConfirmDialog(newOptions);
return panels;
}
}
return _DDeiCoreCloseFileConfirmDialog;
}
static modify(fn) {
return _DDeiCoreCloseFileConfirmDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreCloseFileConfirmDialog, "defaultIns", new _DDeiCoreCloseFileConfirmDialog(null));
let DDeiCoreCloseFileConfirmDialog = _DDeiCoreCloseFileConfirmDialog;
const _sfc_main$E = {
name: "ddei-core-dialog-collfile",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-collfile"
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
},
methods: {
ok() {
var _a3, _b2, _c2, _d2, _e2, _f;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok();
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-collfile");
},
cancel() {
var _a3, _b2, _c2;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.cancel) {
this.editor.tempDialogData[this.dialogId].callback.cancel();
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-collfile");
}
}
};
const CollFileConfirmDialog_vue_vue_type_style_index_0_scoped_068f2102_lang = "";
const _hoisted_1$E = ["id"];
const _hoisted_2$w = { class: "content" };
const _hoisted_3$t = { class: "header" };
const _hoisted_4$m = { class: "tail" };
function _sfc_render$E(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-collfile"
}, [
vue.createElementVNode("div", _hoisted_2$w, [
vue.createElementVNode("div", _hoisted_3$t, [
_cache[4] || (_cache[4] = vue.createElementVNode("svg", {
class: "icon warn",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shoucang" })
], -1)),
vue.createElementVNode("span", null, vue.toDisplayString(_ctx.editor.i18n("ddei.collection")), 1),
_cache[5] || (_cache[5] = vue.createElementVNode("div", { style: { "flex": "1" } }, null, -1)),
(vue.openBlock(), vue.createElementBlock("svg", {
class: "icon close",
"aria-hidden": "true",
onClick: _cache[0] || (_cache[0] = (...args) => $options.cancel && $options.cancel(...args))
}, _cache[3] || (_cache[3] = [
vue.createElementVNode("use", { "xlink:href": "#icon-close" }, null, -1)
])))
]),
_cache[6] || (_cache[6] = vue.createElementVNode("div", { class: "msg" }, null, -1)),
vue.createElementVNode("div", _hoisted_4$m, [
vue.createElementVNode("div", {
class: "button button-main",
onClick: _cache[1] || (_cache[1] = (...args) => $options.ok && $options.ok(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.confirm")), 1),
vue.createElementVNode("div", {
class: "button",
onClick: _cache[2] || (_cache[2] = (...args) => $options.cancel && $options.cancel(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.cancel")), 1)
])
])
], 8, _hoisted_1$E)) : vue.createCommentVNode("", true);
}
const CollFileConfirmDialog = /* @__PURE__ */ _export_sfc(_sfc_main$E, [["render", _sfc_render$E], ["__scopeId", "data-v-068f2102"]]);
const _DDeiCoreCollFileConfirmDialog = class _DDeiCoreCollFileConfirmDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", CollFileConfirmDialog.name);
__publicField3(this, "plugins", [CollFileConfirmDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[CollFileConfirmDialog.name]) {
for (let i2 in options[CollFileConfirmDialog.name]) {
newOptions[i2] = options[CollFileConfirmDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreCollFileConfirmDialog(newOptions);
return panels;
}
}
return _DDeiCoreCollFileConfirmDialog;
}
static modify(fn) {
return _DDeiCoreCollFileConfirmDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreCollFileConfirmDialog, "defaultIns", new _DDeiCoreCollFileConfirmDialog(null));
let DDeiCoreCollFileConfirmDialog = _DDeiCoreCollFileConfirmDialog;
const _sfc_main$D = {
name: "ddei-core-dialog-linepointtype",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-linepointtype",
value: [],
dataSource: null
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_c2 = (_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId]) == null ? void 0 : _c2.value)) {
this.value = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId].value;
}
if (((_e2 = this.editor) == null ? void 0 : _e2.tempDialogData) && ((_g = (_f = this.editor) == null ? void 0 : _f.tempDialogData[this.dialogId]) == null ? void 0 : _g.dataSource)) {
this.dataSource = (_h = this.editor) == null ? void 0 : _h.tempDialogData[this.dialogId].dataSource;
}
},
select(value) {
var _a3, _b2, _c2, _d2, _e2, _f;
this.value = value;
if (this.value) {
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(this.value);
}
}
},
selectAndConfirm(value) {
var _a3, _b2, _c2, _d2, _e2, _f;
this.value = value;
if (this.value) {
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(this.value);
}
}
this.ok();
},
ok() {
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-linepointtype");
}
}
};
const LinePointTypeDialog_vue_vue_type_style_index_0_scoped_ec516138_lang = "";
const _hoisted_1$D = ["id"];
const _hoisted_2$v = { class: "content" };
const _hoisted_3$s = { class: "group" };
const _hoisted_4$l = { class: "title" };
const _hoisted_5$j = { class: "group_content" };
const _hoisted_6$e = ["onClick", "onDblclick"];
function _sfc_render$D(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-linepointtype"
}, [
vue.createElementVNode("div", _hoisted_2$v, [
vue.createElementVNode("div", _hoisted_3$s, [
vue.createElementVNode("div", _hoisted_4$l, vue.toDisplayString(_ctx.editor.i18n("ddei.property.linePointType")), 1),
vue.createElementVNode("div", _hoisted_5$j, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (data) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "item": true, "item-selected": JSON.stringify($data.value) == JSON.stringify(data.value) }),
onClick: ($event) => $options.select(data.value),
onDblclick: ($event) => $options.selectAndConfirm(data.value)
}, vue.toDisplayString(_ctx.editor.i18n(data.text)), 43, _hoisted_6$e);
}), 256))
])
])
])
], 8, _hoisted_1$D)) : vue.createCommentVNode("", true);
}
const LinePointTypeDialog = /* @__PURE__ */ _export_sfc(_sfc_main$D, [["render", _sfc_render$D], ["__scopeId", "data-v-ec516138"]]);
const _DDeiCoreLinePointTypeDialog = class _DDeiCoreLinePointTypeDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", LinePointTypeDialog.name);
__publicField3(this, "plugins", [LinePointTypeDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[LinePointTypeDialog.name]) {
for (let i2 in options[LinePointTypeDialog.name]) {
newOptions[i2] = options[LinePointTypeDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreLinePointTypeDialog(newOptions);
return panels;
}
}
return _DDeiCoreLinePointTypeDialog;
}
static modify(fn) {
return _DDeiCoreLinePointTypeDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreLinePointTypeDialog, "defaultIns", new _DDeiCoreLinePointTypeDialog(null));
let DDeiCoreLinePointTypeDialog = _DDeiCoreLinePointTypeDialog;
const _sfc_main$C = {
name: "ddei-core-dialog-linetype",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-linetype",
value: 1
//当前选中值
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2;
let value = 1;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId])) {
value = (_c2 = this.editor) == null ? void 0 : _c2.tempDialogData[this.dialogId].value;
}
this.value = value;
},
/**
* 修改文本对齐方式
*/
changeType(v) {
var _a3, _b2, _c2, _d2, _e2, _f;
this.value = v;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(this.value);
}
},
/**
* 修改文本对齐方式
*/
ok(v) {
this.changeType(v);
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-linetype");
}
}
};
const LineTypeDialog_vue_vue_type_style_index_0_scoped_5fc9eaad_lang = "";
const _hoisted_1$C = ["id"];
const _hoisted_2$u = { class: "content" };
const _hoisted_3$r = { class: "title" };
const _hoisted_4$k = { class: "group" };
const _hoisted_5$i = { class: "group_content" };
function _sfc_render$C(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-linetype"
}, [
vue.createElementVNode("div", _hoisted_2$u, [
vue.createElementVNode("div", _hoisted_3$r, vue.toDisplayString(_ctx.editor.i18n("ddei.lineType")), 1),
vue.createElementVNode("div", _hoisted_4$k, [
vue.createElementVNode("div", _hoisted_5$i, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 1 }),
onClick: _cache[0] || (_cache[0] = ($event) => $options.changeType(1)),
onDblclick: _cache[1] || (_cache[1] = ($event) => $options.ok(1))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.lineType1")), 35),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 2 }),
onClick: _cache[2] || (_cache[2] = ($event) => $options.changeType(2)),
onDblclick: _cache[3] || (_cache[3] = ($event) => $options.ok(2))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.lineType2")), 35),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 3 }),
onClick: _cache[4] || (_cache[4] = ($event) => $options.changeType(3)),
onDblclick: _cache[5] || (_cache[5] = ($event) => $options.ok(3))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.lineType3")), 35)
])
])
])
], 8, _hoisted_1$C)) : vue.createCommentVNode("", true);
}
const LineTypeDialog = /* @__PURE__ */ _export_sfc(_sfc_main$C, [["render", _sfc_render$C], ["__scopeId", "data-v-5fc9eaad"]]);
const _DDeiCoreLineTypeDialog = class _DDeiCoreLineTypeDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", LineTypeDialog.name);
__publicField3(this, "plugins", [LineTypeDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[LineTypeDialog.name]) {
for (let i2 in options[LineTypeDialog.name]) {
newOptions[i2] = options[LineTypeDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreLineTypeDialog(newOptions);
return panels;
}
}
return _DDeiCoreLineTypeDialog;
}
static modify(fn) {
return _DDeiCoreLineTypeDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreLineTypeDialog, "defaultIns", new _DDeiCoreLineTypeDialog(null));
let DDeiCoreLineTypeDialog = _DDeiCoreLineTypeDialog;
const _sfc_main$B = {
name: "ddei-core-dialog-managerlayers",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-managerlayers",
allowAddLayer: true,
allowEditLayes: true,
//是否允许编辑多图层
allowOpenMultLayers: true,
currentStage: null,
file: null
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2;
this.allowOpenMultLayers = DDeiEditorUtil.getConfigValue(
"GLOBAL_ALLOW_OPEN_MULT_LAYERS",
this.editor
);
this.allowEditLayes = ((_a3 = this.editor.ddInstance) == null ? void 0 : _a3.AC_DESIGN_EDIT) != false ? true : false;
this.allowAddLayer = this.allowEditLayes && DDeiUtil.isAccess(
DDeiEnumOperateType.CREATE,
{ modelType: "DDeiLayer" },
DDeiUtil.getConfigValue("MODE_NAME", this.editor.ddInstance),
this.editor.ddInstance
);
let file = (_c2 = this.editor) == null ? void 0 : _c2.files[(_b2 = this.editor) == null ? void 0 : _b2.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
this.currentStage = sheet == null ? void 0 : sheet.stage;
this.file = file;
},
/**
* layer开始拖拽移动
*/
layerDragStart(layerEle, evt) {
this.dragLayerEle = evt.target;
},
/**
* 拖拽layer移动
*/
layerDragOver(e) {
if (this.dragLayerEle) {
let parentDiv = this.dragLayerEle.parentElement;
let sourceIndex = -1;
let targetIndex = -1;
let children = parentDiv.children;
for (let i2 = 1; i2 < children.length; i2++) {
children[i2].style.borderTop = "";
children[i2].style.borderBottom = "";
if (children[i2] == this.dragLayerEle) {
sourceIndex = i2;
} else if (e.target.parentElement == children[i2]) {
targetIndex = i2;
}
}
if (sourceIndex != -1 && targetIndex != -1) {
this.sourceLayerIndex = sourceIndex - 1;
if (targetIndex == children.length - 1) {
let pos = DDeiUtil.getDomAbsPosition(children[targetIndex]);
let halfPos = pos.top + children[targetIndex].offsetHeight / 2;
if (halfPos <= e.clientY && e.clientY <= pos.top + children[targetIndex].offsetHeight) {
this.changeLayerIndex = targetIndex;
children[targetIndex].style.borderBottom = "2px solid #017fff";
} else {
this.changeLayerIndex = targetIndex - 1;
children[targetIndex].style.borderTop = "2px solid #017fff";
}
} else {
this.changeLayerIndex = targetIndex - 1;
children[targetIndex].style.borderTop = "2px solid #017fff";
}
}
e.preventDefault();
}
},
/**
* 拖拽layer放开
*/
layerDragDrop(e) {
var _a3;
if ((this.sourceLayerIndex || this.sourceLayerIndex == 0) && (this.changeLayerIndex || this.changeLayerIndex == 0)) {
let layers = this.currentStage.layers;
let sourceLayer = this.currentStage.layers[this.sourceLayerIndex];
let currentLayer = this.currentStage.layers[this.currentStage.layerIndex];
layers[this.sourceLayerIndex] = null;
layers.splice(this.changeLayerIndex, 0, sourceLayer);
for (let j2 = layers.length; j2 >= 0; j2--) {
if (layers[j2] == null) {
layers.splice(j2, 1);
}
}
for (let j2 = layers.length; j2 >= 0; j2--) {
if (currentLayer == layers[j2]) {
this.currentStage.layerIndex = j2;
}
}
(_a3 = this.editor.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
this.editor.bus.push(DDeiEditorEnumBusCommandType.AddFileHistroy);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
this.editor.changeState(DDeiEditorState.DESIGNING);
}
let children = this.dragLayerEle.parentElement.children;
for (let i2 = 1; i2 < children.length; i2++) {
children[i2].style.borderTop = "";
children[i2].style.borderBottom = "";
}
this.dragLayerEle = null;
this.sourceLayerIndex = null;
this.changeLayerIndex = null;
},
/**
* 拖拽layer离开
*/
layerDragCancel(e) {
if (this.dragLayerEle) {
let children = this.dragLayerEle.parentElement.children;
for (let i2 = 1; i2 < children.length; i2++) {
children[i2].style.borderTop = "";
children[i2].style.borderBottom = "";
}
this.sourceLayerIndex = null;
this.changeLayerIndex = null;
}
},
//创建新图层
createNewLayer(index) {
var _a3;
if (this.allowAddLayer) {
let newLayer = this.currentStage.addLayer(null, index);
newLayer.initRender();
this.editor.bus.push(
DDeiEnumBusCommandType.CancelCurLevelSelectedModels
);
this.editor.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
this.editor.bus.push(DDeiEnumBusCommandType.AddHistroy);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
(_a3 = this.editor.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
this.editor.changeState(DDeiEditorState.DESIGNING);
}
},
//移除图层
removeLayer(index) {
var _a3;
this.currentStage.removeLayer(index);
this.editor.bus.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels);
this.editor.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
this.editor.bus.push(DDeiEnumBusCommandType.AddHistroy);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
(_a3 = this.editor.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
this.editor.changeState(DDeiEditorState.DESIGNING);
},
//设置图层显示或隐藏
displayOrShowLayer(layer2) {
var _a3;
if (layer2.display == 0) {
layer2.display = 1;
} else {
layer2.display = 0;
}
this.editor.bus.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels);
this.editor.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
this.editor.bus.push(DDeiEnumBusCommandType.AddHistroy);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
(_a3 = this.editor.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
this.editor.changeState(DDeiEditorState.DESIGNING);
},
//设置图层锁定和解锁
lockOrUnLockLayer(layer2) {
layer2.lock = !layer2.lock;
},
//设置图层打印或不打印
printOrNoPrintLayer(layer2) {
layer2.print = !layer2.print;
},
//切换当前图层
changeLayer(index, evt) {
var _a3;
this.currentStage.changeLayer(index);
this.currentStage.displayLayer(null, true);
if (evt.target.className == "not_temp_display") {
this.currentStage.layers[index].tempDisplay = true;
} else {
this.currentStage.layers[index].tempDisplay = false;
}
this.editor.bus.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels);
this.editor.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
(_a3 = this.editor.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
this.editor.changeState(DDeiEditorState.DESIGNING);
},
/**
* 开始修改图层名称
*/
startChangeLayerName(layer2, evt) {
let ele = evt.target;
let domPos = DDeiUtil.getDomAbsPosition(ele);
let editor = DDeiEditor.ACTIVE_INSTANCE;
let editorEle = document.getElementById(editor.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let input = document.getElementById(editor.id + "_change_layer_name_input");
this.currentChangeLayer = layer2;
if (!input) {
input = document.createElement("input");
input.setAttribute("id", editor.id + "_change_layer_name_input");
input.style.position = "absolute";
input.style.fontSize = "14px";
input.style.zIndex = 999;
editorEle.appendChild(input);
const that = this;
input.onblur = () => {
var _a3;
if (input.value) {
let editor2 = this.editor;
if (input.value != that.currentChangeLayer.name) {
that.currentChangeLayer.name = input.value;
(_a3 = editor2.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
editor2.bus.push(DDeiEditorEnumBusCommandType.AddFileHistroy);
editor2.bus.executeAll();
}
input.style.display = "none";
input.style.left = "0px";
input.style.top = "0px";
input.value = "";
}
};
input.onkeydown = (e) => {
var _a3;
if (e.keyCode == 13) {
let editor2 = this.editor;
if (input.value != that.currentChangeLayer.name) {
that.currentChangeLayer.name = input.value;
(_a3 = editor2.editorViewer) == null ? void 0 : _a3.changeFileModifyDirty();
editor2.bus.push(DDeiEditorEnumBusCommandType.AddFileHistroy);
editor2.bus.executeAll();
}
input.style.display = "none";
input.style.left = "0px";
input.style.top = "0px";
input.value = "";
} else if (e.keyCode == 27) {
input.style.display = "none";
input.style.left = "0px";
input.style.top = "0px";
input.value = "";
}
};
}
input.style.width = ele.offsetWidth + "px";
input.style.height = ele.offsetHeight + "px";
input.style.left = domPos.left - editorDomPos.left + "px";
input.style.top = domPos.top - editorDomPos.top + "px";
input.style.outline = "1px solid #017fff";
input.style.border = "none";
input.style.borderRadius = "1px";
input.value = layer2.name;
input.style.display = "block";
input.selectionStart = 0;
input.selectionEnd = input.value.length;
input.style.background = "var(--background)";
input.style.color = "var(--text)";
input.focus();
this.editor.changeState(DDeiEditorState.PROPERTY_EDITING);
}
}
};
const ManageLayersDialog_vue_vue_type_style_index_0_scoped_f8156347_lang = "";
const _hoisted_1$B = ["id"];
const _hoisted_2$t = { class: "content" };
const _hoisted_3$q = { class: "title" };
const _hoisted_4$j = { class: "group" };
const _hoisted_5$h = { class: "group_content" };
const _hoisted_6$d = { style: { "grid-column": "1/8" } };
const _hoisted_7$c = ["draggable", "onDragstart"];
const _hoisted_8$9 = ["onDblclick"];
const _hoisted_9$9 = ["onClick"];
const _hoisted_10$4 = { style: { "grid-column": "1/4", "font-weight": "normal" } };
const _hoisted_11$4 = ["onClick"];
const _hoisted_12$3 = ["onClick"];
const _hoisted_13$3 = {
key: 0,
"xlink:href": "#icon-close-eye"
};
const _hoisted_14$2 = {
key: 1,
"xlink:href": "#icon-open-eye"
};
const _hoisted_15$1 = ["onClick"];
const _hoisted_16$1 = {
key: 0,
"xlink:href": "#icon-lock"
};
const _hoisted_17$1 = {
key: 1,
"xlink:href": "#icon-unlock"
};
const _hoisted_18$1 = ["value", "onMousedown", "checked"];
const _hoisted_19$1 = ["onClick"];
const _hoisted_20$1 = {
key: 0,
"xlink:href": "#icon-print-disabled"
};
const _hoisted_21$1 = {
key: 1,
"xlink:href": "#icon-print"
};
function _sfc_render$B(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2;
return _ctx.forceRefresh && $data.allowOpenMultLayers ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-managerlayers"
}, [
vue.createElementVNode("div", _hoisted_2$t, [
vue.createElementVNode("div", _hoisted_3$q, vue.toDisplayString(_ctx.editor.i18n("ddei.layerName")), 1),
vue.createElementVNode("div", _hoisted_4$j, [
vue.createElementVNode("div", _hoisted_5$h, [
vue.withDirectives(vue.createElementVNode("div", {
class: "item",
onClick: _cache[0] || (_cache[0] = ($event) => $options.createNewLayer(0))
}, [
vue.createElementVNode("span", _hoisted_6$d, vue.toDisplayString(_ctx.editor.i18n("ddei.newLayer")), 1),
_cache[4] || (_cache[4] = vue.createElementVNode("svg", {
class: "icon extbtn",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-add-layer" })
], -1))
], 512), [
[vue.vShow, $data.allowAddLayer]
]),
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_b2 = $data.currentStage) == null ? void 0 : _b2.layers, (layer2, index) => {
var _a4, _b3;
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "item": true, "current": ((_a4 = $data.currentStage) == null ? void 0 : _a4.layerIndex) === index }),
draggable: $data.allowEditLayes,
onDragstart: ($event) => $options.layerDragStart(index, $event),
onDragover: _cache[1] || (_cache[1] = ($event) => $options.layerDragOver($event)),
onDrop: _cache[2] || (_cache[2] = ($event) => $options.layerDragDrop($event)),
onDragleave: _cache[3] || (_cache[3] = ($event) => $options.layerDragCancel($event))
}, [
vue.createElementVNode("span", {
style: { "grid-column": "1/8" },
onDblclick: ($event) => $data.allowEditLayes && $options.startChangeLayerName(layer2, $event)
}, vue.toDisplayString(layer2.name ? layer2.name : _ctx.editor.i18n("ddei.layerName")), 41, _hoisted_8$9),
vue.withDirectives((vue.openBlock(), vue.createElementBlock("svg", {
class: "icon",
"aria-hidden": "true",
onClick: ($event) => $options.removeLayer(index)
}, _cache[5] || (_cache[5] = [
vue.createElementVNode("use", { "xlink:href": "#icon-remove" }, null, -1)
]), 8, _hoisted_9$9)), [
[vue.vShow, $data.allowEditLayes]
]),
vue.createElementVNode("span", _hoisted_10$4, vue.toDisplayString(_ctx.editor.i18n("ddei.shapes")) + ":" + vue.toDisplayString(layer2.modelNumber), 1),
vue.withDirectives((vue.openBlock(), vue.createElementBlock("svg", {
class: "icon",
"aria-hidden": "true",
onClick: ($event) => $options.createNewLayer(index)
}, _cache[6] || (_cache[6] = [
vue.createElementVNode("use", { "xlink:href": "#icon-add-layer" }, null, -1)
]), 8, _hoisted_11$4)), [
[vue.vShow, $data.allowAddLayer]
]),
(vue.openBlock(), vue.createElementBlock("svg", {
class: "icon",
onClick: ($event) => $options.displayOrShowLayer(layer2)
}, [
layer2.display == 0 && !layer2.tempDisplay ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_13$3)) : vue.createCommentVNode("", true),
!(layer2.display == 0 && !layer2.tempDisplay) ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_14$2)) : vue.createCommentVNode("", true)
], 8, _hoisted_12$3)),
(vue.openBlock(), vue.createElementBlock("svg", {
class: "icon",
onClick: ($event) => $options.lockOrUnLockLayer(layer2)
}, [
layer2.lock ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_16$1)) : vue.createCommentVNode("", true),
!layer2.lock ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_17$1)) : vue.createCommentVNode("", true)
], 8, _hoisted_15$1)),
vue.createElementVNode("input", {
type: "radio",
class: vue.normalizeClass({ "not_temp_display": !layer2.tempDisplay }),
name: "rdo_layers",
value: layer2.id,
onMousedown: ($event) => $options.changeLayer(index, $event),
checked: ((_b3 = $data.currentStage) == null ? void 0 : _b3.layerIndex) === index,
autocomplete: "off"
}, null, 42, _hoisted_18$1),
(vue.openBlock(), vue.createElementBlock("svg", {
class: "icon",
onClick: ($event) => $options.printOrNoPrintLayer(layer2)
}, [
!layer2.print ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_20$1)) : vue.createCommentVNode("", true),
layer2.print ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_21$1)) : vue.createCommentVNode("", true)
], 8, _hoisted_19$1))
], 42, _hoisted_7$c);
}), 256))
])
])
])
], 8, _hoisted_1$B)) : vue.createCommentVNode("", true);
}
const ManageLayersDialog = /* @__PURE__ */ _export_sfc(_sfc_main$B, [["render", _sfc_render$B], ["__scopeId", "data-v-f8156347"]]);
const _DDeiCoreManageLayersDialog = class _DDeiCoreManageLayersDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", ManageLayersDialog.name);
__publicField3(this, "plugins", [ManageLayersDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ManageLayersDialog.name]) {
for (let i2 in options[ManageLayersDialog.name]) {
newOptions[i2] = options[ManageLayersDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreManageLayersDialog(newOptions);
return panels;
}
}
return _DDeiCoreManageLayersDialog;
}
static modify(fn) {
return _DDeiCoreManageLayersDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreManageLayersDialog, "defaultIns", new _DDeiCoreManageLayersDialog(null));
let DDeiCoreManageLayersDialog = _DDeiCoreManageLayersDialog;
const _sfc_main$A = {
name: "ddei-core-dialog-mergecompose",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-mergecompose"
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
},
methods: {
//是否可以取消组合
canCancelMerge() {
var _a3, _b2;
let file = (_a3 = this.editor) == null ? void 0 : _a3.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_b2 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _b2.size) > 0) {
let models = Array.from(stage2 == null ? void 0 : stage2.selectedModels.values());
if (models[0].baseModelType == "DDeiContainer" && models[0].layout == "compose") {
return true;
}
}
return false;
},
//是否可以组合
canMerge() {
var _a3, _b2;
let file = (_a3 = this.editor) == null ? void 0 : _a3.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_b2 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _b2.size) > 1) {
return true;
}
return false;
},
/**
* 执行组合
*/
doMerge() {
var _a3, _b2;
let file = (_a3 = this.editor) == null ? void 0 : _a3.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_b2 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _b2.size) > 1) {
this.editor.bus.push(DDeiEnumBusCommandType.ModelMerge);
this.editor.bus.executeAll();
}
},
/**
* 执行取消组合
*/
doCancelMerge() {
var _a3, _b2;
let file = (_a3 = this.editor) == null ? void 0 : _a3.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_b2 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _b2.size) > 0) {
this.editor.bus.push(DDeiEnumBusCommandType.ModelCancelMerge);
this.editor.bus.executeAll();
}
}
}
};
const MergeComposeDialog_vue_vue_type_style_index_0_scoped_eb54102e_lang = "";
const _hoisted_1$A = ["id"];
const _hoisted_2$s = { class: "content" };
const _hoisted_3$p = { class: "title" };
const _hoisted_4$i = { class: "group" };
const _hoisted_5$g = { class: "group_content" };
const _hoisted_6$c = { class: "text" };
const _hoisted_7$b = { class: "text" };
function _sfc_render$A(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-mergecompose"
}, [
vue.createElementVNode("div", _hoisted_2$s, [
vue.createElementVNode("div", _hoisted_3$p, vue.toDisplayString(_ctx.editor.i18n("ddei.combina")), 1),
vue.createElementVNode("div", _hoisted_4$i, [
vue.createElementVNode("div", _hoisted_5$g, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item_disabled": !$options.canMerge(), "item": $options.canMerge() }),
onClick: _cache[0] || (_cache[0] = ($event) => $options.canMerge() && $options.doMerge())
}, [
_cache[2] || (_cache[2] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-merge" })
], -1)),
vue.createElementVNode("div", _hoisted_6$c, vue.toDisplayString(_ctx.editor.i18n("ddei.combina")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item_disabled": !$options.canCancelMerge(), "item": $options.canCancelMerge() }),
onClick: _cache[1] || (_cache[1] = ($event) => $options.canCancelMerge() && $options.doCancelMerge())
}, [
_cache[3] || (_cache[3] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-cancel-merge" })
], -1)),
vue.createElementVNode("div", _hoisted_7$b, vue.toDisplayString(_ctx.editor.i18n("ddei.cancelCombina")), 1)
], 2)
])
])
])
], 8, _hoisted_1$A)) : vue.createCommentVNode("", true);
}
const MergeComposeDialog = /* @__PURE__ */ _export_sfc(_sfc_main$A, [["render", _sfc_render$A], ["__scopeId", "data-v-eb54102e"]]);
const _DDeiCoreMergeComposeDialog = class _DDeiCoreMergeComposeDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", MergeComposeDialog.name);
__publicField3(this, "plugins", [MergeComposeDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[MergeComposeDialog.name]) {
for (let i2 in options[MergeComposeDialog.name]) {
newOptions[i2] = options[MergeComposeDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreMergeComposeDialog(newOptions);
return panels;
}
}
return _DDeiCoreMergeComposeDialog;
}
static modify(fn) {
return _DDeiCoreMergeComposeDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreMergeComposeDialog, "defaultIns", new _DDeiCoreMergeComposeDialog(null));
let DDeiCoreMergeComposeDialog = _DDeiCoreMergeComposeDialog;
const _sfc_main$z = {
name: "ddei-core-dialog-changeposition",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-changeposition"
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
},
methods: {
//是否置于上层
canPush(type) {
return true;
},
//修改图形层次
doPush(v) {
var _a3;
let file = (_a3 = this.editor) == null ? void 0 : _a3.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
let stageRender = stage2 == null ? void 0 : stage2.render;
let optContainer = stageRender == null ? void 0 : stageRender.currentOperateContainer;
if (optContainer) {
this.editor.bus.push(DDeiEnumBusCommandType.ModelPush, {
container: optContainer,
type: v
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
}
}
};
const PositionDialog_vue_vue_type_style_index_0_scoped_70a473a4_lang = "";
const _hoisted_1$z = ["id"];
const _hoisted_2$r = { class: "content" };
const _hoisted_3$o = { class: "title" };
const _hoisted_4$h = { class: "group" };
const _hoisted_5$f = { class: "group_content" };
const _hoisted_6$b = { class: "text" };
const _hoisted_7$a = { class: "text" };
const _hoisted_8$8 = { class: "text" };
const _hoisted_9$8 = { class: "text" };
function _sfc_render$z(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-changeposition"
}, [
vue.createElementVNode("div", _hoisted_2$r, [
vue.createElementVNode("div", _hoisted_3$o, vue.toDisplayString(_ctx.editor.i18n("ddei.position")), 1),
vue.createElementVNode("div", _hoisted_4$h, [
vue.createElementVNode("div", _hoisted_5$f, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item_disabled": !$options.canPush("top"), "item": $options.canPush("top") }),
onClick: _cache[0] || (_cache[0] = ($event) => $options.canPush("top") && $options.doPush("top"))
}, [
_cache[4] || (_cache[4] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-move-top" })
], -1)),
vue.createElementVNode("div", _hoisted_6$b, vue.toDisplayString(_ctx.editor.i18n("ddei.pushTop")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item_disabled": !$options.canPush("bottom"), "item": $options.canPush("bottom") }),
onClick: _cache[1] || (_cache[1] = ($event) => $options.canPush("top") && $options.doPush("bottom"))
}, [
_cache[5] || (_cache[5] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-move-bottom" })
], -1)),
vue.createElementVNode("div", _hoisted_7$a, vue.toDisplayString(_ctx.editor.i18n("ddei.pushBottom")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item_disabled": !$options.canPush("up"), "item": $options.canPush("up") }),
onClick: _cache[2] || (_cache[2] = ($event) => $options.canPush("up") && $options.doPush("up"))
}, [
_cache[6] || (_cache[6] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-move-up" })
], -1)),
vue.createElementVNode("div", _hoisted_8$8, vue.toDisplayString(_ctx.editor.i18n("ddei.pushUp")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item_disabled": !$options.canPush("down"), "item": $options.canPush("down") }),
onClick: _cache[3] || (_cache[3] = ($event) => $options.canPush("down") && $options.doPush("down"))
}, [
_cache[7] || (_cache[7] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-move-down" })
], -1)),
vue.createElementVNode("div", _hoisted_9$8, vue.toDisplayString(_ctx.editor.i18n("ddei.pushDown")), 1)
], 2)
])
])
])
], 8, _hoisted_1$z)) : vue.createCommentVNode("", true);
}
const PositionDialog = /* @__PURE__ */ _export_sfc(_sfc_main$z, [["render", _sfc_render$z], ["__scopeId", "data-v-70a473a4"]]);
const _DDeiCorePositionDialog = class _DDeiCorePositionDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", PositionDialog.name);
__publicField3(this, "plugins", [PositionDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[PositionDialog.name]) {
for (let i2 in options[PositionDialog.name]) {
newOptions[i2] = options[PositionDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCorePositionDialog(newOptions);
return panels;
}
}
return _DDeiCorePositionDialog;
}
static modify(fn) {
return _DDeiCorePositionDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCorePositionDialog, "defaultIns", new _DDeiCorePositionDialog(null));
let DDeiCorePositionDialog = _DDeiCorePositionDialog;
const _sfc_main$y = {
name: "ddei-core-dialog-publishfile",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-publishfile"
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
},
methods: {
ok() {
var _a3, _b2, _c2, _d2, _e2, _f;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok();
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-publishfile");
},
cancel() {
var _a3, _b2, _c2;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.cancel) {
this.editor.tempDialogData[this.dialogId].callback.cancel();
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-publishfile");
}
}
};
const PublishFileConfirmDialog_vue_vue_type_style_index_0_scoped_251feafa_lang = "";
const _hoisted_1$y = ["id"];
const _hoisted_2$q = { class: "content" };
const _hoisted_3$n = { class: "header" };
const _hoisted_4$g = { class: "tail" };
function _sfc_render$y(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-publishfile"
}, [
vue.createElementVNode("div", _hoisted_2$q, [
vue.createElementVNode("div", _hoisted_3$n, [
_cache[4] || (_cache[4] = vue.createElementVNode("svg", {
class: "icon warn",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-publish" })
], -1)),
vue.createElementVNode("span", null, vue.toDisplayString(_ctx.editor.i18n("ddei.publish")) + vue.toDisplayString(_ctx.editor.i18n("ddei.file")), 1),
_cache[5] || (_cache[5] = vue.createElementVNode("div", { style: { "flex": "1" } }, null, -1)),
(vue.openBlock(), vue.createElementBlock("svg", {
class: "icon close",
"aria-hidden": "true",
onClick: _cache[0] || (_cache[0] = (...args) => $options.cancel && $options.cancel(...args))
}, _cache[3] || (_cache[3] = [
vue.createElementVNode("use", { "xlink:href": "#icon-close" }, null, -1)
])))
]),
_cache[6] || (_cache[6] = vue.createElementVNode("div", { class: "msg" }, null, -1)),
vue.createElementVNode("div", _hoisted_4$g, [
vue.createElementVNode("div", {
class: "button button-main",
onClick: _cache[1] || (_cache[1] = (...args) => $options.ok && $options.ok(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.publish")), 1),
vue.createElementVNode("div", {
class: "button",
onClick: _cache[2] || (_cache[2] = (...args) => $options.cancel && $options.cancel(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.cancel")), 1)
])
])
], 8, _hoisted_1$y)) : vue.createCommentVNode("", true);
}
const PublishFileConfirmDialog = /* @__PURE__ */ _export_sfc(_sfc_main$y, [["render", _sfc_render$y], ["__scopeId", "data-v-251feafa"]]);
const _DDeiCorePublishFileConfirmDialog = class _DDeiCorePublishFileConfirmDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", PublishFileConfirmDialog.name);
__publicField3(this, "plugins", [PublishFileConfirmDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[PublishFileConfirmDialog.name]) {
for (let i2 in options[PublishFileConfirmDialog.name]) {
newOptions[i2] = options[PublishFileConfirmDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCorePublishFileConfirmDialog(newOptions);
return panels;
}
}
return _DDeiCorePublishFileConfirmDialog;
}
static modify(fn) {
return _DDeiCorePublishFileConfirmDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCorePublishFileConfirmDialog, "defaultIns", new _DDeiCorePublishFileConfirmDialog(null));
let DDeiCorePublishFileConfirmDialog = _DDeiCorePublishFileConfirmDialog;
const _sfc_main$x = {
name: "ddei-core-dialog-qcview",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-qcview",
dataSource: null,
//强制刷新控制变量
forceRefresh: false
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2, _d2, _e2;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_c2 = (_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId]) == null ? void 0 : _c2.dataSource)) {
this.dataSource = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.dataSource;
}
},
ok(item) {
var _a3, _b2, _c2, _d2, _e2, _f;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(item);
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-qcview");
},
cancel() {
var _a3, _b2, _c2;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.cancel) {
this.editor.tempDialogData[this.dialogId].callback.cancel();
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-qcview");
}
}
};
const QCViewDialog_vue_vue_type_style_index_0_scoped_6bab58c9_lang = "";
const _hoisted_1$x = ["id"];
const _hoisted_2$p = { class: "items" };
const _hoisted_3$m = ["title", "onClick"];
const _hoisted_4$f = {
class: "icon",
"aria-hidden": "true"
};
const _hoisted_5$e = ["xlink:href"];
function _sfc_render$x(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return $data.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-qcview"
}, [
vue.createElementVNode("div", _hoisted_2$p, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (item) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: "item",
title: item.text,
onClick: ($event) => $options.ok(item)
}, [
(vue.openBlock(), vue.createElementBlock("svg", _hoisted_4$f, [
vue.createElementVNode("use", {
"xlink:href": item.img
}, null, 8, _hoisted_5$e)
])),
vue.createElementVNode("div", null, vue.toDisplayString(item.text), 1)
], 8, _hoisted_3$m);
}), 256))
])
], 8, _hoisted_1$x)) : vue.createCommentVNode("", true);
}
const QCViewDialog = /* @__PURE__ */ _export_sfc(_sfc_main$x, [["render", _sfc_render$x], ["__scopeId", "data-v-6bab58c9"]]);
const _DDeiCoreQCViewDialog = class _DDeiCoreQCViewDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QCViewDialog.name);
__publicField3(this, "plugins", [QCViewDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QCViewDialog.name]) {
for (let i2 in options[QCViewDialog.name]) {
newOptions[i2] = options[QCViewDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreQCViewDialog(newOptions);
return panels;
}
}
return _DDeiCoreQCViewDialog;
}
static modify(fn) {
return _DDeiCoreQCViewDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreQCViewDialog, "defaultIns", new _DDeiCoreQCViewDialog(null));
let DDeiCoreQCViewDialog = _DDeiCoreQCViewDialog;
const _sfc_main$w = {
name: "ddei-core-dialog-setstyle",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-setstyle",
ds: [
{ border: DDeiUtil.rgb2hex("rgb(78,215,197)"), fill: DDeiUtil.rgb2hex("rgb(255,255,255)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(70,125,254)"), fill: DDeiUtil.rgb2hex("rgb(255,255,255)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(66,185,198)"), fill: DDeiUtil.rgb2hex("rgb(255,255,255)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(255,126,121)"), fill: DDeiUtil.rgb2hex("rgb(255,255,255)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(255,204,83)"), fill: DDeiUtil.rgb2hex("rgb(255,255,255)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(78,215,197)"), fill: DDeiUtil.rgb2hex("rgb(233,248,245)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(70,125,254)"), fill: DDeiUtil.rgb2hex("rgb(233,236,255)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(66,185,198)"), fill: DDeiUtil.rgb2hex("rgb(232,233,245)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(255,126,121)"), fill: DDeiUtil.rgb2hex("rgb(255,236,236)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(255,204,83)"), fill: DDeiUtil.rgb2hex("rgb(255,246,233)"), round: 4 },
{ fill: DDeiUtil.rgb2hex("rgb(233,248,245)"), round: 4 },
{ fill: DDeiUtil.rgb2hex("rgb(233,236,255)"), round: 4 },
{ fill: DDeiUtil.rgb2hex("rgb(232,233,245)"), round: 4 },
{ fill: DDeiUtil.rgb2hex("rgb(255,236,236)"), round: 4 },
{ fill: DDeiUtil.rgb2hex("rgb(255,246,233)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(68,189,173)"), fill: DDeiUtil.rgb2hex("rgb(255,255,255)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(61,109,224)"), fill: DDeiUtil.rgb2hex("rgb(255,255,255)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(66,74,174)"), fill: DDeiUtil.rgb2hex("rgb(255,255,255)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(225,110,106)"), fill: DDeiUtil.rgb2hex("rgb(255,255,255)"), round: 4 },
{ border: DDeiUtil.rgb2hex("rgb(225,179,72)"), fill: DDeiUtil.rgb2hex("rgb(255,255,255)"), round: 4 }
]
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
},
methods: {
/**
* 修改样式
*/
select(data) {
if (this.editor.currentControlDefine) {
let controlDefine = this.editor.currentControlDefine;
if (controlDefine) {
let selectedModels = this.editor.ddInstance.stage.selectedModels;
selectedModels == null ? void 0 : selectedModels.forEach((model) => {
if (data.border) {
let borderType = controlDefine.attrDefineMap.get("border.type");
borderType.value = 1;
let borderColor = controlDefine.attrDefineMap.get("border.color");
borderColor.value = data.border;
let paths2 = ["border.color"];
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [model.id], paths: paths2, value: data.border },
null,
true
);
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [model.id], paths: ["border.type"], value: 1 },
null,
true
);
} else {
let borderType = controlDefine.attrDefineMap.get("border.type");
borderType.value = 0;
let paths2 = ["border.type"];
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [model.id], paths: paths2, value: 0 },
null,
true
);
}
if (data.fill) {
let fillType = controlDefine.attrDefineMap.get("fill.type");
fillType.value = 1;
let fillColor = controlDefine.attrDefineMap.get("fill.color");
fillColor.value = data.fill;
let paths2 = ["fill.color"];
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [model.id], paths: paths2, value: data.fill },
null,
true
);
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [model.id], paths: ["fill.type"], value: 1 },
null,
true
);
} else {
let fillType = controlDefine.attrDefineMap.get("fill.type");
fillType.value = 0;
let paths2 = ["fill.type"];
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [model.id], paths: paths2, value: 0 },
null,
true
);
}
if (data.round) {
let borderRound = controlDefine.attrDefineMap.get("borderRound");
borderRound.value = data.round;
let paths2 = ["border.round"];
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [model.id], paths: paths2, value: data.round },
null,
true
);
} else {
let borderRound = controlDefine.attrDefineMap.get("borderRound");
borderRound.value = 0;
let paths2 = ["border.round"];
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [model.id], paths: paths2, value: 0 },
null,
true
);
}
let fontColor = "black";
if (data.color) {
fontColor = data.color;
}
let fontColorDefine = controlDefine.attrDefineMap.get("font.color");
fontColorDefine.value = fontColor;
let paths = ["font.color"];
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{ mids: [model.id], paths, value: data.round },
null,
true
);
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
}
},
/**
* 修改文本对齐方式
*/
ok(data) {
this.select(data);
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-setstyle");
}
}
};
const QuickSetStyleDialog_vue_vue_type_style_index_0_scoped_a2a1cbf5_lang = "";
const _hoisted_1$w = ["id"];
const _hoisted_2$o = { class: "content" };
const _hoisted_3$l = { class: "title" };
const _hoisted_4$e = { class: "group" };
const _hoisted_5$d = { class: "group_content" };
const _hoisted_6$a = ["onClick", "onDblclick"];
function _sfc_render$w(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-setstyle"
}, [
vue.createElementVNode("div", _hoisted_2$o, [
vue.createElementVNode("div", _hoisted_3$l, vue.toDisplayString(_ctx.editor.i18n("ddei.style")), 1),
vue.createElementVNode("div", _hoisted_4$e, [
vue.createElementVNode("div", _hoisted_5$d, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.ds, (data) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: "item",
style: vue.normalizeStyle({ "color": data.text ? data.text : "black", "border-radius": data.round ? data.round + "px" : "", "border-color": data.border ? data.border : "transparent", "background-color": data.fill ? data.fill : "transparent" }),
onClick: ($event) => $options.select(data),
onDblclick: ($event) => $options.ok(data)
}, vue.toDisplayString(_ctx.editor.i18n("ddei.text")), 45, _hoisted_6$a);
}), 256))
])
])
])
], 8, _hoisted_1$w)) : vue.createCommentVNode("", true);
}
const QuickSetStyleDialog = /* @__PURE__ */ _export_sfc(_sfc_main$w, [["render", _sfc_render$w], ["__scopeId", "data-v-a2a1cbf5"]]);
const _DDeiCoreQuickSetStyleDialog = class _DDeiCoreQuickSetStyleDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QuickSetStyleDialog.name);
__publicField3(this, "plugins", [QuickSetStyleDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QuickSetStyleDialog.name]) {
for (let i2 in options[QuickSetStyleDialog.name]) {
newOptions[i2] = options[QuickSetStyleDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreQuickSetStyleDialog(newOptions);
return panels;
}
}
return _DDeiCoreQuickSetStyleDialog;
}
static modify(fn) {
return _DDeiCoreQuickSetStyleDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreQuickSetStyleDialog, "defaultIns", new _DDeiCoreQuickSetStyleDialog(null));
let DDeiCoreQuickSetStyleDialog = _DDeiCoreQuickSetStyleDialog;
const _sfc_main$v = {
name: "ddei-core-dialog-changerotate",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-changerotate"
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
},
methods: {
//是否可以镜像
canMirror() {
var _a3, _b2, _c2;
let models = null;
if (((_b2 = (_a3 = this.editor.ddInstance.stage) == null ? void 0 : _a3.selectedModels) == null ? void 0 : _b2.size) > 0) {
models = Array.from((_c2 = this.editor.ddInstance.stage) == null ? void 0 : _c2.selectedModels.values());
}
let canMirror = DDei.beforeOperateValid(DDeiEnumOperateType.MIRROR, { models }, this.editor.ddInstance, null);
if (!(canMirror == 0 || canMirror == 1)) {
return true;
} else {
return false;
}
},
canRotate() {
var _a3, _b2, _c2;
let models = null;
if (((_b2 = (_a3 = this.editor.ddInstance.stage) == null ? void 0 : _a3.selectedModels) == null ? void 0 : _b2.size) > 0) {
models = Array.from((_c2 = this.editor.ddInstance.stage) == null ? void 0 : _c2.selectedModels.values());
}
let canRotate = DDei.beforeOperateValid(DDeiEnumOperateType.ROTATE, { models }, this.editor.ddInstance, null);
if (!(canRotate == 0 || canRotate == 1)) {
return true;
} else {
return false;
}
},
doRotate(rotate2) {
var _a3;
let file = this.editor.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_a3 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _a3.size) > 0) {
stage2.selectedModels.forEach((model) => {
var _a4;
let oldRotate = model.rotate ? model.rotate : 0;
let newRotate = (oldRotate ? oldRotate : 0) + rotate2;
if (rotate2 == -1) {
newRotate = 0;
}
if (oldRotate != newRotate) {
let m12 = new Matrix3();
let move1Matrix = new Matrix3(
1,
0,
-model.cpv.x,
0,
1,
-model.cpv.y,
0,
0,
1
);
m12.premultiply(move1Matrix);
if (oldRotate) {
let angle2 = (oldRotate * DDeiConfig.ROTATE_UNIT).toFixed(4);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
m12.premultiply(rotateMatrix);
}
if (newRotate != 0) {
let angle1 = (-newRotate * DDeiConfig.ROTATE_UNIT).toFixed(4);
let rotate1Matrix = new Matrix3(
Math.cos(angle1),
Math.sin(angle1),
0,
-Math.sin(angle1),
Math.cos(angle1),
0,
0,
0,
1
);
m12.premultiply(rotate1Matrix);
}
let move2Matrix = new Matrix3(
1,
0,
model.cpv.x,
0,
1,
model.cpv.y,
0,
0,
1
);
m12.premultiply(move2Matrix);
model.transVectors(m12);
}
(_a4 = model.render) == null ? void 0 : _a4.enableRefreshShape();
});
this.editor.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
this.editor.bus.push(DDeiEnumBusCommandType.NodifyChange);
this.editor.bus.push(DDeiEnumBusCommandType.AddHistroy);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
},
doMirror(mirrorType) {
var _a3;
let file = this.editor.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_a3 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _a3.size) > 0) {
stage2.selectedModels.forEach((model) => {
var _a4;
if (mirrorType == 1) {
if (!model.mirrorX) {
model.mirrorX = true;
} else {
delete model.mirrorX;
}
} else if (mirrorType == 2) {
if (!model.mirrorY) {
model.mirrorY = true;
} else {
delete model.mirrorY;
}
}
(_a4 = model.render) == null ? void 0 : _a4.enableRefreshShape();
});
this.editor.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
this.editor.bus.push(DDeiEnumBusCommandType.NodifyChange);
this.editor.bus.push(DDeiEnumBusCommandType.AddHistroy);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
}
}
};
const RotateDialog_vue_vue_type_style_index_0_scoped_2fcc5441_lang = "";
const _hoisted_1$v = ["id"];
const _hoisted_2$n = { class: "content" };
const _hoisted_3$k = { class: "title" };
const _hoisted_4$d = { class: "group" };
const _hoisted_5$c = { class: "title" };
const _hoisted_6$9 = { class: "group_content" };
const _hoisted_7$9 = { class: "group" };
const _hoisted_8$7 = { class: "title" };
const _hoisted_9$7 = { class: "group_content" };
function _sfc_render$v(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-changerotate"
}, [
vue.createElementVNode("div", _hoisted_2$n, [
vue.createElementVNode("div", _hoisted_3$k, vue.toDisplayString(_ctx.editor.i18n("ddei.flip")), 1),
vue.createElementVNode("div", _hoisted_4$d, [
vue.createElementVNode("div", _hoisted_5$c, vue.toDisplayString(_ctx.editor.i18n("ddei.mirror")) + ":", 1),
vue.createElementVNode("div", _hoisted_6$9, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": $options.canMirror(), "item_disabled": !$options.canMirror() }),
onClick: _cache[0] || (_cache[0] = ($event) => $options.canMirror() && $options.doMirror(1))
}, _cache[5] || (_cache[5] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-mirror-v" })
], -1)
]), 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": $options.canMirror(), "item_disabled": !$options.canMirror() }),
onClick: _cache[1] || (_cache[1] = ($event) => $options.canMirror() && $options.doMirror(2))
}, _cache[6] || (_cache[6] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-mirror-h" })
], -1)
]), 2)
])
]),
vue.createElementVNode("div", _hoisted_7$9, [
vue.createElementVNode("div", _hoisted_8$7, vue.toDisplayString(_ctx.editor.i18n("ddei.rotate")) + ":", 1),
vue.createElementVNode("div", _hoisted_9$7, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": $options.canRotate(), "item_disabled": !$options.canRotate() }),
onClick: _cache[2] || (_cache[2] = ($event) => $options.canRotate() && $options.doRotate(90))
}, _cache[7] || (_cache[7] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-rotate-90" })
], -1)
]), 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": $options.canRotate(), "item_disabled": !$options.canRotate() }),
onClick: _cache[3] || (_cache[3] = ($event) => $options.canRotate() && $options.doRotate(-90))
}, _cache[8] || (_cache[8] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-rotate-270" })
], -1)
]), 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": $options.canRotate(), "item_disabled": !$options.canRotate() }),
onClick: _cache[4] || (_cache[4] = ($event) => $options.canRotate() && $options.doRotate(-1))
}, _cache[9] || (_cache[9] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-rotate-0" })
], -1)
]), 2)
])
])
])
], 8, _hoisted_1$v)) : vue.createCommentVNode("", true);
}
const RotateDialog = /* @__PURE__ */ _export_sfc(_sfc_main$v, [["render", _sfc_render$v], ["__scopeId", "data-v-2fcc5441"]]);
const _DDeiCoreRotateDialog = class _DDeiCoreRotateDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", RotateDialog.name);
__publicField3(this, "plugins", [RotateDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[RotateDialog.name]) {
for (let i2 in options[RotateDialog.name]) {
newOptions[i2] = options[RotateDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreRotateDialog(newOptions);
return panels;
}
}
return _DDeiCoreRotateDialog;
}
static modify(fn) {
return _DDeiCoreRotateDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreRotateDialog, "defaultIns", new _DDeiCoreRotateDialog(null));
let DDeiCoreRotateDialog = _DDeiCoreRotateDialog;
const _sfc_main$u = {
name: "ddei-core-dialog-selectborderdash",
extends: null,
mixins: [DialogBase$2],
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() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_c2 = (_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId]) == null ? void 0 : _c2.value)) {
this.value = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId].value;
}
if (((_e2 = this.editor) == null ? void 0 : _e2.tempDialogData) && ((_g = (_f = this.editor) == null ? void 0 : _f.tempDialogData[this.dialogId]) == null ? void 0 : _g.dataSource)) {
this.dataSource = (_h = this.editor) == null ? void 0 : _h.tempDialogData[this.dialogId].dataSource;
}
},
select(value) {
this.value = value;
},
selectAndConfirm(value) {
this.value = value;
this.ok();
},
ok() {
var _a3, _b2, _c2, _d2, _e2, _f;
if (this.value) {
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(this.value);
}
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-selectborderdash");
},
cancel() {
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-selectborderdash");
}
}
};
const SelectBorderDashDialog_vue_vue_type_style_index_0_scoped_143dc703_lang = "";
const _hoisted_1$u = ["id"];
const _hoisted_2$m = { class: "content" };
const _hoisted_3$j = { class: "group" };
const _hoisted_4$c = { class: "title" };
const _hoisted_5$b = { class: "group_content" };
const _hoisted_6$8 = ["onClick", "onDblclick"];
const _hoisted_7$8 = { class: "div_input" };
const _hoisted_8$6 = ["stroke-dasharray"];
const _hoisted_9$6 = { class: "tail" };
function _sfc_render$u(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-selectborderdash"
}, [
vue.createElementVNode("div", _hoisted_2$m, [
vue.createElementVNode("div", _hoisted_3$j, [
vue.createElementVNode("div", _hoisted_4$c, vue.toDisplayString(_ctx.editor.i18n("ddei.lineDash")), 1),
vue.createElementVNode("div", _hoisted_5$b, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (data) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "item": true, "item-selected": JSON.stringify($data.value) == JSON.stringify(data.value) }),
onClick: ($event) => $options.select(data.value),
onDblclick: ($event) => $options.selectAndConfirm(data.value)
}, [
(vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$8, [
vue.createElementVNode("line", {
x1: "0",
y1: "0",
x2: "100%",
y2: "0",
"stroke-width": "3",
"stroke-dasharray": data.value
}, null, 8, _hoisted_8$6)
]))
], 42, _hoisted_6$8);
}), 256))
])
]),
vue.createElementVNode("div", _hoisted_9$6, [
vue.createElementVNode("div", {
class: "button button-main",
onClick: _cache[0] || (_cache[0] = (...args) => $options.ok && $options.ok(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.confirm")), 1),
vue.createElementVNode("div", {
class: "button",
onClick: _cache[1] || (_cache[1] = (...args) => $options.cancel && $options.cancel(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.cancel")), 1)
])
])
], 8, _hoisted_1$u)) : vue.createCommentVNode("", true);
}
const SelectBorderDashDialog = /* @__PURE__ */ _export_sfc(_sfc_main$u, [["render", _sfc_render$u], ["__scopeId", "data-v-143dc703"]]);
const _DDeiCoreSelectBorderDashDialog = class _DDeiCoreSelectBorderDashDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", SelectBorderDashDialog.name);
__publicField3(this, "plugins", [SelectBorderDashDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[SelectBorderDashDialog.name]) {
for (let i2 in options[SelectBorderDashDialog.name]) {
newOptions[i2] = options[SelectBorderDashDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreSelectBorderDashDialog(newOptions);
return panels;
}
}
return _DDeiCoreSelectBorderDashDialog;
}
static modify(fn) {
return _DDeiCoreSelectBorderDashDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSelectBorderDashDialog, "defaultIns", new _DDeiCoreSelectBorderDashDialog(null));
let DDeiCoreSelectBorderDashDialog = _DDeiCoreSelectBorderDashDialog;
const _sfc_main$t = {
name: "ddei-core-dialog-selectboderweight",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-selectboderweight",
value: [],
//最近使用的颜色
dataSource: null,
dash: []
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_c2 = (_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId]) == null ? void 0 : _c2.value)) {
this.value = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId].value;
}
if (((_e2 = this.editor) == null ? void 0 : _e2.tempDialogData) && ((_g = (_f = this.editor) == null ? void 0 : _f.tempDialogData[this.dialogId]) == null ? void 0 : _g.dataSource)) {
this.dataSource = (_h = this.editor) == null ? void 0 : _h.tempDialogData[this.dialogId].dataSource;
}
if (((_i = this.editor) == null ? void 0 : _i.tempDialogData) && ((_k = (_j = this.editor) == null ? void 0 : _j.tempDialogData[this.dialogId]) == null ? void 0 : _k.dash)) {
this.dash = (_l = this.editor) == null ? void 0 : _l.tempDialogData[this.dialogId].dash;
}
},
select(value) {
this.value = value;
},
selectAndConfirm(value) {
this.value = value;
this.ok();
},
ok() {
var _a3, _b2, _c2, _d2, _e2, _f;
if (this.value) {
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(this.value);
}
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-selectboderweight");
},
cancel() {
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-selectboderweight");
}
}
};
const SelectBorderWeightDialog_vue_vue_type_style_index_0_scoped_b939438e_lang = "";
const _hoisted_1$t = ["id"];
const _hoisted_2$l = { class: "content" };
const _hoisted_3$i = { class: "group" };
const _hoisted_4$b = { class: "title" };
const _hoisted_5$a = { class: "group_content" };
const _hoisted_6$7 = ["onClick", "onDblclick"];
const _hoisted_7$7 = { class: "div_input" };
const _hoisted_8$5 = ["stroke-width", "stroke-dasharray"];
const _hoisted_9$5 = { class: "tail" };
function _sfc_render$t(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-selectboderweight"
}, [
vue.createElementVNode("div", _hoisted_2$l, [
vue.createElementVNode("div", _hoisted_3$i, [
vue.createElementVNode("div", _hoisted_4$b, vue.toDisplayString(_ctx.editor.i18n("ddei.lineWeight")), 1),
vue.createElementVNode("div", _hoisted_5$a, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (data) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "item": true, "item-selected": JSON.stringify($data.value) == JSON.stringify(data.value) }),
onClick: ($event) => $options.select(data.value),
onDblclick: ($event) => $options.selectAndConfirm(data.value)
}, [
(vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$7, [
vue.createElementVNode("line", {
x1: "0",
y1: "50%",
x2: "100%",
y2: "50%",
"stroke-width": data.value,
"stroke-dasharray": $data.dash
}, null, 8, _hoisted_8$5)
]))
], 42, _hoisted_6$7);
}), 256))
])
]),
vue.createElementVNode("div", _hoisted_9$5, [
vue.createElementVNode("div", {
class: "button button-main",
onClick: _cache[0] || (_cache[0] = (...args) => $options.ok && $options.ok(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.confirm")), 1),
vue.createElementVNode("div", {
class: "button",
onClick: _cache[1] || (_cache[1] = (...args) => $options.cancel && $options.cancel(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.cancel")), 1)
])
])
], 8, _hoisted_1$t)) : vue.createCommentVNode("", true);
}
const SelectBorderWeightDialog = /* @__PURE__ */ _export_sfc(_sfc_main$t, [["render", _sfc_render$t], ["__scopeId", "data-v-b939438e"]]);
const _DDeiCoreSelectBorderWeightDialog = class _DDeiCoreSelectBorderWeightDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", SelectBorderWeightDialog.name);
__publicField3(this, "plugins", [SelectBorderWeightDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[SelectBorderWeightDialog.name]) {
for (let i2 in options[SelectBorderWeightDialog.name]) {
newOptions[i2] = options[SelectBorderWeightDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreSelectBorderWeightDialog(newOptions);
return panels;
}
}
return _DDeiCoreSelectBorderWeightDialog;
}
static modify(fn) {
return _DDeiCoreSelectBorderWeightDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSelectBorderWeightDialog, "defaultIns", new _DDeiCoreSelectBorderWeightDialog(null));
let DDeiCoreSelectBorderWeightDialog = _DDeiCoreSelectBorderWeightDialog;
const _sfc_main$s = {
name: "ddei-core-dialog-selectcolor",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-selectcolor",
dataSource: null,
value: "#000000",
//最近使用的颜色
ds1: [
DDeiUtil.rgb2hex("rgb(255,255,255)"),
"#000000",
DDeiUtil.rgb2hex("rgb(78,215,197)"),
DDeiUtil.rgb2hex("rgb(70,125,254)"),
DDeiUtil.rgb2hex("rgb(66,185,198)"),
DDeiUtil.rgb2hex("rgb(255,126,121)"),
DDeiUtil.rgb2hex("rgb(255,204,83)"),
DDeiUtil.rgb2hex("rgb(141,192,255)"),
DDeiUtil.rgb2hex("rgb(121,145,255)"),
DDeiUtil.rgb2hex("rgb(254,157,23)")
],
//备选色
ds2: [
DDeiUtil.rgb2hex("rgb(255,255,255)"),
"#000000",
DDeiUtil.rgb2hex("rgb(78,215,197)"),
DDeiUtil.rgb2hex("rgb(70,125,254)"),
DDeiUtil.rgb2hex("rgb(66,185,198)"),
DDeiUtil.rgb2hex("rgb(255,126,121)"),
DDeiUtil.rgb2hex("rgb(255,204,83)"),
DDeiUtil.rgb2hex("rgb(141,192,255)"),
DDeiUtil.rgb2hex("rgb(121,145,255)"),
DDeiUtil.rgb2hex("rgb(254,157,23)"),
DDeiUtil.rgb2hex("rgb(235,235,235)"),
DDeiUtil.rgb2hex("rgb(126,126,126)"),
DDeiUtil.rgb2hex("rgb(233,248,245)"),
DDeiUtil.rgb2hex("rgb(233,236,255)"),
DDeiUtil.rgb2hex("rgb(232,233,245)"),
DDeiUtil.rgb2hex("rgb(255,236,236)"),
DDeiUtil.rgb2hex("rgb(255,246,233)"),
DDeiUtil.rgb2hex("rgb(238,244,255)"),
DDeiUtil.rgb2hex("rgb(236,238,255)"),
DDeiUtil.rgb2hex("rgb(255,240,231)"),
DDeiUtil.rgb2hex("rgb(215,215,215)"),
DDeiUtil.rgb2hex("rgb(105,105,105)"),
DDeiUtil.rgb2hex("rgb(208,240,234)"),
DDeiUtil.rgb2hex("rgb(207,215,255)"),
DDeiUtil.rgb2hex("rgb(207,209,234)"),
DDeiUtil.rgb2hex("rgb(255,216,215)"),
DDeiUtil.rgb2hex("rgb(255,236,209)"),
DDeiUtil.rgb2hex("rgb(219,232,255)"),
DDeiUtil.rgb2hex("rgb(215,220,255)"),
DDeiUtil.rgb2hex("rgb(255,223,204)"),
DDeiUtil.rgb2hex("rgb(195,195,195)"),
DDeiUtil.rgb2hex("rgb(89,89,89)"),
DDeiUtil.rgb2hex("rgb(178,232,223)"),
DDeiUtil.rgb2hex("rgb(176,191,254)"),
DDeiUtil.rgb2hex("rgb(176,180,223)"),
DDeiUtil.rgb2hex("rgb(255,192,190)"),
DDeiUtil.rgb2hex("rgb(255,226,179)"),
DDeiUtil.rgb2hex("rgb(197,220,255)"),
DDeiUtil.rgb2hex("rgb(190,199,255)"),
DDeiUtil.rgb2hex("rgb(254,204,171)"),
DDeiUtil.rgb2hex("rgb(175,175,175)"),
DDeiUtil.rgb2hex("rgb(69,69,69)"),
DDeiUtil.rgb2hex("rgb(140,224,210)"),
DDeiUtil.rgb2hex("rgb(137,163,254)"),
DDeiUtil.rgb2hex("rgb(135,143,211)"),
DDeiUtil.rgb2hex("rgb(255,163,160)"),
DDeiUtil.rgb2hex("rgb(255,215,142)"),
DDeiUtil.rgb2hex("rgb(172,207,255)"),
DDeiUtil.rgb2hex("rgb(160,175,255)"),
DDeiUtil.rgb2hex("rgb(254,182,106)"),
DDeiUtil.rgb2hex("rgb(155,155,155)"),
DDeiUtil.rgb2hex("rgb(48,48,48)"),
DDeiUtil.rgb2hex("rgb(68,189,173)"),
DDeiUtil.rgb2hex("rgb(61,109,224)"),
DDeiUtil.rgb2hex("rgb(66,74,174)"),
DDeiUtil.rgb2hex("rgb(225,110,106)"),
DDeiUtil.rgb2hex("rgb(225,179,72)"),
DDeiUtil.rgb2hex("rgb(123,169,225)"),
DDeiUtil.rgb2hex("rgb(106,127,225)"),
DDeiUtil.rgb2hex("rgb(224,138,19)"),
DDeiUtil.rgb2hex("rgb(135,135,135)"),
DDeiUtil.rgb2hex("rgb(25,25,25)"),
DDeiUtil.rgb2hex("rgb(55,158,144)"),
DDeiUtil.rgb2hex("rgb(49,90,187)"),
DDeiUtil.rgb2hex("rgb(45,60,145)"),
DDeiUtil.rgb2hex("rgb(188,91,87)"),
DDeiUtil.rgb2hex("rgb(188,149,59)"),
DDeiUtil.rgb2hex("rgb(102,140,188)"),
DDeiUtil.rgb2hex("rgb(87,105,188)"),
DDeiUtil.rgb2hex("rgb(187,114,14)")
],
//常用标准色
ds3: [
DDeiUtil.rgb2hex("rgb(192,0,0)"),
DDeiUtil.rgb2hex("rgb(255,0,0)"),
DDeiUtil.rgb2hex("rgb(255,192,0)"),
DDeiUtil.rgb2hex("rgb(255,255,0)"),
DDeiUtil.rgb2hex("rgb(146,208,80)"),
DDeiUtil.rgb2hex("rgb(0,176,80)"),
DDeiUtil.rgb2hex("rgb(0,146,240)"),
DDeiUtil.rgb2hex("rgb(0,112,192)"),
DDeiUtil.rgb2hex("rgb(0,32,96)"),
DDeiUtil.rgb2hex("rgb(112,48,160)")
]
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_c2 = (_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId]) == null ? void 0 : _c2.dataSource)) {
this.dataSource = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId].dataSource;
}
if (((_e2 = this.editor) == null ? void 0 : _e2.tempDialogData) && ((_g = (_f = this.editor) == null ? void 0 : _f.tempDialogData[this.dialogId]) == null ? void 0 : _g.value)) {
this.value = (_h = this.editor) == null ? void 0 : _h.tempDialogData[this.dialogId].value;
}
DDeiUtil.readRecentlyChooseColors();
for (let i2 = (_i = DDeiUtil.recentlyChooseColors) == null ? void 0 : _i.length; i2 >= 0; i2--) {
this.ds1.splice(0, 0, DDeiUtil.recentlyChooseColors[i2]);
if (this.ds1.length > 10) {
this.ds1.splice(10, 1);
}
}
},
selectColor(evt) {
let srcElement = evt.currentTarget;
this.value = DDeiUtil.rgb2hex(srcElement.style.backgroundColor);
},
selectConfirmColor(evt) {
let srcElement = evt.currentTarget;
this.value = DDeiUtil.rgb2hex(srcElement.style.backgroundColor);
this.ok();
},
ok() {
var _a3, _b2, _c2, _d2, _e2, _f;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(this.value);
}
if (this.value) {
DDeiUtil.whiteRecentlyChooseColors(this.value);
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-selectcolor");
},
clear() {
this.value = null;
},
cancel() {
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-selectcolor");
}
}
};
const SelectColorDialog_vue_vue_type_style_index_0_scoped_cd291105_lang = "";
const _hoisted_1$s = ["id"];
const _hoisted_2$k = { class: "content" };
const _hoisted_3$h = { class: "group" };
const _hoisted_4$a = { class: "title" };
const _hoisted_5$9 = { class: "group_content color1" };
const _hoisted_6$6 = { class: "group" };
const _hoisted_7$6 = { class: "group_content color2" };
const _hoisted_8$4 = { class: "group" };
const _hoisted_9$4 = { class: "title" };
const _hoisted_10$3 = { class: "group_content color1" };
const _hoisted_11$3 = { class: "group" };
const _hoisted_12$2 = { class: "title" };
const _hoisted_13$2 = { class: ".group_content color3" };
const _hoisted_14$1 = { class: "tail" };
function _sfc_render$s(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-selectcolor"
}, [
vue.createElementVNode("div", _hoisted_2$k, [
vue.createElementVNode("div", _hoisted_3$h, [
vue.createElementVNode("div", _hoisted_4$a, vue.toDisplayString(_ctx.editor.i18n("ddei.selectColor.recently")), 1),
vue.createElementVNode("div", _hoisted_5$9, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.ds1, (color) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "item": true, "item-selected": color == $data.value }),
onClick: _cache[0] || (_cache[0] = ($event) => $options.selectColor($event)),
style: vue.normalizeStyle({ "background": color }),
onDblclick: _cache[1] || (_cache[1] = ($event) => $options.selectConfirmColor($event))
}, null, 38);
}), 256))
])
]),
vue.createElementVNode("div", _hoisted_6$6, [
vue.createElementVNode("div", _hoisted_7$6, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.ds2, (color) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "item": true, "item-selected": color == $data.value }),
onClick: _cache[2] || (_cache[2] = ($event) => $options.selectColor($event)),
style: vue.normalizeStyle({ "background": color }),
onDblclick: _cache[3] || (_cache[3] = ($event) => $options.selectConfirmColor($event))
}, null, 38);
}), 256))
])
]),
vue.createElementVNode("div", _hoisted_8$4, [
vue.createElementVNode("div", _hoisted_9$4, vue.toDisplayString(_ctx.editor.i18n("ddei.selectColor.standard")), 1),
vue.createElementVNode("div", _hoisted_10$3, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.ds3, (color) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "item": true, "item-selected": color == $data.value }),
onClick: _cache[4] || (_cache[4] = ($event) => $options.selectColor($event)),
style: vue.normalizeStyle({ "background": color }),
onDblclick: _cache[5] || (_cache[5] = ($event) => $options.selectConfirmColor($event))
}, null, 38);
}), 256))
])
]),
vue.createElementVNode("div", _hoisted_11$3, [
vue.createElementVNode("div", _hoisted_12$2, vue.toDisplayString(_ctx.editor.i18n("ddei.selectColor.choosed")), 1),
vue.createElementVNode("div", _hoisted_13$2, [
vue.withDirectives(vue.createElementVNode("input", {
type: "color",
"onUpdate:modelValue": _cache[6] || (_cache[6] = ($event) => $data.value = $event),
class: "colorinput",
autocomplete: "off"
}, null, 512), [
[vue.vModelText, $data.value]
]),
vue.withDirectives(vue.createElementVNode("input", {
type: "text",
"onUpdate:modelValue": _cache[7] || (_cache[7] = ($event) => $data.value = $event),
autocomplete: "off"
}, null, 512), [
[vue.vModelText, $data.value]
]),
vue.createElementVNode("div", {
class: "button button-small",
onClick: _cache[8] || (_cache[8] = (...args) => $options.clear && $options.clear(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.clear")), 1)
])
]),
vue.createElementVNode("div", _hoisted_14$1, [
vue.createElementVNode("div", {
class: "button button-main",
onClick: _cache[9] || (_cache[9] = (...args) => $options.ok && $options.ok(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.confirm")), 1),
vue.createElementVNode("div", {
class: "button",
onClick: _cache[10] || (_cache[10] = (...args) => $options.cancel && $options.cancel(...args))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.cancel")), 1)
])
])
], 8, _hoisted_1$s)) : vue.createCommentVNode("", true);
}
const SelectColorDialog = /* @__PURE__ */ _export_sfc(_sfc_main$s, [["render", _sfc_render$s], ["__scopeId", "data-v-cd291105"]]);
const _DDeiCoreSelectColorDialog = class _DDeiCoreSelectColorDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", SelectColorDialog.name);
__publicField3(this, "plugins", [SelectColorDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[SelectColorDialog.name]) {
for (let i2 in options[SelectColorDialog.name]) {
newOptions[i2] = options[SelectColorDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreSelectColorDialog(newOptions);
return panels;
}
}
return _DDeiCoreSelectColorDialog;
}
static modify(fn) {
return _DDeiCoreSelectColorDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSelectColorDialog, "defaultIns", new _DDeiCoreSelectColorDialog(null));
let DDeiCoreSelectColorDialog = _DDeiCoreSelectColorDialog;
const _sfc_main$r = {
name: "ddei-core-dialog-selectfont",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-selectfont",
dataSource: null,
value: null
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_c2 = (_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId]) == null ? void 0 : _c2.dataSource)) {
this.dataSource = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId].dataSource;
}
if (((_e2 = this.editor) == null ? void 0 : _e2.tempDialogData) && ((_g = (_f = this.editor) == null ? void 0 : _f.tempDialogData[this.dialogId]) == null ? void 0 : _g.value)) {
this.value = (_h = this.editor) == null ? void 0 : _h.tempDialogData[this.dialogId].value;
}
},
ok(data) {
var _a3, _b2, _c2, _d2, _e2, _f;
this.value = data;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(data);
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-selectfont");
},
select(data) {
var _a3, _b2, _c2, _d2, _e2, _f;
this.value = data;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(data);
}
}
}
};
const SelectFontDialog_vue_vue_type_style_index_0_scoped_64fcb708_lang = "";
const _hoisted_1$r = ["id"];
const _hoisted_2$j = { class: "content" };
const _hoisted_3$g = { class: "group" };
const _hoisted_4$9 = { class: "group_content" };
const _hoisted_5$8 = ["onDblclick", "onClick", "title"];
function _sfc_render$r(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-selectfont"
}, [
vue.createElementVNode("div", _hoisted_2$j, [
vue.createElementVNode("div", _hoisted_3$g, [
vue.createElementVNode("div", _hoisted_4$9, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (item) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "item": true, "item_selected": item.value == $data.value, "item_deleted": item.deleted, "item_disabled": item.disabled, "item_underline": item.underline, "item_bold": item.bold }),
onDblclick: ($event) => !item.disabled && $options.ok(item.value),
onClick: ($event) => !item.disabled && $options.select(item.value),
title: item.desc
}, [
item.text ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
class: "text",
style: vue.normalizeStyle({ "font-family": item.fontFamily })
}, vue.toDisplayString(item.text), 5)) : vue.createCommentVNode("", true)
], 42, _hoisted_5$8);
}), 256))
])
])
])
], 8, _hoisted_1$r)) : vue.createCommentVNode("", true);
}
const SelectFontDialog = /* @__PURE__ */ _export_sfc(_sfc_main$r, [["render", _sfc_render$r], ["__scopeId", "data-v-64fcb708"]]);
const _DDeiCoreSelectFontDialog = class _DDeiCoreSelectFontDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", SelectFontDialog.name);
__publicField3(this, "plugins", [SelectFontDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[SelectFontDialog.name]) {
for (let i2 in options[SelectFontDialog.name]) {
newOptions[i2] = options[SelectFontDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreSelectFontDialog(newOptions);
return panels;
}
}
return _DDeiCoreSelectFontDialog;
}
static modify(fn) {
return _DDeiCoreSelectFontDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSelectFontDialog, "defaultIns", new _DDeiCoreSelectFontDialog(null));
let DDeiCoreSelectFontDialog = _DDeiCoreSelectFontDialog;
const _sfc_main$q = {
name: "ddei-core-dialog-selectfontsize",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-selectfontsize",
dataSource: null,
value: null
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_c2 = (_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId]) == null ? void 0 : _c2.dataSource)) {
this.dataSource = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId].dataSource;
}
if (((_e2 = this.editor) == null ? void 0 : _e2.tempDialogData) && ((_g = (_f = this.editor) == null ? void 0 : _f.tempDialogData[this.dialogId]) == null ? void 0 : _g.value)) {
this.value = (_h = this.editor) == null ? void 0 : _h.tempDialogData[this.dialogId].value;
}
},
ok(data) {
var _a3, _b2, _c2, _d2, _e2, _f;
this.value = data;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(data);
}
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-selectfontsize");
},
select(data) {
var _a3, _b2, _c2, _d2, _e2, _f;
this.value = data;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(data);
}
}
}
};
const SelectFontSizeDialog_vue_vue_type_style_index_0_scoped_9fc02a16_lang = "";
const _hoisted_1$q = ["id"];
const _hoisted_2$i = { class: "content" };
const _hoisted_3$f = { class: "group" };
const _hoisted_4$8 = { class: "group_content" };
const _hoisted_5$7 = ["onDblclick", "onClick", "title"];
function _sfc_render$q(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-selectfontsize"
}, [
vue.createElementVNode("div", _hoisted_2$i, [
vue.createElementVNode("div", _hoisted_3$f, [
vue.createElementVNode("div", _hoisted_4$8, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (item) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "itembox": true, "itembox_selected": item.value == $data.value, "itembox_deleted": item.deleted, "itembox_disabled": item.disabled, "itembox_underline": item.underline, "itembox_bold": item.bold }),
onDblclick: ($event) => !item.disabled && $options.ok(item.value),
onClick: ($event) => !item.disabled && $options.select(item.value),
title: item.desc
}, [
item.text ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
class: "itembox_text",
style: vue.normalizeStyle({ "font-family": item.fontFamily })
}, vue.toDisplayString(item.text), 5)) : vue.createCommentVNode("", true)
], 42, _hoisted_5$7);
}), 256))
])
])
])
], 8, _hoisted_1$q)) : vue.createCommentVNode("", true);
}
const SelectFontSizeDialog = /* @__PURE__ */ _export_sfc(_sfc_main$q, [["render", _sfc_render$q], ["__scopeId", "data-v-9fc02a16"]]);
const _DDeiCoreSelectFontSizeDialog = class _DDeiCoreSelectFontSizeDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", SelectFontSizeDialog.name);
__publicField3(this, "plugins", [SelectFontSizeDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[SelectFontSizeDialog.name]) {
for (let i2 in options[SelectFontSizeDialog.name]) {
newOptions[i2] = options[SelectFontSizeDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreSelectFontSizeDialog(newOptions);
return panels;
}
}
return _DDeiCoreSelectFontSizeDialog;
}
static modify(fn) {
return _DDeiCoreSelectFontSizeDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSelectFontSizeDialog, "defaultIns", new _DDeiCoreSelectFontSizeDialog(null));
let DDeiCoreSelectFontSizeDialog = _DDeiCoreSelectFontSizeDialog;
const _sfc_main$p = {
name: "ddei-core-dialog-textalign",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-textalign",
value: 5
//当前选中值
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2, _d2;
let align = 2;
let valign = 2;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempDialogData) && ((_b2 = this.editor) == null ? void 0 : _b2.tempDialogData[this.dialogId])) {
align = (_c2 = this.editor) == null ? void 0 : _c2.tempDialogData[this.dialogId].align;
valign = (_d2 = this.editor) == null ? void 0 : _d2.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) {
var _a3, _b2, _c2, _d2, _e2, _f;
this.value = v;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempDialogData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempDialogData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(this.value);
}
},
/**
* 修改文本对齐方式
*/
ok(v) {
this.changeAlign(v);
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-textalign");
}
}
};
const TextAlignDialog_vue_vue_type_style_index_0_scoped_fe33bdea_lang = "";
const _hoisted_1$p = ["id"];
const _hoisted_2$h = { class: "content" };
const _hoisted_3$e = { class: "title" };
const _hoisted_4$7 = { class: "group" };
const _hoisted_5$6 = { class: "group_content" };
function _sfc_render$p(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-textalign"
}, [
vue.createElementVNode("div", _hoisted_2$h, [
vue.createElementVNode("div", _hoisted_3$e, vue.toDisplayString(_ctx.editor.i18n("ddei.align")), 1),
vue.createElementVNode("div", _hoisted_4$7, [
vue.createElementVNode("div", _hoisted_5$6, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 1 }),
onClick: _cache[0] || (_cache[0] = ($event) => $options.changeAlign(1)),
onDblclick: _cache[1] || (_cache[1] = ($event) => $options.ok(1))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.pos1")), 35),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 2 }),
onClick: _cache[2] || (_cache[2] = ($event) => $options.changeAlign(2)),
onDblclick: _cache[3] || (_cache[3] = ($event) => $options.ok(2))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.pos2")), 35),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 3 }),
onClick: _cache[4] || (_cache[4] = ($event) => $options.changeAlign(3)),
onDblclick: _cache[5] || (_cache[5] = ($event) => $options.ok(3))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.pos3")), 35),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 4 }),
onClick: _cache[6] || (_cache[6] = ($event) => $options.changeAlign(4)),
onDblclick: _cache[7] || (_cache[7] = ($event) => $options.ok(4))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.pos4")), 35),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 5 }),
onClick: _cache[8] || (_cache[8] = ($event) => $options.changeAlign(5)),
onDblclick: _cache[9] || (_cache[9] = ($event) => $options.ok(5))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.pos5")), 35),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 6 }),
onClick: _cache[10] || (_cache[10] = ($event) => $options.changeAlign(6)),
onDblclick: _cache[11] || (_cache[11] = ($event) => $options.ok(6))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.pos6")), 35),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 7 }),
onClick: _cache[12] || (_cache[12] = ($event) => $options.changeAlign(7)),
onDblclick: _cache[13] || (_cache[13] = ($event) => $options.ok(7))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.pos7")), 35),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 8 }),
onClick: _cache[14] || (_cache[14] = ($event) => $options.changeAlign(8)),
onDblclick: _cache[15] || (_cache[15] = ($event) => $options.ok(8))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.pos8")), 35),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "item": true, "selected": $data.value == 9 }),
onClick: _cache[16] || (_cache[16] = ($event) => $options.changeAlign(9)),
onDblclick: _cache[17] || (_cache[17] = ($event) => $options.ok(9))
}, vue.toDisplayString(_ctx.editor.i18n("ddei.property.ds.pos9")), 35)
])
])
])
], 8, _hoisted_1$p)) : vue.createCommentVNode("", true);
}
const TextAlignDialog = /* @__PURE__ */ _export_sfc(_sfc_main$p, [["render", _sfc_render$p], ["__scopeId", "data-v-fe33bdea"]]);
const _DDeiCoreTextAlignDialog = class _DDeiCoreTextAlignDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", TextAlignDialog.name);
__publicField3(this, "plugins", [TextAlignDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[TextAlignDialog.name]) {
for (let i2 in options[TextAlignDialog.name]) {
newOptions[i2] = options[TextAlignDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreTextAlignDialog(newOptions);
return panels;
}
}
return _DDeiCoreTextAlignDialog;
}
static modify(fn) {
return _DDeiCoreTextAlignDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreTextAlignDialog, "defaultIns", new _DDeiCoreTextAlignDialog(null));
let DDeiCoreTextAlignDialog = _DDeiCoreTextAlignDialog;
const _sfc_main$o = {
name: "ddei-core-dialog-choosecontrol",
extends: null,
mixins: [DialogBase$2],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-choosecontrol",
group: null
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2, _d2;
if (((_a3 = this.editor) == null ? void 0 : _a3.tempPopData) && ((_c2 = (_b2 = this.editor) == null ? void 0 : _b2.tempPopData[this.dialogId]) == null ? void 0 : _c2.controlGroup)) {
this.group = (_d2 = this.editor) == null ? void 0 : _d2.tempPopData[this.dialogId].controlGroup;
}
},
ok(control, evt) {
var _a3, _b2, _c2, _d2, _e2, _f;
delete this.isDrag;
delete this.dragControl;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempPopData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.ok) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempPopData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.ok(this.group, control, evt);
}
},
prepareDrag(control, evt) {
var _a3, _b2, _c2;
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempPopData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.drag) {
this.isDrag = true;
this.dragControl = control;
}
},
dragMove(evt) {
var _a3, _b2, _c2, _d2, _e2, _f;
if (this.isDrag) {
if ((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.tempPopData[this.dialogId]) == null ? void 0 : _b2.callback) == null ? void 0 : _c2.drag) {
(_f = (_e2 = (_d2 = this.editor) == null ? void 0 : _d2.tempPopData[this.dialogId]) == null ? void 0 : _e2.callback) == null ? void 0 : _f.drag(this.group, this.dragControl, evt);
delete this.isDrag;
delete this.dragControl;
}
}
}
}
};
const ChooseControlDialog_vue_vue_type_style_index_0_scoped_5962d4b2_lang = "";
const _hoisted_1$o = ["id"];
const _hoisted_2$g = { class: "ddei-core-dialog-choosecontrol-content" };
const _hoisted_3$d = {
key: 0,
class: "ddei-core-dialog-choosecontrol-content-itempanel"
};
const _hoisted_4$6 = ["onClick", "onMousedown", "title"];
const _hoisted_5$5 = ["src"];
const _hoisted_6$5 = ["innerHTML"];
const _hoisted_7$5 = { class: "text" };
function _sfc_render$o(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-core-dialog-choosecontrol"
}, [
vue.createElementVNode("div", _hoisted_2$g, [
$data.group ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3$d, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.group.controls, (control) => {
var _a4;
return vue.openBlock(), vue.createElementBlock("div", {
onClick: ($event) => $options.ok(control, $event),
onMousedown: ($event) => $options.prepareDrag(control, $event),
onMousemove: _cache[0] || (_cache[0] = ($event) => $options.dragMove($event)),
class: vue.normalizeClass({ "ddei-core-dialog-choosecontrol-content-itempanel-item": true }),
title: control.desc
}, [
!control.icon ? (vue.openBlock(), vue.createElementBlock("img", {
key: 0,
class: "icon",
src: (_a4 = _ctx.editor) == null ? void 0 : _a4.icons[control.id]
}, null, 8, _hoisted_5$5)) : vue.createCommentVNode("", true),
control.icon ? (vue.openBlock(), vue.createElementBlock("div", {
key: 1,
class: "icon-html",
innerHTML: control.icon
}, null, 8, _hoisted_6$5)) : vue.createCommentVNode("", true),
vue.createElementVNode("div", _hoisted_7$5, vue.toDisplayString(_ctx.editor.i18n(control.name)), 1)
], 40, _hoisted_4$6);
}), 256))
])) : vue.createCommentVNode("", true)
])
], 8, _hoisted_1$o)) : vue.createCommentVNode("", true);
}
const ChooseControlDialog = /* @__PURE__ */ _export_sfc(_sfc_main$o, [["render", _sfc_render$o], ["__scopeId", "data-v-5962d4b2"]]);
const _DDeiCoreChooseControlDialog = class _DDeiCoreChooseControlDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", ChooseControlDialog.name);
__publicField3(this, "plugins", [ChooseControlDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ChooseControlDialog.name]) {
for (let i2 in options[ChooseControlDialog.name]) {
newOptions[i2] = options[ChooseControlDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreChooseControlDialog(newOptions);
return panels;
}
}
return _DDeiCoreChooseControlDialog;
}
static modify(fn) {
return _DDeiCoreChooseControlDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreChooseControlDialog, "defaultIns", new _DDeiCoreChooseControlDialog(null));
let DDeiCoreChooseControlDialog = _DDeiCoreChooseControlDialog;
const _DDeiCoreDialogs = class _DDeiCoreDialogs extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [
DDeiCoreAlignDialog,
DDeiCoreChangeRatioDialog,
DDeiCoreChooseControlGroupDialog,
DDeiCoreCloseFileConfirmDialog,
DDeiCoreCollFileConfirmDialog,
DDeiCoreLinePointTypeDialog,
DDeiCoreLineTypeDialog,
DDeiCoreManageLayersDialog,
DDeiCoreMergeComposeDialog,
DDeiCorePositionDialog,
DDeiCorePublishFileConfirmDialog,
DDeiCoreQCViewDialog,
DDeiCoreQuickSetStyleDialog,
DDeiCoreRotateDialog,
DDeiCoreSelectBorderDashDialog,
DDeiCoreSelectBorderWeightDialog,
DDeiCoreSelectColorDialog,
DDeiCoreSelectFontDialog,
DDeiCoreSelectFontSizeDialog,
DDeiCoreTextAlignDialog,
DDeiCoreChooseControlDialog
]);
}
getDialogs(editor) {
var _a3;
let panels = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getDialogs(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getDialogs(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
panels = panels.concat(ls);
}
});
return panels;
}
static configuration(options) {
var _a3;
if (options) {
let panels = new _DDeiCoreDialogs(options);
for (let i2 = 0; i2 < ((_a3 = panels.plugins) == null ? void 0 : _a3.length); i2++) {
panels.plugins[i2] = panels.plugins[i2].configuration(options, true);
}
return panels;
}
return _DDeiCoreDialogs;
}
static modify(fn) {
return _DDeiCoreDialogs.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreDialogs, "defaultIns", new _DDeiCoreDialogs(null));
let DDeiCoreDialogs = _DDeiCoreDialogs;
const _sfc_main$n = {
name: "pv-text",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
watch: {},
created() {
this.$watch("attrDefine.value", function(newVal, oldVal) {
this.valueChange();
});
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
valueChange(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let value = parser.parseValue(this.attrDefine.value);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, value);
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
} else {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
});
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVTextEditor_vue_vue_type_style_index_0_scoped_48447048_lang = "";
const _hoisted_1$n = ["type", "disabled", "placeholder"];
function _sfc_render$n(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2;
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-text": true, "ddei-pv-editor-text--disabled": $props.attrDefine.readonly })
}, [
vue.withDirectives(vue.createElementVNode("input", {
type: ((_b2 = (_a3 = $props.attrDefine) == null ? void 0 : _a3.itemStyle) == null ? void 0 : _b2.type) ? (_d2 = (_c2 = $props.attrDefine) == null ? void 0 : _c2.itemStyle) == null ? void 0 : _d2.type : "input",
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $props.attrDefine.value = $event),
disabled: $props.attrDefine.readonly,
placeholder: $props.editor.i18n($props.attrDefine.defaultValue),
autocomplete: "off"
}, null, 8, _hoisted_1$n), [
[vue.vModelDynamic, $props.attrDefine.value]
])
], 2);
}
const PVTextEditor = /* @__PURE__ */ _export_sfc(_sfc_main$n, [["render", _sfc_render$n], ["__scopeId", "data-v-48447048"]]);
const _DDeiCoreTextPropEditor = class _DDeiCoreTextPropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", PVTextEditor.name);
__publicField3(this, "type", "plugin");
__publicField3(this, "plugins", [PVTextEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreTextPropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVTextEditor.name]) {
for (let i2 in options[PVTextEditor.name]) {
newOptions[i2] = options[PVTextEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreTextPropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreTextPropEditor;
}
static modify(fn) {
return _DDeiCoreTextPropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreTextPropEditor, "defaultIns", new _DDeiCoreTextPropEditor(null));
let DDeiCoreTextPropEditor = _DDeiCoreTextPropEditor;
const _sfc_main$m = {
name: "pv-basecombox",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
canSearch: {
type: Boolean,
default: false
},
searchMethod: {
type: Function,
defaut: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
//是否展开
expanded: false,
//值
value: null,
//文本
text: null,
//图片
img: null,
defaultText: ""
};
},
computed: {},
watch: {},
created() {
this.search = debounce(this.search, 200);
},
mounted() {
this.destroyDialog();
},
methods: {
getShowDialogId(id) {
return "ddei_attr_editor_dialog_" + id;
},
getEditorId(id) {
return "ddei_attr_editor_" + id;
},
search(evt) {
if (this.searchMethod) {
this.searchMethod(this.text, evt);
}
},
//打开弹出框
showDialog(show = false, evt) {
var _a3;
if (!((_a3 = this.editor) == null ? void 0 : _a3.containerid)) {
return;
}
let dialogId = this.getShowDialogId(this.attrDefine.code);
let dialog = document.getElementById(dialogId);
let haveElement = false;
let ele = document.getElementById(this.editor.containerid);
for (let i2 = 0; i2 < ele.children.length; i2++) {
if (ele.children[i2] == dialog) {
haveElement = true;
}
}
if (!haveElement) {
let ele2 = document.getElementById(this.editor.containerid);
ele2.appendChild(dialog);
}
if (!this.expanded || haveElement) {
dialog.style.display = "block";
let attrEditor = document.getElementById(
this.getEditorId(this.attrDefine.code)
);
let position = DDeiUtil.getDomAbsPosition(attrEditor, this.editor);
let tabPanelEles = this.editor.htmlElement.getElementsByClassName("propertyview-subgroup-tabpanel");
let tabPanelTop = 0;
if ((tabPanelEles == null ? void 0 : tabPanelEles.length) > 0) {
tabPanelTop = tabPanelEles[0].scrollTop;
}
dialog.style.left = position.left - dialog.offsetWidth + attrEditor.offsetWidth - 9.5 + "px";
dialog.style.top = position.top + attrEditor.offsetHeight - tabPanelTop + "px";
this.expanded = true;
if (!DDeiEditor.ACTIVE_INSTANCE.tempDialogData) {
DDeiEditor.ACTIVE_INSTANCE.tempDialogData = {};
}
DDeiEditor.ACTIVE_INSTANCE.tempDialogData[dialogId] = { group: "property-dialog" };
} else {
dialog.style.display = "none";
this.expanded = false;
if (DDeiEditor.ACTIVE_INSTANCE.tempDialogData) {
DDeiEditor.ACTIVE_INSTANCE.tempDialogData[dialogId] = null;
}
}
},
//移除弹出框
destroyDialog() {
var _a3;
if ((_a3 = this.editor) == null ? void 0 : _a3.containerid) {
let dialogs = [];
let ele = document.getElementById(this.editor.containerid);
for (let i2 = 0; i2 < ele.children.length; i2++) {
if (ele.children[i2].className == "ddei-combox-show-dialog") {
dialogs.push(ele.children[i2]);
}
}
dialogs.forEach((dialog) => {
dialog.remove();
});
}
},
closeDialog(evt) {
this.expanded = false;
let dialog = document.getElementById(
this.getShowDialogId(this.attrDefine.code)
);
dialog.style.display = "none";
}
}
};
const PVBaseCombox_vue_vue_type_style_index_0_scoped_b36dc5e7_lang = "";
const _hoisted_1$m = ["id"];
const _hoisted_2$f = ["readonly", "placeholder"];
const _hoisted_3$c = ["id"];
const _hoisted_4$5 = { class: "ddei-combox-show-dialog-content" };
function _sfc_render$m(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p;
return vue.openBlock(), vue.createElementBlock("div", {
id: $options.getEditorId((_a3 = $props.attrDefine) == null ? void 0 : _a3.code),
class: vue.normalizeClass({ "ddei-pv-base-combox": true, "ddei-pv-base-combox--disabled": !$props.attrDefine || $props.attrDefine.readonly })
}, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "textinput": true, "textinput_expanded": $data.expanded, "display_img": $data.img && ((_c2 = (_b2 = $props.attrDefine) == null ? void 0 : _b2.itemStyle) == null ? void 0 : _c2.display) == "img", "display_img_text": $data.img && ((_e2 = (_d2 = $props.attrDefine) == null ? void 0 : _d2.itemStyle) == null ? void 0 : _e2.display) == "img-text" })
}, [
$data.img && (((_g = (_f = $props.attrDefine) == null ? void 0 : _f.itemStyle) == null ? void 0 : _g.display) == "img-text" || ((_i = (_h = $props.attrDefine) == null ? void 0 : _h.itemStyle) == null ? void 0 : _i.display) == "img") ? (vue.openBlock(), vue.createElementBlock("span", {
key: 0,
class: vue.normalizeClass($data.img),
onClick: _cache[0] || (_cache[0] = ($event) => $props.attrDefine && !$props.attrDefine.readonly && !$props.canSearch && $options.showDialog())
}, null, 2)) : vue.createCommentVNode("", true),
!((_k = (_j = $props.attrDefine) == null ? void 0 : _j.itemStyle) == null ? void 0 : _k.display) || ((_m = (_l = $props.attrDefine) == null ? void 0 : _l.itemStyle) == null ? void 0 : _m.display) == "img-text" || ((_o = (_n = $props.attrDefine) == null ? void 0 : _n.itemStyle) == null ? void 0 : _o.display) == "text" ? vue.withDirectives((vue.openBlock(), vue.createElementBlock("input", {
key: 1,
type: "text",
autocomplete: "off",
readonly: $props.attrDefine && ($props.attrDefine.readonly || !$props.canSearch),
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => $data.text = $event),
placeholder: $data.defaultText,
onClick: _cache[2] || (_cache[2] = ($event) => $props.attrDefine && !$props.attrDefine.readonly && !$props.canSearch && $options.showDialog()),
onKeydown: _cache[3] || (_cache[3] = ($event) => $options.search($event))
}, null, 40, _hoisted_2$f)), [
[vue.vModelText, $data.text]
]) : vue.createCommentVNode("", true),
vue.createElementVNode("div", {
style: { "display": "flex", "justify-content": "center", "align-items": "center" },
onClick: _cache[4] || (_cache[4] = ($event) => $props.attrDefine && !$props.attrDefine.readonly && $options.showDialog())
}, _cache[5] || (_cache[5] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
], -1)
]))
], 2),
vue.createElementVNode("div", {
id: $options.getShowDialogId((_p = $props.attrDefine) == null ? void 0 : _p.code),
class: vue.normalizeClass({ "ddei-combox-show-dialog": true })
}, [
vue.createElementVNode("div", _hoisted_4$5, [
vue.renderSlot(_ctx.$slots, "default", {}, void 0, true)
])
], 8, _hoisted_3$c)
], 10, _hoisted_1$m);
}
const PVBaseCombox = /* @__PURE__ */ _export_sfc(_sfc_main$m, [["render", _sfc_render$m], ["__scopeId", "data-v-b36dc5e7"]]);
const _sfc_main$l = {
name: "pv-align-type",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
//临时选择的值
value: null
};
},
computed: {},
components: {
PVBaseCombox
},
watch: {},
created() {
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n;
let type = this.getTypeValue();
let text2 = this.getTypeText(type.value);
if (!type.isDefault) {
this.attrDefine.value = type.value;
}
this.$refs.combox.text = text2;
this.$refs.combox.value = type.value;
this.value = type.value;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
let mds = [];
if (((_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.size) > 0) {
mds = Array.from(
(_l = (_k = (_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage) == null ? void 0 : _k.selectedModels) == null ? void 0 : _l.values()
);
}
if (((_m = this.attrDefine) == null ? void 0 : _m.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_n = this.attrDefine) == null ? void 0 : _n.code }, this.editor.ddInstance, null);
this.attrDefine.readonly = rsState == -1;
}
},
methods: {
getTypeText(type) {
return this.editor.i18n("ddei.property.ds.pos" + type);
},
getTypeValue() {
let align = DDeiUtil.getDataByPathList(
this.attrDefine.model,
"textStyle.align"
);
let valign = DDeiUtil.getDataByPathList(
this.attrDefine.model,
"textStyle.valign"
);
if (align == 1 && valign == 1) {
return { value: 1 };
} else if (align == 2 && valign == 1) {
return { value: 2 };
} else if (align == 3 && valign == 1) {
return { value: 3 };
} else if (align == 1 && valign == 2) {
return { value: 4 };
} else if (align == 2 && valign == 2) {
return { value: 5 };
} else if (align == 3 && valign == 2) {
return { value: 6 };
} else if (align == 1 && valign == 3) {
return { value: 7 };
} else if (align == 2 && valign == 3) {
return { value: 8 };
} else if (align == 3 && valign == 3) {
return { value: 9 };
}
return { isDefault: true, value: 5 };
},
valueChange(type, evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let align = 2;
let valign = 2;
switch (type) {
case 1:
align = 1;
valign = 1;
break;
case 2:
align = 2;
valign = 1;
break;
case 3:
align = 3;
valign = 1;
break;
case 4:
align = 1;
valign = 2;
break;
case 5:
align = 2;
valign = 2;
break;
case 6:
align = 3;
valign = 2;
break;
case 7:
align = 1;
valign = 3;
break;
case 8:
align = 2;
valign = 3;
break;
case 9:
align = 3;
valign = 3;
break;
}
this.attrDefine.value = type;
let text2 = this.getTypeText(type);
this.$refs.combox.text = text2;
this.$refs.combox.value = type;
this.value = type;
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let alignValue = parser.parseValue(align);
let valignValue = parser.parseValue(valign);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, this.value);
this.attrDefine.doCascadeDisplayByValue();
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value: this.value,
attrDefine: this.attrDefine
},
evt,
true
);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, this.value);
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths: ["textStyle.align"],
value: alignValue,
attrDefine: this.attrDefine
},
evt,
true
);
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths: ["textStyle.valign"],
value: valignValue,
attrDefine: this.attrDefine
},
evt,
true
);
DDeiUtil.setAttrValueByPath(
this.attrDefine.model,
["textStyle.align"],
alignValue
);
DDeiUtil.setAttrValueByPath(
this.attrDefine.model,
["textStyle.valign"],
valignValue
);
});
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVAlignTypeEditor_vue_vue_type_style_index_0_scoped_135fda87_lang = "";
const _hoisted_1$l = { class: "ddei-pv-editor-aligntype" };
const _hoisted_2$e = { class: "ddei-pv-editor-aligntype-items" };
const _hoisted_3$b = { style: { "vertical-align": "top" } };
const _hoisted_4$4 = { style: { "vertical-align": "top" } };
const _hoisted_5$4 = { style: { "vertical-align": "top" } };
const _hoisted_6$4 = { style: { "vertical-align": "middle" } };
const _hoisted_7$4 = { style: { "vertical-align": "middle" } };
const _hoisted_8$3 = { style: { "vertical-align": "middle" } };
const _hoisted_9$3 = { style: { "vertical-align": "bottom" } };
const _hoisted_10$2 = { style: { "vertical-align": "bottom" } };
const _hoisted_11$2 = { style: { "vertical-align": "bottom" } };
function _sfc_render$l(_ctx, _cache, $props, $setup, $data, $options) {
const _component_PVBaseCombox = vue.resolveComponent("PVBaseCombox");
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$l, [
vue.createVNode(_component_PVBaseCombox, {
editor: $props.editor,
controlDefine: $props.controlDefine,
attrDefine: $props.attrDefine,
ref: "combox",
canSearch: false
}, {
default: vue.withCtx(() => [
vue.createElementVNode("div", _hoisted_2$e, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-pv-editor-aligntype-item": true, "ddei-pv-editor-aligntype-item--selected": $data.value == 1 }),
style: { "text-align": "left" },
onClick: _cache[0] || (_cache[0] = ($event) => $options.valueChange(1, $event))
}, [
vue.createElementVNode("div", _hoisted_3$b, vue.toDisplayString($props.editor.i18n("ddei.property.ds.pos1")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-pv-editor-aligntype-item": true, "ddei-pv-editor-aligntype-item--selected": $data.value == 2 }),
style: { "text-align": "center" },
onClick: _cache[1] || (_cache[1] = ($event) => $options.valueChange(2, $event))
}, [
vue.createElementVNode("div", _hoisted_4$4, vue.toDisplayString($props.editor.i18n("ddei.property.ds.pos2")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-pv-editor-aligntype-item": true, "ddei-pv-editor-aligntype-item--selected": $data.value == 3 }),
style: { "text-align": "right" },
onClick: _cache[2] || (_cache[2] = ($event) => $options.valueChange(3, $event))
}, [
vue.createElementVNode("div", _hoisted_5$4, vue.toDisplayString($props.editor.i18n("ddei.property.ds.pos3")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-pv-editor-aligntype-item": true, "ddei-pv-editor-aligntype-item--selected": $data.value == 4 }),
style: { "text-align": "left" },
onClick: _cache[3] || (_cache[3] = ($event) => $options.valueChange(4, $event))
}, [
vue.createElementVNode("div", _hoisted_6$4, vue.toDisplayString($props.editor.i18n("ddei.property.ds.pos4")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-pv-editor-aligntype-item": true, "ddei-pv-editor-aligntype-item--selected": $data.value == 5 }),
style: { "text-align": "center" },
onClick: _cache[4] || (_cache[4] = ($event) => $options.valueChange(5, $event))
}, [
vue.createElementVNode("div", _hoisted_7$4, vue.toDisplayString($props.editor.i18n("ddei.property.ds.pos5")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-pv-editor-aligntype-item": true, "ddei-pv-editor-aligntype-item--selected": $data.value == 6 }),
style: { "text-align": "right" },
onClick: _cache[5] || (_cache[5] = ($event) => $options.valueChange(6, $event))
}, [
vue.createElementVNode("div", _hoisted_8$3, vue.toDisplayString($props.editor.i18n("ddei.property.ds.pos6")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-pv-editor-aligntype-item": true, "ddei-pv-editor-aligntype-item--selected": $data.value == 7 }),
style: { "text-align": "left" },
onClick: _cache[6] || (_cache[6] = ($event) => $options.valueChange(7, $event))
}, [
vue.createElementVNode("div", _hoisted_9$3, vue.toDisplayString($props.editor.i18n("ddei.property.ds.pos7")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-pv-editor-aligntype-item": true, "ddei-pv-editor-aligntype-item--selected": $data.value == 8 }),
style: { "text-align": "center" },
onClick: _cache[7] || (_cache[7] = ($event) => $options.valueChange(8, $event))
}, [
vue.createElementVNode("div", _hoisted_10$2, vue.toDisplayString($props.editor.i18n("ddei.property.ds.pos8")), 1)
], 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-pv-editor-aligntype-item": true, "ddei-pv-editor-aligntype-item--selected": $data.value == 9 }),
style: { "text-align": "right" },
onClick: _cache[8] || (_cache[8] = ($event) => $options.valueChange(9, $event))
}, [
vue.createElementVNode("div", _hoisted_11$2, vue.toDisplayString($props.editor.i18n("ddei.property.ds.pos9")), 1)
], 2)
])
]),
_: 1
}, 8, ["editor", "controlDefine", "attrDefine"])
]);
}
const PVAlignTypeEditor = /* @__PURE__ */ _export_sfc(_sfc_main$l, [["render", _sfc_render$l], ["__scopeId", "data-v-135fda87"]]);
const _DDeiCoreAlignTypePropEditor = class _DDeiCoreAlignTypePropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVAlignTypeEditor.name);
__publicField3(this, "plugins", [PVAlignTypeEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreAlignTypePropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVAlignTypeEditor.name]) {
for (let i2 in options[PVAlignTypeEditor.name]) {
newOptions[i2] = options[PVAlignTypeEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreAlignTypePropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreAlignTypePropEditor;
}
static modify(fn) {
return _DDeiCoreAlignTypePropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreAlignTypePropEditor, "defaultIns", new _DDeiCoreAlignTypePropEditor(null));
let DDeiCoreAlignTypePropEditor = _DDeiCoreAlignTypePropEditor;
const _sfc_main$k = {
name: "pv-border-dash",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
//值
value: null
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
getEditorId(id) {
return "ddei_attr_editor_" + id;
},
//打开弹出框
showDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-selectborderdash", {
value: this.attrDefine.value,
dataSource: this.attrDefine.dataSource,
callback: {
ok: this.valueChange
},
group: "property-dialog"
}, { type: 5 }, srcElement);
},
valueChange(value) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
this.attrDefine.getParser();
this.attrDefine.value = value;
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, value);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, value);
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
null,
true
);
} else {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value,
attrDefine: this.attrDefine
},
null,
true
);
});
}
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVBorderDashComboEditor_vue_vue_type_style_index_0_scoped_2e01e102_lang = "";
const _hoisted_1$k = ["id"];
const _hoisted_2$d = { class: "div_input" };
const _hoisted_3$a = ["stroke-dasharray"];
function _sfc_render$k(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return vue.openBlock(), vue.createElementBlock("div", {
id: $options.getEditorId((_a3 = $props.attrDefine) == null ? void 0 : _a3.code),
class: vue.normalizeClass({ "ddei-pv-border-dash-combox": true, "ddei-pv-border-dash-combox--disabled": !$props.attrDefine || $props.attrDefine.readonly })
}, [
vue.createElementVNode("div", {
class: "textinput",
onClick: _cache[0] || (_cache[0] = ($event) => $props.attrDefine && !$props.attrDefine.readonly && $options.showDialog($event))
}, [
(vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$d, [
vue.createElementVNode("line", {
x1: "0",
y1: "0",
x2: "100%",
y2: "0",
"stroke-width": "3",
"stroke-dasharray": $props.attrDefine.value
}, null, 8, _hoisted_3$a)
])),
_cache[1] || (_cache[1] = vue.createElementVNode("div", { style: { "display": "flex", "justify-content": "center", "align-items": "center" } }, [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
])
], -1))
])
], 10, _hoisted_1$k);
}
const PVBorderDashComboEditor = /* @__PURE__ */ _export_sfc(_sfc_main$k, [["render", _sfc_render$k], ["__scopeId", "data-v-2e01e102"]]);
const _DDeiCoreBorderDashComboPropEditor = class _DDeiCoreBorderDashComboPropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVBorderDashComboEditor.name);
__publicField3(this, "plugins", [PVBorderDashComboEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreBorderDashComboPropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVBorderDashComboEditor.name]) {
for (let i2 in options[PVBorderDashComboEditor.name]) {
newOptions[i2] = options[PVBorderDashComboEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreBorderDashComboPropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreBorderDashComboPropEditor;
}
static modify(fn) {
return _DDeiCoreBorderDashComboPropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreBorderDashComboPropEditor, "defaultIns", new _DDeiCoreBorderDashComboPropEditor(null));
let DDeiCoreBorderDashComboPropEditor = _DDeiCoreBorderDashComboPropEditor;
const _sfc_main$j = {
name: "pv-border-type",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
dataSource: null
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
this.getDataSource(this.attrDefine);
let type = this.getTypeValue();
if (type) {
this.attrDefine.value = type.value;
this.showOrHiddenOtherAttrs(this.attrDefine.value);
}
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
/**
* 根据值获取选项定义
* @param value 值
*/
getDataDefine(value) {
if (this.dataSource && value) {
for (let i2 = 0; i2 < this.dataSource.length; i2++) {
if (this.dataSource[i2].value.toString() == value.toString()) {
return this.dataSource[i2];
}
}
}
return { text: "" };
},
/**
* 选中radio
*/
checkRadioValue(attrDefine, evt) {
let targetElement = evt.target;
if (targetElement.tagName == "DIV" && targetElement.className == "itembox") {
targetElement = targetElement.children[0];
} else if (targetElement.tagName == "DIV") {
targetElement = targetElement.parentElement.children[0];
}
if (attrDefine.value == targetElement.value) {
attrDefine.value = null;
} else {
attrDefine.value = targetElement.value;
}
this.valueChange();
},
/**
* 获取数据源数据
*/
getDataSource(attrDefine) {
let dataSources = DDeiEditorUtil.getDataSource(this.editor, this.attrDefine);
this.dataSource = dataSources;
return this.dataSource;
},
showOrHiddenOtherAttrs(value) {
if (value == "0") {
this.controlDefine.groups.forEach((group2) => {
DDeiEditorArrtibute.hiddenAttributesByCode(
group2,
"border.color",
"borderOpacity",
"borderWidth",
"borderDash",
"borderRound"
);
});
} else if (value == "1") {
this.controlDefine.groups.forEach((group2) => {
DDeiEditorArrtibute.showAttributesByCode(
group2,
"border.color",
"borderOpacity",
"borderWidth",
"borderDash",
"borderRound"
);
});
}
},
getTypeValue() {
var _a3, _b2;
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.exmapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let value = DDeiUtil.getDataByPathList(this.attrDefine.model, paths);
if (!value) {
return { value: "1" };
} else if (value == "true" || value == true) {
return { value: "0" };
}
return {
isDefault: true,
value: this.attrDefine.getParser().getDefaultValue()
};
},
valueChange(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.exmapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let value = parser.parseValue(this.attrDefine.value);
this.showOrHiddenOtherAttrs(value);
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
if (value == "0") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value: true,
attrDefine: this.attrDefine
},
evt,
true
);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, true);
} else if (value == "1") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value: false,
attrDefine: this.attrDefine
},
evt,
true
);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, false);
}
});
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVBorderTypeEditor_vue_vue_type_style_index_0_scoped_ea9f8fdd_lang = "";
const _hoisted_1$j = ["disabled", "name", "value"];
function _sfc_render$j(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei_pv_editor_bordertype": true, "ddei_pv_editor_bordertype_disabled": $props.attrDefine.readonly }),
style: vue.normalizeStyle({ "pointer-events": $props.attrDefine.readonly ? "none" : "" })
}, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (item) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: "itembox",
onClick: _cache[1] || (_cache[1] = ($event) => $options.checkRadioValue($props.attrDefine, $event))
}, [
vue.withDirectives(vue.createElementVNode("input", {
type: "radio",
disabled: $props.attrDefine.readonly,
name: $props.attrDefine.id,
value: item.value,
autocomplete: "off",
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $props.attrDefine.value = $event)
}, null, 8, _hoisted_1$j), [
[vue.vModelRadio, $props.attrDefine.value]
]),
vue.createElementVNode("div", null, vue.toDisplayString(item.text), 1)
]);
}), 256))
], 6);
}
const PVBorderTypeEditor = /* @__PURE__ */ _export_sfc(_sfc_main$j, [["render", _sfc_render$j], ["__scopeId", "data-v-ea9f8fdd"]]);
const _DDeiCoreBorderTypePropEditor = class _DDeiCoreBorderTypePropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVBorderTypeEditor.name);
__publicField3(this, "plugins", [PVBorderTypeEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreBorderTypePropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVBorderTypeEditor.name]) {
for (let i2 in options[PVBorderTypeEditor.name]) {
newOptions[i2] = options[PVBorderTypeEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreBorderTypePropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreBorderTypePropEditor;
}
static modify(fn) {
return _DDeiCoreBorderTypePropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreBorderTypePropEditor, "defaultIns", new _DDeiCoreBorderTypePropEditor(null));
let DDeiCoreBorderTypePropEditor = _DDeiCoreBorderTypePropEditor;
const _sfc_main$i = {
name: "pv-color-combo",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
//值
value: null
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
getEditorId(id) {
return "ddei_attr_editor_" + id;
},
//打开弹出框
showDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-selectcolor", {
value: this.attrDefine.value,
callback: {
ok: this.valueChange
},
group: "property-dialog"
}, { type: 5 }, srcElement);
},
valueChange(value) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
this.attrDefine.getParser();
this.attrDefine.value = value;
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, value);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, value);
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
null,
true
);
} else {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value,
attrDefine: this.attrDefine
},
null,
true
);
});
}
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVColorComboEditor_vue_vue_type_style_index_0_scoped_22680f1e_lang = "";
const _hoisted_1$i = ["id"];
const _hoisted_2$c = ["readonly"];
function _sfc_render$i(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return vue.openBlock(), vue.createElementBlock("div", {
id: $options.getEditorId((_a3 = $props.attrDefine) == null ? void 0 : _a3.code),
class: vue.normalizeClass({ "ddei-pv-color-combox": true, "ddei-pv-color-combox--disabled": !$props.attrDefine || $props.attrDefine.readonly })
}, [
vue.createElementVNode("div", {
class: "textinput",
onClick: _cache[1] || (_cache[1] = ($event) => $props.attrDefine && !$props.attrDefine.readonly && $options.showDialog($event))
}, [
vue.withDirectives(vue.createElementVNode("input", {
type: "color",
readonly: $props.attrDefine && $props.attrDefine.readonly,
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $props.attrDefine.value = $event),
autocomplete: "off"
}, null, 8, _hoisted_2$c), [
[vue.vModelText, $props.attrDefine.value]
]),
_cache[2] || (_cache[2] = vue.createElementVNode("div", { style: { "display": "flex", "justify-content": "center", "align-items": "center" } }, [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-btn-down" })
])
], -1))
])
], 10, _hoisted_1$i);
}
const PVColorComboEditor = /* @__PURE__ */ _export_sfc(_sfc_main$i, [["render", _sfc_render$i], ["__scopeId", "data-v-22680f1e"]]);
const _DDeiCoreColorComboPropEditor = class _DDeiCoreColorComboPropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVColorComboEditor.name);
__publicField3(this, "plugins", [PVColorComboEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreColorComboPropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVColorComboEditor.name]) {
for (let i2 in options[PVColorComboEditor.name]) {
newOptions[i2] = options[PVColorComboEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreColorComboPropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreColorComboPropEditor;
}
static modify(fn) {
return _DDeiCoreColorComboPropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreColorComboPropEditor, "defaultIns", new _DDeiCoreColorComboPropEditor(null));
let DDeiCoreColorComboPropEditor = _DDeiCoreColorComboPropEditor;
const _sfc_main$h = {
name: "pv-color",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
watch: {},
created() {
this.valueChange = throttle(this.valueChange, 40);
this.$watch("attrDefine.value", function(newVal, oldVal) {
this.valueChange();
});
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
valueChange(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let value = parser.parseValue(this.attrDefine.value);
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, value);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, value);
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
} else {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
});
}
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVColorEditor_vue_vue_type_style_index_0_scoped_ec0fa5a7_lang = "";
const _hoisted_1$h = ["step", "disabled"];
const _hoisted_2$b = { class: "textinput" };
const _hoisted_3$9 = ["disabled", "placeholder"];
function _sfc_render$h(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-color": true, "ddei-pv-editor-color--disabled": $props.attrDefine.readonly })
}, [
vue.withDirectives(vue.createElementVNode("input", {
type: "color",
step: $props.attrDefine.step,
class: "color",
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $props.attrDefine.value = $event),
autocomplete: "off",
disabled: $props.attrDefine.readonly
}, null, 8, _hoisted_1$h), [
[vue.vModelText, $props.attrDefine.value]
]),
vue.createElementVNode("div", _hoisted_2$b, [
vue.withDirectives(vue.createElementVNode("input", {
type: "text",
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => $props.attrDefine.value = $event),
disabled: $props.attrDefine.readonly,
autocomplete: "off",
placeholder: $props.attrDefine.defaultValue
}, null, 8, _hoisted_3$9), [
[vue.vModelText, $props.attrDefine.value]
])
])
], 2);
}
const PVColorEditor = /* @__PURE__ */ _export_sfc(_sfc_main$h, [["render", _sfc_render$h], ["__scopeId", "data-v-ec0fa5a7"]]);
const _DDeiCoreColorPropEditor = class _DDeiCoreColorPropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVColorEditor.name);
__publicField3(this, "plugins", [PVColorEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreColorPropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVColorEditor.name]) {
for (let i2 in options[PVColorEditor.name]) {
newOptions[i2] = options[PVColorEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreColorPropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreColorPropEditor;
}
static modify(fn) {
return _DDeiCoreColorPropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreColorPropEditor, "defaultIns", new _DDeiCoreColorPropEditor(null));
let DDeiCoreColorPropEditor = _DDeiCoreColorPropEditor;
const _sfc_main$g = {
name: "pv-combox",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
//临时选择的值
value: null,
//已加载的数据源
dataSource: null,
width: 0,
height: 0,
col: 1,
gridTemplateColumns: "1fr",
gridTemplateRows: "",
searchText: ""
};
},
computed: {},
components: {
PVBaseCombox
},
watch: {},
created() {
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B;
let itemWidth = ((_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.itemStyle) == null ? void 0 : _b2.width) ? (_d2 = (_c2 = this.attrDefine) == null ? void 0 : _c2.itemStyle) == null ? void 0 : _d2.width : 100;
let itemCols = ((_f = (_e2 = this.attrDefine) == null ? void 0 : _e2.itemStyle) == null ? void 0 : _f.col) ? (_h = (_g = this.attrDefine) == null ? void 0 : _g.itemStyle) == null ? void 0 : _h.col : 1;
let itemHeight = ((_j = (_i = this.attrDefine) == null ? void 0 : _i.itemStyle) == null ? void 0 : _j.height) ? (_l = (_k = this.attrDefine) == null ? void 0 : _k.itemStyle) == null ? void 0 : _l.height : 30;
let itemRows = ((_n = (_m = this.attrDefine) == null ? void 0 : _m.itemStyle) == null ? void 0 : _n.row) ? (_p = (_o = this.attrDefine) == null ? void 0 : _o.itemStyle) == null ? void 0 : _p.row : 0;
this.width = (itemWidth + 5) * itemCols + 10;
this.col = itemCols;
this.height = (itemHeight + 5) * itemRows;
let gridTemplateColumns = this.gridTemplateColumns;
if (this.col > 1) {
for (let i2 = 2; i2 <= this.col; i2++) {
gridTemplateColumns += " 1fr";
}
this.gridTemplateColumns = gridTemplateColumns;
}
if (itemRows) {
let gridTemplateRows = "";
for (let i2 = 1; i2 <= itemRows; i2++) {
gridTemplateRows += itemHeight + "px ";
}
this.gridTemplateRows = gridTemplateRows;
}
this.getDataSource(this.attrDefine);
let type = this.getDataValue();
let define2 = this.getDataDefine(type.value);
if (!type.isDefault) {
this.attrDefine.value = type.value;
this.$refs.combox.text = define2.text;
if (define2.img) {
this.$refs.combox.img = define2.img;
}
} else {
this.$refs.combox.defaultText = define2.text;
this.$refs.combox.img = define2.img;
}
this.$refs.combox.value = type.value;
this.value = type.value;
this.attrDefine.doCascadeDisplayByValue();
let mds;
if (((_t = (_s = (_r = (_q = this.editor) == null ? void 0 : _q.ddInstance) == null ? void 0 : _r.stage) == null ? void 0 : _s.selectedModels) == null ? void 0 : _t.size) > 0) {
mds = Array.from(
(_x = (_w = (_v = (_u = this.editor) == null ? void 0 : _u.ddInstance) == null ? void 0 : _v.stage) == null ? void 0 : _w.selectedModels) == null ? void 0 : _x.values()
);
} else {
mds = [(_z = (_y = this.editor) == null ? void 0 : _y.ddInstance) == null ? void 0 : _z.stage];
}
if (((_A = this.attrDefine) == null ? void 0 : _A.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_B = this.attrDefine) == null ? void 0 : _B.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
/**
* 根据值获取选项定义
* @param value 值
*/
getDataDefine(value) {
if (this.dataSource && value) {
for (let i2 = 0; i2 < this.dataSource.length; i2++) {
if (this.dataSource[i2].value.toString() == value.toString()) {
return this.dataSource[i2];
}
}
}
return { text: "" };
},
doSearch(text2, evt) {
this.searchText = text2;
this.getDataSource(this.attrDefine);
this.$refs.combox.showDialog(true, evt);
},
//获取数据值
getDataValue() {
var _a3;
if (this.attrDefine) {
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(
this.attrDefine.model,
this.attrDefine.code,
this.attrDefine.mapping
);
}
if (dataValue) {
return { value: dataValue };
}
}
return {
isDefault: true,
value: (_a3 = this.attrDefine) == null ? void 0 : _a3.getParser().getDefaultValue()
};
},
valueChange(value, evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
this.attrDefine.value = value;
let itemDefine = this.getDataDefine(value);
let text2 = itemDefine.text;
this.$refs.combox.text = text2;
if (itemDefine.img) {
this.$refs.combox.img = itemDefine.img;
}
this.$refs.combox.value = value;
this.value = value;
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(value);
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, value);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, parsedValue);
this.attrDefine.doCascadeDisplayByValue();
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
} else {
(_o = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _o.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value: parsedValue,
attrDefine: this.attrDefine
},
evt,
true
);
});
}
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_p = this.attrDefine) == null ? void 0 : _p.code }, this.editor.ddInstance, null);
},
/**
* 获取数据源数据
*/
getDataSource(attrDefine) {
if (this.attrDefine) {
let dataSources = DDeiEditorUtil.getDataSource(
this.editor,
this.attrDefine,
this.searchText
);
this.dataSource = dataSources;
return this.dataSource;
}
}
}
};
const PVComboxEditor_vue_vue_type_style_index_0_scoped_e318138d_lang = "";
const _hoisted_1$g = ["onClick", "title"];
const _hoisted_2$a = {
key: 0,
class: "itembox_img"
};
const _hoisted_3$8 = ["src"];
function _sfc_render$g(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
const _component_PVBaseCombox = vue.resolveComponent("PVBaseCombox");
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-combox": true, "ddei-pv-editor-combox--disabled": !$props.attrDefine || $props.attrDefine.readonly }),
style: vue.normalizeStyle({ "pointer-events": $props.attrDefine.readonly ? "none" : "" })
}, [
vue.createVNode(_component_PVBaseCombox, {
editor: $props.editor,
controlDefine: $props.controlDefine,
attrDefine: $props.attrDefine,
searchMethod: $options.doSearch,
ref: "combox",
canSearch: (_a3 = $props.attrDefine) == null ? void 0 : _a3.canSearch
}, {
default: vue.withCtx(() => [
vue.createElementVNode("div", {
class: "itemboxs",
style: vue.normalizeStyle({ width: $data.width ? $data.width + "px" : "", height: $data.height ? $data.height + "px" : "", "grid-template-columns": $data.gridTemplateColumns, "grid-template-rows": $data.gridTemplateRows })
}, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (item) => {
var _a4, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n;
return vue.openBlock(), vue.createElementBlock("div", {
style: vue.normalizeStyle({ width: ((_b2 = (_a4 = $props.attrDefine) == null ? void 0 : _a4.itemStyle) == null ? void 0 : _b2.width) + "px", height: ((_d2 = (_c2 = $props.attrDefine) == null ? void 0 : _c2.itemStyle) == null ? void 0 : _d2.height) + "px" }),
class: vue.normalizeClass({ "itembox": true, "itembox--selected": item.value == $props.attrDefine.value, "itembox--deleted": item.deleted, "itembox--disabled": item.disabled, "itembox--underline": item.underline, "itembox--bold": item.bold }),
onClick: ($event) => !item.disabled && $options.valueChange(item.value, $event),
title: item.desc
}, [
item.img ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2$a, [
vue.createElementVNode("img", {
style: vue.normalizeStyle({ width: ((_f = (_e2 = $props.attrDefine) == null ? void 0 : _e2.itemStyle) == null ? void 0 : _f.imgWidth) + "px", height: ((_h = (_g = $props.attrDefine) == null ? void 0 : _g.itemStyle) == null ? void 0 : _h.imgHeight) + "px" }),
src: item.img
}, null, 12, _hoisted_3$8)
])) : vue.createCommentVNode("", true),
item.text ? (vue.openBlock(), vue.createElementBlock("div", {
key: 1,
class: "itembox_text",
style: vue.normalizeStyle({ "font-family": item.fontFamily, "text-align": (_j = (_i = $props.attrDefine) == null ? void 0 : _i.itemStyle) == null ? void 0 : _j.align, "padding-left": (_l = (_k = $props.attrDefine) == null ? void 0 : _k.itemStyle) == null ? void 0 : _l.paddingLeft })
}, vue.toDisplayString(item.text), 5)) : vue.createCommentVNode("", true),
item.desc ? (vue.openBlock(), vue.createElementBlock("div", {
key: 2,
class: "itembox_desc",
style: vue.normalizeStyle({ "font-family": item.fontFamily, "text-align": (_n = (_m = $props.attrDefine) == null ? void 0 : _m.itemStyle) == null ? void 0 : _n.align })
}, vue.toDisplayString(item.desc), 5)) : vue.createCommentVNode("", true)
], 14, _hoisted_1$g);
}), 256))
], 4)
]),
_: 1
}, 8, ["editor", "controlDefine", "attrDefine", "searchMethod", "canSearch"])
], 6);
}
const PVComboxEditor = /* @__PURE__ */ _export_sfc(_sfc_main$g, [["render", _sfc_render$g], ["__scopeId", "data-v-e318138d"]]);
const _DDeiCoreComboxPropEditor = class _DDeiCoreComboxPropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVComboxEditor.name);
__publicField3(this, "plugins", [PVComboxEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreComboxPropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVComboxEditor.name]) {
for (let i2 in options[PVComboxEditor.name]) {
newOptions[i2] = options[PVComboxEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreComboxPropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreComboxPropEditor;
}
static modify(fn) {
return _DDeiCoreComboxPropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreComboxPropEditor, "defaultIns", new _DDeiCoreComboxPropEditor(null));
let DDeiCoreComboxPropEditor = _DDeiCoreComboxPropEditor;
const _sfc_main$f = {
name: "pv-excheckbox",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
//临时选择的值
value: null,
//已加载的数据源
dataSource: null,
width: 0,
height: 0,
col: 1,
gridTemplateColumns: "1fr",
gridTemplateRows: "",
searchText: ""
};
},
computed: {},
components: {
PVBaseCombox
},
watch: {},
created() {
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B;
let itemWidth = ((_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.itemStyle) == null ? void 0 : _b2.width) ? (_d2 = (_c2 = this.attrDefine) == null ? void 0 : _c2.itemStyle) == null ? void 0 : _d2.width : 100;
let itemCols = ((_f = (_e2 = this.attrDefine) == null ? void 0 : _e2.itemStyle) == null ? void 0 : _f.col) ? (_h = (_g = this.attrDefine) == null ? void 0 : _g.itemStyle) == null ? void 0 : _h.col : 1;
let itemHeight = ((_j = (_i = this.attrDefine) == null ? void 0 : _i.itemStyle) == null ? void 0 : _j.height) ? (_l = (_k = this.attrDefine) == null ? void 0 : _k.itemStyle) == null ? void 0 : _l.height : 30;
let itemRows = ((_n = (_m = this.attrDefine) == null ? void 0 : _m.itemStyle) == null ? void 0 : _n.row) ? (_p = (_o = this.attrDefine) == null ? void 0 : _o.itemStyle) == null ? void 0 : _p.row : 0;
this.width = (itemWidth + 5) * itemCols + 10;
this.col = itemCols;
this.height = (itemHeight + 5) * itemRows;
let gridTemplateColumns = this.gridTemplateColumns;
if (this.col > 1) {
for (let i2 = 2; i2 <= this.col; i2++) {
gridTemplateColumns += " 1fr";
}
this.gridTemplateColumns = gridTemplateColumns;
}
if (itemRows) {
let gridTemplateRows = "";
for (let i2 = 1; i2 <= itemRows; i2++) {
gridTemplateRows += itemHeight + "px ";
}
this.gridTemplateRows = gridTemplateRows;
}
this.getDataSource(this.attrDefine);
let type = this.getDataValue();
let itemDefine = this.getDataDefine(type.value);
if ((itemDefine == null ? void 0 : itemDefine.length) > 0) {
let text2 = itemDefine[0].text;
for (let x2 = 1; x2 < itemDefine.length; x2++) {
text2 += "," + itemDefine[x2].text;
}
this.$refs.combox.text = text2;
if (itemDefine.img) {
this.$refs.combox.img = itemDefine[0].img;
}
this.$refs.combox.value = itemDefine[0].value;
this.attrDefine.value = type.value;
this.value = type.value;
}
this.attrDefine.doCascadeDisplayByValue();
let mds;
if (((_t = (_s = (_r = (_q = this.editor) == null ? void 0 : _q.ddInstance) == null ? void 0 : _r.stage) == null ? void 0 : _s.selectedModels) == null ? void 0 : _t.size) > 0) {
mds = Array.from(
(_x = (_w = (_v = (_u = this.editor) == null ? void 0 : _u.ddInstance) == null ? void 0 : _v.stage) == null ? void 0 : _w.selectedModels) == null ? void 0 : _x.values()
);
} else {
mds = [(_z = (_y = this.editor) == null ? void 0 : _y.ddInstance) == null ? void 0 : _z.stage];
}
if (((_A = this.attrDefine) == null ? void 0 : _A.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_B = this.attrDefine) == null ? void 0 : _B.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
/**
* 根据值获取选项定义
* @param value 值
*/
getDataDefine(value) {
let returnList = [];
if (this.dataSource && value) {
for (let i2 = 0; i2 < this.dataSource.length; i2++) {
for (let j2 = 0; j2 < value.length; j2++) {
if (this.dataSource[i2].value.toString() == value[j2].toString()) {
if (returnList.indexOf(this.getDataSource[i2]) == -1) {
returnList.push(this.dataSource[i2]);
}
}
}
}
}
return returnList;
},
doSearch(text2, evt) {
this.searchText = text2;
this.getDataSource(this.attrDefine);
this.$refs.combox.showDialog(true, evt);
},
//获取数据值
getDataValue() {
let dataValue = this.attrDefine.value;
if (!dataValue) {
dataValue = DDeiUtil.getDataByPathList(
this.attrDefine.model,
this.attrDefine.code,
this.attrDefine.mapping
);
}
if (dataValue) {
return { value: dataValue };
}
return {
isDefault: true,
value: this.attrDefine.getParser().getDefaultValue()
};
},
valueChange(value, evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
if (this.attrDefine.dataType.toLocaleLowerCase() == "integer" || this.attrDefine.dataType.toLocaleLowerCase() == "float" || this.attrDefine.dataType.toLocaleLowerCase() == "number") {
if (!value && value != 0) {
return;
}
} else if (!value) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
if (!this.value) {
this.value = [];
}
let strValue = value;
if (this.value.indexOf(strValue) == -1) {
this.value.push(strValue);
} else {
let index = this.value.indexOf(strValue);
if (index != -1) {
this.value.splice(index, 1);
}
}
this.attrDefine.value = this.value;
let itemDefine = this.getDataDefine(this.value);
if ((itemDefine == null ? void 0 : itemDefine.length) > 0) {
let text2 = itemDefine[0].text;
for (let x2 = 1; x2 < itemDefine.length; x2++) {
text2 += "," + itemDefine[x2].text;
}
this.$refs.combox.text = text2;
if (itemDefine.img) {
this.$refs.combox.img = itemDefine[0].img;
}
this.$refs.combox.value = itemDefine[0].value;
} else {
this.$refs.combox.text = null;
this.$refs.combox.value = null;
this.$refs.combox.img = null;
}
let parser = this.attrDefine.getParser();
let parsedValue = parser.parseValue(this.value);
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, parsedValue);
this.attrDefine.doCascadeDisplayByValue();
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
} else {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value: parsedValue,
attrDefine: this.attrDefine
},
evt,
true
);
});
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
},
/**
* 获取数据源数据
*/
getDataSource(attrDefine) {
let dataSources = DDeiEditorUtil.getDataSource(
this.editor,
this.attrDefine,
this.searchText
);
this.dataSource = dataSources;
return this.dataSource;
}
}
};
const PVExCheckboxEditor_vue_vue_type_style_index_0_scoped_4960d25a_lang = "";
const _hoisted_1$f = ["onClick", "title"];
const _hoisted_2$9 = {
key: 0,
class: "itembox_img"
};
const _hoisted_3$7 = ["src"];
function _sfc_render$f(_ctx, _cache, $props, $setup, $data, $options) {
const _component_PVBaseCombox = vue.resolveComponent("PVBaseCombox");
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-excheckbox": true, "ddei-pv-editor-excheckbox--disabled": $props.attrDefine.readonly }),
style: vue.normalizeStyle({ "pointer-events": $props.attrDefine.readonly ? "none" : "" })
}, [
vue.createVNode(_component_PVBaseCombox, {
editor: $props.editor,
controlDefine: $props.controlDefine,
attrDefine: $props.attrDefine,
searchMethod: $options.doSearch,
ref: "combox",
canSearch: $props.attrDefine.canSearch
}, {
default: vue.withCtx(() => [
vue.createElementVNode("div", {
class: "itemboxs",
style: vue.normalizeStyle({ width: $data.width ? $data.width + "px" : "", height: $data.height ? $data.height + "px" : "", "grid-template-columns": $data.gridTemplateColumns, "grid-template-rows": $data.gridTemplateRows })
}, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (item) => {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s;
return vue.openBlock(), vue.createElementBlock("div", {
style: vue.normalizeStyle({ width: ((_b2 = (_a3 = $props.attrDefine) == null ? void 0 : _a3.itemStyle) == null ? void 0 : _b2.width) + "px", height: ((_d2 = (_c2 = $props.attrDefine) == null ? void 0 : _c2.itemStyle) == null ? void 0 : _d2.height) + "px" }),
class: vue.normalizeClass({ "itembox": true, "itembox--selected": ((_e2 = $props.attrDefine) == null ? void 0 : _e2.value) && ((_g = (_f = $props.attrDefine) == null ? void 0 : _f.value) == null ? void 0 : _g.indexOf(item.value)) != -1, "itembox--deleted": item.deleted, "itembox--disabled": item.disabled || ((_i = (_h = $props.attrDefine) == null ? void 0 : _h.itemStyle) == null ? void 0 : _i.maxSelect) && ((_k = (_j = $props.attrDefine) == null ? void 0 : _j.itemStyle) == null ? void 0 : _k.maxSelect) <= ((_m = (_l = $props.attrDefine) == null ? void 0 : _l.value) == null ? void 0 : _m.length) && ((_o = (_n = $props.attrDefine) == null ? void 0 : _n.value) == null ? void 0 : _o.indexOf(item.value)) == -1, "itembox--underline": item.underline, "itembox--bold": item.bold }),
onClick: ($event) => {
var _a4, _b3, _c3, _d3, _e3, _f2, _g2, _h2;
return !item.disabled && (!((_b3 = (_a4 = $props.attrDefine) == null ? void 0 : _a4.itemStyle) == null ? void 0 : _b3.maxSelect) || ((_d3 = (_c3 = $props.attrDefine) == null ? void 0 : _c3.itemStyle) == null ? void 0 : _d3.maxSelect) > ((_f2 = (_e3 = $props.attrDefine) == null ? void 0 : _e3.value) == null ? void 0 : _f2.length) || ((_h2 = (_g2 = $props.attrDefine) == null ? void 0 : _g2.value) == null ? void 0 : _h2.indexOf(item.value)) != -1) && $options.valueChange(item.value, $event);
},
title: item.desc
}, [
item.img ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2$9, [
vue.createElementVNode("img", {
style: vue.normalizeStyle({ width: ((_q = (_p = $props.attrDefine) == null ? void 0 : _p.itemStyle) == null ? void 0 : _q.imgWidth) + "px", height: ((_s = (_r = $props.attrDefine) == null ? void 0 : _r.itemStyle) == null ? void 0 : _s.imgHeight) + "px" }),
src: item.img
}, null, 12, _hoisted_3$7)
])) : vue.createCommentVNode("", true),
item.text ? (vue.openBlock(), vue.createElementBlock("div", {
key: 1,
class: "itembox_text",
style: vue.normalizeStyle({ "font-family": item.fontFamily })
}, vue.toDisplayString(item.text), 5)) : vue.createCommentVNode("", true)
], 14, _hoisted_1$f);
}), 256))
], 4)
]),
_: 1
}, 8, ["editor", "controlDefine", "attrDefine", "searchMethod", "canSearch"])
], 6);
}
const PVExCheckboxEditor = /* @__PURE__ */ _export_sfc(_sfc_main$f, [["render", _sfc_render$f], ["__scopeId", "data-v-4960d25a"]]);
const _DDeiCoreExCheckboxPropEditor = class _DDeiCoreExCheckboxPropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVExCheckboxEditor.name);
__publicField3(this, "plugins", [PVExCheckboxEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreExCheckboxPropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVExCheckboxEditor.name]) {
for (let i2 in options[PVExCheckboxEditor.name]) {
newOptions[i2] = options[PVExCheckboxEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreExCheckboxPropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreExCheckboxPropEditor;
}
static modify(fn) {
return _DDeiCoreExCheckboxPropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreExCheckboxPropEditor, "defaultIns", new _DDeiCoreExCheckboxPropEditor(null));
let DDeiCoreExCheckboxPropEditor = _DDeiCoreExCheckboxPropEditor;
const _sfc_main$e = {
name: "pv-fill-type",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
dataSource: null
};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
this.getDataSource(this.attrDefine);
let type = this.getTypeValue();
if (type) {
this.attrDefine.value = type.value;
}
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
/**
* 根据值获取选项定义
* @param value 值
*/
getDataDefine(value) {
if (this.dataSource && value) {
for (let i2 = 0; i2 < this.dataSource.length; i2++) {
if (this.dataSource[i2].value.toString() == value.toString()) {
return this.dataSource[i2];
}
}
}
return { text: "" };
},
/**
* 选中radio
*/
checkRadioValue(attrDefine, evt) {
let targetElement = evt.target;
if (targetElement.tagName == "DIV" && targetElement.className == "itembox") {
targetElement = targetElement.children[0];
} else if (targetElement.tagName == "DIV") {
targetElement = targetElement.parentElement.children[0];
}
if (attrDefine.value == targetElement.value) {
attrDefine.value = null;
} else {
attrDefine.value = targetElement.value;
}
this.valueChange();
},
/**
* 获取数据源数据
*/
getDataSource(attrDefine) {
let dataSources = DDeiEditorUtil.getDataSource(this.editor, this.attrDefine);
this.dataSource = dataSources;
return this.dataSource;
},
getTypeValue() {
var _a3, _b2;
let paths = [];
(_b2 = (_a3 = this.attrDefine) == null ? void 0 : _a3.exmapping) == null ? void 0 : _b2.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let value = DDeiUtil.getDataByPathList(this.attrDefine.model, paths);
if (!value) {
return { value: "1" };
} else if (value == "true" || value == true) {
return { value: "0" };
}
return {
isDefault: true,
value: this.attrDefine.getParser().getDefaultValue()
};
},
valueChange(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.exmapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let value = parser.parseValue(this.attrDefine.value);
if (value == "0") {
DDeiEditorArrtibute.hiddenAttributesByCode(
this.controlDefine.styles,
"fill.color",
"fill.opacity"
);
if (this.controlDefine.subStyles) {
DDeiEditorArrtibute.hiddenAttributesByCode(
this.controlDefine.subStyles,
"fill.color",
"fill.opacity"
);
}
} else if (value == "1") {
DDeiEditorArrtibute.showAttributesByCode(
this.controlDefine.styles,
"fill.color",
"fill.opacity"
);
if (this.controlDefine.subStyles) {
DDeiEditorArrtibute.showAttributesByCode(
this.controlDefine.subStyles,
"fill.color",
"fill.opacity"
);
}
}
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
if (value == "0") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value: true,
attrDefine: this.attrDefine
},
evt,
true
);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, true);
} else if (value == "1") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value: false,
attrDefine: this.attrDefine
},
evt,
true
);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, false);
}
});
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVFillTypeEditor_vue_vue_type_style_index_0_scoped_64114ba5_lang = "";
const _hoisted_1$e = ["disabled", "name", "value"];
function _sfc_render$e(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-filltype": true, "ddei-pv-editor-filltype--disabled": $props.attrDefine.readonly }),
style: vue.normalizeStyle({ "pointer-events": $props.attrDefine.readonly ? "none" : "" })
}, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (item) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: "itembox",
onClick: _cache[1] || (_cache[1] = ($event) => $options.checkRadioValue($props.attrDefine, $event))
}, [
vue.withDirectives(vue.createElementVNode("input", {
type: "radio",
disabled: $props.attrDefine.readonly,
name: $props.attrDefine.id,
value: item.value,
autocomplete: "off",
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $props.attrDefine.value = $event)
}, null, 8, _hoisted_1$e), [
[vue.vModelRadio, $props.attrDefine.value]
]),
vue.createElementVNode("div", null, vue.toDisplayString(item.text), 1)
]);
}), 256))
], 6);
}
const PVFillTypeEditor = /* @__PURE__ */ _export_sfc(_sfc_main$e, [["render", _sfc_render$e], ["__scopeId", "data-v-64114ba5"]]);
const _DDeiCoreFillTypePropEditor = class _DDeiCoreFillTypePropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVFillTypeEditor.name);
__publicField3(this, "plugins", [PVFillTypeEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreFillTypePropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVFillTypeEditor.name]) {
for (let i2 in options[PVFillTypeEditor.name]) {
newOptions[i2] = options[PVFillTypeEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreFillTypePropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreFillTypePropEditor;
}
static modify(fn) {
return _DDeiCoreFillTypePropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreFillTypePropEditor, "defaultIns", new _DDeiCoreFillTypePropEditor(null));
let DDeiCoreFillTypePropEditor = _DDeiCoreFillTypePropEditor;
const _sfc_main$d = {
name: "pv-font-size",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
watch: {},
created() {
this.$watch("attrDefine.value", function(newVal, oldVal) {
this.valueChange();
});
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
valueChange(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let value = parser.parseValue(this.attrDefine.value);
value = isNaN(value) || value <= 0 ? null : value;
value = value > 300 ? 300 : value;
let hasEditSetted = false;
if (this.editor.ddInstance.stage.render.operateState == DDeiEnumOperateState.QUICK_EDITING) {
let shadowControl = this.editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
if (curSIdx != -1 && curEIdx != -1 && curSIdx <= curSIdx) {
shadowControl.setSptStyle(curSIdx, curEIdx, paths, value);
hasEditSetted = true;
}
}
}
if (!hasEditSetted) {
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, value);
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
} else {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
});
}
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVFontSizeEditor_vue_vue_type_style_index_0_scoped_b2ded6b2_lang = "";
const _hoisted_1$d = ["step", "min", "max", "disabled"];
const _hoisted_2$8 = { class: "textinput" };
const _hoisted_3$6 = ["step", "min", "max", "disabled", "placeholder"];
function _sfc_render$d(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-fontsize": true, "ddei-pv-editor-fontsize--disabled": $props.attrDefine.readonly }),
style: vue.normalizeStyle({ "pointer-events": $props.attrDefine.readonly ? "none" : "" })
}, [
vue.withDirectives(vue.createElementVNode("input", {
type: "range",
step: $props.attrDefine.step,
class: "range",
min: $props.attrDefine.min,
max: $props.attrDefine.max,
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $props.attrDefine.value = $event),
disabled: $props.attrDefine.readonly,
autocomplete: "off"
}, null, 8, _hoisted_1$d), [
[vue.vModelText, $props.attrDefine.value]
]),
vue.createElementVNode("div", _hoisted_2$8, [
vue.withDirectives(vue.createElementVNode("input", {
type: "number",
step: $props.attrDefine.step,
min: $props.attrDefine.min,
max: $props.attrDefine.max,
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => $props.attrDefine.value = $event),
disabled: $props.attrDefine.readonly,
placeholder: $props.attrDefine.defaultValue,
autocomplete: "off"
}, null, 8, _hoisted_3$6), [
[vue.vModelText, $props.attrDefine.value]
]),
_cache[2] || (_cache[2] = vue.createElementVNode("div", { style: { "float": "left" } }, "px", -1))
])
], 6);
}
const PVFontSizeEditor = /* @__PURE__ */ _export_sfc(_sfc_main$d, [["render", _sfc_render$d], ["__scopeId", "data-v-b2ded6b2"]]);
const _DDeiCoreFontSizePropEditor = class _DDeiCoreFontSizePropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVFontSizeEditor.name);
__publicField3(this, "plugins", [PVFontSizeEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreFontSizePropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVFontSizeEditor.name]) {
for (let i2 in options[PVFontSizeEditor.name]) {
newOptions[i2] = options[PVFontSizeEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreFontSizePropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreFontSizePropEditor;
}
static modify(fn) {
return _DDeiCoreFontSizePropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreFontSizePropEditor, "defaultIns", new _DDeiCoreFontSizePropEditor(null));
let DDeiCoreFontSizePropEditor = _DDeiCoreFontSizePropEditor;
const _sfc_main$c = {
name: "pv-image",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
watch: {},
created() {
this.$watch("attrDefine.value", function(newVal, oldVal) {
this.valueChange();
});
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
async chooseFile() {
const arrFileHandle = await showOpenFilePicker({
types: [{
accept: {
"image/*": [".png", ".gif", ".jpeg", ".jpg", ".webp"]
}
}]
});
let file = await arrFileHandle[0].getFile();
let read = new FileReader();
read.readAsDataURL(file);
read.onload = () => {
let result = read.result;
if (result.indexOf("data:image") != -1) {
this.attrDefine.value = result;
}
};
},
valueChange(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let value = parser.parseValue(this.attrDefine.value);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, value);
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
} else {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
if (element.render) {
element.render.imgObj = null;
}
});
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVImageEditor_vue_vue_type_style_index_0_scoped_d7cc496a_lang = "";
const _hoisted_1$c = { class: "textinput" };
const _hoisted_2$7 = ["disabled", "placeholder", "name"];
function _sfc_render$c(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-image": true, "ddei-pv-editor-image--disabled": $props.attrDefine.readonly })
}, [
vue.createElementVNode("div", _hoisted_1$c, [
vue.withDirectives(vue.createElementVNode("input", {
type: "text",
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $props.attrDefine.value = $event),
disabled: $props.attrDefine.readonly,
placeholder: $props.attrDefine.defaultValue,
name: "ddei-pv-editor-image-" + $props.attrDefine.code,
autocomplete: "off"
}, null, 8, _hoisted_2$7), [
[vue.vModelText, $props.attrDefine.value]
]),
(vue.openBlock(), vue.createElementBlock("svg", {
onClick: _cache[1] || (_cache[1] = ($event) => $props.attrDefine && !$props.attrDefine.readonly && $options.chooseFile()),
class: "icon",
"aria-hidden": "true"
}, _cache[2] || (_cache[2] = [
vue.createElementVNode("use", { "xlink:href": "#icon-link" }, null, -1)
])))
])
], 2);
}
const PVImageEditor = /* @__PURE__ */ _export_sfc(_sfc_main$c, [["render", _sfc_render$c], ["__scopeId", "data-v-d7cc496a"]]);
const _DDeiCoreImagePropEditor = class _DDeiCoreImagePropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVImageEditor.name);
__publicField3(this, "plugins", [PVImageEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreImagePropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVImageEditor.name]) {
for (let i2 in options[PVImageEditor.name]) {
newOptions[i2] = options[PVImageEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreImagePropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreImagePropEditor;
}
static modify(fn) {
return _DDeiCoreImagePropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreImagePropEditor, "defaultIns", new _DDeiCoreImagePropEditor(null));
let DDeiCoreImagePropEditor = _DDeiCoreImagePropEditor;
const _sfc_main$b = {
name: "pv-radio",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
dataSource: null,
editBefore: null,
editAfter: null
};
},
computed: {},
watch: {},
created() {
this.$watch("attrDefine.value", function(newVal, oldVal) {
this.valueChange();
});
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
this.getDataSource(this.attrDefine);
this.attrDefine.doCascadeDisplayByValue();
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
/**
* 选中radio
*/
checkRadioValue(attrDefine, evt) {
let targetElement = evt.target;
if (targetElement.tagName == "DIV" && targetElement.className == "itembox") {
targetElement = targetElement.children[0];
} else if (targetElement.tagName == "DIV") {
targetElement = targetElement.parentElement.children[0];
}
if (attrDefine.value == targetElement.value) {
attrDefine.value = null;
} else {
attrDefine.value = targetElement.value;
}
},
/**
* 获取数据源数据
*/
getDataSource(attrDefine) {
let dataSources = DDeiEditorUtil.getDataSource(this.editor, this.attrDefine);
this.dataSource = dataSources;
return this.dataSource;
},
valueChange(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let value = parser.parseValue(this.attrDefine.value);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, value);
this.attrDefine.doCascadeDisplayByValue();
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
} else {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
});
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVRadioEditor_vue_vue_type_style_index_0_scoped_d06209f3_lang = "";
const _hoisted_1$b = ["disabled", "name", "value"];
function _sfc_render$b(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-radio": true, "ddei-pv-editor-radio--disabled": $props.attrDefine.readonly }),
style: vue.normalizeStyle({ "pointer-events": $props.attrDefine.readonly ? "none" : "" })
}, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.dataSource, (item) => {
return vue.openBlock(), vue.createElementBlock("div", {
class: "itembox",
onClick: _cache[1] || (_cache[1] = ($event) => $options.checkRadioValue($props.attrDefine, $event))
}, [
vue.withDirectives(vue.createElementVNode("input", {
type: "radio",
disabled: $props.attrDefine.readonly,
name: $props.attrDefine.id,
value: item.value,
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $props.attrDefine.value = $event),
autocomplete: "off"
}, null, 8, _hoisted_1$b), [
[vue.vModelRadio, $props.attrDefine.value]
]),
vue.createElementVNode("div", null, vue.toDisplayString(item.text), 1)
]);
}), 256))
], 6);
}
const PVRadioEditor = /* @__PURE__ */ _export_sfc(_sfc_main$b, [["render", _sfc_render$b], ["__scopeId", "data-v-d06209f3"]]);
const _DDeiCoreRadioPropEditor = class _DDeiCoreRadioPropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVRadioEditor.name);
__publicField3(this, "plugins", [PVRadioEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreRadioPropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVRadioEditor.name]) {
for (let i2 in options[PVRadioEditor.name]) {
newOptions[i2] = options[PVRadioEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreRadioPropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreRadioPropEditor;
}
static modify(fn) {
return _DDeiCoreRadioPropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreRadioPropEditor, "defaultIns", new _DDeiCoreRadioPropEditor(null));
let DDeiCoreRadioPropEditor = _DDeiCoreRadioPropEditor;
const _sfc_main$a = {
name: "pv-range",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
watch: {},
created() {
this.valueChange = throttle(this.valueChange, 50);
this.$watch("attrDefine.value", function(newVal, oldVal) {
this.valueChange();
});
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from((_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values());
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
valueChange(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let value = parser.parseValue(this.attrDefine.value);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, value);
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
} else {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
});
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVRangeEditor_vue_vue_type_style_index_0_scoped_713ecc9b_lang = "";
const _hoisted_1$a = ["step", "min", "max", "disabled"];
const _hoisted_2$6 = { class: "textinput" };
const _hoisted_3$5 = ["step", "min", "max", "disabled", "placeholder", "name"];
function _sfc_render$a(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-range": true, "ddei-pv-editor-range--disabled": $props.attrDefine.readonly })
}, [
vue.withDirectives(vue.createElementVNode("input", {
type: "range",
step: $props.attrDefine.step,
class: "range",
min: $props.attrDefine.min,
max: $props.attrDefine.max,
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $props.attrDefine.value = $event),
disabled: $props.attrDefine.readonly
}, null, 8, _hoisted_1$a), [
[vue.vModelText, $props.attrDefine.value]
]),
vue.createElementVNode("div", _hoisted_2$6, [
vue.withDirectives(vue.createElementVNode("input", {
type: "number",
step: $props.attrDefine.step,
min: $props.attrDefine.min,
max: $props.attrDefine.max,
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => $props.attrDefine.value = $event),
disabled: $props.attrDefine.readonly,
placeholder: $props.attrDefine.defaultValue,
name: "ddei-pv-editor-range-" + $props.attrDefine.code,
autocomplete: "off"
}, null, 8, _hoisted_3$5), [
[vue.vModelText, $props.attrDefine.value]
])
])
], 2);
}
const PVRangeEditor = /* @__PURE__ */ _export_sfc(_sfc_main$a, [["render", _sfc_render$a], ["__scopeId", "data-v-713ecc9b"]]);
const _DDeiCoreRangePropEditor = class _DDeiCoreRangePropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVRangeEditor.name);
__publicField3(this, "plugins", [PVRangeEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreRangePropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVRangeEditor.name]) {
for (let i2 in options[PVRangeEditor.name]) {
newOptions[i2] = options[PVRangeEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreRangePropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreRangePropEditor;
}
static modify(fn) {
return _DDeiCoreRangePropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreRangePropEditor, "defaultIns", new _DDeiCoreRangePropEditor(null));
let DDeiCoreRangePropEditor = _DDeiCoreRangePropEditor;
const _sfc_main$9 = {
name: "pv-switch-checkbox",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
watch: {},
created() {
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
this.attrDefine.doCascadeDisplayByValue();
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
doCheck(attrDefine, evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if (attrDefine == null ? void 0 : attrDefine.readonly) {
return;
}
let mds = [];
if (((_e2 = (_d2 = (_c2 = (_b2 = this.editor) == null ? void 0 : _b2.ddInstance) == null ? void 0 : _c2.stage) == null ? void 0 : _d2.selectedModels) == null ? void 0 : _e2.size) > 0) {
mds = Array.from(
(_i = (_h = (_g = (_f = this.editor) == null ? void 0 : _f.ddInstance) == null ? void 0 : _g.stage) == null ? void 0 : _h.selectedModels) == null ? void 0 : _i.values()
);
}
if (((_j = this.attrDefine) == null ? void 0 : _j.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_k = this.attrDefine) == null ? void 0 : _k.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_m = (_l = this.attrDefine) == null ? void 0 : _l.mapping) == null ? void 0 : _m.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
if (attrDefine.value == null) {
if (attrDefine.defaultValue == 1) {
attrDefine.value = 0;
} else {
attrDefine.value = 1;
}
} else if (!attrDefine.value) {
attrDefine.value = 1;
} else {
attrDefine.value = 0;
}
let parser = this.attrDefine.getParser();
let value = parser.parseValue(this.attrDefine.value);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, value);
this.attrDefine.doCascadeDisplayByValue();
(_n = this.editor.ddInstance.stage.selectedModels) == null ? void 0 : _n.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
});
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVSwitchCheckboxEditor_vue_vue_type_style_index_0_scoped_5a394c0d_lang = "";
const _hoisted_1$9 = { class: "title" };
function _sfc_render$9(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-switch-excheckbox": true, "ddei-pv-editor-switch-excheckbox--disabled": $props.attrDefine.readonly }),
onClick: _cache[0] || (_cache[0] = ($event) => $options.doCheck($props.attrDefine, $event)),
style: vue.normalizeStyle({ "pointer-events": $props.attrDefine.readonly ? "none" : "" })
}, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "chk_state": $props.attrDefine.value != 1, "chk_state_checked": $props.attrDefine.value == 1 || $props.attrDefine.value == null && $props.attrDefine.defaultValue == 1 })
}, [
vue.createElementVNode("span", null, vue.toDisplayString($props.attrDefine.value == 1 || $props.attrDefine.value == null && $props.attrDefine.defaultValue == 1 ? "✓" : ""), 1)
], 2),
vue.createElementVNode("div", _hoisted_1$9, vue.toDisplayString($props.editor.i18n($props.attrDefine.name)), 1)
], 6);
}
const PVSwitchCheckboxEditor = /* @__PURE__ */ _export_sfc(_sfc_main$9, [["render", _sfc_render$9], ["__scopeId", "data-v-5a394c0d"]]);
const _DDeiCoreSwitchCheckboxPropEditor = class _DDeiCoreSwitchCheckboxPropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "plugin");
__publicField3(this, "name", PVSwitchCheckboxEditor.name);
__publicField3(this, "plugins", [PVSwitchCheckboxEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreSwitchCheckboxPropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVSwitchCheckboxEditor.name]) {
for (let i2 in options[PVSwitchCheckboxEditor.name]) {
newOptions[i2] = options[PVSwitchCheckboxEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreSwitchCheckboxPropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreSwitchCheckboxPropEditor;
}
static modify(fn) {
return _DDeiCoreSwitchCheckboxPropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreSwitchCheckboxPropEditor, "defaultIns", new _DDeiCoreSwitchCheckboxPropEditor(null));
let DDeiCoreSwitchCheckboxPropEditor = _DDeiCoreSwitchCheckboxPropEditor;
const _sfc_main$8 = {
name: "pv-textarea",
extends: null,
mixins: [],
props: {
//当前属性定义
attrDefine: {
type: DDeiEditorArrtibute,
default: null
},
//当前控件定义
controlDefine: {
type: Object,
default: null
},
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {};
},
computed: {},
watch: {},
created() {
this.$watch("attrDefine.value", function(newVal, oldVal) {
this.valueChange();
});
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l;
let mds;
if (((_d2 = (_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.selectedModels) == null ? void 0 : _d2.size) > 0) {
mds = Array.from(
(_h = (_g = (_f = (_e2 = this.editor) == null ? void 0 : _e2.ddInstance) == null ? void 0 : _f.stage) == null ? void 0 : _g.selectedModels) == null ? void 0 : _h.values()
);
} else {
mds = [(_j = (_i = this.editor) == null ? void 0 : _i.ddInstance) == null ? void 0 : _j.stage];
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: mds, propName: (_l = this.attrDefine) == null ? void 0 : _l.code }, this.editor.ddInstance);
this.attrDefine.readonly = rsState == -1;
},
methods: {
valueChange(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
if (!((_a3 = this.attrDefine) == null ? void 0 : _a3.model)) {
return;
}
if ((_b2 = this.attrDefine) == null ? void 0 : _b2.readonly) {
return;
}
let mds = [];
if (((_f = (_e2 = (_d2 = (_c2 = this.editor) == null ? void 0 : _c2.ddInstance) == null ? void 0 : _d2.stage) == null ? void 0 : _e2.selectedModels) == null ? void 0 : _f.size) > 0) {
mds = Array.from(
(_j = (_i = (_h = (_g = this.editor) == null ? void 0 : _g.ddInstance) == null ? void 0 : _h.stage) == null ? void 0 : _i.selectedModels) == null ? void 0 : _j.values()
);
}
if (((_k = this.attrDefine) == null ? void 0 : _k.model) && mds.indexOf(this.attrDefine.model) == -1) {
mds.push(this.attrDefine.model);
}
if (this.editBefore && !this.editBefore(
DDeiEnumOperateType.EDIT,
mds,
(_l = this.attrDefine) == null ? void 0 : _l.code,
this.editor.ddInstance,
null
)) {
return;
}
let paths = [];
(_n = (_m = this.attrDefine) == null ? void 0 : _m.mapping) == null ? void 0 : _n.forEach((element) => {
paths.push(element);
});
if (!((paths == null ? void 0 : paths.length) > 0)) {
paths = [this.attrDefine.code];
}
let parser = this.attrDefine.getParser();
let value = parser.parseValue(this.attrDefine.value);
DDeiUtil.setAttrValueByPath(this.attrDefine.model, paths, value);
if (this.attrDefine.model.modelType == "DDeiStage" || this.attrDefine.model.modelType == "DDeiLayer") {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [this.attrDefine.model.modelType],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
} else {
this.editor.ddInstance.stage.selectedModels.forEach((element) => {
this.editor.bus.push(
DDeiEnumBusCommandType.ModelChangeValue,
{
mids: [element.id],
paths,
value,
attrDefine: this.attrDefine
},
evt,
true
);
});
}
this.editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", DDeiEnumOperateType.EDIT, { models: mds, propName: (_o = this.attrDefine) == null ? void 0 : _o.code }, this.editor.ddInstance, null);
}
}
};
const PVTextAreaEditor_vue_vue_type_style_index_0_scoped_ac742ab1_lang = "";
const _hoisted_1$8 = ["disabled", "placeholder"];
function _sfc_render$8(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", {
class: vue.normalizeClass({ "ddei-pv-editor-textarea": true, "ddei-pv-editor-textarea--disabled": $props.attrDefine.readonly })
}, [
vue.withDirectives(vue.createElementVNode("textarea", {
ref: "pvTextArea",
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $props.attrDefine.value = $event),
disabled: $props.attrDefine.readonly,
placeholder: $props.attrDefine.defaultValue
}, null, 8, _hoisted_1$8), [
[vue.vModelText, $props.attrDefine.value]
])
], 2);
}
const PVTextAreaEditor = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["render", _sfc_render$8], ["__scopeId", "data-v-ac742ab1"]]);
const _DDeiCoreTextAreaPropEditor = class _DDeiCoreTextAreaPropEditor extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", PVTextAreaEditor.name);
__publicField3(this, "plugins", [PVTextAreaEditor]);
}
getPropEditors(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = Object.assign({}, {}, _DDeiCoreTextAreaPropEditor.defaultIns.options);
if (fullConfig) {
if (fullConfig) {
if (options[PVTextAreaEditor.name]) {
for (let i2 in options[PVTextAreaEditor.name]) {
newOptions[i2] = options[PVTextAreaEditor.name][i2];
}
}
}
} else {
for (let i2 in options) {
newOptions[i2] = options[i2];
}
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let layouts = new _DDeiCoreTextAreaPropEditor(newOptions);
return layouts;
}
}
return _DDeiCoreTextAreaPropEditor;
}
static modify(fn) {
return _DDeiCoreTextAreaPropEditor.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreTextAreaPropEditor, "defaultIns", new _DDeiCoreTextAreaPropEditor(null));
let DDeiCoreTextAreaPropEditor = _DDeiCoreTextAreaPropEditor;
const _DDeiCorePVEditors = class _DDeiCorePVEditors extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [
DDeiCoreTextPropEditor,
DDeiCoreAlignTypePropEditor,
DDeiCoreBorderDashComboPropEditor,
DDeiCoreBorderTypePropEditor,
DDeiCoreColorComboPropEditor,
DDeiCoreColorPropEditor,
DDeiCoreComboxPropEditor,
DDeiCoreExCheckboxPropEditor,
DDeiCoreFillTypePropEditor,
DDeiCoreFontSizePropEditor,
DDeiCoreImagePropEditor,
DDeiCoreRadioPropEditor,
DDeiCoreRangePropEditor,
DDeiCoreSwitchCheckboxPropEditor,
DDeiCoreTextAreaPropEditor
]);
}
getPropEditors(editor) {
var _a3;
let pves = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getPropEditors(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getPropEditors(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
pves = pves.concat(ls);
}
});
return pves;
}
static configuration(options) {
var _a3;
if (options) {
let pves = new _DDeiCorePVEditors(options);
for (let i2 = 0; i2 < ((_a3 = pves.plugins) == null ? void 0 : _a3.length); i2++) {
pves.plugins[i2] = pves.plugins[i2].configuration(options, true);
}
return pves;
}
return _DDeiCorePVEditors;
}
static modify(fn) {
return _DDeiCorePVEditors.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCorePVEditors, "defaultIns", new _DDeiCorePVEditors(null));
let DDeiCorePVEditors = _DDeiCorePVEditors;
const _DDeiKeyActionAllSelect = class _DDeiKeyActionAllSelect extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-all-select");
__publicField3(this, "defaultOptions", {
"keys": [
{
ctrl: 1,
keys: "65",
editorState: DDeiEditorState.DESIGNING
}
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionAllSelect.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionAllSelect.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionAllSelect.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionAllSelect(newOptions);
return panels;
}
}
return _DDeiKeyActionAllSelect;
}
static modify(fn) {
return _DDeiKeyActionAllSelect.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
isActive(element) {
if (!element) {
return true;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return true;
}
return false;
}
action(evt, ddInstance) {
var _a3, _b2, _c2, _d2, _e2, _f;
if (ddInstance && ddInstance.stage) {
if (this.isActive(document.activeElement)) {
let models = [];
if (((_a3 = ddInstance.stage.selectedModels) == null ? void 0 : _a3.size) > 0) {
models = Array.from((_b2 = ddInstance.stage.selectedModels) == null ? void 0 : _b2.values());
}
if ((models == null ? void 0 : models.length) == 1 && models[0].baseModelType == "DDeiTable" && models[0].curRow != -1 && models[0].curCol != -1) {
for (let i2 = 0; i2 < models[0].rows.length; i2++) {
let rowObj = models[0].rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
rowObj[j2].setState(DDeiEnumControlState.SELECTED);
}
}
} else {
let layer2 = ddInstance.stage.layers[ddInstance.stage.layerIndex];
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_SELECT_BEFORE", DDeiEnumOperateType.SELECT, { models: Array.from(layer2.models.values()) }, ddInstance, evt);
if (rsState == 0 || rsState == 1) {
(_c2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _c2.push(DDeiEnumBusCommandType.ModelChangeSelect, { models: layer2.models, value: DDeiEnumControlState.SELECTED }, evt);
(_d2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _d2.push(DDeiEnumBusCommandType.StageChangeSelectModels, {}, evt);
}
}
(_e2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _e2.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
(_f = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _f.executeAll();
return true;
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionAllSelect, "defaultIns", new _DDeiKeyActionAllSelect());
let DDeiKeyActionAllSelect = _DDeiKeyActionAllSelect;
const _DDeiKeyActionBrushData = class _DDeiKeyActionBrushData extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-brush-data");
__publicField3(this, "defaultOptions", {
"keys": [
{
ctrl: 1,
shift: 1,
keys: "67",
editorState: DDeiEditorState.DESIGNING
}
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionBrushData.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionBrushData.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionBrushData.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionBrushData(newOptions);
return panels;
}
}
return _DDeiKeyActionBrushData;
}
static modify(fn) {
return _DDeiKeyActionBrushData.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
isActive(element) {
if (!element) {
return true;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return true;
}
return false;
}
action(evt, ddInstance) {
var _a3, _b2, _c2, _d2, _e2, _f;
if (ddInstance && ddInstance.stage) {
if (this.isActive(document.activeElement)) {
let stage2 = ddInstance.stage;
let editor = DDeiEditor.ACTIVE_INSTANCE;
let models = Array.from((_a3 = ddInstance.stage.selectedModels) == null ? void 0 : _a3.values());
stage2.brushData = null;
if ((models == null ? void 0 : models.length) == 1) {
if (models[0].baseModelType == "DDeiTable") {
let table2 = models[0];
let selectedCells = table2.getSelectedCells();
let minMaxColRow = table2.getMinMaxRowAndCol(selectedCells);
stage2.brushData = [];
for (let i2 = minMaxColRow.minRow; i2 <= minMaxColRow.maxRow; i2++) {
let rowObj = table2.rows[i2];
let rowData = [];
for (let j2 = minMaxColRow.minCol; j2 <= minMaxColRow.maxCol; j2++) {
let cellObj = rowObj[j2];
rowData.push(cellObj);
}
stage2.brushData.push(rowData);
}
if (stage2.brushData.length > 0) {
editor.changeState(DDeiEditorState.DESIGNING);
editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
editor.bus.executeAll();
}
} else {
if (editor.state == DDeiEditorState.QUICK_EDITING) {
let shadowControl = editor.ddInstance.stage.render.editorShadowControl;
if (shadowControl == null ? void 0 : shadowControl.render.isEditoring) {
let editorText = DDeiUtil.getEditorText();
let curSIdx = -1;
let curEIdx = -1;
if (editorText) {
curSIdx = editorText.selectionStart;
curEIdx = editorText.selectionEnd;
}
stage2.brushDataText = cloneDeep(shadowControl.getSptAllStyles(curSIdx, curEIdx));
}
delete stage2.brushData;
(_b2 = editor.bus) == null ? void 0 : _b2.push(DDeiEnumBusCommandType.ChangeCursor, { image: "cursor-brush" });
(_c2 = editor.bus) == null ? void 0 : _c2.executeAll();
} else {
let model = models[0];
stage2.brushData = [model];
delete stage2.brushDataText;
editor.changeState(DDeiEditorState.DESIGNING);
(_d2 = editor.bus) == null ? void 0 : _d2.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
(_e2 = editor.bus) == null ? void 0 : _e2.push(DDeiEnumBusCommandType.ChangeCursor, { image: "cursor-brush" });
(_f = editor.bus) == null ? void 0 : _f.executeAll();
}
return true;
}
}
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionBrushData, "defaultIns", new _DDeiKeyActionBrushData());
let DDeiKeyActionBrushData = _DDeiKeyActionBrushData;
const _DDeiKeyActionCancelCompose = class _DDeiKeyActionCancelCompose extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-cancel-compose");
__publicField3(this, "defaultOptions", {
"keys": [
{
keys: "71",
ctrl: 1,
shift: 1,
editorState: DDeiEditorState.DESIGNING
}
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionCancelCompose.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionCancelCompose.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionCancelCompose.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionCancelCompose(newOptions);
return panels;
}
}
return _DDeiKeyActionCancelCompose;
}
static modify(fn) {
return _DDeiKeyActionCancelCompose.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
if (ddInstance && ddInstance.stage) {
let layer2 = ddInstance.stage.layers[ddInstance.stage.layerIndex];
let selectedModels = layer2.getSelectedModels();
if ((selectedModels == null ? void 0 : selectedModels.size) > 0) {
ddInstance.bus.push(DDeiEnumBusCommandType.ModelCancelMerge);
ddInstance.bus.executeAll();
}
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionCancelCompose, "defaultIns", new _DDeiKeyActionCancelCompose());
let DDeiKeyActionCancelCompose = _DDeiKeyActionCancelCompose;
const _DDeiKeyActionCancelControlCreate = class _DDeiKeyActionCancelControlCreate extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-cancel-control-create");
__publicField3(this, "defaultOptions", {
"keys": [
{
keys: "27",
editorState: DDeiEditorState.CONTROL_CREATING
}
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionCancelControlCreate.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionCancelControlCreate.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionCancelControlCreate.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionCancelControlCreate(newOptions);
return panels;
}
}
return _DDeiKeyActionCancelControlCreate;
}
static modify(fn) {
return _DDeiKeyActionCancelControlCreate.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance, editor) {
var _a3;
if (editor.state == DDeiEditorState.CONTROL_CREATING) {
if (editor.creatingControls) {
let layer2 = ddInstance.stage.layers[ddInstance.stage.layerIndex];
layer2.removeModels(editor.creatingControls);
editor.creatingControls = null;
layer2.opPoints = [];
if ((_a3 = layer2.opLine) == null ? void 0 : _a3.render) {
layer2.opLine.render.enableRefreshShape();
}
delete layer2.opLine;
editor.bus.push(DDeiEnumBusCommandType.ClearTemplateVars);
editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
editor.bus.executeAll();
}
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionCancelControlCreate, "defaultIns", new _DDeiKeyActionCancelControlCreate());
let DDeiKeyActionCancelControlCreate = _DDeiKeyActionCancelControlCreate;
const _DDeiKeyActionCancelCurrentAction = class _DDeiKeyActionCancelCurrentAction extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-cancel-current-action");
__publicField3(this, "defaultOptions", {
"keys": [
{ keys: "27", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionCancelCurrentAction.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionCancelCurrentAction.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionCancelCurrentAction.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionCancelCurrentAction(newOptions);
return panels;
}
}
return _DDeiKeyActionCancelCurrentAction;
}
static modify(fn) {
return _DDeiKeyActionCancelCurrentAction.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance, editor) {
var _a3, _b2;
if (editor.state == DDeiEditorState.DESIGNING) {
let stage2 = ddInstance.stage;
let layer2 = stage2.layers[stage2 == null ? void 0 : stage2.layerIndex];
if (layer2) {
layer2.opPoints = [];
if ((_a3 = layer2.opLine) == null ? void 0 : _a3.render) {
layer2.opLine.render.enableRefreshShape();
}
delete layer2.opLine;
(_b2 = layer2.shadowControls) == null ? void 0 : _b2.forEach((c) => {
c.destroyed();
});
layer2.shadowControls = [];
stage2.render.operateState = DDeiEnumOperateState.NONE;
ddInstance.bus.push(DDeiEnumBusCommandType.ClearTemplateVars, null, evt);
ddInstance.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds, null, evt);
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
ddInstance.bus.executeAll();
}
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionCancelCurrentAction, "defaultIns", new _DDeiKeyActionCancelCurrentAction());
let DDeiKeyActionCancelCurrentAction = _DDeiKeyActionCancelCurrentAction;
const _DDeiKeyActionCancelQuickEdit = class _DDeiKeyActionCancelQuickEdit extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-quickedit-cancel");
__publicField3(this, "defaultOptions", {
"keys": [
{ keys: "27", editorState: DDeiEditorState.QUICK_EDITING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionCancelQuickEdit.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionCancelQuickEdit.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionCancelQuickEdit.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionCancelQuickEdit(newOptions);
return panels;
}
}
return _DDeiKeyActionCancelQuickEdit;
}
static modify(fn) {
return _DDeiKeyActionCancelQuickEdit.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
var _a3;
if (ddInstance.stage.brushDataText) {
delete ddInstance.stage.brushDataText;
} else {
let editor = DDeiEditor.ACTIVE_INSTANCE;
let inputEle = editor.quickEditorInput;
inputEle.value = "";
if ((_a3 = ddInstance.stage.render.editorShadowControl) == null ? void 0 : _a3.isShadowControl) {
ddInstance.stage.render.editorShadowControl.destroyed();
}
ddInstance.stage.render.editorShadowControl = null;
editor.quickEditorModel = null;
delete ddInstance.stage.brushDataText;
editor.changeState(DDeiEditorState.DESIGNING);
editor.bus.push(DDeiEnumBusCommandType.ClearTemplateVars);
editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, { parts: ["topmenu"] });
editor.bus.push(DDeiEnumBusCommandType.StageChangeSelectModels);
editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
editor.bus.executeAll();
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionCancelQuickEdit, "defaultIns", new _DDeiKeyActionCancelQuickEdit());
let DDeiKeyActionCancelQuickEdit = _DDeiKeyActionCancelQuickEdit;
const _DDeiKeyActionCancelSelect = class _DDeiKeyActionCancelSelect extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-cancel-select");
__publicField3(this, "defaultOptions", {
"keys": [
//取消全选,500毫秒内,连续按两下esc键
{ keys: "27", times: 2, interval: 500, editorState: DDeiEditorState.DESIGNING, operateState: DDeiEnumOperateState.NONE }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionCancelSelect.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionCancelSelect.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionCancelSelect.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionCancelSelect(newOptions);
return panels;
}
}
return _DDeiKeyActionCancelSelect;
}
static modify(fn) {
return _DDeiKeyActionCancelSelect.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
var _a3, _b2, _c2, _d2, _e2, _f;
if (ddInstance && ddInstance.stage) {
let models = Array.from((_a3 = ddInstance.stage.selectedModels) == null ? void 0 : _a3.values());
if ((models == null ? void 0 : models.length) == 1 && models[0].baseModelType == "DDeiTable" && models[0].curRow != -1 && models[0].curCol != -1) {
for (let i2 = 0; i2 < models[0].rows.length; i2++) {
let rowObj = models[0].rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
rowObj[j2].setState(DDeiEnumControlState.DEFAULT);
}
}
models[0].curRow = -1;
models[0].curCol = -1;
models[0].tempDragCell = null;
} else {
let layer2 = ddInstance.stage.layers[ddInstance.stage.layerIndex];
(_b2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _b2.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, { container: layer2, curLevel: true }, evt);
(_c2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _c2.push(DDeiEnumBusCommandType.StageChangeSelectModels, {}, evt);
(_d2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _d2.push(DDeiEnumBusCommandType.UpdateSelectorBounds, null, evt);
}
(_e2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _e2.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
(_f = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _f.executeAll();
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionCancelSelect, "defaultIns", new _DDeiKeyActionCancelSelect());
let DDeiKeyActionCancelSelect = _DDeiKeyActionCancelSelect;
const _DDeiKeyActionClearBrushData = class _DDeiKeyActionClearBrushData extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-clear-brushdata");
__publicField3(this, "defaultOptions", {
"keys": [
{ keys: "27", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionClearBrushData.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionClearBrushData.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionClearBrushData.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionClearBrushData(newOptions);
return panels;
}
}
return _DDeiKeyActionClearBrushData;
}
static modify(fn) {
return _DDeiKeyActionClearBrushData.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
var _a3, _b2;
if (ddInstance && ddInstance.stage) {
let stage2 = ddInstance.stage;
if (stage2) {
stage2.brushData = null;
(_a3 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _a3.push(DDeiEnumBusCommandType.ChangeCursor, { cursor: "default" });
(_b2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _b2.executeAll();
}
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionClearBrushData, "defaultIns", new _DDeiKeyActionClearBrushData());
let DDeiKeyActionClearBrushData = _DDeiKeyActionClearBrushData;
const _DDeiKeyActionCloseDialog = class _DDeiKeyActionCloseDialog extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-close-dialog");
__publicField3(this, "defaultOptions", {
"keys": [
//ESC关闭弹出框
{ keys: "27", editorState: DDeiEditorState.PROPERTY_EDITING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionCloseDialog.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionCloseDialog.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionCloseDialog.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionCloseDialog(newOptions);
return panels;
}
}
return _DDeiKeyActionCloseDialog;
}
static modify(fn) {
return _DDeiKeyActionCloseDialog.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
DDeiEditorUtil.closeDialogs(DDeiEditorUtil.getEditorInsByDDei(ddInstance), ["bottom-dialog", "property-dialog", "top-dialog", "toolbox-dialog"]);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionCloseDialog, "defaultIns", new _DDeiKeyActionCloseDialog());
let DDeiKeyActionCloseDialog = _DDeiKeyActionCloseDialog;
const _DDeiKeyActionCompose = class _DDeiKeyActionCompose extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-compose");
__publicField3(this, "defaultOptions", {
"keys": [
//组合
{ keys: "71", ctrl: 1, editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionCompose.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionCompose.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionCompose.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionCompose(newOptions);
return panels;
}
}
return _DDeiKeyActionCompose;
}
static modify(fn) {
return _DDeiKeyActionCompose.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
if (ddInstance) {
ddInstance.bus.push(DDeiEnumBusCommandType.ModelMerge, null, evt);
ddInstance.bus.executeAll();
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionCompose, "defaultIns", new _DDeiKeyActionCompose());
let DDeiKeyActionCompose = _DDeiKeyActionCompose;
const _DDeiKeyActionCopy = class _DDeiKeyActionCopy extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-copy");
__publicField3(this, "defaultOptions", {
"keys": [
{ ctrl: 1, keys: "67", editorState: DDeiEditorState.DESIGNING }
]
});
}
isActive(element) {
if (!element) {
return true;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return true;
}
return false;
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionCopy.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionCopy.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionCopy.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionCopy(newOptions);
return panels;
}
}
return _DDeiKeyActionCopy;
}
static modify(fn) {
return _DDeiKeyActionCopy.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
async action(evt, ddInstance, editor) {
var _a3, _b2, _c2;
if (ddInstance && ddInstance.stage && this.isActive(document.activeElement)) {
let selectedControls = ddInstance.stage.selectedModels;
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_COPY_BEFORE", "COPY", { models: selectedControls }, ddInstance);
if (rsState == 0 || rsState == 1) {
if ((selectedControls == null ? void 0 : selectedControls.size) > 0) {
let models = Array.from(selectedControls.values());
let sortedModels = [];
let modelLines = [];
let selectedSubAllModels = /* @__PURE__ */ new Map();
models[0].pModel.midList.forEach((mid) => {
models.forEach((item) => {
if (item.id == mid) {
sortedModels.push(item);
if (item.baseModelType == "DDeiContainer") {
let subLines = item.getModelsByBaseType("DDeiLine");
let subModels = item.getSubModels(null, 100);
if ((subModels == null ? void 0 : subModels.length) > 0) {
subModels.forEach((element) => {
selectedSubAllModels.set(element.id, element);
});
}
if ((subLines == null ? void 0 : subLines.length) > 0) {
modelLines.push(...subLines);
}
} else if (item.baseModelType == "DDeiLine") {
modelLines.push(item);
}
}
});
});
let copyHtml = "";
copyHtml += '';
let jsonStr = "[";
let jsonLinksStr = "[";
let innerHTML = "";
sortedModels == null ? void 0 : sortedModels.forEach((model, key) => {
var _a4;
if ((selectedControls == null ? void 0 : selectedControls.size) == 1) {
if (model.baseModelType == "DDeiTable") {
if (model.curRow == -1 && model.curCol == -1) {
let json = model.toJSON();
jsonStr += JSON.stringify(json) + ",";
}
let html = model.render.getHTML();
if (html) {
innerHTML += html;
}
} else {
let json = model.toJSON();
jsonStr += JSON.stringify(json) + ",";
}
} else {
let json = model.toJSON();
jsonStr += JSON.stringify(json) + ",";
}
(_a4 = model.linkModels) == null ? void 0 : _a4.forEach((lineLM) => {
if (lineLM.dm) {
if (!selectedControls.has(lineLM.dm.id) && !selectedSubAllModels.has(lineLM.dm.id)) {
let json = lineLM.dm.toJSON();
jsonStr += JSON.stringify(json) + ",";
}
}
});
});
modelLines.forEach((line2) => {
var _a4;
let distModelLinks = (_a4 = ddInstance.stage) == null ? void 0 : _a4.getDistModelLinks(line2.id);
distModelLinks == null ? void 0 : distModelLinks.forEach((link2) => {
var _a5, _b3;
if ((selectedControls == null ? void 0 : selectedControls.has((_a5 = link2 == null ? void 0 : link2.sm) == null ? void 0 : _a5.id)) || (selectedSubAllModels == null ? void 0 : selectedSubAllModels.has((_b3 = link2 == null ? void 0 : link2.sm) == null ? void 0 : _b3.id))) {
jsonLinksStr += JSON.stringify(link2) + ",";
}
});
});
if (jsonStr.length > 1) {
jsonStr = jsonStr.substring(0, jsonStr.length - 1);
jsonStr += "]";
ddInstance.stage.copyMode = "copy";
jsonStr = '{"mode":"copy","data":' + jsonStr;
if (jsonLinksStr.length > 1) {
jsonLinksStr = jsonLinksStr.substring(0, jsonLinksStr.length - 1);
jsonLinksStr += "]";
jsonStr += ' , "links":' + jsonLinksStr;
}
let ruleDisplay;
let ruleInit;
if (((_a3 = ddInstance.stage.ruler) == null ? void 0 : _a3.display) || ((_b2 = ddInstance.stage.ruler) == null ? void 0 : _b2.display) == 0 || ((_c2 = ddInstance.stage.ruler) == null ? void 0 : _c2.display) == false) {
ruleDisplay = ddInstance.stage.ruler.display;
} else if (ddInstance.ruler != null && ddInstance.ruler != void 0) {
if (typeof ddInstance.ruler == "boolean") {
ruleDisplay = ddInstance.ruler ? 1 : 0;
} else {
ruleInit = ddInstance.ruler;
ruleDisplay = ruleInit.display;
}
} else {
ruleDisplay = DDeiModelArrtibuteValue.getAttrValueByState(ddInstance.stage, "ruler.display", true);
}
if (ruleDisplay) {
let unit = DDeiModelArrtibuteValue.getAttrValueByState(ddInstance.stage, "ruler.unit", true, ruleInit);
jsonStr += ',"unit":"' + unit + '"';
}
jsonStr += "}";
} else {
jsonStr = "";
}
copyHtml += jsonStr + '';
copyHtml += "" + innerHTML + "";
let blob = new Blob([copyHtml], {
type: "text/html"
});
if (DDeiConfig.ALLOW_CLIPBOARD || DDeiConfig.ALLOW_CLIPBOARD == void 0) {
try {
let writeDatas = [];
writeDatas.push(new ClipboardItem({ "text/html": blob }));
let cbData = navigator.clipboard;
cbData.write(writeDatas).then(function() {
editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
editor.bus.executeAll();
editor.changeState(DDeiEditorState.DESIGNING);
}, function(e) {
console.error("复制失败" + e);
});
} catch (e) {
DDeiConfig.ALLOW_CLIPBOARD = false;
}
}
if (!DDeiConfig.ALLOW_CLIPBOARD) {
window.DDEI_CLIPBOARD = blob;
}
return true;
}
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionCopy, "defaultIns", new _DDeiKeyActionCopy());
let DDeiKeyActionCopy = _DDeiKeyActionCopy;
const _DDeiKeyActionCopyImage = class _DDeiKeyActionCopyImage extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-copy-image");
__publicField3(this, "defaultOptions", {
"keys": [
{ ctrl: 1, keys: "73", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionCopyImage.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionCopyImage.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionCopyImage.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionCopyImage(newOptions);
return panels;
}
}
return _DDeiKeyActionCopyImage;
}
static modify(fn) {
return _DDeiKeyActionCopyImage.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance, editor) {
if (DDeiConfig.ALLOW_CLIPBOARD || DDeiConfig.ALLOW_CLIPBOARD == void 0) {
if (ddInstance && ddInstance.stage) {
let selectedControls = ddInstance.stage.selectedModels;
let models = null;
if ((selectedControls == null ? void 0 : selectedControls.size) > 0) {
models = Array.from(selectedControls == null ? void 0 : selectedControls.values());
}
this.copyToImage(editor, ddInstance, models);
}
}
}
copyToImage(editor, ddInstance, models) {
try {
let dataURL = ddInstance.stage.toImageDataUrl(models);
let blob = DDeiUtil.dataURLtoBlob(dataURL);
let cbData = navigator.clipboard;
let writeDatas = [new ClipboardItem({ [blob.type]: blob })];
cbData.write(writeDatas).then(function() {
editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
editor.bus.executeAll();
editor.changeState(DDeiEditorState.DESIGNING);
});
} catch (e) {
console.error(e);
DDeiConfig.ALLOW_CLIPBOARD = false;
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionCopyImage, "defaultIns", new _DDeiKeyActionCopyImage());
let DDeiKeyActionCopyImage = _DDeiKeyActionCopyImage;
const _DDeiKeyActionCut = class _DDeiKeyActionCut extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-cut");
__publicField3(this, "defaultOptions", {
"keys": [
{ ctrl: 1, keys: "88", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionCut.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionCut.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionCut.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionCut(newOptions);
return panels;
}
}
return _DDeiKeyActionCut;
}
static modify(fn) {
return _DDeiKeyActionCut.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
async action(evt, ddInstance, editor) {
var _a3, _b2, _c2;
if (ddInstance && ddInstance.stage) {
let selectedControls = ddInstance.stage.selectedModels;
if ((selectedControls == null ? void 0 : selectedControls.size) > 0) {
let models = Array.from(selectedControls.values());
let sortedModels = [];
let modelLines = [];
let selectedSubAllModels = /* @__PURE__ */ new Map();
models[0].pModel.midList.forEach((mid) => {
models.forEach((item) => {
if (item.id == mid) {
sortedModels.push(item);
if (item.baseModelType == "DDeiContainer") {
let subLines = item.getModelsByBaseType("DDeiLine");
let subModels = item.getSubModels(null, 100);
if ((subModels == null ? void 0 : subModels.length) > 0) {
subModels.forEach((element) => {
selectedSubAllModels.set(element.id, element);
});
}
if ((subLines == null ? void 0 : subLines.length) > 0) {
modelLines.push(...subLines);
}
} else if (item.baseModelType == "DDeiLine") {
modelLines.push(item);
}
}
});
});
let copyHtml = "";
copyHtml += '';
let jsonStr = "[";
let jsonLinksStr = "[";
let innerHTML = "";
sortedModels == null ? void 0 : sortedModels.forEach((model, key) => {
if ((selectedControls == null ? void 0 : selectedControls.size) == 1) {
if (model.baseModelType == "DDeiTable") {
if (model.curRow == -1 && model.curCol == -1) {
let json = model.toJSON();
jsonStr += JSON.stringify(json) + ",";
}
let html = model.render.getHTML();
if (html) {
innerHTML += html;
}
} else {
let json = model.toJSON();
jsonStr += JSON.stringify(json) + ",";
}
} else {
let json = model.toJSON();
jsonStr += JSON.stringify(json) + ",";
}
});
modelLines.forEach((line2) => {
var _a4, _b3;
let distModelLinks = (_a4 = ddInstance.stage) == null ? void 0 : _a4.getDistModelLinks(line2.id);
distModelLinks == null ? void 0 : distModelLinks.forEach((link2) => {
var _a5, _b4;
if ((selectedControls == null ? void 0 : selectedControls.has((_a5 = link2 == null ? void 0 : link2.sm) == null ? void 0 : _a5.id)) || (selectedSubAllModels == null ? void 0 : selectedSubAllModels.has((_b4 = link2 == null ? void 0 : link2.sm) == null ? void 0 : _b4.id))) {
jsonLinksStr += JSON.stringify(link2) + ",";
}
});
(_b3 = line2.linkModels) == null ? void 0 : _b3.forEach((lineLM) => {
if (lineLM.dm) {
if (!selectedControls.has(lineLM.dm.id) && !selectedSubAllModels.has(lineLM.dm.id)) {
let json = lineLM.dm.toJSON();
jsonStr += JSON.stringify(json) + ",";
}
}
});
});
if (jsonStr.length > 1) {
jsonStr = jsonStr.substring(0, jsonStr.length - 1);
jsonStr += "]";
ddInstance.stage.copyMode = "cut";
jsonStr = '{"mode":"cut","data":' + jsonStr;
if (jsonLinksStr.length > 1) {
jsonLinksStr = jsonLinksStr.substring(0, jsonLinksStr.length - 1);
jsonLinksStr += "]";
jsonStr += ' , "links":' + jsonLinksStr;
}
let ruleDisplay;
let ruleInit;
if (((_a3 = ddInstance.stage.ruler) == null ? void 0 : _a3.display) || ((_b2 = ddInstance.stage.ruler) == null ? void 0 : _b2.display) == 0 || ((_c2 = ddInstance.stage.ruler) == null ? void 0 : _c2.display) == false) {
ruleDisplay = ddInstance.stage.ruler.display;
} else if (ddInstance.ruler != null && ddInstance.ruler != void 0) {
if (typeof ddInstance.ruler == "boolean") {
ruleDisplay = ddInstance.ruler ? 1 : 0;
} else {
ruleInit = ddInstance.ruler;
ruleDisplay = ruleInit.display;
}
} else {
ruleDisplay = DDeiModelArrtibuteValue.getAttrValueByState(ddInstance.stage, "ruler.display", true);
}
if (ruleDisplay) {
let unit = DDeiModelArrtibuteValue.getAttrValueByState(ddInstance.stage, "ruler.unit", true, ruleInit);
jsonStr += ',"unit":"' + unit + '"';
}
jsonStr += "}";
} else {
jsonStr = "";
}
copyHtml += jsonStr + '';
copyHtml += "" + innerHTML + "";
let blob = new Blob([copyHtml], {
type: "text/html"
});
if (DDeiConfig.ALLOW_CLIPBOARD || DDeiConfig.ALLOW_CLIPBOARD == void 0) {
try {
let writeDatas = [];
writeDatas.push(new ClipboardItem({ "text/html": blob }));
let cbData = navigator.clipboard;
cbData.write(writeDatas).then(function() {
editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {
parts: ["topmenu"]
});
editor.bus.executeAll();
editor.changeState(DDeiEditorState.DESIGNING);
}, function(e) {
console.error("复制失败" + e);
});
} catch (e) {
DDeiConfig.ALLOW_CLIPBOARD = false;
}
}
if (!DDeiConfig.ALLOW_CLIPBOARD) {
window.DDEI_CLIPBOARD = blob;
}
}
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionCut, "defaultIns", new _DDeiKeyActionCut());
let DDeiKeyActionCut = _DDeiKeyActionCut;
const _DDeiKeyActionEnterQuickEdit = class _DDeiKeyActionEnterQuickEdit extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-quickedit-enter");
__publicField3(this, "defaultOptions", {
"keys": [
{ keys: "13", shift: 1, editorState: DDeiEditorState.QUICK_EDITING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionEnterQuickEdit.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionEnterQuickEdit.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionEnterQuickEdit.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionEnterQuickEdit(newOptions);
return panels;
}
}
return _DDeiKeyActionEnterQuickEdit;
}
static modify(fn) {
return _DDeiKeyActionEnterQuickEdit.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
var _a3;
let editor = DDeiEditor.ACTIVE_INSTANCE;
(_a3 = editor.quickEditorInput) == null ? void 0 : _a3.enterValue();
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionEnterQuickEdit, "defaultIns", new _DDeiKeyActionEnterQuickEdit());
let DDeiKeyActionEnterQuickEdit = _DDeiKeyActionEnterQuickEdit;
const _DDeiKeyActionMoveModels = class _DDeiKeyActionMoveModels extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-move-models");
__publicField3(this, "defaultOptions", {
"keys": [
//上
{ shift: 2, keys: "38", editorState: DDeiEditorState.DESIGNING },
//下
{ shift: 2, keys: "40", editorState: DDeiEditorState.DESIGNING },
//左
{ shift: 2, keys: "37", editorState: DDeiEditorState.DESIGNING },
//右
{ shift: 2, keys: "39", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionMoveModels.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionMoveModels.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionMoveModels.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionMoveModels(newOptions);
return panels;
}
}
return _DDeiKeyActionMoveModels;
}
static modify(fn) {
return _DDeiKeyActionMoveModels.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
isActive(element) {
if (!element) {
return true;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return true;
}
return false;
}
action(evt, ddInstance, editor) {
var _a3;
if (ddInstance && ddInstance.stage) {
if (this.isActive(document.activeElement)) {
let selectedModels = ddInstance.stage.selectedModels;
let models = Array.from(selectedModels.values());
if (models.length == 1 && models[0].baseModelType == "DDeiTable" && models[0].curRow != -1 && models[0].curCol != -1) {
if (evt.keyCode == 38) {
if (models[0].curRow > 0) {
if (models[0].tempDragCell) {
models[0].tempDragCell.setState(DDeiEnumControlState.DEFAULT);
}
models[0].curRow--;
models[0].tempDragCell = models[0].rows[models[0].curRow][models[0].curCol];
models[0].tempDragCell.setState(DDeiEnumControlState.SELECTED);
}
} else if (evt.keyCode == 40) {
if (models[0].curRow < models[0].rows.length - 1) {
if (models[0].tempDragCell) {
models[0].tempDragCell.setState(DDeiEnumControlState.DEFAULT);
}
models[0].curRow++;
models[0].tempDragCell = models[0].rows[models[0].curRow][models[0].curCol];
models[0].tempDragCell.setState(DDeiEnumControlState.SELECTED);
}
} else if (evt.keyCode == 37) {
if (models[0].curCol > 0) {
if (models[0].tempDragCell) {
models[0].tempDragCell.setState(DDeiEnumControlState.DEFAULT);
}
models[0].curCol--;
models[0].tempDragCell = models[0].rows[models[0].curRow][models[0].curCol];
models[0].tempDragCell.setState(DDeiEnumControlState.SELECTED);
}
} else if (evt.keyCode == 39) {
if (models[0].curCol < models[0].cols.length - 1) {
if (models[0].tempDragCell) {
models[0].tempDragCell.setState(DDeiEnumControlState.DEFAULT);
}
models[0].curCol++;
models[0].tempDragCell = models[0].rows[models[0].curRow][models[0].curCol];
models[0].tempDragCell.setState(DDeiEnumControlState.SELECTED);
}
}
} else if (editor.GLOBAL_KEYBOARD_ALIGN_ENABLE) {
let moveSize = 1;
let isShift = DDei.KEY_DOWN_STATE.get("shift");
if (!isShift) {
moveSize = 10;
}
let moveOriginLines = [];
models.forEach((md) => {
if (md.baseModelType == "DDeiLine") {
moveOriginLines.push(md.id);
}
});
let outRect = DDeiAbstractShape.getOutRectByPV(models);
let deltaX, deltaY;
if (evt.keyCode == 38) {
let mod = 0;
if (!isShift) {
if (outRect.y % moveSize > 0) {
mod = moveSize - outRect.y % moveSize;
}
}
deltaY = -moveSize + mod;
} else if (evt.keyCode == 40) {
let mod = 0;
if (!isShift) {
mod = Math.round(outRect.y) % moveSize;
}
deltaY = moveSize - mod;
} else if (evt.keyCode == 37) {
let mod = 0;
if (!isShift) {
if (outRect.x % moveSize > 0) {
mod = moveSize - outRect.x % moveSize;
}
}
deltaX = -moveSize + mod;
} else if (evt.keyCode == 39) {
let mod = 0;
if (!isShift) {
mod = Math.round(outRect.x) % moveSize;
}
deltaX = moveSize - mod;
}
let stage2 = ddInstance.stage;
let rsState = DDeiEditorUtil.invokeCallbackFunc("EVENT_CONTROL_DRAG_BEFORE", DDeiEnumOperateType.DRAG, { models }, ddInstance, evt);
if (rsState == 0 || rsState == 1) {
DDeiAbstractShape.moveModels(models, deltaX, deltaY, moveOriginLines);
stage2.layers[stage2.layerIndex].opPoints = [];
if ((_a3 = stage2.layers[stage2.layerIndex].opLine) == null ? void 0 : _a3.render) {
stage2.layers[stage2.layerIndex].opLine.render.enableRefreshShape();
}
delete stage2.layers[stage2.layerIndex].opLine;
stage2.render.refreshJumpLine = false;
ddInstance.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
ddInstance.bus.push(DDeiEnumBusCommandType.ClearTemplateVars);
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
ddInstance.bus.executeAll();
DDeiEditorUtil.invokeCallbackFunc("EVENT_CONTROL_DRAG_AFTER", DDeiEnumOperateType.DRAG, { models }, ddInstance, evt);
}
return true;
}
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionMoveModels, "defaultIns", new _DDeiKeyActionMoveModels());
let DDeiKeyActionMoveModels = _DDeiKeyActionMoveModels;
const _DDeiKeyActionPaste = class _DDeiKeyActionPaste extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-paste");
__publicField3(this, "defaultOptions", {
"keys": [
{ ctrl: 1, keys: "86", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionPaste.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionPaste.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionPaste.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionPaste(newOptions);
return panels;
}
}
return _DDeiKeyActionPaste;
}
static modify(fn) {
return _DDeiKeyActionPaste.defaultIns.modify(fn);
}
isActive(element) {
if (!element) {
return true;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return true;
}
return false;
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
if (ddInstance && ddInstance.stage && this.isActive(document.activeElement)) {
let modeName = DDeiUtil.getConfigValue("MODE_NAME", ddInstance);
let accessCreate = DDeiUtil.isAccess(
DDeiEnumOperateType.CREATE,
null,
null,
modeName,
ddInstance
);
if (accessCreate) {
this.doPaste(evt, ddInstance);
return true;
}
}
return false;
}
/**
* 执行粘贴
*/
async doPaste(evt, ddInstance) {
let blobData = null;
let type = null;
if (DDeiConfig.ALLOW_CLIPBOARD || DDeiConfig.ALLOW_CLIPBOARD == void 0) {
try {
let items = await navigator.clipboard.read();
items[0].types.forEach((t) => {
if (!type) {
type = t;
} else if (t = "text/html") {
type = t;
}
});
blobData = await items[0].getType(type);
DDeiConfig.ALLOW_CLIPBOARD = true;
} catch (e) {
DDeiConfig.ALLOW_CLIPBOARD = false;
}
}
if (!DDeiConfig.ALLOW_CLIPBOARD) {
type = "text/html";
blobData = window.DDEI_CLIPBOARD;
}
if (blobData) {
switch (type) {
case "text/plain": {
let dataText = await new Response(blobData).text();
this.textPaste(evt, ddInstance.stage, dataText);
break;
}
case "image/png": {
this.imagePaste(evt, ddInstance.stage, blobData);
break;
}
case "text/html": {
let dataText = await new Response(blobData).text();
this.htmlPaste(evt, ddInstance.stage, dataText);
}
}
}
}
/**
* 粘贴图片
*/
imagePaste(evt, stage2, blobData) {
let that = this;
let reader = new FileReader();
reader.onload = function(e) {
let image = new Image();
image.onload = function() {
var _a3, _b2, _c2, _d2, _e2;
let imgBase64 = e.target.result;
let layer2 = stage2.layers[stage2.layerIndex];
let offsetX = stage2.ddInstance.render.inAreaX;
let offsetY = stage2.ddInstance.render.inAreaY;
let createControl = true;
let hasChange = false;
if (((_a3 = stage2.selectedModels) == null ? void 0 : _a3.size) == 1) {
let table2 = Array.from(stage2.selectedModels.values())[0];
if (table2.baseModelType == "DDeiTable") {
let cells = table2.getSelectedCells();
if (cells.length > 0) {
cells.forEach((cell) => {
cell.setImgBase64(imgBase64);
});
hasChange = true;
createControl = false;
}
} else {
if (!table2.fill) {
table2.fill = { type: 2 };
}
table2.fill.type = 2;
table2.fill.image = imgBase64;
hasChange = true;
createControl = false;
}
} else if (((_b2 = stage2.selectedModels) == null ? void 0 : _b2.size) > 1) {
let isSimpleControl = true;
(_c2 = stage2.selectedModels) == null ? void 0 : _c2.forEach((item) => {
if (isSimpleControl && (item.baseModelType == "DDeiTable" || item.baseModelType == "DDeiContainer")) {
isSimpleControl = false;
}
});
if (isSimpleControl) {
createControl = false;
(_d2 = stage2.selectedModels) == null ? void 0 : _d2.forEach((item) => {
if (!item.fill) {
item.fill = { type: 2 };
}
item.fill.type = 2;
item.fill.image = imgBase64;
});
hasChange = true;
}
}
if (createControl) {
that.createNewImage(image, imgBase64, offsetX, offsetY, stage2, layer2, evt);
hasChange = true;
}
if (hasChange) {
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
}
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
(_e2 = stage2.ddInstance.bus) == null ? void 0 : _e2.executeAll();
};
image.src = e.target.result;
};
reader.readAsDataURL(blobData);
}
/**
* 粘贴文本
*/
textPaste(evt, stage2, textData) {
var _a3, _b2, _c2, _d2, _e2, _f;
let layer2 = stage2.layers[stage2.layerIndex];
let offsetX = stage2.ddInstance.render.inAreaX;
let offsetY = stage2.ddInstance.render.inAreaY;
let createControl = true;
let hasChange = false;
if (((_a3 = stage2.selectedModels) == null ? void 0 : _a3.size) == 1) {
let table2 = Array.from(stage2.selectedModels.values())[0];
if (table2.baseModelType == "DDeiTable") {
let cells = table2.getSelectedCells();
if (cells.length > 0) {
cells.forEach((cell) => {
cell.text = textData;
});
hasChange = true;
createControl = false;
}
} else if (table2.baseModelType != "DDeiContainer") {
table2.text = textData;
hasChange = true;
createControl = false;
}
} else if (((_b2 = stage2.selectedModels) == null ? void 0 : _b2.size) > 1) {
let isSimpleControl = true;
(_c2 = stage2.selectedModels) == null ? void 0 : _c2.forEach((item) => {
if (isSimpleControl && (item.baseModelType == "DDeiTable" || item.baseModelType == "DDeiContainer")) {
isSimpleControl = false;
}
});
if (isSimpleControl) {
createControl = false;
(_d2 = stage2.selectedModels) == null ? void 0 : _d2.forEach((item) => {
item.text = textData;
});
hasChange = true;
}
}
if (createControl) {
stage2.idIdx++;
hasChange = true;
let searchPaths = [
"font.size",
"font.family"
];
let configAtrs = DDeiUtil.getAttrValueByConfig(
{ modelCode: "100002" },
searchPaths
);
let size = DDeiUtil.measureTextSize(stage2.ddInstance, textData, configAtrs.get("font.family").data, configAtrs.get("font.size").data + 1);
let dataJson = {
id: "rect_" + stage2.idIdx,
modelCode: "100002"
};
let ccDefine = DDeiUtil.getControlDefine(dataJson);
searchPaths.forEach((key) => {
if (configAtrs.get(key)) {
dataJson[key] = configAtrs.get(key).data;
}
if (ccDefine[key] != void 0 && ccDefine[key] != null) {
dataJson[key] = ccDefine[key];
}
});
for (let i2 in ccDefine == null ? void 0 : ccDefine.define) {
dataJson[i2] = cloneDeep(ccDefine == null ? void 0 : ccDefine.define[i2]);
}
dataJson.text = textData;
dataJson.border = { type: 0 };
dataJson.fill = { type: 0 };
dataJson.width = size.width;
dataJson.height = size.height;
delete dataJson.ovs;
delete dataJson.font;
let model = DDeiPolygon.initByJSON(
dataJson,
{ currentStage: stage2 }
);
model.initPVS();
let moveMatrix2 = new Matrix3(
1,
0,
offsetX,
0,
1,
offsetY,
0,
0,
1
);
model.transVectors(moveMatrix2);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.ModelChangeContainer, { newContainer: layer2, models: [model] }, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, null, evt);
(_e2 = stage2.ddInstance.bus) == null ? void 0 : _e2.push(DDeiEnumBusCommandType.ModelChangeSelect, { models: [model], value: DDeiEnumControlState.SELECTED }, evt);
}
if (hasChange) {
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.StageChangeSelectModels, {}, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds, {}, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
}
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
(_f = stage2.ddInstance.bus) == null ? void 0 : _f.executeAll();
}
/**
* 粘贴HTML
*/
htmlPaste(evt, stage2, textData) {
var _a3, _b2, _c2, _d2;
let layer2 = stage2.layers[stage2.layerIndex];
let offsetX = stage2.ddInstance.render.inAreaX;
let offsetY = stage2.ddInstance.render.inAreaY;
let ddeiJson = null;
try {
let searchText = '';
if (textData.indexOf(searchText) != -1) {
let startIndex = textData.indexOf(searchText) + searchText.length;
let endIndex = textData.indexOf('');
let ddeiJsonStr = textData.substring(startIndex, endIndex);
if (ddeiJsonStr) {
ddeiJson = JSON.parse(ddeiJsonStr);
}
}
} catch (e) {
console.error(e);
}
let hasChange = false;
if (ddeiJson) {
let mode = ddeiJson.mode;
let jsonArray = ddeiJson.data;
let jsonLinkArray = ddeiJson.links;
if (!Array.isArray(jsonArray)) {
jsonArray = [jsonArray];
}
let unit = ddeiJson.unit;
if (unit && unit != "px") {
jsonArray.forEach((model) => {
DDeiUtil.convertChildrenJsonUnit(model, stage2, unit);
});
}
let controlInitJSON = DDeiEditorUtil.getModelInitJSON(stage2.ddInstance, null, jsonArray);
if (!controlInitJSON) {
return;
}
let createControl = true;
if (((_a3 = stage2.selectedModels) == null ? void 0 : _a3.size) == 1) {
let model = Array.from(stage2.selectedModels.values())[0];
if (model.baseModelType == "DDeiTable") {
let cells = model.getSelectedCells();
if (cells.length > 0) {
cells.forEach((cell) => {
this.createControl(controlInitJSON, jsonLinkArray, offsetX, offsetY, stage2, cell, mode, evt);
});
hasChange = true;
createControl = false;
}
} else if (model.baseModelType == "DDeiContainer") {
this.createControl(controlInitJSON, jsonLinkArray, offsetX, offsetY, stage2, model, mode, evt);
createControl = false;
hasChange = true;
}
}
if (createControl) {
this.createControl(controlInitJSON, jsonLinkArray, offsetX, offsetY, stage2, layer2, mode, evt);
hasChange = true;
}
if (hasChange) {
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.UpdatePaperArea);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.StageChangeSelectModels, {}, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds, {}, evt);
}
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
(_b2 = stage2.ddInstance.bus) == null ? void 0 : _b2.executeAll();
} else {
let tableJson = this.parseDomToJson(textData);
let createControl = true;
if (((_c2 = stage2.selectedModels) == null ? void 0 : _c2.size) == 1) {
let model = Array.from(stage2.selectedModels.values())[0];
if (model.baseModelType == "DDeiTable") {
this.copyTableToTableCell(model, tableJson);
createControl = false;
hasChange = true;
} else if (model.baseModelType == "DDeiContainer") {
this.createTable(tableJson, offsetX, offsetY, stage2, model, evt);
createControl = false;
hasChange = true;
}
}
if (createControl) {
this.createTable(tableJson, offsetX, offsetY, stage2, layer2, evt);
hasChange = true;
}
if (hasChange) {
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
}
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
(_d2 = stage2.ddInstance.bus) == null ? void 0 : _d2.executeAll();
}
}
/**
* 复制表格内容到另外一个表格的单元格中
* @param table 表格
* @param tableJson 表格单元格
*/
copyTableToTableCell(table2, tableJson) {
var _a3, _b2;
let distCells = table2.getSelectedCells();
if (distCells && distCells.length > 0 && tableJson) {
let sourceTable = tableJson;
let distTable = table2;
let sourceMinMaxRow = { minRow: 0, minCol: 0, maxRow: sourceTable.rows.length - 1, maxCol: sourceTable.rows[0].length - 1 };
let distMinMaxRow = distTable.getMinMaxRowAndCol(distCells);
let distAreaAllSelected = distTable.isAllSelected(distMinMaxRow.minRow, distMinMaxRow.minCol, distMinMaxRow.maxRow, distMinMaxRow.maxCol);
if (!distAreaAllSelected) {
console.log("表格粘贴目标不是一个有效的连续区域");
return;
}
let rowNum = 1;
let colNum = 1;
let sourceRowNum = sourceMinMaxRow.maxRow - sourceMinMaxRow.minRow + 1;
let distRowNum = distMinMaxRow.maxRow - distMinMaxRow.minRow + 1;
let sourceColNum = sourceMinMaxRow.maxCol - sourceMinMaxRow.minCol + 1;
let distColNum = distMinMaxRow.maxCol - distMinMaxRow.minCol + 1;
if (distRowNum == sourceRowNum) {
rowNum = sourceRowNum;
} else if (distRowNum > sourceRowNum) {
rowNum = distRowNum - distRowNum % sourceRowNum;
} else if (distRowNum < sourceRowNum) {
rowNum = sourceRowNum;
}
if (distColNum == sourceColNum) {
colNum = sourceColNum;
} else if (distColNum > sourceColNum) {
colNum = distColNum - distColNum % sourceColNum;
} else if (distColNum < sourceColNum) {
colNum = sourceColNum;
}
if (distTable.hasMergeCell(distMinMaxRow.minRow, distMinMaxRow.minCol, distMinMaxRow.minRow + rowNum - 1, distMinMaxRow.minCol + colNum - 1)) {
console.log("表格粘贴区域存在合并单元格");
return;
}
if (distTable.rows.length <= distMinMaxRow.minRow + rowNum - 1 || distTable.cols.length <= distMinMaxRow.minCol + colNum - 1) {
console.log("表格粘贴区域超出表格所在最大区域");
return;
}
let mergeCells = [];
for (let i2 = 0; i2 < rowNum && distMinMaxRow.minRow + i2 < distTable.rows.length; i2++) {
let offsetI = i2 % sourceRowNum;
for (let j2 = 0; j2 < colNum && distMinMaxRow.minCol + j2 < distTable.cols.length; j2++) {
let offsetJ = j2 % sourceColNum;
let sourceCell = sourceTable.rows[sourceMinMaxRow.minRow + offsetI][sourceMinMaxRow.minCol + offsetJ];
let targetCell = distTable.rows[distMinMaxRow.minRow + i2][distMinMaxRow.minCol + j2];
targetCell.text = sourceCell.text;
targetCell.textStyle = sourceCell.textStyle;
targetCell.font = sourceCell.font;
targetCell.border = sourceCell.border;
if (sourceCell.mergeRowNum > 1 || sourceCell.mergeColNum > 1) {
targetCell.mergeRowNum = sourceCell.mergeRowNum;
targetCell.mergeColNum = sourceCell.mergeColNum;
mergeCells[mergeCells.length] = targetCell;
}
(_b2 = (_a3 = targetCell.render) == null ? void 0 : _a3.renderCacheData) == null ? void 0 : _b2.clear();
}
}
for (let i2 = 0; i2 < mergeCells.length; i2++) {
let mc = mergeCells[i2];
let cells = distTable.getCellsByRect(mc.row, mc.col, mc.row + mc.mergeRowNum - 1, mc.col + mc.mergeColNum - 1);
distTable.mergeCells(cells);
}
}
}
/**
* 解析dom文本到json
* @param textData 文本
* @returns json
*/
parseDomToJson(textData) {
let tableJson = { rows: [], modelCode: "100301" };
let parser = new DOMParser();
let doc = parser.parseFromString(textData, "text/html");
if (doc) {
let tableEle = doc.body.children[0];
let tableHeight = 0;
tableJson.id = "copytable";
let tableWidth = 0;
let eleRows = tableEle.rows;
let mergeAreas = [];
let colSize = {};
let rowSize = {};
for (let i2 = 0; i2 < eleRows.length; i2++) {
let eleCells = eleRows[i2].cells;
if (!tableJson.rows[i2]) {
tableJson.rows[i2] = [];
}
let rowJson = tableJson.rows[i2];
for (let j2 = 0; j2 < eleCells.length; j2++) {
let cellEle = eleCells[j2];
let cellJson = { modelCode: "100302", row: i2, col: j2, text: cellEle.innerText, domRow: i2, domCol: j2 };
rowJson.push(cellJson);
if (cellEle.rowSpan > 1) {
cellJson.mergeRowNum = parseInt(cellEle.rowSpan);
}
if (cellEle.colSpan > 1) {
cellJson.mergeColNum = parseInt(cellEle.colSpan);
}
if (cellJson.mergeRowNum > 1 || cellJson.mergeColNum > 1) {
if (!cellJson.mergeRowNum) {
cellJson.mergeRowNum = 1;
}
if (!cellJson.mergeColNum) {
cellJson.mergeColNum = 1;
}
mergeAreas.push(cellJson);
}
cellJson.font = {};
if (cellEle.style.fontSize) {
cellJson.font.size = parseFloat(cellEle.style.fontSize);
}
if (cellEle.style.color) {
cellJson.font.color = DDeiUtil.getColor(cellEle.style.color);
}
if (cellEle.style.fontFamily) {
cellJson.font.family = cellEle.style.fontFamily;
}
cellJson.border = {};
cellJson.border.top = {};
cellJson.border.bottom = {};
cellJson.border.left = {};
cellJson.border.right = {};
if (cellEle.style.borderTopColor) {
cellJson.border.top.color = cellEle.style.borderTopColor;
if (cellJson.border.top.color == "initial") {
delete cellJson.border.top.color;
}
}
if (cellEle.style.borderTopWidth) {
cellJson.border.top.width = parseFloat(cellEle.style.borderTopWidth);
if (isNaN(cellJson.border.top.width) || cellJson.border.top.width == "initial") {
delete cellJson.border.top.width;
}
}
if (cellEle.style.borderTopStyle) {
cellJson.border.top.style = cellEle.style.borderTopStyle;
}
if (cellEle.style.borderBottomColor) {
cellJson.border.bottom.color = cellEle.style.borderBottomColor;
if (cellJson.border.bottom.color == "initial") {
delete cellJson.border.bottom.color;
}
}
if (cellEle.style.borderBottomWidth) {
cellJson.border.bottom.width = parseFloat(cellEle.style.borderBottomWidth);
if (isNaN(cellJson.border.bottom.width) || cellJson.border.bottom.width == "initial") {
delete cellJson.border.bottom.width;
}
}
if (cellEle.style.borderBottomStyle) {
cellJson.border.bottom.style = cellEle.style.borderBottomStyle;
}
if (cellEle.style.borderLeftColor) {
cellJson.border.left.color = cellEle.style.borderLeftColor;
if (cellJson.border.left.color == "initial") {
delete cellJson.border.left.color;
}
}
if (cellEle.style.borderLeftWidth) {
cellJson.border.left.width = parseFloat(cellEle.style.borderLeftWidth);
if (isNaN(cellJson.border.left.width) || cellJson.border.left.width == "initial") {
delete cellJson.border.left.width;
}
}
if (cellEle.style.borderLeftStyle) {
cellJson.border.left.style = cellEle.style.borderLeftStyle;
}
if (cellEle.style.borderRightColor) {
cellJson.border.right.color = cellEle.style.borderRightColor;
if (cellJson.border.right.color == "initial") {
delete cellJson.border.right.color;
}
}
if (cellEle.style.borderRightWidth) {
cellJson.border.right.width = parseFloat(cellEle.style.borderRightWidth);
if (isNaN(cellJson.border.right.width) || cellJson.border.right.width == "initial") {
delete cellJson.border.right.width;
}
}
if (cellEle.style.borderRightStyle) {
cellJson.border.right.style = cellEle.style.borderRightStyle;
}
cellJson.fill = {};
if (cellEle.style.backgroundColor) {
cellJson.fill.color = cellEle.style.backgroundColor;
}
cellJson.textStyle = {};
if (cellEle.style.textAlign) {
if (cellEle.style.textAlign == "left") {
cellJson.textStyle.align = 1;
} else if (cellEle.style.textAlign == "center") {
cellJson.textStyle.align = 2;
} else if (cellEle.style.textAlign == "right") {
cellJson.textStyle.align = 3;
}
}
if (cellEle.style.verticalAlign) {
if (cellEle.style.verticalAlign == "top") {
cellJson.textStyle.valign = 1;
} else if (cellEle.style.verticalAlign == "middle") {
cellJson.textStyle.valign = 2;
} else if (cellEle.style.verticalAlign == "bottom") {
cellJson.textStyle.valign = 3;
}
}
if (cellEle.style.textDecoration == "underline") {
cellJson.textStyle.underline = "1";
}
if (cellEle.style.textDecoration == "line-through") {
cellJson.textStyle.deleteline = "1";
}
if (cellEle.style.whiteSpace == "nowrap") {
cellJson.textStyle.feed = "0";
} else {
cellJson.textStyle.feed = "1";
}
if (cellEle.style.fontStyle == "italic") {
cellJson.textStyle.italic = "1";
}
if (cellEle.style.fontWeight) {
if (cellEle.style.fontWeight == "bold") {
cellJson.textStyle.bold = "1";
} else if (parseInt(cellEle.style.fontWeight) > 400)
cellJson.textStyle.bold = "1";
}
}
}
mergeAreas.forEach((mergeCell) => {
for (let i2 = 1; i2 <= mergeCell.mergeRowNum; i2++) {
for (let j2 = 1; j2 <= mergeCell.mergeColNum; j2++) {
if (!(i2 == 1 && j2 == 1)) {
tableJson.rows[mergeCell.row + i2 - 1].splice(mergeCell.col + j2 - 1, 0, { width: 0, height: 0, modelCode: "100302", mCell: mergeCell });
for (let k = 0; k < tableJson.rows.length; k++) {
let rowObj = tableJson.rows[k];
for (let l = 0; l < rowObj.length; l++) {
rowObj[l].row = k;
rowObj[l].col = l;
}
}
}
}
}
});
for (let k = 0; k < tableJson.rows.length; k++) {
let rowObj = tableJson.rows[k];
for (let l = 0; l < rowObj.length; l++) {
if ((rowObj[l].domRow || rowObj[l].domRow == 0) && (!rowObj[l].mergeRowNum || rowObj[l].mergeRowNum <= 1) && (!rowObj[l].mergeColNum <= 1 || rowObj[l].mergeColNum <= 1)) {
let rowHeight = null;
let domRowEle = tableEle.rows[rowObj[l].domRow];
let domCellEle = tableEle.rows[rowObj[l].domRow].cells[rowObj[l].domCol];
if (!rowSize["" + k]) {
if (domRowEle.style.height) {
rowHeight = parseFloat(domRowEle.style.height);
} else {
rowHeight = parseFloat(domRowEle.getAttribute("height"));
}
if (!isNaN(rowHeight)) {
rowSize["" + k] = rowHeight;
}
}
let colWidth = null;
if (!colSize["" + l]) {
if (domCellEle.style.width) {
colWidth = parseFloat(domCellEle.style.width);
} else {
colWidth = parseFloat(domCellEle.getAttribute("width"));
}
if (!isNaN(colWidth)) {
colSize["" + l] = colWidth;
}
}
}
}
}
for (let k = 0; k < tableJson.rows.length; k++) {
if (!rowSize[k]) {
let mCell = null;
let rowObj = tableJson.rows[k];
for (let l = 0; l < rowObj.length; l++) {
if (rowObj[l].domRow || rowObj[l].domRow == 0) {
let domCellEle = tableEle.rows[rowObj[l].domRow].cells[rowObj[l].domCol];
if (rowObj[l].mergeRowNum > 1 || rowObj[l].mergeColNum > 1) {
mCell = rowObj[l];
} else if (!mCell && rowObj[l].mCell) {
mCell = rowObj[l].mCell;
} else if (!rowObj[l].mCell) {
let rowHeight = 0;
if (domCellEle.style.height) {
rowHeight = parseFloat(domCellEle.style.height);
} else {
rowHeight = parseFloat(domCellEle.getAttribute("height"));
}
if (!isNaN(rowHeight)) {
rowSize["" + k] = rowHeight;
}
break;
}
}
}
if (!rowSize[k] && mCell) {
let domCellEle = tableEle.rows[mCell.domRow].cells[mCell.domCol];
let rowHeight = 0;
if (domCellEle.style.height) {
rowHeight = parseFloat(domCellEle.style.height);
} else {
rowHeight = parseFloat(domCellEle.getAttribute("height"));
}
if (!isNaN(rowHeight)) {
rowSize[k] = rowHeight / mCell.mergeRowNum;
}
}
}
}
for (let l = 0; l < tableJson.rows[0].length; l++) {
if (!colSize[l]) {
let mCell = null;
for (let k = 0; k < tableJson.rows.length; k++) {
if (tableJson.rows[k][l].domRow || tableJson.rows[k][l].domRow == 0) {
let domCellEle = tableEle.rows[tableJson.rows[k][l].domRow].cells[tableJson.rows[k][l].domCol];
if (tableJson.rows[k][l].mergeRowNum > 1 || tableJson.rows[k][l].mergeColNum > 1) {
mCell = tableJson.rows[k][l];
} else if (!mCell && tableJson.rows[k][l].mCell) {
mCell = tableJson.rows[k][l].mCell;
} else if (!tableJson.rows[k][l].mCell) {
let colWidth = 0;
if (domCellEle.style.width) {
colWidth = parseFloat(domCellEle.style.width);
} else {
colWidth = parseFloat(domCellEle.getAttribute("width"));
}
if (!isNaN(colWidth)) {
colSize["" + l] = colWidth;
}
break;
}
}
}
if (!colSize[l] && mCell) {
let domCellEle = tableEle.rows[mCell.domRow].cells[mCell.domCol];
let colWidth = 0;
if (domCellEle.style.width) {
colWidth = parseFloat(domCellEle.style.width);
} else {
colWidth = parseFloat(domCellEle.getAttribute("width"));
}
if (!isNaN(colWidth)) {
colSize[l] = colWidth / mCell.mergeColNum;
}
}
}
}
for (let k = 0; k < tableJson.rows.length; k++) {
let rowObj = tableJson.rows[k];
for (let l = 0; l < rowObj.length; l++) {
if (k == 0) {
if (isNaN(colSize["" + l])) {
colSize["" + l] = 40;
}
tableWidth += colSize["" + l];
}
if (l == 0) {
if (isNaN(rowSize["" + k])) {
rowSize["" + k] = 20;
}
tableHeight += rowSize["" + k];
}
if (rowObj[l].mergeRowNum > 1 || rowObj[l].mergeColNum > 1) {
let mHeight = 0;
let mWidth = 0;
for (let ki = 1; ki <= rowObj[l].mergeRowNum; ki++) {
if (isNaN(rowSize["" + (k + ki - 1)])) {
rowSize["" + (k + ki - 1)] = 20;
}
mHeight += rowSize["" + (k + ki - 1)];
}
for (let ki = 1; ki <= rowObj[l].mergeColNum; ki++) {
if (isNaN(colSize["" + (l + ki - 1)])) {
colSize["" + (l + ki - 1)] = 40;
}
mWidth += colSize["" + (l + ki - 1)];
}
rowObj[l].height = mHeight;
rowObj[l].width = mWidth;
rowObj[l].originWidth = colSize["" + l];
rowObj[l].originHeight = rowSize["" + k];
delete rowObj[l].domRow;
delete rowObj[l].domCol;
} else if (rowObj[l].mCell) {
rowObj[l].originWidth = colSize["" + l];
rowObj[l].originHeight = rowSize["" + k];
delete rowObj[l].mCell;
delete rowObj[l].domRow;
delete rowObj[l].domCol;
} else {
rowObj[l].width = colSize["" + l];
rowObj[l].height = rowSize["" + k];
delete rowObj[l].domRow;
delete rowObj[l].domCol;
}
}
}
tableJson.height = tableHeight;
tableJson.width = tableWidth;
return tableJson;
}
}
//创建新的表格
createTable(tableJson, x2, y2, stage2, container2, evt) {
let layer2 = stage2.layers[stage2.layerIndex];
let tableModel = DDeiTable.loadFromJSON(tableJson, { currentDdInstance: stage2.ddInstance, currentStage: stage2, currentLayer: layer2, currentContainer: container2 });
stage2.idIdx++;
let newId = "table_" + stage2.idIdx;
tableModel.id = newId;
tableModel.x = x2 - tableModel.width / 2;
tableModel.y = y2 - tableModel.height / 2;
tableModel.resetCellData();
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.ModelChangeContainer, { newContainer: container2, models: [tableModel] }, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, null, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.ModelChangeSelect, { models: [tableModel], value: DDeiEnumControlState.SELECTED }, evt);
}
//创建新的控件
createControl(jsonArray, jsonLinkArray = [], x2, y2, stage2, container2, mode, evt) {
let layer2 = stage2.layers[stage2.layerIndex];
let models = [];
let oldIdMap = {};
jsonArray.forEach((json) => {
if (mode == "copy") {
let copyModel = stage2.ddInstance.controlModelClasses[json.modelType].loadFromJSON(json, { currentDdInstance: stage2.ddInstance, currentStage: stage2, currentLayer: layer2, currentContainer: container2 });
models.push(copyModel);
this.loadJsonModelToMap(copyModel, stage2, mode, oldIdMap);
this.changeModelId(stage2, copyModel);
} else if (mode == "cut") {
let model = stage2.getModelById(json.id);
models.push(model);
this.loadJsonModelToMap(model, stage2, mode, oldIdMap);
}
});
let rsState = -1;
if (mode == "copy") {
rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_CREATE_BEFORE", DDeiEnumOperateType.CREATE, { models, links: jsonLinkArray }, stage2.ddInstance);
} else if (mode == "cut") {
rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_DRAG_BEFORE", DDeiEnumOperateType.DRAG, { models, links: jsonLinkArray }, stage2.ddInstance);
}
if (rsState != -1) {
let outRect = DDeiAbstractShape.getOutRectByPV(models);
outRect = { x: outRect.x + outRect.width / 2, y: outRect.y + outRect.height / 2 };
if (mode == "copy") {
let appendExPvs = {};
jsonLinkArray == null ? void 0 : jsonLinkArray.forEach((lk) => {
if (!lk.disabled) {
let sm = lk.sm;
let dm = lk.dm;
if (!sm && lk.smid) {
sm = oldIdMap[lk.smid];
}
if (!dm && lk.dmid) {
dm = oldIdMap[lk.dmid];
}
if (lk.smpath) {
let sourcePV = DDeiUtil.getDataByPathList(sm, lk.smpath);
let newId = "_" + DDeiUtil.getUniqueCode();
sourcePV.id = newId;
if (!appendExPvs[sm.id]) {
appendExPvs[sm.id] = {};
}
appendExPvs[sm.id][newId] = sourcePV;
lk.smpath = "exPvs." + newId;
}
let link2 = new DDeiLink({
group: lk.group,
smpath: lk.smpath,
dmpath: lk.dmpath,
stage: stage2,
sm,
dm
});
stage2.links.push(link2);
}
});
for (let m in oldIdMap) {
let item = oldIdMap[m];
item.exPvs = {};
if (appendExPvs[item.id]) {
item.exPvs = appendExPvs[item.id];
}
if (item.linkModels) {
let linkModels = /* @__PURE__ */ new Map();
for (let key in item.linkModels) {
let lkItem = item.linkModels[key];
if (lkItem == null ? void 0 : lkItem.dmid) {
let dm = oldIdMap[lkItem.dmid];
if (dm) {
lkItem.dm = dm;
lkItem.depModel = item;
dm.depModel = item;
let lm = new DDeiModelLink(lkItem);
linkModels.set(dm.id, lm);
}
}
}
item.linkModels = linkModels;
}
}
stage2.refreshLinkCache();
}
models.forEach((item) => {
let cpx = item.cpv.x;
let cpy = item.cpv.y;
let dx = outRect.x - cpx;
let dy = outRect.y - cpy;
let moveMatrix2 = new Matrix3(
1,
0,
x2 - dx - cpx,
0,
1,
y2 - dy - cpy,
0,
0,
1
);
item.transVectors(moveMatrix2);
});
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.ModelChangeContainer, { newContainer: container2, models }, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, null, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.ModelChangeSelect, { models, value: DDeiEnumControlState.SELECTED }, evt);
if (mode == "copy") {
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyControlCreated, {
models
});
} else if (mode == "cut") {
DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_DRAG_AFTER", DDeiEnumOperateType.DRAG, { models }, stage2.ddInstance, evt);
}
}
}
/**
* 修改模型ID
* @param stage 舞台
* @param item 控件
* @return 新的ID
*/
changeModelId(stage2, item) {
let newId = "";
while (true) {
stage2.idIdx++;
if (item.id.indexOf("_") != -1) {
newId = item.id.substring(0, item.id.lastIndexOf("_")) + "_" + stage2.idIdx;
} else {
newId = item.id + "_cp_" + stage2.idIdx;
}
if (!stage2.getModelById(newId)) {
break;
}
}
item.oldId = item.id;
item.id = newId;
item.unicode = DDeiUtil.getUniqueCode();
let accuContainer = item.getAccuContainer();
if ((accuContainer == null ? void 0 : accuContainer.baseModelType) == "DDeiContainer") {
let midList = [];
let models = /* @__PURE__ */ new Map();
accuContainer.midList.forEach((mid) => {
let model = accuContainer.models.get(mid);
let modelNewId = this.changeModelId(stage2, model);
models.set(modelNewId, model);
midList.push(modelNewId);
});
accuContainer.models = models;
accuContainer.midList = midList;
} else if ((accuContainer == null ? void 0 : accuContainer.baseModelType) == "DDeiTable") {
for (let i2 = 0; i2 < accuContainer.rows; i2++) {
let rowObj = accuContainer.rows[i2];
for (let j2 = 0; j2 < rowObj.length; j2++) {
let accuContainer2 = rowObj[j2].getAccuContainer();
let midList = [];
let models = /* @__PURE__ */ new Map();
accuContainer2.midList.forEach((mid) => {
let model = accuContainer2.models.get(mid);
let modelNewId = this.changeModelId(stage2, model);
models.set(modelNewId, model);
midList.push(modelNewId);
});
accuContainer2.models = models;
accuContainer2.midList = midList;
}
}
}
return newId;
}
//创建新的图片控件
createNewImage(image, imgBase64, x2, y2, stage2, container2, evt) {
stage2.idIdx++;
let rat1 = stage2.ddInstance.render.ratio;
let stageRatio2 = stage2.getStageRatio();
let dataJson = {
id: "img_" + stage2.idIdx,
modelCode: "100002"
};
let ccDefine = DDeiUtil.getControlDefine(dataJson);
for (let i2 in ccDefine == null ? void 0 : ccDefine.define) {
dataJson[i2] = cloneDeep(ccDefine == null ? void 0 : ccDefine.define[i2]);
}
dataJson.text = "";
dataJson.border = { type: 0 };
dataJson.fill = { type: 2 };
dataJson.fill.image = imgBase64;
dataJson.width = image.width / rat1 / stageRatio2;
dataJson.height = image.height / rat1 / stageRatio2;
delete dataJson.ovs;
let model = DDeiPolygon.initByJSON(
dataJson,
{ currentStage: stage2 }
);
model.initPVS();
let moveMatrix2 = new Matrix3(
1,
0,
x2,
0,
1,
y2,
0,
0,
1
);
model.transVectors(moveMatrix2);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.ModelChangeContainer, { newContainer: container2, models: [model] }, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.CancelCurLevelSelectedModels, null, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.ModelChangeSelect, { models: [model], value: DDeiEnumControlState.SELECTED }, evt);
stage2.ddInstance.bus.push(DDeiEnumBusCommandType.StageChangeSelectModels);
}
loadJsonModelToMap(json, stage2, mode, map) {
map[json.id] = json;
if (json.baseModelType == "DDeiContainer") {
json.models.forEach((item) => {
this.loadJsonModelToMap(item, stage2, mode, map);
});
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionPaste, "defaultIns", new _DDeiKeyActionPaste());
let DDeiKeyActionPaste = _DDeiKeyActionPaste;
const _DDeiKeyActionPushModels = class _DDeiKeyActionPushModels extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-push-models");
__publicField3(this, "defaultOptions", {
"keys": [
//置于上层
{ ctrl: 1, keys: "38", editorState: DDeiEditorState.DESIGNING },
//置于下层
{ ctrl: 1, keys: "40", editorState: DDeiEditorState.DESIGNING },
//置于顶层
{ ctrl: 1, shift: 1, keys: "38", editorState: DDeiEditorState.DESIGNING },
//置于底层
{ ctrl: 1, shift: 1, keys: "40", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionPushModels.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionPushModels.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionPushModels.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionPushModels(newOptions);
return panels;
}
}
return _DDeiKeyActionPushModels;
}
static modify(fn) {
return _DDeiKeyActionPushModels.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
isActive(element) {
if (!element) {
return true;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return true;
}
return false;
}
action(evt, ddInstance) {
if (ddInstance && ddInstance.stage) {
if (this.isActive(document.activeElement)) {
let stageRender = ddInstance.stage.render;
let optContainer = stageRender.currentOperateContainer;
if (optContainer) {
let isCtrl = DDei.KEY_DOWN_STATE.get("ctrl");
let isShift = DDei.KEY_DOWN_STATE.get("shift");
if (isCtrl && isShift) {
if (evt.keyCode == 38) {
ddInstance.bus.push(DDeiEnumBusCommandType.ModelPush, { container: optContainer, type: "top" }, evt);
} else if (evt.keyCode == 40) {
ddInstance.bus.push(DDeiEnumBusCommandType.ModelPush, { container: optContainer, type: "bottom" }, evt);
}
} else if (isCtrl) {
if (evt.keyCode == 38) {
ddInstance.bus.push(DDeiEnumBusCommandType.ModelPush, { container: optContainer, type: "up" }, evt);
} else if (evt.keyCode == 40) {
ddInstance.bus.push(DDeiEnumBusCommandType.ModelPush, { container: optContainer, type: "down" }, evt);
}
}
}
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
ddInstance.bus.executeAll();
return true;
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionPushModels, "defaultIns", new _DDeiKeyActionPushModels());
let DDeiKeyActionPushModels = _DDeiKeyActionPushModels;
const _DDeiKeyActionNewRowQuickEdit = class _DDeiKeyActionNewRowQuickEdit extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-quickedit-newrow");
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionNewRowQuickEdit.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionNewRowQuickEdit.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionNewRowQuickEdit.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionNewRowQuickEdit(newOptions);
return panels;
}
}
return _DDeiKeyActionNewRowQuickEdit;
}
static modify(fn) {
return _DDeiKeyActionNewRowQuickEdit.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
let editor = DDeiEditor.ACTIVE_INSTANCE;
editor.quickEditorInput.value += "\n";
editor.quickEditorInput.selectionEnd = editor.quickEditorInput.value.length;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionNewRowQuickEdit, "defaultIns", new _DDeiKeyActionNewRowQuickEdit());
let DDeiKeyActionNewRowQuickEdit = _DDeiKeyActionNewRowQuickEdit;
const _DDeiKeyActionRemoveModels = class _DDeiKeyActionRemoveModels extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-remove-models");
__publicField3(this, "defaultOptions", {
"keys": [
{ keys: "8", editorState: DDeiEditorState.DESIGNING },
{ keys: "46", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionRemoveModels.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionRemoveModels.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionRemoveModels.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionRemoveModels(newOptions);
return panels;
}
}
return _DDeiKeyActionRemoveModels;
}
static modify(fn) {
return _DDeiKeyActionRemoveModels.defaultIns.modify(fn);
}
isActive(element) {
if (!element) {
return true;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return true;
}
return false;
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
var _a3;
if (ddInstance && ddInstance.stage) {
if (this.isActive(document.activeElement)) {
let stageRender = ddInstance.stage.render;
let optContainer = stageRender.currentOperateContainer;
if (optContainer) {
let selectedModels = optContainer.getSelectedModels();
let rsState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_DEL_BEFORE", DDeiEnumOperateType.DEL, { models: Array.from(selectedModels.values()) }, ddInstance, evt);
if (rsState == 0 || rsState == 1) {
let models = Array.from(selectedModels.values());
models[0].layer.opPoints = [];
if ((_a3 = models[0].layer.opLine) == null ? void 0 : _a3.render) {
models[0].layer.opLine.render.enableRefreshShape();
}
delete models[0].layer.opLine;
optContainer.removeModels(models, true);
optContainer.cascadeRemoveSelf();
ddInstance.bus.push(DDeiEnumBusCommandType.UpdatePaperArea);
ddInstance.bus.push(DDeiEnumBusCommandType.StageChangeSelectModels);
ddInstance.bus.push(DDeiEnumBusCommandType.UpdateSelectorBounds);
ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy);
ddInstance.bus.push(DDeiEnumBusCommandType.ChangeStageWPV, {
dragObj: { dx: 0, dy: 0 },
x: 0,
y: 0
});
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.executeAll();
return true;
}
}
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionRemoveModels, "defaultIns", new _DDeiKeyActionRemoveModels());
let DDeiKeyActionRemoveModels = _DDeiKeyActionRemoveModels;
const _DDeiKeyActionReRevoke = class _DDeiKeyActionReRevoke extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-re-revoke");
__publicField3(this, "defaultOptions", {
"keys": [
//反撤销
{ ctrl: 1, keys: "89", editorState: DDeiEditorState.DESIGNING },
{ ctrl: 1, shift: 1, keys: "90", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionReRevoke.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionReRevoke.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionReRevoke.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionReRevoke(newOptions);
return panels;
}
}
return _DDeiKeyActionReRevoke;
}
static modify(fn) {
return _DDeiKeyActionReRevoke.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
isActive(element) {
if (!element) {
return true;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return true;
}
return false;
}
action(evt, ddInstance) {
let editor = DDeiEditor.ACTIVE_INSTANCE;
if (this.isActive(document.activeElement)) {
let histype = DDeiEditorUtil.getConfigValue("HISTROY_LEVEL", editor);
if (histype == "file") {
if ((editor == null ? void 0 : editor.files.length) > 0 && (editor.currentFileIndex == 0 || editor.currentFileIndex)) {
let file = editor == null ? void 0 : editor.files[editor.currentFileIndex];
if ((file == null ? void 0 : file.active) == DDeiActiveType.ACTIVE) {
let hisData = file.reRevokeHistroyData();
if (hisData == null ? void 0 : hisData.data) {
let jsonData = JSON.parse(hisData == null ? void 0 : hisData.data);
if (jsonData) {
let ddInstance2 = editor == null ? void 0 : editor.ddInstance;
ddInstance2.stage.destroyRender();
let hisFile = DDeiFile.loadFromJSON(jsonData, {
currentDdInstance: ddInstance2
});
if (hisData.isNew == true) {
file.state = DDeiFileState.NONE;
} else {
file.state = DDeiFileState.MODIFY;
}
file.name = hisFile == null ? void 0 : hisFile.name;
file.desc = hisFile == null ? void 0 : hisFile.desc;
file.lastUpdateTime = hisFile == null ? void 0 : hisFile.lastUpdateTime;
file.sheets = hisFile == null ? void 0 : hisFile.sheets;
if (file && file.sheets && ddInstance2) {
file.changeSheet(hisFile.currentSheetIndex);
let stage2 = file.sheets[file.currentSheetIndex].stage;
stage2.ddInstance = ddInstance2;
ddInstance2.stage = stage2;
stage2.initRender();
ddInstance2.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance2.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts);
ddInstance2.bus.executeAll();
return true;
}
}
}
}
}
} else if (histype == "stage") {
if (ddInstance && ddInstance.stage) {
let hisData = ddInstance.stage.reRevokeHistroyData();
if (hisData == null ? void 0 : hisData.data) {
let jsonData = JSON.parse(hisData == null ? void 0 : hisData.data);
if (jsonData) {
ddInstance.stage.destroyRender();
let tempData = { "currentDdInstance": ddInstance, "currentStage": ddInstance.stage };
tempData[ddInstance.stage.id] = ddInstance.stage;
let layers = [];
jsonData.layers.forEach((layer2) => {
let model = DDeiLayer.loadFromJSON(layer2, tempData);
layers.push(model);
});
ddInstance.stage.idIdx = jsonData.idIdx;
ddInstance.stage.layers = layers;
ddInstance.stage.initRender();
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts);
ddInstance.bus.executeAll();
return true;
}
}
}
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionReRevoke, "defaultIns", new _DDeiKeyActionReRevoke());
let DDeiKeyActionReRevoke = _DDeiKeyActionReRevoke;
const _DDeiKeyActionRevoke = class _DDeiKeyActionRevoke extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-revoke");
__publicField3(this, "defaultOptions", {
"keys": [
//撤销
{ ctrl: 1, keys: "90", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionRevoke.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionRevoke.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionRevoke.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionRevoke(newOptions);
return panels;
}
}
return _DDeiKeyActionRevoke;
}
static modify(fn) {
return _DDeiKeyActionRevoke.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
isActive(element) {
if (!element) {
return true;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return true;
}
return false;
}
action(evt, ddInstance) {
let editor = DDeiEditor.ACTIVE_INSTANCE;
if (this.isActive(document.activeElement)) {
let histype = DDeiEditorUtil.getConfigValue("HISTROY_LEVEL", editor);
if (histype == "file") {
let editor2 = DDeiEditor.ACTIVE_INSTANCE;
if ((editor2 == null ? void 0 : editor2.files.length) > 0 && (editor2.currentFileIndex == 0 || editor2.currentFileIndex)) {
let file = editor2 == null ? void 0 : editor2.files[editor2.currentFileIndex];
if ((file == null ? void 0 : file.active) == DDeiActiveType.ACTIVE) {
let hisData = file.revokeHistroyData();
if (hisData == null ? void 0 : hisData.data) {
let jsonData = JSON.parse(hisData == null ? void 0 : hisData.data);
if (jsonData) {
let ddInstance2 = editor2 == null ? void 0 : editor2.ddInstance;
ddInstance2.stage.destroyRender();
let hisFile = DDeiFile.loadFromJSON(jsonData, {
currentDdInstance: ddInstance2
});
if (hisData.isNew == true) {
file.state = DDeiFileState.NONE;
} else {
file.state = DDeiFileState.MODIFY;
}
file.name = hisFile == null ? void 0 : hisFile.name;
file.desc = hisFile == null ? void 0 : hisFile.desc;
file.lastUpdateTime = hisFile == null ? void 0 : hisFile.lastUpdateTime;
file.sheets = hisFile == null ? void 0 : hisFile.sheets;
if (file && file.sheets && ddInstance2) {
file.changeSheet(hisFile.currentSheetIndex);
let stage2 = file.sheets[file.currentSheetIndex].stage;
stage2.ddInstance = ddInstance2;
ddInstance2.stage = stage2;
stage2.initRender();
ddInstance2.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance2.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts);
ddInstance2.bus.executeAll();
return true;
}
}
}
}
}
} else if (histype == "stage") {
if (ddInstance && ddInstance.stage) {
let hisData = ddInstance.stage.revokeHistroyData();
if (hisData == null ? void 0 : hisData.data) {
let jsonData = JSON.parse(hisData == null ? void 0 : hisData.data);
if (jsonData) {
ddInstance.stage.destroyRender();
let tempData = { "currentDdInstance": ddInstance, "currentStage": ddInstance.stage };
tempData[ddInstance.stage.id] = ddInstance.stage;
let layers = [];
jsonData.layers.forEach((layer2) => {
let model = DDeiLayer.loadFromJSON(layer2, tempData);
layers.push(model);
});
ddInstance.stage.idIdx = jsonData.idIdx;
ddInstance.stage.layers = layers;
ddInstance.stage.initRender();
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts);
ddInstance.bus.executeAll();
return true;
}
}
}
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionRevoke, "defaultIns", new _DDeiKeyActionRevoke());
let DDeiKeyActionRevoke = _DDeiKeyActionRevoke;
const _DDeiKeyActionSaveFile = class _DDeiKeyActionSaveFile extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-save-file");
__publicField3(this, "defaultOptions", {
"keys": [
//保存
{ ctrl: 1, keys: "83" }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionSaveFile.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionSaveFile.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionSaveFile.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionSaveFile(newOptions);
return panels;
}
}
return _DDeiKeyActionSaveFile;
}
static modify(fn) {
return _DDeiKeyActionSaveFile.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
var _a3, _b2;
(_a3 = ddInstance.bus) == null ? void 0 : _a3.push(DDeiEditorEnumBusCommandType.SaveFile, {}, evt);
(_b2 = ddInstance.bus) == null ? void 0 : _b2.executeAll();
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionSaveFile, "defaultIns", new _DDeiKeyActionSaveFile());
let DDeiKeyActionSaveFile = _DDeiKeyActionSaveFile;
const _DDeiKeyActionStartQuickEdit = class _DDeiKeyActionStartQuickEdit extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-quickedit-start");
__publicField3(this, "defaultOptions", {
"keys": [
//F2快捷编辑
{ keys: "113", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionStartQuickEdit.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionStartQuickEdit.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionStartQuickEdit.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionStartQuickEdit(newOptions);
return panels;
}
}
return _DDeiKeyActionStartQuickEdit;
}
static modify(fn) {
return _DDeiKeyActionStartQuickEdit.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
isActive(element) {
if (!element) {
return true;
}
if (element.tagName == "BODY" || element.tagName == "HEAD" || element.tagName == "HTML") {
return true;
}
return false;
}
action(evt, ddInstance) {
var _a3, _b2, _c2, _d2, _e2, _f, _g;
if (ddInstance && ddInstance.stage) {
if (this.isActive(document.activeElement)) {
if (((_b2 = (_a3 = ddInstance.stage) == null ? void 0 : _a3.selectedModels) == null ? void 0 : _b2.size) == 1) {
let model = Array.from((_c2 = ddInstance.stage) == null ? void 0 : _c2.selectedModels.values())[0];
let editor = DDeiEditor.ACTIVE_INSTANCE;
if (editor.state == DDeiEditorState.DESIGNING) {
let rsState1 = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_VIEW", DDeiEnumOperateType.VIEW, { models: [model] }, ddInstance, null);
if (rsState1 == 0 || rsState1 == 1) {
let editState = DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_BEFORE", DDeiEnumOperateType.EDIT, { models: [model] }, ddInstance, null);
if (editState == 0 || editState == 1) {
let stage2 = ddInstance.stage;
let stageRatio2 = stage2.getStageRatio();
if (model == null ? void 0 : model.render) {
let ex = -1;
let ey = -1;
if (evt.offsetX || evt.offsetY) {
ex = evt.offsetX;
ey = evt.offsetY;
ex /= window.remRatio;
ey /= window.remRatio;
ex -= stage2.wpv.x;
ey -= stage2.wpv.y;
ex = ex / stageRatio2;
ey = ey / stageRatio2;
}
let realModel = null;
let posPoint = null;
let posType;
let isCreateRealModel = false;
let isLineLM = false;
if (model.baseModelType == "DDeiLine") {
posType = 3;
if (evt.offsetX || evt.offsetY) {
let cdist = DDeiUtil.getPointDistance(model.pvs[0].x, model.pvs[1].y, model.pvs[model.pvs.length - 1].x, model.pvs[model.pvs.length - 1].y);
let sdist = DDeiUtil.getPointDistance(ex, ey, model.pvs[0].x, model.pvs[0].y);
let edist = DDeiUtil.getPointDistance(ex, ey, model.pvs[model.pvs.length - 1].x, model.pvs[model.pvs.length - 1].y);
if (sdist < cdist / 5) {
posType = 1;
} else if (edist < cdist / 5) {
posType = 2;
}
}
if (posType == 1) {
posPoint = model.startPoint;
} else if (posType == 2) {
posPoint = model.endPoint;
} else if (posType == 3) {
let pi = Math.floor(model.pvs.length / 2);
if (model.pvs.length % 3 == 0) {
posPoint = model.pvs[pi];
} else {
posPoint = {
x: (model.pvs[pi - 1].x + model.pvs[pi].x) / 2,
y: (model.pvs[pi - 1].y + model.pvs[pi].y) / 2
};
}
}
model.linkModels.forEach((lm) => {
if (lm.type == posType) {
realModel = lm.dm;
}
});
if (!realModel) {
isCreateRealModel = true;
isLineLM = true;
}
} else {
model.linkModels.forEach((lm) => {
posType = lm.type;
realModel = lm.dm;
});
if (!realModel) {
let modelDefine = DDeiEditorUtil.getControlDefine(model);
if ((_e2 = (_d2 = modelDefine == null ? void 0 : modelDefine.define) == null ? void 0 : _d2.sample) == null ? void 0 : _e2.depPos) {
let depPos = modelDefine.define.sample.depPos;
let essBounds = model.essBounds;
let dmEssBounds = { width: 80, height: 18 };
posType = depPos.type;
if (depPos.type == 5) {
posPoint = model.cpv;
} else if (depPos.type == 6) {
posPoint = {
x: model.cpv.x,
y: essBounds.y - dmEssBounds.height / 2
};
} else if (depPos.type == 7) {
posPoint = {
x: essBounds.x1 + dmEssBounds.width / 2,
y: model.cpv.y
};
} else if (depPos.type == 8) {
posPoint = {
x: model.cpv.x,
y: essBounds.y1 + dmEssBounds.height / 2
};
} else if (depPos.type == 9) {
posPoint = {
x: essBounds.x - dmEssBounds.width / 2,
y: model.cpv.y
};
}
isCreateRealModel = true;
}
}
}
if (isCreateRealModel) {
let dataJson = {
modelCode: "100200"
};
let controlDefine = DDeiUtil.getControlDefine(dataJson);
for (let i2 in controlDefine == null ? void 0 : controlDefine.define) {
dataJson[i2] = cloneDeep(controlDefine.define[i2]);
}
dataJson["id"] = "lsm_" + stage2.idIdx++;
dataJson["width"] = 80;
dataJson["height"] = 28;
dataJson["font"] = { size: 12 };
dataJson["textStyle"] = { paddingWeight: 0 };
if (isLineLM) {
dataJson["fill"] = { type: 1, color: "white" };
}
for (let i2 in dataJson) {
let value = dataJson[i2];
if (typeof value == "string") {
dataJson[i2] = editor.i18n(value);
}
}
(_f = dataJson.composes) == null ? void 0 : _f.forEach((compose) => {
for (let i2 in compose) {
let value = compose[i2];
if (typeof value == "string") {
compose[i2] = editor.i18n(value);
}
}
});
realModel = ddInstance.controlModelClasses["DDeiPolygon"].initByJSON(
dataJson,
{ currentStage: stage2, currentDdInstance: ddInstance, currentContainer: model.pModel }
);
let move1Matrix = new Matrix3(
1,
0,
posPoint.x,
0,
1,
posPoint.y,
0,
0,
1
);
realModel.transVectors(move1Matrix);
model.layer.addModel(realModel, false);
realModel.initRender();
let lineLink = new DDeiModelLink({
depModel: model,
type: posType,
dm: realModel,
dx: 0,
dy: 0
});
realModel.depModel = model;
model.linkModels.set(realModel.id, lineLink);
}
if (realModel) {
model = realModel;
editor.quickEditorModel = model;
}
model = DDeiAbstractShape.findBottomComponseByArea(model, ex, ey);
let fillArea = model.textArea;
if ((fillArea == null ? void 0 : fillArea.length) > 0) {
editor.quickEditorModel = model;
let canvasPos = DDeiUtil.getDomAbsPosition(ddInstance.render.canvas);
let inputEle = DDeiUtil.getEditorText();
let rotate2 = model.rotate;
let stageRatio22 = ddInstance.stage.getStageRatio();
let pos = new Vector3(model.pvs[0].x, model.pvs[0].y, 1);
if (rotate2 != 0) {
let pvc = new Vector3(model.cpv.x, model.cpv.y, 1);
let angle2 = (rotate2 * DDeiConfig.ROTATE_UNIT).toFixed(4);
let move1Matrix = new Matrix3(
1,
0,
-pvc.x,
0,
1,
-pvc.y,
0,
0,
1
);
let rotateMatrix = new Matrix3(
Math.cos(angle2),
Math.sin(angle2),
0,
-Math.sin(angle2),
Math.cos(angle2),
0,
0,
0,
1
);
let move2Matrix = new Matrix3(
1,
0,
pvc.x,
0,
1,
pvc.y,
0,
0,
1
);
let m12 = new Matrix3().premultiply(move1Matrix).premultiply(rotateMatrix).premultiply(move2Matrix);
pos.applyMatrix3(m12);
}
inputEle.value = model.text ? model.text : "";
inputEle.style.fontSize = model.render.getCachedValue("font.size") * stageRatio22 + "px";
inputEle.style.color = DDeiUtil.getColor(model.render.getCachedValue("font.color"));
inputEle.style.width = fillArea.width * stageRatio22 + "px";
inputEle.style.height = fillArea.height * stageRatio22 + "px";
inputEle.style.left = canvasPos.left + pos.x + ddInstance.stage.wpv.x + 1 + "px";
inputEle.style.top = canvasPos.top + pos.y + ddInstance.stage.wpv.y + 10 + "px";
inputEle.style.display = "block";
let textAreaRect = DDeiAbstractShape.pvsToOutRect(model.textArea);
inputEle.style.width = textAreaRect.width + "px";
inputEle.style.height = textAreaRect.height + "px";
ddInstance.stage.render.editorShadowControl = DDeiUtil.getShadowControl(model);
model.layer.opPoints = [];
if ((_g = model.layer.opLine) == null ? void 0 : _g.render) {
model.layer.opLine.render.enableRefreshShape();
}
delete model.layer.opLine;
ddInstance.stage.render.editorShadowControl.render.isEditoring = true;
inputEle.focus();
inputEle.selectionStart = 0;
inputEle.selectionEnd = inputEle.value.length;
editor.changeState(DDeiEditorState.QUICK_EDITING);
delete ddInstance.stage.brushData;
delete ddInstance.stage.brushDataText;
ddInstance.stage.render.operateState = DDeiEnumOperateState.QUICK_EDITING;
editor.bus.push(DDeiEnumBusCommandType.StageChangeSelectModels);
editor.bus.push(DDeiEnumBusCommandType.TextEditorChangeSelectPos);
editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
editor.bus.executeAll();
return true;
}
}
}
}
}
}
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionStartQuickEdit, "defaultIns", new _DDeiKeyActionStartQuickEdit());
let DDeiKeyActionStartQuickEdit = _DDeiKeyActionStartQuickEdit;
const _DDeiKeyActionTableNextCol = class _DDeiKeyActionTableNextCol extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-table-next-col");
__publicField3(this, "defaultOptions", {
"keys": [
//表格内部tab,往下一列
{ keys: "9", modelType: "DDeiTable", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionTableNextCol.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionTableNextCol.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionTableNextCol.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionTableNextCol(newOptions);
return panels;
}
}
return _DDeiKeyActionTableNextCol;
}
static modify(fn) {
return _DDeiKeyActionTableNextCol.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
var _a3, _b2, _c2;
if (ddInstance && ddInstance.stage) {
let models = Array.from((_a3 = ddInstance.stage.selectedModels) == null ? void 0 : _a3.values());
if ((models == null ? void 0 : models.length) == 1 && models[0].baseModelType == "DDeiTable" && models[0].curRow != -1 && models[0].curCol != -1) {
if (models[0].curCol < models[0].cols.length - 1) {
if (models[0].tempDragCell) {
models[0].tempDragCell.setState(DDeiEnumControlState.DEFAULT);
}
models[0].curCol++;
models[0].tempDragCell = models[0].rows[models[0].curRow][models[0].curCol];
models[0].tempDragCell.setState(DDeiEnumControlState.SELECTED);
}
}
(_b2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _b2.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
(_c2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _c2.executeAll();
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionTableNextCol, "defaultIns", new _DDeiKeyActionTableNextCol());
let DDeiKeyActionTableNextCol = _DDeiKeyActionTableNextCol;
const _DDeiKeyActionTableNextRow = class _DDeiKeyActionTableNextRow extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-table-next-row");
__publicField3(this, "defaultOptions", {
"keys": [
//表格内部回车,往下一行
{ keys: "13", modelType: "DDeiTable", editorState: DDeiEditorState.DESIGNING }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionTableNextRow.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionTableNextRow.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionTableNextRow.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionTableNextRow(newOptions);
return panels;
}
}
return _DDeiKeyActionTableNextRow;
}
static modify(fn) {
return _DDeiKeyActionTableNextRow.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance) {
var _a3, _b2, _c2;
if (ddInstance && ddInstance.stage) {
let models = Array.from((_a3 = ddInstance.stage.selectedModels) == null ? void 0 : _a3.values());
if ((models == null ? void 0 : models.length) == 1 && models[0].baseModelType == "DDeiTable" && models[0].curRow != -1 && models[0].curCol != -1) {
if (models[0].curRow < models[0].rows.length - 1) {
if (models[0].tempDragCell) {
models[0].tempDragCell.setState(DDeiEnumControlState.DEFAULT);
}
models[0].curRow++;
models[0].tempDragCell = models[0].rows[models[0].curRow][models[0].curCol];
models[0].tempDragCell.setState(DDeiEnumControlState.SELECTED);
}
}
(_b2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _b2.push(DDeiEnumBusCommandType.RefreshShape, null, evt);
(_c2 = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _c2.executeAll();
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionTableNextRow, "defaultIns", new _DDeiKeyActionTableNextRow());
let DDeiKeyActionTableNextRow = _DDeiKeyActionTableNextRow;
const _DDeiCoreHotkeys = class _DDeiCoreHotkeys extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [
DDeiKeyActionAllSelect,
DDeiKeyActionBrushData,
DDeiKeyActionCancelCompose,
DDeiKeyActionCancelControlCreate,
DDeiKeyActionCancelCurrentAction,
DDeiKeyActionCancelQuickEdit,
DDeiKeyActionCancelSelect,
DDeiKeyActionClearBrushData,
DDeiKeyActionCloseDialog,
DDeiKeyActionCompose,
DDeiKeyActionCopy,
DDeiKeyActionCopyImage,
DDeiKeyActionCut,
DDeiKeyActionEnterQuickEdit,
DDeiKeyActionMoveModels,
DDeiKeyActionReRevoke,
DDeiKeyActionRevoke,
DDeiKeyActionSaveFile,
DDeiKeyActionStartQuickEdit,
DDeiKeyActionTableNextCol,
DDeiKeyActionTableNextRow,
DDeiKeyActionPaste,
DDeiKeyActionPushModels,
DDeiKeyActionNewRowQuickEdit,
DDeiKeyActionRemoveModels
]);
}
getHotKeys(editor) {
var _a3;
let hotkeys = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getHotKeys(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getHotKeys(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
hotkeys = hotkeys.concat(ls);
}
});
return hotkeys;
}
static configuration(options) {
var _a3;
let hotkeys = new _DDeiCoreHotkeys(options);
for (let i2 = 0; i2 < ((_a3 = hotkeys.plugins) == null ? void 0 : _a3.length); i2++) {
hotkeys.plugins[i2] = hotkeys.plugins[i2].configuration(options, true);
}
return hotkeys;
}
static modify(fn) {
return _DDeiCoreHotkeys.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreHotkeys, "defaultIns", new _DDeiCoreHotkeys(null));
let DDeiCoreHotkeys = _DDeiCoreHotkeys;
const composeContainer = {
"id": "100202",
"name": "组合容器",
"code": "comp",
"desc": "用于组合关系的容器",
"type": "DDeiPolygonContainer",
"from": "100201",
"define": {
ext: {
groups: []
}
}
};
const __vite_glob_0_0$5 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: composeContainer
}, Symbol.toStringTag, { value: "Module" }));
const container = {
"id": "100201",
"name": "矩形容器",
"code": "rectange_container",
"desc": "矩形形状的容器,能够包含其他容器",
"type": "DDeiPolygonContainer",
"from": "100008",
"define": {
poly: 2
},
/**
* 定义组件属性
* 样式属性会影响图形的显示,修改样式属性也会刷新图形
* 数据属性一般用于业务计算,数据属性一般不会刷新图形,除非数据属性和样式属性产生联动关系
* 事件属性一般用来作为扩展用
* 属性采用三层结构:组---子分组---属性,在基础json中先定义而后使用(可以复写)
* 特殊属性:
* code属性编码在统一个组中,code唯一
* mapping建立与模型中属性的映射关系,为null时为默认,采用code指向的属性映射;mapping为[]时交由控件编辑器处理值映射
* hiddenTitle隐藏标题,为true时不会显示属性标题,默认false不隐藏标题
* display控件显示模式,有row(横向排列)和column(纵向排列)两个选项,默认row
*/
attrs: [
{
"code": "layout",
"name": "布局",
"desc": "文本的字体名称",
"controlType": "radio",
"dataSource": [
{ "text": "自由布局", "value": "free" },
{ "text": "完全填充", "value": "full" },
{ "text": "九宫格", "value": "nine" },
{ "text": "表格", "value": "table" },
{ "text": "圆心", "value": "cc" }
],
"defaultValue": null,
"hiddenTitle": true,
"display": "column",
"dataType": "string"
},
{
"code": "width",
"name": "ddei.property.width",
"desc": "控件的宽度",
"controlType": "text",
"dataSource": null,
"dataType": "integer",
"defaultValue": "150"
},
{
"code": "height",
"name": "ddei.property.height",
"desc": "控件的高度",
"controlType": "text",
"dataSource": null,
"dataType": "integer",
"defaultValue": "150"
},
{
"id": "100500003",
"code": "border.type",
"name": "ddei.property.borderType",
"desc": "用来快速选择边框的类型,以便于套用相关的样式",
"controlType": "border-type",
"dataSource": [{ "text": "ddei.property.ds.none", "value": 0 }, { "text": "ddei.property.ds.line", "value": 1 }],
"dataType": "string",
"defaultValue": "1",
"hiddenTitle": true,
"display": "column"
},
{
"id": "100500004",
"code": "border.color",
"name": "ddei.property.color",
"desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": "black"
},
{
"code": "borderOpacity",
"name": "ddei.property.opacity",
"desc": "图形的边框的透明度,0完全透明~1完全不透明",
"controlType": "range",
"min": 0,
"max": 1,
"step": 0.01,
"mapping": ["border.opacity"],
"dataType": "float",
"defaultValue": 1,
"display": "column"
},
{
"code": "borderWidth",
"name": "ddei.property.width",
"desc": "图形的边框的粗细,0为无边框",
"controlType": "range",
"min": 0,
"max": 10,
"step": 0.1,
"mapping": ["border.width"],
"dataType": "integer",
"defaultValue": 1
},
{
"code": "borderDash",
"name": "ddei.property.dash",
"desc": "图形的边框的是否为虚线样式,虚线由长短不一的线段构成",
"controlType": "border-dash",
"dataSource": [
{ "text": "1", "value": [] },
{ "text": "2", "value": [10, 5] },
{ "text": "3", "value": [5, 5] },
{ "text": "4", "value": [10, 4, 2, 4] },
{ "text": "5", "value": [10, 4, 2, 4, 2, 4] },
{ "text": "6", "value": [10, 4, 10, 4, 2, 4] },
{ "text": "7", "value": [20, 5, 10, 5] },
{ "text": "8", "value": [20, 5, 10, 5, 10, 5] },
{ "text": "9", "value": [3, 3] },
{ "text": "10", "value": [2, 2] },
{ "text": "11", "value": [3, 2, 2, 2] },
{ "text": "13", "value": [20, 10] }
],
"mapping": ["border.dash"],
"dataType": "integer",
"defaultValue": [],
"isArray": true
},
{
"code": "borderRound",
"name": "ddei.property.round",
"desc": "图形的边框的是否为为圆角的弧度",
"controlType": "range",
"mapping": ["border.round"],
"min": 0,
"max": 30,
"step": 1,
"defaultValue": 0,
"dataType": "integer"
},
{
"code": "fill.type",
"name": "ddei.property.fillType",
"desc": "图形填充的类型快速设置",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.none", "value": 0 }, { "text": "ddei.property.ds.color", "value": 1 }, { "text": "ddei.property.ds.image", "value": 2 }],
"defaultValue": 1,
"type": 1,
"orderNo": 2,
"cascadeDisplay": { 1: { show: ["fill.color", "fill.opacity"], hidden: ["fill.image"] }, 2: { show: ["fill.image", "fill.opacity"], hidden: ["fill.color"] }, default: { show: ["fill.color", "fill.opacity"], hidden: ["fill.image"] }, empty: { hidden: ["fill.color", "fill.image", "fill.opacity"] } },
"hiddenTitle": true,
"display": "column"
},
{
"code": "fill.color",
"name": "ddei.property.color",
"desc": "图形的填充颜色",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": "white"
},
{
"code": "fill.image",
"name": "ddei.property.image",
"desc": "图形的填充图片",
"controlType": "text",
"dataType": "string",
"defaultValue": "",
"type": 1
},
{
"code": "fill.opacity",
"name": "ddei.property.opacity",
"desc": "图形的填充的透明度,0完全透明~1完全不透明",
"controlType": "range",
"min": 0,
"max": 1,
"step": 0.01,
"defaultValue": 1,
"dataType": "float",
"display": "column"
},
{
"code": "font.family",
"name": "ddei.property.font",
"desc": "文本的字体名称",
"controlType": "combox",
"dataType": "string",
"dataSource": {
"type": "config",
"data": "fonts",
"text": "ch",
"value": "en",
"bold": "isSystemDefault",
"fontFamily": "en"
},
"itemStyle": { width: 80, height: 25, col: 2, row: 0, imgWidth: 20, imgHeight: 20 },
"canSearch": true,
"defaultValue": "Microsoft YaHei"
},
{
"code": "font.size",
"name": "ddei.property.size",
"desc": "文本的字体大小",
"max": 50,
"min": 5,
"step": 0.5,
"controlType": "font-size",
"dataType": "float",
"defaultValue": 14
},
{
"code": "font.color",
"name": "ddei.property.color",
"desc": "文本的颜色",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": "#252525"
},
{
"code": "fontAlign",
"name": "ddei.property.align",
"desc": "文本的对齐,采用九宫格式设置",
"controlType": "align-type",
"mapping": [],
"dataType": "string"
},
{
"code": "textStyle.feed",
"name": "ddei.property.feed",
"desc": "自动换行",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.scale",
"name": "ddei.property.outSize",
"desc": "文本的自动缩小字体填充",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.hollow",
"name": "ddei.property.hollow",
"desc": "文本的镂空显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.bold",
"name": "ddei.property.bold",
"desc": "文本的加粗显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.italic",
"name": "ddei.property.italic",
"desc": "文本的斜体显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.underline",
"name": "ddei.property.underline",
"desc": "文本的下划线显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.deleteline",
"name": "ddei.property.deleteline",
"desc": "文本的删除线显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.topline",
"name": "ddei.property.topline",
"desc": "文本的删除线显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.bgcolor",
"name": "ddei.property.textbg",
"desc": "文本的背景颜色",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": ""
},
{
"code": "textStyle.subtype",
"name": "ddei.property.subtype",
"desc": "文本的标注类型",
"controlType": "radio",
"dataType": "integer",
"dataSource": [{ "text": "ddei.property.ds.subType", "value": 0 }, { "text": "ddei.property.ds.subType1", "value": 1 }, { "text": "ddei.property.ds.subType2", "value": 2 }, { "text": "ddei.property.ds.subType3", "value": 3 }],
"defaultValue": 0
},
{
"code": "textStyle.align",
"name": "ddei.property.textAlign",
"desc": "文本的水平对齐",
"controlType": "text",
"dataType": "integer",
"defaultValue": 2
},
{
"code": "textStyle.valign",
"name": "ddei.property.textValign",
"desc": "文本的垂直对齐",
"controlType": "text",
"dataType": "integer",
"defaultValue": 2
},
{
"code": "textStyle.hspace",
"name": "ddei.property.hspace",
"desc": "文本之间的水平间距",
"controlType": "range",
"min": 0,
"max": 10,
"step": 0.1,
"dataType": "float",
"defaultValue": 0.5
},
{
"code": "textStyle.vspace",
"name": "ddei.property.vspace",
"desc": "文本之间的垂直间距",
"controlType": "range",
"min": 0,
"max": 10,
"step": 0.1,
"dataType": "float",
"defaultValue": 0.5
},
{
"code": "borderCreatingOpacity",
"name": "ddei.property.opacity",
"desc": "图形的边框的透明度,0完全透明~1完全不透明",
"controlType": "text",
"mapping": ["border.creating.top.opacity", "border.creating.right.opacity", "border.creating.bottom.opacity", "border.creating.left.opacity"],
"dataType": "float",
"defaultValue": 0.5,
"display": "column"
},
{
"code": "fillCreatingOpacity",
"name": "ddei.property.opacity",
"desc": "图形的填充的透明度,0完全透明~1完全不透明",
"controlType": "text",
"mapping": ["fill.creating.opacity"],
"dataType": "float",
"defaultValue": 0.5,
"display": "column"
},
{
"code": "imageCreatingOpacity",
"name": "ddei.property.opacity",
"desc": "图形的填充图片的透明度,0完全透明~1完全不透明",
"controlType": "text",
"mapping": ["fill.creating.opacity"],
"dataType": "float",
"defaultValue": 0.5,
"display": "column"
},
{
"code": "id",
"name": "ddei.property.id",
"desc": "控件在画布的全局唯一ID",
"controlType": "text",
"dataType": "string",
"readonly": true
},
{
"code": "code",
"name": "ddei.property.code",
"desc": "控件在业务上的唯一编码,缺省和控件ID一致",
"controlType": "text",
"dataType": "string",
"defaultValue": "ddei.property.code001"
},
{
"code": "text",
"name": "ddei.property.text",
"desc": "控件的主体显示文本",
"controlType": "textarea",
"defaultValue": "",
"dataType": "string",
"type": [1, 2],
//类别,1图形,2业务,3事件
"readonly": true
},
{
"code": "fmt.type",
"name": "ddei.format",
"desc": "文本的显示格式",
"controlType": "radio",
"dataType": "integer",
"dataSource": [{ "text": "ddei.property.ds.text", "value": 0 }, { "text": "ddei.property.ds.decimal", "value": 1 }, { "text": "ddei.property.ds.money", "value": 2 }, { "text": "ddei.property.ds.time", "value": 3 }],
"defaultValue": 0,
"type": [1, 2],
"cascadeDisplay": { 1: { show: ["fmt.nscale", "fmt.tmark"], hidden: ["fmt.mmark", "fmt.munit", "fmt.dtype", "fmt.format", "fmt.mrmb"] }, 2: { show: ["fmt.nscale", "fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.mrmb"], hidden: ["fmt.dtype", "fmt.format"] }, 3: { show: ["fmt.dtype", "fmt.format"], hidden: ["fmt.mrmb", "fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.nscale"] }, default: { hidden: ["fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.nscale", "fmt.dtype", "fmt.format", "fmt.mrmb"] }, empty: { hidden: ["fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.nscale", "fmt.dtype", "fmt.format", "fmt.mrmb"] } }
},
{
"code": "fmt.nscale",
"name": "ddei.property.nscale",
"desc": "格式化小数位数",
"controlType": "range",
"min": 0,
"max": 5,
"dataType": "integer",
"defaultValue": 0,
"type": [1, 2]
},
{
"code": "fmt.tmark",
"name": "ddei.property.tmark",
"desc": "显示逗号千分符",
"controlType": "switch-checkbox",
"dataType": "integer",
"defaultValue": 0,
"hiddenTitle": true,
"display": "column",
"type": [1, 2]
},
{
"code": "fmt.mmark",
"name": "ddei.property.mmark",
"desc": "显示货币符号",
"controlType": "combox",
"dataSource": [{ "text": "ddei.property.ds.none", "value": "" }, { "text": "ddei.property.ds.money1", "value": "¥" }, { "text": "ddei.property.ds.money2", "value": "$" }, { "text": "ddei.property.ds.money3", "value": "€" }, { "text": "ddei.property.ds.money4", "value": "£" }, { "text": "ddei.property.ds.money5", "value": "¥" }, { "text": "ddei.property.ds.money6", "value": "₽" }, { "text": "ddei.property.ds.money7", "value": "€" }],
"defaultValue": "",
"dataType": "string",
"type": [1, 2],
"itemStyle": { width: 80, height: 25, col: 2, row: 0, imgWidth: 20, imgHeight: 20 }
},
{
"code": "fmt.munit",
"name": "ddei.property.moneyUnit",
"desc": "显示在后方的货币单位",
"controlType": "text",
"defaultValue": "",
"dataType": "string",
"type": [1, 2]
},
{
"code": "fmt.mrmb",
"name": "ddei.property.moneyUpCase",
"desc": "显示为人民币大写",
"controlType": "switch-checkbox",
"dataType": "integer",
"defaultValue": 0,
"hiddenTitle": true,
"display": "column",
"type": [1, 2]
},
{
"code": "fmt.dtype",
"name": "ddei.property.dateType",
"desc": "日期和时间的格式化类型",
"controlType": "radio",
"dataSource": [{ "text": "2023-01-01", "value": 1 }, { "text": "23:59:59", "value": 2 }, { "text": "2023-01-01 23:59:59", "value": 3 }, { "text": "ddei.property.ds.custom", "value": 99 }],
"dataType": "integer",
"defaultValue": 1,
"hiddenTitle": true,
"display": "column",
"cascadeDisplay": { 1: { show: [], hidden: ["fmt.format"] }, 2: { show: [], hidden: ["fmt.format"] }, 3: { show: [], hidden: ["fmt.format"] }, 99: { hidden: [], show: ["fmt.format"] }, default: { hidden: ["fmt.format"] }, empty: { hidden: ["fmt.format"] } }
},
{
"code": "fmt.format",
"name": "ddei.property.format",
"desc": "自定义格式化字符串",
"controlType": "text",
"dataType": "string"
}
],
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.layout",
attrs: ["layout"]
},
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
};
const __vite_glob_0_1$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: container
}, Symbol.toStringTag, { value: "Module" }));
const line = {
"id": "100401",
"name": "ddei.control.line",
"code": "line",
"desc": "直线、折线、曲线三种连接线",
"type": "DDeiLine",
/**
* 定义组件属性
* 样式属性会影响图形的显示,修改样式属性也会刷新图形
* 数据属性一般用于业务计算,数据属性一般不会刷新图形,除非数据属性和样式属性产生联动关系
* 事件属性一般用来作为扩展用
* 属性采用三层结构:组---子分组---属性,在基础json中先定义而后使用(可以复写)
* 特殊属性:
* code属性编码在统一个组中,code唯一
* mapping建立与模型中属性的映射关系,为null时为默认,采用code指向的属性映射;mapping为[]时交由控件编辑器处理值映射
* hiddenTitle隐藏标题,为true时不会显示属性标题,默认false不隐藏标题
* display控件显示模式,有row(横向排列)和column(纵向排列)两个选项,默认row
*/
attrs: [
{
"code": "type",
"name": "ddei.lineType",
"desc": "用来快速连线类型,以便于套用相关的样式",
"controlType": "radio",
"dataSource": [{ "text": "ddei.property.ds.lineType1", "value": 1 }, { "text": "ddei.property.ds.lineType2", "value": 2 }, { "text": "ddei.property.ds.lineType3", "value": 3 }],
"dataType": "integer",
"defaultValue": 1,
"cascadeDisplay": { 2: { show: ["round"], hidden: [] }, default: { show: [], hidden: ["round"] }, notempty: { hidden: ["round"] } },
"mapping": [],
"type": 1
},
{
"code": "weight",
"name": "ddei.property.weight",
"desc": "控件的宽度",
"controlType": "range",
"min": 0.1,
"max": 10,
"step": 0.1,
"dataType": "float",
"defaultValue": 1
},
{
"code": "color",
"name": "ddei.property.color",
"desc": "线段的边框显示颜色",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": ""
},
{
"code": "fill.weight",
"name": "ddei.fill",
"desc": "填充的大小",
"controlType": "range",
"min": 0,
"max": 30,
"step": 1,
"defaultValue": 0,
"dataType": "integer"
},
{
"code": "fill.color",
"name": "ddei.property.color",
"desc": "线段的边框显示颜色",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": "black"
},
{
"code": "dash",
"name": "ddei.property.dash",
"desc": "图形的边框的是否为虚线样式,虚线由长短不一的线段构成",
"controlType": "border-dash",
"dataSource": [
{ "text": "1", "value": [] },
{ "text": "2", "value": [10, 5] },
{ "text": "3", "value": [5, 5] },
{ "text": "4", "value": [10, 4, 2, 4] },
{ "text": "5", "value": [10, 4, 2, 4, 2, 4] },
{ "text": "6", "value": [10, 4, 10, 4, 2, 4] },
{ "text": "7", "value": [20, 5, 10, 5] },
{ "text": "8", "value": [20, 5, 10, 5, 10, 5] },
{ "text": "9", "value": [3, 3] },
{ "text": "10", "value": [2, 2] },
{ "text": "11", "value": [3, 2, 2, 2] },
{ "text": "13", "value": [20, 10] }
],
"dataType": "integer",
"defaultValue": [],
"isArray": true
},
{
"code": "opacity",
"name": "ddei.property.opacity",
"desc": "图形的边框的透明度,0完全透明~1完全不透明",
"controlType": "range",
"min": 0,
"max": 1,
"step": 0.01,
"dataType": "float",
"defaultValue": 1,
"display": "column"
},
{
"code": "sp.type",
"name": "ddei.property.startPointType",
"desc": "起点的样式样式",
"controlType": "combox",
"dataSource": [
{ "text": "ddei.property.ds.none", "value": -1 },
{ "text": "ddei.property.ds.pointType1", "value": 1 },
{ "text": "ddei.property.ds.pointType2", "value": 2 },
{ "text": "ddei.property.ds.pointType21", "value": 21 },
{ "text": "ddei.property.ds.pointType3", "value": 3 },
{ "text": "ddei.property.ds.pointType31", "value": 31 },
{ "text": "ddei.property.ds.pointType4", "value": 4 },
{ "text": "ddei.property.ds.pointType41", "value": 41 },
{ "text": "ddei.property.ds.pointType5", "value": 5 },
{ "text": "ddei.property.ds.pointType51", "value": 51 },
{ "text": "ddei.property.ds.pointType6", "value": 6 },
{ "text": "ddei.property.ds.pointType61", "value": 61 }
],
"itemStyle": { width: 80, height: 25, col: 2, row: 6 },
"dataType": "integer",
"cascadeDisplay": { "-1": { hidden: ["startWeidht"] }, empty: { hidden: ["startWeidht"] }, notempty: { show: ["startWeidht"] } },
"defaultValue": -1
},
{
"code": "sp.weight",
"name": "ddei.property.weight",
"desc": "起点的箭头的宽度",
"controlType": "range",
"min": 1,
"max": 30,
"step": 1,
"defaultValue": 6,
"dataType": "integer"
},
{
"code": "ep.type",
"name": "ddei.property.endPointType",
"desc": "终点的样式样式",
"controlType": "combox",
"dataSource": [
{ "text": "ddei.property.ds.none", "value": -1 },
{ "text": "ddei.property.ds.pointType1", "value": 1 },
{ "text": "ddei.property.ds.pointType2", "value": 2 },
{ "text": "ddei.property.ds.pointType21", "value": 21 },
{ "text": "ddei.property.ds.pointType3", "value": 3 },
{ "text": "ddei.property.ds.pointType31", "value": 31 },
{ "text": "ddei.property.ds.pointType4", "value": 4 },
{ "text": "ddei.property.ds.pointType41", "value": 41 },
{ "text": "ddei.property.ds.pointType5", "value": 5 },
{ "text": "ddei.property.ds.pointType51", "value": 51 },
{ "text": "ddei.property.ds.pointType6", "value": 6 },
{ "text": "ddei.property.ds.pointType61", "value": 61 }
],
"itemStyle": { width: 80, height: 25, col: 2, row: 6 },
"dataType": "integer",
"cascadeDisplay": { "-1": { hidden: ["endWeidht"] }, empty: { hidden: ["endWeidht"] }, notempty: { show: ["endWeidht"] } },
"defaultValue": 5
},
{
"code": "ep.weight",
"name": "ddei.property.weight",
"desc": "终点的箭头的宽度",
"controlType": "range",
"min": 1,
"max": 30,
"step": 1,
"defaultValue": 6,
"dataType": "integer"
},
{
"code": "round",
"name": "ddei.property.round",
"desc": "图形的边框的是否为为圆角的弧度",
"controlType": "range",
"min": 0,
"max": 30,
"step": 1,
"defaultValue": 0,
"dataType": "integer"
},
{
"code": "jumpline",
"name": "ddei.jumpline",
"desc": "用来控制当前线段的跳线类型",
"controlType": "radio",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": 1 }, { "text": "ddei.property.ds.no", "value": 2 }, { "text": "ddei.property.ds.global", "value": 0 }],
"dataType": "integer",
"defaultValue": 0,
"type": 1
},
{
"code": "id",
"name": "ddei.property.id",
"desc": "控件在画布的全局唯一ID",
"controlType": "text",
"dataType": "string",
"readonly": true
},
{
"code": "code",
"name": "ddei.property.code",
"desc": "控件在业务上的唯一编码,缺省和控件ID一致",
"controlType": "text",
"dataType": "string",
"defaultValue": "ddei.property.code001"
}
],
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: [
"type",
"weight",
"color",
"fill.weight",
"fill.color",
"dash",
"opacity",
"sp.type",
"sp.weight",
"ep.type",
"ep.weight",
"round",
"jumpline"
]
}
]
},
{
name: "ddei.propertyName",
icon: "icon-edit-properies",
subGroups: [
{
name: "ddei.propertyName",
attrs: ["code"]
}
]
}
],
icon: ``,
filters: {
LINE_OBI_FILTER: (model, params) => {
return false;
}
}
};
const __vite_glob_0_2$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: line
}, Symbol.toStringTag, { value: "Module" }));
const polygonContainer = {
"id": "100203",
"name": "多边形容器",
"code": "polygon_container",
"desc": "基于点采样的的容器",
"type": "DDeiPolygonContainer",
"from": "100201",
"define": {
width: 300,
height: 200,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: false,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0,op2close = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
op2close = 1
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,r:sample.r,select:1,clip:1,oppoint:2,op2close:op2close,align:1,stroke:1,fill:1});
}`
]
}
}
};
const __vite_glob_0_3$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: polygonContainer
}, Symbol.toStringTag, { value: "Module" }));
const polygon = {
"id": "100500",
"name": "ddei.control.polygon",
"code": "polygon",
"desc": "多个3-N边构成的多边形",
"type": "DDeiPolygon",
/**
* 定义组件属性
* 样式属性会影响图形的显示,修改样式属性也会刷新图形
* 数据属性一般用于业务计算,数据属性一般不会刷新图形,除非数据属性和样式属性产生联动关系
* 事件属性一般用来作为扩展用
* 属性采用三层结构:组---子分组---属性,在基础json中先定义而后使用(可以复写)
* 特殊属性:
* code属性编码在统一个组中,code唯一
* mapping建立与模型中属性的映射关系,为null时为默认,采用code指向的属性映射;mapping为[]时交由控件编辑器处理值映射
* hiddenTitle隐藏标题,为true时不会显示属性标题,默认false不隐藏标题
* display控件显示模式,有row(横向排列)和column(纵向排列)两个选项,默认row
*/
attrs: [
{
"code": "width",
"name": "ddei.property.width",
"desc": "控件的宽度",
"controlType": "text",
"dataSource": null,
"dataType": "integer",
"defaultValue": "150"
},
{
"code": "height",
"name": "ddei.property.height",
"desc": "控件的高度",
"controlType": "text",
"dataSource": null,
"dataType": "integer",
"defaultValue": "150"
},
{
"code": "border.type",
"name": "ddei.property.borderType",
"desc": "用来快速选择边框的类型,以便于套用相关的样式",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.none", "value": 0 }, { "text": "ddei.property.ds.line", "value": 1 }],
"defaultValue": 1,
"hiddenTitle": true,
"display": "column",
"cascadeDisplay": { 1: { show: ["border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"], hidden: [] }, default: { show: ["border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"], hidden: [] }, empty: { hidden: ["border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"] } }
},
{
"code": "border.color",
"name": "ddei.property.color",
"desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": ""
},
{
"code": "borderOpacity",
"name": "ddei.property.opacity",
"desc": "图形的边框的透明度,0完全透明~1完全不透明",
"controlType": "range",
"min": 0,
"max": 1,
"step": 0.01,
"mapping": ["border.opacity"],
"dataType": "float",
"defaultValue": 1,
"display": "column"
},
{
"code": "borderWidth",
"name": "ddei.property.width",
"desc": "图形的边框的粗细,0为无边框",
"controlType": "range",
"min": 0,
"max": 10,
"step": 0.1,
"mapping": ["border.width"],
"dataType": "integer",
"defaultValue": 1
},
{
"code": "borderDash",
"name": "ddei.property.dash",
"desc": "图形的边框的是否为虚线样式,虚线由长短不一的线段构成",
"controlType": "border-dash",
"dataSource": [
{ "text": "1", "value": [] },
{ "text": "2", "value": [10, 5] },
{ "text": "3", "value": [5, 5] },
{ "text": "4", "value": [10, 4, 2, 4] },
{ "text": "5", "value": [10, 4, 2, 4, 2, 4] },
{ "text": "6", "value": [10, 4, 10, 4, 2, 4] },
{ "text": "7", "value": [20, 5, 10, 5] },
{ "text": "8", "value": [20, 5, 10, 5, 10, 5] },
{ "text": "9", "value": [3, 3] },
{ "text": "10", "value": [2, 2] },
{ "text": "11", "value": [3, 2, 2, 2] },
{ "text": "13", "value": [20, 10] }
],
"mapping": ["border.dash"],
"dataType": "integer",
"defaultValue": [],
"isArray": true
},
{
"code": "borderRound",
"name": "ddei.property.round",
"desc": "图形的边框的是否为为圆角的弧度",
"controlType": "range",
"mapping": ["border.round"],
"min": 0,
"max": 30,
"step": 1,
"defaultValue": 0,
"dataType": "integer"
},
{
"code": "fill.type",
"name": "ddei.property.fillType",
"desc": "图形填充的类型快速设置",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.none", "value": 0 }, { "text": "ddei.property.ds.color", "value": 1 }, { "text": "ddei.property.ds.image", "value": 2 }],
"defaultValue": 1,
"type": 1,
"orderNo": 2,
"cascadeDisplay": { 1: { show: ["fill.color", "fill.opacity"], hidden: ["fill.image"] }, 2: { show: ["fill.image", "fill.opacity"], hidden: ["fill.color"] }, default: { show: ["fill.color", "fill.opacity"], hidden: ["fill.image"] }, empty: { hidden: ["fill.color", "fill.image", "fill.opacity"] } },
"hiddenTitle": true,
"display": "column"
},
{
"code": "fill.color",
"name": "ddei.property.color",
"desc": "图形的填充颜色",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": ""
},
{
"code": "fill.image",
"name": "ddei.property.image",
"desc": "图形的填充图片",
"controlType": "image",
"dataType": "string",
"defaultValue": "",
"type": 1
},
{
"code": "fill.opacity",
"name": "ddei.property.opacity",
"desc": "图形的填充的透明度,0完全透明~1完全不透明",
"controlType": "range",
"min": 0,
"max": 1,
"step": 0.01,
"defaultValue": 1,
"dataType": "float",
"display": "column"
},
{
"code": "font.family",
"name": "ddei.property.font",
"desc": "文本的字体名称",
"controlType": "combox",
"dataType": "string",
"dataSource": {
"type": "config",
"data": "fonts",
"text": "ch",
"value": "en",
"bold": "isSystemDefault",
"fontFamily": "en"
},
"itemStyle": { width: 80, height: 25, col: 2, row: 0, imgWidth: 20, imgHeight: 20 },
"canSearch": true,
"defaultValue": "Microsoft YaHei"
},
{
"code": "font.size",
"name": "ddei.property.size",
"desc": "文本的字体大小",
"max": 50,
"min": 5,
"step": 0.5,
"controlType": "font-size",
"dataType": "float",
"defaultValue": 14
},
{
"code": "font.color",
"name": "ddei.property.color",
"desc": "文本的颜色",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": ""
},
{
"code": "fontAlign",
"name": "ddei.property.align",
"desc": "文本的对齐,采用九宫格式设置",
"controlType": "align-type",
"mapping": [],
"dataType": "string"
},
{
"code": "textStyle.feed",
"name": "ddei.property.feed",
"desc": "自动换行",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "1"
},
{
"code": "textStyle.scale",
"name": "ddei.property.outSize",
"desc": "文本的超出范围后的策略",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.hidden", "value": "0" }, { "text": "ddei.property.ds.ellipsis", "value": "2" }, { "text": "ddei.property.ds.narrow", "value": "1" }, { "text": "ddei.property.ds.ext", "value": "3" }],
"defaultValue": "0",
"cascadeDisplay": { 3: { show: ["textStyle.lockWidth", "textStyle.paddingWeight"], hidden: [] }, default: { hidden: ["textStyle.lockWidth", "textStyle.paddingWeight"] }, empty: { hidden: ["textStyle.lockWidth", "textStyle.paddingWeight"] }, notempty: { hidden: ["textStyle.lockWidth", "textStyle.paddingWeight"] } }
},
{
"code": "textStyle.lockWidth",
"name": "ddei.property.lockWidth",
"desc": "超范围自动扩展的情况下锁定宽度",
"controlType": "switch-checkbox",
"dataType": "integer",
"defaultValue": 0,
"hiddenTitle": true,
"display": "column",
"type": [1, 2]
},
{
"code": "textStyle.paddingWeight",
"name": "ddei.property.paddingWeight",
"desc": "超范围自动扩展的情况下保留的宽度",
"controlType": "text",
"dataType": "integer",
"defaultValue": 0,
"hiddenTitle": true,
"display": "column",
"type": [1, 2]
},
{
"code": "textStyle.hollow",
"name": "ddei.property.hollow",
"desc": "文本的镂空显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.bold",
"name": "ddei.property.bold",
"desc": "文本的加粗显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.italic",
"name": "ddei.property.italic",
"desc": "文本的斜体显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.underline",
"name": "ddei.property.underline",
"desc": "文本的下划线显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.deleteline",
"name": "ddei.property.deleteline",
"desc": "文本的删除线显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.topline",
"name": "ddei.property.topline",
"desc": "文本的删除线显示",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0"
},
{
"code": "textStyle.bgcolor",
"name": "ddei.property.textbg",
"desc": "文本的背景颜色",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": ""
},
{
"code": "textStyle.subtype",
"name": "ddei.property.subtype",
"desc": "文本的标注类型",
"controlType": "radio",
"dataType": "integer",
"dataSource": [{ "text": "ddei.property.ds.subType", "value": 0 }, { "text": "ddei.property.ds.subType1", "value": 1 }, { "text": "ddei.property.ds.subType2", "value": 2 }, { "text": "ddei.property.ds.subType3", "value": 3 }],
"defaultValue": 0
},
{
"code": "textStyle.align",
"name": "ddei.property.textAlign",
"desc": "文本的水平对齐",
"controlType": "text",
"dataType": "integer",
"defaultValue": 2
},
{
"code": "textStyle.valign",
"name": "ddei.property.textValign",
"desc": "文本的垂直对齐",
"controlType": "text",
"dataType": "integer",
"defaultValue": 2
},
{
"code": "textStyle.hspace",
"name": "ddei.property.hspace",
"desc": "文本之间的水平间距",
"controlType": "range",
"min": 0,
"max": 10,
"step": 0.1,
"dataType": "float",
"defaultValue": 0.5
},
{
"code": "textStyle.vspace",
"name": "ddei.property.vspace",
"desc": "文本之间的垂直间距",
"controlType": "range",
"min": 0,
"max": 10,
"step": 0.1,
"dataType": "float",
"defaultValue": 0.5
},
{
"code": "borderCreatingOpacity",
"name": "ddei.property.opacity",
"desc": "图形的边框的透明度,0完全透明~1完全不透明",
"controlType": "text",
"mapping": ["border.creating.top.opacity", "border.creating.right.opacity", "border.creating.bottom.opacity", "border.creating.left.opacity"],
"dataType": "float",
"defaultValue": 0.5,
"display": "column"
},
{
"code": "fillCreatingOpacity",
"name": "ddei.property.opacity",
"desc": "图形的填充的透明度,0完全透明~1完全不透明",
"controlType": "text",
"mapping": ["fill.creating.opacity"],
"dataType": "float",
"defaultValue": 0.5,
"display": "column"
},
{
"code": "imageCreatingOpacity",
"name": "ddei.property.opacity",
"desc": "图形的填充图片的透明度,0完全透明~1完全不透明",
"controlType": "text",
"mapping": ["fill.creating.opacity"],
"dataType": "float",
"defaultValue": 0.5,
"display": "column"
},
{
"code": "id",
"name": "ddei.property.id",
"desc": "控件在画布的全局唯一ID",
"controlType": "text",
"dataType": "string",
"readonly": true
},
{
"code": "code",
"name": "ddei.property.code",
"desc": "控件在业务上的唯一编码,缺省和控件ID一致",
"controlType": "text",
"dataType": "string",
"defaultValue": "ddei.property.code001"
},
{
"code": "text",
"name": "ddei.property.text",
"desc": "控件的主体显示文本",
"controlType": "textarea",
"defaultValue": "",
"dataType": "string",
"type": [1, 2],
//类别,1图形,2业务,3事件
"readonly": true
},
{
"code": "fmt.type",
"name": "ddei.format",
"desc": "文本的显示格式",
"controlType": "radio",
"dataType": "integer",
"dataSource": [{ "text": "ddei.property.ds.text", "value": 0 }, { "text": "ddei.property.ds.decimal", "value": 1 }, { "text": "ddei.property.ds.money", "value": 2 }, { "text": "ddei.property.ds.time", "value": 3 }],
"defaultValue": 0,
"type": [1, 2],
"cascadeDisplay": { 1: { show: ["fmt.nscale", "fmt.tmark"], hidden: ["fmt.mmark", "fmt.munit", "fmt.dtype", "fmt.format", "fmt.mrmb"] }, 2: { show: ["fmt.nscale", "fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.mrmb"], hidden: ["fmt.dtype", "fmt.format"] }, 3: { show: ["fmt.dtype", "fmt.format"], hidden: ["fmt.mrmb", "fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.nscale"] }, default: { hidden: ["fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.nscale", "fmt.dtype", "fmt.format", "fmt.mrmb"] }, empty: { hidden: ["fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.nscale", "fmt.dtype", "fmt.format", "fmt.mrmb"] } }
},
{
"code": "fmt.nscale",
"name": "ddei.property.nscale",
"desc": "格式化小数位数",
"controlType": "range",
"min": 0,
"max": 5,
"dataType": "integer",
"defaultValue": 0,
"type": [1, 2]
},
{
"code": "fmt.tmark",
"name": "ddei.property.tmark",
"desc": "显示逗号千分符",
"controlType": "switch-checkbox",
"dataType": "integer",
"defaultValue": 0,
"hiddenTitle": true,
"display": "column",
"type": [1, 2]
},
{
"code": "fmt.mmark",
"name": "ddei.property.mmark",
"desc": "显示货币符号",
"controlType": "combox",
"dataSource": [{ "text": "ddei.property.ds.none", "value": "" }, { "text": "ddei.property.ds.money1", "value": "¥" }, { "text": "ddei.property.ds.money2", "value": "$" }, { "text": "ddei.property.ds.money3", "value": "€" }, { "text": "ddei.property.ds.money4", "value": "£" }, { "text": "ddei.property.ds.money5", "value": "¥" }, { "text": "ddei.property.ds.money6", "value": "₽" }, { "text": "ddei.property.ds.money7", "value": "€" }],
"defaultValue": "",
"dataType": "string",
"type": [1, 2],
"itemStyle": { width: 80, height: 25, col: 2, row: 0, imgWidth: 20, imgHeight: 20 }
},
{
"code": "fmt.munit",
"name": "ddei.property.moneyUnit",
"desc": "显示在后方的货币单位",
"controlType": "text",
"defaultValue": "",
"dataType": "string",
"type": [1, 2]
},
{
"code": "fmt.mrmb",
"name": "ddei.property.moneyUpCase",
"desc": "显示为人民币大写",
"controlType": "switch-checkbox",
"dataType": "integer",
"defaultValue": 0,
"hiddenTitle": true,
"display": "column",
"type": [1, 2]
},
{
"code": "fmt.dtype",
"name": "ddei.property.dateType",
"desc": "日期和时间的格式化类型",
"controlType": "radio",
"dataSource": [{ "text": "2023-01-01", "value": 1 }, { "text": "23:59:59", "value": 2 }, { "text": "2023-01-01 23:59:59", "value": 3 }, { "text": "ddei.property.ds.custom", "value": 99 }],
"dataType": "integer",
"defaultValue": 1,
"hiddenTitle": true,
"display": "column",
"cascadeDisplay": { 1: { show: [], hidden: ["fmt.format"] }, 2: { show: [], hidden: ["fmt.format"] }, 3: { show: [], hidden: ["fmt.format"] }, 99: { hidden: [], show: ["fmt.format"] }, default: { hidden: ["fmt.format"] }, empty: { hidden: ["fmt.format"] } }
},
{
"code": "fmt.format",
"name": "ddei.property.format",
"desc": "自定义格式化字符串",
"controlType": "text",
"dataType": "string"
}
],
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.border",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "ddei.text",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.lockWidth",
"textStyle.paddingWeight",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
},
{
name: "ddei.data",
icon: "icon-edit-properies",
subGroups: [
{
name: "ddei.basic",
attrs: ["code", "text", "fmt.type", "fmt.nscale", "fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.mrmb", "fmt.dtype", "fmt.format"]
}
]
}
]
};
const __vite_glob_0_4$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: polygon
}, Symbol.toStringTag, { value: "Module" }));
const tableCell = {
"id": "100302",
"name": "单元格",
"code": "table-cell",
"desc": "表格的单元格",
"type": "DDeiTableCell"
};
const styles$1 = {
"name": "样式",
"children": [
{
"id": "100302001",
"code": "width",
"name": "宽度",
"desc": "控件的宽度",
"group": "布局",
"controlType": "text",
"dataSource": null,
"dataType": "integer",
"defaultValue": "160",
"orderNo": 1,
"visiable": false
},
{
"id": "100302002",
"code": "height",
"name": "高度",
"desc": "控件的高度",
"group": "布局",
"controlType": "text",
"dataSource": null,
"dataType": "integer",
"defaultValue": "80",
"orderNo": 2,
"visiable": false
},
{
"id": "100302003",
"code": "border.type",
"name": "边框类型",
"desc": "用来快速选择边框的类型,以便于套用相关的样式",
"group": "边框",
"controlType": "border-type",
"dataSource": [{ "text": "无线条", "value": "0" }, { "text": "实线", "value": "1" }],
"dataType": "string",
"defaultValue": "1",
"hiddenTitle": true,
"display": "column",
"exmapping": ["border.top.disabled", "border.right.disabled", "border.bottom.disabled", "border.left.disabled"],
"orderNo": 1,
"visiable": true
},
{
"id": "100302004",
"code": "border.color",
"name": "颜色",
"desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式",
"group": "边框",
"controlType": "color-combo",
"mapping": ["border.top.color", "border.right.color", "border.bottom.color", "border.left.color"],
"dataType": "string",
"defaultValue": "rgb(219,219,233)",
"orderNo": 2,
"visiable": true
},
{
"id": "100302005",
"code": "borderOpacity",
"name": "透明度",
"desc": "图形的边框的透明度,0完全透明~1完全不透明",
"group": "边框",
"controlType": "range",
"min": 0,
"max": 1,
"step": 0.01,
"mapping": ["border.top.opacity", "border.right.opacity", "border.bottom.opacity", "border.left.opacity"],
"dataType": "float",
"defaultValue": 1,
"display": "column",
"orderNo": 3,
"visiable": true
},
{
"id": "100302006",
"code": "borderWidth",
"name": "粗细",
"desc": "图形的边框的粗细,0为无边框",
"group": "边框",
"controlType": "range",
"min": 0,
"max": 10,
"step": 0.1,
"mapping": ["border.top.width", "border.right.width", "border.bottom.width", "border.left.width"],
"dataType": "integer",
"defaultValue": 1,
"orderNo": 4,
"visiable": true
},
{
"id": "100302007",
"code": "borderDash",
"name": "虚线",
"desc": "图形的边框的是否为虚线样式,虚线由长短不一的线段构成",
"group": "边框",
"controlType": "combox",
"dataSource": [
{ "img": "icon-line-00", "text": "1", "value": [] },
{ "img": "icon-line-00", "text": "2", "value": [10, 5] },
{ "img": "icon-line-00", "text": "3", "value": [5, 5] },
{ "img": "icon-line-00", "text": "4", "value": [10, 4, 2, 4] },
{ "img": "icon-line-00", "text": "5", "value": [10, 4, 2, 4, 2, 4] },
{ "img": "icon-line-00", "text": "6", "value": [10, 4, 10, 4, 2, 4] },
{ "img": "icon-line-00", "text": "7", "value": [20, 5, 10, 5] },
{ "img": "icon-line-00", "text": "8", "value": [20, 5, 10, 5, 10, 5] },
{ "img": "icon-line-00", "text": "9", "value": [3, 3] },
{ "img": "icon-line-00", "text": "10", "value": [2, 2] },
{ "img": "icon-line-00", "text": "11", "value": [3, 2, 2, 2] },
{ "img": "icon-line-00", "text": "12", "value": [3, 2, 2, 2, 2, 2] }
],
"itemStyle": { width: 80, height: 25, col: 2, row: 6, imgWidth: 60, imgHeight: 20, display: "img-text" },
"mapping": ["border.top.dash", "border.right.dash", "border.bottom.dash", "border.left.dash"],
"dataType": "integer",
"defaultValue": [],
"isArray": true,
"orderNo": 5,
"visiable": true
},
{
"id": "100302008",
"code": "borderRound",
"name": "圆角",
"desc": "图形的边框的是否为为圆角的弧度",
"group": "边框",
"controlType": "range",
"mapping": ["border.top.round", "border.right.round", "border.bottom.round", "border.left.round"],
"min": 0,
"max": 100,
"step": 1,
"defaultValue": 0,
"dataType": "integer",
"orderNo": 6,
"visiable": true
},
{
"id": "100302101",
"code": "fillType",
"name": "填充类型",
"desc": "图形填充的类型快速设置",
"group": "填充",
"controlType": "fill-type",
"dataSource": [{ "text": "无填充", "value": "0" }, { "text": "单色填充", "value": "1" }],
"exmapping": ["fill.disabled"],
"dataType": "string",
"defaultValue": "1",
"hiddenTitle": true,
"display": "column",
"orderNo": 1,
"visiable": true
},
{
"id": "100302102",
"code": "fill.color",
"name": "颜色",
"desc": "图形的填充颜色",
"group": "填充",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": "white",
"orderNo": 2,
"visiable": true
},
{
"id": "100302103",
"code": "fill.opacity",
"name": "透明度",
"desc": "图形的填充的透明度,0完全透明~1完全不透明",
"group": "填充",
"controlType": "range",
"min": 0,
"max": 1,
"step": 0.01,
"defaultValue": 1,
"dataType": "float",
"display": "column",
"orderNo": 3,
"visiable": true
},
{
"id": "100302201",
"code": "font.family",
"name": "字体",
"desc": "文本的字体名称",
"group": "文本",
"controlType": "combox",
"dataType": "string",
"dataSource": {
"type": "config",
"data": "fonts",
"text": "ch",
"value": "en",
"bold": "isSystemDefault",
"fontFamily": "en"
},
"itemStyle": { width: 80, height: 25, col: 2, row: 0, imgWidth: 20, imgHeight: 20 },
"canSearch": true,
"defaultValue": "Microsoft YaHei",
"orderNo": 1,
"visiable": true
},
{
"id": "100302202",
"code": "font.size",
"name": "大小",
"desc": "文本的字体大小",
"group": "文本",
"max": 50,
"min": 5,
"step": 0.5,
"controlType": "font-size",
"dataType": "float",
"defaultValue": 14,
"orderNo": 2,
"visiable": true
},
{
"id": "100302203",
"code": "font.color",
"name": "颜色",
"desc": "文本的颜色",
"group": "文本",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": "#252525",
"orderNo": 3,
"visiable": true
},
{
"id": "100302204",
"code": "fontAlign",
"name": "对齐",
"desc": "文本的对齐,采用九宫格式设置",
"group": "文本",
"controlType": "align-type",
"mapping": [],
"dataType": "string",
"orderNo": 4,
"visiable": true
},
{
"id": "100302205",
"code": "textStyle.feed",
"name": "换行",
"desc": "自动换行",
"group": "文本",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0",
"orderNo": 10,
"visiable": true
},
{
"id": "100302206",
"code": "textStyle.scale",
"name": "ddei.property.outSize",
"desc": "文本的自动缩小字体填充",
"group": "文本",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0",
"orderNo": 11,
"visiable": true
},
{
"id": "100302207",
"code": "textStyle.hollow",
"name": "ddei.property.hollow",
"desc": "文本的镂空显示",
"group": "文本",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0",
"orderNo": 9,
"visiable": true
},
{
"id": "100302208",
"code": "textStyle.bold",
"name": "ddei.property.bold",
"desc": "文本的加粗显示",
"group": "文本",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0",
"orderNo": 5,
"visiable": true
},
{
"id": "100302209",
"code": "textStyle.italic",
"name": "ddei.property.italic",
"desc": "文本的斜体显示",
"group": "文本",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0",
"orderNo": 6,
"visiable": true
},
{
"id": "100302210",
"code": "textStyle.underline",
"name": "ddei.property.underline",
"desc": "文本的下划线显示",
"group": "文本",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0",
"orderNo": 7,
"visiable": true
},
{
"id": "100302211",
"code": "textStyle.deleteline",
"name": "ddei.property.deleteline",
"desc": "文本的删除线显示",
"group": "文本",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0",
"orderNo": 8,
"visiable": true
},
{
"id": "100302212",
"code": "textStyle.topline",
"name": "ddei.property.topline",
"desc": "文本的删除线显示",
"group": "文本",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.yes", "value": "1" }, { "text": "ddei.property.ds.no", "value": "0" }],
"defaultValue": "0",
"orderNo": 8,
"visiable": true
},
{
"id": "100302303",
"code": "textStyle.align",
"name": "ddei.property.textAlign",
"desc": "文本的水平对齐",
"group": "文本",
"controlType": "text",
"dataType": "integer",
"defaultValue": 2,
"visiable": false
},
{
"id": "100302304",
"code": "textStyle.valign",
"name": "ddei.property.textValign",
"desc": "文本的垂直对齐",
"group": "文本",
"controlType": "text",
"dataType": "integer",
"defaultValue": 2,
"visiable": false
}
],
"visiable": false,
"order": 1
};
const datas$1 = {
"name": "数据",
"children": [
{
"id": "100302401",
"code": "id",
"name": "ddei.property.id",
"desc": "控件在画布的全局唯一ID",
"group": "布局与文本",
"controlType": "text",
"dataType": "string",
"readonly": true,
"orderNo": 1,
"visiable": false
},
{
"id": "100302403",
"code": "text",
"name": "ddei.property.text",
"desc": "控件的主体显示文本",
"group": "布局与文本",
"controlType": "textarea",
"defaultValue": "ddei.property.text",
"hiddenTitle": false,
"display": "column",
"dataType": "string",
"type": [1, 2],
//类别,1图形,2业务,3事件
"orderNo": 3,
"visiable": true
},
{
"id": "100302404",
"code": "layout",
"name": "布局",
"desc": "文本的字体名称",
"group": "布局与文本",
"controlType": "radio",
"dataSource": [
{ "text": "自由布局", "value": "free" },
{ "text": "完全填充", "value": "full" },
{ "text": "九宫格", "value": "nine" },
{ "text": "表格", "value": "table" },
{ "text": "圆心", "value": "cc" }
],
"defaultValue": "full",
"hiddenTitle": false,
"display": "column",
"dataType": "string",
"orderNo": 2,
"visiable": true
}
],
"visiable": true,
"order": 2
};
const events$1 = {
"name": "事件",
"children": [],
"visiable": false,
"order": 3
};
const __vite_glob_0_5$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
datas: datas$1,
default: tableCell,
events: events$1,
styles: styles$1
}, Symbol.toStringTag, { value: "Module" }));
const table = {
"id": "100301",
"name": "表格",
"code": "table",
"desc": "表格控件,可以通过插入、移动、合并单元格完成复杂的布局",
"type": "DDeiTable",
"icon": "icon-table",
"subcontrol": "100302"
};
const styles = {
"name": "样式",
"children": [
{
"id": "100301001",
"code": "width",
"name": "宽度",
"desc": "控件的宽度",
"group": "布局",
"controlType": "text",
"dataSource": null,
"dataType": "integer",
"defaultValue": "600",
"orderNo": 1,
"visiable": false
},
{
"id": "100301002",
"code": "height",
"name": "高度",
"desc": "控件的高度",
"group": "布局",
"controlType": "text",
"dataSource": null,
"dataType": "integer",
"defaultValue": "200",
"orderNo": 2,
"visiable": false
},
{
"id": "100301003",
"code": "border.type",
"name": "边框类型",
"desc": "用来快速选择边框的类型,以便于套用相关的样式",
"group": "边框",
"controlType": "border-type",
"dataSource": [{ "text": "无线条", "value": "0" }, { "text": "实线", "value": "1" }],
"dataType": "string",
"defaultValue": "1",
"hiddenTitle": true,
"display": "column",
"exmapping": ["border.top.disabled", "border.right.disabled", "border.bottom.disabled", "border.left.disabled"],
"orderNo": 1,
"visiable": true
},
{
"id": "100301004",
"code": "border.color",
"name": "颜色",
"desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式",
"group": "边框",
"controlType": "color-combo",
"mapping": ["border.top.color", "border.right.color", "border.bottom.color", "border.left.color"],
"dataType": "string",
"defaultValue": "black",
"orderNo": 2,
"visiable": true
},
{
"id": "100301005",
"code": "borderOpacity",
"name": "透明度",
"desc": "图形的边框的透明度,0完全透明~1完全不透明",
"group": "边框",
"controlType": "range",
"min": 0,
"max": 1,
"step": 0.01,
"mapping": ["border.top.opacity", "border.right.opacity", "border.bottom.opacity", "border.left.opacity"],
"dataType": "float",
"defaultValue": 1,
"display": "column",
"orderNo": 3,
"visiable": true
},
{
"id": "100301006",
"code": "borderWidth",
"name": "粗细",
"desc": "图形的边框的粗细,0为无边框",
"group": "边框",
"controlType": "range",
"min": 0,
"max": 10,
"step": 0.1,
"mapping": ["border.top.width", "border.right.width", "border.bottom.width", "border.left.width"],
"dataType": "integer",
"defaultValue": 1,
"orderNo": 4,
"visiable": true
},
{
"id": "100301007",
"code": "borderDash",
"name": "虚线",
"desc": "图形的边框的是否为虚线样式,虚线由长短不一的线段构成",
"group": "边框",
"controlType": "combox",
"dataSource": [
{ "img": "icon-line-00", "text": "1", "value": [] },
{ "img": "icon-line-00", "text": "2", "value": [10, 5] },
{ "img": "icon-line-00", "text": "3", "value": [5, 5] },
{ "img": "icon-line-00", "text": "4", "value": [10, 4, 2, 4] },
{ "img": "icon-line-00", "text": "5", "value": [10, 4, 2, 4, 2, 4] },
{ "img": "icon-line-00", "text": "6", "value": [10, 4, 10, 4, 2, 4] },
{ "img": "icon-line-00", "text": "7", "value": [20, 5, 10, 5] },
{ "img": "icon-line-00", "text": "8", "value": [20, 5, 10, 5, 10, 5] },
{ "img": "icon-line-00", "text": "9", "value": [3, 3] },
{ "img": "icon-line-00", "text": "10", "value": [2, 2] },
{ "img": "icon-line-00", "text": "11", "value": [3, 2, 2, 2] },
{ "img": "icon-line-00", "text": "12", "value": [3, 2, 2, 2, 2, 2] }
],
"itemStyle": { width: 80, height: 25, col: 2, row: 6, imgWidth: 60, imgHeight: 20, display: "img-text" },
"mapping": ["border.top.dash", "border.right.dash", "border.bottom.dash", "border.left.dash"],
"dataType": "integer",
"defaultValue": [],
"isArray": true,
"orderNo": 5,
"visiable": true
},
{
"id": "100301008",
"code": "borderRound",
"name": "圆角",
"desc": "图形的边框的是否为为圆角的弧度",
"group": "边框",
"controlType": "range",
"mapping": ["border.top.round", "border.right.round", "border.bottom.round", "border.left.round"],
"min": 0,
"max": 100,
"step": 1,
"defaultValue": 0,
"dataType": "integer",
"orderNo": 6,
"visiable": true
},
{
"id": "100301305",
"code": "borderCreatingOpacity",
"name": "透明度",
"desc": "图形的边框的透明度,0完全透明~1完全不透明",
"group": "边框",
"controlType": "text",
"mapping": ["border.creating.top.opacity", "border.creating.right.opacity", "border.creating.bottom.opacity", "border.creating.left.opacity"],
"dataType": "float",
"defaultValue": 0.5,
"display": "column",
"orderNo": 3,
"visiable": false
},
{
"id": "100301306",
"code": "fillCreatingOpacity",
"name": "透明度",
"desc": "图形的填充的透明度,0完全透明~1完全不透明",
"group": "填充",
"controlType": "text",
"mapping": ["fill.creating.opacity"],
"dataType": "float",
"defaultValue": 0.5,
"display": "column",
"orderNo": 3,
"visiable": false
}
],
"visiable": false,
"order": 1
};
const datas = {
"name": "数据",
"children": [
{
"id": "100301401",
"code": "id",
"name": "ddei.property.id",
"desc": "控件在画布的全局唯一ID",
"group": "基础信息",
"controlType": "text",
"dataType": "string",
"readonly": true,
"orderNo": 1,
"visiable": false
},
{
"id": "100301402",
"code": "code",
"name": "ddei.property.code",
"desc": "控件在业务上的唯一编码,缺省和控件ID一致",
"group": "基础信息",
"controlType": "text",
"dataType": "string",
"defaultValue": "ddei.property.code001",
"orderNo": 2,
"visiable": true
}
],
"visiable": true,
"order": 1
};
const events = {
"name": "事件",
"children": [],
"visiable": false,
"order": 3
};
const menus = [
{
"code": "insert-row",
"name": "插入行",
"icon": "icon-insert-row"
},
{
"code": "insert-col",
"name": "插入列",
"icon": "icon-insert-col"
},
{
"code": "remove-row",
"name": "删除行",
"icon": "icon-delete-row"
},
{
"code": "remove-col",
"name": "删除列",
"icon": "icon-delete-column"
},
{
"code": "split"
},
{
"code": "merge-cell",
"name": "合并单元格",
"icon": "icon-merge-cells"
},
{
"code": "cancel-merge-cell",
"name": "取消合并单元格",
"icon": "icon-merge-cells"
}
];
const __vite_glob_0_6$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
datas,
default: table,
events,
menus,
styles
}, Symbol.toStringTag, { value: "Module" }));
const circleSplit = {
"id": "100104",
"name": "圆形-切割",
"code": "circle",
"desc": "由圆形,从中间横向/纵向切割开",
"from": "100103",
"define": {
//扩展采样信息,用于在原有的基础上增加采样,或者覆盖采样的部分信息
ext: {
//追加一个从中间切开的采样点,用于横向切割
sample: {
direct: 1,
//1横向切割,2纵向切割
pvalue: 0,
//切割的坐标,横向切割时为纵坐标,纵向切割时为横坐标
rules: [
`(i, sample, pvs, model, ovs){
if(i == 0){
if(sample.direct == 1){
pvs.push({x:-50,y:sample.pvalue,stroke:1,type:1});
pvs.push({x:50,y:sample.pvalue,stroke:1,type:1});
}else{
pvs.push({x:sample.pvalue,y:-50,stroke:1,type:1});
pvs.push({x:sample.pvalue,y:50,stroke:1,type:1});
}
}
}`
]
}
}
}
};
const __vite_glob_0_7$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: circleSplit
}, Symbol.toStringTag, { value: "Module" }));
const circleText = {
"id": "100003",
"name": "ddei.control.circle",
"code": "circle",
"desc": "由极坐标系构造的圆形,带有text",
"from": "100103",
"define": {
ext: {
//采样信息
sample: {
//采样的规则,多组采样返回多组规则
rules: [
//文本区域
`(i, sample, pvs, model, ovs){
pvs.push({x:sample.x,y:sample.y,r:sample.r,text:1});
}`
]
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_8$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: circleText
}, Symbol.toStringTag, { value: "Module" }));
const circle = {
"id": "100103",
"name": "ddei.control.circle",
"code": "circle",
"desc": "由极坐标系构造的圆形",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let x = er * sample.cos
let y = er * sample.sin
pvs.push({x:x,y:y,r:er,select:1});
}`,
//操作点
`(i, sample, pvs, model, ovs){
let x = sample.r * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = sample.r * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y,r:sample.r ,oppoint:1});
if(i == 3){
pvs.push({x:0,y:0,r:sample.r ,oppoint:3});
}
}`,
//绘制线段、填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({r:sample.r,stroke:1,fill:1,clip:1,begin:1,end:1});
}
}`
]
},
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
}
]
}
]
}
}
};
const __vite_glob_0_9$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: circle
}, Symbol.toStringTag, { value: "Module" }));
const cube = {
"id": "100501",
"name": "ddei.control.cube",
"code": "cube",
"desc": "正方体",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: true,
//只采样一次
loop: 1,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//允许文本输入
textInput: 1,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
pvs.push({begin:1,x:50,y:50,stroke:1,select:1,oppoint:2,fill:1});
pvs.push({x:-50,y:50,stroke:1,select:1,oppoint:2,fill:1});
pvs.push({x:-50,y:-50,stroke:1,select:1,oppoint:2,fill:1});
pvs.push({x:-45,y:-60,stroke:1,select:1,oppoint:1,fill:1});
pvs.push({x:55,y:-60,stroke:1,select:1,oppoint:1,fill:1});
pvs.push({end:1,x:55,y:40,stroke:1,select:1,oppoint:1,fill:1});
}`,
//内部连线
`(i, sample, pvs, model, ovs){
pvs.push({begin:1,x:-50,y:-50,stroke:1});
pvs.push({x:50,y:-50,stroke:1,oppoint:2,op2close:1});
pvs.push({x:55,y:-60,stroke:1});
pvs.push({x:-50,y:-50,type:3});
pvs.push({x:50,y:-50,stroke:1});
pvs.push({x:50,y:50,stroke:1});
pvs.push({x:-50,y:-50,type:3});
}`,
//文本区域
`(i, sample, pvs, model, ovs){
pvs.push({x:-48,y:48,text:sample.textInput});
pvs.push({x:-48,y:-48,text:sample.textInput});
pvs.push({x:48,y:-48,text:sample.textInput});
pvs.push({x:48,y:48,text:sample.textInput});
}`
]
}
}
};
const __vite_glob_0_10$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: cube
}, Symbol.toStringTag, { value: "Module" }));
const diamondRound = {
"id": "100041",
"name": "ddei.control.diamond",
"code": "diamond",
"desc": "圆角的菱形",
"from": "100040",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_11$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: diamondRound
}, Symbol.toStringTag, { value: "Module" }));
const diamond = {
"id": "100040",
"name": "ddei.control.diamond",
"code": "diamond",
"desc": "标准的菱形",
"from": "100500",
"define": {
width: 160,
height: 80,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: -90,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
pvs.push({begin:i==0,end:i==3,x:sample.x,y:sample.y,select:1,oppoint:1,stroke:1,fill:1,clip:1});
}`,
`(i, sample, pvs, model, ovs){
let er = sample.r * Math.cos(45)
let x = er * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = er * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({begin:i==0,end:i==3,x:x,y:y,text:1});
}`
]
}
}
};
const __vite_glob_0_12$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: diamond
}, Symbol.toStringTag, { value: "Module" }));
const ellipse = {
"id": "100006",
"name": "ddei.control.ellipse",
"code": "ellipse",
"desc": "由极坐标系构造的椭圆形",
"from": "100500",
"define": {
width: 160,
height: 80,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let x = er * sample.cos
let y = er * sample.sin
pvs.push({x:x,y:y,r:er,select:1});
}`,
//操作点
`(i, sample, pvs, model, ovs){
let x = sample.r * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = sample.r * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y,r:sample.r ,oppoint:1});
if(i == 3){
pvs.push({x:0,y:0,r:sample.r ,oppoint:3});
}
}`,
//绘制线段、填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({r:sample.r,stroke:1,fill:1,clip:1,begin:1,end:1});
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
pvs.push({x:sample.x,y:sample.y,r:sample.r,text:1});
}`
]
}
}
};
const __vite_glob_0_13$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: ellipse
}, Symbol.toStringTag, { value: "Module" }));
const fivestar = {
"id": "100070",
"name": "ddei.control.fivestar",
"code": "fivestar",
"desc": "由极坐标系构造的五角星",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
eqrat: true,
//一圈10次采样
loop: 10,
//初始次采样的开始角度
angle: -90,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model,ovs){
let er = i % 2 == 0 ? sample.r : sample.r / 2.7+(ovs[0].x-ovs[0].ovi.x)
let x = er * sample.cos
let y = er * sample.sin
pvs.push({ begin:i==0,end:i==9,x: x, y: y ,fill:1,select:1,stroke:1,clip:1,oppoint:1});
}`,
`(i, sample, pvs, model,ovs){
if (i == 0) {
let er = sample.r / 3+(ovs[0].x-ovs[0].ovi.x)
let x = er * Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let y = er * Math.sin(45 * DDeiConfig.ROTATE_UNIT)
pvs.push({ begin:1,x: x, y: y, text:1 });
x = er * Math.cos(135 * DDeiConfig.ROTATE_UNIT)
y = er * Math.sin(135 * DDeiConfig.ROTATE_UNIT)
pvs.push({ x: x, y: y, text:1 });
x = er * Math.cos(225 * DDeiConfig.ROTATE_UNIT)
y = er * Math.sin(225 * DDeiConfig.ROTATE_UNIT)
pvs.push({ x: x, y: y, text:1 });
x = er * Math.cos(315 * DDeiConfig.ROTATE_UNIT)
y = er * Math.sin(315 * DDeiConfig.ROTATE_UNIT)
pvs.push({ end:1,x: x, y: y, text:1 });
}
}`
]
},
//操作点定义
ovs: [
{
x: 10,
y: 0,
ix: 10,
iy: 0,
//约束,控制点的移动路径和位置
constraint: {
type: 2,
//矩形范围
x0: 0,
x1: 30,
y0: 0,
y1: 0
}
}
]
}
};
const __vite_glob_0_14$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: fivestar
}, Symbol.toStringTag, { value: "Module" }));
const halfCircle = {
"id": "100110",
"name": "ddei.control.half-circle",
"code": "hcircle",
"desc": "由极坐标系构造的半圆形",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//方向,上右下左1,2,3,4
direct: 2,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let deltaRotate = 0
switch(sample.direct){
case 1:
deltaRotate = -90
break;
case 3:
deltaRotate = -270
break;
case 4:
deltaRotate = -180
break;
}
let rad1 = (90+deltaRotate) * DDeiConfig.ROTATE_UNIT
let rad2 = (-90+deltaRotate) * DDeiConfig.ROTATE_UNIT
let rad0 = (deltaRotate) * DDeiConfig.ROTATE_UNIT
let x0 = sample.r * Math.cos(rad0)
let y0 = sample.r * Math.sin(rad0)
let x1 = sample.r * Math.cos(rad1)
let y1 = sample.r * Math.sin(rad1)
let x2 = sample.r * Math.cos(rad2)
let y2 = sample.r * Math.sin(rad2)
pvs.push({begin:1,x:x2,y:y2,r:sample.r,rad:rad2,stroke:1,type:2,direct:1});
pvs.push({x:x2,y:y2,r:sample.r,rad:rad1,stroke:1,type:2,direct:1});
pvs.push({x:x2,y:y2});
pvs.push({end:1,x:0,y:0});
pvs.push({x:x1,y:y1,type:0,oppoint:1});
pvs.push({x:x2,y:y2,type:0,oppoint:1});
pvs.push({x:x0,y:0,type:0,oppoint:1});
pvs.push({x:x2,y:0,type:0,oppoint:1});
pvs.push({x:x0,y:y2,type:0});
pvs.push({x:x0,y:y1,type:0});
}
}`,
//选中区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let x = er * sample.cos
let y = er * sample.sin
pvs.push({x:x,y:y,r:er,select:1});
}`
]
},
iconPos: {
dx: -50
}
}
};
const __vite_glob_0_15$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: halfCircle
}, Symbol.toStringTag, { value: "Module" }));
const hexagonRound = {
"id": "100031",
"name": "ddei.control.hexagon",
"code": "hexagon",
"desc": "由六个点构成的六边形",
"from": "100030",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_16$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: hexagonRound
}, Symbol.toStringTag, { value: "Module" }));
const hexagon = {
"id": "100030",
"name": "ddei.control.hexagon",
"code": "hexagon",
"desc": "由六个点构成的六边形",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 6,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let x = er * sample.cos
let y = er * sample.sin
pvs.push({begin:i == 0,end:i == 5,op2close:i == 5 ? 1 :0,oppoint:2,x:x,y:y,select:1,clip:1,stroke:1,fill:1});
}`,
`(i, sample, pvs, model, ovs){
switch(i){
case 0:;
case 2:;
case 3:;
case 5:
let er = sample.r / Math.cos(30 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+30) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
pvs.push({begin:i == 0,end:i == 5,x:x,y:y,text:1});
;
}
}`
]
}
}
};
const __vite_glob_0_17$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: hexagon
}, Symbol.toStringTag, { value: "Module" }));
const hexstar = {
"id": "100075",
"name": "ddei.control.hexstar",
"code": "hexstar",
"desc": "由极坐标系构造的六芒星",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
//一圈6次采样
loop: 12,
//初始次采样的开始角度
angle: -90,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let er = i%2 == 0 ? sample.r : sample.r * 0.58
let x = er * sample.cos
let y = er * sample.sin
pvs.push({begin:i==0,end:i==11, x: x, y: y, oppoint:1,select:1,clip:1,stroke:1,fill:1 });
}`,
`(i, sample, pvs, model, ovs){
if(i % 2 == 1){
let er = sample.r * 0.58
let x = er * sample.cos
let y = er * sample.sin
pvs.push({begin:i==1,end:i==11, x: x, y: y,stroke:1,fill:1 });
}
}`,
`(i, sample, pvs, model, ovs){
if(i % 2 == 0 && i != 6 && i !=0){
let er = sample.r * 0.5
let x = er * sample.cos
let y = er * sample.sin
pvs.push({begin:i==2,end:i==10, x: x, y: y,text:1 });
}
}`
]
},
textArea: [
{ x: -2.5, y: 32.5, z: 1 },
{ x: 102.5, y: 32.5, z: 1 },
{ x: 102.5, y: 142.5, z: 1 },
{ x: -2.5, y: 142.5, z: 1 }
]
}
};
const __vite_glob_0_18$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: hexstar
}, Symbol.toStringTag, { value: "Module" }));
const hexstar1 = {
"id": "100076",
"name": "ddei.control.hexstar",
"code": "hexstar",
"desc": "由极坐标系构造的六角星",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
//一圈6次采样
loop: 12,
//初始次采样的开始角度
angle: -90,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let er = i%2 == 0 ? sample.r : sample.r * 0.58
let x = er * sample.cos
let y = er * sample.sin
pvs.push({begin:i==0,end:i==11, x: x, y: y,select:1,clip:1,stroke:1,fill:1,oppoint:1 });
}`,
`(i, sample, pvs, model, ovs){
if(i % 2 == 0 && i != 6 && i !=0){
let x = sample.x * 0.5
let y = sample.y * 0.5
pvs.push({begin:i==2,end:i==10, x: x, y: y,text:1 });
}
}`
]
}
}
};
const __vite_glob_0_19$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: hexstar1
}, Symbol.toStringTag, { value: "Module" }));
const hexstar2 = {
"id": "100077",
"name": "ddei.control.hexstar",
"code": "hexstar",
"desc": "由极坐标系构造的六芒星",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
//一圈6次采样
loop: 12,
//初始次采样的开始角度
angle: -90,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选择范围
`(i, sample, pvs, model, ovs){
if(i % 3 == 0){
let er = (sample.r+5) / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let x = er * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = er * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({ begin:i==0,end:i==9,x: x, y: y,select:1 });
}
}`,
//第一层圈
`(i, sample, pvs, model, ovs){
if(i == 0){
let er = sample.r+5
let x = er * sample.cos
let y = er * sample.sin
pvs.push({begin:1,end:1, x: x, y: y,r:er,clip:1,stroke:1,fill:1 });
}
}`,
//第二层圈
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,end:1, x: sample.x, y: sample.y,r:sample.r,stroke:1,fill:1 });
}
}`,
//六边形外围
`(i, sample, pvs, model, ovs){
let er = i%2 == 0 ? sample.r : sample.r * 0.58
let x = er * sample.cos
let y = er * sample.sin
pvs.push({ begin:i==0,end:i==11,x: x, y: y,oppoint:1,stroke:1,fill:1 });
}`,
//内部五边形
`(i, sample, pvs, model, ovs){
if(i % 2 == 1){
let x = sample.x * 0.58
let y = sample.y * 0.58
pvs.push({ begin:i==1,end:i==11,x: x, y: y,stroke:1,fill:1 });
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(i % 2 == 0 && i != 6 && i !=0){
let x = sample.x*0.5
let y = sample.y*0.5
pvs.push({ begin:i==2,end:i==10,x: x, y: y,text:1 });
}
}`
]
}
}
};
const __vite_glob_0_20$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: hexstar2
}, Symbol.toStringTag, { value: "Module" }));
const leftArrow = {
"id": "100121",
"name": "ddei.control.arrow-left",
"code": "arr-l",
"desc": "指向左边的箭头",
"from": "100120",
"define": {
//采样信息
ext: {
sample: {
angle: 180
}
}
}
};
const __vite_glob_0_21$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: leftArrow
}, Symbol.toStringTag, { value: "Module" }));
const parallelogramRound = {
"id": "100051",
"name": "ddei.control.paralgram",
"code": "paralgram",
"desc": "由4个点组成的平行四边形",
"from": "100050",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_22$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: parallelogramRound
}, Symbol.toStringTag, { value: "Module" }));
const parallelogram = {
"id": "100050",
"name": "ddei.control.paralgram",
"code": "paralgram",
"desc": "由4个点组成的平行四边形",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model,ovs){
switch(i){
case 0:
pvs.push({begin:1,x:sample.x,y:sample.y,r:sample.r,select:1,clip:1,oppoint:2,stroke:1,fill:1});
break;
case 1:
pvs.push({x:sample.x,y:sample.y,r:sample.r,select:1,clip:1,oppoint:2,stroke:1,fill:1});
break;
case 2:
pvs.push({x:sample.x,y:sample.y,r:sample.r,select:1,clip:1,oppoint:2,stroke:1,fill:1});
break;
case 3:
pvs.push({end:1,x:sample.x,y:sample.y,r:sample.r,select:1,clip:1,oppoint:2,op2close:1,stroke:1,fill:1});
pvs[0].y = pvs[1].y
pvs[1].x = pvs[2].x
pvs[2].y = pvs[3].y
pvs[3].x = pvs[0].x+(ovs[0].x-ovs[0].ovi.x)
pvs[2].x = pvs[2].x+(ovs[0].x-ovs[0].ovi.x)
pvs[0].x = pvs[0].x-(ovs[0].x-ovs[0].ovi.x)
pvs[1].x = pvs[1].x-(ovs[0].x-ovs[0].ovi.x)
break;
}
}`,
//文本区域
`(i, sample, pvs, model,ovs){
switch(i){
case 0:
pvs.push({begin:1,x:sample.x,y:sample.y,text:1});
break;
case 1:
pvs.push({x:sample.x,y:sample.y,text:1});
break;
case 2:
pvs.push({x:sample.x,y:sample.y,text:1});
break;
case 3:
pvs.push({end:1,x:sample.x,y:sample.y,text:1});
pvs[0].y = pvs[1].y
pvs[1].x = pvs[2].x
pvs[2].y = pvs[3].y
pvs[3].x = pvs[0].x+(ovs[0].x-ovs[0].ovi.x)
pvs[2].x = pvs[2].x+(ovs[0].x-ovs[0].ovi.x)
pvs[0].x = pvs[0].x-(ovs[0].x-ovs[0].ovi.x)
pvs[1].x = pvs[1].x-(ovs[0].x-ovs[0].ovi.x)
let x0 = Math.max(pvs[1].x,pvs[2].x)
let x1 = Math.min(pvs[3].x,pvs[0].x)
pvs[0].x = x1
pvs[3].x = x1
pvs[1].x = x0
pvs[2].x = x0
break;
}
}`
]
},
//操作点定义
ovs: [
{
x: 25,
y: -50,
ix: 0,
iy: -50,
//约束,控制点的移动路径和位置
constraint: {
type: 2,
//矩形范围
x0: -100,
x1: 100,
y0: -50,
y1: -50
}
}
]
}
};
const __vite_glob_0_23$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: parallelogram
}, Symbol.toStringTag, { value: "Module" }));
const pentagonRound = {
"id": "100021",
"name": "ddei.control.pentagon",
"code": "pentagon",
"desc": "由五个点构成的五边形",
"from": "100020",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_24$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: pentagonRound
}, Symbol.toStringTag, { value: "Module" }));
const pentagon = {
"id": "100020",
"name": "ddei.control.pentagon",
"code": "pentagon",
"desc": "由五个点构成的五边形",
"from": "100500",
"define": {
width: 154,
height: 154,
poly: 2,
//采样信息
sample: {
eqrat: true,
//一圈5次采样
loop: 5,
//初始次采样的开始角度
angle: 198,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 4:
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,select:1,clip:1,oppoint:2,op2close:i == 4?1:0,stroke:1,fill:1});
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:28,y:35,text:1});
pvs.push({x:-28,y:35,text:1});
pvs.push({x:-28,y:-28,text:1});
pvs.push({end:1,x:28,y:-28,text:1});
}
}`
]
}
}
};
const __vite_glob_0_25$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: pentagon
}, Symbol.toStringTag, { value: "Module" }));
const rectangleBorder = {
"id": "100007",
"name": "ddei.control.rectangle",
"code": "rect",
"desc": "带边框的矩形",
"from": "100002",
"define": {
width: 160,
height: 80,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let er = sample.r * 1.25
let x = er * sample.cos
let y = er * sample.sin
let begin = 0,end = 0,op2close = 0
switch(i){
case 0:
begin = 1
break;
case 1:
pvs[0].y=y
break;
case 2:
pvs[1].x=x
break;
case 3:
op2close = 1
pvs[2].y=y
x = pvs[0].x
end = 1
break;
}
pvs.push({begin:begin,end:end,x:x,y:y,r:er,select:1,clip:1,oppoint:2,op2close:op2close});
}`,
`(i, sample, pvs, model, ovs){
let er = sample.r
let x = sample.x
let y = sample.y
let begin = 0,end = 0
switch(i){
case 0:
begin = 1
break;
case 1:
pvs[0].y=y
break;
case 2:
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
end = 1
break;
}
pvs.push({begin:begin,end:end,x:x,y:y,r:er,stroke:1,fill:1,text:1});
}`
]
},
//组合控件
composes: [
{
width: 200,
height: 100,
id: "100002",
cIndex: 1
}
]
}
};
const __vite_glob_0_26$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: rectangleBorder
}, Symbol.toStringTag, { value: "Module" }));
const rectangleRound = {
"id": "100005",
"name": "ddei.control.rectangle",
"code": "rect",
"desc": "由4个点组成的矩形",
"from": "100002",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_27$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: rectangleRound
}, Symbol.toStringTag, { value: "Module" }));
const rectangleSplit = {
"id": "100009",
"name": "ddei.control.rectangle-split",
"code": "rect",
"desc": "由4个点组成的长方形,从中间横向/纵向切割开",
"from": "100008",
"define": {
//扩展采样信息,用于在原有的基础上增加采样,或者覆盖采样的部分信息
ext: {
//追加一个从中间切开的采样点,用于横向切割
sample: {
direct: 1,
//1横向切割,2纵向切割
pvalue: -10,
//切割的坐标,横向切割时为纵坐标,纵向切割时为横坐标
rules: [
`(i, sample, pvs, model, ovs){
if(i == 0){
if(sample.direct == 1){
pvs.push({x:-50,y:sample.pvalue,stroke:1,type:1});
pvs.push({x:50,y:sample.pvalue,stroke:1,type:1});
}else{
pvs.push({x:sample.pvalue,y:-50,stroke:1,type:1});
pvs.push({x:sample.pvalue,y:50,stroke:1,type:1});
}
}
}`
]
}
}
}
};
const __vite_glob_0_28$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: rectangleSplit
}, Symbol.toStringTag, { value: "Module" }));
const rectangleText = {
"id": "100002",
"name": "ddei.control.rectangle",
"code": "rect",
"desc": "由4个点组成的长方形",
"from": "100008",
"define": {
ext: {
sample: {
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,text:1});
}`
]
}
}
}
};
const __vite_glob_0_29$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: rectangleText
}, Symbol.toStringTag, { value: "Module" }));
const rectangle = {
"id": "100008",
"name": "ddei.control.rectangle",
"code": "rect",
"desc": "由4个点组成的长方形",
"from": "100000",
"define": {
width: 160,
height: 80,
ext: {
//采样信息
sample: {
eqrat: false
}
}
}
};
const __vite_glob_0_30$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: rectangle
}, Symbol.toStringTag, { value: "Module" }));
const rightArrow = {
"id": "100120",
"name": "ddei.control.arrow-right",
"code": "arr-r",
"desc": "指向右边的箭头",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
//一圈12次采样
loop: 12,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
if(i % 4 == 0){
let op2close = 0
if(i == 8){
op2close = 1
}
pvs.push({begin:i == 0,end:i == 8,x:sample.x,y:sample.y,select:1,clip:1,oppoint:2,op2close:op2close,stroke:1,fill:1});
}
}`
]
}
}
};
const __vite_glob_0_31$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: rightArrow
}, Symbol.toStringTag, { value: "Module" }));
const squareRound = {
"id": "100004",
"name": "ddei.control.square",
"code": "square",
"desc": "由4个点组成的正方形",
"from": "100001",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_32$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: squareRound
}, Symbol.toStringTag, { value: "Module" }));
const squareText = {
"id": "100001",
"name": "ddei.control.square",
"code": "square",
"desc": "由4个点组成的正方形",
"from": "100000",
"define": {
ext: {
sample: {
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,text:1});
}`
]
}
}
}
};
const __vite_glob_0_33$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: squareText
}, Symbol.toStringTag, { value: "Module" }));
const square = {
"id": "100000",
"name": "ddei.control.square",
"code": "square",
"desc": "由4个点组成的正方形",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: true,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0,op2close = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
op2close = 1
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,r:sample.r,select:1,clip:1,oppoint:2,op2close:op2close,align:1,stroke:1,fill:1});
}`
]
}
}
};
const __vite_glob_0_34$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: square
}, Symbol.toStringTag, { value: "Module" }));
const text = {
"id": "100200",
"name": "ddei.control.text",
"code": "text",
"desc": "跟随内容变化大小的文本",
"from": "100002",
"define": {
borderType: 0,
border: {
type: 0,
selected: {
type: 1,
dash: [5, 5],
width: 1
}
},
fill: {
type: 0
},
text: "ddei.property.text",
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.text",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.lockWidth",
"textStyle.paddingWeight",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
},
{
name: "ddei.border",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
}
]
},
{
name: "ddei.data",
icon: "icon-edit-properies",
subGroups: [
{
name: "ddei.basic",
attrs: ["code", "text", "fmt.type", "fmt.nscale", "fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.mrmb", "fmt.dtype", "fmt.format"]
}
]
}
],
attrs: [
{
"code": "textStyle.paddingWeight",
"name": "ddei.property.paddingWeight",
"desc": "超范围自动扩展的情况下保留的宽度",
"controlType": "text",
"dataType": "integer",
"defaultValue": 10,
"hiddenTitle": true,
"display": "column",
"type": [1, 2]
},
{
"code": "textStyle.scale",
"name": "ddei.property.outSize",
"desc": "文本的超出范围后的策略",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.hidden", "value": "0" }, { "text": "ddei.property.ds.ellipsis", "value": "2" }, { "text": "ddei.property.ds.narrow", "value": "1" }, { "text": "ddei.property.ds.ext", "value": "3" }],
"defaultValue": 3,
"cascadeDisplay": { 3: { show: ["textStyle.lockWidth", "textStyle.paddingWeight"], hidden: [] }, default: { show: ["textStyle.lockWidth", "textStyle.paddingWeight"] }, empty: { hidden: ["textStyle.lockWidth", "textStyle.paddingWeight"] }, notempty: { hidden: ["textStyle.lockWidth", "textStyle.paddingWeight"] } }
}
]
}
}
};
const __vite_glob_0_35$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: text
}, Symbol.toStringTag, { value: "Module" }));
const trapezoidRound = {
"id": "100061",
"name": "ddei.control.trapezoid",
"code": "trapezoid",
"desc": "由4个点组成的梯形",
"from": "100060",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_36$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: trapezoidRound
}, Symbol.toStringTag, { value: "Module" }));
const trapezoid = {
"id": "100060",
"name": "ddei.control.trapezoid",
"code": "trapezoid",
"desc": "由4个点组成的梯形",
"from": "100500",
"define": {
width: 160,
height: 80,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: true,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0,op2close = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
sample.x+=20
break;
case 3:
op2close = 1
pvs[2].y=sample.y
sample.x = pvs[0].x-20
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,oppoint:2,op2close:op2close,select:1,clip:1,stroke:1,fill:1});
}`,
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
sample.x -= 20
break;
case 1:
pvs[0].y=sample.y
sample.x += 20
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,text:1});
}`
]
}
}
};
const __vite_glob_0_37$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: trapezoid
}, Symbol.toStringTag, { value: "Module" }));
const triangleLeft90Round = {
"id": "100014",
"name": "ddei.control.triangle-left-90",
"code": "triangle",
"desc": "由三个点构成的三角形",
"from": "100011",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_38$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: triangleLeft90Round
}, Symbol.toStringTag, { value: "Module" }));
const triangleLeft90 = {
"id": "100011",
"name": "ddei.control.triangle-left-90",
"code": "triangle",
"desc": "由三个点构成的三角形",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈1次采样
loop: 1,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
pvs.push({begin:1,x:50,y:50,select:1,clip:1});
pvs.push({x:-50,y:50,select:1,clip:1});
pvs.push({x:-50,y:-50,select:1,clip:1});
pvs.push({end:1,x:50,y:-50,select:1,clip:1});
}`,
`(i, sample, pvs, model, ovs){
pvs.push({begin:1,x:50,y:50,oppoint:2,align:1,stroke:1,fill:1});
pvs.push({x:-50,y:50,oppoint:2,align:1,stroke:1,fill:1});
pvs.push({end:1,x:-50,y:-50,oppoint:2,op2close:1,align:1,stroke:1,fill:1});
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:-50,y:50,text:1});
pvs.push({x:0,y:50,text:1});
pvs.push({x:0,y:0,text:1});
pvs.push({end:1,x:-50,y:0,text:1});
}
}`
]
}
}
};
const __vite_glob_0_39$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: triangleLeft90
}, Symbol.toStringTag, { value: "Module" }));
const triangleRight90Round = {
"id": "100015",
"name": "ddei.control.triangle-right-90",
"code": "triangle",
"desc": "由三个点构成的三角形",
"from": "100012",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_40$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: triangleRight90Round
}, Symbol.toStringTag, { value: "Module" }));
const triangleRight90 = {
"id": "100012",
"name": "ddei.control.triangle-right-90",
"code": "triangle",
"desc": "由三个点构成的三角形",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈1次采样
loop: 1,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
pvs.push({begin:1,x:50,y:50,select:1,clip:1});
pvs.push({x:-50,y:50,select:1,clip:1});
pvs.push({x:-50,y:-50,select:1,clip:1});
pvs.push({end:1,x:50,y:-50,select:1,clip:1});
}`,
`(i, sample, pvs, model, ovs){
pvs.push({begin:1,x:50,y:50,oppoint:2,align:1,stroke:1,fill:1});
pvs.push({x:-50,y:50,oppoint:2,align:1,stroke:1,fill:1});
pvs.push({end:1,x:50,y:-50,oppoint:2,op2close:1,align:1,stroke:1,fill:1});
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:50,y:50,text:1});
pvs.push({x:0,y:50,text:1});
pvs.push({x:0,y:0,text:1});
pvs.push({end:1,x:50,y:0,text:1});
}
}`
]
}
}
};
const __vite_glob_0_41$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: triangleRight90
}, Symbol.toStringTag, { value: "Module" }));
const triangleRound = {
"id": "100013",
"name": "ddei.control.triangle",
"code": "triangle",
"desc": "由三个点构成的三角形",
"from": "100010",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_42$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: triangleRound
}, Symbol.toStringTag, { value: "Module" }));
const triangle = {
"id": "100010",
"name": "ddei.control.triangle",
"code": "triangle",
"desc": "由三个点构成的三角形",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
eqrat: true,
//一圈12次采样
loop: 12,
//初始次采样的开始角度
angle: -90,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
if(i % 4 == 0){
let op2close = 0
if(i == 8){
op2close = 1
}
pvs.push({begin:i == 0,end:i == 8,x:sample.x,y:sample.y,clip:1,oppoint:2,op2close:op2close,stroke:1,fill:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i % 3 == 0){
let er = sample.r/2
let x = er * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = er * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({begin:i == 0,end:i == 9,x:x,y:y,text:1});
}
}`,
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let sita = 45;
let rad = sita * DDeiConfig.ROTATE_UNIT
let cos = parseFloat(Math.cos(rad).toFixed(4))
let sin = parseFloat(Math.sin(rad).toFixed(4))
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let x = er * cos
let y = er * sin
pvs.push({x:x,y:y,r:er,select:1});
sita = 135;
rad = sita * DDeiConfig.ROTATE_UNIT
cos = parseFloat(Math.cos(rad).toFixed(4))
sin = parseFloat(Math.sin(rad).toFixed(4))
er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
x = er * cos
y = er * sin
pvs.push({x:x,y:y,r:er,select:1});
sita = 225;
rad = sita * DDeiConfig.ROTATE_UNIT
cos = parseFloat(Math.cos(rad).toFixed(4))
sin = parseFloat(Math.sin(rad).toFixed(4))
er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
x = er * cos
y = er * sin
pvs.push({x:x,y:y,r:er,select:1});
sita = 315;
rad = sita * DDeiConfig.ROTATE_UNIT
cos = parseFloat(Math.cos(rad).toFixed(4))
sin = parseFloat(Math.sin(rad).toFixed(4))
er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
x = er * cos
y = er * sin
pvs.push({x:x,y:y,r:er,select:1});
}
}`
]
},
iconPos: {
dy: 10
}
}
};
const __vite_glob_0_43$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: triangle
}, Symbol.toStringTag, { value: "Module" }));
const flowCardTab = {
"id": "102053",
"name": "ddei.control.card",
"code": "fct",
"desc": "流程的卡片",
"from": "100500",
"define": {
width: 110,
height: 70,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let weight = 20
switch(i){
case 0:
pvs.push({begin:1,x:sample.x,y:sample.y,select:1,clip:1,text:1,stroke:1,oppoint:2,fill:1});
break;
case 1:
pvs[0].y=sample.y
pvs.push({x:sample.x,y:sample.y,select:1,clip:1,text:1,stroke:1,oppoint:2,fill:1});
break;
case 2:
pvs[1].x=sample.x
pvs.push({x:sample.x,y:sample.y,select:1,clip:1,text:1,stroke:1,oppoint:2,fill:1});
break;
case 3:
pvs[2].y=sample.y+weight
pvs.push({x:pvs[2].x+weight,y:sample.y,select:1,clip:1,stroke:1,oppoint:2,fill:1});
sample.x = pvs[0].x
pvs.push({x:sample.x,y:sample.y,select:1,clip:1,stroke:1,fill:1,oppoint:2,op2close:1,end:1});
pvs.push({x:sample.x,y:pvs[2].y,text:1,type:0});
break;
}
}`
]
}
}
};
const __vite_glob_0_44$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowCardTab
}, Symbol.toStringTag, { value: "Module" }));
const flowControlTransfer = {
"id": "102058",
"name": "ddei.control.controltran",
"code": "ctran",
"desc": "控制传递",
"from": "100401",
"define": {
type: 2,
ep: {
type: 1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
],
cpv: {
x: 0,
y: 0
},
//组合控件
composes: [
{
width: 30,
height: 30,
id: "100120",
cIndex: 1,
initCPV: {
x: 0,
y: 0,
z: 1
}
}
],
//操作点
ovs: [
{
x: 0,
y: 0,
ix: 0,
iy: 0,
//约束,控制点的移动路径和位置
constraint: {
type: 1,
//跟随线段
pvs: ["pvs"]
//当前对象的pvs
// type: 5, //不允许移动,固定路径位置,沿路径方向,固定在等比例或者等长度位置(长度不足则按照0.5比例位置)
// pvs: ["pvs[0]","pvs[1]"],//定义路径
// rate:0.5, //固定比例
// len: 0 //固定长度
},
//联动,点移动后控制的其它点
links: [
{
type: 1,
//1施加矩阵
// type:2,//同步中心点
pvs: ["composes[0]"]
}
]
}
]
}
};
const __vite_glob_0_45$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowControlTransfer
}, Symbol.toStringTag, { value: "Module" }));
const flowData = {
"id": "102030",
"name": "ddei.data",
"code": "fdata",
"desc": "流程的数据节点",
"from": "100500",
"define": {
width: 150,
height: 90,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 45,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
`(i,sample, pvs, model){
let ds = i == 2 || i ==3 ? 5: -5
let x = sample.x+ds
let y = sample.y
let op2close = i == 3 ? 1 :0
pvs.push({begin:i==0,end:i==3, x: x, y: y,select:1,clip:1,fill:1,stroke:1,oppoint:2,op2close:op2close });
}`,
`(i,sample, pvs, model){
let ds = i == 1 || i ==2 ? 5: -5
let x = sample.x+ds
let y = sample.y
pvs.push({ begin:i==0,end:i==3, x: x, y: y,text:1 });
}`
]
}
}
};
const __vite_glob_0_46$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowData
}, Symbol.toStringTag, { value: "Module" }));
const flowData1 = {
"id": "102031",
"name": "ddei.data",
"code": "fdata",
"desc": "流程的数据节点",
"from": "102030",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_47$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowData1
}, Symbol.toStringTag, { value: "Module" }));
const flowData2 = {
"id": "102032",
"name": "ddei.control.store-data",
"code": "fdata",
"desc": "流程的数据节点",
"from": "102030",
"define": {
width: 100,
height: 70,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
//一圈采样次数
loop: 1,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let dr = -50/ Math.cos(45 * DDeiConfig.ROTATE_UNIT)
pvs.push({begin:1,x:-dr,y:50,select:1})
pvs.push({x:dr,y:50,select:1})
pvs.push({x:dr,y:-50,select:1})
pvs.push({end:1,x:-dr,y:-50,select:1})
}`,
//操作点
`(i, sample, pvs, model, ovs){
let dr = 50/ Math.cos(45 * DDeiConfig.ROTATE_UNIT)
pvs.push({x:100-dr,y:0,oppoint:1})
pvs.push({x:-dr,y:0,oppoint:1})
pvs.push({x:0,y:50,oppoint:1})
pvs.push({x:0,y:-50,oppoint:1})
}`,
//主体区域
`(i, sample, pvs, model, ovs){
let dr = 50/ Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad1 = 135 * DDeiConfig.ROTATE_UNIT
let rad2 = 225 * DDeiConfig.ROTATE_UNIT
pvs.push({begin:1,x:50,y:50,stroke:1,fill:1,clip:1})
pvs.push({x:-50,y:50,r:dr,rad:rad1,stroke:1,fill:1,clip:1})
pvs.push({x:-50,y:-50,type:2,r:dr,rad:rad2,direct:1,stroke:1,fill:1,clip:1})
pvs.push({x:50,y:-50,r:dr,rad:rad2,stroke:1,fill:1,clip:1})
pvs.push({end:1,dx:100,type:2,r:dr,rad:rad1,direct:0,stroke:1,fill:1,clip:1})
}`,
//文本区域
`(i, sample, pvs, model, ovs){
let dr = 50/ Math.cos(45 * DDeiConfig.ROTATE_UNIT)
pvs.push({begin:1,x:100-dr,y:50,text:1})
pvs.push({x:-50,y:50,text:1})
pvs.push({x:-50,y:-50,text:1})
pvs.push({end:1,x:100-dr,y:-50,text:1})
}`
]
},
iconPos: {
dw: 15
}
}
};
const __vite_glob_0_48$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowData2
}, Symbol.toStringTag, { value: "Module" }));
const flowData3 = {
"id": "102033",
"name": "ddei.control.seq-data",
"code": "sqdata",
"desc": "流程的顺序数据节点",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT) + 2
let x = er * sample.cos
let y = er * sample.sin
pvs.push({x:x,y:y,r:er,select:1});
}`,
//操作点
`(i, sample, pvs, model, ovs){
let x = sample.r * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = sample.r * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y,r:sample.r ,oppoint:1});
}`,
//绘制线段、填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:50,y:50});
pvs.push({y:50,x:0,stroke:1,type:1,end:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({r:sample.r,stroke:1,fill:1,begin:1,end:1});
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
pvs.push({x:sample.x,y:sample.y,r:sample.r,text:1});
}`
]
}
}
};
const __vite_glob_0_49$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowData3
}, Symbol.toStringTag, { value: "Module" }));
const flowDefflow = {
"id": "102041",
"name": "ddei.control.defined-flow",
"code": "defflow",
"desc": "流程的子流程节点",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 45,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
pvs.push({ begin:i==0,end:i==3,x: sample.x, y: sample.y,select:1,clip:1,stroke:1,fill:1 });
}`,
`(i, sample, pvs, model, ovs){
let er = sample.r
let x = sample.x
let y = sample.y
let op2close = i == 3?1:0
pvs.push({x:x,y:y,r:er,type:0,oppoint:2,op2close:op2close});
}`,
`(i, sample, pvs, model, ovs){
if(i == 1){
pvs.push({begin:1, x: sample.x, y: sample.y,stroke:1});
}else if(i == 2){
pvs[3] = {end:1, x: sample.x, y: sample.y,stroke:1};
pvs[1] = { x: sample.x+10, y: sample.y,stroke:1};
pvs[2] = { x: pvs[0].x+10, y: pvs[0].y,stroke:1};
}
}`,
`(i, sample, pvs, model, ovs){
let ds = i == 1 || i ==2 ? 10: -10
let x = sample.x+ds
let y = sample.y
pvs.push({ begin:i==0,end:i==3,x: x, y: y,text:1,stroke:1 });
}`
]
}
}
};
const __vite_glob_0_50$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowDefflow
}, Symbol.toStringTag, { value: "Module" }));
const flowDelay = {
"id": "102055",
"name": "ddei.control.delay",
"code": "fdy",
"desc": "数据库图标",
"from": "100500",
"define": {
width: 80,
height: 80,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:100,y:50,select:1,clip:1})
pvs.push({x:-50,y:50,select:1,clip:1})
pvs.push({x:-50,y:-50,select:1,clip:1})
pvs.push({end:1,x:100,y:-50,select:1,clip:1})
}
}`,
//操作点
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:100,y:0,oppoint:1})
pvs.push({x:0,y:50,oppoint:1})
pvs.push({x:-50,y:0,oppoint:1})
pvs.push({end:1,x:0,y:-50,oppoint:1})
}
}`,
//绘制线段区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
let rad90 = 90 * DDeiConfig.ROTATE_UNIT
switch(i){
case 0:
pvs.push({begin:1,x:x,y:y,fill:1,stroke:1,r:er,rad:0});
break;
case 1:
pvs.push({x:x,y:y,fill:1,stroke:1});
break;
case 2:
pvs.push({x:x,y:y,fill:1,stroke:1,r:er,rad:rad90});
break;
case 3:
pvs.push({x:x,y:y,fill:1,stroke:1,r:er,rad:-rad90});
pvs.push({r:er,dx:50,rad:rad90,stroke:1,type:4,direct:1,end:1});
pvs.push({r:sample.r});
pvs.push({r:sample.r});
break;
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:50,y:50,text:1})
pvs.push({x:-50,y:50,text:1})
pvs.push({x:-50,y:-50,text:1})
pvs.push({end:1,x:50,y:-50,text:1})
}
}`
]
},
iconPos: {
dx: -20,
dw: 10
}
}
};
const __vite_glob_0_51$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowDelay
}, Symbol.toStringTag, { value: "Module" }));
const flowDisplayContent = {
"id": "102056",
"name": "ddei.control.display",
"code": "fdc",
"desc": "显示内容",
"from": "100500",
"define": {
width: 80,
height: 80,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:135,y:50,select:1,clip:1})
pvs.push({x:-135,y:50,select:1,clip:1})
pvs.push({x:-135,y:-50,select:1,clip:1})
pvs.push({end:1,x:135,y:-50,select:1,clip:1})
}
}`,
//操作点
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:65,y:0,oppoint:1})
pvs.push({x:0,y:50,oppoint:1})
pvs.push({x:-135,y:0,oppoint:1})
pvs.push({end:1,x:0,y:-50,oppoint:1})
}
}`,
//绘制线段区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
let rad90 = 90 * DDeiConfig.ROTATE_UNIT
switch(i){
case 0:
pvs.push({begin:1,x:x-10,y:y,fill:1,stroke:1,r:er,rad:0});
break;
case 1:
pvs.push({x:x,y:y,fill:1,stroke:1});
break;
case 2:
pvs.push({x:-135,y:0,fill:1,stroke:1});
pvs.push({x:x,y:y,fill:1,stroke:1});
break;
case 3:
pvs.push({x:x-10,y:y,fill:1,stroke:1,r:er,rad:-rad90,rd:0});
pvs.push({r:er,dx:40,rad:rad90,stroke:1,type:4,direct:1,end:1});
pvs.push({r:25});
pvs.push({r:sample.r});
break;
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:50,y:50,text:1})
pvs.push({x:-50,y:50,text:1})
pvs.push({x:-50,y:-50,text:1})
pvs.push({end:1,x:50,y:-50,text:1})
}
}`
]
},
iconPos: {
dx: 20,
dw: 10
},
border: {
round: 5
}
}
};
const __vite_glob_0_52$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowDisplayContent
}, Symbol.toStringTag, { value: "Module" }));
const flowEnd = {
"id": "102090",
"name": "ddei.control.end",
"code": "end",
"desc": "流程的开始节点",
"from": "102001",
"define": {
width: 40,
height: 40,
fill: {
color: "black"
},
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
}
};
const __vite_glob_0_53$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowEnd
}, Symbol.toStringTag, { value: "Module" }));
const flowEnd1 = {
"id": "102091",
"name": "ddei.control.end",
"code": "end",
"desc": "流程的开始节点",
"from": "100003",
"define": {
width: 40,
height: 40,
cIndex: 1,
composes: [
{
id: "102090",
width: 30,
height: 30,
cIndex: 2,
attrLinks: [
{ code: "fill", mapping: ["*"] },
{ code: "border", mapping: ["*"] }
]
}
],
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
}
};
const __vite_glob_0_54$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowEnd1
}, Symbol.toStringTag, { value: "Module" }));
const flowEnd2 = {
"id": "102092",
"name": "ddei.control.end",
"code": "end",
"desc": "流程的开始节点",
"from": "100003",
"define": {
width: 40,
height: 40,
fill: {
color: "red"
},
border: {
type: 0
},
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
}
};
const __vite_glob_0_55$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowEnd2
}, Symbol.toStringTag, { value: "Module" }));
const flowEnd3 = {
"id": "102093",
"name": "ddei.control.end",
"code": "end",
"desc": "流程的开始节点",
"from": "100003",
"define": {
width: 40,
height: 40,
cIndex: 1,
composes: [
{
id: "102001",
width: 30,
height: 30,
cIndex: 2,
attrLinks: [
{ code: "fill", mapping: ["*"] },
{ code: "border", mapping: ["*"] }
]
}
],
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
}
]
}
]
}
}
};
const __vite_glob_0_56$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowEnd3
}, Symbol.toStringTag, { value: "Module" }));
const flowHandInput = {
"id": "102052",
"name": "ddei.control.manualinput",
"code": "fhi",
"desc": "流程的手动输入节点",
"from": "100500",
"define": {
width: 110,
height: 70,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let weight = 20
switch(i){
case 0:
pvs.push({begin:1,x:sample.x,y:sample.y,select:1,clip:1,text:1,stroke:1,oppoint:2,fill:1});
break;
case 1:
pvs[0].y=sample.y
pvs.push({x:sample.x,y:sample.y,select:1,clip:1,text:1,stroke:1,oppoint:2,fill:1});
break;
case 2:
pvs[1].x=sample.x
pvs.push({x:sample.x,y:sample.y,select:1,clip:1,text:1,stroke:1,oppoint:2,fill:1});
break;
case 3:
pvs[2].y=sample.y+weight
sample.x = pvs[0].x
pvs.push({x:sample.x,y:sample.y,select:1,clip:1,stroke:1,fill:1,oppoint:2,op2close:1,end:1});
pvs.push({x:sample.x,y:pvs[2].y,text:1,type:0});
break;
}
}`
]
}
}
};
const __vite_glob_0_57$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowHandInput
}, Symbol.toStringTag, { value: "Module" }));
const flowLoopArea = {
"id": "102050",
"name": "ddei.control.looparea",
"code": "fla",
"desc": "流程的循环界限",
"from": "100500",
"define": {
width: 110,
height: 70,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let weight = 20
switch(i){
case 0:
pvs.push({begin:1,x:sample.x,y:sample.y,select:1,clip:1,text:1,oppoint:2,stroke:1,fill:1});
break;
case 1:
pvs[0].y=sample.y
pvs.push({x:sample.x,y:sample.y,select:1,clip:1,text:1,stroke:1,oppoint:2,fill:1});
break;
case 2:
pvs[1].x=sample.x
pvs.push({x:sample.x,y:sample.y,select:1,clip:1,text:1,stroke:1,oppoint:2,fill:1});
break;
case 3:
pvs[2].y=sample.y+weight
pvs.push({x:pvs[2].x+weight,y:sample.y,select:1,clip:1,stroke:1,oppoint:2,fill:1});
sample.x = pvs[0].x
pvs.push({x:sample.x-weight,y:sample.y,select:1,clip:1,stroke:1,oppoint:2,fill:1});
pvs.push({x:sample.x,y:sample.y+weight,select:1,clip:1,text:1,stroke:1,oppoint:2,op2close:1,fill:1,end:1});
break;
}
}`
]
}
}
};
const __vite_glob_0_58$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowLoopArea
}, Symbol.toStringTag, { value: "Module" }));
const flowManualOperate = {
"id": "102057",
"name": "ddei.control.manualoperate",
"code": "fmo",
"desc": "由人工手动完成的节点",
"from": "100500",
"define": {
width: 140,
height: 70,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: true,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
sample.x -= 20
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x = sample.x+20
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x+20
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,oppoint:2,op2close:i == 3 ? 1 :0,select:1,clip:1,stroke:1,fill:1});
}`,
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
sample.x +=20
pvs[1].x = sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,text:1});
}`
]
}
}
};
const __vite_glob_0_59$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowManualOperate
}, Symbol.toStringTag, { value: "Module" }));
const flowPageRef = {
"id": "102051",
"name": "ddei.control.pageref",
"code": "fpr",
"desc": "流程的跨页引用",
"from": "100500",
"define": {
width: 70,
height: 70,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
switch(i){
case 0:
pvs.push({begin:1,x:sample.x,y:sample.y,select:1,clip:1,text:1,oppoint:2,stroke:1,fill:1});
break;
case 1:
pvs.push({x:sample.x,y:sample.y,select:1,clip:1,stroke:1,oppoint:2,fill:1});
break;
case 2:
pvs.push({x:sample.x,y:sample.y,select:1,clip:1,text:1,oppoint:2,stroke:1,fill:1});
break;
case 3:
pvs.push({x:-pvs[0].x,y:sample.y,select:1,clip:1,text:1,oppoint:2,stroke:1,fill:1});
pvs.push({x:pvs[0].x,y:sample.y,select:1,clip:1,text:1,oppoint:2,op2close:1,stroke:1,fill:1,end:1});
break;
}
}`
]
}
}
};
const __vite_glob_0_60$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowPageRef
}, Symbol.toStringTag, { value: "Module" }));
const flowPrepare = {
"id": "102054",
"name": "ddei.control.prepare",
"code": "prepare",
"desc": "流程的准备",
"from": "100030",
"define": {
width: 100,
height: 70
}
};
const __vite_glob_0_61$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowPrepare
}, Symbol.toStringTag, { value: "Module" }));
const flowStart = {
"id": "102001",
"name": "ddei.control.start",
"code": "start",
"desc": "流程的开始节点",
"from": "100103",
"define": {
width: 40,
height: 40
}
};
const __vite_glob_0_62$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowStart
}, Symbol.toStringTag, { value: "Module" }));
const flowStart1 = {
"id": "102002",
"name": "ddei.control.start",
"code": "start",
"desc": "流程的开始节点",
"from": "102001",
"define": {
width: 100,
height: 50
}
};
const __vite_glob_0_63$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowStart1
}, Symbol.toStringTag, { value: "Module" }));
const flowSubflow = {
"id": "102040",
"name": "ddei.control.subflow",
"code": "subflow",
"desc": "流程的子流程节点",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 45,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
pvs.push({ begin:i==0,end:i==3,x: sample.x, y: sample.y,select:1,clip:1,stroke:1,fill:1 });
}`,
`(i, sample, pvs, model, ovs){
let er = sample.r
let x = sample.x
let y = sample.y
pvs.push({x:x,y:y,r:er,type:0,oppoint:2,op2close:i == 3 ? 1: 0});
}`,
`(i, sample, pvs, model, ovs){
let ds = i == 1 || i ==2 ? 10: -10
let x = sample.x+ds
let y = sample.y
pvs.push({ begin:i==0,end:i==3,x: x, y: y,text:1,stroke:1 });
}`
]
}
}
};
const __vite_glob_0_64$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowSubflow
}, Symbol.toStringTag, { value: "Module" }));
const flowSwitch = {
"id": "102020",
"name": "ddei.control.switch",
"code": "switch",
"desc": "流程的分支节点",
"from": "100040",
"define": {
width: 110,
height: 70
}
};
const __vite_glob_0_65$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowSwitch
}, Symbol.toStringTag, { value: "Module" }));
const flowSwitch1 = {
"id": "102021",
"name": "ddei.control.switch",
"code": "switch",
"desc": "流程的分支节点",
"from": "102020",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_66$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowSwitch1
}, Symbol.toStringTag, { value: "Module" }));
const flowTask = {
"id": "102010",
"name": "ddei.control.task",
"code": "task",
"desc": "流程的任务节点",
"from": "100002",
"define": {
width: 110,
height: 70
}
};
const __vite_glob_0_67$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowTask
}, Symbol.toStringTag, { value: "Module" }));
const flowTask1 = {
"id": "102011",
"name": "ddei.control.task",
"code": "task",
"desc": "流程的任务节点",
"from": "102010",
"define": {
border: {
round: 5
}
}
};
const __vite_glob_0_68$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowTask1
}, Symbol.toStringTag, { value: "Module" }));
const flowTask2 = {
"id": "102012",
"name": "ddei.control.start-or-end",
"code": "flowsoe",
"desc": "流程的开始或结束节点",
"from": "102010",
"define": {
height: 60,
width: 100,
border: {
round: 15
}
}
};
const __vite_glob_0_69$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: flowTask2
}, Symbol.toStringTag, { value: "Module" }));
const bidfunnel = {
"id": "103007",
"name": "ddei.control.bindfunnel",
"code": "bidfunnel",
"desc": "双向漏斗",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
//采样信息
sample: {
//一圈采样次数
loop: 6,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i !=0 && i != 3){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let x = er * sample.cos
let y = er * sample.sin
pvs.push({begin:i == 1,end:i == 5,x:x,y:y,select:1,clip:1});
}
}`,
//主体图形
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let x = er * sample.cos
let y = er * sample.sin
switch(i){
case 1:
pvs.push({begin:1,x:x,y:y,oppoint:2,clip:1,stroke:1,fill:1});
break;
case 2:
pvs.push({x:x,y:y,oppoint:2,clip:1,stroke:1,fill:1});
pvs.push({x:0,y:0,oppoint:1,clip:1,stroke:1,fill:1});
break;
case 4:
pvs.push({end:1,x:x,y:y,oppoint:2,op2close:1,clip:1,stroke:1,fill:1});
break;
case 5:
pvs.splice(3,0,{x:x,y:y,oppoint:2,clip:1,stroke:1,fill:1})
break;
}
}`
]
}
}
};
const __vite_glob_0_70$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bidfunnel
}, Symbol.toStringTag, { value: "Module" }));
const bracketBigLeftText = {
"id": "104124",
"name": "ddei.control.big-bracket",
"code": "bmt",
"desc": "左大括号,带文本编辑",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,oppoint:2,op2close:i == 3 ? 1 : 0,select:1,clip:1});
}`
]
},
//组合控件
composes: [
{
width: 30,
height: 100,
id: "104122",
cIndex: 2,
initCPV: {
x: -65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 150,
height: 95,
id: "100002",
cIndex: 1,
initCPV: {
x: 5,
y: 0,
z: 1
},
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
feed: 1,
scale: 1,
align: 1
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
],
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_71$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketBigLeftText
}, Symbol.toStringTag, { value: "Module" }));
const bracketBigLeft = {
"id": "104122",
"name": "ddei.control.big-bracket",
"code": "bb",
"desc": "由极坐标系构造的右大括号,不带任何文本",
"from": "104121",
"define": {
width: 50,
height: 100,
ext: {
//采样信息
sample: {
direct: 4
}
}
}
};
const __vite_glob_0_72$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketBigLeft
}, Symbol.toStringTag, { value: "Module" }));
const bracketBigRightText = {
"id": "104123",
"name": "ddei.control.big-bracket",
"code": "bbt",
"desc": "右大括号,带文本编辑",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,oppoint:2,op2close:i == 3 ? 1 : 0,select:1,clip:1});
}`
]
},
//组合控件
composes: [
{
width: 30,
height: 100,
id: "104121",
cIndex: 2,
initCPV: {
x: 65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 150,
height: 95,
id: "100002",
cIndex: 1,
initCPV: {
x: -5,
y: 0,
z: 1
},
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
feed: 1,
scale: 1,
align: 3
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
],
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_73$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketBigRightText
}, Symbol.toStringTag, { value: "Module" }));
const bracketBigRight = {
"id": "104121",
"name": "ddei.control.big-bracket",
"code": "bb",
"desc": "由极坐标系构造的右大括号,不带任何文本",
"from": "100500",
"define": {
width: 50,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//方向,上右下左1,2,3,4
direct: 2,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let deltaRotate = 0
switch(sample.direct){
case 1:
deltaRotate = -90
break;
case 3:
deltaRotate = -270
break;
case 4:
deltaRotate = -180
break;
}
let rad1 = (72+deltaRotate) * DDeiConfig.ROTATE_UNIT
let rad2 = (-72+deltaRotate) * DDeiConfig.ROTATE_UNIT
let rad0 = (deltaRotate) * DDeiConfig.ROTATE_UNIT
let x0 = sample.r * Math.cos(rad0)
let y0 = sample.r * Math.sin(rad0)
let x1 = sample.r * Math.cos(rad1)
let y1 = sample.r * Math.sin(rad1)
let x2 = sample.r * Math.cos(rad2)
let y2 = sample.r * Math.sin(rad2)
switch(sample.direct){
case 1:
pvs.push({begin:1,x:x2,y:y1+10,type:3});
pvs.push({x:x2,y:y1+10,type:5,stroke:1});
pvs.push({x:x2-2,y:y0+10});
pvs.push({x:(x2+10)/2,y:y0+25});
pvs.push({x:-10,y:y0+20});
pvs.push({x:-10,y:y0+20,type:5,stroke:1});
pvs.push({x:-3,y:y0+18});
pvs.push({x:0,y:y0+10});
pvs.push({x:0,y:y0});
pvs.push({x:0,y:y0,stroke:1,type:5});
pvs.push({x:0,y:y0+10});
pvs.push({x:3,y:y0+18});
pvs.push({x:10,y:y0+20});
pvs.push({x:10,y:y0+20,stroke:1,type:5});
pvs.push({x:(x1-10)/2,y:y0+25});
pvs.push({x:x1+2,y:y0+10});
pvs.push({x:x1,y:y2+10});
pvs.push({x:x1,y:y1+10,type:0,oppoint:1,select:1});
pvs.push({x:x2,y:y2+10,type:0,oppoint:1,select:1});
pvs.push({x:0,y:y0,type:0,oppoint:1});
pvs.push({x:0,y:y2+10,type:0,oppoint:1});
pvs.push({x:x2,y:y0,type:0,select:1});
pvs.push({x:x1,y:y0,type:0,select:1});
break;
case 2:
//由4段贝塞尔曲线构造
pvs.push({begin:1,x:x2-10,y:y2,type:3});
pvs.push({x:x2-10,y:y2,type:5,stroke:1});
pvs.push({x:x0-10,y:y2-2});
pvs.push({x:x0-25,y:(y2-10)/2});
pvs.push({x:x0-20,y:-10});
pvs.push({x:x0-20,y:-10,stroke:1,type:5});
pvs.push({x:x0-18,y:-3});
pvs.push({x:x0-10,y:0});
pvs.push({x:x0,y:0});
pvs.push({x:x0,y:0,stroke:1,type:5});
pvs.push({x:x0-10,y:0});
pvs.push({x:x0-18,y:3});
pvs.push({x:x0-20,y:10});
pvs.push({x:x0-20,y:10,stroke:1,type:5});
pvs.push({x:x0-25,y:(y1-10)/2});
pvs.push({x:x0-10,y:y1+2});
pvs.push({x:x2-10,y:y1});
pvs.push({x:x1-10,y:y1,type:0,oppoint:1,select:1});
pvs.push({x:x2-10,y:y2,type:0,oppoint:1,select:1});
pvs.push({x:x0,y:0,type:0,oppoint:1});
pvs.push({x:x2-10,y:0,type:0,oppoint:1});
pvs.push({x:x0,y:y2,type:0,select:1});
pvs.push({x:x0,y:y1,type:0,select:1});
break;
case 3:
//由4段贝塞尔曲线构造
pvs.push({begin:1,x:x1,y:y1-10,type:3});
pvs.push({x:x1,y:y1-10,type:5,stroke:1});
pvs.push({x:x1-2,y:y0-10});
pvs.push({x:(x1+10)/2,y:y0-25});
pvs.push({x:-10,y:y0-20});
pvs.push({x:-10,y:y0-20,type:5,stroke:1});
pvs.push({x:-3,y:y0-18});
pvs.push({x:0,y:y0-10});
pvs.push({x:0,y:y0});
pvs.push({x:0,y:y0,stroke:1,type:5});
pvs.push({x:0,y:y0-10});
pvs.push({x:3,y:y0-18});
pvs.push({x:10,y:y0-20});
pvs.push({x:10,y:y0-20,stroke:1,type:5});
pvs.push({x:(x2-10)/2,y:y0-25});
pvs.push({x:x2+2,y:y0-10});
pvs.push({x:x2,y:y2-10});
pvs.push({x:x1,y:y1-10,type:0,oppoint:1,select:1});
pvs.push({x:x2,y:y2-10,type:0,oppoint:1,select:1});
pvs.push({x:0,y:y0,type:0,oppoint:1});
pvs.push({x:0,y:y2-10,type:0,oppoint:1});
pvs.push({x:x2,y:y0,type:0,select:1});
pvs.push({x:x1,y:y0,type:0,select:1});
break;
case 4:
//由4段贝塞尔曲线构造
pvs.push({begin:1,x:x2+10,y:y1,type:3});
pvs.push({x:x2+10,y:y1,type:5,stroke:1});
pvs.push({x:x0+10,y:y1-2});
pvs.push({x:x0+25,y:(y1-10)/2});
pvs.push({x:x0+20,y:-10});
pvs.push({x:x0+20,y:-10,stroke:1,type:5});
pvs.push({x:x0+18,y:-3});
pvs.push({x:x0+10,y:0});
pvs.push({x:x0,y:0});
pvs.push({x:x0,y:0,stroke:1,type:5});
pvs.push({x:x0+10,y:0});
pvs.push({x:x0+18,y:3});
pvs.push({x:x0+20,y:10});
pvs.push({x:x0+20,y:10,stroke:1,type:5});
pvs.push({x:x0+25,y:(y2-10)/2});
pvs.push({x:x0+10,y:y2+2});
pvs.push({x:x2+10,y:y2});
pvs.push({x:x1+10,y:y2,type:0,oppoint:1,select:1});
pvs.push({x:x2+10,y:y1,type:0,oppoint:1,select:1});
pvs.push({x:x0,y:0,type:0,oppoint:1});
pvs.push({x:x2+10,y:0,type:0,oppoint:1});
pvs.push({x:x0,y:y1,type:0,select:1});
pvs.push({x:x0,y:y2,type:0,select:1});
break;
}
}
}`
]
},
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
}
};
const __vite_glob_0_74$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketBigRight
}, Symbol.toStringTag, { value: "Module" }));
const bracketBigText = {
"id": "104125",
"name": "ddei.control.big-bracket",
"code": "bmt",
"desc": "左右大括号,带文本编辑",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,select:1,oppoint:2,op2close:i == 3 ? 1 : 0,clip:1});
}`
]
},
//组合控件
composes: [
{
width: 30,
height: 100,
id: "104122",
cIndex: 2,
initCPV: {
x: -65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 30,
height: 100,
id: "104121",
cIndex: 2,
initCPV: {
x: 65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 140,
height: 95,
id: "100002",
cIndex: 1,
initCPV: {
x: 0,
y: 0,
z: 1
},
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
feed: 1,
scale: 1
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
],
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_75$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketBigText
}, Symbol.toStringTag, { value: "Module" }));
const bracketMiddleLeftText = {
"id": "104114",
"name": "ddei.control.middle-bracket",
"code": "bmt",
"desc": "左中括号,带文本编辑",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,oppoint:2,op2close:i == 3 ? 1 : 0,select:1,clip:1});
}`
]
},
//组合控件
composes: [
{
width: 30,
height: 100,
id: "104112",
cIndex: 2,
initCPV: {
x: -65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 150,
height: 95,
id: "100002",
cIndex: 1,
initCPV: {
x: 5,
y: 0,
z: 1
},
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
feed: 1,
scale: 1,
align: 1
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
],
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_76$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketMiddleLeftText
}, Symbol.toStringTag, { value: "Module" }));
const bracketMiddleLeft = {
"id": "104112",
"name": "ddei.control.middle-bracket",
"code": "bm",
"desc": "由极坐标系构造的左中括号,不带任何文本",
"from": "104111",
"define": {
ext: {
sample: {
//方向,上右下左1,2,3,4
direct: 4
}
}
}
};
const __vite_glob_0_77$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketMiddleLeft
}, Symbol.toStringTag, { value: "Module" }));
const bracketMiddleRightText = {
"id": "104113",
"name": "ddei.control.middle-bracket",
"code": "bmt",
"desc": "右中括号,带文本编辑",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,oppoint:2,op2close:i == 3 ? 1 : 0,select:1,clip:1});
}`
]
},
//组合控件
composes: [
{
width: 30,
height: 100,
id: "104111",
cIndex: 2,
initCPV: {
x: 65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 150,
height: 95,
id: "100002",
cIndex: 1,
initCPV: {
x: -5,
y: 0,
z: 1
},
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
feed: 1,
scale: 1,
align: 3
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
],
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_78$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketMiddleRightText
}, Symbol.toStringTag, { value: "Module" }));
const bracketMiddleRight = {
"id": "104111",
"name": "ddei.control.middle-bracket",
"code": "bm",
"desc": "由极坐标系构造的右中括号,不带任何文本",
"from": "100500",
"define": {
width: 50,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//方向,上右下左1,2,3,4
direct: 2,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let deltaRotate = 0
switch(sample.direct){
case 1:
deltaRotate = -90
break;
case 3:
deltaRotate = -270
break;
case 4:
deltaRotate = -180
break;
}
let rad1 = (72+deltaRotate) * DDeiConfig.ROTATE_UNIT
let rad2 = (-72+deltaRotate) * DDeiConfig.ROTATE_UNIT
let rad0 = (deltaRotate) * DDeiConfig.ROTATE_UNIT
let x0 = sample.r * Math.cos(rad0)
let y0 = sample.r * Math.sin(rad0)
let x1 = sample.r * Math.cos(rad1)
let y1 = sample.r * Math.sin(rad1)
let x2 = sample.r * Math.cos(rad2)
let y2 = sample.r * Math.sin(rad2)
pvs.push({begin:1,x:x2,y:y2});
pvs.push({x:x0,y:y2,stroke:1});
pvs.push({x:x0,y:y1,stroke:1});
pvs.push({x:x1,y:y1,stroke:1});
pvs.push({x:x1,y:y1,type:0,oppoint:1,select:1});
pvs.push({x:x2,y:y2,type:0,oppoint:1,select:1});
pvs.push({x:x0,y:0,type:0,oppoint:1});
pvs.push({x:x2,y:0,type:0,oppoint:1});
pvs.push({x:x0,y:y2,type:0,select:1});
pvs.push({x:x0,y:y1,type:0,select:1});
}
}`
]
},
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
}
};
const __vite_glob_0_79$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketMiddleRight
}, Symbol.toStringTag, { value: "Module" }));
const bracketMiddleText = {
"id": "104115",
"name": "ddei.control.middle-bracket",
"code": "bmt",
"desc": "左右中括号,带文本编辑",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,select:1,oppoint:2,op2close:i == 3 ? 1 : 0,clip:1});
}`
]
},
//组合控件
composes: [
{
width: 30,
height: 100,
id: "104112",
cIndex: 2,
initCPV: {
x: -65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 30,
height: 100,
id: "104111",
cIndex: 2,
initCPV: {
x: 65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 140,
height: 95,
id: "100002",
cIndex: 1,
initCPV: {
x: 0,
y: 0,
z: 1
},
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
feed: 1,
scale: 1
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
],
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_80$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketMiddleText
}, Symbol.toStringTag, { value: "Module" }));
const bracketSmallLeftText = {
"id": "104104",
"name": "ddei.control.small-bracket",
"code": "bst",
"desc": "左小括号,带文本编辑",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,oppoint:2,op2close:i == 3 ? 1 : 0,select:1,clip:1});
}`
]
},
//组合控件
composes: [
{
width: 30,
height: 100,
id: "104102",
cIndex: 2,
initCPV: {
x: -65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 150,
height: 95,
id: "100002",
cIndex: 1,
initCPV: {
x: 5,
y: 0,
z: 1
},
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
feed: 1,
scale: 1,
align: 1
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
],
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_81$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketSmallLeftText
}, Symbol.toStringTag, { value: "Module" }));
const bracketSmallLeft = {
"id": "104102",
"name": "ddei.control.small-bracket",
"code": "bs",
"desc": "由极坐标系构造的左小括号,不带任何文本",
"from": "104101",
"define": {
ext: {
sample: {
//方向,上右下左1,2,3,4
direct: 4
}
}
}
};
const __vite_glob_0_82$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketSmallLeft
}, Symbol.toStringTag, { value: "Module" }));
const bracketSmallRightText = {
"id": "104103",
"name": "ddei.control.small-bracket",
"code": "bst",
"desc": "右小括号,带文本编辑",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,oppoint:2,op2close:i == 3 ? 1 : 0,select:1,clip:1});
}`
]
},
//组合控件
composes: [
{
width: 30,
height: 100,
id: "104101",
cIndex: 2,
initCPV: {
x: 65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 150,
height: 95,
id: "100002",
cIndex: 1,
initCPV: {
x: -5,
y: 0,
z: 1
},
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
feed: 1,
scale: 1,
align: 3
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
],
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_83$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketSmallRightText
}, Symbol.toStringTag, { value: "Module" }));
const bracketSmallRight = {
"id": "104101",
"name": "ddei.control.small-bracket",
"code": "bs",
"desc": "由极坐标系构造的右小括号,不带任何文本",
"from": "100500",
"define": {
width: 50,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//方向,上右下左1,2,3,4
direct: 2,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let deltaRotate = 0
switch(sample.direct){
case 1:
deltaRotate = -90
break;
case 3:
deltaRotate = -270
break;
case 4:
deltaRotate = -180
break;
}
let rad1 = (72+deltaRotate) * DDeiConfig.ROTATE_UNIT
let rad2 = (-72+deltaRotate) * DDeiConfig.ROTATE_UNIT
let rad0 = (deltaRotate) * DDeiConfig.ROTATE_UNIT
let x0 = sample.r * Math.cos(rad0)
let y0 = sample.r * Math.sin(rad0)
let x1 = sample.r * Math.cos(rad1)
let y1 = sample.r * Math.sin(rad1)
let x2 = sample.r * Math.cos(rad2)
let y2 = sample.r * Math.sin(rad2)
pvs.push({begin:1,x:x2,y:y2,r:sample.r,rad:rad2,stroke:1,type:2,direct:1});
pvs.push({x:x2,y:y2,r:sample.r,rad:rad1,stroke:1,type:2,direct:1});
pvs.push({x:x2,y:y2});
pvs.push({end:1,x:0,y:0});
pvs.push({x:x1,y:y1,type:0,oppoint:1,select:1});
pvs.push({x:x2,y:y2,type:0,oppoint:1,select:1});
pvs.push({x:x0,y:0,type:0,oppoint:1});
pvs.push({x:x2,y:0,type:0,oppoint:1});
pvs.push({x:x0,y:y2,type:0,select:1});
pvs.push({x:x0,y:y1,type:0,select:1});
}
}`
]
},
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
}
};
const __vite_glob_0_84$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketSmallRight
}, Symbol.toStringTag, { value: "Module" }));
const bracketSmallText = {
"id": "104105",
"name": "ddei.control.small-bracket",
"code": "bst",
"desc": "左右小括号,带文本编辑",
"from": "100500",
"define": {
width: 160,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,select:1,oppoint:2,op2close:i == 3 ? 1 : 0,clip:1});
}`
]
},
//组合控件
composes: [
{
width: 30,
height: 100,
id: "104102",
cIndex: 2,
initCPV: {
x: -65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 30,
height: 100,
id: "104101",
cIndex: 2,
initCPV: {
x: 65,
y: 0,
z: 1
},
attrLinks: [
{ code: "border", mapping: ["*"] }
]
},
{
width: 140,
height: 95,
id: "100002",
cIndex: 1,
initCPV: {
x: 0,
y: 0,
z: 1
},
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
feed: 1,
scale: 1
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
],
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_85$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: bracketSmallText
}, Symbol.toStringTag, { value: "Module" }));
const comment = {
"id": "103005",
"name": "ddei.control.comment",
"code": "comment",
"desc": "注释备注",
"from": "100500",
"define": {
width: 110,
height: 70,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//允许文本输入
textInput: 1,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let weight = 20
let x=sample.x,y=sample.y
switch(i){
case 0:
pvs.push({begin:1,x:x,y:y,select:1,clip:1,oppoint:2,stroke:1,fill:1});
break;
case 1:
pvs[0].y=y
pvs.push({x:x,y:y,select:1,clip:1,stroke:1,oppoint:2,fill:1});
break;
case 2:
pvs[1].x=x
pvs.push({x:x,y:y,select:1,clip:1,stroke:1,oppoint:2,fill:1});
break;
case 3:
pvs[2].y=y
x = pvs[0].x
pvs.push({x:x-weight,y:y,select:1,clip:1,stroke:1,oppoint:2,fill:1});
pvs.push({x:x,y:y+weight,select:1,clip:1,stroke:1,oppoint:2,op2close:1,fill:1,end:1});
break;
}
}`,
`(i, sample, pvs, model, ovs){
if(i==3){
pvs.push({x:30,y:sample.y,stroke:1,type:1,begin:1});
pvs.push({x:30,y:sample.y+20,stroke:1,type:1});
pvs.push({x:50,y:sample.y+20,stroke:1,type:1});
pvs.push({x:50,y:sample.y+20,end:1});
}
}`,
//文本
`(i, sample, pvs, model, ovs){
if(sample.textInput){
let weight = 20
let x=sample.x,y=sample.y
switch(i){
case 0:
pvs.push({begin:1,x:x,y:y,text:1});
break;
case 1:
pvs[0].y=y
pvs.push({x:x,y:y,text:1});
break;
case 2:
pvs[1].x=x
pvs.push({x:x,y:y,text:1});
break;
case 3:
pvs[2].y=y+weight
x = pvs[0].x
pvs.push({x:x,y:pvs[2].y,text:1});
break;
}
}
}`
]
}
}
};
const __vite_glob_0_86$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: comment
}, Symbol.toStringTag, { value: "Module" }));
const comment1 = {
"id": "103008",
"name": "ddei.control.comment",
"code": "comment",
"desc": "跟随内容变化大小的注释文本",
"from": "100000",
"define": {
borderType: 0,
border: {
type: 0,
selected: {
type: 1,
dash: [5, 5],
width: 1
}
},
fill: {
type: 0
},
text: "ddei.control.comment",
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0,op2close = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
op2close = 1
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,r:sample.r,select:1,clip:1,op2close:op2close,align:1,stroke:1,fill:1});
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({type:0,x:50,y:0,oppoint:1});
pvs.push({type:0,x:0,y:50,oppoint:1});
pvs.push({type:0,x:-50,y:0,oppoint:1});
pvs.push({type:0,x:0,y:-50,oppoint:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
if(model.exPvs){
let left
for(let n in model.exPvs){
let ep = model.exPvs[n]
if(ep.sita == 180){
left = 1
break
}
}
if(left){
pvs.push({begin:1,x:-45,y:-50});
pvs.push({x:-50,y:-50,stroke:1,forceStroke:1});
pvs.push({x:-50,y:50,stroke:1,forceStroke:1});
pvs.push({x:-45,y:50,stroke:1,forceStroke:1});
pvs.push({end:1,x:-45,y:-50});
}
}
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
if(model.exPvs){
let right
for(let n in model.exPvs){
let ep = model.exPvs[n]
if(ep.sita == 0){
right = 1
break;
}
}
if(right){
pvs.push({begin:1,x:45,y:-50});
pvs.push({x:50,y:-50,stroke:1,forceStroke:1});
pvs.push({x:50,y:50,stroke:1,forceStroke:1});
pvs.push({x:45,y:50,stroke:1,forceStroke:1});
pvs.push({end:1,x:45,y:50});
}
}
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
if(model.exPvs){
let top
for(let n in model.exPvs){
let ep = model.exPvs[n]
if(ep.sita == -90){
top = 1
break;
}
}
if(top){
pvs.push({begin:1,x:-50,y:-45});
pvs.push({x:-50,y:-50,stroke:1,forceStroke:1});
pvs.push({x:50,y:-50,stroke:1,forceStroke:1});
pvs.push({x:50,y:-45,stroke:1,forceStroke:1});
pvs.push({end:1,x:50,y:-45});
}
}
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
if(model.exPvs){
let bottom
for(let n in model.exPvs){
let ep = model.exPvs[n]
if(ep.sita == 90){
bottom = 1
break;
}
}
if(bottom){
pvs.push({begin:1,x:-50,y:45});
pvs.push({x:-50,y:50,stroke:1,forceStroke:1});
pvs.push({x:50,y:50,stroke:1,forceStroke:1});
pvs.push({x:50,y:45,stroke:1,forceStroke:1});
pvs.push({end:1,x:50,y:45});
}
}
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,text:1});
}`
]
},
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.paddingWeight",
"textStyle.lockWidth",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
},
{
name: "ddei.border",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
}
]
},
{
name: "ddei.data",
icon: "icon-edit-properies",
subGroups: [
{
name: "ddei.basic",
attrs: ["code", "text", "fmt.type", "fmt.nscale", "fmt.tmark", "fmt.mmark", "fmt.munit", "fmt.mrmb", "fmt.dtype", "fmt.format"]
}
]
}
],
attrs: [
{
"code": "textStyle.paddingWeight",
"name": "ddei.property.paddingWeight",
"desc": "超范围自动扩展的情况下保留的宽度",
"controlType": "text",
"dataType": "integer",
"defaultValue": 10,
"hiddenTitle": true,
"display": "column",
"type": [1, 2]
},
{
"code": "textStyle.scale",
"name": "ddei.property.outSize",
"desc": "文本的超出范围后的策略",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.hidden", "value": "0" }, { "text": "ddei.property.ds.ellipsis", "value": "2" }, { "text": "ddei.property.ds.narrow", "value": "1" }, { "text": "ddei.property.ds.ext", "value": "3" }],
"defaultValue": 3,
"cascadeDisplay": { 3: { show: ["textStyle.lockWidth", "textStyle.paddingWeight"], hidden: [] }, default: { show: ["textStyle.lockWidth", "textStyle.paddingWeight"] }, empty: { hidden: ["textStyle.lockWidth", "textStyle.paddingWeight"] }, notempty: { hidden: ["textStyle.lockWidth", "textStyle.paddingWeight"] } }
}
]
}
}
};
const __vite_glob_0_87$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: comment1
}, Symbol.toStringTag, { value: "Module" }));
const database = {
"id": "103010",
"name": "ddei.database",
"code": "database",
"desc": "数据库图标",
"from": "100500",
"define": {
width: 100,
height: 60,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 12;
pvs.push({begin:1,x:50,y:50+dn,select:1,clip:1})
pvs.push({x:-50,y:50+dn,select:1,clip:1})
pvs.push({x:-50,y:-50-dn,select:1,clip:1})
pvs.push({end:1,x:50,y:-50-dn,select:1,clip:1})
}
}`,
//操作点
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 12;
pvs.push({begin:1,x:50,y:0,oppoint:1})
pvs.push({x:0,y:50+dn,oppoint:1})
pvs.push({x:-50,y:0,oppoint:1})
pvs.push({end:1,x:0,y:-50-dn,oppoint:1})
}
}`,
//绘制线段区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
let rad180 = 0
switch(i){
case 0:
pvs.push({begin:1,x:x,y:y,fill:1,r:er,rad:0});
break;
case 1:
rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({r:er,dy:50,rad:rad180,stroke:1,type:4,direct:1});
pvs.push({r:sample.r});
pvs.push({r:10});
pvs.push({x:pvs[0].x,y:pvs[0].y});
pvs.push({x:x,y:y});
break;
case 2:
rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({x:x,y:y,stroke:1,rad:rad180,r:er});
break;
case 3:
rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({r:er,dy:-50,rad:0,stroke:1,type:4,direct:1});
pvs.push({r:sample.r});
pvs.push({r:10});
pvs.push({x:pvs[0].x,y:pvs[0].y,stroke:1});
pvs.push({end:1,x:pvs[0].x,y:pvs[0].y});
break;
}
}`,
// 上方的下半椭圆
`(i, sample, pvs, model, ovs){
if(i == 2 || i ==3){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
switch(i){
case 2:
let rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({begin:1,x:x,y:y,r:er,rad:rad180});
break;
case 3:
pvs.push({r:er,dy:-50,rad:0,stroke:1,type:4,direct:0});
pvs.push({r:sample.r});
pvs.push({r:10});
pvs.push({end:1,x:x,y:y});
break;
}
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 10;
pvs.push({begin:1,x:50,y:50,text:1})
pvs.push({x:-50,y:50,text:1})
pvs.push({x:-50,y:-50+dn,text:1})
pvs.push({end:1,x:50,y:-50+dn,text:1})
}
}`
]
}
}
};
const __vite_glob_0_88$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: database
}, Symbol.toStringTag, { value: "Module" }));
const database1 = {
"id": "103011",
"name": "ddei.database",
"code": "database",
"desc": "数据库图标",
"from": "100500",
"define": {
width: 100,
height: 60,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 12;
pvs.push({begin:1,x:50,y:50+dn,select:1,clip:1})
pvs.push({x:-50,y:50+dn,select:1,clip:1})
pvs.push({x:-50,y:-50-dn,select:1,clip:1})
pvs.push({end:1,x:50,y:-50-dn,select:1,clip:1})
}
}`,
//操作点
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 12;
pvs.push({begin:1,x:50,y:0,oppoint:1})
pvs.push({x:0,y:50+dn,oppoint:1})
pvs.push({x:-50,y:0,oppoint:1})
pvs.push({end:1,x:0,y:-50-dn,oppoint:1})
}
}`,
//绘制线段区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
let rad180 = 0
switch(i){
case 0:
pvs.push({begin:1,x:x,y:y,fill:1,r:er,rad:0});
break;
case 1:
rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({r:er,dy:50,rad:rad180,stroke:1,type:4,direct:1});
pvs.push({r:sample.r});
pvs.push({r:10});
pvs.push({x:pvs[0].x,y:pvs[0].y});
pvs.push({x:x,y:y});
break;
case 2:
rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({x:x,y:y,stroke:1,rad:rad180,r:er});
break;
case 3:
rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({r:er,dy:-50,rad:0,stroke:1,type:4,direct:1});
pvs.push({r:sample.r});
pvs.push({r:10});
pvs.push({x:pvs[0].x,y:pvs[0].y,stroke:1});
pvs.push({end:1,x:pvs[0].x,y:pvs[0].y});
break;
}
}`,
// 上方的下半椭圆
`(i, sample, pvs, model, ovs){
if(i == 2 || i ==3){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
switch(i){
case 2:
let rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({begin:1,x:x,y:y,r:er,rad:rad180});
break;
case 3:
pvs.push({r:er,dy:-50,rad:0,stroke:1,type:4,direct:0});
pvs.push({r:sample.r});
pvs.push({r:10});
pvs.push({end:1,x:x,y:y});
break;
}
}
}`,
// 上方的下半椭圆
`(i, sample, pvs, model, ovs){
if(i == 2 || i ==3){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
switch(i){
case 2:
let rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({begin:1,x:x,y:y,r:er,rad:rad180});
break;
case 3:
pvs.push({r:er,dy:-40,rad:0,stroke:1,type:4,direct:0});
pvs.push({r:sample.r});
pvs.push({r:10});
pvs.push({end:1,x:x,y:y});
break;
}
}
}`,
// 上方的下半椭圆
`(i, sample, pvs, model, ovs){
if(i == 2 || i ==3){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
switch(i){
case 2:
let rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({begin:1,x:x,y:y,r:er,rad:rad180});
break;
case 3:
pvs.push({r:er,dy:-30,rad:0,stroke:1,type:4,direct:0});
pvs.push({r:sample.r});
pvs.push({r:10});
pvs.push({end:1,x:x,y:y});
break;
}
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 10;
pvs.push({begin:1,x:50,y:50,text:1})
pvs.push({x:-50,y:50,text:1})
pvs.push({x:-50,y:-30+dn,text:1})
pvs.push({end:1,x:50,y:-30+dn,text:1})
}
}`
]
}
}
};
const __vite_glob_0_89$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: database1
}, Symbol.toStringTag, { value: "Module" }));
const database2 = {
"id": "103012",
"name": "ddei.database",
"code": "database",
"desc": "数据库图标",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 12;
pvs.push({begin:1,x:50,y:50,select:1,clip:1})
pvs.push({x:-50,y:50,select:1,clip:1})
pvs.push({x:-50,y:-50-dn,select:1,clip:1})
pvs.push({end:1,x:50,y:-50-dn,select:1,clip:1})
}
}`,
//操作点
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 12;
pvs.push({begin:1,x:50,y:0,oppoint:1})
pvs.push({x:0,y:56,oppoint:1})
pvs.push({x:-50,y:0,oppoint:1})
pvs.push({end:1,x:0,y:-50-dn,oppoint:1})
}
}`,
//绘制线段区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
let rad180 = 0
switch(i){
case 0:
pvs.push({begin:1,x:x,y:y,fill:1,r:er,rad:0,strokeClear:1});
break;
case 1:
rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({r:er,dy:35,rad:rad180,stroke:1,type:4,direct:1});
pvs.push({r:sample.r});
pvs.push({r:20});
pvs.push({x:pvs[0].x,y:pvs[0].y});
pvs.push({x:x,y:y});
break;
case 2:
rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({x:x,y:y,stroke:1,rad:rad180,r:er});
break;
case 3:
rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({r:er,dy:-40,rad:0,stroke:1,type:4,direct:1});
pvs.push({r:sample.r});
pvs.push({r:25});
pvs.push({end:1,x:pvs[0].x,y:pvs[0].y,stroke:1});
break;
}
}`,
// 上方的下半椭圆
`(i, sample, pvs, model, ovs){
if(i == 2 || i ==3){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
switch(i){
case 2:
let rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({begin:1,x:x,y:y,r:er,rad:rad180,strokeClear:1});
break;
case 3:
pvs.push({r:er,dy:-40,rad:0,stroke:1,type:4,direct:0});
pvs.push({r:sample.r});
pvs.push({r:25});
pvs.push({end:1,x:x,y:y});
break;
}
}
}`,
// 上方的下半椭圆
`(i, sample, pvs, model, ovs){
if(i == 2 || i ==3){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
switch(i){
case 2:
let rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({begin:1,x:x,y:y,r:er,rad:rad180,strokeClear:1});
break;
case 3:
pvs.push({r:er,dy:-12,rad:0,stroke:1,type:4,direct:0});
pvs.push({r:sample.r});
pvs.push({r:20});
pvs.push({end:1,x:x,y:y});
break;
}
}
}`,
// 上方的下半椭圆
`(i, sample, pvs, model, ovs){
if(i == 2 || i ==3){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
switch(i){
case 2:
let rad180 = 180 * DDeiConfig.ROTATE_UNIT
pvs.push({begin:1,x:x,y:y,r:er,rad:rad180,strokeClear:1});
break;
case 3:
pvs.push({r:er,dy:12,rad:0,stroke:1,type:4,direct:0});
pvs.push({r:sample.r});
pvs.push({r:20});
pvs.push({end:1,x:x,y:y});
break;
}
}
}`
]
},
border: {
width: 10
},
fill: {
color: "#017fff"
}
}
};
const __vite_glob_0_90$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: database2
}, Symbol.toStringTag, { value: "Module" }));
const database3 = {
"id": "103013",
"name": "ddei.database",
"code": "database",
"desc": "数据库图标",
"from": "100500",
"define": {
width: 110,
height: 70,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 12;
pvs.push({begin:1,x:50+dn,y:50,select:1,clip:1})
pvs.push({x:-50-dn,y:50,select:1,clip:1})
pvs.push({x:-50-dn,y:-50,select:1,clip:1})
pvs.push({end:1,x:50+dn,y:-50,select:1,clip:1})
}
}`,
//操作点
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 12;
pvs.push({begin:1,x:50+dn,y:0,oppoint:1})
pvs.push({x:0,y:50,oppoint:1})
pvs.push({x:-50-dn,y:0,oppoint:1})
pvs.push({end:1,x:0,y:-50,oppoint:1})
}
}`,
//绘制线段区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
let rad90 = 90 * DDeiConfig.ROTATE_UNIT
switch(i){
case 0:
pvs.push({begin:1,x:x,y:y,fill:1,stroke:1,r:er,rad:0});
break;
case 1:
pvs.push({x:x,y:y,fill:1,stroke:1,r:er,rad:rad90});
break;
case 2:
pvs.push({r:er,dx:-50,rad:-rad90,stroke:1,type:4,direct:1});
pvs.push({r:10});
pvs.push({r:sample.r});
break;
case 3:
pvs.push({x:x,y:y,fill:1,stroke:1,r:er,rad:-rad90});
pvs.push({r:er,dx:50,rad:rad90,stroke:1,type:4,direct:1,end:1});
pvs.push({r:10});
pvs.push({r:sample.r});
break;
}
}`,
// 右方左半椭圆
`(i, sample, pvs, model, ovs){
if(i == 3){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT)
let rad = (sample.sita+45) * DDeiConfig.ROTATE_UNIT
let x = er * Math.cos(rad)
let y = er * Math.sin(rad)
let rad90 = 90 * DDeiConfig.ROTATE_UNIT
pvs.push({x:x,y:y,fill:1,stroke:1,r:er,rad:-rad90});
pvs.push({r:er,dx:50,rad:rad90,stroke:1,type:4,direct:0});
pvs.push({r:10});
pvs.push({r:sample.r});
pvs.push({end:1,x:50,y:-50});
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let dn = 10;
pvs.push({begin:1,x:50-dn,y:50,text:1})
pvs.push({x:-50,y:50,text:1})
pvs.push({x:-50,y:-50,text:1})
pvs.push({end:1,x:50-dn,y:-50,text:1})
}
}`
]
}
}
};
const __vite_glob_0_91$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: database3
}, Symbol.toStringTag, { value: "Module" }));
const document$1 = {
"id": "103003",
"name": "ddei.control.document",
"code": "doc",
"desc": "文档",
"from": "100500",
"define": {
width: 100,
height: 60,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
sample.y += 15
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
break;
case 3:
pvs[2].y=sample.y
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,select:1});
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
//从左下,左上,右上,右下,曲线:左下
pvs.push({begin:1,x:-sample.x,y:sample.x,fill:1,clip:1});
pvs.push({x:-sample.x,y:-sample.x,stroke:1,oppoint:2});
pvs.push({x:sample.x,y:-sample.x,stroke:1,oppoint:2});
pvs.push({x:sample.x,y:sample.x,stroke:1});
//贝塞尔曲线,至少需要四个点,
pvs.push({x:50,y:50,stroke:1,type:5});
pvs.push({x:33,y:30});
pvs.push({x:16,y:30});
pvs.push({x:0,y:50});
pvs.push({x:0,y:50,type:5,stroke:1,stroke:1,end:1});
pvs.push({x:-17,y:70});
pvs.push({x:-34,y:70});
pvs.push({x:-50,y:50});
pvs.push({x:-sample.x,y:0,type:0,oppoint:1});
pvs.push({x:sample.x,y:0,type:0,oppoint:1});
pvs.push({x:0,y:50,type:0,oppoint:1});
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(i == 0){
//从左下,左上,右上,右下,曲线:左下
pvs.push({begin:1,x:-sample.x,y:sample.x-15,text:1});
pvs.push({x:-sample.x,y:-sample.x,text:1});
pvs.push({x:sample.x,y:-sample.x,text:1});
pvs.push({x:sample.x,y:sample.x-15,end:1,text:1});
}
}`
]
},
iconPos: {
dh: 5
}
}
};
const __vite_glob_0_92$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: document$1
}, Symbol.toStringTag, { value: "Module" }));
const human = {
"id": "103001",
"name": "ddei.control.human",
"code": "human",
"desc": "人形图标",
"from": "100500",
"define": {
width: 50,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 1,
//采样信息
sample: {
//依附图形的初始化配置,如果产生依附图形,则会在配置的位置生成
depPos: {
type: 8
},
depProps: {
"8": "text"
//映射属性
},
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let x = sample.x
let y = sample.y
switch(i){
case 1:
pvs[0].y=y
break;
case 2:
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
break;
}
pvs.push({begin:i==0,end:i==3,x:x,y:y,select:1,clip:1});
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
let x = 0
let y = -20
pvs.push({begin:1,x:x,y:y,stroke:1});
y = 10
pvs.push({x:x,y:y,stroke:1});
y += 10
let y1= y
let x1 = x
pvs.push({x:x,y:y,stroke:1});
let er = sample.r
x = sample.x
y = sample.y
let y2 = er * Math.sin(90 * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y2,oppoint:1,stroke:1});
pvs.push({x:x1,y:y1,type:3});
let x3 = er * Math.cos(180 * DDeiConfig.ROTATE_UNIT)
let y3 = er * Math.sin(180 * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x3,y:y2,oppoint:1,stroke:1});
pvs.push({x:x1,y:y1,type:3});
pvs.push({x:0,y:-10,type:3});
pvs.push({x:x3,y:10,oppoint:1,stroke:1});
pvs.push({x:0,y:-10,type:3});
pvs.push({x:x,y:10,oppoint:1,stroke:1});
pvs.push({x:0,y:-10,type:3});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:0,y:-50,oppoint:1,type:0});
}
}`
]
},
//组合控件
composes: [
{
id: "100103",
cIndex: 2,
initCPV: {
x: 0,
y: -35
},
width: 30,
height: 30,
attrLinks: [
{ code: "border", mapping: ["*"] },
{ code: "fill", mapping: ["*"] }
]
}
],
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
}
]
},
{
name: "ddei.data",
icon: "icon-edit-properies",
subGroups: [
{
name: "ddei.basic",
attrs: ["code", "text"]
}
]
}
]
}
}
};
const __vite_glob_0_93$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: human
}, Symbol.toStringTag, { value: "Module" }));
const human1 = {
"id": "103002",
"name": "ddei.control.human",
"code": "human",
"desc": "人形图标",
"from": "100500",
"define": {
width: 60,
height: 85,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 1,
//采样信息
sample: {
//依附图形的初始化配置,如果产生依附图形,则会在配置的位置生成
depPos: {
type: 8
},
//一圈
depProps: {
"8": "text"
//映射属性
},
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let x = sample.x
let y = sample.y
switch(i){
case 1:
y = y-8
pvs[0].y=y
break;
case 2:
pvs[1].x=x
break;
case 3:
y = y-8
pvs[2].y=y
x = pvs[0].x
break;
}
pvs.push({begin:i==0,end:i==3,x:x,y:y,select:1,oppoint:2,op2close:i == 3 ? 1 : 0,clip:1});
}`
]
},
iconPos: {
dy: 20
},
depProps: {
"8": "text"
//映射属性
},
//组合控件
composes: [
{
id: "100103",
cIndex: 2,
initCPV: {
x: 0,
y: -35
},
width: 35,
height: 35,
attrLinks: [
{ code: "border", mapping: ["*"] },
{ code: "fill", mapping: ["*"] }
]
},
{
id: "100008",
cIndex: 1,
width: 60,
height: 50,
attrLinks: [
{ code: "border", mapping: ["*"] },
{ code: "fill", mapping: ["*"] }
]
}
],
border: {
round: 15
},
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
}
]
},
{
name: "ddei.data",
icon: "icon-edit-properies",
subGroups: [
{
name: "ddei.basic",
attrs: ["code", "text"]
}
]
}
]
}
}
};
const __vite_glob_0_94$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: human1
}, Symbol.toStringTag, { value: "Module" }));
const human2 = {
"id": "103006",
"name": "ddei.control.human",
"code": "human",
"desc": "人形图标",
"from": "100500",
"define": {
width: 50,
height: 100,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 1,
fill: {
type: 0
},
//采样信息
sample: {
//依附图形的初始化配置,如果产生依附图形,则会在配置的位置生成
depPos: {
type: 8
},
depProps: {
"8": "text"
//映射属性
},
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let x = sample.x
let y = sample.y
switch(i){
case 1:
pvs[0].y=y
break;
case 2:
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
break;
}
pvs.push({begin:i==0,end:i==3,x:x,y:y,select:1,clip:1});
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
let x = 0
let y = -20
pvs.push({begin:1,x:x,y:y,stroke:1});
y = 10
pvs.push({x:x,y:y,stroke:1});
y += 10
let y1= y
let x1 = x
pvs.push({x:x,y:y,stroke:1});
let er = sample.r
x = sample.x
y = sample.y
let y2 = er * Math.sin(90 * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y2,oppoint:1,stroke:1});
pvs.push({x:x1,y:y1,type:3});
let x3 = er * Math.cos(180 * DDeiConfig.ROTATE_UNIT)
let y3 = er * Math.sin(180 * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x3,y:y2,oppoint:1,stroke:1});
pvs.push({x:x1,y:y1,type:3});
pvs.push({x:0,y:-10,type:3});
pvs.push({x:x3,y:-10,oppoint:1,stroke:1});
pvs.push({x:0,y:-10,type:3});
pvs.push({x:x,y:-10,oppoint:1,stroke:1});
pvs.push({x:0,y:-10,type:3});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:0,y:-50,oppoint:1,type:0});
}
}`
]
},
//组合控件
composes: [
{
id: "100103",
cIndex: 2,
initCPV: {
x: 0,
y: -35
},
width: 30,
height: 30,
attrLinks: [
{ code: "border", mapping: ["*"] },
{ code: "fill", mapping: ["*"] }
]
}
],
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
}
]
},
{
name: "ddei.data",
icon: "icon-edit-properies",
subGroups: [
{
name: "ddei.basic",
attrs: ["code", "text"]
}
]
}
]
}
}
};
const __vite_glob_0_95$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: human2
}, Symbol.toStringTag, { value: "Module" }));
const papertape = {
"id": "103004",
"name": "ddei.control.ptap",
"code": "ptap",
"desc": "纸带",
"from": "100500",
"define": {
width: 100,
height: 60,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
switch(i){
case 0:
start = 1
break;
case 1:
sample.y += 15
pvs[0].y=sample.y
break;
case 2:
pvs[1].x=sample.x
sample.y -= 15
break;
case 3:
pvs[2].y=sample.y
sample.y -= 15
sample.x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:sample.x,y:sample.y,select:1});
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
//从左下,左上,曲线:右上,右下,曲线:左下
pvs.push({begin:1,x:-sample.x,y:sample.x,fill:1});
pvs.push({x:-sample.x,y:-sample.x,stroke:1});
//贝塞尔曲线,至少需要四个点,
pvs.push({x:-50,y:-50,stroke:1,type:5});
pvs.push({x:-33,y:-30});
pvs.push({x:-16,y:-30});
pvs.push({x:0,y:-50});
pvs.push({x:0,y:-50,type:5,stroke:1,stroke:1});
pvs.push({x:17,y:-70});
pvs.push({x:34,y:-70});
pvs.push({x:50,y:-50});
pvs.push({x:sample.x,y:sample.x,stroke:1});
//贝塞尔曲线,至少需要四个点,
pvs.push({x:50,y:50,stroke:1,type:5});
pvs.push({x:33,y:30});
pvs.push({x:16,y:30});
pvs.push({x:0,y:50});
pvs.push({x:0,y:50,type:5,stroke:1,stroke:1,end:1});
pvs.push({x:-17,y:70});
pvs.push({x:-34,y:70});
pvs.push({x:-50,y:50});
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(i == 0){
//从左下,左上,右上,右下,曲线:左下
pvs.push({begin:1,x:-sample.x,y:sample.x-15,text:1});
pvs.push({x:-sample.x,y:-sample.x+15,text:1});
pvs.push({x:sample.x,y:-sample.x+15,text:1});
pvs.push({x:sample.x,y:sample.x-15,end:1,text:1});
}
}`,
//操作点
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:-sample.x,y:0,type:0,oppoint:1});
pvs.push({x:sample.x,y:0,type:0,oppoint:1});
pvs.push({x:0,y:50,type:0,oppoint:1});
pvs.push({x:0,y:-50,type:0,oppoint:1});
}
}`
]
}
}
};
const __vite_glob_0_96$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: papertape
}, Symbol.toStringTag, { value: "Module" }));
const layer = {
"id": "DDeiLayer",
"name": "ddei.layerName",
"code": "layer",
"desc": "整体图层的属性",
"type": "DDeiLayer",
/**
* 定义组件属性
* 样式属性会影响图形的显示,修改样式属性也会刷新图形
* 数据属性一般用于业务计算,数据属性一般不会刷新图形,除非数据属性和样式属性产生联动关系
* 事件属性一般用来作为扩展用
* 属性采用三层结构:组---子分组---属性,在基础json中先定义而后使用(可以复写)
* 特殊属性:
* code属性编码在统一个组中,code唯一
* mapping建立与模型中属性的映射关系,为null时为默认,采用code指向的属性映射;mapping为[]时交由控件编辑器处理值映射
* hiddenTitle隐藏标题,为true时不会显示属性标题,默认false不隐藏标题
* display控件显示模式,有row(横向排列)和column(纵向排列)两个选项,默认row
*/
attrs: [
{
"code": "bg.type",
"name": "ddei.property.background",
"desc": "背景的类型",
"controlType": "radio",
"dataType": "string",
"dataSource": [{ "text": "ddei.property.ds.none", "value": -1 }, { "text": "ddei.property.ds.color", "value": 1 }, { "text": "ddei.property.ds.image", "value": 2 }],
"defaultValue": 1,
"type": 1,
"cascadeDisplay": { 1: { show: ["bg.color", "bg.opacity"], hidden: ["bg.image", "bg.imageMode", "bg.imageScale", "bg.imageAlign"] }, 2: { show: ["bg.image", "bg.imageMode", "bg.imageScale", "bg.imageAlign"], hidden: ["bg.color"] }, 0: { hidden: ["bg.opacity", "bg.color", "bg.image", "bg.imageMode", "bg.imageScale", "bg.imageAlign"] }, default: { show: ["bg.color", "bg.opacity"], hidden: ["bg.image", "bg.imageMode", "bg.imageScale", "bg.imageAlign"] } },
"hiddenTitle": true,
"display": "column"
},
{
"code": "bg.color",
"name": "ddei.property.backgroundColor",
"desc": "背景的颜色",
"controlType": "color-combo",
"dataType": "string",
"defaultValue": "",
"type": 1
},
{
"code": "bg.image",
"name": "ddei.property.backgroundImage",
"desc": "背景的图片",
"controlType": "image",
"dataType": "string",
"defaultValue": "",
"type": 1
},
{
"code": "bg.opacity",
"name": "ddei.property.opacity",
"desc": "背景的透明度",
"controlType": "range",
"min": 0,
"max": 1,
"step": 0.01,
"dataType": "float",
"defaultValue": 1,
"display": "column",
"type": 1
},
{
"code": "bg.imageMode",
"name": "ddei.property.bgImageMode",
"desc": "背景的图片的模式",
"controlType": "radio",
"dataType": "integer",
"dataSource": [{ "text": "ddei.property.ds.original", "value": 0 }, { "text": "ddei.property.ds.scale", "value": 1 }, { "text": "ddei.property.ds.fill", "value": 2 }],
"cascadeDisplay": { 1: { show: ["bg.imageScale", "bg.imageAlign"] }, 2: { hidden: ["bg.imageScale", "bg.imageAlign"] }, empty: { hidden: ["bg.imageScale"], show: ["bg.imageAlign"] } },
"defaultValue": 2,
"type": 1
},
{
"code": "bg.imageScale",
"name": "ddei.property.bgImageScale",
"desc": "背景的图片的缩放比例",
"controlType": "range",
"min": 0.01,
"max": 10,
"step": 0.01,
"dataType": "float",
"defaultValue": 1,
"type": 1
},
{
"code": "bg.imageAlign",
"name": "ddei.property.bgImagePosition",
"desc": "背景的图片布局方位",
"controlType": "align-type",
"dataType": "string",
"type": 1
}
],
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.background",
icon: "icon-background",
subGroups: [
{
name: "ddei.background",
attrs: ["bg.type", "bg.color", "bg.image", "bg.opacity", "bg.imageMode", "bg.imageScale", "bg.imageAlign"]
}
]
}
]
};
const __vite_glob_0_97$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: layer
}, Symbol.toStringTag, { value: "Module" }));
const angle = {
"id": "104001",
"name": "ddei.control.angle",
"code": "angle",
"desc": "表示一个角度",
"from": "100500",
"define": {
width: 200,
height: 200,
//2为极坐标,缺省点为原点
poly: 2,
font: {
size: 10
},
//采样信息
sample: {
eqrat: true,
//一圈采样次数
loop: 1,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
//选择区域
`(i, sample, pvs, model, ovs){
let sita = Math.round(ovs[1].sita)
let hdelta = (ovs[2].x-ovs[2].ovi.x)
pvs.push({begin:1,x:hdelta,y:hdelta,select:1,clip:1});
pvs.push({x:-hdelta,y:hdelta,select:1,clip:1});
pvs.push({x:-hdelta,y:-hdelta,select:1,clip:1});
pvs.push({x:hdelta,y:-hdelta,select:1,clip:1});
}`,
//下方直线
`(i, sample, pvs, model, ovs){
pvs.push({begin:1,x:0,y:0,stroke:1,oppoint:1,type:1});
pvs.push({end:1,x:(ovs[2].x-ovs[2].ovi.x),y:0,stroke:1,oppoint:1,type:1});
}`,
//上方直线
`(i, sample, pvs, model, ovs){
let rad = (ovs[1].sita) * DDeiConfig.ROTATE_UNIT
let hdelta = (ovs[2].x-ovs[2].ovi.x)
let x = hdelta * Math.cos(rad)
let y = hdelta * Math.sin(rad)
pvs.push({begin:1,x:0,y:0,stroke:1,type:1});
pvs.push({end:1,x:x,y:y,stroke:1,oppoint:1,type:1});
}`,
//弧线/直角线
`(i, sample, pvs, model, ovs){
let sita = ovs[1].sita
if(Math.round(sita) == -90){
let ar = (ovs[0].x-ovs[0].ovi.x)
pvs.push({begin:1,x:0,y:-ar,stroke:1});
pvs.push({x:ar,y:-ar,stroke:1});
pvs.push({x:ar,y:0,stroke:1});
pvs.push({end:1,x:0,y:0,stroke:1});
}else{
let rad = sita * DDeiConfig.ROTATE_UNIT
let ar = (ovs[0].x-ovs[0].ovi.x)
let x = ar * Math.cos(rad)
let y = ar * Math.sin(rad)
pvs.push({begin:1,x:ar,y:0,r:ar,rad:0,stroke:1});
pvs.push({end:1,x:x,y:y,r:ar,rad:rad,stroke:1});
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
let sita = ovs[1].sita
let disSita
//显示半径
let ar = (ovs[0].x-ovs[0].ovi.x)+7
let dtSita = sita / 2
let x = ar * Math.cos(dtSita * DDeiConfig.ROTATE_UNIT)
let y = ar * Math.sin(dtSita * DDeiConfig.ROTATE_UNIT)
if(sita<0 && sita >= -180){
disSita = (-sita.toFixed(1))+""
}else{
x = -x
y = -y
disSita = (180+(180-sita)).toFixed(1)+""
}
let size = 10;
pvs.push({begin:1,x:x+size,y:y+size/2,text:1});
pvs.push({x:x-size,y:y+size/2,text:1});
pvs.push({x:x-size,y:y-size/2,text:1});
pvs.push({end:1,x:x+size,y:y-size/2,text:1});
model.text = disSita
model.render?.setCachedValue("text",disSita)
}`
]
},
iconPos: {
dx: -50,
dy: 50
},
//操作点定义
ovs: [
//控制角度显示位置
{
x: 25,
y: 0,
ix: 0,
iy: 0,
//约束,控制点的移动路径和位置
constraint: {
type: 2,
//矩形范围
x0: 0,
x1: 50,
y0: 0,
y1: 0
}
},
//控制角度
{
//初始化的角度
isita: 30,
//约束,控制点的移动路径和位置
constraint: {
type: 3,
//圆形范围
r: 25
}
},
{
x: 50,
y: 0,
ix: 0,
iy: 0,
//约束,控制点的移动路径和位置
constraint: {
type: 2,
//矩形范围
x0: 5,
x1: 100,
y0: 0,
y1: 0
}
}
],
ext: {
/**
* 定义分组,用于属性编辑
*/
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_98$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: angle
}, Symbol.toStringTag, { value: "Module" }));
const basicFlowShapes = {
"id": "102",
"name": "ddei.control.groups.flow",
"code": "basic-flow-shapes",
"desc": "基础的流程形状,包含了开始、结束、任务、分支等基础形状",
"orderNo": 2,
"subject": "basic",
//当前分组下所有控件
"controls": [
{
"id": "102001",
"orderNo": 1
},
{
"id": "102002",
"orderNo": 2
},
{
"id": "102010",
"orderNo": 10
},
{
"id": "102011",
"orderNo": 11
},
{
"id": "102012",
"orderNo": 12
},
{
"id": "102020",
"orderNo": 20
},
{
"id": "102021",
"orderNo": 21
},
{
"id": "102040",
"orderNo": 25
},
{
"id": "102041",
"orderNo": 26
},
{
"id": "103003",
"orderNo": 27
},
{
"id": "102030",
"orderNo": 30
},
{
"id": "102031",
"orderNo": 31
},
{
"id": "102032",
"orderNo": 32
},
{
"id": "102033",
"orderNo": 33
},
{
"id": "103013",
"name": "ddei.control.direct-data",
"orderNo": 34
},
{
"id": "102090",
"orderNo": 50
},
{
"id": "102091",
"orderNo": 51
},
{
"id": "102092",
"orderNo": 52
},
{
"id": "103010",
"orderNo": 60
},
{
"id": "103001",
"orderNo": 71
},
{
"id": "103002",
"orderNo": 72
},
{
"id": "102050",
"orderNo": 73
},
{
"id": "102052",
"orderNo": 74
},
{
"id": "102057",
"orderNo": 74
},
{
"id": "102053",
"orderNo": 75
},
{
"id": "102054",
"orderNo": 76
},
{
"id": "103004",
"orderNo": 77
},
{
"id": "102055",
"orderNo": 78
},
{
"id": "102056",
"orderNo": 79
},
{
"id": "102051",
"orderNo": 83
},
{
"id": "102058",
"orderNo": 84
}
]
};
const __vite_glob_1_0$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: basicFlowShapes
}, Symbol.toStringTag, { value: "Module" }));
const basicShapes = {
"id": "101",
"name": "ddei.control.groups.basic",
"code": "basic-shapes",
"desc": "基础的绘图形状,包含了正方形、长方形、三角形、圆形、线条等基础形状",
"orderNo": 1,
"subject": "basic",
//当前分组下所有控件
"controls": [
{
"id": "100200",
"orderNo": 0
},
{
"id": "100001",
"orderNo": 1
},
{
"id": "100002",
"orderNo": 2
},
{
"id": "100003",
"orderNo": 3
},
{
"id": "100004",
"orderNo": 4
},
{
"id": "100005",
"orderNo": 5
},
{
"id": "100006",
"text": "",
"orderNo": 6
},
{
"id": "100007",
"text": "",
"orderNo": 7
},
{
"id": "100010",
"text": "",
"orderNo": 10
},
{
"id": "100011",
"text": "",
"orderNo": 11
},
{
"id": "100012",
"text": "",
"orderNo": 12
},
{
"id": "100013",
"text": "",
"orderNo": 13
},
{
"id": "100014",
"text": "",
"orderNo": 14
},
{
"id": "100015",
"text": "",
"orderNo": 15
},
{
"id": "100020",
"orderNo": 20
},
{
"id": "100021",
"text": "",
"orderNo": 21
},
{
"id": "100030",
"text": "",
"orderNo": 30
},
{
"id": "100031",
"text": "",
"orderNo": 31
},
{
"id": "100040",
"orderNo": 40
},
{
"id": "100041",
"text": "",
"orderNo": 41
},
{
"id": "100050",
"text": "",
"orderNo": 50
},
{
"id": "100051",
"text": "",
"orderNo": 51
},
{
"id": "100060",
"text": "",
"orderNo": 60
},
{
"id": "100061",
"text": "",
"orderNo": 61
},
{
"id": "100070",
"text": "",
"orderNo": 70
},
{
"id": "100076",
"text": "",
"orderNo": 75
},
{
"id": "100075",
"text": "",
"orderNo": 76
},
{
"id": "100077",
"text": "",
"orderNo": 77
},
{
"id": "104001",
"text": "",
"orderNo": 80
},
{
"id": "104105",
"text": "",
"orderNo": 91
},
{
"id": "104115",
"text": "",
"orderNo": 92
},
{
"id": "104125",
"text": "",
"orderNo": 93
},
{
"id": "100110",
"text": "",
"orderNo": 94
},
{
"id": "103005",
"orderNo": 305
},
{
"id": "103008",
"orderNo": 308
}
]
};
const __vite_glob_1_1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: basicShapes
}, Symbol.toStringTag, { value: "Module" }));
const databases = {
"id": "201",
"name": "ddei.database",
"code": "databases",
"desc": "包含了数据库的各种类型",
"orderNo": 21,
"subject": "basic",
//当前分组下所有控件
"controls": [
{
"id": "103010",
"orderNo": 0
},
{
"id": "103011",
"orderNo": 1
},
{
"id": "103012",
"orderNo": 2
}
]
};
const __vite_glob_1_2$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: databases
}, Symbol.toStringTag, { value: "Module" }));
const ToDefaultPropertys = [
"fill.type",
"fill.color",
"fill.image",
"fill.opacity",
"border.type",
"border.color",
"borderOpacity",
"borderWidth",
"borderDash",
"borderRound",
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
];
const parseAttrsToGroup = function(control) {
var _a3;
if (control.attrs) {
control.attrs.forEach((curAttr) => {
let attrDefine = new DDeiEditorArrtibute(curAttr);
if (ToDefaultPropertys.indexOf(curAttr.code) != -1) {
let defValue = DDeiUtil.getDataByPathList(control.define, curAttr.code, curAttr.mapping);
if (defValue || defValue == 0) {
attrDefine.defaultValue = defValue;
}
}
if (!control.attrDefineMap) {
control.attrDefineMap = /* @__PURE__ */ new Map();
}
control.attrDefineMap.set(curAttr.code, attrDefine);
});
}
(_a3 = control.groups) == null ? void 0 : _a3.forEach((group2) => {
var _a4;
(_a4 = group2.subGroups) == null ? void 0 : _a4.forEach((subGroup) => {
var _a5;
let attrs = [];
(_a5 = subGroup.attrs) == null ? void 0 : _a5.forEach((attrCode) => {
let attrDefine = control.attrDefineMap.get(attrCode);
if (attrDefine) {
attrDefine.topGroup = group2;
attrDefine.modelCode = control.id;
attrs.push(attrDefine);
}
});
subGroup.children = attrs;
});
});
};
const loadControlByFrom = function(controlOriginDefinies, control) {
if (control.from && !control.def) {
let fromControl = controlOriginDefinies.get(control.from);
if (fromControl.from) {
loadControlByFrom(controlOriginDefinies, fromControl);
}
control.attrs = cloneDeep(fromControl.attrs);
control.groups = cloneDeep(fromControl.groups);
let fromMenus = cloneDeep(fromControl.menus);
let fromDefine = cloneDeep(fromControl.define);
let fromFilters = cloneDeep(fromControl.filters);
if (fromDefine) {
if (!control.define) {
control.define = {};
}
for (let i2 in fromDefine) {
if (!(control.define[i2] || control.define[i2] == 0)) {
control.define[i2] = fromDefine[i2];
}
}
}
if (fromFilters) {
if (!control.filters) {
control.filters = fromFilters;
} else {
for (let k in fromFilters) {
if (!control.filters[k]) {
control.filters[k] = fromFilters[k];
}
}
}
}
loadControlDefineExt(control);
loadControlDefineComposes(controlOriginDefinies, control);
loadControlOthers(controlOriginDefinies, control);
if (fromMenus) {
if (!control.menus) {
control.menus = {};
}
for (let i2 in fromMenus) {
if (!(control.menus[i2] || control.menus[i2] == 0)) {
control.menus[i2] = fromMenus[i2];
}
}
}
control.menus = fromMenus;
control.attrDefineMap = /* @__PURE__ */ new Map();
if (!control.type && control.type != fromControl.type) {
control.type = fromControl.type;
}
controlOriginDefinies.set(control.id, control);
}
if (control.viewer) {
control.viewer = vue.markRaw(control.viewer);
}
parseAttrsToGroup(control);
control.def = true;
};
const loadControlOthers = function(controlOriginDefinies, control) {
if (control.others) {
control.others.forEach((other) => {
let otherControlDefine = controlOriginDefinies.get(other.id);
if (otherControlDefine.from) {
loadControlByFrom(controlOriginDefinies, otherControlDefine);
}
other.code = otherControlDefine.code;
let otherDefine = cloneDeep(otherControlDefine.define);
if (otherDefine) {
for (let i2 in otherDefine) {
if (!other.define) {
other.define = {};
}
if (!(other.define[i2] || other.define[i2] == 0)) {
other.define[i2] = otherDefine[i2];
}
}
}
other.type = otherControlDefine.type;
other.others = otherControlDefine.others;
loadControlOthers(controlOriginDefinies, other);
});
}
};
const loadAndSortGroup = function(groups, controlOriginDefinies) {
let groupOriginDefinies = [];
groups.forEach((group2) => {
if (group2.controls) {
let cos = [];
group2.controls.forEach((control) => {
let id = control.id;
let controlDefine = controlOriginDefinies.get(id);
if (controlDefine) {
let c = cloneDeep(controlDefine);
for (let i2 in control) {
if (control[i2] != void 0 && control[i2] != null) {
c[i2] = control[i2];
}
}
cos.push(c);
}
});
cos.sort((a, b) => {
return a.orderNo - b.orderNo;
});
group2.controls = cos;
}
group2.display = true;
groupOriginDefinies.push(group2);
});
groupOriginDefinies.sort((a, b) => {
return a.orderNo - b.orderNo;
});
return groupOriginDefinies;
};
const loadControlDefineComposes = function(controlOriginDefinies, control) {
var _a3, _b2;
if ((_a3 = control.define) == null ? void 0 : _a3.composes) {
(_b2 = control.define) == null ? void 0 : _b2.composes.forEach((compose) => {
let composeControlDefine = controlOriginDefinies.get(compose.id);
if (composeControlDefine.from) {
loadControlByFrom(controlOriginDefinies, composeControlDefine);
}
compose.attrs = cloneDeep(composeControlDefine.attrs);
let composeDefine = cloneDeep(composeControlDefine.define);
if (composeDefine) {
for (let i2 in composeDefine) {
if (!(compose[i2] || compose[i2] == 0)) {
compose[i2] = composeDefine[i2];
}
}
}
});
}
};
const loadControlDefineExt = function(control) {
var _a3, _b2, _c2, _d2;
if ((_a3 = control.define) == null ? void 0 : _a3.ext) {
for (let i2 in control.define.ext) {
switch (i2) {
case "composes": {
let extComps = (_b2 = control.define) == null ? void 0 : _b2.ext.composes;
let defineComps = control.define.composes;
for (let j2 = 0; j2 < extComps.length; j2++) {
let extComp = extComps[j2];
let defComp = defineComps[j2];
if (defComp && !extComp.type) {
for (let k in extComp) {
defComp[k] = extComp[k];
}
}
}
break;
}
case "ovs": {
let extOVS = (_c2 = control.define) == null ? void 0 : _c2.ext.ovs;
let defineOVS = control.define.ovs;
for (let j2 = 0; j2 < extOVS.length; j2++) {
let extComp = extOVS[j2];
let defComp = defineOVS[j2];
if (defComp && extComp) {
for (let k in extComp) {
defComp[k] = extComp[k];
}
}
}
break;
}
case "sample": {
if (!((_d2 = control.define) == null ? void 0 : _d2.sample)) {
control.define.sample = {};
}
for (let j2 in control.define.ext.sample) {
if (j2 != "rules") {
control.define.sample[j2] = control.define.ext.sample[j2];
} else {
if (!control.define.sample.rules) {
control.define.sample.rules = [];
}
control.define.ext.sample[j2].forEach((rule) => {
control.define.sample.rules.push(rule);
});
}
}
break;
}
case "attrs": {
let extAttrs = control.define.ext.attrs;
extAttrs == null ? void 0 : extAttrs.forEach((extAttr) => {
let append = true;
for (let x2 = 0; x2 < control.attrs.length; x2++) {
if (control.attrs[x2].code == extAttr.code) {
control.attrs[x2] = extAttr;
append = false;
break;
}
}
if (append) {
control.attrs.push(extAttr);
}
});
break;
}
case "groups": {
let extGroups = control.define.ext.groups;
control.groups = extGroups;
break;
}
default: {
control.define[i2] = control.define.ext[i2];
break;
}
}
}
delete control.define.ext;
}
};
const control_ctx$1 = /* @__PURE__ */ Object.assign({ "./control/base/compose-container.ts": __vite_glob_0_0$5, "./control/base/container.ts": __vite_glob_0_1$2, "./control/base/line.ts": __vite_glob_0_2$1, "./control/base/polygon-container.ts": __vite_glob_0_3$1, "./control/base/polygon.ts": __vite_glob_0_4$1, "./control/base/table-cell.ts": __vite_glob_0_5$1, "./control/base/table.ts": __vite_glob_0_6$1, "./control/basic/circle-split.ts": __vite_glob_0_7$1, "./control/basic/circle-text.ts": __vite_glob_0_8$1, "./control/basic/circle.ts": __vite_glob_0_9$1, "./control/basic/cube.ts": __vite_glob_0_10$1, "./control/basic/diamond-round.ts": __vite_glob_0_11$1, "./control/basic/diamond.ts": __vite_glob_0_12$1, "./control/basic/ellipse.ts": __vite_glob_0_13$1, "./control/basic/fivestar.ts": __vite_glob_0_14$1, "./control/basic/half-circle.ts": __vite_glob_0_15$1, "./control/basic/hexagon-round.ts": __vite_glob_0_16$1, "./control/basic/hexagon.ts": __vite_glob_0_17$1, "./control/basic/hexstar.ts": __vite_glob_0_18$1, "./control/basic/hexstar1.ts": __vite_glob_0_19$1, "./control/basic/hexstar2.ts": __vite_glob_0_20$1, "./control/basic/left-arrow.ts": __vite_glob_0_21$1, "./control/basic/parallelogram-round.ts": __vite_glob_0_22$1, "./control/basic/parallelogram.ts": __vite_glob_0_23$1, "./control/basic/pentagon-round.ts": __vite_glob_0_24$1, "./control/basic/pentagon.ts": __vite_glob_0_25$1, "./control/basic/rectangle-border.ts": __vite_glob_0_26$1, "./control/basic/rectangle-round.ts": __vite_glob_0_27$1, "./control/basic/rectangle-split.ts": __vite_glob_0_28$1, "./control/basic/rectangle-text.ts": __vite_glob_0_29$1, "./control/basic/rectangle.ts": __vite_glob_0_30$1, "./control/basic/right-arrow.ts": __vite_glob_0_31$1, "./control/basic/square-round.ts": __vite_glob_0_32$1, "./control/basic/square-text.ts": __vite_glob_0_33$1, "./control/basic/square.ts": __vite_glob_0_34$1, "./control/basic/text.ts": __vite_glob_0_35$1, "./control/basic/trapezoid-round.ts": __vite_glob_0_36$1, "./control/basic/trapezoid.ts": __vite_glob_0_37$1, "./control/basic/triangle-left-90-round.ts": __vite_glob_0_38$1, "./control/basic/triangle-left-90.ts": __vite_glob_0_39$1, "./control/basic/triangle-right-90-round.ts": __vite_glob_0_40$1, "./control/basic/triangle-right-90.ts": __vite_glob_0_41$1, "./control/basic/triangle-round.ts": __vite_glob_0_42$1, "./control/basic/triangle.ts": __vite_glob_0_43$1, "./control/basicflow/flow-card-tab.ts": __vite_glob_0_44$1, "./control/basicflow/flow-control-transfer.ts": __vite_glob_0_45$1, "./control/basicflow/flow-data.ts": __vite_glob_0_46$1, "./control/basicflow/flow-data1.ts": __vite_glob_0_47$1, "./control/basicflow/flow-data2.ts": __vite_glob_0_48$1, "./control/basicflow/flow-data3.ts": __vite_glob_0_49$1, "./control/basicflow/flow-defflow.ts": __vite_glob_0_50$1, "./control/basicflow/flow-delay.ts": __vite_glob_0_51$1, "./control/basicflow/flow-display-content.ts": __vite_glob_0_52$1, "./control/basicflow/flow-end.ts": __vite_glob_0_53$1, "./control/basicflow/flow-end1.ts": __vite_glob_0_54$1, "./control/basicflow/flow-end2.ts": __vite_glob_0_55$1, "./control/basicflow/flow-end3.ts": __vite_glob_0_56$1, "./control/basicflow/flow-hand-input.ts": __vite_glob_0_57$1, "./control/basicflow/flow-loop-area.ts": __vite_glob_0_58$1, "./control/basicflow/flow-manual-operate.ts": __vite_glob_0_59$1, "./control/basicflow/flow-page-ref.ts": __vite_glob_0_60$1, "./control/basicflow/flow-prepare.ts": __vite_glob_0_61$1, "./control/basicflow/flow-start.ts": __vite_glob_0_62$1, "./control/basicflow/flow-start1.ts": __vite_glob_0_63$1, "./control/basicflow/flow-subflow.ts": __vite_glob_0_64$1, "./control/basicflow/flow-switch.ts": __vite_glob_0_65$1, "./control/basicflow/flow-switch1.ts": __vite_glob_0_66$1, "./control/basicflow/flow-task.ts": __vite_glob_0_67$1, "./control/basicflow/flow-task1.ts": __vite_glob_0_68$1, "./control/basicflow/flow-task2.ts": __vite_glob_0_69$1, "./control/common/bidfunnel.ts": __vite_glob_0_70$1, "./control/common/bracket-big-left-text.ts": __vite_glob_0_71$1, "./control/common/bracket-big-left.ts": __vite_glob_0_72$1, "./control/common/bracket-big-right-text.ts": __vite_glob_0_73$1, "./control/common/bracket-big-right.ts": __vite_glob_0_74$1, "./control/common/bracket-big-text.ts": __vite_glob_0_75$1, "./control/common/bracket-middle-left-text.ts": __vite_glob_0_76$1, "./control/common/bracket-middle-left.ts": __vite_glob_0_77$1, "./control/common/bracket-middle-right-text.ts": __vite_glob_0_78$1, "./control/common/bracket-middle-right.ts": __vite_glob_0_79$1, "./control/common/bracket-middle-text.ts": __vite_glob_0_80$1, "./control/common/bracket-small-left-text.ts": __vite_glob_0_81$1, "./control/common/bracket-small-left.ts": __vite_glob_0_82$1, "./control/common/bracket-small-right-text.ts": __vite_glob_0_83$1, "./control/common/bracket-small-right.ts": __vite_glob_0_84$1, "./control/common/bracket-small-text.ts": __vite_glob_0_85$1, "./control/common/comment.ts": __vite_glob_0_86$1, "./control/common/comment1.ts": __vite_glob_0_87$1, "./control/common/database.ts": __vite_glob_0_88$1, "./control/common/database1.ts": __vite_glob_0_89$1, "./control/common/database2.ts": __vite_glob_0_90$1, "./control/common/database3.ts": __vite_glob_0_91$1, "./control/common/document.ts": __vite_glob_0_92$1, "./control/common/human.ts": __vite_glob_0_93$1, "./control/common/human1.ts": __vite_glob_0_94$1, "./control/common/human2.ts": __vite_glob_0_95$1, "./control/common/papertape.ts": __vite_glob_0_96$1, "./control/layer.ts": __vite_glob_0_97$1, "./control/math/angle.ts": __vite_glob_0_98$1, "./control/stage.ts": __vite_glob_0_99$1 });
const group_ctx$1 = /* @__PURE__ */ Object.assign({ "./group/basic/basic-flow-shapes.ts": __vite_glob_1_0$1, "./group/basic/basic-shapes.ts": __vite_glob_1_1$1, "./group/common/databases.ts": __vite_glob_1_2$1 });
const _DDeiCoreControls = class _DDeiCoreControls extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "controls", /* @__PURE__ */ new Map());
}
getControls(editor) {
let extOptions = this.getOptions();
let controls2 = /* @__PURE__ */ new Map();
let controls1 = new Map(editor.controls);
for (let i2 in control_ctx$1) {
let control = control_ctx$1[i2].default;
if (control) {
let c = cloneDeep(control);
controls2.set(control.id, c);
controls1.set(control.id, c);
if (extOptions && extOptions[control.id]) {
for (let x2 in extOptions[control.id]) {
c.define[x2] = extOptions[control.id][x2];
}
}
}
}
controls2.forEach((control) => {
loadControlByFrom(controls1, control);
});
this.controls = controls2;
return controls2;
}
getGroups(editor) {
if (!this.controls) {
this.getControls(editor);
}
let groups = [];
for (let path in group_ctx$1) {
groups.push(group_ctx$1[path].default);
}
loadAndSortGroup(groups, this.controls);
return groups;
}
static configuration(options) {
if (options) {
let controls2 = new _DDeiCoreControls(options);
return controls2;
}
return _DDeiCoreControls;
}
static modify(fn) {
return _DDeiCoreControls.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreControls, "defaultIns", new _DDeiCoreControls(null));
let DDeiCoreControls = _DDeiCoreControls;
const _MenuCancelMergeCell = class _MenuCancelMergeCell extends DDeiMenuBase {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-menu-cancel-merge-cell");
__publicField3(this, "defaultOptions", {
"label": "取消合并单元格",
"icon": "icon-merge-cells",
"disabled": false
});
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_MenuCancelMergeCell.defaultIns.name]) {
for (let i2 in options[_MenuCancelMergeCell.defaultIns.name]) {
newOptions[i2] = options[_MenuCancelMergeCell.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _MenuCancelMergeCell(newOptions);
return panels;
}
}
return _MenuCancelMergeCell;
}
static modify(fn) {
return _MenuCancelMergeCell.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
/**
* 执行的方法
*/
action(model, evt) {
if ((model == null ? void 0 : model.baseModelType) == "DDeiTable") {
let table2 = model;
table2.cancelSelectedMergeCells();
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
model.stage.ddInstance.bus.executeAll();
}
}
/**
* 判定是否显示的方法
*/
isVisiable(model) {
if (!this.disabled && (model == null ? void 0 : model.baseModelType) == "DDeiTable") {
let table2 = model;
let selectedCells = table2.getSelectedCells();
if (selectedCells.length == 1 && (selectedCells[0].mergeRowNum > 1 || selectedCells[0].mergeColNum > 1)) {
return true;
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_MenuCancelMergeCell, "defaultIns", new _MenuCancelMergeCell());
let MenuCancelMergeCell = _MenuCancelMergeCell;
const _MenuCopySheet = class _MenuCopySheet extends DDeiMenuBase {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-menu-copy-sheet");
__publicField3(this, "defaultOptions", {
"label": "ddei.copy",
"icon": "#icon-paste",
"models": ["DDeiSheet"],
"disabled": false
});
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_MenuCopySheet.defaultIns.name]) {
for (let i2 in options[_MenuCopySheet.defaultIns.name]) {
newOptions[i2] = options[_MenuCopySheet.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _MenuCopySheet(newOptions);
return panels;
}
}
return _MenuCopySheet;
}
static modify(fn) {
return _MenuCopySheet.defaultIns.modify(fn);
}
/**
* 执行的方法
*/
action(model, evt) {
var _a3, _b2, _c2, _d2, _e2;
if (model.modelType == "DDeiSheet") {
let editor = DDeiEditor.ACTIVE_INSTANCE;
let file = editor == null ? void 0 : editor.files[editor.currentFileIndex];
let ddInstance = model.stage.ddInstance;
let rsState = DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_SHEET_BEFORE", "ADD_SHEET", null, ddInstance, null);
if (rsState != -1) {
let sheetJson = model.toJSON();
let dpi = (_a3 = ddInstance.dpi) == null ? void 0 : _a3.x;
if (!sheetJson.stage.dpi) {
sheetJson.stage.dpi = dpi;
}
let unit = sheetJson.stage.unit;
if (dpi && unit && unit != "px") {
(_c2 = (_b2 = sheetJson.stage) == null ? void 0 : _b2.layers) == null ? void 0 : _c2.forEach((layer2) => {
DDeiUtil.convertChildrenJsonUnit(layer2, sheetJson.stage, unit);
});
}
let newSheet = DDeiSheet.loadFromJSON(sheetJson, { currentDdInstance: ddInstance });
let pageText = editor.i18n("ddei.page");
file.sheets.splice((file == null ? void 0 : file.currentSheetIndex) + 1, 0, newSheet);
newSheet.name = pageText + "-" + file.sheets.length;
file.changeSheet(file.currentSheetIndex + 1);
let stage2 = newSheet.stage;
stage2.ddInstance = ddInstance;
ddInstance.stage = stage2;
stage2.initRender();
editor.changeState(DDeiEditorState.DESIGNING);
editor.bus.push(DDeiEditorEnumBusCommandType.ClearTemplateUI);
editor.bus.push(DDeiEnumBusCommandType.RefreshShape, null, null);
editor.bus.push(DDeiEnumBusCommandType.AddHistroy);
editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, { parts: ["bottommenu"] });
(_d2 = editor.bus) == null ? void 0 : _d2.executeAll();
(_e2 = editor.editorViewer) == null ? void 0 : _e2.changeFileModifyDirty();
}
}
}
/**
* 判定是否显示的方法
*/
isVisiable(model) {
var _a3;
if (model) {
let allowEditSheet = ((_a3 = model.stage.ddInstance) == null ? void 0 : _a3.AC_DESIGN_EDIT) != false ? true : false;
return allowEditSheet && !this.disabled;
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_MenuCopySheet, "defaultIns", new _MenuCopySheet());
let MenuCopySheet = _MenuCopySheet;
const _MenuInsertCol = class _MenuInsertCol extends DDeiMenuBase {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-menu-insert-col");
__publicField3(this, "defaultOptions", {
"label": "合并单元格",
"icon": "icon-merge-cells",
"disabled": false
});
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_MenuInsertCol.defaultIns.name]) {
for (let i2 in options[_MenuInsertCol.defaultIns.name]) {
newOptions[i2] = options[_MenuInsertCol.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _MenuInsertCol(newOptions);
return panels;
}
}
return _MenuInsertCol;
}
static modify(fn) {
return _MenuInsertCol.defaultIns.modify(fn);
}
/**
* 执行的方法
*/
action(model, evt) {
if ((model == null ? void 0 : model.baseModelType) == "DDeiTable") {
let table2 = model;
if (table2.curRow != void 0 && table2.curCol != void 0 && table2.curRow != -1 && table2.curCol != -1) {
let cell = table2.rows[table2.curRow][table2.curCol];
let col = cell.col;
if (col < 0) {
col = -1;
} else if (col > table2.cols.length - 1) {
col = table2.cols.length - 1;
}
table2.insertCol(col, 2);
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
model.stage.ddInstance.bus.executeAll();
}
}
}
/**
* 判定是否显示的方法
*/
isVisiable(model) {
if (!this.disabled && (model == null ? void 0 : model.baseModelType) == "DDeiTable") {
return true;
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_MenuInsertCol, "defaultIns", new _MenuInsertCol());
let MenuInsertCol = _MenuInsertCol;
const _MenuInsertRow = class _MenuInsertRow extends DDeiMenuBase {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-menu-insert-row");
__publicField3(this, "defaultOptions", {
"label": "插入行",
"icon": "icon-insert-row",
"disabled": false
});
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_MenuInsertRow.defaultIns.name]) {
for (let i2 in options[_MenuInsertRow.defaultIns.name]) {
newOptions[i2] = options[_MenuInsertRow.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _MenuInsertRow(newOptions);
return panels;
}
}
return _MenuInsertRow;
}
static modify(fn) {
return _MenuInsertRow.defaultIns.modify(fn);
}
/**
* 执行的方法
*/
action(model, evt) {
if ((model == null ? void 0 : model.baseModelType) == "DDeiTable") {
let table2 = model;
if (table2.curRow != void 0 && table2.curCol != void 0 && table2.curRow != -1 && table2.curCol != -1) {
let cell = table2.rows[table2.curRow][table2.curCol];
let row = cell.row;
if (row - 1 < 0) {
row = -1;
} else {
row = row - 1;
}
if (row < 0) {
row = -1;
} else if (row > table2.rows.length - 1) {
row = table2.rows.length - 1;
}
table2.insertRow(row, 1);
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
model.stage.ddInstance.bus.executeAll();
}
}
}
/**
* 判定是否显示的方法
*/
isVisiable(model) {
if (!this.disabled && (model == null ? void 0 : model.baseModelType) == "DDeiTable") {
return true;
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_MenuInsertRow, "defaultIns", new _MenuInsertRow());
let MenuInsertRow = _MenuInsertRow;
const _MenuMergeCell = class _MenuMergeCell extends DDeiMenuBase {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-menu-merge-cell");
__publicField3(this, "defaultOptions", {
"label": "插入列",
"icon": "icon-insert-col",
"disabled": false
});
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_MenuMergeCell.defaultIns.name]) {
for (let i2 in options[_MenuMergeCell.defaultIns.name]) {
newOptions[i2] = options[_MenuMergeCell.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _MenuMergeCell(newOptions);
return panels;
}
}
return _MenuMergeCell;
}
static modify(fn) {
return _MenuMergeCell.defaultIns.modify(fn);
}
/**
* 执行的方法
*/
action(model, evt) {
if ((model == null ? void 0 : model.baseModelType) == "DDeiTable") {
let table2 = model;
table2.mergeSelectedCells();
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
model.stage.ddInstance.bus.executeAll();
}
}
/**
* 判定是否显示的方法
*/
isVisiable(model) {
if (!this.disabled && (model == null ? void 0 : model.baseModelType) == "DDeiTable") {
let table2 = model;
let selectedCells = table2.getSelectedCells();
if (selectedCells.length >= 2) {
let minMaxColRow = table2.getMinMaxRowAndCol(selectedCells);
return table2.isAllSelected(minMaxColRow.minRow, minMaxColRow.minCol, minMaxColRow.maxRow, minMaxColRow.maxCol);
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_MenuMergeCell, "defaultIns", new _MenuMergeCell());
let MenuMergeCell = _MenuMergeCell;
const _MenuRemoveCol = class _MenuRemoveCol extends DDeiMenuBase {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-menu-remove-col");
__publicField3(this, "defaultOptions", {
"label": "删除列",
"icon": "icon-delete-column",
"disabled": false
});
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_MenuRemoveCol.defaultIns.name]) {
for (let i2 in options[_MenuRemoveCol.defaultIns.name]) {
newOptions[i2] = options[_MenuRemoveCol.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _MenuRemoveCol(newOptions);
return panels;
}
}
return _MenuRemoveCol;
}
static modify(fn) {
return _MenuRemoveCol.defaultIns.modify(fn);
}
/**
* 执行的方法
*/
action(model, evt) {
if ((model == null ? void 0 : model.baseModelType) == "DDeiTable") {
let table2 = model;
if (table2.curRow != void 0 && table2.curCol != void 0 && table2.curRow != -1 && table2.curCol != -1) {
let cell = table2.rows[table2.curRow][table2.curCol];
let col = cell.col;
if (col < 0) {
col = 0;
} else if (col > table2.cols.length - 1) {
col = table2.cols.length - 1;
}
table2.removeCol(col);
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
model.stage.ddInstance.bus.executeAll();
}
}
}
/**
* 判定是否显示的方法
*/
isVisiable(model) {
var _a3;
if (!this.disabled && (model == null ? void 0 : model.baseModelType) == "DDeiTable") {
if (((_a3 = model == null ? void 0 : model.cols) == null ? void 0 : _a3.length) > 1) {
return true;
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_MenuRemoveCol, "defaultIns", new _MenuRemoveCol());
let MenuRemoveCol = _MenuRemoveCol;
const _MenuRemoveRow = class _MenuRemoveRow extends DDeiMenuBase {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-menu-remove-row");
__publicField3(this, "defaultOptions", {
"label": "删除行",
"icon": "icon-delete-row",
"disabled": false
});
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_MenuRemoveRow.defaultIns.name]) {
for (let i2 in options[_MenuRemoveRow.defaultIns.name]) {
newOptions[i2] = options[_MenuRemoveRow.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _MenuRemoveRow(newOptions);
return panels;
}
}
return _MenuRemoveRow;
}
static modify(fn) {
return _MenuRemoveRow.defaultIns.modify(fn);
}
/**
* 执行的方法
*/
action(model, evt) {
if ((model == null ? void 0 : model.baseModelType) == "DDeiTable") {
let table2 = model;
if (table2.curRow != void 0 && table2.curCol != void 0 && table2.curRow != -1 && table2.curCol != -1) {
let cell = table2.rows[table2.curRow][table2.curCol];
let row = cell.row;
if (row < 0) {
row = 0;
} else if (row > table2.rows.length - 1) {
row = table2.rows.length - 1;
}
table2.removeRow(row);
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.NodifyChange);
model.stage.ddInstance.bus.push(DDeiEnumBusCommandType.AddHistroy, null, evt);
model.stage.ddInstance.bus.executeAll();
}
}
}
/**
* 判定是否显示的方法
*/
isVisiable(model) {
var _a3;
if (!this.disabled && (model == null ? void 0 : model.baseModelType) == "DDeiTable") {
if (((_a3 = model == null ? void 0 : model.rows) == null ? void 0 : _a3.length) > 1) {
return true;
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_MenuRemoveRow, "defaultIns", new _MenuRemoveRow());
let MenuRemoveRow = _MenuRemoveRow;
const _MenuRemoveSheet = class _MenuRemoveSheet extends DDeiMenuBase {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-menu-remove-sheet");
__publicField3(this, "defaultOptions", {
"label": "ddei.delete",
"icon": "#icon-remove",
"models": ["DDeiSheet"],
"disabled": false
});
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_MenuRemoveSheet.defaultIns.name]) {
for (let i2 in options[_MenuRemoveSheet.defaultIns.name]) {
newOptions[i2] = options[_MenuRemoveSheet.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _MenuRemoveSheet(newOptions);
return panels;
}
}
return _MenuRemoveSheet;
}
static modify(fn) {
return _MenuRemoveSheet.defaultIns.modify(fn);
}
action(model, evt) {
var _a3, _b2, _c2;
if (model.modelType == "DDeiSheet") {
let editor = DDeiEditor.ACTIVE_INSTANCE;
let file = editor == null ? void 0 : editor.files[editor.currentFileIndex];
if (file.sheets.length > 1) {
let ddInstance = model.stage.ddInstance;
let rsState = DDeiEditorUtil.invokeCallbackFunc("EVENT_DEL_SHEET_BEFORE", "DEL_SHEET", null, ddInstance, null);
if (rsState != -1) {
let currentIndex = -1;
for (let i2 = 0; i2 < ((_a3 = file == null ? void 0 : file.sheets) == null ? void 0 : _a3.length); i2++) {
if (file.sheets[i2].unicode == model.unicode) {
currentIndex = i2;
break;
}
}
file.sheets.splice(currentIndex, 1);
if (currentIndex <= file.currentSheetIndex) {
file.changeSheet(file.currentSheetIndex - 1);
}
let stage2 = file.sheets[file == null ? void 0 : file.currentSheetIndex].stage;
stage2.ddInstance = ddInstance;
ddInstance.stage.destroyRender();
ddInstance.stage = stage2;
stage2.initRender();
DDeiEditorUtil.invokeCallbackFunc("EVENT_DEL_SHEET_AFTER", "DEL_SHEET", null, ddInstance, null);
(_b2 = editor.editorViewer) == null ? void 0 : _b2.changeFileModifyDirty();
editor.bus.push(DDeiEnumBusCommandType.RefreshShape, null, null);
editor.bus.push(DDeiEnumBusCommandType.AddHistroy);
editor.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, { parts: ["bottommenu"] });
(_c2 = editor.bus) == null ? void 0 : _c2.executeAll();
_MenuRemoveSheet.showPopPicker(stage2);
editor.changeState(DDeiEditorState.DESIGNING);
}
}
}
}
static showPopPicker(stage2) {
var _a3;
if (((_a3 = stage2.selectedModels) == null ? void 0 : _a3.size) > 0) {
let models = Array.from(stage2.selectedModels.values());
if ((models == null ? void 0 : models.length) > 0) {
let height = 100;
let modelPos = DDeiUtil.getModelsDomAbsPosition(models);
let left = modelPos.left + modelPos.width / 2;
let top = modelPos.top + modelPos.height / 2;
if (modelPos.top - height <= modelPos.cTop) {
if (modelPos.height > 400) {
top = top + height + 20;
} else {
top = top + modelPos.height / 2 + 20;
}
} else {
top = top - height;
}
if (top < 0) {
top = modelPos.cTop + modelPos.cHeight / 2;
}
if (left < 0) {
left = 0;
}
DDeiEditorUtil.showDialog(this.editor, "ddei-core-dialog-quickpop", {
group: "canvas-pop"
}, { type: 99, left, top, hiddenMask: true }, null, true, true);
}
}
}
/**
* 判定是否显示的方法
*/
isVisiable(model) {
var _a3;
if (model) {
let allowEditSheet = ((_a3 = model.stage.ddInstance) == null ? void 0 : _a3.AC_DESIGN_EDIT) != false ? true : false;
if (allowEditSheet && !this.disabled && (model == null ? void 0 : model.modelType) == "DDeiSheet") {
let editor = DDeiEditor.ACTIVE_INSTANCE;
let file = editor == null ? void 0 : editor.files[editor.currentFileIndex];
if (file.sheets.length > 1) {
return true;
}
}
}
return false;
}
};
/**
* 缺省实例
*/
__publicField3(_MenuRemoveSheet, "defaultIns", new _MenuRemoveSheet());
let MenuRemoveSheet = _MenuRemoveSheet;
const _DDeiCoreMenus = class _DDeiCoreMenus extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [
MenuCancelMergeCell,
MenuCopySheet,
MenuInsertCol,
MenuInsertRow,
MenuMergeCell,
MenuRemoveCol,
MenuRemoveRow,
MenuRemoveSheet
]);
}
getMenus(editor) {
var _a3;
let menus2 = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getMenus(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getMenus(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
menus2 = menus2.concat(ls);
}
});
return menus2;
}
static configuration(options) {
var _a3;
let menus2 = new _DDeiCoreMenus(options);
for (let i2 = 0; i2 < ((_a3 = menus2.plugins) == null ? void 0 : _a3.length); i2++) {
menus2.plugins[i2] = menus2.plugins[i2].configuration(options, true);
}
return menus2;
}
static modify(fn) {
return _DDeiCoreMenus.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreMenus, "defaultIns", new _DDeiCoreMenus(null));
let DDeiCoreMenus = _DDeiCoreMenus;
const themeDefault = ".ddei-editor[theme='ddei-core-theme-default'] {\n --background: white;\n --theme: #F5F5F5;\n --text: black;\n --dot: #176eff;\n --hover: #e7e7e7;\n --icon: #424242;\n --border:#D5D5DF;\n --placeholder: #AdAdAd;\n --scroll-background: var(--theme);\n --scroll-hover: var(--hover);\n --scroll-border: var(--border);\n\n --panel-header:var(--theme);\n --panel-background: var(--background);\n --panel-title: var(--text);\n --panel-border: var(--border);\n --panel-hover: var(--hover);\n --panel-disabled: var(--theme);\n --panel-selected: var(--hover);\n --panel-title-disabled: #AdAdAd;\n --panel-title-selected: var(--text);\n\n\n --toolbox-header:var(--theme);\n --toolbox-background:var(--background);\n --toolbox-title:var(--text);\n --toolbox-hover:var(--hover);\n --toolbox-control-hover: #EDEFFF;\n --toolbox-control-hover-outline: 2px solid #BED0EF;\n --toolbox-control-title: var(--text);\n\n\n --topmenu-background: var(--background);\n --topmenu-header: var(--theme);\n\n\n\n --canvas-rule-background: var(--background);\n --canvas-rule-border: #E0E3E9;\n --canvas-scroll-background: var(--background);\n --canvas-scroll-border: #E0E3E9;\n --canvas-grid-line: rgb(220, 220, 220);\n --canvas-grid-dot: rgb(121, 121, 121);\n --canvas-control-border: black;\n --canvas-control-background: white;\n --canvas-control-title: #252525;\n\n --canvas-mark-title: #252525;\n --canvas-text-selection: #97bdf2;\n --canvas-text-cursor: black;\n}";
const __vite_glob_0_0$4 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: themeDefault
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiCoreThemeDefault = class _DDeiCoreThemeDefault extends DDeiThemeBase {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-theme-default");
__publicField3(this, "label", "默认");
__publicField3(this, "default", true);
}
getThemes(editor) {
let theme_ctx = /* @__PURE__ */ Object.assign({
"./theme-default.css": __vite_glob_0_0$4
});
for (let path in theme_ctx) {
let css = theme_ctx[path].default;
this.css = css;
}
return super.getThemes(editor);
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiCoreThemeDefault.defaultIns.name]) {
for (let i2 in options[_DDeiCoreThemeDefault.defaultIns.name]) {
newOptions[i2] = options[_DDeiCoreThemeDefault.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreThemeDefault(newOptions);
return panels;
}
}
return _DDeiCoreThemeDefault;
}
static modify(fn) {
return _DDeiCoreThemeDefault.defaultIns.modify(fn);
}
};
// //背景色
// background:string = 'white';
// //主题色
// theme:string = '#F5F5F5';
// //文本色
// text:string = 'black';
// //点缀色
// dot: string = '#176eff';
// //交互色
// active:string = '#edefff';
// //图标色
// icon:string = '#424242';
/**
* 缺省实例
*/
__publicField3(_DDeiCoreThemeDefault, "defaultIns", new _DDeiCoreThemeDefault());
let DDeiCoreThemeDefault = _DDeiCoreThemeDefault;
const themeBlack = ".ddei-editor[theme='ddei-core-theme-black'] {\n --background: #212121;\n --theme: #2c2c2c;\n --text: white;\n --dot: #176eff;\n --hover: rgb(60,60,60);\n --icon: white;\n --border: #DFDFDF;\n --placeholder: #A1A1A1;\n --scroll-background: var(--theme);\n --scroll-hover: var(--hover);\n --scroll-border: white;\n\n --panel-header: var(--theme);\n --panel-background: var(--background);\n --panel-title: var(--text);\n --panel-border: var(--border);\n --panel-hover: var(--hover);\n --panel-disabled: var(--theme);\n --panel-selected: var(--hover);\n --panel-title-disabled: #A1A1A1;\n --panel-title-selected: var(--text);\n\n\n\n --toolbox-header: var(--theme);\n --toolbox-background: var(--background);\n --toolbox-title: var(--text);\n --toolbox-hover: var(--hover);\n --toolbox-control-hover: var(--dot);\n --toolbox-control-hover-outline: 2px solid #BED0EF;\n --toolbox-control-title: var(--text);\n\n\n --canvas-rule-background: var(--theme);\n --canvas-rule-border: white;\n --canvas-scroll-background: var(--theme);\n --canvas-scroll-border: white;\n --canvas-grid-line: rgb(121, 121, 121);\n --canvas-grid-dot: rgb(121, 121, 121);\n --canvas-control-border: white;\n --canvas-control-background: var(--theme);\n --canvas-control-title: white;\n\n --canvas-mark-title: white;\n --canvas-text-selection: #97bdf2;\n --canvas-text-cursor: white;\n \n}";
const __vite_glob_0_0$3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: themeBlack
}, Symbol.toStringTag, { value: "Module" }));
const _DDeiCoreThemeBlack = class _DDeiCoreThemeBlack extends DDeiThemeBase {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-theme-black");
__publicField3(this, "label", "黑色");
}
getThemes(editor) {
let theme_ctx = /* @__PURE__ */ Object.assign({
"./theme-black.css": __vite_glob_0_0$3
});
for (let path in theme_ctx) {
let css = theme_ctx[path].default;
this.css = css;
}
return super.getThemes(editor);
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiCoreThemeBlack.defaultIns.name]) {
for (let i2 in options[_DDeiCoreThemeBlack.defaultIns.name]) {
newOptions[i2] = options[_DDeiCoreThemeBlack.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreThemeBlack(newOptions);
return panels;
}
}
return _DDeiCoreThemeBlack;
}
static modify(fn) {
return _DDeiCoreThemeBlack.defaultIns.modify(fn);
}
};
// //背景色
// background:string = 'black';
// //主题色
// theme:string = 'black';
// //文本色
// text:string = 'white';
// //点缀色
// dot: string = '#176eff';
// //交互色
// active:string = '#edefff';
// //图标色
// icon:string = '#424242';
/**
* 缺省实例
*/
__publicField3(_DDeiCoreThemeBlack, "defaultIns", new _DDeiCoreThemeBlack());
let DDeiCoreThemeBlack = _DDeiCoreThemeBlack;
const _DDeiCoreThemes = class _DDeiCoreThemes extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [DDeiCoreThemeDefault, DDeiCoreThemeBlack]);
}
getThemes(editor) {
var _a3;
let themes = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getThemes(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getThemes(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
themes = themes.concat(ls);
}
});
return themes;
}
static configuration(options) {
var _a3;
let themes = new _DDeiCoreThemes(options);
for (let i2 = 0; i2 < ((_a3 = themes.plugins) == null ? void 0 : _a3.length); i2++) {
themes.plugins[i2] = themes.plugins[i2].configuration(options, true);
}
return themes;
}
static modify(fn) {
return _DDeiCoreThemes.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreThemes, "defaultIns", new _DDeiCoreThemes(null));
let DDeiCoreThemes = _DDeiCoreThemes;
const _DDeiCoreLifeCycle = class _DDeiCoreLifeCycle extends DDeiLifeCycle {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-lifecycle");
__publicField3(this, "EVENT_MOUSE_MOVE_IN_LAYER", new DDeiFuncData("mouse-operating", 1, this.mouseOperating));
}
/**
* 正在进行鼠标操作
*/
mouseOperating(operateType, data, ddInstance, evt) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
DDeiEditorUtil.closeDialog(editor, "ddei-core-dialog-choosecontrol");
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiCoreLifeCycle.name]) {
for (let i2 in options[_DDeiCoreLifeCycle.name]) {
newOptions[i2] = options[_DDeiCoreLifeCycle.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreLifeCycle();
if (newOptions.name) {
panels.name = newOptions.name;
}
if (newOptions.sort) {
panels.sort = newOptions.sort;
}
return panels;
}
}
return _DDeiCoreLifeCycle;
}
static modify(fn) {
return _DDeiCoreLifeCycle.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreLifeCycle, "defaultIns", new _DDeiCoreLifeCycle(null));
let DDeiCoreLifeCycle = _DDeiCoreLifeCycle;
const _DDeiCoreLifeCycles = class _DDeiCoreLifeCycles extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "lifecyclies", DDeiCoreLifeCycle);
}
getLifeCyclies(editor) {
if (DDeiPluginBase.isSubclass(this.lifecyclies, DDeiPluginBase)) {
return this.lifecyclies.defaultIns.getLifeCyclies(editor);
} else if (this.lifecyclies instanceof DDeiPluginBase) {
return this.lifecyclies.getLifeCyclies(editor);
}
}
static configuration(options) {
let core = new _DDeiCoreLifeCycles(options);
core.lifecyclies = core.lifecyclies.configuration(options, true);
return core;
}
static modify(fn) {
return _DDeiCoreLifeCycles.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreLifeCycles, "defaultIns", new _DDeiCoreLifeCycles(null));
let DDeiCoreLifeCycles = _DDeiCoreLifeCycles;
const _DDeiCore = class _DDeiCore extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "order", 0);
__publicField3(this, "layouts", DDeiCoreLayouts);
__publicField3(this, "panels", DDeiCorePanels);
__publicField3(this, "components", DDeiCoreComponents);
__publicField3(this, "dialogs", DDeiCoreDialogs);
__publicField3(this, "propeditors", DDeiCorePVEditors);
__publicField3(this, "hotkeys", DDeiCoreHotkeys);
__publicField3(this, "controls", DDeiCoreControls);
__publicField3(this, "menus", DDeiCoreMenus);
__publicField3(this, "themes", DDeiCoreThemes);
__publicField3(this, "lifecycles", DDeiCoreLifeCycles);
}
getOptions() {
let options = {};
let array = [this.layouts, this.panels, this.propeditors, this.dialogs, this.components, this.hotkeys, this.controls, this.menus, this.themes, this.lifecycles];
array.forEach((plugin) => {
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
options = Object.assign({}, options, plugin.defaultIns.getOptions());
} else if (plugin instanceof DDeiPluginBase) {
options = Object.assign({}, options, plugin.getOptions());
}
});
return options;
}
getLangs(editor) {
const langModules = /* @__PURE__ */ Object.assign({ "./i18n/en_US.ts": __vite_glob_0_0$6, "./i18n/zh_CN.ts": __vite_glob_0_1$3 });
let langs = {};
for (let i2 in langModules) {
let langModule = langModules[i2];
let newI = i2.substring(i2.lastIndexOf("/") + 1, i2.lastIndexOf("."));
langs[newI] = langModule.default;
}
return langs;
}
getComponents(editor) {
if (DDeiPluginBase.isSubclass(this.components, DDeiPluginBase)) {
return this.components.defaultIns.getComponents(editor);
} else if (this.components instanceof DDeiPluginBase) {
return this.components.getComponents(editor);
}
}
getPanels(editor) {
if (DDeiPluginBase.isSubclass(this.panels, DDeiPluginBase)) {
return this.panels.defaultIns.getPanels(editor);
} else if (this.panels instanceof DDeiPluginBase) {
return this.panels.getPanels(editor);
}
}
getLayouts(editor) {
if (DDeiPluginBase.isSubclass(this.layouts, DDeiPluginBase)) {
return this.layouts.defaultIns.getLayouts(editor);
} else if (this.layouts instanceof DDeiPluginBase) {
return this.layouts.getLayouts(editor);
}
}
getLifeCyclies(editor) {
if (DDeiPluginBase.isSubclass(this.lifecycles, DDeiPluginBase)) {
return this.lifecycles.defaultIns.getLifeCyclies(editor);
} else if (this.lifecycles instanceof DDeiPluginBase) {
return this.lifecycles.getLifeCyclies(editor);
}
}
getDialogs(editor) {
if (DDeiPluginBase.isSubclass(this.dialogs, DDeiPluginBase)) {
return this.dialogs.defaultIns.getDialogs(editor);
} else if (this.dialogs instanceof DDeiPluginBase) {
return this.dialogs.getDialogs(editor);
}
}
getPropEditors(editor) {
if (DDeiPluginBase.isSubclass(this.propeditors, DDeiPluginBase)) {
return this.propeditors.defaultIns.getPropEditors(editor);
} else if (this.propeditors instanceof DDeiPluginBase) {
return this.propeditors.getPropEditors(editor);
}
}
getHotKeys(editor) {
if (DDeiPluginBase.isSubclass(this.hotkeys, DDeiPluginBase)) {
return this.hotkeys.defaultIns.getHotKeys(editor);
} else if (this.hotkeys instanceof DDeiPluginBase) {
return this.hotkeys.getHotKeys(editor);
}
}
getControls(editor) {
if (DDeiPluginBase.isSubclass(this.controls, DDeiPluginBase)) {
return this.controls.defaultIns.getControls(editor);
} else if (this.controls instanceof DDeiPluginBase) {
return this.controls.getControls(editor);
}
}
getGroups(editor) {
if (DDeiPluginBase.isSubclass(this.controls, DDeiPluginBase)) {
return this.controls.defaultIns.getGroups(editor);
} else if (this.controls instanceof DDeiPluginBase) {
return this.controls.getGroups(editor);
}
}
getMenus(editor) {
if (DDeiPluginBase.isSubclass(this.menus, DDeiPluginBase)) {
return this.menus.defaultIns.getMenus(editor);
} else if (this.menus instanceof DDeiPluginBase) {
return this.menus.getMenus(editor);
}
}
getThemes(editor) {
if (DDeiPluginBase.isSubclass(this.themes, DDeiPluginBase)) {
return this.themes.defaultIns.getThemes(editor);
} else if (this.themes instanceof DDeiPluginBase) {
return this.themes.getThemes(editor);
}
}
static configuration(options) {
let core = new _DDeiCore(options);
core.layouts = core.layouts.configuration(options, true);
core.panels = core.panels.configuration(options, true);
core.components = core.components.configuration(options, true);
core.dialogs = core.dialogs.configuration(options, true);
core.propeditors = core.propeditors.configuration(options, true);
core.hotkeys = core.hotkeys.configuration(options, true);
core.controls = core.controls.configuration(options, true);
core.menus = core.menus.configuration(options, true);
core.themes = core.themes.configuration(options, true);
core.lifecycles = core.lifecycles.configuration(options, true);
return core;
}
static modify(fn) {
return _DDeiCore.defaultIns.modify(fn);
}
};
__publicField3(_DDeiCore, "order", 0);
/**
* 缺省实例
*/
__publicField3(_DDeiCore, "defaultIns", new _DDeiCore(null));
let DDeiCore = _DDeiCore;
const cursorBrush = "";
const __vite_glob_0_0$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: cursorBrush
}, Symbol.toStringTag, { value: "Module" }));
const modules = /* @__PURE__ */ Object.assign({ "./icons/cursor-brush.png": __vite_glob_0_0$2 });
const ICONS = {};
for (let i2 in modules) {
let icon = modules[i2];
let newI = i2.substring(i2.lastIndexOf("/") + 1, i2.lastIndexOf("."));
ICONS[newI] = icon.default;
}
const ddei = "";
const iconfont = "";
window._iconfont_svg_string_4428875 = '', ((l) => {
var a = (h = (h = document.getElementsByTagName("script"))[h.length - 1]).getAttribute("data-injectcss"), h = h.getAttribute("data-disable-injectsvg");
if (!h) {
var t, o, i2, p, z, v = function(a2, h2) {
h2.parentNode.insertBefore(a2, h2);
};
if (a && !l.__iconfont__svg__cssinject__) {
l.__iconfont__svg__cssinject__ = true;
try {
document.write("");
} catch (a2) {
console && console.log(a2);
}
}
t = function() {
var a2, h2 = document.createElement("div");
h2.innerHTML = l._iconfont_svg_string_4428875, (h2 = h2.getElementsByTagName("svg")[0]) && (h2.setAttribute("aria-hidden", "true"), h2.style.position = "absolute", h2.style.width = 0, h2.style.height = 0, h2.style.overflow = "hidden", h2 = h2, (a2 = document.body).firstChild ? v(h2, a2.firstChild) : a2.appendChild(h2));
}, document.addEventListener ? ~["complete", "loaded", "interactive"].indexOf(document.readyState) ? setTimeout(t, 0) : (o = function() {
document.removeEventListener("DOMContentLoaded", o, false), t();
}, document.addEventListener("DOMContentLoaded", o, false)) : document.attachEvent && (i2 = t, p = l.document, z = false, m(), p.onreadystatechange = function() {
"complete" == p.readyState && (p.onreadystatechange = null, d());
});
}
function d() {
z || (z = true, i2());
}
function m() {
try {
p.documentElement.doScroll("left");
} catch (a2) {
return void setTimeout(m, 50);
}
d();
}
})(window);
const _sfc_main$7 = {
name: "DDei-Editor",
extends: null,
mixins: [],
props: {
//外部配置文件的定义,当传入外部配置文件时,用外部配置文件覆盖内部配置
options: {
type: Object,
default: null
},
id: {
type: String,
default: "ddei_editor"
}
},
data() {
return {
editor: null,
dragObj: null,
changeIndex: -1,
refreshMenu: false,
initLeftWidth: 0,
initRightWidth: 0
};
},
//注册组件
components: {
MenuDialog
},
computed: {},
watch: {},
created() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n;
autoLoadCommand();
if (!this.options) {
this.options = vue.markRaw({
//配置扩展插件
extensions: []
});
}
if (!this.options.extensions) {
this.options.extensions = [];
}
this.options.extensions.splice(0, 0, DDeiCore);
let editor = DDeiEditor.newInstance(this.id, this.id, true, this.options);
if ((_a3 = this.options) == null ? void 0 : _a3.i18n) {
if (this.options.i18n.langs) {
editor.registerLangs(this.options.i18n.langs);
}
}
editor.setI18nLang((_c2 = (_b2 = this.options) == null ? void 0 : _b2.i18n) == null ? void 0 : _c2.lang);
this.editor = editor;
this.editor.createRenderViewer = this.createRenderViewer;
this.editor.removeRenderViewer = this.removeRenderViewer;
editor.appContext = vue.getCurrentInstance().appContext;
if (this.options) {
this.editor.applyConfig(this.options.config);
this.editor.extConfig = this.options.config;
this.editor.ddInstance.applyConfig(this.options.config);
}
if (((_f = (_e2 = (_d2 = this.options) == null ? void 0 : _d2.config) == null ? void 0 : _e2.controlDefines) == null ? void 0 : _f.length) > 0) {
(_h = (_g = this.options) == null ? void 0 : _g.config) == null ? void 0 : _h.controlDefines.forEach((control) => {
if (this.editor.controls.has(control.id)) {
let oldControl = this.editor.controls.get(control.id);
if (control.define) {
for (let n in control.define) {
if (control.define[n] || control.define[n] == 0) {
oldControl.define[n] = control.define[n];
}
}
loadControlDefineExt(oldControl);
}
control = oldControl;
}
this.editor.controls.set(control.id, control);
loadControlByFrom(this.editor.controls, control);
});
}
if (((_k = (_j = (_i = this.options) == null ? void 0 : _i.config) == null ? void 0 : _j.groupDefines) == null ? void 0 : _k.length) > 0) {
loadAndSortGroup((_m = (_l = this.options) == null ? void 0 : _l.config) == null ? void 0 : _m.groupDefines, this.editor.controls);
this.options.config.groupDefines.forEach((group2) => {
let finded = false;
for (let i2 = 0; i2 < this.editor.groups.length; i2++) {
if (this.editor.groups[i2].id == group2.id) {
this.editor.groups[i2] = group2;
finded = true;
break;
}
}
if (!finded) {
this.editor.groups.push(group2);
}
});
this.editor.groups.sort((a, b) => {
return a.orderNo - b.orderNo;
});
this.options.config.groupDefines.forEach((group2) => {
group2.controls.forEach((control) => {
delete control.attrs;
});
});
}
(_n = this.editor.controls) == null ? void 0 : _n.forEach((control) => {
if (control.menus) {
if (!editorInstance.menuMapping[control.id]) {
editorInstance.menuMapping[control.id] = control.menus;
}
let menus2 = editorInstance.menuMapping[control.id];
for (let i2 = 0; i2 < menus2.length; i2++) {
for (let j2 in editorInstance.menus) {
if (editorInstance.menus[j2].name == menus2[i2].name) {
menus2[i2] = editorInstance.menus[j2];
break;
}
}
}
}
delete control.attrs;
});
DDeiEditorUtil.ICONS = ICONS;
},
mounted() {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
this.editor.editorViewer = this;
this.editor.htmlElement = this.$refs.editor_div;
this.editor.bindEvent();
this.editor.changeTheme("");
let options = this.editor.options;
if ((_a3 = options == null ? void 0 : options.config) == null ? void 0 : _a3.width) {
this.$refs.editor_div.style.width = ((_b2 = options == null ? void 0 : options.config) == null ? void 0 : _b2.width) + "px";
}
if ((_c2 = options == null ? void 0 : options.config) == null ? void 0 : _c2.height) {
this.$refs.editor_div.style.height = ((_d2 = options == null ? void 0 : options.config) == null ? void 0 : _d2.height) + "px";
}
if ((_e2 = options == null ? void 0 : options.config) == null ? void 0 : _e2.initData) {
let initData = options.config.initData;
let converters = this.editor.getEnabledConverters(initData, 1);
converters == null ? void 0 : converters.forEach((converter) => {
initData = converter.input(initData);
});
let controlInitJSON = DDeiEditorUtil.getModelInitJSON(this.editor.ddInstance, null, initData.controls);
if (controlInitJSON) {
this.editor.addControls(controlInitJSON);
}
}
if ((_f = options == null ? void 0 : options.config) == null ? void 0 : _f.access) {
this.editor.setAccessInfo(options.config.access);
} else if (((_g = options == null ? void 0 : options.config) == null ? void 0 : _g.readonly) == true || ((_h = options == null ? void 0 : options.config) == null ? void 0 : _h.readonly) == false) {
this.editor.setEditable(!options.config.readonly);
}
this.editor.bus.interceptor[DDeiEnumBusCommandType.NodifyChange] = {
after: [this.changeFileModifyDirty]
};
this.editor.bus.interceptor[DDeiEnumBusCommandType.ModelChangeValue] = {
after: [this.changeFileModifyDirty]
};
if (DDeiEditor.HISTROY_LEVEL == "file") {
this.editor.bus.interceptor[DDeiEnumBusCommandType.AddHistroy] = {
execute: [this.addFileHistroy]
};
}
this.editor.bus.interceptor[DDeiEnumBusCommandType.TextEditorChangeSelectPos] = {
execute: [this.textEditorChangeSelectPos]
};
if (!this.editor.setCurrentMenu) {
this.editor.setCurrentMenu = this.setCurrentMenu;
}
if (this.editor.needControlIcon) {
DDeiEditorUtil.getControlIcons(this.editor);
}
if (options == null ? void 0 : options.onMounted) {
options.onMounted(this.editor);
}
},
methods: {
mouseDown(event) {
DDeiEditor.ACTIVE_INSTANCE = this.editor;
},
/**
* 设置当前菜单
* @returns 控件ID
*/
setCurrentMenu(menus2) {
this.editor.currentMenuData = menus2;
this.refreshMenu = false;
this.$nextTick(() => {
this.refreshMenu = true;
});
},
changeFileModifyDirty() {
let action = DDeiEditorCommandFileDirty.newInstance();
return action.action(
{ state: DDeiFileState.MODIFY },
this.editor.bus,
null
);
},
//记录文件的histroy
addFileHistroy() {
let action = DDeiEditorCommandAddHistroy.newInstance();
return action.action({}, this.editor.bus, null);
},
textEditorChangeSelectPos() {
if (!this.editor.textEditorSelectedChange) {
this.editor.textEditorSelectedChange = 1;
} else {
this.editor.textEditorSelectedChange++;
}
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
},
createRenderViewer(model, operate, tempShape, composeRender) {
let editor = this.editor;
let vNode = editor.viewerMap.get(model.id);
if (vNode) {
if (operate == "VIEW") {
model.render.refreshView(editor, vNode, tempShape, composeRender);
} else if (operate == "VIEW-HIDDEN") {
vNode.el.style.display = "none";
}
} else {
let parentNode = model.layer.render.containerViewer;
let div = document.createElement("div");
div.setAttribute("mid", model.id);
parentNode.appendChild(div);
let opts = { editor, model };
if (model.render.viewerOption) {
for (let k in model.render.viewerOption) {
if (k != "viewer") {
opts[k] = model.render.viewerOption[k];
}
}
}
let vNode2 = vue.createVNode(model.render.viewer, opts);
let appContext = editor.appContext;
vNode2.appContext = appContext;
vue.render(vNode2, div);
editor.viewerMap.set(model.id, vNode2);
if (operate == "VIEW") {
model.render.refreshView(editor, vNode2, tempShape, composeRender);
}
}
},
removeRenderViewer(model) {
let editor = this.editor;
let vNode = editor.viewerMap.get(model.id);
if (vNode) {
vNode.component.isUnmounted = true;
vNode.component.update();
vNode.el.parentElement.remove();
editor.viewerMap.delete(model.id);
}
}
}
};
const Editor_vue_vue_type_style_index_0_lang = "";
const _hoisted_1$7 = ["id"];
const _hoisted_2$5 = ["id"];
const _hoisted_3$4 = ["id"];
function _sfc_render$7(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2;
const _component_MenuDialog = vue.resolveComponent("MenuDialog");
return vue.openBlock(), vue.createElementBlock("div", {
id: $props.id,
ref: "editor_div",
class: "ddei-editor",
onContextmenu: _cache[0] || (_cache[0] = vue.withModifiers(() => {
}, ["prevent"])),
onMousedown: _cache[1] || (_cache[1] = ($event) => $options.mouseDown($event))
}, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_a3 = $data.editor) == null ? void 0 : _a3.getLayout()), {
editor: $data.editor,
options: (_b2 = $data.editor) == null ? void 0 : _b2.getLayoutOptions()
}, null, 8, ["editor", "options"])),
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_c2 = $data.editor) == null ? void 0 : _c2.getDialogs(), (item, index) => {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.dialog), vue.mergeProps({
editor: $data.editor,
options: item.options,
ref_for: true
}, item.options), null, 16, ["editor", "options"]);
}), 256)),
vue.withDirectives(vue.createVNode(_component_MenuDialog, { editor: $data.editor }, null, 8, ["editor"]), [
[vue.vShow, !$data.refreshMenu]
]),
vue.createElementVNode("div", {
id: $props.id + "_dialog_background_div",
class: "dialog-background-div"
}, null, 8, _hoisted_2$5),
vue.createElementVNode("div", {
id: $props.id + "_ddei_cut_img_div",
class: "ddei-cut-img-div"
}, null, 8, _hoisted_3$4)
], 40, _hoisted_1$7);
}
const DDeiEditorView = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["render", _sfc_render$7]]);
const en_US = {
ddei: {
uml: {
active: "Active",
state: "State",
substate: "Substate",
compstate: "Composite",
initstate: "Initial",
finalstate: "Final",
statecontainer: "StateC",
object: "Object",
objname: "Object Name",
life: "Lifeline",
objlife: "ObjectLifeline",
seqobj: "Sequence",
rolelife: "RoleLifeline",
hcross: "HoriCros",
vcross: "VertCros",
sendsignal: "SendSignal",
recsignal: "ReceiveSignal",
recevent: "ReceiveEvent",
dot: "Dot",
pause: "Pause",
hlane: "HoriLane",
vlane: "VertLane",
matrix: "Matrix",
control: "Control",
controlflow: "ControlF",
node: "Node",
nodeins: "NodeInst",
initnode: "InitialN",
forknode: "ForkNode",
endnode: "EndNode",
startnode1: "StartN",
endnode1: "EndN",
flowend: "FlowEnd",
invoke: "Invoke",
transition: "Transition",
fork: "Fork",
container: "Container",
case: "UseCase",
ext: "Ext",
extpoint: "ExtPoint",
extcase: "ExtUseC",
system: "System",
role: "Role",
syspart: "SysParti",
participal: "Participant",
coop: "Collab",
assis: "Assoc",
generalization: "Genera",
include: "Include",
ui: "UI",
interface: "Interf",
reqinte: "ReqInter",
class: "Class",
classname: "ClassName",
simpleclass: "SimpCls",
activeclass: "ActCLs",
active1: "Active",
activebreak: "ActBreak",
muti: "Multi",
enum: "Enum",
datatype: "DataType",
signal: "Signal",
original: "Original",
constraint: "Constr",
collection: "Collect",
package: "Package",
overview: "Overvi",
model: "Model",
relation: "Relatio",
implement: "Implem",
together: "Aggr",
compose: "Compos",
dependent: "Depen",
link: "Link",
relationship: "Relatio",
component: "Component",
compbox: "CompBox",
compins: "CompInst",
direct: "Direct",
msg: "Message",
async: "Async",
asyncmsg: "AsyncMsg",
project: "Project",
projins: "ProjInst",
deploydes: "DeployD",
depdesins: "DeployDI",
sketchmap: "Sketch",
communication: "Communi",
extend: "Extend",
manifest: "Manife",
deploy: "Deploy",
entity: "Entity",
alternative: "Alterna",
loopnative: "LoopFrag",
altnative: "AltFrag",
optnative: "OptFrag",
paranative: "ParFrag",
customnative: "CustomF",
objdel: "ObjDel",
edge: "Edge",
switch: "Decisi",
simplehistory: "SimHis",
detailhistroy: "DetHis",
convert: "Convert",
groups: {
active: "UML-Active",
case: "UML-UseCase",
class: "UML-Class",
component: "UML-Component",
cooperate: "UML-Cooperate",
deploy: "UML-Deploy",
sequence: "UML-Sequence",
state: "UML-State"
}
}
}
};
const __vite_glob_0_0$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: en_US
}, Symbol.toStringTag, { value: "Module" }));
const zh_CN = {
ddei: {
uml: {
active: "活动",
state: "状态",
substate: "子状态机",
compstate: "复合状态",
initstate: "初始状态",
finalstate: "最终状态",
statecontainer: "状态容器",
object: "对象",
objname: "对象名",
life: "生命线",
objlife: "对象生命线",
seqobj: "序列对象",
rolelife: "角色生命线",
hcross: "水平交叉",
vcross: "垂直交叉",
sendsignal: "发送信号",
recsignal: "接收信号",
recevent: "接收事件",
dot: "点",
pause: "暂停",
hlane: "水平泳道",
vlane: "垂直泳道",
matrix: "矩阵",
control: "控制",
controlflow: "控制流",
node: "节点",
nodeins: "节点实例",
initnode: "初始节点",
forknode: "分叉节点",
endnode: "终止节点",
startnode1: "起点",
endnode1: "终点",
flowend: "流终",
invoke: "调用",
transition: "过渡",
fork: "分叉",
container: "容器",
case: "用例",
ext: "扩展",
extpoint: "扩展点",
extcase: "扩展用例",
system: "系统",
role: "角色",
syspart: "系统参与者",
participal: "参与者",
coop: "协作",
assis: "协会",
generalization: "泛化",
include: "包含",
ui: "界面",
interface: "接口",
reqinte: "需求接口",
class: "类",
classname: "类名",
simpleclass: "简单类",
activeclass: "活动类",
active1: "激活",
activebreak: "激活中断",
muti: "多重",
enum: "枚举",
datatype: "数据类型",
signal: "信号",
original: "原始",
constraint: "约束",
collection: "汇聚",
package: "包",
overview: "概述",
model: "模型",
relation: "关联",
implement: "实现",
together: "聚合",
compose: "组合",
dependent: "依赖",
link: "链接",
relationship: "关系",
component: "组件",
compbox: "组件盒",
compins: "组件实例",
direct: "方向",
msg: "消息",
async: "异步",
asyncmsg: "异步消息",
project: "项目",
projins: "项目实例",
deploydes: "部署描述",
depdesins: "部署描述实例",
sketchmap: "示意图",
communication: "通信",
extend: "继承",
manifest: "表明",
deploy: "部署",
entity: "实体",
alternative: "替代片段",
loopnative: "循环片段",
altnative: "抉择片段",
optnative: "选项片段",
paranative: "并行片段",
customnative: "自定义片段",
objdel: "对象删除",
edge: "边界",
switch: "判定",
simplehistory: "简略历史",
detailhistroy: "详细历史",
convert: "转换",
groups: {
active: "UML-活动",
case: "UML-用例",
class: "UML-类图",
component: "UML-组件",
cooperate: "UML-协作",
deploy: "UML-部署",
sequence: "UML-序列",
state: "UML-状态图"
}
}
}
};
const __vite_glob_0_1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: zh_CN
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveActive = {
"id": "308001",
"name": "ddei.uml.active",
"code": "act",
"desc": "UML的活动节点",
"from": "100500",
"define": {
width: 110,
height: 50,
text: "Activity",
font: {
size: 14
},
border: {
round: 10
},
textStyle: {
align: 3,
valign: 3
},
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: false,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
let x = sample.x,y = sample.y
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=y
break;
case 2:
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:x,y:y,select:1,clip:1,stroke:1,fill:1});
}`,
//下方子图标
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:35,y:30,type:1,stroke:1});
pvs.push({x:35,y:40,stroke:1,type:1,end:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:45,y:30,type:1,stroke:1});
pvs.push({x:45,y:40,stroke:1,type:1,end:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:35,y:30,type:1,stroke:1});
pvs.push({x:45,y:30,stroke:1,type:1,end:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:40,y:20,type:1,stroke:1});
pvs.push({x:40,y:40,stroke:1,type:1,end:1});
}
}`,
//定义锚点
`(i, sample, pvs, model, ovs){
switch(i){
case 0:
pvs.push({x:sample.x,y:sample.y-25,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y+25,type:0,oppoint:1});
break;
case 1:
pvs.push({x:sample.x-25,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x+25,y:sample.y,type:0,oppoint:1});
break;
case 2:
pvs.push({x:sample.x,y:sample.y-25,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y+25,type:0,oppoint:1});
break;
case 3:
pvs.push({x:sample.x-25,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x+25,y:sample.y,type:0,oppoint:1});
break;
}
}`,
//文本区域,margin:右10,下15
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
let x = sample.x,y = sample.y
switch(i){
case 0:
start = 1
x-=5
break;
case 1:
y=15
pvs[0].y=y
break;
case 2:
x+=5
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:x,y:y,text:1});
}`
]
}
}
};
const __vite_glob_0_0 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveActive
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveBranch = {
"id": "308023",
"name": "ddei.uml.fork",
"code": "uc",
"desc": "分叉",
"from": "301012",
"define": {
width: 50,
border: {
width: 1
},
fill: {
type: 0
}
}
};
const __vite_glob_0_1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveBranch
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveContainer = {
"id": "308015",
"name": "ddei.uml.container",
"code": "uc",
"desc": "容器",
"from": "302003"
};
const __vite_glob_0_2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveContainer
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveCross = {
"id": "308006",
"name": "ddei.uml.hcross",
"code": "cross",
"desc": "水平交叉",
"from": "301012"
};
const __vite_glob_0_3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveCross
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveCross1 = {
"id": "308007",
"name": "ddei.uml.vcross",
"code": "cross",
"desc": "垂直交叉",
"from": "301012",
"define": {
width: 10,
height: 100
}
};
const __vite_glob_0_4 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveCross1
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveCtrlflow = {
"id": "308019",
"name": "ddei.uml.recevent",
"code": "ctrlflow",
"desc": "接收事件",
"from": "100401",
"define": {
type: 1,
ep: {
type: 1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_5 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveCtrlflow
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveCtrlflow1 = {
"id": "308020",
"name": "ddei.uml.recevent",
"code": "ctrlflow",
"desc": "接收事件",
"from": "100401",
"define": {
type: 2,
ep: {
type: 1
},
pvs: [
{ x: -75, y: -75, z: 1 },
{ x: 75, y: 75, z: 1 }
]
}
};
const __vite_glob_0_6 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveCtrlflow1
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveObject = {
"id": "308005",
"name": "ddei.uml.object",
"code": "act",
"desc": "UML的对象节点",
"from": "102010",
"define": {
text: "Object"
}
};
const __vite_glob_0_7 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveObject
}, Symbol.toStringTag, { value: "Module" }));
const umlActivePoint = {
"id": "308012",
"name": "ddei.uml.dot",
"code": "point",
"desc": "点",
"from": "100001",
"define": {
width: 20,
height: 20
}
};
const __vite_glob_0_8 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActivePoint
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveRecevt = {
"id": "308011",
"name": "ddei.uml.recevent",
"code": "recevt",
"desc": "接收事件",
"from": "103007",
"define": {
width: 70,
height: 70,
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
}
};
const __vite_glob_0_9 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveRecevt
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveRecmsg = {
"id": "308009",
"name": "ddei.uml.recsignal",
"code": "uarm",
"desc": "接收信号",
"from": "100500",
"define": {
width: 110,
height: 70,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
//绘制线段区域
`(i, sample, pvs, model, ovs){
switch(i){
case 0:
pvs.push({begin:1,x:50,y:50,fill:1,clip:1,select:1,oppoint:2,stroke:1});
break;
case 1:
pvs.push({x:-50,y:50,fill:1,clip:1,oppoint:2,select:1,stroke:1});
break;
case 2:
pvs.push({x:-25,y:0,fill:1,clip:1,oppoint:2,stroke:1});
pvs.push({x:-50,y:-50,fill:1,clip:1,oppoint:2,select:1,stroke:1});
break;
case 3:
pvs.push({x:50,y:-50,fill:1,stroke:1,oppoint:2,op2close:1,clip:1,select:1,end:1});
break;
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
switch(i){
case 0:
pvs.push({begin:1,x:50,y:50,text:1});
break;
case 1:
pvs.push({x:-25,y:50,text:1});
break;
case 2:
pvs.push({x:-25,y:-50,text:1});
break;
case 3:
pvs.push({x:50,y:-50,text:1,end:1});
break;
}
}`
]
}
}
};
const __vite_glob_0_10 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveRecmsg
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveSendmsg = {
"id": "308008",
"name": "ddei.uml.sendsignal",
"code": "uasm",
"desc": "发送信号",
"from": "100500",
"define": {
width: 110,
height: 70,
//2为极坐标,缺省点为原点
poly: 2,
cIndex: 2,
//采样信息
sample: {
//一圈采样次数
loop: 4,
//半径距离
r: 50,
//初始次采样的开始角度
angle: 0,
//半径距离
//采样的规则,多组采样返回多组规则
rules: [
//绘制线段区域
`(i, sample, pvs, model, ovs){
switch(i){
case 0:
pvs.push({begin:1,x:75,y:0,fill:1,clip:1,select:1,oppoint:2,stroke:1});
break;
case 1:
pvs.push({x:50,y:50,fill:1,clip:1,text:1,select:1,oppoint:2,stroke:1});
pvs.push({x:-50,y:50,fill:1,clip:1,text:1,select:1,oppoint:2,stroke:1});
break;
case 2:
pvs.push({x:-50,y:-50,fill:1,clip:1,text:1,select:1,oppoint:2,stroke:1});
break;
case 3:
pvs.push({x:50,y:-50,fill:1,stroke:1,text:1,clip:1,oppoint:2,op2close:1,select:1,end:1});
break;
}
}`
]
},
iconPos: {
dx: -20
}
}
};
const __vite_glob_0_11 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveSendmsg
}, Symbol.toStringTag, { value: "Module" }));
const umlActiveState = {
"id": "308004",
"name": "ddei.uml.state",
"code": "state",
"desc": "UML的活动的状态节点",
"from": "100009",
"define": {
width: 120,
height: 80,
border: {
round: 5
},
ext: {
sample: {
//分割横线的纵坐标
pvalue: -20
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 115,
height: 20,
cIndex: 2,
id: "100002",
border: {
type: 0
},
fill: {
type: 0
},
text: "State",
initCPV: {
x: 0,
y: -27
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
},
{
width: 115,
height: 53,
cIndex: 2,
id: "100002",
textStyle: {
feed: 1
},
border: {
type: 0
},
fill: {
type: 0
},
text: "Action",
initCPV: {
x: 0,
y: 12
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
]
}
};
const __vite_glob_0_12 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActiveState
}, Symbol.toStringTag, { value: "Module" }));
const umlCaseCase = {
"id": "302002",
"name": "ddei.uml.case",
"code": "case",
"desc": "UML的用例图-用例",
"from": "100006",
"define": {
width: 110,
height: 70
}
};
const __vite_glob_0_13 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCaseCase
}, Symbol.toStringTag, { value: "Module" }));
const umlCaseCase1 = {
"id": "302006",
"name": "ddei.uml.extcase",
"code": "case",
"desc": "UML的用例节点",
"from": "100009",
"define": {
width: 140,
height: 90,
ext: {
sample: {
//分割横线的纵坐标
pvalue: -20
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 136,
height: 24,
cIndex: 2,
id: "100002",
border: {
type: 0
},
fill: {
type: 0
},
text: "ddei.uml.case",
initCPV: {
x: 0,
y: -31.5
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 136,
height: 55,
cIndex: 2,
id: "100002",
textStyle: {
valign: 1,
feed: 1
},
border: {
type: 0
},
fill: {
type: 0
},
text: "ddei.uml.extpoint",
initCPV: {
x: 0,
y: 16
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
]
}
};
const __vite_glob_0_14 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCaseCase1
}, Symbol.toStringTag, { value: "Module" }));
const umlCaseCase2 = {
"id": "302007",
"name": "ddei.uml.extcase",
"code": "case",
"desc": "UML的用例节点",
"from": "100104",
"define": {
width: 140,
height: 100,
ext: {
sample: {
eqrat: false,
//分割横线的纵坐标
pvalue: -10
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 85,
height: 24,
cIndex: 2,
id: "100002",
border: {
type: 0
},
fill: {
type: 0
},
text: "ddei.uml.case",
initCPV: {
x: 0,
y: -27.5
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 90,
height: 45,
cIndex: 2,
id: "100002",
textStyle: {
feed: 1
},
border: {
type: 0
},
fill: {
type: 0
},
text: "ddei.uml.extpoint",
initCPV: {
x: 0,
y: 13
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
]
}
};
const __vite_glob_0_15 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCaseCase2
}, Symbol.toStringTag, { value: "Module" }));
const umlCaseColl = {
"id": "302010",
"name": "ddei.uml.assis",
"code": "assis",
"desc": "协会",
"from": "100401",
"define": {
type: 2,
ep: {
type: -1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_16 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCaseColl
}, Symbol.toStringTag, { value: "Module" }));
const umlCaseCoop = {
"id": "302005",
"name": "ddei.uml.coop",
"code": "coop",
"desc": "UML的用例图-协作",
"from": "302002",
"define": {
border: {
dash: [10, 5]
}
}
};
const __vite_glob_0_17 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCaseCoop
}, Symbol.toStringTag, { value: "Module" }));
const umlCaseExtend = {
"id": "302013",
"name": "ddei.uml.ext",
"code": "ext",
"desc": "扩展",
"from": "100401",
"define": {
type: 2,
dash: [10, 10],
ep: {
type: 1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
],
iLinkModels: {
"0": { type: 3, dx: 0, dy: -10 }
}
},
//其它同时创建的平级控件
others: [
{
"id": "100002",
"define": {
width: 100,
height: 20,
text: "<>",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: 0,
y: -10
}
}
}
]
};
const __vite_glob_0_18 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCaseExtend
}, Symbol.toStringTag, { value: "Module" }));
const umlCaseInclude = {
"id": "302012",
"name": "ddei.uml.include",
"code": "inc",
"desc": "包含",
"from": "100401",
"define": {
type: 2,
dash: [10, 10],
ep: {
type: 1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
],
iLinkModels: {
"0": { type: 3, dx: 0, dy: -10 }
}
},
//其它同时创建的平级控件
others: [
{
"id": "100002",
"define": {
width: 100,
height: 20,
text: "<>",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: 0,
y: -10
}
}
}
]
};
const __vite_glob_0_19 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCaseInclude
}, Symbol.toStringTag, { value: "Module" }));
const umlCaseInterface = {
"id": "302014",
"name": "ddei.uml.interface",
"code": "inte",
"desc": "接口",
"from": "100401",
"define": {
type: 1,
sp: {
type: 2,
weight: 20
},
ep: {
type: -1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_20 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCaseInterface
}, Symbol.toStringTag, { value: "Module" }));
const umlCasePart = {
"id": "302004",
"name": "ddei.uml.participal",
"code": "parti",
"desc": "UML的用例图参与者",
"from": "100009",
"define": {
width: 140,
height: 90,
ext: {
sample: {
//分割横线的纵坐标
pvalue: -20
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 136,
height: 24,
cIndex: 2,
id: "100002",
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
align: 3
},
text: "<>",
initCPV: {
x: 0,
y: -31.5
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 136,
height: 60,
cIndex: 2,
id: "100002",
textStyle: {
align: 3,
feed: 1
},
border: {
type: 0
},
fill: {
type: 0
},
text: "ddei.uml.syspart",
initCPV: {
x: 0,
y: 13.5
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
]
}
};
const __vite_glob_0_21 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCasePart
}, Symbol.toStringTag, { value: "Module" }));
const umlCaseSystem = {
"id": "302003",
"name": "ddei.uml.system",
"code": "coop",
"desc": "UML的用例图-协作",
"from": "100201",
"define": {
width: 400,
height: 300,
text: "系统",
textStyle: {
valign: 1,
align: 3
},
font: {
size: 15
}
}
};
const __vite_glob_0_22 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCaseSystem
}, Symbol.toStringTag, { value: "Module" }));
const umlClassCls = {
"id": "307001",
"name": "ddei.uml.class",
"code": "cls",
"desc": "UML的类节点",
"from": "100008",
"define": {
width: 240,
height: 160,
border: {
round: 5
},
//扩展采样信息,用于在原有的基础上增加采样,或者覆盖采样的部分信息
ext: {
//追加一个从中间切开的采样点,用于横向切割
sample: {
rules: [
`(i, sample, pvs, model,ovs){
if(i == 0){
pvs.push({x:-50,y:(ovs[0].y-model.cpv.y),stroke:1,type:1});
pvs.push({x:50,y:(ovs[0].y-model.cpv.y),stroke:1,type:1});
}
}`,
`(i, sample, pvs, model,ovs){
if(i == 0){
pvs.push({x:-50,y:(ovs[1].y-model.cpv.y),stroke:1,type:1});
pvs.push({x:50,y:(ovs[1].y-model.cpv.y),stroke:1,type:1});
}
}`
]
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 240,
height: 30,
id: "100002",
cIndex: 1,
text: "ddei.uml.classname",
textStyle: {
bold: 1,
scale: 1
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: -65
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 240,
height: 64,
id: "100002",
cIndex: 1,
text: ` + attribute1:type = defaultValue
+ attribute2: type
- attribute3: type`,
textStyle: {
align: 1,
feed: 1,
scale: 1,
vspace: 2
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: -17
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 240,
height: 64,
id: "100002",
cIndex: 1,
text: ` + operation1(params):returnType
- operation2(params)
- operation3()`,
textStyle: {
align: 1,
feed: 1,
scale: 1,
vspace: 2
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: 47
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
],
//操作点定义
ovs: [
//定义标题区域的高度控制点
{
x: 0,
y: -31,
ix: 0,
iy: -50,
type: 1,
//纵向分割点
constraint: {
type: 2,
x0: 0,
x1: 0,
y0: -50,
y1: -20
},
//联动,控制第一个和第二个composes[0]的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_v_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[0]"],
nextModels: ["composes[1]"]
}
]
},
//定义属性区的高度控制点
{
x: 0,
y: 9.375,
ix: 0,
iy: 9.375,
type: 1,
//纵向分割点
constraint: {
type: 2,
x0: 0,
x1: 0,
y0: -31,
y1: 50
},
//联动,控制第一个和第二个composes[0]的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_v_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[1]"],
nextModels: ["composes[2]"]
}
]
}
]
}
};
const __vite_glob_0_23 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassCls
}, Symbol.toStringTag, { value: "Module" }));
const umlClassCls1 = {
"id": "307002",
"name": "ddei.uml.simpleclass",
"code": "cls",
"desc": "UML的简单类节点",
"from": "308005",
"define": {
width: 120,
height: 80,
text: "Class"
}
};
const __vite_glob_0_24 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassCls1
}, Symbol.toStringTag, { value: "Module" }));
const umlClassCls2 = {
"id": "307003",
"name": "ddei.uml.activeclass",
"code": "cls",
"desc": "UML的活动类节点",
"from": "102040",
"define": {
width: 180,
height: 115,
text: "Class"
}
};
const __vite_glob_0_25 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassCls2
}, Symbol.toStringTag, { value: "Module" }));
const umlClassConstraint = {
"id": "307011",
"name": "ddei.uml.constraint",
"code": "constraint",
"desc": "UML的类图约束节点",
"from": "104125",
"define": {
ext: {
composes: [
{},
{},
{
text: "Constraint",
textStyle: {
align: 3,
feed: 1,
scale: 1
}
}
]
}
}
};
const __vite_glob_0_26 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassConstraint
}, Symbol.toStringTag, { value: "Module" }));
const umlClassDt = {
"id": "307008",
"name": "ddei.uml.datatype",
"code": "datatype",
"desc": "UML的数据类型",
"from": "100002",
"define": {
width: 110,
height: 70,
text: `<>
Datatype`,
textStyle: {
valign: 1,
italic: 1,
feed: 1,
vspace: 2
}
}
};
const __vite_glob_0_27 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassDt
}, Symbol.toStringTag, { value: "Module" }));
const umlClassEnum = {
"id": "307007",
"name": "ddei.uml.enum",
"code": "enum",
"desc": "UML的枚举",
"from": "100002",
"define": {
width: 110,
height: 70,
text: `<>
Enumeration`,
textStyle: {
valign: 1,
italic: 1,
feed: 1,
vspace: 2
}
}
};
const __vite_glob_0_28 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassEnum
}, Symbol.toStringTag, { value: "Module" }));
const umlClassGeneralization = {
"id": "307019",
"name": "ddei.uml.generalization",
"code": "gen",
"desc": "泛化关系",
"from": "100401",
"define": {
type: 2,
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_29 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassGeneralization
}, Symbol.toStringTag, { value: "Module" }));
const umlClassImpl = {
"id": "307020",
"name": "ddei.uml.implement",
"code": "impl",
"desc": "实现关系",
"from": "100401",
"define": {
type: 2,
dash: [10, 10],
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_30 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassImpl
}, Symbol.toStringTag, { value: "Module" }));
const umlClassInterface = {
"id": "307004",
"name": "ddei.uml.interface",
"code": "inte",
"desc": "UML的接口节点",
"from": "100008",
"define": {
width: 230,
height: 100,
border: {
round: 5
},
//扩展采样信息,用于在原有的基础上增加采样,或者覆盖采样的部分信息
ext: {
//追加一个从中间切开的采样点,用于横向切割
sample: {
rules: [
`(i, sample, pvs, model,ovs){
if(i == 0){
pvs.push({x:-50,y:(ovs[0].y-model.cpv.y),stroke:1,type:1});
pvs.push({x:50,y:(ovs[0].y-model.cpv.y),stroke:1,type:1});
}
}`
]
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 230,
height: 30,
id: "100002",
cIndex: 1,
text: `<>
接口名`,
textStyle: {
bold: 1,
feed: 1,
scale: 1
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: -35
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 230,
height: 70,
id: "100002",
cIndex: 1,
text: ` + Operation A(int): void
+ Operation B(): void
- Operation C(int): int`,
textStyle: {
align: 1,
feed: 1,
scale: 1,
vspace: 2
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: 15
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
],
//操作点定义
ovs: [
//定义标题区域的高度控制点
{
x: 0,
y: -20,
ix: 0,
iy: -50,
type: 1,
//纵向分割点
constraint: {
type: 2,
x0: 0,
x1: 0,
y0: -50,
y1: -20
},
//联动,控制第一个和第二个composes[0]的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_v_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[0]"],
nextModels: ["composes[1]"]
}
]
}
]
}
};
const __vite_glob_0_31 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassInterface
}, Symbol.toStringTag, { value: "Module" }));
const umlClassLink = {
"id": "307018",
"name": "ddei.uml.relation",
"code": "uclink",
"desc": "UML的关联",
"from": "100040",
"define": {
width: 110,
height: 70
}
};
const __vite_glob_0_32 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassLink
}, Symbol.toStringTag, { value: "Module" }));
const umlClassModel = {
"id": "307014",
"name": "ddei.uml.model",
"code": "model",
"desc": "UML的模型节点",
"from": "305003",
"define": {
ext: {
sample: {
//新增一个三角形
rules: [
`(i, sample, pvs, model, ovs){
let baseX = (ovs[1].x-ovs[1].ovi.x-50)-6
let baseY = -50+(ovs[0].y-ovs[0].ovi.y)/2-4.5
pvs.push({begin:1,x:baseX,y:baseY,stroke:1});
pvs.push({x:baseX-4,y:baseY+8,stroke:1});
pvs.push({end:1,x:baseX+4,y:baseY+8,stroke:1});
}`
]
},
composes: [
{
text: "ddei.uml.model",
textStyle: {
align: 1
}
},
{
text: ""
}
]
}
}
};
const __vite_glob_0_33 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassModel
}, Symbol.toStringTag, { value: "Module" }));
const umlClassObj = {
"id": "307016",
"name": "ddei.uml.object",
"code": "obj",
"desc": "UML的对象节点",
"from": "100008",
"define": {
width: 230,
height: 100,
border: {
round: 5
},
//扩展采样信息,用于在原有的基础上增加采样,或者覆盖采样的部分信息
ext: {
//追加一个从中间切开的采样点,用于横向切割
sample: {
rules: [
`(i, sample, pvs, model,ovs){
if(i == 0){
pvs.push({x:-50,y:(ovs[0].y-model.cpv.y),stroke:1,type:1});
pvs.push({x:50,y:(ovs[0].y-model.cpv.y),stroke:1,type:1});
}
}`
]
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 230,
height: 30,
id: "100002",
cIndex: 1,
text: `ddei.uml.objname`,
textStyle: {
bold: 1,
feed: 1,
scale: 1
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: -35
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 230,
height: 70,
id: "100002",
cIndex: 1,
text: ` attribute A = value A
attribute B = value B`,
textStyle: {
align: 1,
feed: 1,
scale: 1,
vspace: 2
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: 15
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
],
//操作点定义
ovs: [
//定义标题区域的高度控制点
{
x: 0,
y: -20,
ix: 0,
iy: -50,
type: 1,
//纵向分割点
constraint: {
type: 2,
x0: 0,
x1: 0,
y0: -50,
y1: -20
},
//联动,控制第一个和第二个composes[0]的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_v_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[0]"],
nextModels: ["composes[1]"]
}
]
}
]
}
};
const __vite_glob_0_34 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassObj
}, Symbol.toStringTag, { value: "Module" }));
const umlClassOverview = {
"id": "307013",
"name": "ddei.uml.overview",
"code": "overview",
"desc": "UML的概述节点",
"from": "305003",
"define": {
ext: {
composes: [
{
width: 100,
height: 40,
text: `<>
Package`,
textStyle: {
feed: 1,
align: 1,
scale: 1
},
initCPV: {
x: -50,
y: -60
}
},
{
height: 120,
text: ""
}
],
//操作点扩展
ovs: [
{
x: -25,
y: -25,
ix: -25,
iy: -50,
constraint: {
type: 2,
x0: -25,
x1: -25,
y0: -50,
y1: -20
}
},
{
x: 0,
y: -37.5,
ix: -50,
iy: -37.5,
constraint: {
type: 2,
x0: -50,
x1: 50,
y0: -37.5,
y1: -37.5
}
}
]
}
}
};
const __vite_glob_0_35 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassOverview
}, Symbol.toStringTag, { value: "Module" }));
const umlClassPackage = {
"id": "307012",
"name": "ddei.uml.package",
"code": "package",
"desc": "UML的包节点",
"from": "305003",
"define": {
ext: {
composes: [
{},
{
text: ""
}
]
}
}
};
const __vite_glob_0_36 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassPackage
}, Symbol.toStringTag, { value: "Module" }));
const umlClassPrimitive = {
"id": "307010",
"name": "ddei.uml.original",
"code": "primitive",
"desc": "UML的原始",
"from": "100002",
"define": {
width: 110,
height: 70,
text: `<>
Primitive`,
textStyle: {
valign: 1,
italic: 1,
feed: 1,
vspace: 2
}
}
};
const __vite_glob_0_37 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassPrimitive
}, Symbol.toStringTag, { value: "Module" }));
const umlClassRel = {
"id": "307024",
"name": "ddei.uml.relation",
"code": "erl",
"desc": "UML类关联关系",
"from": "100401",
"define": {
type: 2,
ep: {
type: 1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_38 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassRel
}, Symbol.toStringTag, { value: "Module" }));
const umlClassSignal = {
"id": "307009",
"name": "ddei.uml.signal",
"code": "signal",
"desc": "UML的信号",
"from": "100002",
"define": {
width: 110,
height: 70,
text: `<>
Signal`,
textStyle: {
valign: 1,
italic: 1,
feed: 1,
vspace: 2
}
}
};
const __vite_glob_0_39 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassSignal
}, Symbol.toStringTag, { value: "Module" }));
const umlClassUi = {
"id": "307005",
"name": "ddei.uml.ui",
"code": "ui",
"desc": "UML的界面节点",
"from": "100002",
"define": {
width: 110,
height: 70,
text: `<>
Interface`,
textStyle: {
valign: 1,
italic: 1,
feed: 1,
vspace: 2
}
}
};
const __vite_glob_0_40 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClassUi
}, Symbol.toStringTag, { value: "Module" }));
const umlCompBox = {
"id": "305005",
"name": "ddei.uml.compbox",
"code": "cbox",
"desc": "UML的组件盒节点",
"from": "100008",
"define": {
width: 160,
height: 100,
text: "<>",
textStyle: {
valign: 1,
align: 3
},
ext: {
sample: {
rules: [
//文本区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:45,y:50,text:1});
pvs.push({x:-45,y:50,text:1});
pvs.push({x:-45,y:-17,text:1});
pvs.push({end:1,x:45,y:-17,text:1});
}
}`
]
}
},
composes: [
{
width: 20,
height: 20,
cIndex: 2,
id: "305101",
sample: {
textInput: 0
},
initCPV: {
x: 60,
y: -32
}
}
]
}
};
const __vite_glob_0_41 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompBox
}, Symbol.toStringTag, { value: "Module" }));
const umlCompComp = {
"id": "305001",
"name": "ddei.uml.component",
"code": "cmp",
"desc": "UML的组件节点",
"from": "100500",
"define": {
width: 120,
height: 75,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: false,
//允许文本输入
textInput: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
let x = sample.x,y = sample.y
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=y
break;
case 2:
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:x,y:y,select:1});
}`,
//线段与填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:50,y:50,stroke:1,oppoint:2,fill:1});
pvs.push({x:-37.5,y:50,stroke:1,oppoint:2,fill:1});
pvs.push({x:-37.5,y:34,stroke:1,fill:1});
pvs.push({x:-25,y:34,stroke:1,fill:1});
pvs.push({x:-25,y:16,stroke:1,fill:1});
pvs.push({x:-37.5,y:16,stroke:1,fill:1});
pvs.push({x:-37.5,y:-16,stroke:1,fill:1});
pvs.push({x:-25,y:-16,stroke:1,fill:1});
pvs.push({x:-25,y:-34,stroke:1,fill:1});
pvs.push({x:-37.5,y:-34,stroke:1,fill:1});
pvs.push({x:-37.5,y:-50,stroke:1,fill:1,oppoint:2});
pvs.push({end:1,x:50,y:-50,stroke:1,fill:1,oppoint:2,op2close:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:-50,y:34,stroke:1,fill:1});
pvs.push({x:-25,y:34,stroke:1,fill:1});
pvs.push({x:-25,y:16,stroke:1,fill:1});
pvs.push({x:-50,y:16,stroke:1,fill:1,end:1});
pvs.push({x:-50,y:25,type:0,oppoint:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:-50,y:-34,stroke:1,fill:1});
pvs.push({x:-25,y:-34,stroke:1,fill:1});
pvs.push({x:-25,y:-16,stroke:1,fill:1});
pvs.push({x:-50,y:-16,stroke:1,fill:1,end:1});
pvs.push({x:-50,y:-25,type:0,oppoint:1});
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(sample.textInput && i == 0){
pvs.push({begin:1,x:50,y:50,text:1});
pvs.push({x:-25,y:50,text:1});
pvs.push({x:-25,y:-50,text:1});
pvs.push({end:1,x:50,y:-50,text:1});
}
}`
]
}
}
};
const __vite_glob_0_42 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompComp
}, Symbol.toStringTag, { value: "Module" }));
const umlCompComp1 = {
"id": "305101",
"name": "ddei.uml.component",
"code": "cmp",
"desc": "UML的组件节点",
"from": "100500",
"define": {
width: 100,
height: 100,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: false,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//允许文本输入
textInput: 1,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
let x = sample.x,y = sample.y
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=y
break;
case 2:
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:x,y:y,select:1});
}`,
//线段与填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:50,y:50,stroke:1,oppoint:2,fill:1});
pvs.push({x:-25,y:50,stroke:1,oppoint:2,fill:1});
pvs.push({x:-25,y:34,stroke:1,fill:1});
pvs.push({x:0,y:34,stroke:1,fill:1});
pvs.push({x:0,y:16,stroke:1,fill:1});
pvs.push({x:-25,y:16,stroke:1,fill:1});
pvs.push({x:-25,y:-16,stroke:1,fill:1});
pvs.push({x:0,y:-16,stroke:1,fill:1});
pvs.push({x:0,y:-34,stroke:1,fill:1});
pvs.push({x:-25,y:-34,stroke:1,fill:1});
pvs.push({x:-25,y:-50,stroke:1,fill:1,oppoint:2});
pvs.push({end:1,x:50,y:-50,stroke:1,fill:1,oppoint:2,op2close:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:-50,y:34,stroke:1,fill:1});
pvs.push({x:0,y:34,stroke:1,fill:1});
pvs.push({x:0,y:16,stroke:1,fill:1});
pvs.push({x:-50,y:16,stroke:1,fill:1,end:1});
pvs.push({x:-50,y:25,type:0,oppoint:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:-50,y:-34,stroke:1,fill:1});
pvs.push({x:0,y:-34,stroke:1,fill:1});
pvs.push({x:0,y:-16,stroke:1,fill:1});
pvs.push({x:-50,y:-16,stroke:1,fill:1,end:1});
pvs.push({x:-50,y:-25,type:0,oppoint:1});
}
}`,
//文本区域
`(i, sample, pvs, model, ovs){
if(sample.textInput && i == 0){
pvs.push({begin:1,x:50,y:50,text:1});
pvs.push({x:-25,y:50,text:1});
pvs.push({x:-25,y:-50,text:1});
pvs.push({end:1,x:50,y:-50,text:1});
}
}`
]
}
}
};
const __vite_glob_0_43 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompComp1
}, Symbol.toStringTag, { value: "Module" }));
const umlCompCompose = {
"id": "305018",
"name": "ddei.uml.compose",
"code": "compose",
"desc": "组合关系",
"from": "305017",
"define": {
sp: {
type: 41
}
}
};
const __vite_glob_0_44 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompCompose
}, Symbol.toStringTag, { value: "Module" }));
const umlCompDependent = {
"id": "305016",
"name": "ddei.uml.dependent",
"code": "depen",
"desc": "依赖关系",
"from": "305015",
"define": {
dash: [10, 10]
}
};
const __vite_glob_0_45 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompDependent
}, Symbol.toStringTag, { value: "Module" }));
const umlCompDirect = {
"id": "305015",
"name": "ddei.uml.direct",
"code": "direct",
"desc": "方向关系",
"from": "100401",
"define": {
type: 2,
ep: {
type: 1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_46 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompDirect
}, Symbol.toStringTag, { value: "Module" }));
const umlCompInterface = {
"id": "305009",
"name": "ddei.uml.interface",
"code": "interface",
"desc": "接口",
"from": "100401",
"define": {
type: 2,
ep: {
type: -1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
],
//组合控件
composes: [
{
width: 20,
height: 20,
id: "100103",
cIndex: 1,
initCPV: {
x: 0,
y: 0,
z: 1
}
}
],
//操作点
ovs: [
{
x: 0,
y: 0,
ix: 0,
iy: 0,
//约束,控制点的移动路径和位置
constraint: {
type: 0
//不允许移动
},
//联动,点移动后控制的其它点
links: [
{
type: 1,
//1施加矩阵
pvs: ["composes[0]"]
}
]
}
]
}
};
const __vite_glob_0_47 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompInterface
}, Symbol.toStringTag, { value: "Module" }));
const umlCompNode = {
"id": "305002",
"name": "ddei.uml.node",
"code": "node",
"desc": "UML的组件节点",
"from": "100501",
"define": {
width: 200,
height: 160,
text: "ddei.uml.node",
textStyle: {
align: 1,
valign: 1
},
ext: {
sample: {
eqrat: false
}
}
}
};
const __vite_glob_0_48 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompNode
}, Symbol.toStringTag, { value: "Module" }));
const umlCompPackage = {
"id": "305003",
"name": "ddei.uml.package",
"code": "pkg",
"desc": "包",
"from": "100500",
"define": {
width: 200,
height: 160,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: false,
//只采样一次
loop: 1,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model,ovs){
pvs.push({begin:1,x:50,y:50,stroke:1,fill:1,clip:1,oppoint:2,select:1});
pvs.push({x:-50,y:50,stroke:1,fill:1,clip:1,oppoint:2,select:1});
pvs.push({x:-50,y:(ovs[0].y-model.cpv.y),stroke:1,fill:1,clip:1,oppoint:2,select:1});
pvs.push({x:-50,y:-50,stroke:1,fill:1,clip:1,oppoint:2,select:1});
pvs.push({x:(ovs[1].x-ovs[1].ovi.x-50),y:-50,stroke:1,fill:1,clip:1,oppoint:2,select:1});
pvs.push({x:(ovs[1].x-ovs[1].ovi.x-50),y:(ovs[0].y-model.cpv.y),stroke:1,fill:1,clip:1,oppoint:2,select:1});
pvs.push({x:50,y:(ovs[0].y-model.cpv.y),stroke:1,fill:1,clip:1,oppoint:2,op2close:1,select:1,end:1});
}`,
`(i, sample, pvs, model,ovs){
pvs.push({x:-50,y:(ovs[0].y-model.cpv.y),stroke:1,type:1});
pvs.push({x:50,y:(ovs[0].y-model.cpv.y),stroke:1,type:1});
}`
]
},
// 组合控件
composes: [
{
width: 80,
height: 20,
id: "100002",
cIndex: 2,
text: "Package",
fill: { type: 0 },
border: { type: 0 },
textStyle: {
feed: 1,
scale: 1
},
initCPV: {
x: -60,
y: -70
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 200,
height: 140,
id: "100002",
cIndex: 2,
fill: { type: 0 },
border: { type: 0 },
text: "Attribute",
textStyle: {
feed: 1,
scale: 1
},
initCPV: {
x: 0,
y: 10
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
],
//操作点定义
ovs: [
//定义垂直控制点
{
x: -30,
y: -37.5,
ix: -30,
iy: -50,
type: 1,
//纵向分割点
constraint: {
type: 2,
x0: -30,
x1: -30,
y0: -50,
y1: -20
},
//联动,控制composes的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_v_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[0]"],
nextModels: ["composes[1]"]
}
]
},
//上方标题的区域宽度控制点
{
x: -10,
y: -43.75,
ix: -50,
iy: -43.75,
type: 2,
//横向分割点
constraint: {
type: 2,
x0: -50,
x1: 50,
y0: -43.75,
y1: -43.75
},
//联动,控制第一个和第二个composes的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_h_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[0]"],
nextModels: []
}
]
}
],
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_49 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompPackage
}, Symbol.toStringTag, { value: "Module" }));
const umlCompRel = {
"id": "305014",
"name": "ddei.uml.dependent",
"code": "erl",
"desc": "依赖关系",
"from": "100401",
"define": {
type: 2,
ep: {
type: -1
},
sp: {
type: -1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_50 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompRel
}, Symbol.toStringTag, { value: "Module" }));
const umlCompReqinte = {
"id": "305010",
"name": "ddei.uml.reqinte",
"code": "reqinte",
"desc": "需求接口",
"from": "100401",
"define": {
type: 2,
ep: {
type: -1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
],
//组合控件
composes: [
{
width: 25,
height: 25,
id: "100110",
cIndex: 1,
initCPV: {
x: -75,
y: 0,
z: 1
}
}
],
//操作点
ovs: [
{
x: 0,
y: 0,
ix: 0,
iy: 0,
//约束,控制点的移动路径和位置
constraint: {
type: 0
//不允许移动
},
//联动,点移动后控制的其它点
links: [
{
type: 1,
//1施加矩阵
pvs: ["composes[0]"]
}
]
}
]
}
};
const __vite_glob_0_51 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompReqinte
}, Symbol.toStringTag, { value: "Module" }));
const umlCompTogether = {
"id": "305017",
"name": "ddei.uml.together",
"code": "together",
"desc": "依赖关系",
"from": "100401",
"define": {
type: 2,
ep: {
type: -1
},
sp: {
type: 4
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_52 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCompTogether
}, Symbol.toStringTag, { value: "Module" }));
const umlCopMsg = {
"id": "306003",
"name": "ddei.uml.msg",
"code": "msg",
"desc": "消息",
"from": "305015",
"define": {
dash: [],
ep: {
type: -1
}
}
};
const __vite_glob_0_53 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCopMsg
}, Symbol.toStringTag, { value: "Module" }));
const umlCopMsg1 = {
"id": "306004",
"name": "ddei.uml.msg",
"code": "msg",
"desc": "消息",
"from": "306003",
define: {
ep: {
type: 51,
weight: 15
},
iLinkModels: {
"0": { type: 3, dx: -135, dy: 0 }
}
},
others: [
{
"id": "100002",
"define": {
width: 100,
height: 20,
text: "Operation A()",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: -60,
y: 0
}
}
}
]
};
const __vite_glob_0_54 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCopMsg1
}, Symbol.toStringTag, { value: "Module" }));
const umlCopMsg2 = {
"id": "306005",
"name": "ddei.uml.msg",
"code": "msg",
"desc": "消息",
"from": "306004",
define: {
pvs: [
{ x: 0, y: 0, z: 1 },
{ x: 0, y: 50, z: 1 }
],
iLinkModels: {
"0": { type: 3, dx: -60, dy: 0 }
},
iconPos: {
dy: -50,
dx: 50
}
},
others: [
{
"id": "100002",
"define": {
width: 100,
height: 20,
text: "Operation A()",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: -60,
y: 25
}
}
}
]
};
const __vite_glob_0_55 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCopMsg2
}, Symbol.toStringTag, { value: "Module" }));
const umlCopMsg3 = {
"id": "306006",
"name": "ddei.uml.msg",
"code": "msg",
"desc": "消息",
"from": "306004",
define: {
pvs: [
{ x: 0, y: 0, z: 1 },
{ x: 0, y: 50, z: 1 }
],
iLinkModels: {
"0": { type: 3, dx: 65, dy: 0 }
},
iconPos: {
dy: -50,
dx: -50
}
},
others: [
{
"id": "100002",
"define": {
width: 100,
height: 20,
text: "Operation A()",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: 65,
y: 25
}
}
}
]
};
const __vite_glob_0_56 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCopMsg3
}, Symbol.toStringTag, { value: "Module" }));
const umlCopMsg4 = {
"id": "306007",
"name": "ddei.uml.msg",
"code": "msg",
"desc": "消息",
"from": "306004",
define: {
pvs: [
{ x: 0, y: 0, z: 1 },
{ x: -75, y: 0, z: 1 }
],
iLinkModels: {
"0": { type: 3, dx: 100, dy: 0 }
}
},
others: [
{
"id": "100002",
"define": {
width: 100,
height: 20,
text: "Operation A()",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: 65,
y: 0
}
}
}
]
};
const __vite_glob_0_57 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCopMsg4
}, Symbol.toStringTag, { value: "Module" }));
const umlCopMsg5 = {
"id": "306008",
"name": "ddei.uml.msg",
"code": "msg",
"desc": "消息",
"from": "306004",
define: {
pvs: [
{ x: 0, y: 0, z: 1 },
{ x: 0, y: -50, z: 1 }
],
iLinkModels: {
"0": { type: 3, dx: -60, dy: 0 }
},
iconPos: {
dy: 50,
dx: 50
}
},
others: [
{
"id": "100002",
"define": {
width: 100,
height: 20,
text: "Operation A()",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: -60,
y: -25
}
}
}
]
};
const __vite_glob_0_58 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCopMsg5
}, Symbol.toStringTag, { value: "Module" }));
const umlCopMsg6 = {
"id": "306009",
"name": "ddei.uml.msg",
"code": "msg",
"desc": "消息",
"from": "306004",
define: {
pvs: [
{ x: 0, y: 0, z: 1 },
{ x: 0, y: -50, z: 1 }
],
iLinkModels: {
"0": { type: 3, dx: 60, dy: 0 }
},
iconPos: {
dy: 50,
dx: -50
}
},
others: [
{
"id": "100002",
"define": {
width: 100,
height: 20,
text: "Operation A()",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: 65,
y: -25
}
}
}
]
};
const __vite_glob_0_59 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCopMsg6
}, Symbol.toStringTag, { value: "Module" }));
const umlDepComm = {
"id": "304018",
"name": "ddei.uml.communication",
"code": "comm",
"desc": "通信",
"from": "100401",
"define": {
type: 2,
ep: {
type: -1
},
sp: {
type: -1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_60 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepComm
}, Symbol.toStringTag, { value: "Module" }));
const umlDepCompIns = {
"id": "304005",
"name": "ddei.uml.compins",
"code": "compins",
"desc": "UML的组件实例",
"from": "305001",
"define": {
width: 140,
height: 80,
text: `Component
Instance`,
textStyle: {
feed: 1,
underline: 1,
align: 3
}
}
};
const __vite_glob_0_61 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepCompIns
}, Symbol.toStringTag, { value: "Module" }));
const umlDepCompIns1 = {
"id": "304007",
"name": "ddei.uml.compins",
"code": "compins",
"desc": "UML的组件实例",
"from": "304006",
"define": {
text: `<>
Component A`
}
};
const __vite_glob_0_62 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepCompIns1
}, Symbol.toStringTag, { value: "Module" }));
const umlDepComp = {
"id": "304004",
"name": "ddei.uml.component",
"code": "comp",
"desc": "UML的组件",
"from": "305001",
"define": {
width: 140,
height: 80,
text: "Component"
}
};
const __vite_glob_0_63 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepComp
}, Symbol.toStringTag, { value: "Module" }));
const umlDepComp1 = {
"id": "304006",
"name": "ddei.uml.component",
"code": "comp",
"desc": "UML的组件",
"from": "305005",
"define": {
textStyle: {
feed: 1,
valign: 1
}
}
};
const __vite_glob_0_64 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepComp1
}, Symbol.toStringTag, { value: "Module" }));
const umlDepDepend = {
"id": "304020",
"name": "ddei.uml.dependent",
"code": "depend",
"desc": "依赖",
"from": "100401",
"define": {
type: 2,
dash: [20, 10],
ep: {
type: 1
},
sp: {
type: -1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_65 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepDepend
}, Symbol.toStringTag, { value: "Module" }));
const umlDepDeploy = {
"id": "304023",
"name": "ddei.uml.deploy",
"code": "deploy",
"desc": "部署",
"from": "100401",
"define": {
type: 2,
dash: [20, 10],
ep: {
type: 1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
],
iLinkModels: {
"0": { type: 3, dx: 0, dy: -10 }
}
},
//其它同时创建的平级控件
others: [
{
"id": "100002",
"define": {
width: 100,
height: 20,
text: "<>",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: 0,
y: -10
}
}
}
]
};
const __vite_glob_0_66 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepDeploy
}, Symbol.toStringTag, { value: "Module" }));
const umlDepExtend = {
"id": "304019",
"name": "ddei.uml.extend",
"code": "extend",
"desc": "继承",
"from": "100401",
"define": {
type: 2,
ep: {
type: 1
},
sp: {
type: -1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_67 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepExtend
}, Symbol.toStringTag, { value: "Module" }));
const umlDepManifest = {
"id": "304022",
"name": "ddei.uml.manifest",
"code": "manifest",
"desc": "表明",
"from": "100401",
"define": {
type: 2,
dash: [20, 10],
ep: {
type: 1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
],
iLinkModels: {
"0": { type: 3, dx: 0, dy: -10 }
}
},
//其它同时创建的平级控件
others: [
{
"id": "100002",
"define": {
width: 100,
height: 20,
text: "<>",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: 0,
y: -10
}
}
}
]
};
const __vite_glob_0_68 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepManifest
}, Symbol.toStringTag, { value: "Module" }));
const umlDepNodeIns = {
"id": "304011",
"name": "ddei.uml.nodeins",
"code": "nodeins",
"desc": "UML的节点实例",
"from": "305002",
"define": {
text: `Node Instance`,
textStyle: {
align: 2,
valign: 1,
feed: 1,
underline: 1
}
}
};
const __vite_glob_0_69 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepNodeIns
}, Symbol.toStringTag, { value: "Module" }));
const umlDepNode = {
"id": "304010",
"name": "ddei.uml.node",
"code": "node",
"desc": "UML的节点",
"from": "305002",
"define": {
text: `Node`,
textStyle: {
align: 2,
valign: 1,
feed: 1
}
}
};
const __vite_glob_0_70 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepNode
}, Symbol.toStringTag, { value: "Module" }));
const umlDepObj = {
"id": "304003",
"name": "ddei.uml.object",
"code": "obj",
"desc": "UML的对象节点",
"from": "100008",
"define": {
width: 160,
height: 100,
//扩展采样信息,用于在原有的基础上增加采样,或者覆盖采样的部分信息
ext: {
//追加一个从中间切开的采样点,用于横向切割
sample: {
rules: [
`(i, sample, pvs, model,ovs){
if(i == 0){
pvs.push({x:-50,y:(ovs[0].y-model.cpv.y),stroke:1,type:1});
pvs.push({x:50,y:(ovs[0].y-model.cpv.y),stroke:1,type:1});
}
}`
]
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 160,
height: 30,
id: "100002",
cIndex: 1,
text: `ddei.uml.objname`,
textStyle: {
underline: 1,
feed: 1,
scale: 1,
align: 3
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: -35
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 160,
height: 70,
id: "100002",
cIndex: 1,
text: ` attribute A = value A`,
textStyle: {
align: 3,
feed: 1,
scale: 1,
vspace: 2
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: 15
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
],
//操作点定义
ovs: [
//定义标题区域的高度控制点
{
x: 0,
y: -20,
ix: 0,
iy: -50,
type: 1,
//纵向分割点
constraint: {
type: 2,
x0: 0,
x1: 0,
y0: -50,
y1: -20
},
//联动,控制第一个和第二个composes[0]的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_v_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[0]"],
nextModels: ["composes[1]"]
}
]
}
]
}
};
const __vite_glob_0_71 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepObj
}, Symbol.toStringTag, { value: "Module" }));
const umlDepOverviewIns = {
"id": "304014",
"name": "ddei.uml.depdesins",
"code": "ovins",
"desc": "UML的部署概述实例",
"from": "100002",
"define": {
text: `<>
Deployment
Specification A`,
textStyle: {
feed: 1
}
}
};
const __vite_glob_0_72 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepOverviewIns
}, Symbol.toStringTag, { value: "Module" }));
const umlDepOverview = {
"id": "304013",
"name": "ddei.uml.deploydes",
"code": "node",
"desc": "UML的部署概述",
"from": "100002",
"define": {
text: `<>`
}
};
const __vite_glob_0_73 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepOverview
}, Symbol.toStringTag, { value: "Module" }));
const umlDepTogether = {
"id": "304021",
"name": "ddei.uml.together",
"code": "together",
"desc": "聚合",
"from": "100401",
"define": {
type: 2,
ep: {
type: -1
},
sp: {
type: 4,
weight: 10
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_74 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDepTogether
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqActBreak = {
"id": "303005",
"name": "ddei.uml.activebreak",
"code": "actbreak",
"desc": "激活中断",
"from": "100500",
"define": {
width: 20,
height: 200,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
//一圈4次采样
loop: 1,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选择区
`(i, sample, pvs, model, ovs){
pvs.push({begin:1,x:50,y:50,clip:1,select:1});
pvs.push({x:-50,y:50,clip:1,select:1});
pvs.push({x:-50,y:-50,clip:1,select:1});
pvs.push({end:1,x:50,y:-50,clip:1,select:1});
}`,
//下半部分区域
`(i, sample, pvs, model, ovs){
let bpv = DDeiUtil.pointsToZero([model.bpv], model.cpv, model.rotate)[0]
let unitH = 15 * (bpv.y ? 100 / bpv.y : 1)
pvs.push({begin:1,x:50,y:50,stroke:1,fill:1});
pvs.push({x:-50,y:50,stroke:1,fill:1});
pvs.push({x:-50,y:unitH,stroke:1,fill:1});
pvs.push({end:1,x:50,y:0.5*unitH,stroke:1,fill:1});
}`,
//上办部分区域
`(i, sample, pvs, model, ovs){
let bpv = DDeiUtil.pointsToZero([model.bpv], model.cpv, model.rotate)[0]
let unitH = 15 * (bpv.y ? 100 / bpv.y : 1)
pvs.push({begin:1,x:-50,y:-50,stroke:1,fill:1});
pvs.push({x:50,y:-50,stroke:1,fill:1});
pvs.push({x:50,y:-0.5*unitH,stroke:1,fill:1});
pvs.push({end:1,x:-50,y:-unitH,stroke:1,fill:1});
}`,
//操作点
`(i, sample, pvs, model, ovs){
let bpv = DDeiUtil.pointsToZero([model.bpv], model.cpv, model.rotate)[0]
let unitH = 20 * (bpv.y ? 100 / bpv.y : 1)
for(let i = -50; i <= 50; i+=unitH){
pvs.push({ x: -50, y: i, type: 0, oppoint: 1 });
pvs.push({ x: 50, y: i, type: 0, oppoint: 1 });
}
}`
]
}
}
};
const __vite_glob_0_75 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqActBreak
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqAct = {
"id": "303004",
"name": "ddei.uml.active1",
"code": "act",
"desc": "激活",
"from": "100008",
"define": {
width: 20,
height: 200,
ext: {
sample: {
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
let bpv = DDeiUtil.pointsToZero([model.bpv], model.cpv, model.rotate)[0]
let unitH = 20 * (bpv.y ? 100/bpv.y : 1)
for(let i = -50;i <= 50;i+=unitH){
pvs.push({x:-50,y:i,oppoint:1});
pvs.push({x:50,y:i,oppoint:1});
}
}
}`
]
}
}
}
};
const __vite_glob_0_76 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqAct
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqActorLife = {
"id": "303015",
"name": "ddei.uml.rolelife",
"code": "actor",
"desc": "角色生命线",
"from": "100000",
"define": {
create: false,
initMerges: [0, 1],
ext: {
//清空所有属性
groups: []
},
iconPos: {
dy: -150
}
},
//其它同时创建的平级控件
others: [
{
"id": "303014"
},
{
"id": "303002",
"define": {
pvs: [
{ x: 0, y: 30, z: 1 },
{ x: 0, y: 450, z: 1 }
]
}
}
]
};
const __vite_glob_0_77 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqActorLife
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqActor = {
"id": "303014",
"name": "ddei.uml.role",
"code": "actor",
"desc": "角色",
"from": "103006",
"define": {
text: "Actor",
iconPos: {
dy: -10
},
depPos: {
type: 8
},
//一圈
depProps: {
"8": "text"
//映射属性
}
}
};
const __vite_glob_0_78 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqActor
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqAlt = {
"id": "303009",
"name": "ddei.uml.altnative",
"code": "alt",
"desc": "抉择片段",
"from": "303008",
"define": {
ext: {
composes: [
{ text: "Alt" }
]
}
}
};
const __vite_glob_0_79 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqAlt
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqAlternative = {
"id": "303007",
"name": "ddei.uml.alternative",
"code": "alternative",
"desc": "替代片段",
"from": "100008",
"define": {
width: 240,
height: 160,
//扩展采样信息,用于在原有的基础上增加采样,或者覆盖采样的部分信息
ext: {
sample: {
rules: [
`(i, sample, pvs, model,ovs){
if(i == 0){
pvs.push({begin:1,x:-50,y:(ovs[0].y-model.cpv.y),stroke:1});
pvs.push({x:-50,y:-50,stroke:1});
pvs.push({x:(ovs[2].x-ovs[2].ovi.x-50),y:-50,stroke:1});
pvs.push({x:(ovs[2].x-ovs[2].ovi.x-50),y:(ovs[0].y-model.cpv.y)-5,stroke:1});
pvs.push({x:(ovs[2].x-ovs[2].ovi.x-50)-5,y:(ovs[0].y-model.cpv.y),stroke:1});
pvs.push({x:-50,y:(ovs[0].y-model.cpv.y),stroke:1,end:1});
}
}`,
//追加一个从中间切开的采样点,用于横向切割
`(i, sample, pvs, model,ovs){
if(i == 0){
pvs.push({x:-50,y:(ovs[1].y-model.cpv.y),stroke:1,type:1});
pvs.push({x:50,y:(ovs[1].y-model.cpv.y),stroke:1,type:1});
}
}`
]
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 88,
height: 22,
id: "100002",
cIndex: 1,
text: "Alternative",
textStyle: {
scale: 1,
align: 1
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: -70,
y: -68
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 230,
height: 65,
id: "100002",
cIndex: 1,
text: `[Condition]`,
textStyle: {
align: 1,
feed: 1,
scale: 1,
vspace: 2
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: -22.5
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 230,
height: 65,
id: "100002",
cIndex: 1,
text: `[Else]`,
textStyle: {
align: 1,
feed: 1,
scale: 1,
vspace: 2
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: 45
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
],
//操作点定义
ovs: [
//定义标题区域的高度控制点
{
x: -31.25,
y: -35,
ix: -31.25,
iy: -50,
type: 1,
//纵向分割点
constraint: {
type: 2,
x0: -31.25,
x1: -31.25,
y0: -50,
y1: -20
},
//联动,控制第一个和第二个composes[0]的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_v_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[0]"],
nextModels: ["composes[1]"]
}
]
},
//定义属性区的高度控制点
{
x: 0,
y: 6,
ix: 0,
iy: 6,
type: 1,
//纵向分割点
constraint: {
type: 2,
x0: 0,
x1: 0,
y0: -35,
y1: 50
},
//联动,控制第一个和第二个composes[0]的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_v_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[1]"],
nextModels: ["composes[2]"]
}
]
},
//上方标题的区域宽度控制点
{
x: -10,
y: -43.75,
ix: -50,
iy: -43.75,
type: 2,
//横向分割点
constraint: {
type: 2,
x0: -40,
x1: 40,
y0: -43.75,
y1: -43.75
},
//联动,控制第一个和第二个composes的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_h_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[0]"],
nextModels: []
}
]
}
]
}
};
const __vite_glob_0_80 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqAlternative
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqAsync = {
"id": "303021",
"name": "ddei.uml.asyncmsg",
"code": "async",
"desc": "异步消息",
"from": "100401",
"define": {
type: 2,
ep: {
type: 1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_81 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqAsync
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqControl = {
"id": "303018",
"name": "ddei.uml.control",
"code": "control",
"desc": "控制",
"from": "100500",
"define": {
width: 60,
height: 60,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT) + 2
let x = er * sample.cos
let y = er * sample.sin
pvs.push({x:x,y:y,r:er,select:1});
}`,
//操作点
`(i, sample, pvs, model, ovs){
let x = sample.r * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = sample.r * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y,r:sample.r ,oppoint:1});
if(i == 3){
pvs.push({x:0,y:0,r:sample.r ,oppoint:3});
}
}`,
//绘制线段、填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({r:sample.r,stroke:1,fill:1,begin:1,end:1});
}
}`,
//上方箭头
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:0,y:-50,type:1,stroke:1});
pvs.push({x:7.5,y:-56.5,type:1,stroke:1});
pvs.push({x:0,y:-50});
pvs.push({x:6.5,y:-42.5,type:1,stroke:1});
pvs.push({end:1,x:0,y:-50,type:1,stroke:1});
}
}`
]
},
iconPos: {
dy: -10
},
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
},
//其它同时创建的平级控件
others: [
{
"id": "100002",
"define": {
width: 100,
height: 25,
text: "Control",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: 0,
y: 42
}
}
}
]
};
const __vite_glob_0_82 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqControl
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqCustom = {
"id": "303012",
"name": "ddei.uml.customnative",
"code": "custom",
"desc": "自定义片段",
"from": "303008",
"define": {
ext: {
composes: [
{ text: "Custom" }
]
}
}
};
const __vite_glob_0_83 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqCustom
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqEdge = {
"id": "303017",
"name": "ddei.uml.edge",
"code": "edge",
"desc": "边界",
"from": "100500",
"define": {
width: 60,
height: 60,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:50,y:50,select:1});
pvs.push({x:-65,y:50,select:1});
pvs.push({x:-65,y:-50,select:1});
pvs.push({x:50,y:-50,select:1});
}
}`,
//操作点
`(i, sample, pvs, model, ovs){
let x = sample.r * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = sample.r * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y,r:sample.r ,oppoint:1});
if(i == 3){
pvs.push({x:0,y:0,r:sample.r ,oppoint:3});
}
}`,
//绘制线段、填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({r:sample.r,stroke:1,fill:1,begin:1,end:1});
}
}`,
//左方线
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:-50,y:0,type:1,stroke:1});
pvs.push({end:1,x:-65,y:0,type:1,stroke:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:-65,y:50,type:1,stroke:1,oppoint:2});
pvs.push({end:1,x:-65,y:-50,type:1,stroke:1,oppoint:2});
}
}`
]
},
iconPos: {
dy: -10
},
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
},
//其它同时创建的平级控件
others: [
{
"id": "100002",
"define": {
width: 100,
height: 25,
text: "Boundary",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: 0,
y: 42
}
}
}
]
};
const __vite_glob_0_84 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqEdge
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqEntity = {
"id": "303016",
"name": "ddei.uml.entity",
"code": "entity",
"desc": "实体",
"from": "100500",
"define": {
width: 60,
height: 60,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT) + 2
let x = er * sample.cos
let y = er * sample.sin
pvs.push({x:x,y:y,r:er,select:1});
}`,
//操作点
`(i, sample, pvs, model, ovs){
let x = sample.r * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = sample.r * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y,r:sample.r ,oppoint:1});
if(i == 3){
pvs.push({x:0,y:0,r:sample.r ,oppoint:3});
}
}`,
//绘制线段、填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({r:sample.r,stroke:1,fill:1,begin:1,end:1});
}
}`,
//下方横线
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:-50,y:50,type:1,stroke:1});
pvs.push({end:1,x:50,y:50,type:1,stroke:1});
}
}`
]
},
iconPos: {
dy: -10
},
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
},
//其它同时创建的平级控件
others: [
{
"id": "100002",
"define": {
width: 100,
height: 25,
text: "Entity",
fill: { type: 0 },
border: { type: 0 },
initCPV: {
x: 0,
y: 42
}
}
}
]
};
const __vite_glob_0_85 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqEntity
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqInv = {
"id": "303019",
"name": "ddei.uml.invoke",
"code": "inv",
"desc": "调用",
"from": "100401",
"define": {
type: 2,
ep: {
type: 51
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_86 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqInv
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqLife = {
"id": "303002",
"name": "ddei.uml.life",
"code": "life",
"desc": "生命线",
"from": "100401",
"define": {
type: 1,
ep: {
type: -1
},
dash: [20, 10],
border: {
width: 2
},
pvs: [
{ x: 0, y: -225, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 0, y: 225, z: 1 }
],
//线段本身的一些限制
constraint: {
ep: {
//只允许开始节点创建链接
link: false
},
type: {
//直线的情况下,开始节点和结束节点的角度限制范围(旋转后则为角度+rotate)
"1": {
//限制角度区间
angles: [[90, 90], [0, 0], [180, 180], [-90, -90]]
}
}
}
}
};
const __vite_glob_0_87 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqLife
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqLoop = {
"id": "303008",
"name": "ddei.uml.loopnative",
"code": "loop",
"desc": "循环片段",
"from": "100008",
"define": {
width: 240,
height: 160,
//扩展采样信息,用于在原有的基础上增加采样,或者覆盖采样的部分信息
ext: {
//追加一个从中间切开的采样点,用于横向切割
sample: {
rules: [
`(i, sample, pvs, model,ovs){
if(i == 0){
pvs.push({begin:1,x:-50,y:(ovs[0].y-model.cpv.y),stroke:1});
pvs.push({x:-50,y:-50,stroke:1});
pvs.push({x:(ovs[1].x-ovs[1].ovi.x-50),y:-50,stroke:1});
pvs.push({x:(ovs[1].x-ovs[1].ovi.x-50),y:(ovs[0].y-model.cpv.y)-5,stroke:1});
pvs.push({x:(ovs[1].x-ovs[1].ovi.x-50)-5,y:(ovs[0].y-model.cpv.y),stroke:1});
pvs.push({x:-50,y:(ovs[0].y-model.cpv.y),stroke:1,end:1});
}
}`
]
},
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 88,
height: 22,
id: "100002",
cIndex: 1,
text: "Loop",
textStyle: {
scale: 1,
align: 1
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: -72,
y: -68
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
},
{
width: 230,
height: 130,
id: "100002",
cIndex: 1,
text: `[Parameters]`,
textStyle: {
align: 1,
valign: 1,
feed: 1,
scale: 1,
vspace: 2
},
fill: {
type: 0
},
border: {
type: 0
},
initCPV: {
x: 0,
y: 13
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
],
//操作点定义
ovs: [
//定义标题区域的高度控制点
{
x: -31.25,
y: -35,
ix: -31.25,
iy: -50,
type: 1,
//纵向分割点
constraint: {
type: 2,
x0: -31.25,
x1: -31.25,
y0: -50,
y1: -20
},
//联动,控制第一个和第二个composes[0]的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_v_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[0]"],
nextModels: ["composes[1]"]
}
]
},
//上方标题的区域宽度控制点
{
x: -10,
y: -43.75,
ix: -50,
iy: -43.75,
type: 2,
//横向分割点
constraint: {
type: 2,
x0: -40,
x1: 40,
y0: -43.75,
y1: -43.75
},
//联动,控制第一个和第二个composes的大小
//这里计算较为复杂,需要用脚本来进行控制
links: [
{
type: 99,
//执行脚本
script: ov_link_h_split_point,
//参数可以自定义,脚本中可以取到
models: ["composes[0]"],
nextModels: []
}
]
}
]
}
};
const __vite_glob_0_88 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqLoop
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqObj = {
"id": "303003",
"name": "ddei.uml.seqobj",
"code": "obj",
"desc": "序列对象",
"from": "100002",
"define": {
width: 120,
height: 60,
text: "ddei.uml.object"
}
};
const __vite_glob_0_89 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqObj
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqObjdel = {
"id": "303013",
"name": "ddei.uml.objdel",
"code": "objdel",
"desc": "对象删除",
"from": "100500",
"define": {
width: 40,
height: 40,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT) + 2
let x = er * sample.cos
let y = er * sample.sin
pvs.push({x:x,y:y,r:er,select:1});
}`,
//操作点
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:0,y:50,type:0,oppoint:1});
pvs.push({x:-50,y:0,type:0,oppoint:1});
pvs.push({x:0,y:-50,type:0,oppoint:1});
pvs.push({x:50,y:0,type:0,oppoint:1});
}
}`,
//绘制线段、填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:sample.x,y:sample.y,stroke:1,begin:1,type:1});
}else if(i == 2){
pvs.push({x:sample.x,y:sample.y,stroke:1,end:1,type:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 1){
pvs.push({x:sample.x,y:sample.y,stroke:1,begin:1,type:1});
}else if(i == 3){
pvs.push({x:sample.x,y:sample.y,stroke:1,end:1,type:1});
}
}`
]
},
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
}
};
const __vite_glob_0_90 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqObjdel
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqObjlife = {
"id": "303001",
"name": "ddei.uml.objlife",
"code": "obj",
"desc": "对象生命线",
"from": "100000",
"define": {
create: false,
initMerges: [0, 1],
iconPos: {
dy: -150
}
},
//其它同时创建的平级控件
others: [
{
"id": "303003"
},
{
"id": "303002",
"define": {
pvs: [
{ x: 0, y: 30, z: 1 },
{ x: 0, y: 450, z: 1 }
]
}
}
]
};
const __vite_glob_0_91 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqObjlife
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqOpt = {
"id": "303010",
"name": "ddei.uml.optnative",
"code": "opt",
"desc": "选项片段",
"from": "303008",
"define": {
ext: {
composes: [
{ text: "Opt" }
]
}
}
};
const __vite_glob_0_92 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqOpt
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqPackage = {
"id": "303006",
"name": "ddei.uml.package",
"code": "pkg",
"desc": "包",
"from": "305003"
};
const __vite_glob_0_93 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqPackage
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqPar = {
"id": "303011",
"name": "ddei.uml.paranative",
"code": "par",
"desc": "并行片段",
"from": "303008",
"define": {
ext: {
composes: [
{ text: "Par" }
]
}
}
};
const __vite_glob_0_94 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqPar
}, Symbol.toStringTag, { value: "Module" }));
const umlSeqTransition = {
"id": "303020",
"name": "ddei.uml.transition",
"code": "trans",
"desc": "过渡",
"from": "100401",
"define": {
type: 2,
dash: [20, 10],
ep: {
type: 1
},
pvs: [
{ x: 75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: -75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_95 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSeqTransition
}, Symbol.toStringTag, { value: "Module" }));
const umlStateBranch = {
"id": "301012",
"name": "ddei.uml.fork",
"code": "branch",
"desc": "UML的状态的分叉",
"from": "100002",
"define": {
width: 100,
height: 10,
border: {
width: 0,
round: 2
},
fill: {
color: "#017fff"
},
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
}
};
const __vite_glob_0_96 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateBranch
}, Symbol.toStringTag, { value: "Module" }));
const umlStateCollect = {
"id": "301013",
"name": "ddei.uml.collection",
"code": "coll",
"desc": "UML的状态的汇聚",
"from": "301012"
};
const __vite_glob_0_97 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateCollect
}, Symbol.toStringTag, { value: "Module" }));
const umlStateConstraint = {
"id": "301010",
"name": "ddei.uml.constraint",
"code": "constr",
"desc": "UML的约束",
"from": "103005",
"define": {
width: 140,
height: 90,
textStyle: {
align: 3,
feed: 1
},
text: ` Constraint Name :
Body`,
composes: [
{
width: 90,
height: 18,
cIndex: 3,
id: "100002",
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
align: 2
},
text: "<>",
initCPV: {
x: -15,
y: -35
},
attrLinks: [
{ code: "font", mapping: ["*"] },
{ code: "textStyle", mapping: ["*"] }
]
}
],
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
}
}
};
const __vite_glob_0_98 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateConstraint
}, Symbol.toStringTag, { value: "Module" }));
const umlStateConvert = {
"id": "301014",
"name": "ddei.uml.convert",
"code": "conv",
"desc": "转换",
"from": "100401",
"define": {
type: 2,
ep: {
type: 1
},
pvs: [
{ x: -75, y: 0, z: 1 },
{ x: 0, y: 0, z: 1 },
{ x: 75, y: 0, z: 1 }
]
}
};
const __vite_glob_0_99 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateConvert
}, Symbol.toStringTag, { value: "Module" }));
const umlStateEnd = {
"id": "301006",
"name": "ddei.uml.flowend",
"code": "end",
"desc": "UML流程终止",
"from": "100500",
"define": {
width: 40,
height: 40,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT) + 2
let x = er * sample.cos
let y = er * sample.sin
pvs.push({x:x,y:y,r:er,select:1});
}`,
//操作点
`(i, sample, pvs, model, ovs){
let x = sample.r * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = sample.r * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y,r:sample.r ,oppoint:1});
if(i == 3){
pvs.push({x:0,y:0,r:sample.r ,oppoint:3});
}
}`,
//绘制线段、填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({r:sample.r,stroke:1,fill:1,clip:1,begin:1,end:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:sample.x,y:sample.y,stroke:1,begin:1,type:1});
}else if(i == 2){
pvs.push({x:sample.x,y:sample.y,stroke:1,end:1,type:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 1){
pvs.push({x:sample.x,y:sample.y,stroke:1,begin:1,type:1});
}else if(i == 3){
pvs.push({x:sample.x,y:sample.y,stroke:1,end:1,type:1});
}
}`
]
},
ext: {
groups: [
{
name: "ddei.style",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash", "borderRound"]
}
]
}
]
}
}
};
const __vite_glob_0_100 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateEnd
}, Symbol.toStringTag, { value: "Module" }));
const umlStateHis = {
"id": "301008",
"name": "ddei.uml.simplehistory",
"code": "his",
"desc": "UML状态机简略历史",
"from": "100003",
"define": {
width: 40,
height: 40,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT) + 2
let x = er * sample.cos
let y = er * sample.sin
pvs.push({x:x,y:y,r:er,select:1});
}`,
//操作点
`(i, sample, pvs, model, ovs){
let x = sample.r * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = sample.r * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y,r:sample.r ,oppoint:1});
if(i == 3){
pvs.push({x:0,y:0,r:sample.r ,oppoint:3});
}
}`,
//绘制线段、填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({r:sample.r,stroke:1,fill:1,clip:1,begin:1,end:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:-17.5,y:-25,stroke:1,begin:1,type:1});
pvs.push({x:-17.5,y:25,stroke:1,end:1,type:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:17.5,y:-25,stroke:1,begin:1,type:1});
pvs.push({x:17.5,y:25,stroke:1,end:1,type:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:-17.5,y:0,stroke:1,begin:1,type:1});
pvs.push({x:17.5,y:0,stroke:1,end:1,type:1});
}
}`
]
},
ext: {
groups: [
{
name: "属性",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
}
]
}
]
}
}
};
const __vite_glob_0_101 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateHis
}, Symbol.toStringTag, { value: "Module" }));
const umlStateHis1 = {
"id": "301009",
"name": "ddei.uml.detailhistroy",
"code": "his",
"desc": "UML状态机详细历史",
"from": "100003",
"define": {
width: 40,
height: 40,
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: 1,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 45,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
//选中区域
`(i, sample, pvs, model, ovs){
let er = sample.r / Math.cos(45 * DDeiConfig.ROTATE_UNIT) + 2
let x = er * sample.cos
let y = er * sample.sin
pvs.push({x:x,y:y,r:er,select:1});
}`,
//操作点
`(i, sample, pvs, model, ovs){
let x = sample.r * Math.cos((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
let y = sample.r * Math.sin((sample.sita+45) * DDeiConfig.ROTATE_UNIT)
pvs.push({x:x,y:y,r:sample.r ,oppoint:1});
if(i == 3){
pvs.push({x:0,y:0,r:sample.r ,oppoint:3});
}
}`,
//绘制线段、填充区域
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({r:sample.r,stroke:1,fill:1,clip:1,begin:1,end:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:-25.5,y:-25,stroke:1,begin:1,type:1});
pvs.push({x:-25.5,y:25,stroke:1,end:1,type:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:9.5,y:-25,stroke:1,begin:1,type:1});
pvs.push({x:9.5,y:25,stroke:1,end:1,type:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:-25.5,y:0,stroke:1,begin:1,type:1});
pvs.push({x:9.5,y:0,stroke:1,end:1,type:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:13,y:-15,stroke:1,begin:1,type:1});
pvs.push({x:33,y:-15,stroke:1,end:1,type:1});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({x:23,y:-25,stroke:1,begin:1,type:1});
pvs.push({x:23,y:-5,stroke:1,end:1,type:1});
}
}`
]
},
ext: {
groups: [
{
name: "属性",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
}
]
}
]
}
}
};
const __vite_glob_0_102 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateHis1
}, Symbol.toStringTag, { value: "Module" }));
const umlStateState = {
"id": "301001",
"name": "ddei.uml.state",
"code": "state",
"desc": "UML的状态机节点",
"from": "100500",
"define": {
width: 110,
height: 50,
text: "State",
font: {
size: 14
},
border: {
round: 10
},
textStyle: {
align: 3
},
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: false,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
let x = sample.x,y = sample.y
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=y
break;
case 2:
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:x,y:y,select:1,clip:1,stroke:1,fill:1});
}`,
//定义锚点
`(i, sample, pvs, model, ovs){
switch(i){
case 0:
pvs.push({x:sample.x,y:sample.y-25,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y+25,type:0,oppoint:1});
break;
case 1:
pvs.push({x:sample.x-25,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x+25,y:sample.y,type:0,oppoint:1});
break;
case 2:
pvs.push({x:sample.x,y:sample.y-25,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y+25,type:0,oppoint:1});
break;
case 3:
pvs.push({x:sample.x-25,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x+25,y:sample.y,type:0,oppoint:1});
break;
}
}`,
//文本区域,右margin:5
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
let x = sample.x,y = sample.y
switch(i){
case 0:
start = 1
x-=5
break;
case 1:
pvs[0].y=y
break;
case 2:
x+=5
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:x,y:y,text:1});
}`
]
}
}
};
const __vite_glob_0_103 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateState
}, Symbol.toStringTag, { value: "Module" }));
const umlStateState1 = {
"id": "301003",
"name": "ddei.uml.state",
"code": "state",
"desc": "UML的状态机节点",
"from": "100009",
"define": {
width: 140,
height: 90,
border: {
round: 5
},
ext: {
sample: {
//分割横线的纵坐标
pvalue: -20
},
groups: [
{
name: "属性",
icon: "icon-fill",
subGroups: [
{
name: "ddei.style",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity", "border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
},
{
name: "文本",
attrs: [
"font.family",
"font.size",
"font.color",
"fontAlign",
"textStyle.feed",
"textStyle.scale",
"textStyle.hollow",
"textStyle.bold",
"textStyle.italic",
"textStyle.underline",
"textStyle.deleteline",
"textStyle.topline",
"textStyle.hspace",
"textStyle.vspace"
]
}
]
}
]
},
//组合控件
composes: [
{
width: 136,
height: 24,
cIndex: 2,
id: "100002",
border: {
type: 0
},
fill: {
type: 0
},
textStyle: {
align: 3
},
text: "Name",
initCPV: {
x: 0,
y: -31.5
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
},
{
width: 136,
height: 60,
cIndex: 2,
id: "100002",
textStyle: {
align: 3,
feed: 1
},
border: {
type: 0
},
fill: {
type: 0
},
text: "Activities",
initCPV: {
x: 0,
y: 13.5
},
attrLinks: [
{ code: "textStyle", mapping: ["*"] },
{ code: "font", mapping: ["*"] }
]
}
]
}
};
const __vite_glob_0_104 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateState1
}, Symbol.toStringTag, { value: "Module" }));
const umlStateSubstate = {
"id": "301002",
"name": "ddei.uml.substate",
"code": "substate",
"desc": "UML的子状态机节点",
"from": "100500",
"define": {
width: 110,
height: 50,
text: "State",
font: {
size: 14
},
border: {
round: 10
},
textStyle: {
align: 3,
valign: 3
},
//2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放
poly: 2,
//采样信息
sample: {
eqrat: false,
//一圈4次采样
loop: 4,
//初始次采样的开始角度
angle: 0,
//半径距离
r: 50,
//采样的规则,多组采样返回多组规则
rules: [
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
let x = sample.x,y = sample.y
switch(i){
case 0:
start = 1
break;
case 1:
pvs[0].y=y
break;
case 2:
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:x,y:y,select:1,clip:1,stroke:1,fill:1});
}`,
//下方子图标
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:40,y:40,stroke:1,rd:0});
pvs.push({x:30,y:40,stroke:1,rd:0});
pvs.push({x:30,y:30,stroke:1,rd:0});
pvs.push({x:40,y:30,stroke:1,end:1,rd:0});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:25,y:40,stroke:1,rd:0});
pvs.push({x:15,y:40,stroke:1,rd:0});
pvs.push({x:15,y:30,stroke:1,rd:0});
pvs.push({x:25,y:30,stroke:1,end:1,rd:0});
}
}`,
`(i, sample, pvs, model, ovs){
if(i == 0){
pvs.push({begin:1,x:30,y:35,type:1,stroke:1});
pvs.push({x:25,y:35,stroke:1,type:1,end:1});
}
}`,
//定义锚点
`(i, sample, pvs, model, ovs){
switch(i){
case 0:
pvs.push({x:sample.x,y:sample.y-25,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y+25,type:0,oppoint:1});
break;
case 1:
pvs.push({x:sample.x-25,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x+25,y:sample.y,type:0,oppoint:1});
break;
case 2:
pvs.push({x:sample.x,y:sample.y-25,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y+25,type:0,oppoint:1});
break;
case 3:
pvs.push({x:sample.x-25,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x,y:sample.y,type:0,oppoint:1});
pvs.push({x:sample.x+25,y:sample.y,type:0,oppoint:1});
break;
}
}`,
//文本区域,margin:右10,下15
`(i, sample, pvs, model, ovs){
let start = 0,end = 0
let x = sample.x,y = sample.y
switch(i){
case 0:
start = 1
x-=5
break;
case 1:
y=15
pvs[0].y=y
break;
case 2:
x+=5
pvs[1].x=x
break;
case 3:
pvs[2].y=y
x = pvs[0].x
end = 1
break;
}
pvs.push({begin:start,end:end,x:x,y:y,text:1});
}`
]
}
}
};
const __vite_glob_0_105 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateSubstate
}, Symbol.toStringTag, { value: "Module" }));
const umlStateSwitch = {
"id": "301007",
"name": "ddei.uml.switch",
"code": "switch",
"desc": "UML的状态分支",
"from": "100040",
"define": {
width: 40,
height: 40,
ext: {
groups: [
{
name: "属性",
icon: "icon-fill",
subGroups: [
{
name: "ddei.fill",
attrs: ["fill.type", "fill.color", "fill.image", "fill.opacity"]
},
{
name: "ddei.line",
attrs: ["border.type", "border.color", "borderOpacity", "borderWidth", "borderDash"]
}
]
}
]
}
}
};
const __vite_glob_0_106 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlStateSwitch
}, Symbol.toStringTag, { value: "Module" }));
const umlActive = {
"id": "308",
"name": "ddei.uml.groups.active",
"code": "uml-active",
"desc": "UML2.0中的活动图",
"subject": "uml",
"orderNo": 308,
//当前分组下所有控件
"controls": [
{
"id": "308001"
},
{
"id": "301001"
},
{
"id": "301002",
"name": "ddei.uml.state"
},
{
"id": "308004"
},
{
"id": "308005"
},
{
"id": "308006"
},
{
"id": "308007"
},
{
"id": "308008"
},
{
"id": "308009"
},
{
"id": "308010",
"name": "ddei.uml.pause"
},
{
"id": "308011"
},
{
"id": "308012"
},
{
"id": "103005"
},
{
"id": "308014",
"name": "ddei.uml.statecontainer"
},
{
"id": "308016",
"name": "ddei.uml.hlane"
},
{
"id": "308017",
"name": "ddei.uml.vlane"
},
{
"id": "308018",
"name": "ddei.uml.matrix"
},
{
"id": "308019",
"name": "ddei.uml.controlflow"
},
{
"id": "308020",
"name": "ddei.uml.controlflow"
},
{
"id": "102001",
"name": "ddei.uml.initnode"
},
{
"id": "102093",
"name": "ddei.uml.endnode"
},
{
"id": "308023",
"name": "ddei.uml.forknode"
}
]
};
const __vite_glob_1_0 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlActive
}, Symbol.toStringTag, { value: "Module" }));
const umlCase = {
"id": "302",
"name": "ddei.uml.groups.case",
"code": "uml-case",
"desc": "UML2.0中的用例图",
"orderNo": 302,
"subject": "uml",
//当前分组下所有控件
"controls": [
{
"id": "103006",
"name": "ddei.uml.role"
},
{
"id": "302002"
},
{
"id": "302006"
},
{
"id": "302007"
},
{
"id": "302003"
},
{
"id": "302004"
},
{
"id": "302005"
},
{
"id": "103005"
},
{
"id": "302010"
},
{
"id": "307019"
},
{
"id": "302012"
},
{
"id": "302013"
},
{
"id": "302014"
}
]
};
const __vite_glob_1_1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCase
}, Symbol.toStringTag, { value: "Module" }));
const umlClass = {
"id": "307",
"name": "ddei.uml.groups.class",
"code": "uml-class",
"desc": "UML2.0中的类图",
"orderNo": 307,
"subject": "uml",
//当前分组下所有控件
"controls": [
{
"id": "307001"
},
{
"id": "307002"
},
{
"id": "307003"
},
{
"id": "307004"
},
{
"id": "307005"
},
{
"id": "307006",
"name": "ddei.uml.muti"
},
{
"id": "307007"
},
{
"id": "307008"
},
{
"id": "307009"
},
{
"id": "307010"
},
{
"id": "307011"
},
{
"id": "307012"
},
{
"id": "307013"
},
{
"id": "307014"
},
{
"id": "307015",
"name": "ddei.uml.container"
},
{
"id": "307016"
},
{
"id": "103005"
},
{
"id": "307018"
},
{
"id": "307019"
},
{
"id": "307020"
},
{
"id": "305017"
},
{
"id": "305018"
},
{
"id": "305016"
},
{
"id": "307024"
},
{
"id": "305014",
"name": "ddei.uml.link"
}
]
};
const __vite_glob_1_2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlClass
}, Symbol.toStringTag, { value: "Module" }));
const umlComponent = {
"id": "305",
"name": "ddei.uml.groups.component",
"code": "uml-component",
"desc": "UML2.0中的组件图",
"orderNo": 305,
"subject": "uml",
//当前分组下所有控件
"controls": [
{
"id": "305001"
},
{
"id": "305002"
},
{
"id": "305003"
},
{
"id": "305004",
"name": "ddei.uml.container"
},
{
"id": "305005"
},
{
"id": "102001",
"name": "ddei.uml.startnode1"
},
{
"id": "308012"
},
{
"id": "103005"
},
{
"id": "305009"
},
{
"id": "305010"
},
{
"id": "305012",
"name": "ddei.uml.interface"
},
{
"id": "305013",
"name": "ddei.uml.reqinte"
},
{
"id": "305014",
"name": "ddei.uml.relationship"
},
{
"id": "305015"
},
{
"id": "305016"
},
{
"id": "305017"
},
{
"id": "305018"
}
]
};
const __vite_glob_1_3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlComponent
}, Symbol.toStringTag, { value: "Module" }));
const umlCooperate = {
"id": "306",
"name": "ddei.uml.groups.cooperate",
"code": "uml-cooperate",
"desc": "UML2.0中的协作图",
"orderNo": 306,
"subject": "uml",
//当前分组下所有控件
"controls": [
{
"id": "308005"
},
{
"id": "303014"
},
{
"id": "306003"
},
{
"id": "306004"
},
{
"id": "306005"
},
{
"id": "306006"
},
{
"id": "306007"
},
{
"id": "306008"
},
{
"id": "306009"
}
]
};
const __vite_glob_1_4 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlCooperate
}, Symbol.toStringTag, { value: "Module" }));
const umlDeploy = {
"id": "304",
"name": "ddei.uml.groups.deploy",
"code": "uml-deploy",
"desc": "UML2.0中的部署图",
"orderNo": 304,
"subject": "uml",
//当前分组下所有控件
"controls": [
{
"id": "307012"
},
{
"id": "308005"
},
{
"id": "304003"
},
{
"id": "304004"
},
{
"id": "304005"
},
{
"id": "304006"
},
{
"id": "304007"
},
{
"id": "304008"
},
{
"id": "304009",
"name": "ddei.uml.projins"
},
{
"id": "304010"
},
{
"id": "304011"
},
{
"id": "304012",
"name": "ddei.uml.nodeins"
},
{
"id": "304013"
},
{
"id": "304014"
},
{
"id": "307011"
},
{
"id": "103005"
},
{
"id": "304017",
"name": "ddei.uml.sketchmap"
},
{
"id": "304018"
},
{
"id": "304019"
},
{
"id": "304020"
},
{
"id": "304021"
},
{
"id": "304022"
},
{
"id": "304023"
}
]
};
const __vite_glob_1_5 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlDeploy
}, Symbol.toStringTag, { value: "Module" }));
const umlSequence = {
"id": "303",
"name": "ddei.uml.groups.sequence",
"code": "uml-sequence",
"desc": "UML2.0中的序列图",
"orderNo": 303,
"subject": "uml",
//当前分组下所有控件
"controls": [
{
"id": "303001"
},
{
"id": "303002"
},
{
"id": "303003"
},
{
"id": "303004"
},
{
"id": "303005"
},
{
"id": "303006"
},
{
"id": "303007"
},
{
"id": "303008"
},
{
"id": "303009"
},
{
"id": "303010"
},
{
"id": "303011"
},
{
"id": "303012"
},
{
"id": "303013"
},
{
"id": "303014"
},
{
"id": "303015"
},
{
"id": "303016"
},
{
"id": "303017"
},
{
"id": "303018"
},
{
"id": "307011"
},
{
"id": "102090",
"name": "ddei.uml.endnode1"
},
{
"id": "103005"
},
{
"id": "303019"
},
{
"id": "303020"
},
{
"id": "303021"
}
]
};
const __vite_glob_1_6 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlSequence
}, Symbol.toStringTag, { value: "Module" }));
const umlState = {
"id": "301",
"name": "ddei.uml.groups.state",
"code": "uml-state",
"desc": "UML2.0中的状态图",
"orderNo": 301,
"subject": "uml",
//当前分组下所有控件
"controls": [
{
"id": "301001"
},
{
"id": "301002"
},
{
"id": "301003",
"name": "ddei.uml.compstate"
},
{
"id": "102001",
"name": "ddei.uml.initstate"
},
{
"id": "102091",
"name": "ddei.uml.finalstate"
},
{
"id": "301006"
},
{
"id": "301007"
},
{
"id": "301008"
},
{
"id": "301009"
},
{
"id": "301010"
},
{
"id": "103005"
},
{
"id": "301012"
},
{
"id": "301013"
},
{
"id": "301014"
}
]
};
const __vite_glob_1_7 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: umlState
}, Symbol.toStringTag, { value: "Module" }));
const control_ctx = /* @__PURE__ */ Object.assign({ "./control/active/uml-active-active.ts": __vite_glob_0_0, "./control/active/uml-active-branch.ts": __vite_glob_0_1, "./control/active/uml-active-container.ts": __vite_glob_0_2, "./control/active/uml-active-cross.ts": __vite_glob_0_3, "./control/active/uml-active-cross1.ts": __vite_glob_0_4, "./control/active/uml-active-ctrlflow.ts": __vite_glob_0_5, "./control/active/uml-active-ctrlflow1.ts": __vite_glob_0_6, "./control/active/uml-active-object.ts": __vite_glob_0_7, "./control/active/uml-active-point.ts": __vite_glob_0_8, "./control/active/uml-active-recevt.ts": __vite_glob_0_9, "./control/active/uml-active-recmsg.ts": __vite_glob_0_10, "./control/active/uml-active-sendmsg.ts": __vite_glob_0_11, "./control/active/uml-active-state.ts": __vite_glob_0_12, "./control/case/uml-case-case.ts": __vite_glob_0_13, "./control/case/uml-case-case1.ts": __vite_glob_0_14, "./control/case/uml-case-case2.ts": __vite_glob_0_15, "./control/case/uml-case-coll.ts": __vite_glob_0_16, "./control/case/uml-case-coop.ts": __vite_glob_0_17, "./control/case/uml-case-extend.ts": __vite_glob_0_18, "./control/case/uml-case-include.ts": __vite_glob_0_19, "./control/case/uml-case-interface.ts": __vite_glob_0_20, "./control/case/uml-case-part.ts": __vite_glob_0_21, "./control/case/uml-case-system.ts": __vite_glob_0_22, "./control/class/uml-class-cls.ts": __vite_glob_0_23, "./control/class/uml-class-cls1.ts": __vite_glob_0_24, "./control/class/uml-class-cls2.ts": __vite_glob_0_25, "./control/class/uml-class-constraint.ts": __vite_glob_0_26, "./control/class/uml-class-dt.ts": __vite_glob_0_27, "./control/class/uml-class-enum.ts": __vite_glob_0_28, "./control/class/uml-class-generalization.ts": __vite_glob_0_29, "./control/class/uml-class-impl.ts": __vite_glob_0_30, "./control/class/uml-class-interface.ts": __vite_glob_0_31, "./control/class/uml-class-link.ts": __vite_glob_0_32, "./control/class/uml-class-model.ts": __vite_glob_0_33, "./control/class/uml-class-obj.ts": __vite_glob_0_34, "./control/class/uml-class-overview.ts": __vite_glob_0_35, "./control/class/uml-class-package.ts": __vite_glob_0_36, "./control/class/uml-class-primitive.ts": __vite_glob_0_37, "./control/class/uml-class-rel.ts": __vite_glob_0_38, "./control/class/uml-class-signal.ts": __vite_glob_0_39, "./control/class/uml-class-ui.ts": __vite_glob_0_40, "./control/component/uml-comp-box.ts": __vite_glob_0_41, "./control/component/uml-comp-comp.ts": __vite_glob_0_42, "./control/component/uml-comp-comp1.ts": __vite_glob_0_43, "./control/component/uml-comp-compose.ts": __vite_glob_0_44, "./control/component/uml-comp-dependent.ts": __vite_glob_0_45, "./control/component/uml-comp-direct.ts": __vite_glob_0_46, "./control/component/uml-comp-interface.ts": __vite_glob_0_47, "./control/component/uml-comp-node.ts": __vite_glob_0_48, "./control/component/uml-comp-package.ts": __vite_glob_0_49, "./control/component/uml-comp-rel.ts": __vite_glob_0_50, "./control/component/uml-comp-reqinte.ts": __vite_glob_0_51, "./control/component/uml-comp-together.ts": __vite_glob_0_52, "./control/cooperate/uml-cop-msg.ts": __vite_glob_0_53, "./control/cooperate/uml-cop-msg1.ts": __vite_glob_0_54, "./control/cooperate/uml-cop-msg2.ts": __vite_glob_0_55, "./control/cooperate/uml-cop-msg3.ts": __vite_glob_0_56, "./control/cooperate/uml-cop-msg4.ts": __vite_glob_0_57, "./control/cooperate/uml-cop-msg5.ts": __vite_glob_0_58, "./control/cooperate/uml-cop-msg6.ts": __vite_glob_0_59, "./control/deploy/uml-dep-comm.ts": __vite_glob_0_60, "./control/deploy/uml-dep-comp-ins.ts": __vite_glob_0_61, "./control/deploy/uml-dep-comp-ins1.ts": __vite_glob_0_62, "./control/deploy/uml-dep-comp.ts": __vite_glob_0_63, "./control/deploy/uml-dep-comp1.ts": __vite_glob_0_64, "./control/deploy/uml-dep-depend.ts": __vite_glob_0_65, "./control/deploy/uml-dep-deploy.ts": __vite_glob_0_66, "./control/deploy/uml-dep-extend.ts": __vite_glob_0_67, "./control/deploy/uml-dep-manifest.ts": __vite_glob_0_68, "./control/deploy/uml-dep-node-ins.ts": __vite_glob_0_69, "./control/deploy/uml-dep-node.ts": __vite_glob_0_70, "./control/deploy/uml-dep-obj.ts": __vite_glob_0_71, "./control/deploy/uml-dep-overview-ins.ts": __vite_glob_0_72, "./control/deploy/uml-dep-overview.ts": __vite_glob_0_73, "./control/deploy/uml-dep-together.ts": __vite_glob_0_74, "./control/sequence/uml-seq-act-break.ts": __vite_glob_0_75, "./control/sequence/uml-seq-act.ts": __vite_glob_0_76, "./control/sequence/uml-seq-actor-life.ts": __vite_glob_0_77, "./control/sequence/uml-seq-actor.ts": __vite_glob_0_78, "./control/sequence/uml-seq-alt.ts": __vite_glob_0_79, "./control/sequence/uml-seq-alternative.ts": __vite_glob_0_80, "./control/sequence/uml-seq-async.ts": __vite_glob_0_81, "./control/sequence/uml-seq-control.ts": __vite_glob_0_82, "./control/sequence/uml-seq-custom.ts": __vite_glob_0_83, "./control/sequence/uml-seq-edge.ts": __vite_glob_0_84, "./control/sequence/uml-seq-entity.ts": __vite_glob_0_85, "./control/sequence/uml-seq-inv.ts": __vite_glob_0_86, "./control/sequence/uml-seq-life.ts": __vite_glob_0_87, "./control/sequence/uml-seq-loop.ts": __vite_glob_0_88, "./control/sequence/uml-seq-obj.ts": __vite_glob_0_89, "./control/sequence/uml-seq-objdel.ts": __vite_glob_0_90, "./control/sequence/uml-seq-objlife.ts": __vite_glob_0_91, "./control/sequence/uml-seq-opt.ts": __vite_glob_0_92, "./control/sequence/uml-seq-package.ts": __vite_glob_0_93, "./control/sequence/uml-seq-par.ts": __vite_glob_0_94, "./control/sequence/uml-seq-transition.ts": __vite_glob_0_95, "./control/state/uml-state-branch.ts": __vite_glob_0_96, "./control/state/uml-state-collect.ts": __vite_glob_0_97, "./control/state/uml-state-constraint.ts": __vite_glob_0_98, "./control/state/uml-state-convert.ts": __vite_glob_0_99, "./control/state/uml-state-end.ts": __vite_glob_0_100, "./control/state/uml-state-his.ts": __vite_glob_0_101, "./control/state/uml-state-his1.ts": __vite_glob_0_102, "./control/state/uml-state-state.ts": __vite_glob_0_103, "./control/state/uml-state-state1.ts": __vite_glob_0_104, "./control/state/uml-state-substate.ts": __vite_glob_0_105, "./control/state/uml-state-switch.ts": __vite_glob_0_106 });
const group_ctx = /* @__PURE__ */ Object.assign({ "./group/uml-active.ts": __vite_glob_1_0, "./group/uml-case.ts": __vite_glob_1_1, "./group/uml-class.ts": __vite_glob_1_2, "./group/uml-component.ts": __vite_glob_1_3, "./group/uml-cooperate.ts": __vite_glob_1_4, "./group/uml-deploy.ts": __vite_glob_1_5, "./group/uml-sequence.ts": __vite_glob_1_6, "./group/uml-state.ts": __vite_glob_1_7 });
const _DDeiExtUMLControls = class _DDeiExtUMLControls extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "controls", /* @__PURE__ */ new Map());
}
getControls(editor) {
let extOptions = this.getOptions();
let controls2 = /* @__PURE__ */ new Map();
let controls1 = new Map(editor.controls);
for (let i2 in control_ctx) {
let control = control_ctx[i2].default;
if (control) {
let c = cloneDeep(control);
controls2.set(control.id, c);
controls1.set(control.id, c);
if (extOptions && extOptions[control.id]) {
for (let x2 in extOptions[control.id]) {
c.define[x2] = extOptions[control.id][x2];
}
}
}
}
controls2.forEach((control) => {
loadControlByFrom(controls1, control);
});
this.controls = controls2;
return controls2;
}
getGroups(editor) {
if (!this.controls) {
this.getControls(editor);
}
let groups = [];
for (let path in group_ctx) {
groups.push(group_ctx[path].default);
}
loadAndSortGroup(groups, editor.controls);
return groups;
}
static modify(fn) {
return _DDeiExtUMLControls.defaultIns.modify(fn);
}
static configuration(options) {
if (options) {
let controls2 = new _DDeiExtUMLControls(options);
return controls2;
}
return _DDeiExtUMLControls;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtUMLControls, "defaultIns", new _DDeiExtUMLControls(null));
let DDeiExtUMLControls = _DDeiExtUMLControls;
const _DDeiExtUML = class _DDeiExtUML extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "order", 1);
__publicField3(this, "controls", DDeiExtUMLControls);
}
getOptions() {
let options = {};
let array = [this.controls];
array.forEach((plugin) => {
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
options = Object.assign({}, options, plugin.defaultIns.getOptions());
} else if (plugin instanceof DDeiPluginBase) {
options = Object.assign({}, options, plugin.getOptions());
}
});
return options;
}
getLangs(editor) {
const langModules = /* @__PURE__ */ Object.assign({ "./i18n/en_US.ts": __vite_glob_0_0$1, "./i18n/zh_CN.ts": __vite_glob_0_1$1 });
let langs = {};
for (let i2 in langModules) {
let langModule = langModules[i2];
let newI = i2.substring(i2.lastIndexOf("/") + 1, i2.lastIndexOf("."));
langs[newI] = langModule.default;
}
return langs;
}
getControls(editor) {
if (DDeiPluginBase.isSubclass(this.controls, DDeiPluginBase)) {
return this.controls.defaultIns.getControls(editor);
} else if (this.controls instanceof DDeiPluginBase) {
return this.controls.getControls(editor);
}
}
getGroups(editor) {
if (DDeiPluginBase.isSubclass(this.controls, DDeiPluginBase)) {
return this.controls.defaultIns.getGroups(editor);
} else if (this.controls instanceof DDeiPluginBase) {
return this.controls.getGroups(editor);
}
}
static modify(fn) {
return _DDeiExtUML.defaultIns.modify(fn);
}
static configuration(options) {
let core = new _DDeiExtUML(options);
core.controls = core.controls.configuration(controls, true);
return core;
}
};
__publicField3(_DDeiExtUML, "order", 1);
/**
* 缺省实例
*/
__publicField3(_DDeiExtUML, "defaultIns", new _DDeiExtUML(null));
let DDeiExtUML = _DDeiExtUML;
const _sfc_main$6 = {
name: "ddei-core-dialog-quickpop",
extends: null,
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
dialogId: "ddei-core-dialog-quickpop",
//当前选中的控件
selectedModels: null,
//当前操作
operateState: null,
//全部都是线条
allLine: false,
forceRefresh: false
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.editor.dialogs[this.dialogId].viewer = this;
this.refreshData();
},
methods: {
forceRefreshView: function() {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
}
});
},
refreshData() {
var _a3;
let stage2 = this.editor.ddInstance.stage;
if (stage2) {
this.selectedModels = stage2.selectedModels;
this.operateState = stage2.render.operateState;
if (((_a3 = this.selectedModels) == null ? void 0 : _a3.size) > 0) {
let allLine = true;
this.selectedModels.forEach((model) => {
if (model.baseModelType != "DDeiLine") {
allLine = false;
}
});
this.allLine = allLine;
}
}
},
exchangeLinePoint() {
var _a3, _b2;
(_a3 = this.selectedModels) == null ? void 0 : _a3.forEach((model) => {
if (model.baseModelType == "DDeiLine") {
model.exchangeStartAndEnd();
}
});
this.editor.bus.push(DDeiEnumBusCommandType.AddHistroy);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
(_b2 = this.editor.editorViewer) == null ? void 0 : _b2.changeFileModifyDirty();
},
showSetStyleDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-setstyle", {
group: "top-dialog"
}, { type: 5 }, srcElement, false, true);
},
closeAllDialog() {
DDeiEditorUtil.closeDialogs(this.editor);
},
showAlignDialog(evt) {
let srcElement = evt.currentTarget;
DDeiEditorUtil.showOrCloseDialog(this.editor, "ddei-core-dialog-align", {
group: "top-dialog"
}, { type: 5 }, srcElement, false, true);
},
//是否可以取消组合
canCancelMerge() {
var _a3, _b2;
let file = (_a3 = this.editor) == null ? void 0 : _a3.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_b2 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _b2.size) > 0) {
let models = Array.from(stage2 == null ? void 0 : stage2.selectedModels.values());
if (models[0].baseModelType == "DDeiContainer" && models[0].layout == "compose") {
return true;
}
}
return false;
},
//是否可以组合
canMerge() {
var _a3;
return this.operateState != 50 && !this.allLine && ((_a3 = this.selectedModels) == null ? void 0 : _a3.size) > 1;
},
/**
* 执行组合
*/
doMerge() {
var _a3, _b2;
let file = (_a3 = this.editor) == null ? void 0 : _a3.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_b2 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _b2.size) > 1) {
this.editor.bus.push(DDeiEnumBusCommandType.ModelMerge);
this.editor.bus.executeAll();
}
},
/**
* 执行取消组合
*/
doCancelMerge() {
var _a3, _b2;
let file = (_a3 = this.editor) == null ? void 0 : _a3.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
if (((_b2 = stage2 == null ? void 0 : stage2.selectedModels) == null ? void 0 : _b2.size) > 0) {
this.editor.bus.push(DDeiEnumBusCommandType.ModelCancelMerge);
this.editor.bus.executeAll();
}
},
//修改图形层次
doPush(v) {
var _a3;
let file = (_a3 = this.editor) == null ? void 0 : _a3.files[this.editor.currentFileIndex];
let sheet = file == null ? void 0 : file.sheets[file == null ? void 0 : file.currentSheetIndex];
let stage2 = sheet == null ? void 0 : sheet.stage;
let stageRender = stage2 == null ? void 0 : stage2.render;
let optContainer = stageRender == null ? void 0 : stageRender.currentOperateContainer;
if (optContainer) {
this.editor.bus.push(DDeiEnumBusCommandType.ModelPush, {
container: optContainer,
type: v
});
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
},
/**
* 执行格式刷
*/
execBrushAction(evt) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j;
if (this.editor.state == DDeiEditorState.QUICK_EDITING) {
if (!((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.ddInstance) == null ? void 0 : _b2.stage) == null ? void 0 : _c2.brushDataText)) {
(_e2 = (_d2 = this.editor) == null ? void 0 : _d2.hotkeys["ddei-core-keyaction-brush-data"]) == null ? void 0 : _e2.action(evt, this.editor.ddInstance, this.editor);
} else {
delete this.editor.ddInstance.stage.brushDataText;
}
} else {
if (!((_h = (_g = (_f = this.editor) == null ? void 0 : _f.ddInstance) == null ? void 0 : _g.stage) == null ? void 0 : _h.brushData)) {
(_j = (_i = this.editor) == null ? void 0 : _i.hotkeys["ddei-core-keyaction-brush-data"]) == null ? void 0 : _j.action(evt, this.editor.ddInstance, this.editor);
} else {
delete this.editor.ddInstance.stage.brushData;
}
}
}
}
};
const CanvasQuickDialog_vue_vue_type_style_index_0_scoped_c4337de3_lang = "";
const _hoisted_1$6 = ["id"];
const _hoisted_2$4 = {
key: 0,
class: "content"
};
const _hoisted_3$3 = { class: "panel12" };
const _hoisted_4$3 = { class: "panel12-content-1" };
const _hoisted_5$3 = { class: "panel12-content-2" };
const _hoisted_6$3 = { class: "panel12-content-5" };
const _hoisted_7$3 = { class: "panel12-content-5" };
const _hoisted_8$2 = { class: "panel12-content-3" };
const _hoisted_9$2 = { class: "panel12-content-3" };
const _hoisted_10$1 = { class: "panel12-content-3" };
const _hoisted_11$1 = { class: "panel12-content-3" };
const _hoisted_12$1 = { class: "panel12-content-3" };
const _hoisted_13$1 = { class: "panel12-split-3 panel12-content-4 panel1-split-4" };
const _hoisted_14 = { class: "panel12-content-4" };
const _hoisted_15 = ["title"];
const _hoisted_16 = { class: "text" };
const _hoisted_17 = {
key: 1,
class: "content"
};
const _hoisted_18 = { class: "panel6" };
const _hoisted_19 = { class: "panel6-content1 pointtype" };
const _hoisted_20 = { class: "text" };
const _hoisted_21 = { class: "panel6-content1 pointtype" };
const _hoisted_22 = { class: "text" };
const _hoisted_23 = {
class: "panel6",
style: { "border-left": "1px solid #E2E2EB" }
};
const _hoisted_24 = { class: "panel6-content type" };
const _hoisted_25 = { class: "text" };
const _hoisted_26 = { class: "panel6-content color2" };
const _hoisted_27 = { class: "text" };
const _hoisted_28 = { class: "panel6-content dash" };
const _hoisted_29 = { class: "text" };
const _hoisted_30 = { class: "panel6-content dash" };
const _hoisted_31 = { class: "text" };
const _hoisted_32 = {
class: "panel6",
style: { "border-left": "1px solid #E2E2EB" }
};
const _hoisted_33 = { class: "text" };
const _hoisted_34 = {
key: 2,
class: "content"
};
const _hoisted_35 = { class: "panel1" };
const _hoisted_36 = { class: "panel1-content-1" };
const _hoisted_37 = { class: "panel1-content-2" };
const _hoisted_38 = { class: "panel1-content-3" };
const _hoisted_39 = { class: "panel1-content-3" };
const _hoisted_40 = { class: "panel1-content-3" };
const _hoisted_41 = { class: "panel1-split-3 panel1-content-4 panel1-split-4" };
const _hoisted_42 = { class: "panel1-content-4" };
const _hoisted_43 = ["title"];
const _hoisted_44 = { class: "text" };
const _hoisted_45 = { class: "panel3" };
const _hoisted_46 = { class: "text" };
const _hoisted_47 = { class: "panel3-content i2" };
const _hoisted_48 = { class: "text" };
const _hoisted_49 = { class: "panel3-content i3" };
const _hoisted_50 = { class: "text" };
const _hoisted_51 = { class: "panel4" };
const _hoisted_52 = { class: "text" };
const _hoisted_53 = { class: "text" };
const _hoisted_54 = { class: "text" };
const _hoisted_55 = { class: "text" };
const _hoisted_56 = { class: "text" };
function _sfc_render$6(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K;
return $data.forceRefresh ? vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = $props.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
onMousedown: _cache[10] || (_cache[10] = ($event) => $options.closeAllDialog()),
class: "ddei-core-dialog-quickpop"
}, [
$data.operateState == 50 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2$4, [
vue.createElementVNode("div", _hoisted_3$3, [
vue.createElementVNode("div", _hoisted_4$3, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_b2 = $props.editor) == null ? void 0 : _b2.panels["ddei-core-btn-fontfamily"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_5$3, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_c2 = $props.editor) == null ? void 0 : _c2.panels["ddei-core-btn-fontsize"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_6$3, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_d2 = $props.editor) == null ? void 0 : _d2.panels["ddei-core-btn-addfontsize"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
addValue: 1,
attrCode: "font.size",
img: "icon-add-fontsize",
extcls: "magtop-2"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_7$3, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_e2 = $props.editor) == null ? void 0 : _e2.panels["ddei-core-btn-addfontsize"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
addValue: -1,
attrCode: "font.size",
img: "icon-reduce-fontsize",
extcls: "magtop-1"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_8$2, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_f = $props.editor) == null ? void 0 : _f.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
attrCode: "textStyle.bold",
img: "icon-bold"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_9$2, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_g = $props.editor) == null ? void 0 : _g.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
attrCode: "textStyle.italic",
img: "icon-font-italic"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_10$1, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_h = $props.editor) == null ? void 0 : _h.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
attrCode: "textStyle.underline",
img: "icon-text-underline",
extcls: "ext-underline"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_11$1, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_i = $props.editor) == null ? void 0 : _i.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
electedValue: "1",
attrCode: "textStyle.deleteline",
img: "icon-a-ziyuan457"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_12$1, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_j = $props.editor) == null ? void 0 : _j.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
onlyQuickEdit: true,
attrCode: "textStyle.subtype",
img: "icon-text-subtype-2",
extcls: "magtop-1"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_13$1, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_k = $props.editor) == null ? void 0 : _k.panels["ddei-core-btn-color"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "textStyle.bgcolor",
img: "icon-a-ziyuan452"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_14, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_l = $props.editor) == null ? void 0 : _l.panels["ddei-core-btn-color"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "font.color",
img: "icon-font"
}, null, 8, ["editor", "controlDefine"]))
])
]),
vue.createElementVNode("div", {
class: "panel2",
title: $props.editor.i18n("ddei.brush"),
style: { "border-right": "none" },
onClick: _cache[0] || (_cache[0] = ($event) => $options.execBrushAction($event))
}, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "panel2-content": true, "brush-selected": (_o = (_n = (_m = $props.editor) == null ? void 0 : _m.ddInstance) == null ? void 0 : _n.stage) == null ? void 0 : _o.brushDataText })
}, [
_cache[11] || (_cache[11] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-brush" })
], -1)),
vue.createElementVNode("div", _hoisted_16, vue.toDisplayString($props.editor.i18n("ddei.brush")), 1)
], 2)
], 8, _hoisted_15)
])) : vue.createCommentVNode("", true),
$data.operateState != 50 && $data.allLine ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_17, [
vue.createElementVNode("div", _hoisted_18, [
vue.createElementVNode("div", _hoisted_19, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_p = $props.editor) == null ? void 0 : _p.panels["ddei-core-btn-linepointtype"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "sp.type"
}, null, 8, ["editor", "controlDefine"])),
vue.createElementVNode("div", _hoisted_20, vue.toDisplayString($props.editor.i18n("ddei.startPoint")), 1)
]),
vue.createElementVNode("div", {
class: "panel6-content1 exchange",
onClick: _cache[1] || (_cache[1] = (...args) => $options.exchangeLinePoint && $options.exchangeLinePoint(...args))
}, _cache[12] || (_cache[12] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-zhihuan" })
], -1)
])),
vue.createElementVNode("div", _hoisted_21, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_q = $props.editor) == null ? void 0 : _q.panels["ddei-core-btn-linepointtype"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "ep.type"
}, null, 8, ["editor", "controlDefine"])),
vue.createElementVNode("div", _hoisted_22, vue.toDisplayString($props.editor.i18n("ddei.endPoint")), 1)
])
]),
vue.createElementVNode("div", _hoisted_23, [
vue.createElementVNode("div", _hoisted_24, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_r = $props.editor) == null ? void 0 : _r.panels["ddei-core-btn-linetype"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "type",
img: "icon-link-line"
}, null, 8, ["editor", "controlDefine"])),
vue.createElementVNode("div", _hoisted_25, vue.toDisplayString($props.editor.i18n("ddei.lineType")), 1)
]),
vue.createElementVNode("div", _hoisted_26, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_s = $props.editor) == null ? void 0 : _s.panels["ddei-core-btn-color"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "color",
img: "icon-border-pencil"
}, null, 8, ["editor", "controlDefine"])),
vue.createElementVNode("div", _hoisted_27, vue.toDisplayString($props.editor.i18n("ddei.lineColor")), 1)
]),
vue.createElementVNode("div", _hoisted_28, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_t = $props.editor) == null ? void 0 : _t.panels["ddei-core-btn-borderweight"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "weight",
hiddenCombo: "1"
}, null, 8, ["editor", "controlDefine"])),
vue.createElementVNode("div", _hoisted_29, vue.toDisplayString($props.editor.i18n("ddei.lineWeight")), 1)
]),
vue.createElementVNode("div", _hoisted_30, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_u = $props.editor) == null ? void 0 : _u.panels["ddei-core-btn-borderdash"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "dash",
hiddenCombo: "1"
}, null, 8, ["editor", "controlDefine"])),
vue.createElementVNode("div", _hoisted_31, vue.toDisplayString($props.editor.i18n("ddei.lineDash")), 1)
])
]),
vue.createElementVNode("div", _hoisted_32, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "panel6-content brush": true, "brush-selected": (_x = (_w = (_v = $props.editor) == null ? void 0 : _v.ddInstance) == null ? void 0 : _w.stage) == null ? void 0 : _x.brushData }),
onClick: _cache[2] || (_cache[2] = ($event) => $options.execBrushAction($event))
}, [
_cache[13] || (_cache[13] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-brush" })
], -1)),
vue.createElementVNode("div", _hoisted_33, vue.toDisplayString($props.editor.i18n("ddei.brush")), 1)
], 2)
])
])) : vue.createCommentVNode("", true),
$data.operateState != 50 && !$data.allLine ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_34, [
vue.createElementVNode("div", _hoisted_35, [
vue.createElementVNode("div", _hoisted_36, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_y = $props.editor) == null ? void 0 : _y.panels["ddei-core-btn-fontfamily"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_37, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_z = $props.editor) == null ? void 0 : _z.panels["ddei-core-btn-fontsize"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_38, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_A = $props.editor) == null ? void 0 : _A.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
attrCode: "textStyle.bold",
img: "icon-bold"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_39, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_B = $props.editor) == null ? void 0 : _B.panels["ddei-core-btn-editbox"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
selectedValue: "1",
attrCode: "textStyle.italic",
img: "icon-font-italic"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_40, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_C = $props.editor) == null ? void 0 : _C.panels["ddei-core-btn-textalign"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
img: "icon-text-align-left"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_41, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_D = $props.editor) == null ? void 0 : _D.panels["ddei-core-btn-color"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "textStyle.bgcolor",
img: "icon-fill"
}, null, 8, ["editor", "controlDefine"]))
]),
vue.createElementVNode("div", _hoisted_42, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_E = $props.editor) == null ? void 0 : _E.panels["ddei-core-btn-color"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "font.color",
img: "icon-font"
}, null, 8, ["editor", "controlDefine"]))
])
]),
vue.createElementVNode("div", {
class: "panel2",
title: $props.editor.i18n("ddei.brush"),
onClick: _cache[3] || (_cache[3] = ($event) => $options.execBrushAction($event))
}, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "panel2-content": true, "brush-selected": (_H = (_G = (_F = $props.editor) == null ? void 0 : _F.ddInstance) == null ? void 0 : _G.stage) == null ? void 0 : _H.brushData })
}, [
_cache[14] || (_cache[14] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-brush" })
], -1)),
vue.createElementVNode("div", _hoisted_44, vue.toDisplayString($props.editor.i18n("ddei.brush")), 1)
], 2)
], 8, _hoisted_43),
vue.createElementVNode("div", _hoisted_45, [
vue.createElementVNode("div", {
class: "panel3-content i1",
onClick: _cache[4] || (_cache[4] = ($event) => $options.showSetStyleDialog($event))
}, [
_cache[15] || (_cache[15] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-shapes" })
], -1)),
vue.createElementVNode("div", _hoisted_46, vue.toDisplayString($props.editor.i18n("ddei.style")), 1)
]),
vue.createElementVNode("div", _hoisted_47, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_I = $props.editor) == null ? void 0 : _I.panels["ddei-core-btn-color"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "fill.color",
img: "icon-background"
}, null, 8, ["editor", "controlDefine"])),
vue.createElementVNode("div", _hoisted_48, vue.toDisplayString($props.editor.i18n("ddei.fill")), 1)
]),
vue.createElementVNode("div", _hoisted_49, [
(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent((_J = $props.editor) == null ? void 0 : _J.panels["ddei-core-btn-color"]), {
editor: $props.editor,
controlDefine: $props.editor.currentControlDefine,
attrCode: "border.color",
img: "icon-border-pencil"
}, null, 8, ["editor", "controlDefine"])),
vue.createElementVNode("div", _hoisted_50, vue.toDisplayString($props.editor.i18n("ddei.border")), 1)
])
]),
vue.createElementVNode("div", _hoisted_51, [
vue.createElementVNode("div", {
class: "panel4-content",
onClick: _cache[5] || (_cache[5] = ($event) => $options.doPush("top"))
}, [
_cache[16] || (_cache[16] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-move-top" })
], -1)),
vue.createElementVNode("div", _hoisted_52, vue.toDisplayString($props.editor.i18n("ddei.pushTop")), 1)
]),
vue.createElementVNode("div", {
class: "panel4-content",
onClick: _cache[6] || (_cache[6] = ($event) => $options.doPush("bottom"))
}, [
_cache[17] || (_cache[17] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-move-bottom" })
], -1)),
vue.createElementVNode("div", _hoisted_53, vue.toDisplayString($props.editor.i18n("ddei.pushBottom")), 1)
])
]),
vue.createElementVNode("div", {
class: "panel5",
style: vue.normalizeStyle({ "display": $options.canMerge() || $options.canCancelMerge() ? "" : "none" })
}, [
vue.withDirectives(vue.createElementVNode("div", {
class: "panel5-content",
onClick: _cache[7] || (_cache[7] = ($event) => $options.canMerge() && $options.doMerge())
}, [
_cache[18] || (_cache[18] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-merge" })
], -1)),
vue.createElementVNode("div", _hoisted_54, vue.toDisplayString($props.editor.i18n("ddei.combina")), 1)
], 512), [
[vue.vShow, $options.canMerge()]
]),
vue.withDirectives(vue.createElementVNode("div", {
class: "panel5-content",
onClick: _cache[8] || (_cache[8] = ($event) => $options.canCancelMerge() && $options.doCancelMerge())
}, [
_cache[19] || (_cache[19] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-cancel-merge" })
], -1)),
vue.createElementVNode("div", _hoisted_55, vue.toDisplayString($props.editor.i18n("ddei.cancelCombina")), 1)
], 512), [
[vue.vShow, $options.canCancelMerge()]
]),
vue.withDirectives(vue.createElementVNode("div", {
class: "panel5-content",
onClick: _cache[9] || (_cache[9] = ($event) => $options.canMerge() && $options.showAlignDialog($event))
}, [
_cache[20] || (_cache[20] = vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-align" })
], -1)),
vue.createElementVNode("div", _hoisted_56, vue.toDisplayString($props.editor.i18n("ddei.align")), 1)
], 512), [
[vue.vShow, $options.canMerge()]
])
], 4)
])) : vue.createCommentVNode("", true)
], 40, _hoisted_1$6)), [
[vue.vShow, ((_K = $data.selectedModels) == null ? void 0 : _K.size) > 0]
]) : vue.createCommentVNode("", true);
}
const CanvasQuickDialog = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["render", _sfc_render$6], ["__scopeId", "data-v-c4337de3"]]);
const _DDeiCoreCanvasQuickDialog = class _DDeiCoreCanvasQuickDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", CanvasQuickDialog.name);
__publicField3(this, "plugins", [CanvasQuickDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[CanvasQuickDialog.name]) {
for (let i2 in options[CanvasQuickDialog.name]) {
newOptions[i2] = options[CanvasQuickDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreCanvasQuickDialog(newOptions);
return panels;
}
}
return _DDeiCoreCanvasQuickDialog;
}
static modify(fn) {
return _DDeiCoreCanvasQuickDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreCanvasQuickDialog, "defaultIns", new _DDeiCoreCanvasQuickDialog(null));
let DDeiCoreCanvasQuickDialog = _DDeiCoreCanvasQuickDialog;
const _DDeiCoreCanvasLifeCycle = class _DDeiCoreCanvasLifeCycle extends DDeiLifeCycle {
constructor() {
super(...arguments);
__publicField3(this, "name", "quickstyle-lifecycle");
__publicField3(this, "EVENT_CONTROL_SELECT_AFTER", new DDeiFuncData("quickstyle-show", 1, this.showQuickEditPicker));
__publicField3(this, "EVENT_MOUSE_OPERATING", new DDeiFuncData("quickstyle-hidden", 1, this.mouseOperating));
__publicField3(this, "EVENT_CLOSE_FILE_AFTER", new DDeiFuncData("quickstyle-hidden", 1, this.closeDialog));
}
/**
* 正在进行鼠标操作
*/
mouseOperating(operateType, data, ddInstance, evt) {
if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
DDeiEditorUtil.hiddenDialog(editor, "ddei-core-dialog-quickpop");
if (operateType == "SCROLL_WORKING" || operateType == "CHANGE_RATIO" || operateType == "CHANGE_WPV" || operateType == "CHANGE_BOUNDS" || operateType == "CHANGE_ROTATE") {
_DDeiCoreCanvasLifeCycle.displayQuickDialog(editor);
}
}
}
/**
* 正在进行鼠标操作
*/
closeDialog(operateType, data, ddInstance, evt) {
if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
DDeiEditorUtil.closeDialog(editor, "ddei-core-dialog-quickpop");
}
}
static displayQuickDialog(editor) {
var _a3, _b2, _c2, _d2;
if (editor.state == DDeiEditorState.DESIGNING && ((_c2 = (_b2 = (_a3 = editor == null ? void 0 : editor.ddInstance) == null ? void 0 : _a3.stage) == null ? void 0 : _b2.selectedModels) == null ? void 0 : _c2.size) > 0) {
if (editor.ddInstance.stage.render.operateState != 0) {
_DDeiCoreCanvasLifeCycle.displayQuickDialog(editor);
return;
}
let models = Array.from((_d2 = editor.ddInstance.stage) == null ? void 0 : _d2.selectedModels.values());
if ((models == null ? void 0 : models.length) > 0) {
let height = 130;
let editorEle = document.getElementById(editor.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let modelPos = DDeiUtil.getModelsDomAbsPosition(models);
let left = modelPos.left - editorDomPos.left + modelPos.width / 2 + 40;
let top = modelPos.top - editorDomPos.top;
if (modelPos.top - height <= modelPos.cTop) {
if (modelPos.height > 400) {
top = top + height + 40;
} else {
top = top + modelPos.height + 40;
}
} else {
top = top - height;
}
let canvasEle = document.getElementById(editor.id + "_canvas");
if (top < canvasEle.offsetTop) {
top = modelPos.offsetTop;
} else if (top + 80 > canvasEle.offsetTop + canvasEle.clientHeight) {
top = canvasEle.offsetTop + canvasEle.clientHeight - 80;
}
if (left < canvasEle.offsetLeft) {
left = canvasEle.offsetLeft;
} else if (left + 550 > canvasEle.offsetLeft + canvasEle.clientWidth) {
left = canvasEle.offsetLeft + canvasEle.clientWidth - 550;
}
DDeiEditorUtil.displayDialog(editor, "ddei-core-dialog-quickpop", null, { type: 99, left, top, hiddenMask: true });
}
}
}
/**
* 选择后,在选择控件的合适位置显示快捷编辑框
*/
showQuickEditPicker(operateType, data, ddInstance, evt) {
if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) {
let models = data == null ? void 0 : data.models;
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (editor.state == DDeiEditorState.DESIGNING) {
let curState = editor.state;
DDeiEditorUtil.closeDialog(editor, "ddei-core-dialog-quickpop");
if ((models == null ? void 0 : models.length) > 0) {
let height = 130;
let editorEle = document.getElementById(editor.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let modelPos = DDeiUtil.getModelsDomAbsPosition(models);
let left = modelPos.left - editorDomPos.left + modelPos.width / 2 + 40;
let top = modelPos.top - editorDomPos.top + modelPos.height / 2;
if (modelPos.top - height <= modelPos.cTop) {
if (modelPos.height > 400) {
top = top + height + 40;
} else {
top = top + modelPos.height / 2 + 40;
}
} else {
top = top - height;
}
let canvasEle = document.getElementById(editor.id + "_canvas");
if (top < canvasEle.offsetTop) {
top = modelPos.offsetTop;
} else if (top + 80 > canvasEle.offsetTop + canvasEle.clientHeight) {
top = canvasEle.offsetTop + canvasEle.clientHeight - 80;
}
if (left < canvasEle.offsetLeft) {
left = canvasEle.offsetLeft;
} else if (left + 550 > canvasEle.offsetLeft + canvasEle.clientWidth) {
left = canvasEle.offsetLeft + canvasEle.clientWidth - 550;
}
DDeiEditorUtil.showDialog(editor, "ddei-core-dialog-quickpop", {
group: "canvas-pop"
}, { type: 99, left, top, hiddenMask: true }, null, true, true);
editor == null ? void 0 : editor.changeState(curState);
}
}
}
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiCoreCanvasLifeCycle.name]) {
for (let i2 in options[_DDeiCoreCanvasLifeCycle.name]) {
newOptions[i2] = options[_DDeiCoreCanvasLifeCycle.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreCanvasLifeCycle();
if (newOptions.name) {
panels.name = newOptions.name;
}
if (newOptions.sort) {
panels.sort = newOptions.sort;
}
return panels;
}
}
return _DDeiCoreCanvasLifeCycle;
}
static modify(fn) {
return _DDeiCoreCanvasLifeCycle.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreCanvasLifeCycle, "defaultIns", new _DDeiCoreCanvasLifeCycle(null));
_DDeiCoreCanvasLifeCycle.displayQuickDialog = debounce(_DDeiCoreCanvasLifeCycle.displayQuickDialog, 300);
let DDeiCoreCanvasLifeCycle = _DDeiCoreCanvasLifeCycle;
const _DDeiExtQuickStyle = class _DDeiExtQuickStyle extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "order", 2);
__publicField3(this, "dialogs", DDeiCoreCanvasQuickDialog);
__publicField3(this, "lifecyclies", DDeiCoreCanvasLifeCycle);
}
getDialogs(editor) {
if (DDeiPluginBase.isSubclass(this.dialogs, DDeiPluginBase)) {
return this.dialogs.defaultIns.getDialogs(editor);
} else if (this.dialogs instanceof DDeiPluginBase) {
return this.dialogs.getDialogs(editor);
}
}
getLifeCyclies(editor) {
if (DDeiPluginBase.isSubclass(this.lifecyclies, DDeiPluginBase)) {
return this.lifecyclies.defaultIns.getLifeCyclies(editor);
} else if (this.lifecyclies instanceof DDeiPluginBase) {
return this.lifecyclies.getLifeCyclies(editor);
}
}
static configuration(options) {
let core = new _DDeiExtQuickStyle(options);
core.dialogs = core.dialogs.configuration(options, true);
core.lifecyclies = core.lifecyclies.configuration(options, true);
return core;
}
static modify(fn) {
return _DDeiExtQuickStyle.defaultIns.modify(fn);
}
};
__publicField3(_DDeiExtQuickStyle, "order", 2);
/**
* 缺省实例
*/
__publicField3(_DDeiExtQuickStyle, "defaultIns", new _DDeiExtQuickStyle(null));
let DDeiExtQuickStyle = _DDeiExtQuickStyle;
const DialogBase$1 = {
props: {
editor: {
type: DDeiEditor,
default: null
}
},
data: function() {
return {
forceRefresh: false
};
},
methods: {
forceRefreshView: function() {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
}
});
}
},
mounted() {
this.editor.dialogs[this.dialogId].viewer = this;
}
};
const _sfc_main$5 = {
name: "ddei-ext-panel-search",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
searchInputId: "",
replaceInputId: "",
replaceText: ""
};
},
computed: {},
watch: {},
created() {
if (!this.editor.search) {
this.editor.search = {
resultIndex: -1,
result: []
};
}
this.executeQuery = debounce(this.executeQuery, 300);
},
mounted() {
var _a3, _b2, _c2;
if (!this.editor.search.mode) {
this.editor.search.mode = 1;
}
this.searchInputId = this.editor.id + "_search_input";
this.replaceInputId = this.editor.id + "_search_replace_input";
if (((_c2 = (_b2 = (_a3 = this.editor) == null ? void 0 : _a3.search) == null ? void 0 : _b2.result) == null ? void 0 : _c2.length) > 0) {
this.changeFileSheetSelectAndModel();
}
setTimeout(() => {
if (this.editor.search.mode == 2) {
this.$refs.searchReplaceBoxInput.focus();
} else {
this.$refs.searchBoxInput.focus();
}
}, 300);
},
methods: {
changeReplace() {
if (this.editor.search.mode == 1 && this.editor.ddInstance && this.editor.ddInstance["AC_DESIGN_EDIT"]) {
this.editor.search.mode = 2;
} else {
this.editor.search.mode = 1;
}
},
changeMatchCase() {
if (this.editor.search.matchCase == true) {
this.editor.search.matchCase = false;
} else {
this.editor.search.matchCase = true;
}
this.executeQuery();
},
changeMatchAll() {
if (this.editor.search.matchAll == true) {
this.editor.search.matchAll = false;
} else {
this.editor.search.matchAll = true;
}
this.executeQuery();
},
executeQuery(evt) {
var _a3, _b2, _c2;
if ((evt == null ? void 0 : evt.keyCode) != 13 && (evt == null ? void 0 : evt.keyCode) != 27) {
let rs = this.editor.searchModels((_a3 = this.editor.search) == null ? void 0 : _a3.keywords, "text", false, 3, (_b2 = this.editor.search) == null ? void 0 : _b2.matchCase, (_c2 = this.editor.search) == null ? void 0 : _c2.matchAll);
if ((rs == null ? void 0 : rs.length) > 0) {
this.editor.search.result = rs;
this.editor.search.resultIndex = -1;
} else {
this.editor.search.result = [];
this.editor.search.resultIndex = -1;
}
this.moveToNextResult();
}
this.editor.search.inActive = false;
return true;
},
moveToNextResult() {
this.editor.search.resultIndex++;
this.changeFileSheetSelectAndModel();
},
moveToUpResult() {
this.editor.search.resultIndex--;
this.changeFileSheetSelectAndModel();
},
changeFileSheetSelectAndModel(clearSpt = false) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j;
this.editor.search.inActive = false;
if (this.editor.search.resultIndex >= this.editor.search.result.length - 1) {
this.editor.search.resultIndex = this.editor.search.result.length - 1;
} else if (this.editor.search.resultIndex < 0) {
this.editor.search.resultIndex = 0;
}
let ddInstance = this.editor.ddInstance;
let rsData = this.editor.search.result[this.editor.search.resultIndex];
let skipIndex = [this.editor.search.resultIndex];
let textSelectColor = DDeiUtil.getStyleValue("canvas-text-selection", this.editor.ddInstance);
if (rsData == null ? void 0 : rsData.model) {
let file = this.editor.files[rsData.fileIndex];
if (file) {
let sheetIndex = rsData.sheetIndex;
if (sheetIndex >= 0) {
this.editor.changeFile(rsData.fileIndex, sheetIndex);
this.editor.centerModels(ddInstance.stage, rsData.model.id);
(_b2 = (_a3 = rsData.model) == null ? void 0 : _a3.render) == null ? void 0 : _b2.controlSelect();
if (!clearSpt) {
let sptStyle = {};
for (let i2 = 0; i2 < rsData.len; i2++) {
sptStyle["" + (rsData.index + i2)] = { textStyle: { bgcolor: textSelectColor } };
}
for (let k = this.editor.search.resultIndex - 1; k > 0; k--) {
if (this.editor.search.result[k].model == rsData.model) {
let rsd1 = this.editor.search.result[k];
for (let ki = 0; ki < rsd1.len; ki++) {
sptStyle["" + (rsd1.index + ki)] = { textStyle: { bgcolor: "#ebebeb" } };
}
skipIndex.push(k);
} else {
break;
}
}
for (let k = this.editor.search.resultIndex + 1; k < this.editor.search.result.length; k++) {
if (this.editor.search.result[k].model == rsData.model) {
let rsd1 = this.editor.search.result[k];
for (let ki = 0; ki < rsd1.len; ki++) {
sptStyle["" + (rsd1.index + ki)] = { textStyle: { bgcolor: "#ebebeb" } };
}
skipIndex.push(k);
} else {
break;
}
}
(_d2 = (_c2 = rsData.model) == null ? void 0 : _c2.render) == null ? void 0 : _d2.drawShape({ border: { type: 1, color: "#017fff", width: 1, dash: [10, 10] }, sptStyle });
} else {
(_f = (_e2 = rsData.model) == null ? void 0 : _e2.render) == null ? void 0 : _f.enableRefreshShape();
}
}
}
}
for (let ri = 0; ri < this.editor.search.result.length; ri++) {
let rsData2 = this.editor.search.result[ri];
if (rsData2 == null ? void 0 : rsData2.model) {
let file = this.editor.files[rsData2.fileIndex];
if (file) {
let sheetIndex = rsData2.sheetIndex;
if (sheetIndex >= 0) {
if (skipIndex.indexOf(ri) == -1) {
if (!clearSpt) {
let sptStyle = {};
for (let i2 = 0; i2 < rsData2.len; i2++) {
sptStyle["" + (rsData2.index + i2)] = { textStyle: { bgcolor: "#ebebeb" } };
}
for (let k = ri + 1; k < this.editor.search.result.length; k++) {
if (this.editor.search.result[k].model == rsData2.model) {
let rsd1 = this.editor.search.result[k];
for (let ki = 0; ki < rsd1.len; ki++) {
sptStyle["" + (rsd1.index + ki)] = { textStyle: { bgcolor: "#ebebeb" } };
}
} else {
ri = k - 1;
break;
}
}
(_h = (_g = rsData2.model) == null ? void 0 : _g.render) == null ? void 0 : _h.drawShape({ sptStyle });
} else {
(_j = (_i = rsData2.model) == null ? void 0 : _i.render) == null ? void 0 : _j.enableRefreshShape();
}
}
}
}
}
}
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {});
ddInstance.bus.executeAll();
},
executeReplace(editor) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
if (((_b2 = (_a3 = editor.search) == null ? void 0 : _a3.result) == null ? void 0 : _b2.length) > 0) {
let rsData = (_d2 = editor.search) == null ? void 0 : _d2.result[(_c2 = editor.search) == null ? void 0 : _c2.resultIndex];
if (rsData.model) {
editor.replaceModelsData([rsData.model], "text", rsData.index, rsData.index + rsData.len, this.replaceText);
for (let k = editor.search.resultIndex + 1; k < ((_e2 = editor.search.result) == null ? void 0 : _e2.length); k++) {
if (editor.search.result[k].model == rsData.model) {
let lenDelta = this.replaceText.length - rsData.len;
if (lenDelta != 0) {
editor.search.result[k].index += lenDelta;
if (editor.search.result[k].index < 0) {
editor.search.result[k].index = 0;
}
}
} else {
break;
}
}
editor.search.result.splice((_f = editor.search) == null ? void 0 : _f.resultIndex, 1);
if (editor.search.result.length > editor.search.resultIndex) {
editor.search.resultIndex--;
if (editor.search.resultIndex < 0) {
editor.search.resultIndex = 0;
}
}
if (editor.search.result.length == 0) {
editor.search.resultIndex = 0;
(_h = (_g = rsData.model) == null ? void 0 : _g.render) == null ? void 0 : _h.clearCachedValue();
}
}
this.changeFileSheetSelectAndModel();
let ddInstance = editor.ddInstance;
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {});
ddInstance.bus.executeAll();
}
editor.search.inActive = false;
return true;
},
executeReplaceAll(editor) {
var _a3, _b2, _c2, _d2, _e2, _f, _g;
while (((_b2 = (_a3 = editor.search) == null ? void 0 : _a3.result) == null ? void 0 : _b2.length) > 0) {
let rsData = (_c2 = editor.search) == null ? void 0 : _c2.result[0];
if (rsData.model) {
editor.replaceModelsData([rsData.model], "text", rsData.index, rsData.index + rsData.len, this.replaceText);
for (let k = 1; k < ((_d2 = editor.search.result) == null ? void 0 : _d2.length); k++) {
if (editor.search.result[k].model == rsData.model) {
let lenDelta = this.replaceText.length - rsData.len;
if (lenDelta != 0) {
editor.search.result[k].index += lenDelta;
if (editor.search.result[k].index < 0) {
editor.search.result[k].index = 0;
}
}
} else {
break;
}
}
editor.search.result.splice((_e2 = editor.search) == null ? void 0 : _e2.resultIndex, 1);
(_g = (_f = rsData.model) == null ? void 0 : _f.render) == null ? void 0 : _g.clearCachedValue();
}
}
editor.search.resultIndex = -1;
let ddInstance = editor.ddInstance;
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {});
ddInstance.bus.executeAll();
editor.search.inActive = false;
return true;
},
changeEditorState() {
this.editor.changeState("ddei-search");
},
closeDialog() {
DDeiEditorUtil.closeDialog(this.editor, "ddei-ext-dialog-search", true);
this.changeFileSheetSelectAndModel(true);
this.editor.changeState(DDeiEditorState.DESIGNING);
}
}
};
const SearchPanel_vue_vue_type_style_index_0_scoped_75611720_lang = "";
const _hoisted_1$5 = { class: "ddei-ext-panel-search" };
const _hoisted_2$3 = {
class: "icon",
"aria-hidden": "true"
};
const _hoisted_3$2 = {
key: 0,
"xlink:href": "#icon-btn-right1"
};
const _hoisted_4$2 = {
key: 1,
"xlink:href": "#icon-expand2"
};
const _hoisted_5$2 = { class: "ddei-ext-panel-search-box" };
const _hoisted_6$2 = ["id", "placeholder"];
const _hoisted_7$2 = {
class: "icon",
style: { "width": "16px", "height": "16px" },
"aria-hidden": "true"
};
const _hoisted_8$1 = {
key: 0,
class: "ddei-ext-panel-search-result"
};
const _hoisted_9$1 = {
key: 1,
class: "ddei-ext-panel-search-result"
};
const _hoisted_10 = { class: "ddei-ext-panel-search-buttons" };
const _hoisted_11 = {
key: 2,
class: "ddei-ext-panel-search-box"
};
const _hoisted_12 = ["id", "placeholder"];
const _hoisted_13 = {
key: 3,
class: "ddei-ext-panel-search-replace-buttons"
};
function _sfc_render$5(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s;
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$5, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-ext-panel-search-mode": true, "ddei-ext-panel-search-mode__expand": ((_a3 = $props.editor.search) == null ? void 0 : _a3.mode) == 2 }),
onClick: _cache[0] || (_cache[0] = (...args) => $options.changeReplace && $options.changeReplace(...args))
}, [
(vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$3, [
((_b2 = $props.editor.search) == null ? void 0 : _b2.mode) == 1 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_3$2)) : vue.createCommentVNode("", true),
((_c2 = $props.editor.search) == null ? void 0 : _c2.mode) == 2 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_4$2)) : vue.createCommentVNode("", true)
]))
], 2),
vue.createElementVNode("div", _hoisted_5$2, [
vue.withDirectives(vue.createElementVNode("input", {
class: "ddei-ext-panel-search-box-input",
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => $props.editor.search.keywords = $event),
id: $data.searchInputId,
ref: "searchBoxInput",
onKeydown: _cache[2] || (_cache[2] = ($event) => $options.executeQuery($event)),
onFocus: _cache[3] || (_cache[3] = (...args) => $options.changeEditorState && $options.changeEditorState(...args)),
placeholder: $props.editor.i18n("ddei.search"),
autocomplete: "off"
}, null, 40, _hoisted_6$2), [
[vue.vModelText, $props.editor.search.keywords]
]),
vue.createElementVNode("div", {
onClick: _cache[4] || (_cache[4] = ($event) => $options.changeMatchCase()),
class: vue.normalizeClass({ "ddei-ext-panel-search-box-btn": true, "ddei-ext-panel-search-box-btn__selected": ((_d2 = $props.editor.search) == null ? void 0 : _d2.matchCase) == 1 })
}, [
(vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$2, _cache[13] || (_cache[13] = [
vue.createElementVNode("use", { "xlink:href": "#icon-lock-case" }, null, -1)
])))
], 2),
vue.createElementVNode("div", {
onClick: _cache[5] || (_cache[5] = ($event) => $options.changeMatchAll()),
class: vue.normalizeClass({ "ddei-ext-panel-search-box-btn": true, "ddei-ext-panel-search-box-btn__selected": ((_e2 = $props.editor.search) == null ? void 0 : _e2.matchAll) == 1 })
}, _cache[14] || (_cache[14] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-all-match" })
], -1)
]), 2)
]),
$props.editor.lang == "zh_CN" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_8$1, " 第" + vue.toDisplayString(((_f = $props.editor.search) == null ? void 0 : _f.resultIndex) + 1) + "项,共" + vue.toDisplayString((_h = (_g = $props.editor.search) == null ? void 0 : _g.result) == null ? void 0 : _h.length) + "项 ", 1)) : vue.createCommentVNode("", true),
$props.editor.lang != "zh_CN" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_9$1, vue.toDisplayString(((_i = $props.editor.search) == null ? void 0 : _i.resultIndex) + 1) + "/" + vue.toDisplayString((_k = (_j = $props.editor.search) == null ? void 0 : _j.result) == null ? void 0 : _k.length), 1)) : vue.createCommentVNode("", true),
vue.createElementVNode("div", _hoisted_10, [
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-ext-panel-search-buttons-btn": true, "ddei-ext-panel-search-buttons-btn__disabled": !$props.editor.search || ((_l = $props.editor.search) == null ? void 0 : _l.resultIndex) >= ((_n = (_m = $props.editor.search) == null ? void 0 : _m.result) == null ? void 0 : _n.length) - 1 }),
onClick: _cache[6] || (_cache[6] = ($event) => $options.moveToNextResult())
}, _cache[15] || (_cache[15] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-down" })
], -1)
]), 2),
vue.createElementVNode("div", {
class: vue.normalizeClass({ "ddei-ext-panel-search-buttons-btn": true, "ddei-ext-panel-search-buttons-btn__disabled": !$props.editor.search || ((_o = $props.editor.search) == null ? void 0 : _o.resultIndex) == 0 || ((_q = (_p = $props.editor.search) == null ? void 0 : _p.result) == null ? void 0 : _q.length) == 0 }),
onClick: _cache[7] || (_cache[7] = ($event) => $options.moveToUpResult())
}, _cache[16] || (_cache[16] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-up" })
], -1)
]), 2),
vue.createElementVNode("div", {
class: "ddei-ext-panel-search-buttons-btn",
onClick: _cache[8] || (_cache[8] = (...args) => $options.closeDialog && $options.closeDialog(...args))
}, _cache[17] || (_cache[17] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-close" })
], -1)
]))
]),
((_r = $props.editor.search) == null ? void 0 : _r.mode) == 2 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_11, [
vue.withDirectives(vue.createElementVNode("input", {
id: $data.replaceInputId,
ref: "searchReplaceBoxInput",
class: "ddei-ext-panel-search-box-input",
"onUpdate:modelValue": _cache[9] || (_cache[9] = ($event) => $data.replaceText = $event),
onFocus: _cache[10] || (_cache[10] = (...args) => $options.changeEditorState && $options.changeEditorState(...args)),
placeholder: $props.editor.i18n("ddei.replace"),
autocomplete: "off"
}, null, 40, _hoisted_12), [
[vue.vModelText, $data.replaceText]
])
])) : vue.createCommentVNode("", true),
((_s = $props.editor.search) == null ? void 0 : _s.mode) == 2 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_13, [
vue.createElementVNode("div", {
class: "ddei-ext-panel-search-replace-buttons-btn",
onClick: _cache[11] || (_cache[11] = ($event) => $options.executeReplace($props.editor))
}, _cache[18] || (_cache[18] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-replace" })
], -1)
])),
vue.createElementVNode("div", {
class: "ddei-ext-panel-search-replace-buttons-btn",
onClick: _cache[12] || (_cache[12] = ($event) => $options.executeReplaceAll($props.editor))
}, _cache[19] || (_cache[19] = [
vue.createElementVNode("svg", {
class: "icon",
"aria-hidden": "true"
}, [
vue.createElementVNode("use", { "xlink:href": "#icon-replace-all" })
], -1)
]))
])) : vue.createCommentVNode("", true)
]);
}
const SearchPanel = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["render", _sfc_render$5], ["__scopeId", "data-v-75611720"]]);
const _sfc_main$4 = {
name: "ddei-ext-dialog-search",
extends: null,
mixins: [DialogBase$1],
props: {
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-ext-dialog-search"
};
},
computed: {},
components: { SearchPanel },
watch: {},
created() {
},
mounted() {
},
methods: {}
};
const SearchDialog_vue_vue_type_style_index_0_scoped_869178bc_lang = "";
const _hoisted_1$4 = ["id"];
function _sfc_render$4(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
const _component_SearchPanel = vue.resolveComponent("SearchPanel");
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-ext-dialog-search"
}, [
vue.createVNode(_component_SearchPanel, {
editor: _ctx.editor,
options: $props.options
}, null, 8, ["editor", "options"])
], 8, _hoisted_1$4)) : vue.createCommentVNode("", true);
}
const SearchDialog = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["render", _sfc_render$4], ["__scopeId", "data-v-869178bc"]]);
const _DDeiExtSearchDialog = class _DDeiExtSearchDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", SearchDialog.name);
__publicField3(this, "plugins", [SearchDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static modify(fn) {
return _DDeiExtSearchDialog.defaultIns.modify(fn);
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[AlignDialog.name]) {
for (let i2 in options[AlignDialog.name]) {
newOptions[i2] = options[AlignDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiExtSearchDialog(newOptions);
return panels;
}
}
return _DDeiExtSearchDialog;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtSearchDialog, "defaultIns", new _DDeiExtSearchDialog(null));
let DDeiExtSearchDialog = _DDeiExtSearchDialog;
const _DDeiExtSearchPanel = class _DDeiExtSearchPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", SearchPanel.name);
__publicField3(this, "plugins", [SearchPanel]);
}
getPanels(editor) {
return this.plugins;
}
static modify(fn) {
return _DDeiExtSearchPanel.defaultIns.modify(fn);
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ChangeRatio.name]) {
for (let i2 in options[ChangeRatio.name]) {
newOptions[i2] = options[ChangeRatio.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiExtSearchPanel(newOptions);
return panels;
}
}
return _DDeiExtSearchPanel;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtSearchPanel, "defaultIns", new _DDeiExtSearchPanel(null));
let DDeiExtSearchPanel = _DDeiExtSearchPanel;
const _DDeiKeyActionSearch = class _DDeiKeyActionSearch extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-ext-keyaction-search");
__publicField3(this, "defaultOptions", {
"keys": [
{ ctrl: 1, keys: "70", type: "search" },
{ ctrl: 1, keys: "72", type: "replace" }
]
});
}
getHotKeys(editor) {
return [this];
}
static modify(fn) {
return _DDeiKeyActionSearch.defaultIns.modify(fn);
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionSearch.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionSearch.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionSearch.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionSearch(newOptions);
return panels;
}
}
return _DDeiKeyActionSearch;
}
// ============================ 方法 ===============================
action(evt, ddInstance, editor, item) {
var _a3;
let mode = 1;
if ((item == null ? void 0 : item.type) == "replace" && ddInstance && ddInstance["AC_DESIGN_EDIT"]) {
mode = 2;
}
if (!editor.search) {
editor.search = {
resultIndex: -1,
result: []
};
}
editor.search.mode = mode;
if (!editor.tempPopData || !editor.tempPopData["ddei-ext-dialog-search"]) {
let srcElement = document.getElementById(editor.id + "_canvas");
if (srcElement) {
let editor2 = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
DDeiEditorUtil.closeDialog(editor2, "ddei-ext-dialog-search", true);
let editorEle = document.getElementById(editor2.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let canvasPos = DDeiUtil.getDomAbsPosition(srcElement);
let left = canvasPos.left - editorDomPos.left + srcElement.offsetWidth - 500;
let top = canvasPos.top - editorDomPos.top;
if ((_a3 = editor2.search) == null ? void 0 : _a3.result) {
editor2.search.inActive = true;
}
DDeiEditorUtil.showDialog(editor2, "ddei-ext-dialog-search", {
group: "ddei-core-search"
}, { type: 99, left, top, hiddenMask: true }, null, true, true);
editor2.changeState("ddei-search");
}
} else {
if (mode == 2) {
let searchReplaceInput = document.getElementById(editor.id + "_search_replace_input");
if (searchReplaceInput) {
searchReplaceInput.focus();
editor.search.inActive = false;
editor.changeState("ddei-search");
}
} else {
let searchInput = document.getElementById(editor.id + "_search_input");
if (searchInput) {
searchInput.focus();
editor.search.inActive = false;
editor.changeState("ddei-search");
}
}
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionSearch, "defaultIns", new _DDeiKeyActionSearch());
let DDeiKeyActionSearch = _DDeiKeyActionSearch;
const _DDeiKeyActionSearchUp = class _DDeiKeyActionSearchUp extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-ext-keyaction-search-up");
__publicField3(this, "defaultOptions", {
"keys": [
{ shift: 1, keys: "13", editorState: "ddei-search" }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionSearchUp.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionSearchUp.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionSearchUp.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionSearchUp(newOptions);
return panels;
}
}
return _DDeiKeyActionSearchUp;
}
static modify(fn) {
return _DDeiKeyActionSearchUp.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance, editor) {
var _a3;
if (editor.tempPopData && editor.tempPopData["ddei-ext-dialog-search"]) {
if (!((_a3 = editor.search) == null ? void 0 : _a3.inActive)) {
if (editor.search.resultIndex <= 0) {
return;
}
editor.search.resultIndex--;
this.changeFileSheetSelectAndModel(editor);
} else {
editor.search.inActive = false;
}
}
}
changeFileSheetSelectAndModel(editor) {
var _a3, _b2, _c2, _d2, _e2, _f;
editor.search.inActive = false;
if (editor.search.resultIndex >= editor.search.result.length - 1) {
editor.search.resultIndex = editor.search.result.length - 1;
} else if (editor.search.resultIndex < 0) {
editor.search.resultIndex = 0;
}
let ddInstance = editor.ddInstance;
let rsData = editor.search.result[editor.search.resultIndex];
let skipIndex = [editor.search.resultIndex];
let textSelectColor = DDeiUtil.getStyleValue("canvas-text-selection", editor.ddInstance);
if (rsData == null ? void 0 : rsData.model) {
let file = editor.files[rsData.fileIndex];
if (file) {
let sheetIndex = rsData.sheetIndex;
if (sheetIndex >= 0) {
editor.changeFile(rsData.fileIndex, sheetIndex);
editor.centerModels(ddInstance.stage, rsData.model.id);
(_b2 = (_a3 = rsData.model) == null ? void 0 : _a3.render) == null ? void 0 : _b2.controlSelect();
let sptStyle = {};
for (let i2 = 0; i2 < rsData.len; i2++) {
sptStyle["" + (rsData.index + i2)] = { textStyle: { bgcolor: textSelectColor } };
}
for (let k = editor.search.resultIndex - 1; k > 0; k--) {
if (editor.search.result[k].model == rsData.model) {
let rsd1 = editor.search.result[k];
for (let ki = 0; ki < rsd1.len; ki++) {
sptStyle["" + (rsd1.index + ki)] = { textStyle: { bgcolor: "#ebebeb" } };
}
skipIndex.push(k);
} else {
break;
}
}
for (let k = editor.search.resultIndex + 1; k < editor.search.result.length; k++) {
if (editor.search.result[k].model == rsData.model) {
let rsd1 = editor.search.result[k];
for (let ki = 0; ki < rsd1.len; ki++) {
sptStyle["" + (rsd1.index + ki)] = { textStyle: { bgcolor: "#ebebeb" } };
}
skipIndex.push(k);
} else {
break;
}
}
(_d2 = (_c2 = rsData.model) == null ? void 0 : _c2.render) == null ? void 0 : _d2.drawShape({ border: { type: 1, color: "#017fff", width: 1, dash: [10, 10] }, sptStyle });
}
}
}
for (let ri = 0; ri < editor.search.result.length; ri++) {
let rsData2 = editor.search.result[ri];
if (rsData2 == null ? void 0 : rsData2.model) {
let file = editor.files[rsData2.fileIndex];
if (file) {
let sheetIndex = rsData2.sheetIndex;
if (sheetIndex >= 0) {
if (skipIndex.indexOf(ri) == -1) {
let sptStyle = {};
for (let i2 = 0; i2 < rsData2.len; i2++) {
sptStyle["" + (rsData2.index + i2)] = { textStyle: { bgcolor: "#ebebeb" } };
}
for (let k = ri + 1; k < editor.search.result.length; k++) {
if (editor.search.result[k].model == rsData2.model) {
let rsd1 = editor.search.result[k];
for (let ki = 0; ki < rsd1.len; ki++) {
sptStyle["" + (rsd1.index + ki)] = { textStyle: { bgcolor: "#ebebeb" } };
}
} else {
ri = k - 1;
break;
}
}
(_f = (_e2 = rsData2.model) == null ? void 0 : _e2.render) == null ? void 0 : _f.drawShape({ sptStyle });
}
}
}
}
}
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {});
ddInstance.bus.executeAll();
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionSearchUp, "defaultIns", new _DDeiKeyActionSearchUp());
let DDeiKeyActionSearchUp = _DDeiKeyActionSearchUp;
const _DDeiKeyActionSearchNext = class _DDeiKeyActionSearchNext extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-core-keyaction-search-next");
__publicField3(this, "defaultOptions", {
"keys": [
{ keys: "13", editorState: "ddei-search" },
{ ctrl: 1, keys: "13", editorState: "ddei-search", type: "replaceAll" }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionSearchNext.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionSearchNext.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionSearchNext.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionSearchNext(newOptions);
return panels;
}
}
return _DDeiKeyActionSearchNext;
}
static modify(fn) {
return _DDeiKeyActionSearchNext.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance, editor, item) {
var _a3;
if (editor.tempPopData && editor.tempPopData["ddei-ext-dialog-search"]) {
if (!((_a3 = editor.search) == null ? void 0 : _a3.inActive)) {
if (editor.search.resultIndex >= editor.search.result.length - 1) {
return;
}
let replaceInput = document.getElementById(editor.id + "_search_replace_input");
if (replaceInput && document.activeElement == replaceInput && ddInstance && ddInstance["AC_DESIGN_EDIT"]) {
if ((item == null ? void 0 : item.type) == "replaceAll") {
this.executeReplaceAll(editor, replaceInput);
return;
} else {
this.executeReplace(editor, replaceInput);
}
}
editor.search.resultIndex++;
this.changeFileSheetSelectAndModel(editor);
} else {
editor.search.inActive = false;
}
}
}
executeReplace(editor, textInput) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
if (((_b2 = (_a3 = editor.search) == null ? void 0 : _a3.result) == null ? void 0 : _b2.length) > 0) {
let rsData = (_d2 = editor.search) == null ? void 0 : _d2.result[(_c2 = editor.search) == null ? void 0 : _c2.resultIndex];
if (rsData.model) {
editor.replaceModelsData([rsData.model], "text", rsData.index, rsData.index + rsData.len, textInput.value);
for (let k = editor.search.resultIndex + 1; k < ((_e2 = editor.search.result) == null ? void 0 : _e2.length); k++) {
if (editor.search.result[k].model == rsData.model) {
let lenDelta = textInput.value.length - rsData.len;
if (lenDelta != 0) {
editor.search.result[k].index += lenDelta;
if (editor.search.result[k].index < 0) {
editor.search.result[k].index = 0;
}
}
} else {
break;
}
}
editor.search.result.splice((_f = editor.search) == null ? void 0 : _f.resultIndex, 1);
if (editor.search.result.length > editor.search.resultIndex) {
editor.search.resultIndex--;
if (editor.search.resultIndex < 0) {
editor.search.resultIndex = 0;
}
}
if (editor.search.result.length == 0) {
editor.search.resultIndex = 0;
(_h = (_g = rsData.model) == null ? void 0 : _g.render) == null ? void 0 : _h.clearCachedValue();
}
}
}
}
changeFileSheetSelectAndModel(editor) {
var _a3, _b2, _c2, _d2, _e2, _f;
editor.search.inActive = false;
if (editor.search.resultIndex >= editor.search.result.length - 1) {
editor.search.resultIndex = editor.search.result.length - 1;
} else if (editor.search.resultIndex < 0) {
editor.search.resultIndex = 0;
}
let ddInstance = editor.ddInstance;
let rsData = editor.search.result[editor.search.resultIndex];
let skipIndex = [editor.search.resultIndex];
let textSelectColor = DDeiUtil.getStyleValue("canvas-text-selection", editor.ddInstance);
if (rsData == null ? void 0 : rsData.model) {
let file = editor.files[rsData.fileIndex];
if (file) {
let sheetIndex = rsData.sheetIndex;
if (sheetIndex >= 0) {
editor.changeFile(rsData.fileIndex, sheetIndex);
editor.centerModels(ddInstance.stage, rsData.model.id);
(_b2 = (_a3 = rsData.model) == null ? void 0 : _a3.render) == null ? void 0 : _b2.controlSelect();
let sptStyle = {};
for (let i2 = 0; i2 < rsData.len; i2++) {
sptStyle["" + (rsData.index + i2)] = { textStyle: { bgcolor: textSelectColor } };
}
for (let k = editor.search.resultIndex - 1; k > 0; k--) {
if (editor.search.result[k].model == rsData.model) {
let rsd1 = editor.search.result[k];
for (let ki = 0; ki < rsd1.len; ki++) {
sptStyle["" + (rsd1.index + ki)] = { textStyle: { bgcolor: "#ebebeb" } };
}
skipIndex.push(k);
} else {
break;
}
}
for (let k = editor.search.resultIndex + 1; k < editor.search.result.length; k++) {
if (editor.search.result[k].model == rsData.model) {
let rsd1 = editor.search.result[k];
for (let ki = 0; ki < rsd1.len; ki++) {
sptStyle["" + (rsd1.index + ki)] = { textStyle: { bgcolor: "#ebebeb" } };
}
skipIndex.push(k);
} else {
break;
}
}
(_d2 = (_c2 = rsData.model) == null ? void 0 : _c2.render) == null ? void 0 : _d2.drawShape({ border: { type: 1, color: "#017fff", width: 1, dash: [10, 10] }, sptStyle });
}
}
}
for (let ri = 0; ri < editor.search.result.length; ri++) {
let rsData2 = editor.search.result[ri];
if (rsData2 == null ? void 0 : rsData2.model) {
let file = editor.files[rsData2.fileIndex];
if (file) {
let sheetIndex = rsData2.sheetIndex;
if (sheetIndex >= 0) {
if (skipIndex.indexOf(ri) == -1) {
let sptStyle = {};
for (let i2 = 0; i2 < rsData2.len; i2++) {
sptStyle["" + (rsData2.index + i2)] = { textStyle: { bgcolor: "#ebebeb" } };
}
for (let k = ri + 1; k < editor.search.result.length; k++) {
if (editor.search.result[k].model == rsData2.model) {
let rsd1 = editor.search.result[k];
for (let ki = 0; ki < rsd1.len; ki++) {
sptStyle["" + (rsd1.index + ki)] = { textStyle: { bgcolor: "#ebebeb" } };
}
} else {
ri = k - 1;
break;
}
}
(_f = (_e2 = rsData2.model) == null ? void 0 : _e2.render) == null ? void 0 : _f.drawShape({ sptStyle });
}
}
}
}
}
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.executeAll();
}
executeReplaceAll(editor, textInput) {
var _a3, _b2, _c2, _d2, _e2, _f, _g;
while (((_b2 = (_a3 = editor.search) == null ? void 0 : _a3.result) == null ? void 0 : _b2.length) > 0) {
let rsData = (_c2 = editor.search) == null ? void 0 : _c2.result[0];
if (rsData.model) {
editor.replaceModelsData([rsData.model], "text", rsData.index, rsData.index + rsData.len, textInput.value);
for (let k = 1; k < ((_d2 = editor.search.result) == null ? void 0 : _d2.length); k++) {
if (editor.search.result[k].model == rsData.model) {
let lenDelta = textInput.value.length - rsData.len;
if (lenDelta != 0) {
editor.search.result[k].index += lenDelta;
if (editor.search.result[k].index < 0) {
editor.search.result[k].index = 0;
}
}
} else {
break;
}
}
editor.search.result.splice((_e2 = editor.search) == null ? void 0 : _e2.resultIndex, 1);
(_g = (_f = rsData.model) == null ? void 0 : _f.render) == null ? void 0 : _g.clearCachedValue();
}
}
editor.search.resultIndex = -1;
let ddInstance = editor.ddInstance;
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {});
ddInstance.bus.executeAll();
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionSearchNext, "defaultIns", new _DDeiKeyActionSearchNext());
let DDeiKeyActionSearchNext = _DDeiKeyActionSearchNext;
const _DDeiKeyActionSearchEsc = class _DDeiKeyActionSearchEsc extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-ext-keyaction-search-esc");
__publicField3(this, "defaultOptions", {
"keys": [
{ keys: "27" }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionSearchEsc.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionSearchEsc.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionSearchEsc.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionSearchEsc(newOptions);
return panels;
}
}
return _DDeiKeyActionSearchEsc;
}
static modify(fn) {
return _DDeiKeyActionSearchEsc.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance, editor) {
var _a3, _b2;
if (editor.tempPopData && editor.tempPopData["ddei-ext-dialog-search"]) {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-search", true);
if (editor.search.resultIndex >= editor.search.result.length - 1) {
editor.search.resultIndex = editor.search.result.length - 1;
} else if (editor.search.resultIndex < 0) {
editor.search.resultIndex = 0;
}
let rsData = editor.search.result[editor.search.resultIndex];
if (rsData == null ? void 0 : rsData.model) {
(_b2 = (_a3 = rsData.model) == null ? void 0 : _a3.render) == null ? void 0 : _b2.enableRefreshShape();
ddInstance.bus.push(DDeiEnumBusCommandType.RefreshShape);
ddInstance.bus.push(DDeiEditorEnumBusCommandType.RefreshEditorParts, {});
ddInstance.bus.executeAll();
}
editor.changeState(DDeiEditorState.DESIGNING);
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionSearchEsc, "defaultIns", new _DDeiKeyActionSearchEsc());
let DDeiKeyActionSearchEsc = _DDeiKeyActionSearchEsc;
const _DDeiExtSearchHotkeys = class _DDeiExtSearchHotkeys extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [DDeiKeyActionSearch, DDeiKeyActionSearchUp, DDeiKeyActionSearchNext, DDeiKeyActionSearchEsc]);
}
getHotKeys(editor) {
var _a3;
let hotkeys = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getHotKeys(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getHotKeys(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
hotkeys = hotkeys.concat(ls);
}
});
return hotkeys;
}
static modify(fn) {
return _DDeiExtSearchHotkeys.defaultIns.modify(fn);
}
static configuration(options) {
var _a3;
let hotkeys = new _DDeiExtSearchHotkeys(options);
for (let i2 = 0; i2 < ((_a3 = hotkeys.plugins) == null ? void 0 : _a3.length); i2++) {
hotkeys.plugins[i2] = hotkeys.plugins[i2].configuration(options, true);
}
return hotkeys;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtSearchHotkeys, "defaultIns", new _DDeiExtSearchHotkeys(null));
let DDeiExtSearchHotkeys = _DDeiExtSearchHotkeys;
let DDeiExtSearchLifeCycle$1 = (_a2 = class extends DDeiLifeCycle {
constructor() {
super(...arguments);
__publicField3(this, "name", "search-ext-lifecycle");
__publicField3(this, "EVENT_MOUSE_OPERATING", new DDeiFuncData("search-ext-hidden", 1, this.mouseOperating));
}
/**
* 正在进行鼠标操作
*/
mouseOperating(operateType, data, ddInstance, evt) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (editor.tempPopData && editor.tempPopData["ddei-ext-dialog-search"]) {
DDeiEditorUtil.hiddenDialog(editor, "ddei-ext-dialog-search");
if (operateType == "SCROLL_WORKING" || operateType == "CHANGE_RATIO" || operateType == "SELECT_WORKING" || operateType == "DRAG" || operateType == "CREATE" || operateType == "CHANGE_WPV" || operateType == "CHANGE_BOUNDS" || operateType == "CHANGE_ROTATE") {
_a2.displaySearchDialog(editor);
}
}
}
static displaySearchDialog(editor) {
let srcElement = document.getElementById(editor.id + "_canvas");
let editorEle = document.getElementById(editor.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let canvasPos = DDeiUtil.getDomAbsPosition(srcElement);
let left = canvasPos.left - editorDomPos.left + srcElement.offsetWidth - 500;
let top = canvasPos.top - editorDomPos.top;
DDeiEditorUtil.displayDialog(editor, "ddei-ext-dialog-search", null, { type: 99, left, top, hiddenMask: true });
}
static modify(fn) {
return _a2.defaultIns.modify(fn);
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_a2.name]) {
for (let i2 in options[_a2.name]) {
newOptions[i2] = options[_a2.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _a2();
if (newOptions.name) {
panels.name = newOptions.name;
}
if (newOptions.sort) {
panels.sort = newOptions.sort;
}
return panels;
}
}
return _a2;
}
}, /**
* 缺省实例
*/
__publicField3(_a2, "defaultIns", new _a2(null)), _a2.displaySearchDialog = debounce(_a2.displaySearchDialog, 300), _a2);
const DialogBase = {
props: {
editor: {
type: DDeiEditor,
default: null
}
},
data: function() {
return {
forceRefresh: false
};
},
methods: {
forceRefreshView: function() {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
}
});
}
},
mounted() {
this.editor.dialogs[this.dialogId].viewer = this;
}
};
const _sfc_main$3 = {
name: "ddei-ext-panel-quickcontrol",
extends: null,
mixins: [],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
leftOffset: null,
rightOffset: null,
topOffset: null,
bottomOffset: null,
//四个方向的状态,0无连线,1有连线
leftState: 0,
rightState: 0,
bottomState: 0,
topState: 0
};
},
computed: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2, _c2, _d2, _e2;
if (this.editor.tempPopData && this.editor.tempPopData["ddei-ext-dialog-quickcontrol"] && this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].model) {
let model = this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].model;
if (model) {
let outRect = DDeiAbstractShape.getOutRectByPV([model]);
let stageRatio2 = (_a3 = model.stage) == null ? void 0 : _a3.getStageRatio();
outRect.x *= stageRatio2;
outRect.x1 *= stageRatio2;
outRect.y *= stageRatio2;
outRect.y1 *= stageRatio2;
outRect.width *= stageRatio2;
outRect.height *= stageRatio2;
let width = this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].width;
width = width || width == 0 ? width : 40;
let height = this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].height;
height = height || height == 0 ? height : 40;
this.$refs.quickControlDiv.style.width = outRect.width + width + "px";
this.$refs.quickControlDiv.style.height = outRect.height + height + "px";
this.leftOffset = (_b2 = this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].offset) == null ? void 0 : _b2.left;
this.rightOffset = (_c2 = this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].offset) == null ? void 0 : _c2.right;
this.topOffset = (_d2 = this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].offset) == null ? void 0 : _d2.top;
this.bottomOffset = (_e2 = this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].offset) == null ? void 0 : _e2.bottom;
for (let i2 in model.exPvs) {
let mlPoint = model.exPvs[i2];
if (parseInt(mlPoint.y) == parseInt(outRect.y)) {
this.topState = 1;
} else if (parseInt(mlPoint.x) == parseInt(outRect.x1)) {
this.rightState = 1;
} else if (parseInt(mlPoint.y) == parseInt(outRect.y1)) {
this.bottomState = 1;
} else if (parseInt(mlPoint.x) == parseInt(outRect.x)) {
this.leftState = 1;
}
}
}
}
},
mouseEnter(type, el, evt) {
if (this.editor.state == "designing") {
if (this.editor.tempPopData["ddei-ext-dialog-quickcontrol"]) {
let existsControl = null;
let model = this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].model;
let layer2 = model.layer;
let outRect = DDeiAbstractShape.getOutRectByPV([model]);
if (type == 1) {
let controls2 = layer2.getSubModels([model.id], 100, { x: outRect.x, y: outRect.y - 150, x1: outRect.x1, y1: outRect.y });
controls2 = this.filtControls(model, controls2);
if (controls2.length > 0) {
existsControl = controls2[0];
}
} else if (type == 2) {
let controls2 = layer2.getSubModels([model.id], 100, { x: outRect.x1, y: outRect.y, x1: outRect.x1 + 150, y1: outRect.y1 });
controls2 = this.filtControls(model, controls2);
if (controls2.length > 0) {
existsControl = controls2[0];
}
} else if (type == 3) {
let controls2 = layer2.getSubModels([model.id], 100, { x: outRect.x, y: outRect.y1, x1: outRect.x1, y1: outRect.y1 + 150 });
controls2 = this.filtControls(model, controls2);
if (controls2.length > 0) {
existsControl = controls2[0];
}
} else if (type == 4) {
let controls2 = layer2.getSubModels([model.id], 100, { x: outRect.x - 150, y: outRect.y, x1: outRect.x, y1: outRect.y1 });
controls2 = this.filtControls(model, controls2);
if (controls2.length > 0) {
existsControl = controls2[0];
}
}
if (!existsControl) {
if (this.editor.tempLineModel) {
this.editor.ddInstance.stage.removeModel(this.editor.tempLineModel, true);
delete this.editor.tempLineModel;
}
let editorEle = document.getElementById(this.editor.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let modelPos = DDeiUtil.getModelsDomAbsPosition([model]);
let width = this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].width;
width = width || width == 0 ? width : 40;
let height = this.editor.tempPopData["ddei-ext-dialog-quickcontrol"].height;
height = height || height == 0 ? height : 40;
if (model.state == DDeiEnumControlState.SELECTED) {
height = 70;
}
let left = modelPos.left - editorDomPos.left - width / 2;
let top = modelPos.top - editorDomPos.top - height / 2;
let qcWidth = modelPos.width + width;
let qcHeight = modelPos.height + height;
if (type == 1) {
left = left + qcWidth / 2 - 120;
top = top - 240;
} else if (type == 2) {
left = left + qcWidth;
top = top + qcHeight / 2 - 120;
} else if (type == 3) {
left = left + qcWidth / 2 - 120;
top = top + qcHeight;
} else if (type == 4) {
left = left - 240;
top = top + qcHeight / 2 - 120;
}
if (model.state == DDeiEnumControlState.SELECTED) {
top -= 10;
}
DDeiEditorUtil.showDialog(this.editor, "ddei-ext-dialog-quickchoosecontrol", {
group: "canvas-pop-quickcreatecontrol",
type,
model
}, { type: 99, left, top, hiddenMask: true }, null, true, true);
} else if (!this.editor.tempLineModel) {
let outRect1 = DDeiAbstractShape.getOutRectByPV([existsControl]);
let sx, sy, ex, ey;
let startSita, endSita;
if (type == 1) {
sx = (outRect.x + outRect.x1) / 2;
sy = outRect.y;
ex = (outRect1.x + outRect1.x1) / 2;
ey = outRect1.y1;
startSita = -90;
endSita = 90;
} else if (type == 2) {
sx = outRect.x1;
sy = (outRect.y + outRect.y1) / 2;
ex = outRect1.x;
ey = (outRect1.y + outRect1.y1) / 2;
startSita = 0;
endSita = 180;
} else if (type == 3) {
sx = (outRect.x + outRect.x1) / 2;
sy = outRect.y1;
ex = (outRect1.x + outRect1.x1) / 2;
ey = outRect1.y;
startSita = 90;
endSita = -90;
} else if (type == 4) {
sx = outRect.x;
sy = (outRect.y + outRect.y1) / 2;
ex = outRect1.x1;
ey = (outRect1.y + outRect1.y1) / 2;
startSita = 180;
endSita = 0;
}
let smodel = { id: model.id, x: sx, y: sy, rate: 0.5, sita: startSita };
let emodel = { id: existsControl.id, x: ex, y: ey, rate: 0.5, sita: endSita };
let initLine = DDeiEditorUtil.getLineInitJSON(this.editor.ddInstance, smodel, emodel);
if (initLine) {
let initJson = clone(initLine);
initJson.model = initLine.modelCode ? initLine.modelCode : initLine.model ? initLine.model : initLine.id ? initLine.id : "100401";
if (!initJson.type) {
initJson.type = 2;
}
if (!initJson.dash) {
initJson.dash = [10, 5];
this.lockDash = false;
} else {
this.lockDash = true;
}
if (!initJson.startPoint) {
initJson.startPoint = { x: sx, y: sy };
}
if (!initJson.endPoint) {
initJson.endPoint = { x: ex, y: ey };
}
if (!initJson.smodel) {
initJson.smodel = smodel;
}
if (!initJson.emodel) {
initJson.emodel = emodel;
}
let lines = this.editor.addLines([
initJson
], true, true, false);
this.editor.tempLineModel = lines[0];
DDeiEditorUtil.closeDialog(this.editor, "ddei-ext-dialog-quickchoosecontrol", true);
this.editor.bus.push(DDeiEnumBusCommandType.RefreshShape);
this.editor.bus.executeAll();
}
}
}
}
},
createLineOk() {
var _a3;
if (this.editor.tempLineModel) {
if (!this.lockDash) {
delete this.editor.tempLineModel.dash;
}
delete this.lockDash;
(_a3 = this.editor.tempLineModel.render) == null ? void 0 : _a3.clearCachedValue();
delete this.editor.tempLineModel;
this.refreshData();
}
},
mouseleave() {
if (this.editor.tempLineModel) {
this.editor.ddInstance.stage.removeModel(this.editor.tempLineModel, true);
delete this.editor.tempLineModel;
}
},
filtControls(model, controls2) {
let returnControls = [];
if ((controls2 == null ? void 0 : controls2.length) > 0) {
for (let i2 = 0; i2 < controls2.length; i2++) {
if (controls2[i2].baseModelType != "DDeiLine" && controls2[i2].depModel != model) {
let define2 = DDeiUtil.getControlDefine(controls2[i2]);
let filterMethod = null;
if (define2 && define2.filters && define2.filters["LINE_OBI_FILTER"]) {
filterMethod = define2.filters["LINE_OBI_FILTER"];
}
if (!filterMethod || filterMethod(model, { model: controls2[i2] })) {
returnControls.push(controls2[i2]);
}
}
}
}
return returnControls;
}
}
};
const QuickControlPanel_vue_vue_type_style_index_0_scoped_dd1c62d6_lang = "";
const _hoisted_1$3 = {
class: "ddei-ext-panel-quickcontrol",
ref: "quickControlDiv"
};
const _hoisted_2$2 = { class: "ddei-ext-panel-quickcontrol-middle" };
function _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$3, [
vue.createElementVNode("div", {
class: "ddei-ext-panel-quickcontrol-left",
style: vue.normalizeStyle($data.leftOffset)
}, [
$data.leftState != 1 ? (vue.openBlock(), vue.createElementBlock("svg", {
key: 0,
width: "16",
height: "11",
onMouseenter: _cache[0] || (_cache[0] = ($event) => $options.mouseEnter(4, _ctx.$el, $event)),
onMousedown: _cache[1] || (_cache[1] = (...args) => $options.createLineOk && $options.createLineOk(...args)),
onMouseleave: _cache[2] || (_cache[2] = (...args) => $options.mouseleave && $options.mouseleave(...args)),
style: { "transform": "rotate(-90deg)" }
}, _cache[12] || (_cache[12] = [
vue.createElementVNode("polygon", { points: "8,0 1,10 15,10" }, null, -1)
]), 32)) : vue.createCommentVNode("", true)
], 4),
vue.createElementVNode("div", _hoisted_2$2, [
vue.createElementVNode("div", {
class: "ddei-ext-panel-quickcontrol-middle-top",
style: vue.normalizeStyle($data.topOffset)
}, [
$data.topState != 1 ? (vue.openBlock(), vue.createElementBlock("svg", {
key: 0,
width: "16",
height: "11",
onMouseenter: _cache[3] || (_cache[3] = ($event) => $options.mouseEnter(1, _ctx.$el, $event)),
onMouseleave: _cache[4] || (_cache[4] = (...args) => $options.mouseleave && $options.mouseleave(...args)),
onMousedown: _cache[5] || (_cache[5] = (...args) => $options.createLineOk && $options.createLineOk(...args))
}, _cache[13] || (_cache[13] = [
vue.createElementVNode("polygon", { points: "8,0 1,10 15,10" }, null, -1)
]), 32)) : vue.createCommentVNode("", true)
], 4),
_cache[15] || (_cache[15] = vue.createElementVNode("div", { class: "ddei-ext-panel-quickcontrol-middle-middle" }, null, -1)),
vue.createElementVNode("div", {
class: "ddei-ext-panel-quickcontrol-middle-bottom",
style: vue.normalizeStyle($data.bottomOffset)
}, [
$data.bottomState != 1 ? (vue.openBlock(), vue.createElementBlock("svg", {
key: 0,
width: "16",
height: "11",
onMouseenter: _cache[6] || (_cache[6] = ($event) => $options.mouseEnter(3, _ctx.$el, $event)),
onMouseleave: _cache[7] || (_cache[7] = (...args) => $options.mouseleave && $options.mouseleave(...args)),
onMousedown: _cache[8] || (_cache[8] = (...args) => $options.createLineOk && $options.createLineOk(...args)),
style: { "transform": "rotate(180deg)" }
}, _cache[14] || (_cache[14] = [
vue.createElementVNode("polygon", { points: "8,0 1,10 15,10" }, null, -1)
]), 32)) : vue.createCommentVNode("", true)
], 4)
]),
vue.createElementVNode("div", {
class: "ddei-ext-panel-quickcontrol-right",
style: vue.normalizeStyle($data.rightOffset)
}, [
$data.rightState != 1 ? (vue.openBlock(), vue.createElementBlock("svg", {
key: 0,
width: "16",
height: "11",
onMouseenter: _cache[9] || (_cache[9] = ($event) => $options.mouseEnter(2, _ctx.$el, $event)),
onMouseleave: _cache[10] || (_cache[10] = (...args) => $options.mouseleave && $options.mouseleave(...args)),
onMousedown: _cache[11] || (_cache[11] = (...args) => $options.createLineOk && $options.createLineOk(...args)),
style: { "transform": "rotate(90deg)" }
}, _cache[16] || (_cache[16] = [
vue.createElementVNode("polygon", { points: "8,0 1,10 15,10" }, null, -1)
]), 32)) : vue.createCommentVNode("", true)
], 4)
], 512);
}
const QuickControlPanel = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["render", _sfc_render$3], ["__scopeId", "data-v-dd1c62d6"]]);
const _sfc_main$2 = {
name: "ddei-ext-dialog-quickcontrol",
extends: null,
mixins: [DialogBase],
props: {
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: "ddei-ext-dialog-quickcontrol"
};
},
computed: {},
components: { QuickControlPanel },
watch: {},
created() {
},
mounted() {
},
methods: {}
};
const QuickControlDialog_vue_vue_type_style_index_0_scoped_737aeea8_lang = "";
const _hoisted_1$2 = ["id"];
function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
const _component_QuickControlPanel = vue.resolveComponent("QuickControlPanel");
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-ext-dialog-quickcontrol"
}, [
vue.createVNode(_component_QuickControlPanel, vue.mergeProps({ editor: _ctx.editor }, $props.options, { options: $props.options }), null, 16, ["editor", "options"])
], 8, _hoisted_1$2)) : vue.createCommentVNode("", true);
}
const QuickControlDialog = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["render", _sfc_render$2], ["__scopeId", "data-v-737aeea8"]]);
const _DDeiExtQuickControlDialog = class _DDeiExtQuickControlDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QuickControlDialog.name);
__publicField3(this, "plugins", [QuickControlDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[AlignDialog.name]) {
for (let i2 in options[AlignDialog.name]) {
newOptions[i2] = options[AlignDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiExtQuickControlDialog(newOptions);
return panels;
}
}
return _DDeiExtQuickControlDialog;
}
static modify(fn) {
return _DDeiExtQuickControlDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtQuickControlDialog, "defaultIns", new _DDeiExtQuickControlDialog(null));
let DDeiExtQuickControlDialog = _DDeiExtQuickControlDialog;
const _sfc_main$1 = {
name: "ddei-ext-dialog-quickchoosecontrol",
extends: null,
mixins: [DialogBase],
props: {
options: {
type: Object,
default: null
},
//定义分组
customGroups: {
type: Array,
default: null
},
//定义控件
customControls: {
type: Array,
default: null
}
},
data() {
return {
dialogId: "ddei-ext-dialog-quickchoosecontrol",
//分组数据
groups: [],
model: null
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.refreshData();
},
methods: {
refreshData() {
var _a3, _b2;
let groups = this.editor.groups;
if (this.customControls) {
let controls2 = [];
let gps = [{ display: true, controls: controls2 }];
let hasControlids = {};
groups.forEach((group2) => {
var _a4;
(_a4 = group2 == null ? void 0 : group2.controls) == null ? void 0 : _a4.forEach((control) => {
if (!hasControlids[control.id] && this.customControls.indexOf(control.id) != -1) {
hasControlids[control.id] = true;
controls2.push(control);
}
});
});
this.groups = gps;
} else if (this.customGroups) {
let newGroups = [];
(_a3 = this.customGroups) == null ? void 0 : _a3.forEach((cg) => {
for (let i2 = 0; i2 < groups.length; i2++) {
if (groups[i2].id == cg) {
newGroups.push(groups[i2]);
break;
}
}
});
this.groups = newGroups;
} else {
let model = this.editor.tempPopData ? (_b2 = this.editor.tempPopData["ddei-ext-dialog-quickchoosecontrol"]) == null ? void 0 : _b2.model : null;
if (!model) {
DDeiEditorUtil.readRecentlyToolGroups();
let hisGroups = DDeiEditorUtil.recentlyToolGroups;
let gps = [];
if ((hisGroups == null ? void 0 : hisGroups.length) > 0) {
hisGroups.forEach((hg) => {
let group2 = null;
for (let i2 = 0; i2 < groups.length; i2++) {
if (groups[i2].id == hg.id) {
group2 = groups[i2];
break;
}
}
if (group2) {
group2.expand = hg.expand;
gps.push(group2);
}
});
this.groups = gps;
}
} else {
let newGroups = [];
for (let i2 = 0; i2 < groups.length; i2++) {
let finded = false;
for (let c = 0; c < groups[i2].controls.length; c++) {
if (groups[i2].controls[c].id == model.modelCode) {
finded = true;
break;
}
}
if (finded) {
newGroups.push(groups[i2]);
break;
}
}
this.model = model;
this.groups = newGroups;
}
}
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
});
},
quickCreateControl(controlId) {
if (controlId && this.editor.tempPopData["ddei-ext-dialog-quickchoosecontrol"]) {
let model = this.editor.tempPopData["ddei-ext-dialog-quickchoosecontrol"].model;
let type = this.editor.tempPopData["ddei-ext-dialog-quickchoosecontrol"].type;
if (model) {
let outRect = DDeiAbstractShape.getOutRectByPV([model]);
let controlInitJSON = DDeiEditorUtil.getModelInitJSON(this.editor.ddInstance, model, [
{
model: controlId
}
]);
if (controlInitJSON) {
let controls2 = this.editor.addControls(controlInitJSON, true, false, true);
if ((controls2 == null ? void 0 : controls2.length) > 0) {
let outRect1 = DDeiAbstractShape.getOutRectByPV(controls2);
let x2, y2, sx, sy, ex, ey;
let startSita, endSita;
let weight = 60;
if (type == 1) {
x2 = (outRect.x + outRect.x1) / 2;
y2 = outRect.y - weight - outRect1.height / 2;
sx = x2;
sy = outRect.y;
ex = x2;
ey = y2 + outRect1.height / 2;
startSita = -90;
endSita = 90;
} else if (type == 2) {
x2 = outRect.x1 + weight + outRect1.width / 2, y2 = (outRect.y1 + outRect.y) / 2;
sx = outRect.x1;
sy = y2;
ex = x2 - outRect1.width / 2;
ey = y2;
startSita = 0;
endSita = 180;
} else if (type == 3) {
x2 = (outRect.x + outRect.x1) / 2, y2 = outRect.y1 + weight + outRect1.height / 2;
sx = x2;
sy = outRect.y1;
ex = x2;
ey = y2 - outRect1.height / 2;
startSita = 90;
endSita = -90;
} else if (type == 4) {
x2 = outRect.x - weight - outRect1.width / 2;
y2 = (outRect.y1 + outRect.y) / 2;
sx = outRect.x;
sy = y2;
ex = x2 + outRect1.width / 2;
ey = y2;
startSita = 180;
endSita = 0;
}
controls2[0].setPosition({ x: x2, y: y2 });
let smodel = { id: model.id, x: sx, y: sy, rate: 0.5, sita: startSita };
let emodel = { id: controls2[0].id, x: ex, y: ey, rate: 0.5, sita: endSita };
let initLine = DDeiEditorUtil.getLineInitJSON(this.editor.ddInstance, smodel, emodel);
let lines = null;
if (initLine) {
let initJson = clone(initLine);
initJson.model = initLine.modelCode ? initLine.modelCode : initLine.model ? initLine.model : initLine.id ? initLine.id : "100401";
if (!initJson.type) {
initJson.type = 2;
}
if (!initJson.startPoint) {
initJson.startPoint = { x: sx, y: sy };
}
if (!initJson.endPoint) {
initJson.endPoint = { x: ex, y: ey };
}
if (!initJson.smodel) {
initJson.smodel = smodel;
}
if (!initJson.emodel) {
initJson.emodel = emodel;
}
lines = this.editor.addLines([
initJson
], true, true, false);
}
this.editor.bus.push(DDeiEnumBusCommandType.NodifyControlCreated, { models: controls2, lines });
this.editor.bus.executeAll();
this.editor.ddInstance.stage.makeSelectModels(controls2);
this.editor.ddInstance.stage.notifyChange();
}
}
}
}
}
}
};
const QuickChooseControlDialog_vue_vue_type_style_index_0_scoped_5bda071e_lang = "";
const _hoisted_1$1 = ["id"];
const _hoisted_2$1 = { class: "ddei-ext-dialog-quickchoosecontrol-group" };
const _hoisted_3$1 = {
key: 0,
class: "ddei-ext-dialog-quickchoosecontrol-group-itempanel"
};
const _hoisted_4$1 = ["title", "onClick"];
const _hoisted_5$1 = ["src"];
const _hoisted_6$1 = ["innerHTML"];
const _hoisted_7$1 = { class: "text" };
function _sfc_render$1(_ctx, _cache, $props, $setup, $data, $options) {
var _a3;
return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = _ctx.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-ext-dialog-quickchoosecontrol"
}, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.groups, (group2) => {
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", _hoisted_2$1, [
$props.customControls || $props.customGroups || group2.expand == true || $data.model ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3$1, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(group2.controls, (control) => {
var _a4;
return vue.openBlock(), vue.createElementBlock("div", {
class: "ddei-ext-dialog-quickchoosecontrol-group-itempanel-item",
title: control.desc,
onClick: ($event) => $options.quickCreateControl(control.id)
}, [
!control.icon ? (vue.openBlock(), vue.createElementBlock("img", {
key: 0,
class: "icon",
src: (_a4 = _ctx.editor) == null ? void 0 : _a4.icons[control.id]
}, null, 8, _hoisted_5$1)) : vue.createCommentVNode("", true),
control.icon ? (vue.openBlock(), vue.createElementBlock("div", {
key: 1,
class: "icon-html",
innerHTML: control.icon
}, null, 8, _hoisted_6$1)) : vue.createCommentVNode("", true),
vue.createElementVNode("div", _hoisted_7$1, vue.toDisplayString(_ctx.editor.i18n(control.name)), 1)
], 8, _hoisted_4$1);
}), 256))
])) : vue.createCommentVNode("", true)
], 512)), [
[vue.vShow, group2.display == true]
]);
}), 256))
], 8, _hoisted_1$1)) : vue.createCommentVNode("", true);
}
const QuickChooseControlDialog = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["render", _sfc_render$1], ["__scopeId", "data-v-5bda071e"]]);
const _DDeiExtQuickChooseControlDialog = class _DDeiExtQuickChooseControlDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QuickChooseControlDialog.name);
__publicField3(this, "plugins", [QuickChooseControlDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[QuickChooseControlDialog.name]) {
for (let i2 in options[QuickChooseControlDialog.name]) {
newOptions[i2] = options[QuickChooseControlDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiExtQuickChooseControlDialog(newOptions);
return panels;
}
}
return _DDeiExtQuickChooseControlDialog;
}
static modify(fn) {
return _DDeiExtQuickChooseControlDialog.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtQuickChooseControlDialog, "defaultIns", new _DDeiExtQuickChooseControlDialog(null));
let DDeiExtQuickChooseControlDialog = _DDeiExtQuickChooseControlDialog;
const _DDeiExtQuickControlDialogs = class _DDeiExtQuickControlDialogs extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [
DDeiExtQuickControlDialog,
DDeiExtQuickChooseControlDialog
]);
}
getDialogs(editor) {
var _a3;
let panels = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getDialogs(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getDialogs(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
panels = panels.concat(ls);
}
});
return panels;
}
static configuration(options) {
var _a3;
if (options) {
let panels = new _DDeiExtQuickControlDialogs(options);
for (let i2 = 0; i2 < ((_a3 = panels.plugins) == null ? void 0 : _a3.length); i2++) {
panels.plugins[i2] = panels.plugins[i2].configuration(options, true);
}
return panels;
}
return _DDeiExtQuickControlDialogs;
}
static modify(fn) {
return _DDeiExtQuickControlDialogs.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtQuickControlDialogs, "defaultIns", new _DDeiExtQuickControlDialogs(null));
let DDeiExtQuickControlDialogs = _DDeiExtQuickControlDialogs;
const _DDeiExtQuickControlPanel = class _DDeiExtQuickControlPanel extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", QuickControlPanel.name);
__publicField3(this, "plugins", [QuickControlPanel]);
}
getPanels(editor) {
return this.plugins;
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[ChangeRatio.name]) {
for (let i2 in options[ChangeRatio.name]) {
newOptions[i2] = options[ChangeRatio.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiExtQuickControlPanel(newOptions);
return panels;
}
}
return _DDeiExtQuickControlPanel;
}
static modify(fn) {
return _DDeiExtQuickControlPanel.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtQuickControlPanel, "defaultIns", new _DDeiExtQuickControlPanel(null));
let DDeiExtQuickControlPanel = _DDeiExtQuickControlPanel;
const _DDeiKeyActionQuickControlEsc = class _DDeiKeyActionQuickControlEsc extends DDeiKeyAction {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-ext-keyaction-quickcontrol-esc");
__publicField3(this, "defaultOptions", {
"keys": [
{ keys: "27" }
]
});
}
getHotKeys(editor) {
return [this];
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiKeyActionQuickControlEsc.defaultIns.name]) {
for (let i2 in options[_DDeiKeyActionQuickControlEsc.defaultIns.name]) {
newOptions[i2] = options[_DDeiKeyActionQuickControlEsc.defaultIns.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiKeyActionQuickControlEsc(newOptions);
return panels;
}
}
return _DDeiKeyActionQuickControlEsc;
}
static modify(fn) {
return _DDeiKeyActionQuickControlEsc.defaultIns.modify(fn);
}
// ============================ 方法 ===============================
action(evt, ddInstance, editor) {
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiKeyActionQuickControlEsc, "defaultIns", new _DDeiKeyActionQuickControlEsc());
let DDeiKeyActionQuickControlEsc = _DDeiKeyActionQuickControlEsc;
const _DDeiExtQuickControlHotkeys = class _DDeiExtQuickControlHotkeys extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "plugins", [DDeiKeyActionQuickControlEsc]);
}
getHotKeys(editor) {
var _a3;
let hotkeys = [];
(_a3 = this.plugins) == null ? void 0 : _a3.forEach((plugin) => {
let ls;
if (DDeiPluginBase.isSubclass(plugin, DDeiPluginBase)) {
ls = plugin.defaultIns.getHotKeys(editor);
} else if (plugin instanceof DDeiPluginBase) {
ls = plugin.getHotKeys(editor);
}
if ((ls == null ? void 0 : ls.length) > 0) {
hotkeys = hotkeys.concat(ls);
}
});
return hotkeys;
}
static configuration(options) {
var _a3;
let hotkeys = new _DDeiExtQuickControlHotkeys(options);
for (let i2 = 0; i2 < ((_a3 = hotkeys.plugins) == null ? void 0 : _a3.length); i2++) {
hotkeys.plugins[i2] = hotkeys.plugins[i2].configuration(options, true);
}
return hotkeys;
}
static modify(fn) {
return _DDeiExtQuickControlHotkeys.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtQuickControlHotkeys, "defaultIns", new _DDeiExtQuickControlHotkeys(null));
let DDeiExtQuickControlHotkeys = _DDeiExtQuickControlHotkeys;
const _DDeiExtSearchLifeCycle = class _DDeiExtSearchLifeCycle extends DDeiLifeCycle {
constructor() {
super(...arguments);
__publicField3(this, "name", "quickcontrol-ext-lifecycle");
// static{
// DDeiExtSearchLifeCycle.changeQuickControlDialogPos = debounce(DDeiExtSearchLifeCycle.changeQuickControlDialogPos,200)
// }
__publicField3(this, "EVENT_MOUSE_MOVE_IN_CONTROL", new DDeiFuncData("quickcontrol-ext-show", 1, this.moveInControl));
__publicField3(this, "EVENT_CONTROL_DRAG_AFTER", new DDeiFuncData("quickcontrol-ext-changepos", 1, this.changeQuickControlDialogPos));
__publicField3(this, "EVENT_MOUSE_MOVE_IN_LAYER", new DDeiFuncData("quickcontrol-ext-close", 1, this.closeQuickControlDialog));
__publicField3(this, "EVENT_CONTROL_SELECT_AFTER", new DDeiFuncData("quickcontrol-ext-show", 1, this.closeAndShowQuickControlDialog));
__publicField3(this, "EVENT_MOUSE_OPERATING", new DDeiFuncData("quickstyle-ext-close", 1, this.mouseOperating));
__publicField3(this, "EVENT_CLOSE_FILE_AFTER", new DDeiFuncData("quickcontrol-ext-close", 1, this.closeDialogs));
}
moveInControl(operateType, data, ddInstance, evt) {
var _a3, _b2, _c2;
if (ddInstance && ddInstance["AC_DESIGN_EDIT"] && ((_a3 = data == null ? void 0 : data.models) == null ? void 0 : _a3.length) > 0) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (editor.state == "designing") {
let model = data.models[0];
if (((_b2 = editor.ddInstance.stage.selectedModels) == null ? void 0 : _b2.size) > 0) {
if (!editor.ddInstance.stage.selectedModels.has(model.id)) {
if (((_c2 = editor.ddInstance.stage.selectedModels) == null ? void 0 : _c2.size) == 1) {
model = Array.from(editor.ddInstance.stage.selectedModels.values())[0];
} else {
return;
}
}
}
data.model = model;
_DDeiExtSearchLifeCycle.showQuickControlDialog(operateType, data, ddInstance, evt);
}
}
}
changeQuickControlDialogPos(operateType, data, ddInstance, evt) {
var _a3, _b2, _c2;
if (ddInstance && ddInstance["AC_DESIGN_EDIT"] && ((_a3 = data == null ? void 0 : data.models) == null ? void 0 : _a3.length) > 0) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (editor.state == "designing") {
let model = data.models[0];
if (((_b2 = editor.ddInstance.stage.selectedModels) == null ? void 0 : _b2.size) > 0) {
if (!editor.ddInstance.stage.selectedModels.has(model.id)) {
if (((_c2 = editor.ddInstance.stage.selectedModels) == null ? void 0 : _c2.size) == 1) {
model = Array.from(editor.ddInstance.stage.selectedModels.values())[0];
} else {
return;
}
}
}
data.model = model;
_DDeiExtSearchLifeCycle.changeQuickControlDialogPos(operateType, data, ddInstance, evt);
}
}
}
/**
* 正在进行鼠标操作
*/
mouseOperating(operateType, data, ddInstance, evt) {
if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (editor.state == "designing") {
let oldState = editor.state;
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickcontrol", true);
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickchoosecontrol", true);
editor.changeState(oldState);
}
}
}
/**
* 鼠标进入控件
*/
closeAndShowQuickControlDialog(operateType, data, ddInstance, evt) {
var _a3;
if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (editor.state == "designing") {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickcontrol", true);
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickchoosecontrol", true);
if (((_a3 = data.models) == null ? void 0 : _a3.length) > 0) {
data.model = data.models[0];
_DDeiExtSearchLifeCycle.showQuickControlDialog(operateType, data, ddInstance, evt);
}
}
}
}
/**
* 鼠标进入控件
*/
static showQuickControlDialog(operateType, data, ddInstance, evt) {
var _a3, _b2;
if (ddInstance && ddInstance["AC_DESIGN_EDIT"] && (data == null ? void 0 : data.model)) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (!((_a3 = data.model) == null ? void 0 : _a3.rotate) && ((_b2 = data.model) == null ? void 0 : _b2.baseModelType) != "DDeiLine" && (!editor.tempPopData || !editor.tempPopData["ddei-ext-dialog-quickcontrol"] || editor.tempPopData["ddei-ext-dialog-quickcontrol"].model != data.model)) {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickcontrol", true);
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickchoosecontrol", true);
let editorEle = document.getElementById(editor.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let modelPos = DDeiUtil.getModelsDomAbsPosition([data.model]);
let width = 50;
let height = 50;
let left = modelPos.left - editorDomPos.left - width / 2;
let top = modelPos.top - editorDomPos.top - height / 2;
let offset = null;
if (data.model.state == DDeiEnumControlState.SELECTED) {
height = 70;
top -= 20;
offset = {
"left": "margin-top:20px",
"right": "margin-top:20px"
};
}
DDeiEditorUtil.showDialog(editor, "ddei-ext-dialog-quickcontrol", {
group: "canvas-pop-quickcontrol",
model: data.model,
width,
height,
offset
}, { type: 99, left, top, ignoreOutSide: 1, hiddenMask: true }, null, true, true);
}
}
}
/**
* 修改坐标
*/
static changeQuickControlDialogPos(operateType, data, ddInstance, evt) {
if (ddInstance && ddInstance["AC_DESIGN_EDIT"] && (data == null ? void 0 : data.model)) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
let editorEle = document.getElementById(editor.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let modelPos = DDeiUtil.getModelsDomAbsPosition([data.model]);
let width = 50;
let height = 50;
let left = modelPos.left - editorDomPos.left - width / 2;
let top = modelPos.top - editorDomPos.top - height / 2;
let offset = null;
if (data.model.state == DDeiEnumControlState.SELECTED) {
height = 70;
top -= 20;
offset = {
"left": "margin-top:20px",
"right": "margin-top:20px"
};
}
DDeiEditorUtil.displayDialog(editor, "ddei-ext-dialog-quickcontrol", {
group: "canvas-pop-quickcontrol",
model: data.model,
width,
height,
offset
}, { type: 99, left, top, ignoreOutSide: 1, hiddenMask: true }, null, true, true);
}
}
/**
* 鼠标进入画布
*/
closeQuickControlDialog(operateType, data, ddInstance, evt) {
var _a3, _b2, _c2, _d2;
if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (editor.tempPopData && ((_a3 = editor.tempPopData["ddei-ext-dialog-quickcontrol"]) == null ? void 0 : _a3.model)) {
let model = (_b2 = editor.tempPopData["ddei-ext-dialog-quickcontrol"]) == null ? void 0 : _b2.model;
let type = (_c2 = editor.tempPopData["ddei-ext-dialog-quickchoosecontrol"]) == null ? void 0 : _c2.type;
let modelPos = DDeiUtil.getModelsDomAbsPosition([model]);
let width = 25;
let height = 25;
if (model.state == DDeiEnumControlState.SELECTED) {
height = 35;
}
modelPos.x -= width;
modelPos.x1 += width;
modelPos.y -= height;
modelPos.y1 += height;
if (type == 1) {
modelPos.y -= 15;
} else if (type == 2) {
modelPos.x1 += 10;
} else if (type == 3) {
modelPos.y1 += 10;
} else if (type == 4) {
modelPos.x -= 10;
}
if (!(modelPos.x <= data.ex && modelPos.x1 >= data.ex && modelPos.y <= data.ey && modelPos.y1 >= data.ey)) {
let selectedModels = ddInstance.stage.selectedModels;
if ((selectedModels == null ? void 0 : selectedModels.size) == 1 && Array.from(selectedModels.values())[0] == ((_d2 = editor.tempPopData["ddei-ext-dialog-quickcontrol"]) == null ? void 0 : _d2.model)) {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickchoosecontrol", true);
} else {
let quickChooseControlDialog = document.getElementById(editor.id + "_ddei-ext-dialog-quickchoosecontrol");
if (quickChooseControlDialog) {
let quickChooseControlDialogPos = DDeiUtil.getDomAbsPosition(quickChooseControlDialog);
let dx1 = quickChooseControlDialogPos.left + (quickChooseControlDialog == null ? void 0 : quickChooseControlDialog.clientWidth);
let dy1 = quickChooseControlDialogPos.top + (quickChooseControlDialog == null ? void 0 : quickChooseControlDialog.clientHeight);
let dx = quickChooseControlDialogPos.left;
let dy = quickChooseControlDialogPos.top;
if (!(dx <= evt.clientX && dx1 >= evt.clientX && dy <= evt.clientY && dy1 > evt.clientY)) {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickcontrol", true);
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickchoosecontrol", true);
}
} else {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickcontrol", true);
}
}
}
}
}
}
/**
* 鼠标进入画布
*/
closeDialogs(operateType, data, ddInstance, evt) {
var _a3;
if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (editor.tempPopData && ((_a3 = editor.tempPopData["ddei-ext-dialog-quickcontrol"]) == null ? void 0 : _a3.model)) {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickcontrol", true);
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-quickchoosecontrol", true);
}
}
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiExtSearchLifeCycle.name]) {
for (let i2 in options[_DDeiExtSearchLifeCycle.name]) {
newOptions[i2] = options[_DDeiExtSearchLifeCycle.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiExtSearchLifeCycle();
if (newOptions.name) {
panels.name = newOptions.name;
}
if (newOptions.sort) {
panels.sort = newOptions.sort;
}
return panels;
}
}
return _DDeiExtSearchLifeCycle;
}
static modify(fn) {
return _DDeiExtSearchLifeCycle.defaultIns.modify(fn);
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtSearchLifeCycle, "defaultIns", new _DDeiExtSearchLifeCycle(null));
let DDeiExtSearchLifeCycle = _DDeiExtSearchLifeCycle;
const _DDeiExtQuickControl = class _DDeiExtQuickControl extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "order", 2);
__publicField3(this, "dialogs", DDeiExtQuickControlDialogs);
__publicField3(this, "panels", DDeiExtQuickControlPanel);
__publicField3(this, "hotkeys", DDeiExtQuickControlHotkeys);
__publicField3(this, "lifecyclies", DDeiExtSearchLifeCycle);
}
getDialogs(editor) {
if (DDeiPluginBase.isSubclass(this.dialogs, DDeiPluginBase)) {
return this.dialogs.defaultIns.getDialogs(editor);
} else if (this.dialogs instanceof DDeiPluginBase) {
return this.dialogs.getDialogs(editor);
}
}
getPanels(editor) {
if (DDeiPluginBase.isSubclass(this.panels, DDeiPluginBase)) {
return this.panels.defaultIns.getPanels(editor);
} else if (this.panels instanceof DDeiPluginBase) {
return this.panels.getPanels(editor);
}
}
getHotKeys(editor) {
if (DDeiPluginBase.isSubclass(this.hotkeys, DDeiPluginBase)) {
return this.hotkeys.defaultIns.getHotKeys(editor);
} else if (this.hotkeys instanceof DDeiPluginBase) {
return this.hotkeys.getHotKeys(editor);
}
}
getLifeCyclies(editor) {
if (DDeiPluginBase.isSubclass(this.lifecyclies, DDeiPluginBase)) {
return this.lifecyclies.defaultIns.getLifeCyclies(editor);
} else if (this.lifecyclies instanceof DDeiPluginBase) {
return this.lifecyclies.getLifeCyclies(editor);
}
}
static configuration(options) {
let core = new _DDeiExtQuickControl(options);
core.dialogs = core.dialogs.configuration(options, true);
core.panels = core.panels.configuration(options, true);
core.hotkeys = core.hotkeys.configuration(options, true);
core.lifecyclies = core.lifecyclies.configuration(options, true);
return core;
}
static modify(fn) {
return _DDeiExtQuickControl.defaultIns.modify(fn);
}
};
__publicField3(_DDeiExtQuickControl, "order", 2);
/**
* 缺省实例
*/
__publicField3(_DDeiExtQuickControl, "defaultIns", new _DDeiExtQuickControl(null));
let DDeiExtQuickControl = _DDeiExtQuickControl;
const _DDeiExtSearch = class _DDeiExtSearch extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "order", 2);
__publicField3(this, "dialogs", DDeiExtSearchDialog);
__publicField3(this, "panels", DDeiExtSearchPanel);
__publicField3(this, "hotkeys", DDeiExtSearchHotkeys);
__publicField3(this, "lifecyclies", DDeiExtSearchLifeCycle$1);
}
getDialogs(editor) {
if (DDeiPluginBase.isSubclass(this.dialogs, DDeiPluginBase)) {
return this.dialogs.defaultIns.getDialogs(editor);
} else if (this.dialogs instanceof DDeiPluginBase) {
return this.dialogs.getDialogs(editor);
}
}
getPanels(editor) {
if (DDeiPluginBase.isSubclass(this.panels, DDeiPluginBase)) {
return this.panels.defaultIns.getPanels(editor);
} else if (this.panels instanceof DDeiPluginBase) {
return this.panels.getPanels(editor);
}
}
getHotKeys(editor) {
if (DDeiPluginBase.isSubclass(this.hotkeys, DDeiPluginBase)) {
return this.hotkeys.defaultIns.getHotKeys(editor);
} else if (this.hotkeys instanceof DDeiPluginBase) {
return this.hotkeys.getHotKeys(editor);
}
}
getLifeCyclies(editor) {
if (DDeiPluginBase.isSubclass(this.lifecyclies, DDeiPluginBase)) {
return this.lifecyclies.defaultIns.getLifeCyclies(editor);
} else if (this.lifecyclies instanceof DDeiPluginBase) {
return this.lifecyclies.getLifeCyclies(editor);
}
}
static modify(fn) {
return _DDeiExtSearch.defaultIns.modify(fn);
}
static configuration(options) {
let core = new _DDeiExtSearch(options);
core.dialogs = core.dialogs.configuration(options, true);
core.panels = core.panels.configuration(options, true);
core.hotkeys = core.hotkeys.configuration(options, true);
core.lifecyclies = core.lifecyclies.configuration(options, true);
return core;
}
};
__publicField3(_DDeiExtSearch, "order", 2);
/**
* 缺省实例
*/
__publicField3(_DDeiExtSearch, "defaultIns", new _DDeiExtSearch(null));
let DDeiExtSearch = _DDeiExtSearch;
const _sfc_main = {
name: "ddei-ext-dialog-tooltip",
extends: null,
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
},
editor: {
type: DDeiEditor,
default: null
}
},
data() {
return {
dialogId: "ddei-ext-dialog-tooltip",
//当前控件
model: null,
forceRefresh: false
};
},
computed: {},
components: {},
watch: {},
created() {
},
mounted() {
this.editor.dialogs[this.dialogId].viewer = this;
this.refreshData();
},
methods: {
forceRefreshView: function() {
this.forceRefresh = false;
this.$nextTick(() => {
this.forceRefresh = true;
if (this.refreshData) {
this.refreshData();
}
});
},
refreshData() {
if (this.editor.tempPopData && this.editor.tempPopData["ddei-ext-dialog-tooltip"]) {
this.model = this.editor.tempPopData["ddei-ext-dialog-tooltip"].model;
}
}
}
};
const TooltipDialog_vue_vue_type_style_index_0_scoped_d9902947_lang = "";
const _hoisted_1 = ["id"];
const _hoisted_2 = { key: 1 };
const _hoisted_3 = { class: "ddei-ext-dialog-tooltip-row" };
const _hoisted_4 = {
key: 0,
class: "ddei-ext-dialog-tooltip-row-title"
};
const _hoisted_5 = {
key: 1,
class: "ddei-ext-dialog-tooltip-row-data"
};
const _hoisted_6 = {
key: 0,
class: "ddei-ext-dialog-tooltip-row"
};
const _hoisted_7 = { class: "ddei-ext-dialog-tooltip-row-data" };
const _hoisted_8 = {
key: 1,
class: "ddei-ext-dialog-tooltip-row"
};
const _hoisted_9 = { class: "ddei-ext-dialog-tooltip-row-data" };
function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j;
return $data.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
id: ((_a3 = $props.editor) == null ? void 0 : _a3.id) + "_" + $data.dialogId,
class: "ddei-ext-dialog-tooltip fade-in"
}, [
((_b2 = $props.options) == null ? void 0 : _b2.viewer) ? (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent($props.options.viewer), {
key: 0,
editor: $props.editor,
options: $props.options,
model: $data.model
}, null, 8, ["editor", "options", "model"])) : vue.createCommentVNode("", true),
!((_c2 = $props.options) == null ? void 0 : _c2.viewer) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2, [
vue.createElementVNode("div", _hoisted_3, [
((_d2 = $data.model) == null ? void 0 : _d2.id) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_4, " ID ")) : vue.createCommentVNode("", true),
((_e2 = $data.model) == null ? void 0 : _e2.id) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_5, vue.toDisplayString((_f = $data.model) == null ? void 0 : _f.id), 1)) : vue.createCommentVNode("", true)
]),
((_g = $data.model) == null ? void 0 : _g.code) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6, [
_cache[0] || (_cache[0] = vue.createElementVNode("div", { class: "ddei-ext-dialog-tooltip-row-title" }, " CODE ", -1)),
vue.createElementVNode("div", _hoisted_7, vue.toDisplayString((_h = $data.model) == null ? void 0 : _h.code), 1)
])) : vue.createCommentVNode("", true),
((_i = $data.model) == null ? void 0 : _i.text) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_8, [
_cache[1] || (_cache[1] = vue.createElementVNode("div", { class: "ddei-ext-dialog-tooltip-row-title" }, " 文本 ", -1)),
vue.createElementVNode("div", _hoisted_9, vue.toDisplayString((_j = $data.model) == null ? void 0 : _j.text), 1)
])) : vue.createCommentVNode("", true)
])) : vue.createCommentVNode("", true)
], 8, _hoisted_1)) : vue.createCommentVNode("", true);
}
const TooltipDialog = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-d9902947"]]);
const _DDeiCoreTooltipDialog = class _DDeiCoreTooltipDialog extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "name", TooltipDialog.name);
__publicField3(this, "plugins", [TooltipDialog]);
}
getDialogs(editor) {
return this.plugins;
}
static modify(fn) {
return _DDeiCoreTooltipDialog.defaultIns.modify(fn);
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[TooltipDialog.name]) {
for (let i2 in options[TooltipDialog.name]) {
newOptions[i2] = options[TooltipDialog.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiCoreTooltipDialog(newOptions);
return panels;
}
}
return _DDeiCoreTooltipDialog;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiCoreTooltipDialog, "defaultIns", new _DDeiCoreTooltipDialog(null));
let DDeiCoreTooltipDialog = _DDeiCoreTooltipDialog;
const _DDeiExtTooltipLifeCycle = class _DDeiExtTooltipLifeCycle extends DDeiLifeCycle {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-ext-tooltip-lifecycle");
__publicField3(this, "EVENT_MOUSE_MOVE_IN_CONTROL", new DDeiFuncData("tooltip-show", 1, (operateType, data, ddInstance, evt) => {
this.showTooltip(operateType, data, ddInstance, evt);
}));
__publicField3(this, "EVENT_MOUSE_MOVE_IN_LAYER", new DDeiFuncData("tooltip-hidden", 1, this.mouseOperating));
__publicField3(this, "EVENT_CLOSE_FILE_AFTER", new DDeiFuncData("tooltip-close", 1, this.mouseOperating));
}
static modify(fn) {
return _DDeiExtTooltipLifeCycle.defaultIns.modify(fn);
}
static configuration(options, fullConfig = false) {
if (options) {
let newOptions = {};
if (fullConfig) {
if (fullConfig) {
if (options[_DDeiExtTooltipLifeCycle.name]) {
for (let i2 in options[_DDeiExtTooltipLifeCycle.name]) {
newOptions[i2] = options[_DDeiExtTooltipLifeCycle.name][i2];
}
}
}
} else {
newOptions = options;
}
if (newOptions && Object.keys(newOptions).length !== 0) {
let panels = new _DDeiExtTooltipLifeCycle(newOptions);
return panels;
}
}
return _DDeiExtTooltipLifeCycle;
}
showTooltip(operateType, data, ddInstance, evt) {
var _a3, _b2, _c2;
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
let stage2 = (_a3 = editor.ddInstance) == null ? void 0 : _a3.stage;
if (((_b2 = stage2 == null ? void 0 : stage2.render) == null ? void 0 : _b2.operateState) == 0 && ((_c2 = data.models) == null ? void 0 : _c2.length) > 0 && data.models[0]) {
if (editor.tempHoverModel != data.models[0]) {
if (!editor.tempHoverX || !editor.tempHoverY || Math.abs(editor.tempHoverX - data.x) > 10 || Math.abs(editor.tempHoverY - data.y) > 10) {
if (editor.tempPopData && editor.tempPopData["ddei-ext-dialog-tooltip"]) {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-tooltip", true);
}
editor.tempHoverModel = data.models[0];
editor.tempHoverX = data.x;
editor.tempHoverY = data.y;
editor.tempHoverTime = (/* @__PURE__ */ new Date()).getTime();
}
} else {
if ((/* @__PURE__ */ new Date()).getTime() - editor.tempHoverTime >= this.options.time) {
data.model = editor.tempHoverModel;
this.showTooltipDialog(operateType, data, ddInstance, evt);
}
}
} else {
if (editor.tempPopData && editor.tempPopData["ddei-ext-dialog-tooltip"]) {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-tooltip", true);
}
delete editor.tempHoverModel;
delete editor.tempHoverTime;
delete editor.tempHoverX;
delete editor.tempHoverY;
}
}
/**
* 鼠标进入控件
*/
showTooltipDialog(operateType, data, ddInstance, evt, options) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (!editor.tempPopData || !editor.tempPopData["ddei-ext-dialog-tooltip"] || editor.tempPopData["ddei-ext-dialog-tooltip"].model != data.model) {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-tooltip", true);
let editorEle = document.getElementById(editor.id);
let editorDomPos = DDeiUtil.getDomAbsPosition(editorEle);
let modelPos = DDeiUtil.getModelsDomAbsPosition([data.model]);
let left = modelPos.left - editorDomPos.left + modelPos.width + 20;
let top = modelPos.top - editorDomPos.top - 20;
DDeiEditorUtil.showDialog(editor, "ddei-ext-dialog-tooltip", {
group: "canvas-pop-tooltip",
model: data.model
}, { type: 99, left, top, hiddenMask: true }, null, true, true);
}
}
mouseOperating(operateType, data, ddInstance, evt) {
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (editor.tempPopData && editor.tempPopData["ddei-ext-dialog-tooltip"]) {
DDeiEditorUtil.closeDialog(editor, "ddei-ext-dialog-tooltip", true);
}
delete editor.tempHoverModel;
delete editor.tempHoverTime;
delete editor.tempHoverX;
delete editor.tempHoverY;
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtTooltipLifeCycle, "defaultIns", new _DDeiExtTooltipLifeCycle({
time: 400
}));
let DDeiExtTooltipLifeCycle = _DDeiExtTooltipLifeCycle;
const _DDeiExtTooltip = class _DDeiExtTooltip extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "order", 2);
__publicField3(this, "dialogs", DDeiCoreTooltipDialog);
__publicField3(this, "lifecyclies", DDeiExtTooltipLifeCycle);
}
getOptions() {
return this.options;
}
getDialogs(editor) {
if (DDeiPluginBase.isSubclass(this.dialogs, DDeiPluginBase)) {
return this.dialogs.defaultIns.getDialogs(editor);
} else if (this.dialogs instanceof DDeiPluginBase) {
return this.dialogs.getDialogs(editor);
}
}
getLifeCyclies(editor) {
if (DDeiPluginBase.isSubclass(this.lifecyclies, DDeiPluginBase)) {
return this.lifecyclies.defaultIns.getLifeCyclies(editor);
} else if (this.lifecyclies instanceof DDeiPluginBase) {
return this.lifecyclies.getLifeCyclies(editor);
}
}
static modify(fn) {
return _DDeiExtTooltip.defaultIns.modify(fn);
}
static configuration(options) {
let core = new _DDeiExtTooltip(options);
core.dialogs = core.dialogs.configuration(options, true);
core.lifecyclies = core.lifecyclies.configuration(options, true);
return core;
}
};
__publicField3(_DDeiExtTooltip, "order", 2);
/**
* 缺省实例
*/
__publicField3(_DDeiExtTooltip, "defaultIns", new _DDeiExtTooltip(null));
let DDeiExtTooltip = _DDeiExtTooltip;
const _DDeiExtHtmlViewerLifeCycle = class _DDeiExtHtmlViewerLifeCycle extends DDeiLifeCycle {
constructor() {
super(...arguments);
__publicField3(this, "name", "ddei-ext-htmlviewer-lifecycle");
__publicField3(this, "EVENT_CONTROL_VIEW", new DDeiFuncData("htmlviewer-drawshape", 1, (operateType, data, ddInstance, evt) => {
return this.htmlDrawShape(operateType, data, ddInstance, evt);
}));
}
installed(editor) {
for (let i2 in this.options) {
if (i2 != "matchField") {
if (this.options[i2]["viewer"]) {
this.options[i2]["viewer"] = vue.markRaw(this.options[i2]["viewer"]);
}
}
}
}
static configuration(options) {
if (options && Object.keys(options).length !== 0) {
let lcs = new _DDeiExtHtmlViewerLifeCycle(options);
return lcs;
}
return _DDeiExtHtmlViewerLifeCycle;
}
static modify(fn) {
return _DDeiExtHtmlViewerLifeCycle.defaultIns.modify(fn);
}
htmlDrawShape(operate, data, ddInstance, evt) {
let models = data == null ? void 0 : data.models;
let editor = DDeiEditorUtil.getEditorInsByDDei(ddInstance);
if (editor) {
let field = this.options.matchField;
for (let i2 = 0; i2 < (models == null ? void 0 : models.length); i2++) {
let model = models[i2];
if (model && model[field]) {
let option = this.options[model[field]];
if (option && option.viewer) {
if (model.render.tempCanvas) {
model.render.tempCanvas.remove();
}
if (model.render.viewerOption != option && vue.toRaw(model.render.viewerOption) != option) {
DDeiUtil.removeRenderViewer(model);
model.render.viewerOption = option;
model.render.viewer = option.viewer;
}
}
}
}
}
}
};
/**
* 缺省实例
*/
__publicField3(_DDeiExtHtmlViewerLifeCycle, "defaultIns", new _DDeiExtHtmlViewerLifeCycle({
matchField: "code"
}));
let DDeiExtHtmlViewerLifeCycle = _DDeiExtHtmlViewerLifeCycle;
const _DDeiExtHtmlViewer = class _DDeiExtHtmlViewer extends DDeiPluginBase {
constructor() {
super(...arguments);
__publicField3(this, "type", "package");
__publicField3(this, "order", 1);
__publicField3(this, "lifecyclies", DDeiExtHtmlViewerLifeCycle);
}
getLifeCyclies(editor) {
if (DDeiPluginBase.isSubclass(this.lifecyclies, DDeiPluginBase)) {
return this.lifecyclies.defaultIns.getLifeCyclies(editor);
} else if (this.lifecyclies instanceof DDeiPluginBase) {
return this.lifecyclies.getLifeCyclies(editor);
}
}
installed(editor) {
if (DDeiPluginBase.isSubclass(this.lifecyclies, DDeiPluginBase)) {
return this.lifecyclies.defaultIns.installed(editor);
} else if (this.lifecyclies instanceof DDeiPluginBase) {
return this.lifecyclies.installed(editor);
}
}
static configuration(options) {
let core = new _DDeiExtHtmlViewer(options);
core.lifecyclies = core.lifecyclies.configuration(options);
return core;
}
static modify(fn) {
return _DDeiExtHtmlViewer.defaultIns.modify(fn);
}
};
__publicField3(_DDeiExtHtmlViewer, "order", 1);
/**
* 缺省实例
*/
__publicField3(_DDeiExtHtmlViewer, "defaultIns", new _DDeiExtHtmlViewer(null));
let DDeiExtHtmlViewer = _DDeiExtHtmlViewer;
exports.COMMANDS = COMMANDS;
exports.DDei = DDei;
exports.DDeiAbstractArrtibuteParser = DDeiAbstractArrtibuteParser;
exports.DDeiAbstractShape = DDeiAbstractShape;
exports.DDeiAbstractShapeRender = DDeiAbstractShapeRender;
exports.DDeiActiveType = DDeiActiveType;
exports.DDeiArrtibuteDefine = DDeiArrtibuteDefine;
exports.DDeiArrtibuteParserBool = DDeiArrtibuteParserBool;
exports.DDeiArrtibuteParserNumber = DDeiArrtibuteParserNumber;
exports.DDeiArrtibuteParserString = DDeiArrtibuteParserString;
exports.DDeiBus = DDeiBus;
exports.DDeiBusCommand = DDeiBusCommand;
exports.DDeiBusCommandAddHistroy = DDeiBusCommandAddHistroy;
exports.DDeiBusCommandCancelCurLevelSelectedModels = DDeiBusCommandCancelCurLevelSelectedModels;
exports.DDeiBusCommandCenterStageWPV = DDeiBusCommandCenterStageWPV;
exports.DDeiBusCommandChangeCursor = DDeiBusCommandChangeCursor;
exports.DDeiBusCommandChangeLayout = DDeiBusCommandChangeLayout;
exports.DDeiBusCommandChangeLinePoint = DDeiBusCommandChangeLinePoint;
exports.DDeiBusCommandChangeSelectorPassIndex = DDeiBusCommandChangeSelectorPassIndex;
exports.DDeiBusCommandChangeStageRatio = DDeiBusCommandChangeStageRatio;
exports.DDeiBusCommandChangeStageWPV = DDeiBusCommandChangeStageWPV;
exports.DDeiBusCommandClearTemplateVars = DDeiBusCommandClearTemplateVars;
exports.DDeiBusCommandModelAlign = DDeiBusCommandModelAlign;
exports.DDeiBusCommandModelAutoPos = DDeiBusCommandModelAutoPos;
exports.DDeiBusCommandModelCancelMerge = DDeiBusCommandModelCancelMerge;
exports.DDeiBusCommandModelChangeBounds = DDeiBusCommandModelChangeBounds;
exports.DDeiBusCommandModelChangeContainer = DDeiBusCommandModelChangeContainer;
exports.DDeiBusCommandModelChangePosition = DDeiBusCommandModelChangePosition;
exports.DDeiBusCommandModelChangeRotate = DDeiBusCommandModelChangeRotate;
exports.DDeiBusCommandModelChangeSelect = DDeiBusCommandModelChangeSelect;
exports.DDeiBusCommandModelChangeValue = DDeiBusCommandModelChangeValue;
exports.DDeiBusCommandModelCopyStyle = DDeiBusCommandModelCopyStyle;
exports.DDeiBusCommandModelEdgePosition = DDeiBusCommandModelEdgePosition;
exports.DDeiBusCommandModelMerge = DDeiBusCommandModelMerge;
exports.DDeiBusCommandModelPush = DDeiBusCommandModelPush;
exports.DDeiBusCommandModelRemove = DDeiBusCommandModelRemove;
exports.DDeiBusCommandNodifyControlCreated = DDeiBusCommandNodifyControlCreated;
exports.DDeiBusCommandOVSChangePosition = DDeiBusCommandOVSChangePosition;
exports.DDeiBusCommandRefreshShape = DDeiBusCommandRefreshShape;
exports.DDeiBusCommandResetSelectorState = DDeiBusCommandResetSelectorState;
exports.DDeiBusCommandSetHelpLine = DDeiBusCommandSetHelpLine;
exports.DDeiBusCommandStageChangeSelectModels = DDeiBusCommandStageChangeSelectModels;
exports.DDeiBusCommandTextEditorChangeSelectPos = DDeiBusCommandTextEditorChangeSelectPos;
exports.DDeiBusCommandUpdateDragObj = DDeiBusCommandUpdateDragObj;
exports.DDeiBusCommandUpdatePaperArea = DDeiBusCommandUpdatePaperArea;
exports.DDeiBusCommandUpdateSelectorBounds = DDeiBusCommandUpdateSelectorBounds;
exports.DDeiCircle = DDeiCircle;
exports.DDeiCircleCanvasRender = DDeiCircleCanvasRender;
exports.DDeiColor = DDeiColor;
exports.DDeiCommandChangeEditMode = DDeiCommandChangeEditMode;
exports.DDeiCommandChangeNodifyChange = DDeiCommandChangeNodifyChange;
exports.DDeiConfig = DDeiConfig;
exports.DDeiConverterBase = DDeiConverterBase;
exports.DDeiCore = DDeiCore;
exports.DDeiCoreAddFontSizeButton = DDeiCoreAddFontSizeButton;
exports.DDeiCoreAlignDialog = DDeiCoreAlignDialog;
exports.DDeiCoreAlignTypePropEditor = DDeiCoreAlignTypePropEditor;
exports.DDeiCoreBorderDashButton = DDeiCoreBorderDashButton;
exports.DDeiCoreBorderDashComboPropEditor = DDeiCoreBorderDashComboPropEditor;
exports.DDeiCoreBorderTypePropEditor = DDeiCoreBorderTypePropEditor;
exports.DDeiCoreBorderWeightButton = DDeiCoreBorderWeightButton;
exports.DDeiCoreBottomMenuPanel = DDeiCoreBottomMenuPanel;
exports.DDeiCoreBottomPanels = DDeiCoreBottomPanels;
exports.DDeiCoreCanvasViewPanel = DDeiCoreCanvasViewPanel;
exports.DDeiCoreChangeRatioDialog = DDeiCoreChangeRatioDialog;
exports.DDeiCoreChangeRatioPanel = DDeiCoreChangeRatioPanel;
exports.DDeiCoreChooseControlDialog = DDeiCoreChooseControlDialog;
exports.DDeiCoreChooseControlGroupDialog = DDeiCoreChooseControlGroupDialog;
exports.DDeiCoreCloseFileConfirmDialog = DDeiCoreCloseFileConfirmDialog;
exports.DDeiCoreCollFileConfirmDialog = DDeiCoreCollFileConfirmDialog;
exports.DDeiCoreColorComboPropEditor = DDeiCoreColorComboPropEditor;
exports.DDeiCoreColorPropEditor = DDeiCoreColorPropEditor;
exports.DDeiCoreComboxPropEditor = DDeiCoreComboxPropEditor;
exports.DDeiCoreCommonPanels = DDeiCoreCommonPanels;
exports.DDeiCoreComponents = DDeiCoreComponents;
exports.DDeiCoreControls = DDeiCoreControls;
exports.DDeiCoreDialogs = DDeiCoreDialogs;
exports.DDeiCoreEditBoxButton = DDeiCoreEditBoxButton;
exports.DDeiCoreEditColorButton = DDeiCoreEditColorButton;
exports.DDeiCoreEditFontFamilyButton = DDeiCoreEditFontFamilyButton;
exports.DDeiCoreEditFontSizeButton = DDeiCoreEditFontSizeButton;
exports.DDeiCoreEditLinePointTypeButton = DDeiCoreEditLinePointTypeButton;
exports.DDeiCoreEditLineTypeButton = DDeiCoreEditLineTypeButton;
exports.DDeiCoreEditTextAlignButton = DDeiCoreEditTextAlignButton;
exports.DDeiCoreExCheckboxPropEditor = DDeiCoreExCheckboxPropEditor;
exports.DDeiCoreExportAndImportPanel = DDeiCoreExportAndImportPanel;
exports.DDeiCoreFileInfoPanel = DDeiCoreFileInfoPanel;
exports.DDeiCoreFileOperatePanel = DDeiCoreFileOperatePanel;
exports.DDeiCoreFillTypePropEditor = DDeiCoreFillTypePropEditor;
exports.DDeiCoreFontAndTextPanel = DDeiCoreFontAndTextPanel;
exports.DDeiCoreFontSizePropEditor = DDeiCoreFontSizePropEditor;
exports.DDeiCoreHotkeys = DDeiCoreHotkeys;
exports.DDeiCoreImagePropEditor = DDeiCoreImagePropEditor;
exports.DDeiCoreLayouts = DDeiCoreLayouts;
exports.DDeiCoreLifeCycles = DDeiCoreLifeCycles;
exports.DDeiCoreLinePointTypeDialog = DDeiCoreLinePointTypeDialog;
exports.DDeiCoreLineTypeDialog = DDeiCoreLineTypeDialog;
exports.DDeiCoreManageLayersDialog = DDeiCoreManageLayersDialog;
exports.DDeiCoreManageLayersPanel = DDeiCoreManageLayersPanel;
exports.DDeiCoreMenus = DDeiCoreMenus;
exports.DDeiCoreMergeComposeDialog = DDeiCoreMergeComposeDialog;
exports.DDeiCoreOpenFilesViewPanel = DDeiCoreOpenFilesViewPanel;
exports.DDeiCoreOperatePanel = DDeiCoreOperatePanel;
exports.DDeiCorePVEditors = DDeiCorePVEditors;
exports.DDeiCorePanels = DDeiCorePanels;
exports.DDeiCorePlayPanel = DDeiCorePlayPanel;
exports.DDeiCorePositionDialog = DDeiCorePositionDialog;
exports.DDeiCorePropertyViewPanel = DDeiCorePropertyViewPanel;
exports.DDeiCorePublishFileConfirmDialog = DDeiCorePublishFileConfirmDialog;
exports.DDeiCoreQCViewDialog = DDeiCoreQCViewDialog;
exports.DDeiCoreQuickColorViewPanel = DDeiCoreQuickColorViewPanel;
exports.DDeiCoreQuickSetStyleDialog = DDeiCoreQuickSetStyleDialog;
exports.DDeiCoreRadioPropEditor = DDeiCoreRadioPropEditor;
exports.DDeiCoreRangePropEditor = DDeiCoreRangePropEditor;
exports.DDeiCoreRotateDialog = DDeiCoreRotateDialog;
exports.DDeiCoreSelectBorderDashDialog = DDeiCoreSelectBorderDashDialog;
exports.DDeiCoreSelectBorderWeightDialog = DDeiCoreSelectBorderWeightDialog;
exports.DDeiCoreSelectColorDialog = DDeiCoreSelectColorDialog;
exports.DDeiCoreSelectFontDialog = DDeiCoreSelectFontDialog;
exports.DDeiCoreSelectFontSizeDialog = DDeiCoreSelectFontSizeDialog;
exports.DDeiCoreShapeCountPanel = DDeiCoreShapeCountPanel;
exports.DDeiCoreSheetsPanel = DDeiCoreSheetsPanel;
exports.DDeiCoreSimpleLayout = DDeiCoreSimpleLayout;
exports.DDeiCoreSimplePanels = DDeiCoreSimplePanels;
exports.DDeiCoreSortPanel = DDeiCoreSortPanel;
exports.DDeiCoreStandLayout = DDeiCoreStandLayout;
exports.DDeiCoreStylePanel = DDeiCoreStylePanel;
exports.DDeiCoreSuitRatioPanel = DDeiCoreSuitRatioPanel;
exports.DDeiCoreSwitchCheckboxPropEditor = DDeiCoreSwitchCheckboxPropEditor;
exports.DDeiCoreTextAlignDialog = DDeiCoreTextAlignDialog;
exports.DDeiCoreTextAreaPropEditor = DDeiCoreTextAreaPropEditor;
exports.DDeiCoreTextPropEditor = DDeiCoreTextPropEditor;
exports.DDeiCoreThemeBlack = DDeiCoreThemeBlack;
exports.DDeiCoreThemeDefault = DDeiCoreThemeDefault;
exports.DDeiCoreThemes = DDeiCoreThemes;
exports.DDeiCoreToolPanel = DDeiCoreToolPanel;
exports.DDeiCoreToolboxPanel = DDeiCoreToolboxPanels;
exports.DDeiCoreToolboxPanels = DDeiCoreToolboxPanels;
exports.DDeiCoreToolboxSimplePanel = DDeiCoreToolboxSimplePanel;
exports.DDeiCoreTopMenuPanel = DDeiCoreTopMenuPanel;
exports.DDeiCoreTopMenuSimplePanel = DDeiCoreTopMenuSimplePanel;
exports.DDeiDiamond = DDeiDiamond;
exports.DDeiDiamondCanvasRender = DDeiDiamondCanvasRender;
exports.DDeiEditor = DDeiEditor;
exports.DDeiEditorArrtibute = DDeiEditorArrtibute;
exports.DDeiEditorCommandAddHistroy = DDeiEditorCommandAddHistroy;
exports.DDeiEditorCommandChangeEditMode = DDeiEditorCommandChangeEditMode;
exports.DDeiEditorCommandClearTemplateUI = DDeiEditorCommandClearTemplateUI;
exports.DDeiEditorCommandFileDirty = DDeiEditorCommandFileDirty;
exports.DDeiEditorCommandLoadFile = DDeiEditorCommandLoadFile;
exports.DDeiEditorCommandRefreshEditorParts = DDeiEditorCommandRefreshEditorParts;
exports.DDeiEditorCommandSaveFile = DDeiEditorCommandSaveFile;
exports.DDeiEditorEnumBusCommandType = DDeiEditorEnumBusCommandType;
exports.DDeiEditorState = DDeiEditorState;
exports.DDeiEditorUtil = DDeiEditorUtil;
exports.DDeiEditorView = DDeiEditorView;
exports.DDeiEnumAttributeType = DDeiEnumAttributeType;
exports.DDeiEnumBusCommandType = DDeiEnumBusCommandType;
exports.DDeiEnumControlState = DDeiEnumControlState;
exports.DDeiEnumOperateState = DDeiEnumOperateState;
exports.DDeiEnumOperateType = DDeiEnumOperateType;
exports.DDeiEnumState = DDeiEnumState;
exports.DDeiEnumStoreType = DDeiEnumStoreType;
exports.DDeiExtHtmlViewer = DDeiExtHtmlViewer;
exports.DDeiExtQuickControl = DDeiExtQuickControl;
exports.DDeiExtQuickControlDialogs = DDeiExtQuickControlDialogs;
exports.DDeiExtQuickControlHotkeys = DDeiExtQuickControlHotkeys;
exports.DDeiExtQuickStyle = DDeiExtQuickStyle;
exports.DDeiExtSearch = DDeiExtSearch;
exports.DDeiExtSearchHotkeys = DDeiExtSearchHotkeys;
exports.DDeiExtTooltip = DDeiExtTooltip;
exports.DDeiExtUML = DDeiExtUML;
exports.DDeiFile = DDeiFile;
exports.DDeiFileState = DDeiFileState;
exports.DDeiFuncCallResult = DDeiFuncCallResult;
exports.DDeiFuncData = DDeiFuncData;
exports.DDeiKeyAction = DDeiKeyAction;
exports.DDeiKeyActionAllSelect = DDeiKeyActionAllSelect;
exports.DDeiKeyActionBrushData = DDeiKeyActionBrushData;
exports.DDeiKeyActionCancelCompose = DDeiKeyActionCancelCompose;
exports.DDeiKeyActionCancelControlCreate = DDeiKeyActionCancelControlCreate;
exports.DDeiKeyActionCancelCurrentAction = DDeiKeyActionCancelCurrentAction;
exports.DDeiKeyActionCancelQuickEdit = DDeiKeyActionCancelQuickEdit;
exports.DDeiKeyActionCancelSelect = DDeiKeyActionCancelSelect;
exports.DDeiKeyActionClearBrushData = DDeiKeyActionClearBrushData;
exports.DDeiKeyActionCloseDialog = DDeiKeyActionCloseDialog;
exports.DDeiKeyActionCompose = DDeiKeyActionCompose;
exports.DDeiKeyActionCopy = DDeiKeyActionCopy;
exports.DDeiKeyActionCopyImage = DDeiKeyActionCopyImage;
exports.DDeiKeyActionCut = DDeiKeyActionCut;
exports.DDeiKeyActionEnterQuickEdit = DDeiKeyActionEnterQuickEdit;
exports.DDeiKeyActionMoveModels = DDeiKeyActionMoveModels;
exports.DDeiKeyActionNewRowQuickEdit = DDeiKeyActionNewRowQuickEdit;
exports.DDeiKeyActionPaste = DDeiKeyActionPaste;
exports.DDeiKeyActionPushModels = DDeiKeyActionPushModels;
exports.DDeiKeyActionQuickControlEsc = DDeiKeyActionQuickControlEsc;
exports.DDeiKeyActionReRevoke = DDeiKeyActionReRevoke;
exports.DDeiKeyActionRemoveModels = DDeiKeyActionRemoveModels;
exports.DDeiKeyActionRevoke = DDeiKeyActionRevoke;
exports.DDeiKeyActionSaveFile = DDeiKeyActionSaveFile;
exports.DDeiKeyActionSearch = DDeiKeyActionSearch;
exports.DDeiKeyActionSearchEsc = DDeiKeyActionSearchEsc;
exports.DDeiKeyActionSearchNext = DDeiKeyActionSearchNext;
exports.DDeiKeyActionSearchUp = DDeiKeyActionSearchUp;
exports.DDeiKeyActionStartQuickEdit = DDeiKeyActionStartQuickEdit;
exports.DDeiKeyActionTableNextCol = DDeiKeyActionTableNextCol;
exports.DDeiKeyActionTableNextRow = DDeiKeyActionTableNextRow;
exports.DDeiLayer = DDeiLayer;
exports.DDeiLayerCanvasRender = DDeiLayerCanvasRender;
exports.DDeiLayoutManager = DDeiLayoutManager;
exports.DDeiLayoutManagerCompose = DDeiLayoutManagerCompose;
exports.DDeiLayoutManagerFactory = DDeiLayoutManagerFactory;
exports.DDeiLayoutManagerFree = DDeiLayoutManagerFree;
exports.DDeiLayoutManagerFull = DDeiLayoutManagerFull;
exports.DDeiLayoutManagerNine = DDeiLayoutManagerNine;
exports.DDeiLifeCycle = DDeiLifeCycle;
exports.DDeiLine = DDeiLine;
exports.DDeiLineCanvasRender = DDeiLineCanvasRender;
exports.DDeiLink = DDeiLink;
exports.DDeiMenuBase = DDeiMenuBase;
exports.DDeiModelArrtibuteValue = DDeiModelArrtibuteValue;
exports.DDeiModelLink = DDeiModelLink;
exports.DDeiPluginBase = DDeiPluginBase;
exports.DDeiPolygon = DDeiPolygon;
exports.DDeiPolygonContainer = DDeiPolygonContainer;
exports.DDeiPolygonContainerCanvasRender = DDeiPolygonContainerCanvasRender;
exports.DDeiRectangle = DDeiRectangle;
exports.DDeiRectangleCanvasRender = DDeiRectangleCanvasRender;
exports.DDeiSelector = DDeiSelector;
exports.DDeiSelectorCanvasRender = DDeiSelectorCanvasRender;
exports.DDeiSheet = DDeiSheet;
exports.DDeiStage = DDeiStage;
exports.DDeiStageCanvasRender = DDeiStageCanvasRender;
exports.DDeiStore = DDeiStore;
exports.DDeiTable = DDeiTable;
exports.DDeiTableCanvasRender = DDeiTableCanvasRender;
exports.DDeiTableCell = DDeiTableCell;
exports.DDeiTableCellCanvasRender = DDeiTableCellCanvasRender;
exports.DDeiTableSelector = DDeiTableSelector;
exports.DDeiTableSelectorCanvasRender = DDeiTableSelectorCanvasRender;
exports.DDeiThemeBase = DDeiThemeBase;
exports.DDeiUtil = DDeiUtil;
exports.FONTS = FONTS;
exports.Matrix3 = Matrix3;
exports.MenuCancelMergeCell = MenuCancelMergeCell;
exports.MenuCopySheet = MenuCopySheet;
exports.MenuInsertCol = MenuInsertCol;
exports.MenuInsertRow = MenuInsertRow;
exports.MenuMergeCell = MenuMergeCell;
exports.MenuRemoveCol = MenuRemoveCol;
exports.MenuRemoveRow = MenuRemoveRow;
exports.MenuRemoveSheet = MenuRemoveSheet;
exports.QuickChooseControlDialog = DDeiExtQuickChooseControlDialog;
exports.QuickControlDialog = DDeiExtQuickControlDialog;
exports.Vector3 = Vector3;
exports.addCommand = addCommand;
exports.autoLoadCommand = autoLoadCommand;
exports.clone = clone;
exports.cloneDeep = cloneDeep;
exports.config = config;
exports.debounce = debounce;
exports.default = DDeiEditorView;
exports.loadAndSortGroup = loadAndSortGroup;
exports.loadControlByFrom = loadControlByFrom;
exports.loadControlDefineComposes = loadControlDefineComposes;
exports.loadControlDefineExt = loadControlDefineExt;
exports.merge = merge$1;
exports.ov_link_h_split_point = ov_link_h_split_point;
exports.ov_link_v_split_point = ov_link_v_split_point;
exports.throttle = throttle;
exports.trim = trim;
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
});