Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
J
jiedao-app-operator-master
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lanbaoming
jiedao-app-operator-master
Commits
03b8b1a7
Commit
03b8b1a7
authored
Jun 20, 2022
by
wanglianghe
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
广告弹窗
parent
bf7a33d0
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
122 additions
and
26 deletions
+122
-26
index.vue
src/components/Editor/index.vue
+16
-2
index.vue
src/views/ecw/bannerPop/index.vue
+106
-24
No files found.
src/components/Editor/index.vue
View file @
03b8b1a7
...
@@ -172,11 +172,11 @@ export default {
...
@@ -172,11 +172,11 @@ export default {
// 获取富文本组件实例
// 获取富文本组件实例
let
quill
=
this
.
Quill
;
let
quill
=
this
.
Quill
;
// 如果上传成功
// 如果上传成功
if
(
res
.
code
==
20
0
)
{
if
(
res
.
code
==
0
)
{
// 获取光标所在位置
// 获取光标所在位置
let
length
=
quill
.
getSelection
().
index
;
let
length
=
quill
.
getSelection
().
index
;
// 插入图片 res.url为服务器返回的图片地址
// 插入图片 res.url为服务器返回的图片地址
quill
.
insertEmbed
(
length
,
"
image
"
,
process
.
env
.
VUE_APP_BASE_API
+
res
.
fileName
);
quill
.
insertEmbed
(
length
,
"
image
"
,
res
.
data
);
// 调整光标到最后
// 调整光标到最后
quill
.
setSelection
(
length
+
1
);
quill
.
setSelection
(
length
+
1
);
}
else
{
}
else
{
...
@@ -186,6 +186,20 @@ export default {
...
@@ -186,6 +186,20 @@ export default {
handleUploadError
()
{
handleUploadError
()
{
this
.
$message
.
error
(
"
图片插入失败
"
);
this
.
$message
.
error
(
"
图片插入失败
"
);
},
},
uuid
()
{
var
s
=
[];
var
hexDigits
=
"
0123456789abcdef
"
;
for
(
var
i
=
0
;
i
<
36
;
i
++
)
{
s
[
i
]
=
hexDigits
.
substr
(
Math
.
floor
(
Math
.
random
()
*
0x10
),
1
);
}
s
[
14
]
=
"
4
"
;
// bits 12-15 of the time_hi_and_version field to 0010
s
[
19
]
=
hexDigits
.
substr
((
s
[
19
]
&
0x3
)
|
0x8
,
1
);
// bits 6-7 of the clock_seq_hi_and_reserved to 01
s
[
8
]
=
s
[
13
]
=
s
[
18
]
=
s
[
23
]
=
"
-
"
;
var
uuid
=
s
.
join
(
""
);
return
uuid
;
},
},
},
};
};
</
script
>
</
script
>
...
...
src/views/ecw/bannerPop/index.vue
View file @
03b8b1a7
...
@@ -55,31 +55,31 @@
...
@@ -55,31 +55,31 @@
<!-- 列表 -->
<!-- 列表 -->
<el-table
v-loading=
"loading"
:data=
"list"
>
<el-table
v-loading=
"loading"
:data=
"list"
>
<el-table-column
label=
""
align=
"center"
prop=
"id"
/>
<el-table-column
label=
""
align=
"center"
prop=
"id"
/>
<el-table-column
label=
"中文标题"
align=
"center"
prop=
"titleZh"
/>
<el-table-column
label=
"弹窗标题"
align=
"center"
prop=
"titleZh"
/>
<el-table-column
label=
"英文标题"
align=
"center"
prop=
"titleEn"
/>
<el-table-column
label=
"弹窗时间"
align=
"center"
prop=
"validateDate"
width=
"180"
>
<el-table-column
label=
"有效期开始时间"
align=
"center"
prop=
"validateStart"
width=
"180"
>
<template
slot-scope=
"scope"
>
<template
slot-scope=
"scope"
>
<span>
{{
parseTime
(
scope
.
row
.
validateStart
)
}}
</span>
<span>
{{
formatTime
(
scope
.
row
.
validateStart
)
}}
~
{{
formatTime
(
scope
.
row
.
validateEnd
)
}}
</span>
</
template
>
</
template
>
</el-table-column>
</el-table-column>
<el-table-column
label=
"有效期结束时间"
align=
"center"
prop=
"validateEnd"
width=
"180"
>
<el-table-column
label=
"状态"
align=
"center"
prop=
"status"
>
<
template
slot-scope=
"scope"
>
<
template
slot-scope=
"scope"
>
<span>
{{
parseTime
(
scope
.
row
.
validateEnd
)
}}
</span>
<span>
{{
statusName
(
scope
.
row
.
status
)
}}
</span>
</
template
>
</
template
>
</el-table-column>
</el-table-column>
<el-table-column
label=
"web网页中文"
align=
"center"
prop=
"htmlWebZh"
/>
<el-table-column
label=
"web网页英文"
align=
"center"
prop=
"htmlWebEn"
/>
<el-table-column
label=
"app网页中文"
align=
"center"
prop=
"htmlAppZh"
/>
<el-table-column
label=
"0显示 1不显示"
align=
"center"
prop=
"status"
/>
<el-table-column
label=
"创建时间"
align=
"center"
prop=
"createTime"
width=
"180"
>
<el-table-column
label=
"创建时间"
align=
"center"
prop=
"createTime"
width=
"180"
>
<
template
slot-scope=
"scope"
>
<
template
slot-scope=
"scope"
>
<span>
{{
parseTime
(
scope
.
row
.
createTime
)
}}
</span>
<span>
{{
parseTime
(
scope
.
row
.
createTime
)
}}
</span>
</
template
>
</
template
>
</el-table-column>
</el-table-column>
<el-table-column
label=
"操作"
align=
"center"
class-name=
"small-padding fixed-width"
>
<el-table-column
label=
"操作"
align=
"center"
class-name=
"small-padding fixed-width"
>
<
template
slot-scope=
"scope"
>
<
template
slot-scope=
"scope"
>
<el-button
size=
"mini"
type=
"text"
icon=
"el-icon-edit"
@
click=
"handleUpdate(scope.row)"
<!--
<el-button
size=
"mini"
type=
"text"
icon=
"el-icon-edit"
@
click=
"handleUpdate(scope.row)"
v-hasPermi=
"['ecw:banner-pop:update']"
>
修改
</el-button>
v-hasPermi=
"['ecw:banner-pop:update']"
>
修改
</el-button>
-->
<el-button
size=
"mini"
type=
"text"
@
click=
"handleStatus(scope.row)"
v-hasPermi=
"['ecw:banner-pop:update']"
>
{{
scope
.
row
.
status
==
CommonStatusEnum
.
ENABLE
?
'
禁用
'
:
'
启用
'
}}
</el-button>
<el-button
size=
"mini"
type=
"text"
icon=
"el-icon-delete"
@
click=
"handleDelete(scope.row)"
<el-button
size=
"mini"
type=
"text"
icon=
"el-icon-delete"
@
click=
"handleDelete(scope.row)"
v-hasPermi=
"['ecw:banner-pop:delete']"
>
删除
</el-button>
v-hasPermi=
"['ecw:banner-pop:delete']"
>
删除
</el-button>
</
template
>
</
template
>
...
@@ -90,8 +90,8 @@
...
@@ -90,8 +90,8 @@
@
pagination=
"getList"
/>
@
pagination=
"getList"
/>
<!-- 对话框(添加 / 修改) -->
<!-- 对话框(添加 / 修改) -->
<el-dialog
:title=
"title"
:visible.sync=
"open"
width=
"
5
00px"
append-to-body
>
<el-dialog
:title=
"title"
:visible.sync=
"open"
width=
"
9
00px"
append-to-body
>
<el-form
ref=
"form"
:model=
"form"
:rules=
"rules"
label-width=
"
8
0px"
>
<el-form
ref=
"form"
:model=
"form"
:rules=
"rules"
label-width=
"
10
0px"
>
<el-form-item
label=
"标题(中文)"
prop=
"titleZh"
>
<el-form-item
label=
"标题(中文)"
prop=
"titleZh"
>
<el-input
v-model=
"form.titleZh"
placeholder=
"请输入中文标题"
/>
<el-input
v-model=
"form.titleZh"
placeholder=
"请输入中文标题"
/>
</el-form-item>
</el-form-item>
...
@@ -99,7 +99,7 @@
...
@@ -99,7 +99,7 @@
<el-input
v-model=
"form.titleEn"
placeholder=
"请输入英文标题"
/>
<el-input
v-model=
"form.titleEn"
placeholder=
"请输入英文标题"
/>
</el-form-item>
</el-form-item>
<el-form-item
label=
"有效期"
prop=
"validateStart"
>
<el-form-item
label=
"有效期"
prop=
"validateStart"
>
<el-date-picker
v-model=
"form.validateStart"
<el-date-picker
v-model=
"form.validateStart"
@
change=
"startChange"
type=
"date"
type=
"date"
placeholder=
"选择日期"
>
placeholder=
"选择日期"
>
</el-date-picker>
</el-date-picker>
...
@@ -108,19 +108,20 @@
...
@@ -108,19 +108,20 @@
type=
"date"
type=
"date"
placeholder=
"选择日期"
>
placeholder=
"选择日期"
>
</el-date-picker>
</el-date-picker>
<span
style=
"color:red;font-size:14px;"
>
注意:留空则表示永久有效
</span>
</el-form-item>
</el-form-item>
<el-form-item
label=
"
web
网页中文"
prop=
"htmlWebZh"
>
<el-form-item
label=
"网页中文"
prop=
"htmlWebZh"
>
<e
l-input
v-model=
"form.htmlWebZh"
placeholder=
"请输入web网页中文"
/>
<e
ditor
v-model=
"form.htmlWebZh"
:min-height=
"150"
/>
</el-form-item>
</el-form-item>
<el-form-item
label=
"
web
网页英文"
prop=
"htmlWebEn"
>
<el-form-item
label=
"网页英文"
prop=
"htmlWebEn"
>
<e
l-input
v-model=
"form.htmlWebEn"
placeholder=
"请输入web网页英文"
/>
<e
ditor
v-model=
"form.htmlWebEn"
:min-height=
"150"
/>
</el-form-item>
</el-form-item>
<el-form-item
label=
"
app网页
中文"
prop=
"htmlAppZh"
>
<el-form-item
label=
"
APP
中文"
prop=
"htmlAppZh"
>
<e
l-input
v-model=
"form.htmlAppZh"
placeholder=
"请输入app网页中文"
/>
<e
ditor
v-model=
"form.htmlAppZh"
:min-height=
"150"
/>
</el-form-item>
</el-form-item>
<el-form-item
label=
"
app网页英文"
prop=
"htmlAppZh
"
>
<el-form-item
label=
"
APP英文"
prop=
"htmlAppEn
"
>
<el-input
v-model=
"form.htmlAppZh"
placeholder=
"请输入app网页英文"
/>
<editor
v-model=
"form.htmlAppEn"
:min-height=
"150"
/>
</el-form-item>
</el-form-item>
</el-form>
</el-form>
<div
slot=
"footer"
class=
"dialog-footer"
>
<div
slot=
"footer"
class=
"dialog-footer"
>
...
@@ -133,10 +134,14 @@
...
@@ -133,10 +134,14 @@
<
script
>
<
script
>
import
{
createBannerPop
,
updateBannerPop
,
deleteBannerPop
,
getBannerPop
,
getBannerPopPage
,
exportBannerPopExcel
}
from
"
@/api/ecw/bannerPop
"
;
import
{
createBannerPop
,
updateBannerPop
,
deleteBannerPop
,
getBannerPop
,
getBannerPopPage
,
exportBannerPopExcel
}
from
"
@/api/ecw/bannerPop
"
;
import
Editor
from
'
@/components/Editor
'
;
import
{
getDictDatas
,
DICT_TYPE
}
from
'
@/utils/dict
'
;
import
{
CommonStatusEnum
}
from
'
@/utils/constants
'
export
default
{
export
default
{
name
:
"
BannerPop
"
,
name
:
"
BannerPop
"
,
components
:
{
components
:
{
Editor
,
},
},
data
()
{
data
()
{
return
{
return
{
...
@@ -172,9 +177,70 @@ export default {
...
@@ -172,9 +177,70 @@ export default {
form
:
{},
form
:
{},
// 表单校验
// 表单校验
rules
:
{
rules
:
{
}
titleZh
:
[{
required
:
true
,
message
:
"
中文标题不能为空
"
,
trigger
:
"
blur
"
}],
titleEn
:
[{
required
:
true
,
message
:
"
英文标题不能为空
"
,
trigger
:
"
blur
"
}],
validateStart
:
[{
required
:
true
,
message
:
"
有效期开始时间不能为空
"
,
trigger
:
"
blur
"
}]
},
CommonStatusEnum
:
CommonStatusEnum
,
statusDictDatas
:
getDictDatas
(
DICT_TYPE
.
COMMON_STATUS
),
};
};
},
},
watch
:
{
'
form.validateStart
'
(
newV
,
oldV
)
{
if
(
this
.
form
.
validateStart
&&
this
.
form
.
validateEnd
)
{
let
startDate
=
new
Date
(
this
.
form
.
validateStart
)
let
endDate
=
new
Date
(
this
.
form
.
validateEnd
)
if
(
startDate
.
getTime
()
>
endDate
.
getTime
()){
this
.
$message
.
error
(
'
开始时间不能大于结束时间
'
);
if
(
oldV
)
{
this
.
form
.
validateStart
=
oldV
;
}
else
{
this
.
form
.
validateStart
=
""
}
}
}
},
'
form.validateEnd
'
(
newV
,
oldV
)
{
if
(
this
.
form
.
validateStart
&&
this
.
form
.
validateEnd
)
{
let
startDate
=
new
Date
(
this
.
form
.
validateStart
)
let
endDate
=
new
Date
(
this
.
form
.
validateEnd
)
if
(
startDate
.
getTime
()
>
endDate
.
getTime
()){
this
.
$message
.
error
(
'
结束时间不能小于开始时间
'
);
if
(
oldV
)
{
this
.
form
.
validateEnd
=
oldV
;
}
else
{
this
.
form
.
validateEnd
=
""
}
}
}
},
},
computed
:
{
formatTime
()
{
return
millisecond
=>
{
if
(
millisecond
)
{
return
new
Date
(
millisecond
).
format
(
'
yyyy-MM-dd
'
);
}
return
''
;
}
},
statusName
()
{
return
value
=>
{
for
(
let
index
in
this
.
statusDictDatas
)
{
let
dictItem
=
this
.
statusDictDatas
[
index
];
if
(
dictItem
.
value
==
value
)
{
return
dictItem
.
value
==
CommonStatusEnum
.
ENABLE
+
''
?
'
正常
'
:
'
禁用
'
;
}
}
}
},
},
created
()
{
created
()
{
this
.
getList
();
this
.
getList
();
},
},
...
@@ -212,6 +278,22 @@ export default {
...
@@ -212,6 +278,22 @@ export default {
};
};
this
.
resetForm
(
"
form
"
);
this
.
resetForm
(
"
form
"
);
},
},
/**修改状态 */
handleStatus
(
row
)
{
row
.
status
=
row
.
status
===
CommonStatusEnum
.
ENABLE
?
CommonStatusEnum
.
DISABLE
:
CommonStatusEnum
.
ENABLE
;
updateBannerPop
(
row
).
then
(()
=>
{
this
.
$modal
.
msgSuccess
(
"
修改成功
"
);
}).
catch
(
function
()
{
row
.
status
=
row
.
status
===
CommonStatusEnum
.
ENABLE
?
CommonStatusEnum
.
DISABLE
:
CommonStatusEnum
.
ENABLE
;
});
},
/**开始日期变了 */
startChange
(
val
)
{
},
/** 搜索按钮操作 */
/** 搜索按钮操作 */
handleQuery
()
{
handleQuery
()
{
this
.
queryParams
.
pageNo
=
1
;
this
.
queryParams
.
pageNo
=
1
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment