格式化代码

This commit is contained in:
不做码农 2022-03-10 15:04:05 +08:00
parent d2077762d1
commit 7828f5995e
2 changed files with 127 additions and 161 deletions

View File

@ -16,7 +16,7 @@ const actions = {
changeOnlineNum({ commit }, data) {
commit('SET_ONLINEUSER_NUM', data)
},
// 更新系统通知
// 更新系统通知
getNoticeList({ commit }, data) {
commit('SET_NOTICE_list', data)
}

View File

@ -11,19 +11,9 @@
<div class="components-title">
<svg-icon icon-class="component" />输入型组件
</div>
<draggable
class="components-draggable"
:list="inputComponents"
:group="{ name: 'componentsGroup', pull: 'clone', put: false }"
:clone="cloneComponent"
draggable=".components-item"
:sort="false"
@end="onEnd"
>
<div
v-for="(element, index) in inputComponents" :key="index" class="components-item"
@click="addComponent(element)"
>
<draggable class="components-draggable" :list="inputComponents" :group="{ name: 'componentsGroup', pull: 'clone', put: false }"
:clone="cloneComponent" draggable=".components-item" :sort="false" @end="onEnd">
<div v-for="(element, index) in inputComponents" :key="index" class="components-item" @click="addComponent(element)">
<div class="components-body">
<svg-icon :icon-class="element.tagIcon" />
{{ element.label }}
@ -33,21 +23,9 @@
<div class="components-title">
<svg-icon icon-class="component" />选择型组件
</div>
<draggable
class="components-draggable"
:list="selectComponents"
:group="{ name: 'componentsGroup', pull: 'clone', put: false }"
:clone="cloneComponent"
draggable=".components-item"
:sort="false"
@end="onEnd"
>
<div
v-for="(element, index) in selectComponents"
:key="index"
class="components-item"
@click="addComponent(element)"
>
<draggable class="components-draggable" :list="selectComponents" :group="{ name: 'componentsGroup', pull: 'clone', put: false }"
:clone="cloneComponent" draggable=".components-item" :sort="false" @end="onEnd">
<div v-for="(element, index) in selectComponents" :key="index" class="components-item" @click="addComponent(element)">
<div class="components-body">
<svg-icon :icon-class="element.tagIcon" />
{{ element.label }}
@ -57,15 +35,9 @@
<div class="components-title">
<svg-icon icon-class="component" /> 布局型组件
</div>
<draggable
class="components-draggable" :list="layoutComponents"
:group="{ name: 'componentsGroup', pull: 'clone', put: false }" :clone="cloneComponent"
draggable=".components-item" :sort="false" @end="onEnd"
>
<div
v-for="(element, index) in layoutComponents" :key="index" class="components-item"
@click="addComponent(element)"
>
<draggable class="components-draggable" :list="layoutComponents" :group="{ name: 'componentsGroup', pull: 'clone', put: false }"
:clone="cloneComponent" draggable=".components-item" :sort="false" @end="onEnd">
<div v-for="(element, index) in layoutComponents" :key="index" class="components-item" @click="addComponent(element)">
<div class="components-body">
<svg-icon :icon-class="element.tagIcon" />
{{ element.label }}
@ -90,25 +62,12 @@
</div>
<el-scrollbar class="center-scrollbar">
<el-row class="center-board-row" :gutter="formConf.gutter">
<el-form
:size="formConf.size"
:label-position="formConf.labelPosition"
:disabled="formConf.disabled"
:label-width="formConf.labelWidth + 'px'"
>
<el-form :size="formConf.size" :label-position="formConf.labelPosition" :disabled="formConf.disabled"
:label-width="formConf.labelWidth + 'px'">
<draggable class="drawing-board" :list="drawingList" :animation="340" group="componentsGroup">
<draggable-item
v-for="(element, index) in drawingList"
:key="element.renderKey"
:drawing-list="drawingList"
:element="element"
:index="index"
:active-id="activeId"
:form-conf="formConf"
@activeItem="activeFormItem"
@copyItem="drawingItemCopy"
@deleteItem="drawingItemDelete"
/>
<draggable-item v-for="(element, index) in drawingList" :key="element.renderKey" :drawing-list="drawingList" :element="element"
:index="index" :active-id="activeId" :form-conf="formConf" @activeItem="activeFormItem" @copyItem="drawingItemCopy"
@deleteItem="drawingItemDelete" />
</draggable>
<div v-show="!drawingList.length" class="empty-info">
从左侧拖入或点选组件进行表单设计
@ -118,19 +77,9 @@
</el-scrollbar>
</div>
<right-panel
:active-data="activeData"
:form-conf="formConf"
:show-field="!!drawingList.length"
@tag-change="tagChange"
/>
<right-panel :active-data="activeData" :form-conf="formConf" :show-field="!!drawingList.length" @tag-change="tagChange" />
<code-type-dialog
:visible.sync="dialogVisible"
title="选择生成类型"
:show-file-name="showFileName"
@confirm="generate"
/>
<code-type-dialog :visible.sync="dialogVisible" title="选择生成类型" :show-file-name="showFileName" @confirm="generate" />
<input id="copyNode" type="hidden">
</div>
</template>
@ -149,10 +98,16 @@ import {
formConf
} from '@/utils/generator/config'
import {
exportDefault, beautifierConf, isNumberStr, titleCase
exportDefault,
beautifierConf,
isNumberStr,
titleCase
} from '@/utils/index'
import {
makeUpHtml, vueTemplate, vueScript, cssStyle
makeUpHtml,
vueTemplate,
vueScript,
cssStyle
} from '@/utils/generator/html'
import { makeUpJs } from '@/utils/generator/js'
import { makeUpCss } from '@/utils/generator/css'
@ -161,7 +116,7 @@ import logo from '@/assets/logo/logo.png'
import CodeTypeDialog from './CodeTypeDialog'
import DraggableItem from './DraggableItem'
const emptyActiveData = { style: {}, autosize: {} }
const emptyActiveData = { style: {}, autosize: {}}
let oldActiveId
let tempActiveData
@ -193,19 +148,19 @@ export default {
activeData: drawingDefalut[0]
}
},
computed: {
},
computed: {},
watch: {
// eslint-disable-next-line func-names
'activeData.label': function (val, oldVal) {
'activeData.label': function(val, oldVal) {
if (
this.activeData.placeholder === undefined
|| !this.activeData.tag
|| oldActiveId !== this.activeId
this.activeData.placeholder === undefined ||
!this.activeData.tag ||
oldActiveId !== this.activeId
) {
return
}
this.activeData.placeholder = this.activeData.placeholder.replace(oldVal, '') + val
this.activeData.placeholder =
this.activeData.placeholder.replace(oldVal, '') + val
},
activeId: {
handler(val) {
@ -216,7 +171,7 @@ export default {
},
mounted() {
const clipboard = new ClipboardJS('#copyNode', {
text: trigger => {
text: (trigger) => {
const codeStr = this.generateCode()
this.$notify({
title: '成功',
@ -226,7 +181,7 @@ export default {
return codeStr
}
})
clipboard.on('error', e => {
clipboard.on('error', (e) => {
this.$message.error('代码复制失败')
})
},
@ -309,7 +264,9 @@ export default {
item.componentName = `row${this.idGlobal}`
}
if (Array.isArray(item.children)) {
item.children = item.children.map(childItem => this.createIdAndKey(childItem))
item.children = item.children.map((childItem) =>
this.createIdAndKey(childItem)
)
}
return item
},
@ -353,9 +310,11 @@ export default {
delete this.activeData.tag
delete this.activeData.tagIcon
delete this.activeData.document
Object.keys(newTag).forEach(key => {
if (this.activeData[key] !== undefined
&& typeof this.activeData[key] === typeof newTag[key]) {
Object.keys(newTag).forEach((key) => {
if (
this.activeData[key] !== undefined &&
typeof this.activeData[key] === typeof newTag[key]
) {
newTag[key] = this.activeData[key]
}
})
@ -363,12 +322,12 @@ export default {
this.updateDrawingList(newTag, this.drawingList)
},
updateDrawingList(newTag, list) {
const index = list.findIndex(item => item.formId === this.activeId)
const index = list.findIndex((item) => item.formId === this.activeId)
if (index > -1) {
list.splice(index, 1, newTag)
} else {
list.forEach(item => {
if (Array.isArray(item.children)) this.updateDrawingList(newTag, item.children)
list.forEach((item) => {
if (Array.isArray(item.children)) { this.updateDrawingList(newTag, item.children) }
})
}
}
@ -377,30 +336,34 @@ export default {
</script>
<style lang='scss'>
body, html{
body,
html {
margin: 0;
padding: 0;
background: #fff;
-moz-osx-font-smoothing: grayscale;
-webkit-font-smoothing: antialiased;
text-rendering: optimizeLegibility;
font-family: -apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji;
font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial,
sans-serif, Apple Color Emoji, Segoe UI Emoji;
}
input, textarea{
font-family: -apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji;
input,
textarea {
font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial,
sans-serif, Apple Color Emoji, Segoe UI Emoji;
}
.editor-tabs{
.editor-tabs {
background: #121315;
.el-tabs__header{
.el-tabs__header {
margin: 0;
border-bottom-color: #121315;
.el-tabs__nav{
.el-tabs__nav {
border-color: #121315;
}
}
.el-tabs__item{
.el-tabs__item {
height: 32px;
line-height: 32px;
color: #888a8e;
@ -409,15 +372,15 @@ input, textarea{
margin-right: 5px;
user-select: none;
}
.el-tabs__item.is-active{
.el-tabs__item.is-active {
background: #1e1e1e;
border-bottom-color: #1e1e1e!important;
border-bottom-color: #1e1e1e !important;
color: #fff;
}
.el-icon-edit{
.el-icon-edit {
color: #f1fa8c;
}
.el-icon-document{
.el-icon-document {
color: #a95812;
}
}
@ -433,24 +396,24 @@ input, textarea{
overflow-x: hidden !important;
margin-bottom: 0 !important;
}
.center-tabs{
.el-tabs__header{
margin-bottom: 0!important;
.center-tabs {
.el-tabs__header {
margin-bottom: 0 !important;
}
.el-tabs__item{
.el-tabs__item {
width: 50%;
text-align: center;
}
.el-tabs__nav{
.el-tabs__nav {
width: 100%;
}
}
.reg-item{
.reg-item {
padding: 12px 6px;
background: #f8f8f8;
position: relative;
border-radius: 4px;
.close-btn{
.close-btn {
position: absolute;
right: -6px;
top: -6px;
@ -465,16 +428,16 @@ input, textarea{
z-index: 1;
cursor: pointer;
font-size: 12px;
&:hover{
background: rgba(210, 23, 23, 0.5)
&:hover {
background: rgba(210, 23, 23, 0.5);
}
}
& + .reg-item{
& + .reg-item {
margin-top: 18px;
}
}
.action-bar{
& .el-button+.el-button {
.action-bar {
& .el-button + .el-button {
margin-left: 15px;
}
& i {
@ -485,37 +448,37 @@ input, textarea{
}
}
.custom-tree-node{
.custom-tree-node {
width: 100%;
font-size: 14px;
.node-operation{
.node-operation {
float: right;
}
i[class*="el-icon"] + i[class*="el-icon"]{
i[class*="el-icon"] + i[class*="el-icon"] {
margin-left: 6px;
}
.el-icon-plus{
color: #409EFF;
.el-icon-plus {
color: #409eff;
}
.el-icon-delete{
.el-icon-delete {
color: #157a0c;
}
}
.left-scrollbar .el-scrollbar__view{
.left-scrollbar .el-scrollbar__view {
overflow-x: hidden;
}
.el-rate{
.el-rate {
display: inline-block;
vertical-align: text-top;
}
.el-upload__tip{
.el-upload__tip {
line-height: 1.2;
}
$selectedColor: #f6f7ff;
$lighterBlue: #409EFF;
$lighterBlue: #409eff;
.container {
position: relative;
@ -534,14 +497,14 @@ $lighterBlue: #409EFF;
transition: transform 0ms !important;
}
}
.components-draggable{
.components-draggable {
padding-bottom: 20px;
}
.components-title{
.components-title {
font-size: 14px;
color: #222;
margin: 6px 2px;
.svg-icon{
.svg-icon {
color: #666;
font-size: 18px;
}
@ -554,7 +517,7 @@ $lighterBlue: #409EFF;
cursor: move;
border: 1px dashed $selectedColor;
border-radius: 3px;
.svg-icon{
.svg-icon {
color: #777;
font-size: 15px;
}
@ -574,7 +537,7 @@ $lighterBlue: #409EFF;
top: 0;
height: 100vh;
}
.left-scrollbar{
.left-scrollbar {
height: calc(100vh - 42px);
overflow: hidden;
}
@ -591,7 +554,7 @@ $lighterBlue: #409EFF;
margin: 0 350px 0 260px;
box-sizing: border-box;
}
.empty-info{
.empty-info {
position: absolute;
top: 46%;
left: 0;
@ -601,27 +564,27 @@ $lighterBlue: #409EFF;
color: #ccb1ea;
letter-spacing: 4px;
}
.action-bar{
.action-bar {
position: relative;
height: 42px;
text-align: right;
padding: 0 15px;
box-sizing: border-box;;
box-sizing: border-box;
border: 1px solid #f1e8e8;
border-top: none;
border-left: none;
.delete-btn{
color: #F56C6C;
.delete-btn {
color: #f56c6c;
}
}
.logo-wrapper{
.logo-wrapper {
position: relative;
height: 42px;
background: #fff;
border-bottom: 1px solid #f1e8e8;
box-sizing: border-box;
}
.logo{
.logo {
position: absolute;
left: 12px;
top: 6px;
@ -630,16 +593,16 @@ $lighterBlue: #409EFF;
font-weight: 600;
font-size: 17px;
white-space: nowrap;
> img{
> img {
width: 30px;
height: 30px;
vertical-align: top;
}
.github{
.github {
display: inline-block;
vertical-align: sub;
margin-left: 15px;
> img{
> img {
height: 22px;
}
}
@ -682,32 +645,33 @@ $lighterBlue: #409EFF;
background-color: $selectedColor;
}
.active-from-item {
& > .el-form-item{
& > .el-form-item {
background: $selectedColor;
border-radius: 6px;
}
& > .drawing-item-copy, & > .drawing-item-delete{
& > .drawing-item-copy,
& > .drawing-item-delete {
display: initial;
}
& > .component-name{
& > .component-name {
color: $lighterBlue;
}
}
.el-form-item{
.el-form-item {
margin-bottom: 15px;
}
}
.drawing-item{
.drawing-item {
position: relative;
cursor: move;
&.unfocus-bordered:not(.activeFromItem) > div:first-child {
&.unfocus-bordered:not(.activeFromItem) > div:first-child {
border: 1px dashed #ccc;
}
.el-form-item{
.el-form-item {
padding: 12px 10px;
}
}
.drawing-row-item{
.drawing-row-item {
position: relative;
cursor: move;
box-sizing: border-box;
@ -718,19 +682,19 @@ $lighterBlue: #409EFF;
.drawing-row-item {
margin-bottom: 2px;
}
.el-col{
.el-col {
margin-top: 22px;
}
.el-form-item{
.el-form-item {
margin-bottom: 0;
}
.drag-wrapper{
.drag-wrapper {
min-height: 80px;
}
&.active-from-item{
&.active-from-item {
border: 1px dashed $lighterBlue;
}
.component-name{
.component-name {
position: absolute;
top: 0;
left: 0;
@ -740,17 +704,20 @@ $lighterBlue: #409EFF;
padding: 0 6px;
}
}
.drawing-item, .drawing-row-item{
.drawing-item,
.drawing-row-item {
&:hover {
& > .el-form-item{
& > .el-form-item {
background: $selectedColor;
border-radius: 6px;
}
& > .drawing-item-copy, & > .drawing-item-delete{
& > .drawing-item-copy,
& > .drawing-item-delete {
display: initial;
}
}
& > .drawing-item-copy, & > .drawing-item-delete{
& > .drawing-item-copy,
& > .drawing-item-delete {
display: none;
position: absolute;
top: -10px;
@ -764,26 +731,25 @@ $lighterBlue: #409EFF;
cursor: pointer;
z-index: 1;
}
& > .drawing-item-copy{
& > .drawing-item-copy {
right: 56px;
border-color: $lighterBlue;
color: $lighterBlue;
background: #fff;
&:hover{
&:hover {
background: $lighterBlue;
color: #fff;
}
}
& > .drawing-item-delete{
& > .drawing-item-delete {
right: 24px;
border-color: #F56C6C;
color: #F56C6C;
border-color: #f56c6c;
color: #f56c6c;
background: #fff;
&:hover{
background: #F56C6C;
&:hover {
background: #f56c6c;
color: #fff;
}
}
}
</style>