@@ -470,6 +470,15 @@ | |||
"enablePullDownRefresh": true | |||
} | |||
}, | |||
{ | |||
"path": "prohibited/details", | |||
"style": { | |||
"navigationBarTitleText": "违禁详情", | |||
"navigationBarBackgroundColor": "#FFFFFF", | |||
"navigationBarTextStyle": "black", | |||
"enablePullDownRefresh": false | |||
} | |||
}, | |||
{ | |||
"path": "consumer/index", | |||
"style": { | |||
@@ -6,19 +6,24 @@ | |||
{{ timeText }} | |||
<u-icon name="arrow-down" size="24" style="padding-left: 12rpx;"></u-icon> | |||
</view> | |||
<view class="tabbox" @click="selectshow = true"> | |||
{{ guwenText }} | |||
<u-icon name="arrow-down" size="24" style="padding-left: 12rpx;"></u-icon> | |||
</view> | |||
<view class="tabbox" @click="tapsoltishow"> | |||
{{ sortText }}<u-icon name="arrow-down" size="24" style="padding-left: 12rpx;"></u-icon> | |||
{{ steyStatus }} | |||
<u-icon name="arrow-down" size="24" style="padding-left: 12rpx;"></u-icon> | |||
</view> | |||
<view class="tabbox" @click="selectshow = true"> | |||
{{ adviserText }}<u-icon name="arrow-down" size="24" style="padding-left: 12rpx;"></u-icon> | |||
<view class="tabbox" @click="showIdent = true"> | |||
{{ weijinTag }} | |||
<u-icon name="arrow-down" size="24" style="padding-left: 12rpx;"></u-icon> | |||
</view> | |||
</view> | |||
<!-- 筛选后的数量 --> | |||
</view> | |||
<view class="count" v-if="recordList.length > 0"> | |||
筛选结果:<text>{{totalRecords}} </text>条 | |||
</view> | |||
<view class="content"> | |||
<view v-if="recordList.length==0" | |||
style="width: 100%;height: 100%;display: flex;align-items: center;background: #FFFFFF;"> | |||
@@ -31,26 +36,33 @@ | |||
</view> | |||
</view> | |||
<view v-if="recordList.length!=0" class="content-tips" v-for="(item,index) in recordList" :key='index' | |||
@click="tapThevisiting(item)"> | |||
@click="tapThevisiting(item, index)"> | |||
<view class="content-first"> | |||
<view class="left"> | |||
<!-- <view class="img">{{item.agentName.slice(0,1)}}</view> --> | |||
<view class="img">顾</view> | |||
<view class="name">{{item.agentName}}</view> | |||
<view class="status" v-if="item.replaceReception==1">代接待</view> | |||
</view> | |||
<view class="right"> | |||
<view class=""></view> | |||
<view class=""> | |||
{{ item.violatedStatus | ViolatedStatus }}|{{ item.disposeStatus | DisposeStatus }} | |||
</view> | |||
</view> | |||
</view> | |||
<view class="content-sec"> | |||
<view class="left"> | |||
<view class="cus">客户:{{item.name || '--'}} |</view> | |||
<view class="arriveNum">{{item.visitRecord || "--"}}次到访</view> | |||
</view> | |||
</view> | |||
<view class="content-last"> | |||
{{item.createTime}} | {{item.mm || '0'}} min | |||
<view class="item"> | |||
<image src="@/static/images/img/time.png" mode=""></image> | |||
<text>{{item.createTime}}</text> | |||
</view> | |||
<view class="item"> | |||
<image src="@/static/images/img/voice.png" mode=""></image> | |||
<text>{{item.mm || '0'}}min</text> | |||
</view> | |||
<view class="item"> | |||
<image src="@/static/images/img/hit.png" mode=""></image> | |||
<text>{{item.violatedFrequency || '0'}}</text> | |||
</view> | |||
</view> | |||
</view> | |||
</view> | |||
@@ -60,20 +72,14 @@ | |||
<u-select v-model="selectshow" :list="freeList" @confirm="actionSelectCallback"></u-select> | |||
<u-calendar v-model="totalTimeShow" mode="range" @change="totalTimeChange"></u-calendar> | |||
<u-popup v-model="timeshow" mode="bottom"> | |||
<view class="timeview" :style="{ color: activeTotal == 5 ? '#2B6EFF' : '#333333' }" @click="tabtimetap(5, '接待时间')"> | |||
全部</view> | |||
<view class="timeview" :style="{ color: activeTotal == 0 ? '#2B6EFF' : '#333333' }" @click="tabtimetap(0, '今天')"> | |||
今天</view> | |||
<view class="timeview" :style="{ color: activeTotal == 1 ? '#2B6EFF' : '#333333' }" @click="tabtimetap(1, '昨天')"> | |||
昨天</view> | |||
<view class="timeview" :style="{ color: activeTotal == 2 ? '#2B6EFF' : '#333333' }" @click="tabtimetap(2, '近7天')"> | |||
近7天</view> | |||
<view class="timeview" :style="{ color: activeTotal == 3 ? '#2B6EFF' : '#333333' }" @click="tabtimetap(3, '近30天')"> | |||
近30天</view> | |||
<view class="timeview" :style="{ color: activeTotal == 4 ? '#2B6EFF' : '#333333' }" @click="tabtimetap(4)"> | |||
自定义</view> | |||
<block v-for="(data, index) in activeList" :key="index"> | |||
<view class="timeview" :style="{ color: activeTotal == data.id ? '#2B6EFF' : '#333333' }" | |||
@click="tabtimetap(data.id, data.title)">{{ data.title }}</view> | |||
</block> | |||
</u-popup> | |||
<u-select v-model="soltishow" :list="orderBylist" @confirm="selectCallback2"></u-select> | |||
<u-select v-model="showIdent" :list="identList" @confirm="selectIdent"></u-select> | |||
</view> | |||
</template> | |||
@@ -81,38 +87,65 @@ | |||
export default { | |||
data() { | |||
return { | |||
// 筛选文字描述 | |||
timeText: '接待时间', | |||
sortText: '排序', | |||
adviserText: '顾问', | |||
// | |||
orderBylist: [ | |||
// {label:'全部',value:'0'}, | |||
orderBylist: [{ | |||
label: '全部', | |||
value: null | |||
}, { | |||
label: '待处理', | |||
value: 0 | |||
}, { | |||
label: '已处理', | |||
value: 1 | |||
}], | |||
activeTotal: 5, | |||
activeList: [ // 时间筛选数组 | |||
{ | |||
title: '全部', | |||
id: 5, | |||
}, | |||
{ | |||
title: '今天', | |||
id: 0, | |||
}, | |||
{ | |||
label: '创建时间倒序', | |||
value: '1' | |||
title: '昨天', | |||
id: 1, | |||
}, | |||
{ | |||
label: '创建时间正序', | |||
value: '2' | |||
title: '近7天', | |||
id: 2, | |||
}, | |||
{ | |||
label: '接待时间倒序', | |||
value: '3' | |||
title: '近30天', | |||
id: 3, | |||
}, | |||
{ | |||
label: '接待时间正序', | |||
value: '4' | |||
title: '自定义', | |||
id: 4, | |||
}, | |||
], | |||
activeTotal: 5, | |||
showIdent: false, // 显示选择违禁标识列表 | |||
identList: [ // 违禁标识列表 | |||
{ | |||
label: '全部', | |||
value: null | |||
}, | |||
{ | |||
label: '有效', | |||
value: 1 | |||
}, | |||
{ | |||
label: '无效', | |||
value: 2 | |||
}, | |||
], | |||
violatedStatus: null, // 违禁状态 | |||
selectshow: false, | |||
totalTimeShow: false, | |||
screen: { | |||
agentId: '', //顾问id | |||
record: '0', | |||
}, | |||
totalRecords: '', | |||
freeList: [], //顾问 | |||
recordList: [], | |||
buildingID: '', | |||
@@ -124,9 +157,18 @@ | |||
activeTotal2: 0, | |||
timeshow: false, | |||
soltishow: false, | |||
orderBy: '', | |||
orderBy: null, | |||
userInfo: {}, | |||
isRefresh:false | |||
totalRecords: '', // 列表全部的条数 | |||
isRefresh: false, | |||
nextPageObj: {}, // 跳转详情页面的参数 | |||
// 页面文字展示内容 | |||
timeText: '接待时间', // | |||
guwenText: '顾问', // | |||
steyStatus: '处理状态', // | |||
weijinTag: '违禁标识', // 违禁标识 | |||
} | |||
}, | |||
@@ -139,26 +181,30 @@ | |||
this.staTime = options.staTime; | |||
this.endtime = options.endtime; | |||
} | |||
if (options.violatedStatus) this.violatedStatus = options.violatedStatus | |||
}, | |||
onShow() { | |||
this.$store.commit('stopAduio') | |||
this.userInfo = uni.getStorageSync('weapp_session_userInfo_data'); | |||
if (this.isnorefresh == 'refresh') { | |||
this.buildingID = uni.getStorageSync('buildingID').id; | |||
this.recordList = []; | |||
this.nextPage = 1; | |||
this.isRefresh = false; | |||
this.isRefresh = false; | |||
this.getMyCustom() | |||
this.getFreeList(); | |||
this.isnorefresh = ''; | |||
} | |||
var pages = getCurrentPages(); | |||
pages[0].$vm.path = '/pages/index/index' | |||
console.log(pages[0].$vm.path) | |||
}, | |||
onPullDownRefresh(){ | |||
onPullDownRefresh() { | |||
this.nextPage = 1; | |||
this.isRefresh = true; | |||
this.getMyCustom() | |||
setTimeout(function () { | |||
uni.stopPullDownRefresh(); | |||
this.resetRefreshParams() | |||
setTimeout(function() { | |||
uni.stopPullDownRefresh(); | |||
}, 1000); | |||
}, | |||
onReachBottom() { | |||
@@ -171,11 +217,23 @@ | |||
return | |||
} else { | |||
this.nextPage += 1; | |||
this.isRefresh = false; | |||
this.isRefresh = false; | |||
this.getMyCustom(); | |||
} | |||
}, | |||
methods: { | |||
// 重置参数 | |||
resetRefreshParams() { | |||
this.timeText = '接待时间' | |||
this.activeTotal = 5 | |||
this.guwenText = '顾问' | |||
this.screen.agentId = '' // 顾问id | |||
this.steyStatus = '处理状态' | |||
this.orderBy = null | |||
this.weijinTag = '违禁标识' | |||
this.violatedStatus = null // 违禁状态 | |||
}, | |||
tapsoltishow() { | |||
this.soltishow = true; | |||
}, | |||
@@ -183,28 +241,40 @@ | |||
taptimeisshow() { | |||
this.timeshow = true; | |||
}, | |||
//选择标签 | |||
selectCallback2(e) { | |||
this.orderBy = e[0].value; | |||
this.sortText = e[0].label | |||
this.steyStatus = e[0].label; | |||
this.nextPage = 1; | |||
this.recordList = []; | |||
this.isRefresh = false; | |||
this.isRefresh = false; | |||
this.getMyCustom(); | |||
}, | |||
// 选择违禁标识 | |||
selectIdent(e) { | |||
this.violatedStatus = e[0].value | |||
this.weijinTag = e[0].label | |||
this.nextPage = 1; | |||
this.recordList = []; | |||
this.isRefresh = false; | |||
this.getMyCustom(); | |||
}, | |||
//时间选择 | |||
tabtimetap(index, text) { | |||
if (text) this.timeText = text | |||
tabtimetap(index, title) { | |||
this.timeshow = false; | |||
if (index == 4) { | |||
this.totalTimeShow = true; | |||
} else { | |||
this.timeText = title | |||
this.activeTotal = index; | |||
this.staTime = ''; | |||
this.endtime = ''; | |||
this.nextPage = 1; | |||
this.recordList = []; | |||
this.isRefresh = false; | |||
this.isRefresh = false; | |||
this.getMyCustom(); | |||
} | |||
}, | |||
@@ -212,14 +282,16 @@ | |||
totalTimeChange(e) { | |||
this.staTime = e.startDate; | |||
this.endtime = e.endDate; | |||
this.timeText = `${e.startDate}-${e.endDate}` | |||
this.activeTotal = 4; | |||
this.nextPage = 1; | |||
this.recordList = []; | |||
this.timeText = `${e.startDate}-${e.endDate}` | |||
this.isRefresh = false; | |||
this.isRefresh = false; | |||
this.getMyCustom(); | |||
}, | |||
tapThevisiting(item) { | |||
// 跳转违禁详情 | |||
tapThevisiting(item, index) { | |||
if (item.status == 0) { | |||
uni.showToast({ | |||
icon: "none", | |||
@@ -234,37 +306,56 @@ | |||
customerId: item.id, | |||
} | |||
} | |||
var item = { | |||
bg: 0, | |||
customerId: item.id, | |||
} | |||
uni.setStorageSync("searchobj", item); //写入缓存 | |||
this.$u.post("/corpus/findByPage", parames).then(res => { | |||
if (res == null) { | |||
uni.showToast({ | |||
icon: "none", | |||
title: "暂无音频" | |||
}) | |||
return | |||
} else { | |||
let newobj = res[0]; | |||
if (res[0].merge == 0) { | |||
uni.navigateTo({ | |||
url: `/pages/mine/details2?customerId=${newobj.customerId}&status=${newobj.status}&stateisshow=${"2"}` | |||
this.$u.post("/customer/prohibitedMatch", { | |||
customerId: item.id | |||
}).then(res => { | |||
let newweijin = res[0]; | |||
newweijin.transferContent = JSON.parse(newweijin.transferContent) | |||
var item = { | |||
bg: newweijin.transferContent.bg, | |||
customerId: newweijin.corpusId, | |||
} | |||
uni.setStorageSync("searchobj", item); //写入缓存 | |||
this.$u.post("/corpus/findByPage", parames).then(res => { | |||
if (res == null) { | |||
uni.showToast({ | |||
icon: "none", | |||
title: "暂无音频" | |||
}) | |||
return | |||
} else { | |||
let newobj = res[0]; | |||
let obj = { | |||
pageSize: index+1, | |||
num: this.totalRecords, | |||
query: { | |||
...this.nextPageObj | |||
} | |||
} | |||
uni.setStorageSync('nextPageObj', JSON.stringify(obj)) | |||
uni.navigateTo({ | |||
url: `/pages/mine/details?customerId=${newobj.customerId}&status=${newobj.status}&stateisshow=${"1"}` | |||
url: `/pages/center/prohibited/details?customerId=${newobj.customerId}&status=${newobj.status}&stateisshow=${"2"}&index=${index}&isMerge=${res[0].merge}` | |||
}) | |||
// if (res[0].merge == 0) { | |||
// } | |||
// else { | |||
// uni.navigateTo({ | |||
// url: `/pages/mine/details?customerId=${newobj.customerId}&status=${newobj.status}&stateisshow=${"2"}` | |||
// }) | |||
// } | |||
} | |||
} | |||
}) | |||
}) | |||
} | |||
}, | |||
// 获取围巾列表 | |||
getMyCustom() { | |||
let dateType = 0; | |||
let orderBy = 0; | |||
if (this.activeTotal == 5) { | |||
dateType = null; | |||
} else if (this.activeTotal == 4) { | |||
@@ -273,22 +364,18 @@ | |||
dateType = this.activeTotal; | |||
} | |||
if (this.orderBy == 0) { | |||
orderBy = null; | |||
} else { | |||
orderBy = this.orderBy; | |||
} | |||
var parames = { | |||
pageNum: this.nextPage, | |||
pageSize: 10, | |||
query: { | |||
projectId: this.buildingID, | |||
time: 1, | |||
staDate: this.staTime, | |||
endDate: this.endtime, | |||
staTime: this.staTime, | |||
endtime: this.endtime, | |||
taboo: 1, | |||
dateType: dateType, | |||
orderBy: orderBy | |||
disposeStatus: this.orderBy, // 处理状态 | |||
violatedStatus: this.violatedStatus, // 违禁状态 | |||
} | |||
}; | |||
if (this.screen.agentId) { | |||
@@ -297,52 +384,100 @@ | |||
this.$u.post("/customer/findbypage", parames).then(data => { | |||
var list = data.results || []; | |||
// this.recordList = [...this.recordList, ...list]; | |||
if(this.isRefresh){ | |||
if (this.isRefresh) { | |||
this.recordList = list; | |||
}else{ | |||
} else { | |||
this.recordList = [...this.recordList, ...list]; | |||
} | |||
this.totalRecord = data.totalPage; | |||
this.totalRecords = data.totalRecord; | |||
this.nextPageObj = parames.query | |||
}) | |||
}, | |||
//获取顾问列表 | |||
getFreeList() { | |||
this.$u.get("/zkAgentPool/freeList?itemId=" + this.buildingID).then(res => { | |||
this.$u.post("/cusLvStatistics/selectAllAccountIdByHouseId", { | |||
houseId: this.buildingID | |||
}).then(res => { | |||
this.freeList = res; | |||
this.freeList.forEach(item => { | |||
item.label = item.name; | |||
item.value = item.agentId | |||
item.value = item.accountId | |||
}) | |||
this.freeList.unshift({ | |||
label: '全部', | |||
value: null, | |||
}) | |||
}) | |||
}, | |||
//顾问确认 | |||
actionSelectCallback(e) { | |||
this.screen.agentId = e[0].value; | |||
this.adviserText = e[0].label | |||
this.guwenText = e[0].label; | |||
this.recordList = []; | |||
this.nextPage = 1; | |||
this.selectshow = false; | |||
this.isRefresh = false; | |||
this.isRefresh = false; | |||
this.getMyCustom(); | |||
}, | |||
}, | |||
}, | |||
filters: { | |||
// violatedStatus | |||
ViolatedStatus(status) { | |||
let str = ''; | |||
switch (status) { | |||
case 0: | |||
str = '有效违禁' | |||
break; | |||
case 1: | |||
str = '有效违禁' | |||
break; | |||
case 2: | |||
str = '无效违禁' | |||
break; | |||
} | |||
return str | |||
}, | |||
// DisposeStatus | |||
DisposeStatus(status) { | |||
let str = ''; | |||
switch (status) { | |||
case 0: | |||
str = '待处理' | |||
break; | |||
case 1: | |||
str = '已处理' | |||
break; | |||
} | |||
return str | |||
}, | |||
} | |||
} | |||
</script> | |||
<style lang="scss" scoped> | |||
.box { | |||
width: 100%; | |||
height: 100%; | |||
width: 100vw; | |||
min-height: calc(100vh - var(--window-top)); | |||
background: #F8F8F8; | |||
} | |||
.count { | |||
width: 100%; | |||
height: 90rpx; | |||
display: flex; | |||
align-items: center; | |||
justify-content: center; | |||
background-color: #FBE4E4; | |||
text { | |||
color: #F71616; | |||
} | |||
} | |||
.timeview { | |||
height: 80rpx; | |||
line-height: 80rpx; | |||
@@ -355,6 +490,7 @@ | |||
.boxtittab { | |||
position: sticky; | |||
top: var(--window-top); | |||
z-index: 100; | |||
width: 100; | |||
height: 92rpx; | |||
background: #FFFFFF; | |||
@@ -370,13 +506,11 @@ | |||
color: #666666; | |||
font-size: 28rpx; | |||
overflow: hidden; | |||
/* 超出一行文字自动隐藏 */ | |||
text-overflow: ellipsis; | |||
display: -webkit-box; | |||
/* 将对象作为弹性伸缩盒子模型显示 */ | |||
-webkit-line-clamp: 1; | |||
/* 控制最多显示几行 */ | |||
-webkit-box-orient: vertical; | |||
/* 设置或检索伸缩盒对象的子元素的排列方式 */ | |||
/*文字隐藏后添加省略号*/ | |||
white-space: nowrap; | |||
/*强制不换行*/ | |||
} | |||
} | |||
@@ -428,37 +562,25 @@ | |||
} | |||
} | |||
.count { | |||
width: 100%; | |||
height: 90rpx; | |||
display: flex; | |||
align-items: center; | |||
justify-content: center; | |||
background-color: #FBE4E4; | |||
text { | |||
color: #F71616; | |||
} | |||
} | |||
.content { | |||
.content-tips { | |||
margin: 0 0 20rpx 0; | |||
background: #fff; | |||
padding: 0 20rpx; | |||
box-sizing: border-box; | |||
overflow: hidden; | |||
margin-top: 20rpx; | |||
display: flex; | |||
flex-direction: column; | |||
.content-first { | |||
margin-top: 19rpx; | |||
padding: 20rpx 30rpx; | |||
display: flex; | |||
justify-content: space-between; | |||
background-color: #EEF4FD; | |||
.left { | |||
display: flex; | |||
.img { | |||
margin-right: 10rpx; | |||
width: 52rpx; | |||
height: 52rpx; | |||
background: #FFFFFF; | |||
@@ -507,51 +629,30 @@ | |||
} | |||
.content-sec { | |||
.content-last { | |||
padding: 24rpx 30rpx; | |||
font-size: 30rpx; | |||
font-weight: 400; | |||
color: #666666; | |||
display: flex; | |||
justify-content: space-between; | |||
margin-top: 19rpx; | |||
.left { | |||
.item { | |||
flex-shrink: 0; | |||
display: flex; | |||
align-items: center; | |||
.cus { | |||
font-size: 30rpx; | |||
font-weight: 400; | |||
color: #666666; | |||
// line-height: 30rpx; | |||
image { | |||
margin-right: 10rpx; | |||
width: 32rpx; | |||
height: 32rpx; | |||
} | |||
.arriveNum { | |||
font-size: 30rpx; | |||
font-weight: 400; | |||
// line-height: 30rpx; | |||
margin-left: 10rpx; | |||
text { | |||
font-size: 28rpx; | |||
} | |||
} | |||
.right { | |||
width: 120rpx; | |||
height: 46rpx; | |||
background: #F4F8FD; | |||
border-radius: 6rpx; | |||
text-align: center; | |||
line-height: 46rpx; | |||
font-weight: 400; | |||
color: #2671E2; | |||
} | |||
} | |||
.content-last { | |||
// margin: 30rpx 0; | |||
font-size: 30rpx; | |||
font-weight: 400; | |||
color: #666666; | |||
line-height: 30rpx; | |||
margin-top: 22rpx; | |||
margin-bottom: 30rpx; | |||
} | |||
} | |||
} | |||
@@ -1,20 +1,31 @@ | |||
<template> | |||
<view class="main"> | |||
<!-- <u-parse :content="content" /> --> | |||
<view class="tit">{{tit}}</view> | |||
<u-parse class="ql-editor" :content="content" @preview="preview" @navigate="navigate"/> | |||
<web-view v-if="webviewShow" :webview-styles="webviewStyles" :src="webviewUrl"></web-view> | |||
<!-- <view v-html="content"></view> --> | |||
<rich-text :nodes="content"></rich-text> | |||
<!-- <rich-text :nodes="content"></rich-text> --> | |||
</view> | |||
</template> | |||
<script> | |||
var util = require("../../utils/util.js"); | |||
var config = require("../../config"); | |||
import uParse from '../../components/gaoyia-parse/parse.vue' | |||
import uParse from '@/components/gaoyia-parse/parse.vue' | |||
export default { | |||
data() { | |||
return { | |||
tit:"", | |||
content:"", | |||
id:"" | |||
id:"", | |||
webviewShow:false, | |||
webviewUrl:"", | |||
webviewStyles: { | |||
progress: { | |||
color: '#FF3333' | |||
} | |||
} | |||
}; | |||
}, | |||
components: { | |||
@@ -24,14 +35,26 @@ | |||
this.id = e.id; | |||
let link=JSON.parse(decodeURIComponent(e.content)) | |||
this.content = link | |||
this.tit = e.tit | |||
this.read() | |||
}, | |||
methods:{ | |||
navigate(href, e) { | |||
if(href!=undefined && href!=""){ | |||
this.webviewShow = true; | |||
this.webviewUrl = href | |||
} | |||
console.log(href,111) | |||
//比如点击a标签,打开某个传输url | |||
uni.navigateTo({ | |||
url: href, | |||
}) | |||
}, | |||
read(){ | |||
uni.request({ | |||
url: config.service.updateRead, | |||
method: "GET", | |||
data:{id:this.id}, | |||
data:{id:this.id,accountId:uni.getStorageSync('weapp_session_userInfo_data').accountId}, | |||
header: { | |||
'content-type': 'application/json', | |||
'Authorization': 'Bearer '+uni.getStorageSync('weapp_session_login_data').token | |||
@@ -46,8 +69,61 @@ | |||
</script> | |||
<style lang="scss"> | |||
@import '../../static/css/quill/quill.core.css'; | |||
@import '../../static/css/quill/quill.snow.css'; | |||
@import '../../static/css/quill/quill.bubble.css'; | |||
.main{ | |||
padding: 20rpx; | |||
word-wrap: break-word; | |||
.tit{ | |||
font-size: 46rpx; | |||
font-weight: 800; | |||
text-align: center; | |||
margin-bottom: 16rpx; | |||
} | |||
} | |||
.ql-editor{ | |||
font-size: 32rpx; | |||
.strong { | |||
font-weight: bold; | |||
} | |||
.ol{ | |||
padding-left: 16rpx; | |||
.li{ | |||
font-size: 34rpx; | |||
&::before{ | |||
content: "·"; | |||
font-size: 34rpx; | |||
} | |||
} | |||
} | |||
.ql-indent-1{ | |||
text-indent: 10px; | |||
} | |||
.h1{ | |||
font-size: 5em; | |||
} | |||
.h2{ | |||
font-size: 4em; | |||
} | |||
.h3{ | |||
font-size: 3em; | |||
} | |||
.h4{ | |||
font-size: 2em; | |||
} | |||
.h4{ | |||
font-size: 1em; | |||
} | |||
.em{ | |||
font-style: italic | |||
} | |||
.u{ | |||
text-decoration:underline | |||
} | |||
.blockquote{ | |||
text-decoration: line-through; | |||
} | |||
} | |||
.ql-container { | |||
box-sizing: border-box; | |||
@@ -57,6 +133,10 @@ | |||
margin: 0px; | |||
position: relative; | |||
} | |||
.ql-editor h1 { | |||
font-size: 2em; | |||
} | |||
.ql-container.ql-disabled .ql-tooltip { | |||
visibility: hidden; | |||
} | |||
@@ -1,243 +1,299 @@ | |||
<template> | |||
<view class="message_list"> | |||
<u-tabs :list="list" :show-bar="false" :is-scroll="false" :current="current" @change="change"></u-tabs> | |||
<view class="listMain"> | |||
<view class="systemList" v-if="current==0"> | |||
<view class="sysItem"> | |||
<image class="headpic" src="../../static/images/function1.png"></image> | |||
<view class="right"> | |||
<view class="headInfo"> | |||
<view class="title">优秀案例</view> | |||
<view class="info">恭喜你,你的接待记录被设为了优秀案例!</view> | |||
</view> | |||
<view class="content"> | |||
我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充 | |||
</view> | |||
<view class="time"> | |||
2021-01-12 12:23:01 | |||
</view> | |||
</view> | |||
</view> | |||
<view class="sysItem"> | |||
<image class="headpic" src="../../static/images/function1.png"></image> | |||
<view class="right"> | |||
<view class="headInfo"> | |||
<view class="title">优秀案例</view> | |||
<view class="info">赞了你的接待</view> | |||
</view> | |||
<view class="content"> | |||
我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充 | |||
</view> | |||
<view class="time"> | |||
2021-01-12 12:23:01 | |||
</view> | |||
</view> | |||
</view> | |||
<view class="sysItem"> | |||
<image class="headpic" src="../../static/images/function1.png"></image> | |||
<view class="right"> | |||
<view class="headInfo"> | |||
<view class="title">优秀案例</view> | |||
<view class="info">评价你:非常好,品牌价值观还需要补充</view> | |||
</view> | |||
<view class="content"> | |||
我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充 | |||
</view> | |||
<view class="time"> | |||
2021-01-12 12:23:01 | |||
</view> | |||
</view> | |||
</view> | |||
<view class="sysItem"> | |||
<image class="headpic" src="../../static/images/function1.png"></image> | |||
<view class="right"> | |||
<view class="headInfo"> | |||
<view class="title">优秀案例</view> | |||
<view class="info">回复你:非常好,品牌价值观还需要补充</view> | |||
</view> | |||
<view class="content"> | |||
我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充 | |||
</view> | |||
<view class="time"> | |||
2021-01-12 12:23:01 | |||
</view> | |||
</view> | |||
</view> | |||
<view class="sysItem"> | |||
<image class="headpic" src="../../static/images/function1.png"></image> | |||
<view class="right"> | |||
<view class="headInfo"> | |||
<view class="title">优秀案例</view> | |||
<view class="info">赞了你的接待</view> | |||
</view> | |||
<view class="content"> | |||
我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充 | |||
</view> | |||
<view class="time"> | |||
2021-01-12 12:23:01 | |||
</view> | |||
</view> | |||
</view> | |||
<view class="sysItem"> | |||
<image class="headpic" src="../../static/images/function1.png"></image> | |||
<view class="right"> | |||
<view class="headInfo"> | |||
<view class="title">优秀案例</view> | |||
<view class="info">评价你:非常好,品牌价值观还需要补充</view> | |||
</view> | |||
<view class="content"> | |||
我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充 | |||
</view> | |||
<view class="time"> | |||
2021-01-12 12:23:01 | |||
</view> | |||
</view> | |||
</view> | |||
</view> | |||
<view class="upgradeList" v-if="current==1"> | |||
<block v-for="(item,index) in updateAnnList" :key="index"> | |||
<view class="upgradeItem" @click="goDetail(item.content,item.id)"> | |||
<view class="notRead"> | |||
<view v-if="item.readFlag==0" class="red"></view> | |||
</view> | |||
<view class="right"> | |||
<view class="title">{{item.title}}</view> | |||
<view class="time">{{item.createTime}}</view> | |||
</view> | |||
</view> | |||
</block> | |||
</view> | |||
</view> | |||
<!-- <u-tabs :list="list" :show-bar="false" :is-scroll="false" :current="current" @change="change"></u-tabs> --> | |||
<view class="listMain"> | |||
<view class="upgradeList"> | |||
<scroll-view :scroll-top="scrollTop" refresher-enabled="true" :refresher-triggered="triggered" | |||
@refresherpulling="onPulling" @refresherrefresh="onRefresh" @refresherrestore="onRestore" | |||
:scroll-y="true" class="scroll-Y" @scrolltolower="lower"> | |||
<block v-if="updateAnnList.length!=0"> | |||
<block v-for="(item,index) in updateAnnList" :key="index"> | |||
<view class="upgradeItem" @click="goDetail(item.content,item.id,item.title)"> | |||
<view class="notRead"> | |||
<view v-if="item.readFlag==0" class="red"></view> | |||
</view> | |||
<view class="right"> | |||
<view class="title">{{item.title}}</view> | |||
<view class="time">{{item.createTime}}</view> | |||
</view> | |||
</view> | |||
</block> | |||
</block> | |||
<block v-else> | |||
<view style=" padding: 100rpx 0;"> | |||
<u-empty text="暂无数据" mode="list"></u-empty> | |||
</view> | |||
</block> | |||
</scroll-view> | |||
</view> | |||
<!-- <view class="systemList" v-if="current==0"> | |||
<block v-if="sysItemList.length!=0"> | |||
<block v-for="(item,index) in sysItemList" :key="index"> | |||
<view class="sysItem"> | |||
<image class="headpic" src="../../static/images/function1.png"></image> | |||
<view class="right"> | |||
<view class="headInfo"> | |||
<view class="title">优秀案例</view> | |||
<view class="info">评价你:非常好,品牌价值观还需要补充</view> | |||
</view> | |||
<view class="content"> | |||
我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充我的评论:非常好,品牌价值观还需要补充 | |||
</view> | |||
<view class="time"> | |||
2021-01-12 12:23:01 | |||
</view> | |||
</view> | |||
</view> | |||
</block> | |||
</block> | |||
<block v-else> | |||
<view style=" padding: 100rpx 0;"> | |||
<u-empty text="暂无数据" mode="list"></u-empty> | |||
</view> | |||
</block> | |||
</view> | |||
<view class="upgradeList" v-if="current==1"> | |||
<block v-if="updateAnnList.length!=0"> | |||
<block v-for="(item,index) in updateAnnList" :key="index"> | |||
<view class="upgradeItem" @click="goDetail(item.content,item.id)"> | |||
<view class="notRead"> | |||
<view v-if="item.readFlag==0" class="red"></view> | |||
</view> | |||
<view class="right"> | |||
<view class="title">{{item.title}}</view> | |||
<view class="time">{{item.createTime}}</view> | |||
</view> | |||
</view> | |||
</block> | |||
</block> | |||
<block v-else> | |||
<view style=" padding: 100rpx 0;"> | |||
<u-empty text="暂无数据" mode="list"></u-empty> | |||
</view> | |||
</block> | |||
</view> | |||
--> | |||
</view> | |||
</view> | |||
</template> | |||
<script> | |||
var util = require("../../utils/util.js"); | |||
<script> | |||
var util = require("../../utils/util.js"); | |||
var config = require("../../config"); | |||
export default { | |||
data() { | |||
return { | |||
updateAnnList:[], | |||
return { | |||
triggered: true, | |||
scrollTop: 0, | |||
old: { | |||
scrollTop: 0 | |||
}, | |||
updateAnnList: [], | |||
sysItemList: [], | |||
list: [{ | |||
name: '系统消息' | |||
},{ | |||
name: `升级公告`, | |||
count:"", | |||
}, { | |||
name: `升级公告`, | |||
count: "", | |||
}], | |||
current: 0 | |||
current: 0, | |||
pageNum: 1, | |||
pageSize: 10, | |||
}; | |||
}, | |||
onShow() { | |||
this.updateInit() | |||
}, | |||
methods:{ | |||
change(index) { | |||
this.current = index; | |||
if(this.current==1){ | |||
this.updateInit() | |||
} | |||
}, | |||
updateInit(){ | |||
uni.request({ | |||
url: config.service.updateList, | |||
method: "GET", | |||
header: { | |||
'content-type': 'application/json', | |||
'Authorization': 'Bearer '+uni.getStorageSync('weapp_session_login_data').token | |||
}, | |||
success: (res) => { | |||
this.updateAnnList = res.data.data.list | |||
this.list[1].count = res.data.data.count | |||
} | |||
}) | |||
}, | |||
goDetail(text,id){ | |||
let link=encodeURIComponent(JSON.stringify(text)) | |||
uni.navigateTo({ | |||
url:"./messageDetail?content="+link+"&id="+id | |||
}) | |||
}, | |||
}, | |||
onShow() { | |||
this.updateAnnList = [] | |||
this.pageNum = 1 | |||
this.updateInit() | |||
}, | |||
onLoad() { | |||
this._freshing = false; | |||
setTimeout(() => { | |||
this.triggered = true; | |||
}, 1000) | |||
}, | |||
onPullDownRefresh() { | |||
this.updateInit() | |||
setTimeout(function() { | |||
uni.stopPullDownRefresh(); | |||
}, 1000); | |||
}, | |||
// onReachBottom(){ | |||
// this.pageNum++ | |||
// this.updateInit() | |||
// }, | |||
methods: { | |||
onPulling(e) { | |||
console.log("onpulling", e); | |||
}, | |||
onRefresh() { | |||
if (this._freshing) return; | |||
this.updateInit() | |||
this._freshing = true; | |||
setTimeout(() => { | |||
this.triggered = false; | |||
this._freshing = false; | |||
}, 3000) | |||
}, | |||
onRestore() { | |||
this.triggered = 'restore'; // 需要重置 | |||
console.log("onRestore"); | |||
}, | |||
// uppers(e) { | |||
// this.pageNum = 1 | |||
// this.updateInit() | |||
// }, | |||
lower(e) { | |||
this.pageNum++ | |||
this.updateInit() | |||
}, | |||
updateInit() { | |||
uni.request({ | |||
url: config.service.updateList, | |||
method: "GET", | |||
data: { | |||
id: uni.getStorageSync('weapp_session_userInfo_data').accountId, | |||
num: this.pageNum, | |||
size: this.pageSize | |||
}, | |||
header: { | |||
'content-type': 'application/json', | |||
'Authorization': 'Bearer ' + uni.getStorageSync('weapp_session_login_data').token | |||
}, | |||
success: (res) => { | |||
// this.updateAnnList = res.data.data.list.results | |||
if (res.data.data != null) { | |||
this.list[1].count = res.data.data.count | |||
} | |||
if (res.data.data == null) { | |||
console.log(11) | |||
uni.showToast({ | |||
title: '已经到底了!', | |||
duration: 2000 | |||
}); | |||
} else { | |||
if (this.pageNum != 1) { | |||
this.updateAnnList = [...this.updateAnnList, ...res.data.data.list.records]; | |||
} else { | |||
this.updateAnnList = res.data.data.list.records | |||
} | |||
} | |||
} | |||
}) | |||
}, | |||
goDetail(text, id, title) { | |||
let link = encodeURIComponent(JSON.stringify(text)) | |||
uni.navigateTo({ | |||
url: "./messageDetail?content=" + link + "&id=" + id + "&tit=" + title | |||
}) | |||
}, | |||
change(index) { | |||
this.current = index; | |||
if (this.current == 1) { | |||
this.updateInit() | |||
} | |||
} | |||
} | |||
} | |||
</script> | |||
<style lang="scss"> | |||
.message_list{ | |||
.u-tab-item{ | |||
border: 0.5rpx solid #dedede; | |||
} | |||
.listMain{ | |||
margin-top: 20rpx; | |||
.systemList{ | |||
.sysItem{ | |||
padding: 20rpx; | |||
border: 1rpx solid #ccc; | |||
display: flex; | |||
margin: 16rpx 0; | |||
.headpic{ | |||
width: 70rpx; | |||
height: 70rpx; | |||
border-radius: 100%; | |||
margin-right: 30rpx; | |||
} | |||
.right{ | |||
.headInfo{ | |||
.title{ | |||
font-size: 32rpx; | |||
font-weight: bold; | |||
margin-bottom: 8rpx; | |||
} | |||
} | |||
.content{ | |||
width: 600rpx; | |||
background: #e6e6e6; | |||
padding: 10rpx; | |||
margin: 14rpx 0; | |||
overflow: hidden; | |||
text-overflow: ellipsis; | |||
white-space: nowrap; | |||
} | |||
.time{ | |||
color: #6f6f6f; | |||
font-size: 24rpx; | |||
} | |||
} | |||
} | |||
} | |||
.upgradeList{ | |||
.upgradeItem{ | |||
padding: 20rpx; | |||
border: 1rpx solid #ccc; | |||
margin: 16rpx 0; | |||
display: flex; | |||
.notRead{ | |||
width: 14rpx; | |||
height: 14rpx; | |||
margin-right: 20rpx; | |||
margin-top: 16rpx; | |||
.red{ | |||
background: #FF0000; | |||
width: 100%; | |||
height: 100%; | |||
border-radius: 100%; | |||
} | |||
} | |||
.right{ | |||
.title{ | |||
font-size: 32rpx; | |||
font-weight: bold; | |||
margin-bottom: 8rpx; | |||
} | |||
.time{ | |||
color: #6f6f6f; | |||
font-size: 24rpx; | |||
} | |||
} | |||
} | |||
} | |||
} | |||
<style lang="scss"> | |||
.scroll-Y { | |||
height: 100%; | |||
width: 100%; | |||
position: fixed; | |||
} | |||
.message_list { | |||
.u-tab-item { | |||
border: 0.5rpx solid #dedede; | |||
} | |||
.listMain { | |||
margin-top: 20rpx; | |||
.systemList { | |||
.sysItem { | |||
padding: 20rpx; | |||
border: 1rpx solid #ccc; | |||
display: flex; | |||
margin: 16rpx 0; | |||
.headpic { | |||
width: 70rpx; | |||
height: 70rpx; | |||
border-radius: 100%; | |||
margin-right: 30rpx; | |||
} | |||
.right { | |||
.headInfo { | |||
.title { | |||
font-size: 32rpx; | |||
font-weight: bold; | |||
margin-bottom: 8rpx; | |||
} | |||
} | |||
.content { | |||
width: 600rpx; | |||
background: #e6e6e6; | |||
padding: 10rpx; | |||
margin: 14rpx 0; | |||
overflow: hidden; | |||
text-overflow: ellipsis; | |||
white-space: nowrap; | |||
} | |||
.time { | |||
color: #6f6f6f; | |||
font-size: 24rpx; | |||
} | |||
} | |||
} | |||
} | |||
.upgradeList { | |||
.upgradeItem { | |||
padding: 20rpx; | |||
border: 1rpx solid #ccc; | |||
margin: 16rpx 0; | |||
display: flex; | |||
.notRead { | |||
width: 14rpx; | |||
height: 14rpx; | |||
margin-right: 20rpx; | |||
margin-top: 16rpx; | |||
.red { | |||
background: #FF0000; | |||
width: 100%; | |||
height: 100%; | |||
border-radius: 100%; | |||
} | |||
} | |||
.right { | |||
.title { | |||
font-size: 32rpx; | |||
font-weight: bold; | |||
margin-bottom: 8rpx; | |||
} | |||
.time { | |||
color: #6f6f6f; | |||
font-size: 24rpx; | |||
} | |||
} | |||
} | |||
} | |||
} | |||
} | |||
</style> |
@@ -0,0 +1,952 @@ | |||
/*! | |||
* Quill Editor v1.3.7 | |||
* https://quilljs.com/ | |||
* Copyright (c) 2014, Jason Chen | |||
* Copyright (c) 2013, salesforce.com | |||
*/ | |||
.ql-container { | |||
box-sizing: border-box; | |||
font-family: Helvetica, Arial, sans-serif; | |||
font-size: 13px; | |||
height: 100%; | |||
margin: 0px; | |||
position: relative; | |||
} | |||
.ql-container.ql-disabled .ql-tooltip { | |||
visibility: hidden; | |||
} | |||
.ql-container.ql-disabled .ql-editor ul[data-checked] > li::before { | |||
pointer-events: none; | |||
} | |||
.ql-clipboard { | |||
left: -100000px; | |||
height: 1px; | |||
overflow-y: hidden; | |||
position: absolute; | |||
top: 50%; | |||
} | |||
.ql-clipboard p { | |||
margin: 0; | |||
padding: 0; | |||
} | |||
.ql-editor { | |||
box-sizing: border-box; | |||
line-height: 1.42; | |||
height: 100%; | |||
outline: none; | |||
overflow-y: auto; | |||
padding: 12px 15px; | |||
tab-size: 4; | |||
-moz-tab-size: 4; | |||
text-align: left; | |||
white-space: pre-wrap; | |||
word-wrap: break-word; | |||
} | |||
.ql-editor > * { | |||
cursor: text; | |||
} | |||
.ql-editor p, | |||
.ql-editor ol, | |||
.ql-editor ul, | |||
.ql-editor pre, | |||
.ql-editor blockquote, | |||
.ql-editor h1, | |||
.ql-editor h2, | |||
.ql-editor h3, | |||
.ql-editor h4, | |||
.ql-editor h5, | |||
.ql-editor h6 { | |||
margin: 0; | |||
padding: 0; | |||
counter-reset: list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol, | |||
.ql-editor ul { | |||
padding-left: 1.5em; | |||
} | |||
.ql-editor ol > li, | |||
.ql-editor ul > li { | |||
list-style-type: none; | |||
} | |||
.ql-editor ul > li::before { | |||
content: '\2022'; | |||
} | |||
.ql-editor ul[data-checked=true], | |||
.ql-editor ul[data-checked=false] { | |||
pointer-events: none; | |||
} | |||
.ql-editor ul[data-checked=true] > li *, | |||
.ql-editor ul[data-checked=false] > li * { | |||
pointer-events: all; | |||
} | |||
.ql-editor ul[data-checked=true] > li::before, | |||
.ql-editor ul[data-checked=false] > li::before { | |||
color: #777; | |||
cursor: pointer; | |||
pointer-events: all; | |||
} | |||
.ql-editor ul[data-checked=true] > li::before { | |||
content: '\2611'; | |||
} | |||
.ql-editor ul[data-checked=false] > li::before { | |||
content: '\2610'; | |||
} | |||
.ql-editor li::before { | |||
display: inline-block; | |||
white-space: nowrap; | |||
width: 1.2em; | |||
} | |||
.ql-editor li:not(.ql-direction-rtl)::before { | |||
margin-left: -1.5em; | |||
margin-right: 0.3em; | |||
text-align: right; | |||
} | |||
.ql-editor li.ql-direction-rtl::before { | |||
margin-left: 0.3em; | |||
margin-right: -1.5em; | |||
} | |||
.ql-editor ol li:not(.ql-direction-rtl), | |||
.ql-editor ul li:not(.ql-direction-rtl) { | |||
padding-left: 1.5em; | |||
} | |||
.ql-editor ol li.ql-direction-rtl, | |||
.ql-editor ul li.ql-direction-rtl { | |||
padding-right: 1.5em; | |||
} | |||
.ql-editor ol li { | |||
counter-reset: list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
counter-increment: list-0; | |||
} | |||
.ql-editor ol li:before { | |||
content: counter(list-0, decimal) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-1 { | |||
counter-increment: list-1; | |||
} | |||
.ql-editor ol li.ql-indent-1:before { | |||
content: counter(list-1, lower-alpha) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-1 { | |||
counter-reset: list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-2 { | |||
counter-increment: list-2; | |||
} | |||
.ql-editor ol li.ql-indent-2:before { | |||
content: counter(list-2, lower-roman) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-2 { | |||
counter-reset: list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-3 { | |||
counter-increment: list-3; | |||
} | |||
.ql-editor ol li.ql-indent-3:before { | |||
content: counter(list-3, decimal) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-3 { | |||
counter-reset: list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-4 { | |||
counter-increment: list-4; | |||
} | |||
.ql-editor ol li.ql-indent-4:before { | |||
content: counter(list-4, lower-alpha) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-4 { | |||
counter-reset: list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-5 { | |||
counter-increment: list-5; | |||
} | |||
.ql-editor ol li.ql-indent-5:before { | |||
content: counter(list-5, lower-roman) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-5 { | |||
counter-reset: list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-6 { | |||
counter-increment: list-6; | |||
} | |||
.ql-editor ol li.ql-indent-6:before { | |||
content: counter(list-6, decimal) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-6 { | |||
counter-reset: list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-7 { | |||
counter-increment: list-7; | |||
} | |||
.ql-editor ol li.ql-indent-7:before { | |||
content: counter(list-7, lower-alpha) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-7 { | |||
counter-reset: list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-8 { | |||
counter-increment: list-8; | |||
} | |||
.ql-editor ol li.ql-indent-8:before { | |||
content: counter(list-8, lower-roman) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-8 { | |||
counter-reset: list-9; | |||
} | |||
.ql-editor ol li.ql-indent-9 { | |||
counter-increment: list-9; | |||
} | |||
.ql-editor ol li.ql-indent-9:before { | |||
content: counter(list-9, decimal) '. '; | |||
} | |||
.ql-editor .ql-indent-1:not(.ql-direction-rtl) { | |||
padding-left: 3em; | |||
} | |||
.ql-editor li.ql-indent-1:not(.ql-direction-rtl) { | |||
padding-left: 4.5em; | |||
} | |||
.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right { | |||
padding-right: 3em; | |||
} | |||
.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right { | |||
padding-right: 4.5em; | |||
} | |||
.ql-editor .ql-indent-2:not(.ql-direction-rtl) { | |||
padding-left: 6em; | |||
} | |||
.ql-editor li.ql-indent-2:not(.ql-direction-rtl) { | |||
padding-left: 7.5em; | |||
} | |||
.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right { | |||
padding-right: 6em; | |||
} | |||
.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right { | |||
padding-right: 7.5em; | |||
} | |||
.ql-editor .ql-indent-3:not(.ql-direction-rtl) { | |||
padding-left: 9em; | |||
} | |||
.ql-editor li.ql-indent-3:not(.ql-direction-rtl) { | |||
padding-left: 10.5em; | |||
} | |||
.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right { | |||
padding-right: 9em; | |||
} | |||
.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right { | |||
padding-right: 10.5em; | |||
} | |||
.ql-editor .ql-indent-4:not(.ql-direction-rtl) { | |||
padding-left: 12em; | |||
} | |||
.ql-editor li.ql-indent-4:not(.ql-direction-rtl) { | |||
padding-left: 13.5em; | |||
} | |||
.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right { | |||
padding-right: 12em; | |||
} | |||
.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right { | |||
padding-right: 13.5em; | |||
} | |||
.ql-editor .ql-indent-5:not(.ql-direction-rtl) { | |||
padding-left: 15em; | |||
} | |||
.ql-editor li.ql-indent-5:not(.ql-direction-rtl) { | |||
padding-left: 16.5em; | |||
} | |||
.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right { | |||
padding-right: 15em; | |||
} | |||
.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right { | |||
padding-right: 16.5em; | |||
} | |||
.ql-editor .ql-indent-6:not(.ql-direction-rtl) { | |||
padding-left: 18em; | |||
} | |||
.ql-editor li.ql-indent-6:not(.ql-direction-rtl) { | |||
padding-left: 19.5em; | |||
} | |||
.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right { | |||
padding-right: 18em; | |||
} | |||
.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right { | |||
padding-right: 19.5em; | |||
} | |||
.ql-editor .ql-indent-7:not(.ql-direction-rtl) { | |||
padding-left: 21em; | |||
} | |||
.ql-editor li.ql-indent-7:not(.ql-direction-rtl) { | |||
padding-left: 22.5em; | |||
} | |||
.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right { | |||
padding-right: 21em; | |||
} | |||
.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right { | |||
padding-right: 22.5em; | |||
} | |||
.ql-editor .ql-indent-8:not(.ql-direction-rtl) { | |||
padding-left: 24em; | |||
} | |||
.ql-editor li.ql-indent-8:not(.ql-direction-rtl) { | |||
padding-left: 25.5em; | |||
} | |||
.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right { | |||
padding-right: 24em; | |||
} | |||
.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right { | |||
padding-right: 25.5em; | |||
} | |||
.ql-editor .ql-indent-9:not(.ql-direction-rtl) { | |||
padding-left: 27em; | |||
} | |||
.ql-editor li.ql-indent-9:not(.ql-direction-rtl) { | |||
padding-left: 28.5em; | |||
} | |||
.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right { | |||
padding-right: 27em; | |||
} | |||
.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right { | |||
padding-right: 28.5em; | |||
} | |||
.ql-editor .ql-video { | |||
display: block; | |||
max-width: 100%; | |||
} | |||
.ql-editor .ql-video.ql-align-center { | |||
margin: 0 auto; | |||
} | |||
.ql-editor .ql-video.ql-align-right { | |||
margin: 0 0 0 auto; | |||
} | |||
.ql-editor .ql-bg-black { | |||
background-color: #000; | |||
} | |||
.ql-editor .ql-bg-red { | |||
background-color: #e60000; | |||
} | |||
.ql-editor .ql-bg-orange { | |||
background-color: #f90; | |||
} | |||
.ql-editor .ql-bg-yellow { | |||
background-color: #ff0; | |||
} | |||
.ql-editor .ql-bg-green { | |||
background-color: #008a00; | |||
} | |||
.ql-editor .ql-bg-blue { | |||
background-color: #06c; | |||
} | |||
.ql-editor .ql-bg-purple { | |||
background-color: #93f; | |||
} | |||
.ql-editor .ql-color-white { | |||
color: #fff; | |||
} | |||
.ql-editor .ql-color-red { | |||
color: #e60000; | |||
} | |||
.ql-editor .ql-color-orange { | |||
color: #f90; | |||
} | |||
.ql-editor .ql-color-yellow { | |||
color: #ff0; | |||
} | |||
.ql-editor .ql-color-green { | |||
color: #008a00; | |||
} | |||
.ql-editor .ql-color-blue { | |||
color: #06c; | |||
} | |||
.ql-editor .ql-color-purple { | |||
color: #93f; | |||
} | |||
.ql-editor .ql-font-serif { | |||
font-family: Georgia, Times New Roman, serif; | |||
} | |||
.ql-editor .ql-font-monospace { | |||
font-family: Monaco, Courier New, monospace; | |||
} | |||
.ql-editor .ql-size-small { | |||
font-size: 0.75em; | |||
} | |||
.ql-editor .ql-size-large { | |||
font-size: 1.5em; | |||
} | |||
.ql-editor .ql-size-huge { | |||
font-size: 2.5em; | |||
} | |||
.ql-editor .ql-direction-rtl { | |||
direction: rtl; | |||
text-align: inherit; | |||
} | |||
.ql-editor .ql-align-center { | |||
text-align: center; | |||
} | |||
.ql-editor .ql-align-justify { | |||
text-align: justify; | |||
} | |||
.ql-editor .ql-align-right { | |||
text-align: right; | |||
} | |||
.ql-editor.ql-blank::before { | |||
color: rgba(0,0,0,0.6); | |||
content: attr(data-placeholder); | |||
font-style: italic; | |||
left: 15px; | |||
pointer-events: none; | |||
position: absolute; | |||
right: 15px; | |||
} | |||
.ql-bubble.ql-toolbar:after, | |||
.ql-bubble .ql-toolbar:after { | |||
clear: both; | |||
content: ''; | |||
display: table; | |||
} | |||
.ql-bubble.ql-toolbar button, | |||
.ql-bubble .ql-toolbar button { | |||
background: none; | |||
border: none; | |||
cursor: pointer; | |||
display: inline-block; | |||
float: left; | |||
height: 24px; | |||
padding: 3px 5px; | |||
width: 28px; | |||
} | |||
.ql-bubble.ql-toolbar button svg, | |||
.ql-bubble .ql-toolbar button svg { | |||
float: left; | |||
height: 100%; | |||
} | |||
.ql-bubble.ql-toolbar button:active:hover, | |||
.ql-bubble .ql-toolbar button:active:hover { | |||
outline: none; | |||
} | |||
.ql-bubble.ql-toolbar input.ql-image[type=file], | |||
.ql-bubble .ql-toolbar input.ql-image[type=file] { | |||
display: none; | |||
} | |||
.ql-bubble.ql-toolbar button:hover, | |||
.ql-bubble .ql-toolbar button:hover, | |||
.ql-bubble.ql-toolbar button:focus, | |||
.ql-bubble .ql-toolbar button:focus, | |||
.ql-bubble.ql-toolbar button.ql-active, | |||
.ql-bubble .ql-toolbar button.ql-active, | |||
.ql-bubble.ql-toolbar .ql-picker-label:hover, | |||
.ql-bubble .ql-toolbar .ql-picker-label:hover, | |||
.ql-bubble.ql-toolbar .ql-picker-label.ql-active, | |||
.ql-bubble .ql-toolbar .ql-picker-label.ql-active, | |||
.ql-bubble.ql-toolbar .ql-picker-item:hover, | |||
.ql-bubble .ql-toolbar .ql-picker-item:hover, | |||
.ql-bubble.ql-toolbar .ql-picker-item.ql-selected, | |||
.ql-bubble .ql-toolbar .ql-picker-item.ql-selected { | |||
color: #fff; | |||
} | |||
.ql-bubble.ql-toolbar button:hover .ql-fill, | |||
.ql-bubble .ql-toolbar button:hover .ql-fill, | |||
.ql-bubble.ql-toolbar button:focus .ql-fill, | |||
.ql-bubble .ql-toolbar button:focus .ql-fill, | |||
.ql-bubble.ql-toolbar button.ql-active .ql-fill, | |||
.ql-bubble .ql-toolbar button.ql-active .ql-fill, | |||
.ql-bubble.ql-toolbar .ql-picker-label:hover .ql-fill, | |||
.ql-bubble .ql-toolbar .ql-picker-label:hover .ql-fill, | |||
.ql-bubble.ql-toolbar .ql-picker-label.ql-active .ql-fill, | |||
.ql-bubble .ql-toolbar .ql-picker-label.ql-active .ql-fill, | |||
.ql-bubble.ql-toolbar .ql-picker-item:hover .ql-fill, | |||
.ql-bubble .ql-toolbar .ql-picker-item:hover .ql-fill, | |||
.ql-bubble.ql-toolbar .ql-picker-item.ql-selected .ql-fill, | |||
.ql-bubble .ql-toolbar .ql-picker-item.ql-selected .ql-fill, | |||
.ql-bubble.ql-toolbar button:hover .ql-stroke.ql-fill, | |||
.ql-bubble .ql-toolbar button:hover .ql-stroke.ql-fill, | |||
.ql-bubble.ql-toolbar button:focus .ql-stroke.ql-fill, | |||
.ql-bubble .ql-toolbar button:focus .ql-stroke.ql-fill, | |||
.ql-bubble.ql-toolbar button.ql-active .ql-stroke.ql-fill, | |||
.ql-bubble .ql-toolbar button.ql-active .ql-stroke.ql-fill, | |||
.ql-bubble.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill, | |||
.ql-bubble .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill, | |||
.ql-bubble.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill, | |||
.ql-bubble .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill, | |||
.ql-bubble.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill, | |||
.ql-bubble .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill, | |||
.ql-bubble.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill, | |||
.ql-bubble .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill { | |||
fill: #fff; | |||
} | |||
.ql-bubble.ql-toolbar button:hover .ql-stroke, | |||
.ql-bubble .ql-toolbar button:hover .ql-stroke, | |||
.ql-bubble.ql-toolbar button:focus .ql-stroke, | |||
.ql-bubble .ql-toolbar button:focus .ql-stroke, | |||
.ql-bubble.ql-toolbar button.ql-active .ql-stroke, | |||
.ql-bubble .ql-toolbar button.ql-active .ql-stroke, | |||
.ql-bubble.ql-toolbar .ql-picker-label:hover .ql-stroke, | |||
.ql-bubble .ql-toolbar .ql-picker-label:hover .ql-stroke, | |||
.ql-bubble.ql-toolbar .ql-picker-label.ql-active .ql-stroke, | |||
.ql-bubble .ql-toolbar .ql-picker-label.ql-active .ql-stroke, | |||
.ql-bubble.ql-toolbar .ql-picker-item:hover .ql-stroke, | |||
.ql-bubble .ql-toolbar .ql-picker-item:hover .ql-stroke, | |||
.ql-bubble.ql-toolbar .ql-picker-item.ql-selected .ql-stroke, | |||
.ql-bubble .ql-toolbar .ql-picker-item.ql-selected .ql-stroke, | |||
.ql-bubble.ql-toolbar button:hover .ql-stroke-miter, | |||
.ql-bubble .ql-toolbar button:hover .ql-stroke-miter, | |||
.ql-bubble.ql-toolbar button:focus .ql-stroke-miter, | |||
.ql-bubble .ql-toolbar button:focus .ql-stroke-miter, | |||
.ql-bubble.ql-toolbar button.ql-active .ql-stroke-miter, | |||
.ql-bubble .ql-toolbar button.ql-active .ql-stroke-miter, | |||
.ql-bubble.ql-toolbar .ql-picker-label:hover .ql-stroke-miter, | |||
.ql-bubble .ql-toolbar .ql-picker-label:hover .ql-stroke-miter, | |||
.ql-bubble.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter, | |||
.ql-bubble .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter, | |||
.ql-bubble.ql-toolbar .ql-picker-item:hover .ql-stroke-miter, | |||
.ql-bubble .ql-toolbar .ql-picker-item:hover .ql-stroke-miter, | |||
.ql-bubble.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter, | |||
.ql-bubble .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter { | |||
stroke: #fff; | |||
} | |||
@media (pointer: coarse) { | |||
.ql-bubble.ql-toolbar button:hover:not(.ql-active), | |||
.ql-bubble .ql-toolbar button:hover:not(.ql-active) { | |||
color: #ccc; | |||
} | |||
.ql-bubble.ql-toolbar button:hover:not(.ql-active) .ql-fill, | |||
.ql-bubble .ql-toolbar button:hover:not(.ql-active) .ql-fill, | |||
.ql-bubble.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill, | |||
.ql-bubble .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill { | |||
fill: #ccc; | |||
} | |||
.ql-bubble.ql-toolbar button:hover:not(.ql-active) .ql-stroke, | |||
.ql-bubble .ql-toolbar button:hover:not(.ql-active) .ql-stroke, | |||
.ql-bubble.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter, | |||
.ql-bubble .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter { | |||
stroke: #ccc; | |||
} | |||
} | |||
.ql-bubble { | |||
box-sizing: border-box; | |||
} | |||
.ql-bubble * { | |||
box-sizing: border-box; | |||
} | |||
.ql-bubble .ql-hidden { | |||
display: none; | |||
} | |||
.ql-bubble .ql-out-bottom, | |||
.ql-bubble .ql-out-top { | |||
visibility: hidden; | |||
} | |||
.ql-bubble .ql-tooltip { | |||
position: absolute; | |||
transform: translateY(10px); | |||
} | |||
.ql-bubble .ql-tooltip a { | |||
cursor: pointer; | |||
text-decoration: none; | |||
} | |||
.ql-bubble .ql-tooltip.ql-flip { | |||
transform: translateY(-10px); | |||
} | |||
.ql-bubble .ql-formats { | |||
display: inline-block; | |||
vertical-align: middle; | |||
} | |||
.ql-bubble .ql-formats:after { | |||
clear: both; | |||
content: ''; | |||
display: table; | |||
} | |||
.ql-bubble .ql-stroke { | |||
fill: none; | |||
stroke: #ccc; | |||
stroke-linecap: round; | |||
stroke-linejoin: round; | |||
stroke-width: 2; | |||
} | |||
.ql-bubble .ql-stroke-miter { | |||
fill: none; | |||
stroke: #ccc; | |||
stroke-miterlimit: 10; | |||
stroke-width: 2; | |||
} | |||
.ql-bubble .ql-fill, | |||
.ql-bubble .ql-stroke.ql-fill { | |||
fill: #ccc; | |||
} | |||
.ql-bubble .ql-empty { | |||
fill: none; | |||
} | |||
.ql-bubble .ql-even { | |||
fill-rule: evenodd; | |||
} | |||
.ql-bubble .ql-thin, | |||
.ql-bubble .ql-stroke.ql-thin { | |||
stroke-width: 1; | |||
} | |||
.ql-bubble .ql-transparent { | |||
opacity: 0.4; | |||
} | |||
.ql-bubble .ql-direction svg:last-child { | |||
display: none; | |||
} | |||
.ql-bubble .ql-direction.ql-active svg:last-child { | |||
display: inline; | |||
} | |||
.ql-bubble .ql-direction.ql-active svg:first-child { | |||
display: none; | |||
} | |||
.ql-bubble .ql-editor h1 { | |||
font-size: 2em; | |||
} | |||
.ql-bubble .ql-editor h2 { | |||
font-size: 1.5em; | |||
} | |||
.ql-bubble .ql-editor h3 { | |||
font-size: 1.17em; | |||
} | |||
.ql-bubble .ql-editor h4 { | |||
font-size: 1em; | |||
} | |||
.ql-bubble .ql-editor h5 { | |||
font-size: 0.83em; | |||
} | |||
.ql-bubble .ql-editor h6 { | |||
font-size: 0.67em; | |||
} | |||
.ql-bubble .ql-editor a { | |||
text-decoration: underline; | |||
} | |||
.ql-bubble .ql-editor blockquote { | |||
border-left: 4px solid #ccc; | |||
margin-bottom: 5px; | |||
margin-top: 5px; | |||
padding-left: 16px; | |||
} | |||
.ql-bubble .ql-editor code, | |||
.ql-bubble .ql-editor pre { | |||
background-color: #f0f0f0; | |||
border-radius: 3px; | |||
} | |||
.ql-bubble .ql-editor pre { | |||
white-space: pre-wrap; | |||
margin-bottom: 5px; | |||
margin-top: 5px; | |||
padding: 5px 10px; | |||
} | |||
.ql-bubble .ql-editor code { | |||
font-size: 85%; | |||
padding: 2px 4px; | |||
} | |||
.ql-bubble .ql-editor pre.ql-syntax { | |||
background-color: #23241f; | |||
color: #f8f8f2; | |||
overflow: visible; | |||
} | |||
.ql-bubble .ql-editor img { | |||
max-width: 100%; | |||
} | |||
.ql-bubble .ql-picker { | |||
color: #ccc; | |||
display: inline-block; | |||
float: left; | |||
font-size: 14px; | |||
font-weight: 500; | |||
height: 24px; | |||
position: relative; | |||
vertical-align: middle; | |||
} | |||
.ql-bubble .ql-picker-label { | |||
cursor: pointer; | |||
display: inline-block; | |||
height: 100%; | |||
padding-left: 8px; | |||
padding-right: 2px; | |||
position: relative; | |||
width: 100%; | |||
} | |||
.ql-bubble .ql-picker-label::before { | |||
display: inline-block; | |||
line-height: 22px; | |||
} | |||
.ql-bubble .ql-picker-options { | |||
background-color: #444; | |||
display: none; | |||
min-width: 100%; | |||
padding: 4px 8px; | |||
position: absolute; | |||
white-space: nowrap; | |||
} | |||
.ql-bubble .ql-picker-options .ql-picker-item { | |||
cursor: pointer; | |||
display: block; | |||
padding-bottom: 5px; | |||
padding-top: 5px; | |||
} | |||
.ql-bubble .ql-picker.ql-expanded .ql-picker-label { | |||
color: #777; | |||
z-index: 2; | |||
} | |||
.ql-bubble .ql-picker.ql-expanded .ql-picker-label .ql-fill { | |||
fill: #777; | |||
} | |||
.ql-bubble .ql-picker.ql-expanded .ql-picker-label .ql-stroke { | |||
stroke: #777; | |||
} | |||
.ql-bubble .ql-picker.ql-expanded .ql-picker-options { | |||
display: block; | |||
margin-top: -1px; | |||
top: 100%; | |||
z-index: 1; | |||
} | |||
.ql-bubble .ql-color-picker, | |||
.ql-bubble .ql-icon-picker { | |||
width: 28px; | |||
} | |||
.ql-bubble .ql-color-picker .ql-picker-label, | |||
.ql-bubble .ql-icon-picker .ql-picker-label { | |||
padding: 2px 4px; | |||
} | |||
.ql-bubble .ql-color-picker .ql-picker-label svg, | |||
.ql-bubble .ql-icon-picker .ql-picker-label svg { | |||
right: 4px; | |||
} | |||
.ql-bubble .ql-icon-picker .ql-picker-options { | |||
padding: 4px 0px; | |||
} | |||
.ql-bubble .ql-icon-picker .ql-picker-item { | |||
height: 24px; | |||
width: 24px; | |||
padding: 2px 4px; | |||
} | |||
.ql-bubble .ql-color-picker .ql-picker-options { | |||
padding: 3px 5px; | |||
width: 152px; | |||
} | |||
.ql-bubble .ql-color-picker .ql-picker-item { | |||
border: 1px solid transparent; | |||
float: left; | |||
height: 16px; | |||
margin: 2px; | |||
padding: 0px; | |||
width: 16px; | |||
} | |||
.ql-bubble .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg { | |||
position: absolute; | |||
margin-top: -9px; | |||
right: 0; | |||
top: 50%; | |||
width: 18px; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=''])::before, | |||
.ql-bubble .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=''])::before, | |||
.ql-bubble .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=''])::before, | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=''])::before, | |||
.ql-bubble .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=''])::before, | |||
.ql-bubble .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=''])::before { | |||
content: attr(data-label); | |||
} | |||
.ql-bubble .ql-picker.ql-header { | |||
width: 98px; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-label::before, | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item::before { | |||
content: 'Normal'; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-label[data-value="1"]::before, | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="1"]::before { | |||
content: 'Heading 1'; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-label[data-value="2"]::before, | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="2"]::before { | |||
content: 'Heading 2'; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-label[data-value="3"]::before, | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="3"]::before { | |||
content: 'Heading 3'; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-label[data-value="4"]::before, | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="4"]::before { | |||
content: 'Heading 4'; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-label[data-value="5"]::before, | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="5"]::before { | |||
content: 'Heading 5'; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-label[data-value="6"]::before, | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="6"]::before { | |||
content: 'Heading 6'; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="1"]::before { | |||
font-size: 2em; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="2"]::before { | |||
font-size: 1.5em; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="3"]::before { | |||
font-size: 1.17em; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="4"]::before { | |||
font-size: 1em; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="5"]::before { | |||
font-size: 0.83em; | |||
} | |||
.ql-bubble .ql-picker.ql-header .ql-picker-item[data-value="6"]::before { | |||
font-size: 0.67em; | |||
} | |||
.ql-bubble .ql-picker.ql-font { | |||
width: 108px; | |||
} | |||
.ql-bubble .ql-picker.ql-font .ql-picker-label::before, | |||
.ql-bubble .ql-picker.ql-font .ql-picker-item::before { | |||
content: 'Sans Serif'; | |||
} | |||
.ql-bubble .ql-picker.ql-font .ql-picker-label[data-value=serif]::before, | |||
.ql-bubble .ql-picker.ql-font .ql-picker-item[data-value=serif]::before { | |||
content: 'Serif'; | |||
} | |||
.ql-bubble .ql-picker.ql-font .ql-picker-label[data-value=monospace]::before, | |||
.ql-bubble .ql-picker.ql-font .ql-picker-item[data-value=monospace]::before { | |||
content: 'Monospace'; | |||
} | |||
.ql-bubble .ql-picker.ql-font .ql-picker-item[data-value=serif]::before { | |||
font-family: Georgia, Times New Roman, serif; | |||
} | |||
.ql-bubble .ql-picker.ql-font .ql-picker-item[data-value=monospace]::before { | |||
font-family: Monaco, Courier New, monospace; | |||
} | |||
.ql-bubble .ql-picker.ql-size { | |||
width: 98px; | |||
} | |||
.ql-bubble .ql-picker.ql-size .ql-picker-label::before, | |||
.ql-bubble .ql-picker.ql-size .ql-picker-item::before { | |||
content: 'Normal'; | |||
} | |||
.ql-bubble .ql-picker.ql-size .ql-picker-label[data-value=small]::before, | |||
.ql-bubble .ql-picker.ql-size .ql-picker-item[data-value=small]::before { | |||
content: 'Small'; | |||
} | |||
.ql-bubble .ql-picker.ql-size .ql-picker-label[data-value=large]::before, | |||
.ql-bubble .ql-picker.ql-size .ql-picker-item[data-value=large]::before { | |||
content: 'Large'; | |||
} | |||
.ql-bubble .ql-picker.ql-size .ql-picker-label[data-value=huge]::before, | |||
.ql-bubble .ql-picker.ql-size .ql-picker-item[data-value=huge]::before { | |||
content: 'Huge'; | |||
} | |||
.ql-bubble .ql-picker.ql-size .ql-picker-item[data-value=small]::before { | |||
font-size: 10px; | |||
} | |||
.ql-bubble .ql-picker.ql-size .ql-picker-item[data-value=large]::before { | |||
font-size: 18px; | |||
} | |||
.ql-bubble .ql-picker.ql-size .ql-picker-item[data-value=huge]::before { | |||
font-size: 32px; | |||
} | |||
.ql-bubble .ql-color-picker.ql-background .ql-picker-item { | |||
background-color: #fff; | |||
} | |||
.ql-bubble .ql-color-picker.ql-color .ql-picker-item { | |||
background-color: #000; | |||
} | |||
.ql-bubble .ql-toolbar .ql-formats { | |||
margin: 8px 12px 8px 0px; | |||
} | |||
.ql-bubble .ql-toolbar .ql-formats:first-child { | |||
margin-left: 12px; | |||
} | |||
.ql-bubble .ql-color-picker svg { | |||
margin: 1px; | |||
} | |||
.ql-bubble .ql-color-picker .ql-picker-item.ql-selected, | |||
.ql-bubble .ql-color-picker .ql-picker-item:hover { | |||
border-color: #fff; | |||
} | |||
.ql-bubble .ql-tooltip { | |||
background-color: #444; | |||
border-radius: 25px; | |||
color: #fff; | |||
} | |||
.ql-bubble .ql-tooltip-arrow { | |||
border-left: 6px solid transparent; | |||
border-right: 6px solid transparent; | |||
content: " "; | |||
display: block; | |||
left: 50%; | |||
margin-left: -6px; | |||
position: absolute; | |||
} | |||
.ql-bubble .ql-tooltip:not(.ql-flip) .ql-tooltip-arrow { | |||
border-bottom: 6px solid #444; | |||
top: -6px; | |||
} | |||
.ql-bubble .ql-tooltip.ql-flip .ql-tooltip-arrow { | |||
border-top: 6px solid #444; | |||
bottom: -6px; | |||
} | |||
.ql-bubble .ql-tooltip.ql-editing .ql-tooltip-editor { | |||
display: block; | |||
} | |||
.ql-bubble .ql-tooltip.ql-editing .ql-formats { | |||
visibility: hidden; | |||
} | |||
.ql-bubble .ql-tooltip-editor { | |||
display: none; | |||
} | |||
.ql-bubble .ql-tooltip-editor input[type=text] { | |||
background: transparent; | |||
border: none; | |||
color: #fff; | |||
font-size: 13px; | |||
height: 100%; | |||
outline: none; | |||
padding: 10px 20px; | |||
position: absolute; | |||
width: 100%; | |||
} | |||
.ql-bubble .ql-tooltip-editor a { | |||
top: 10px; | |||
position: absolute; | |||
right: 20px; | |||
} | |||
.ql-bubble .ql-tooltip-editor a:before { | |||
color: #ccc; | |||
content: "\D7"; | |||
font-size: 16px; | |||
font-weight: bold; | |||
} | |||
.ql-container.ql-bubble:not(.ql-disabled) a { | |||
position: relative; | |||
white-space: nowrap; | |||
} | |||
.ql-container.ql-bubble:not(.ql-disabled) a::before { | |||
background-color: #444; | |||
border-radius: 15px; | |||
top: -5px; | |||
font-size: 12px; | |||
color: #fff; | |||
content: attr(href); | |||
font-weight: normal; | |||
overflow: hidden; | |||
padding: 5px 15px; | |||
text-decoration: none; | |||
z-index: 1; | |||
} | |||
.ql-container.ql-bubble:not(.ql-disabled) a::after { | |||
border-top: 6px solid #444; | |||
border-left: 6px solid transparent; | |||
border-right: 6px solid transparent; | |||
top: 0; | |||
content: " "; | |||
height: 0; | |||
width: 0; | |||
} | |||
.ql-container.ql-bubble:not(.ql-disabled) a::before, | |||
.ql-container.ql-bubble:not(.ql-disabled) a::after { | |||
left: 0; | |||
margin-left: 50%; | |||
position: absolute; | |||
transform: translate(-50%, -100%); | |||
transition: visibility 0s ease 200ms; | |||
visibility: hidden; | |||
} | |||
.ql-container.ql-bubble:not(.ql-disabled) a:hover::before, | |||
.ql-container.ql-bubble:not(.ql-disabled) a:hover::after { | |||
visibility: visible; | |||
} |
@@ -0,0 +1,397 @@ | |||
/*! | |||
* Quill Editor v1.3.7 | |||
* https://quilljs.com/ | |||
* Copyright (c) 2014, Jason Chen | |||
* Copyright (c) 2013, salesforce.com | |||
*/ | |||
.ql-container { | |||
box-sizing: border-box; | |||
font-family: Helvetica, Arial, sans-serif; | |||
font-size: 13px; | |||
height: 100%; | |||
margin: 0px; | |||
position: relative; | |||
} | |||
.ql-container.ql-disabled .ql-tooltip { | |||
visibility: hidden; | |||
} | |||
.ql-container.ql-disabled .ql-editor ul[data-checked] > li::before { | |||
pointer-events: none; | |||
} | |||
.ql-clipboard { | |||
left: -100000px; | |||
height: 1px; | |||
overflow-y: hidden; | |||
position: absolute; | |||
top: 50%; | |||
} | |||
.ql-clipboard p { | |||
margin: 0; | |||
padding: 0; | |||
} | |||
.ql-editor { | |||
box-sizing: border-box; | |||
line-height: 1.42; | |||
height: 100%; | |||
outline: none; | |||
overflow-y: auto; | |||
padding: 12px 15px; | |||
tab-size: 4; | |||
-moz-tab-size: 4; | |||
text-align: left; | |||
white-space: pre-wrap; | |||
word-wrap: break-word; | |||
} | |||
.ql-editor > * { | |||
cursor: text; | |||
} | |||
.ql-editor p, | |||
.ql-editor ol, | |||
.ql-editor ul, | |||
.ql-editor pre, | |||
.ql-editor blockquote, | |||
.ql-editor h1, | |||
.ql-editor h2, | |||
.ql-editor h3, | |||
.ql-editor h4, | |||
.ql-editor h5, | |||
.ql-editor h6 { | |||
margin: 0; | |||
padding: 0; | |||
counter-reset: list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol, | |||
.ql-editor ul { | |||
padding-left: 1.5em; | |||
} | |||
.ql-editor ol > li, | |||
.ql-editor ul > li { | |||
list-style-type: none; | |||
} | |||
.ql-editor ul > li::before { | |||
content: '\2022'; | |||
} | |||
.ql-editor ul[data-checked=true], | |||
.ql-editor ul[data-checked=false] { | |||
pointer-events: none; | |||
} | |||
.ql-editor ul[data-checked=true] > li *, | |||
.ql-editor ul[data-checked=false] > li * { | |||
pointer-events: all; | |||
} | |||
.ql-editor ul[data-checked=true] > li::before, | |||
.ql-editor ul[data-checked=false] > li::before { | |||
color: #777; | |||
cursor: pointer; | |||
pointer-events: all; | |||
} | |||
.ql-editor ul[data-checked=true] > li::before { | |||
content: '\2611'; | |||
} | |||
.ql-editor ul[data-checked=false] > li::before { | |||
content: '\2610'; | |||
} | |||
.ql-editor li::before { | |||
display: inline-block; | |||
white-space: nowrap; | |||
width: 1.2em; | |||
} | |||
.ql-editor li:not(.ql-direction-rtl)::before { | |||
margin-left: -1.5em; | |||
margin-right: 0.3em; | |||
text-align: right; | |||
} | |||
.ql-editor li.ql-direction-rtl::before { | |||
margin-left: 0.3em; | |||
margin-right: -1.5em; | |||
} | |||
.ql-editor ol li:not(.ql-direction-rtl), | |||
.ql-editor ul li:not(.ql-direction-rtl) { | |||
padding-left: 1.5em; | |||
} | |||
.ql-editor ol li.ql-direction-rtl, | |||
.ql-editor ul li.ql-direction-rtl { | |||
padding-right: 1.5em; | |||
} | |||
.ql-editor ol li { | |||
counter-reset: list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
counter-increment: list-0; | |||
} | |||
.ql-editor ol li:before { | |||
content: counter(list-0, decimal) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-1 { | |||
counter-increment: list-1; | |||
} | |||
.ql-editor ol li.ql-indent-1:before { | |||
content: counter(list-1, lower-alpha) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-1 { | |||
counter-reset: list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-2 { | |||
counter-increment: list-2; | |||
} | |||
.ql-editor ol li.ql-indent-2:before { | |||
content: counter(list-2, lower-roman) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-2 { | |||
counter-reset: list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-3 { | |||
counter-increment: list-3; | |||
} | |||
.ql-editor ol li.ql-indent-3:before { | |||
content: counter(list-3, decimal) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-3 { | |||
counter-reset: list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-4 { | |||
counter-increment: list-4; | |||
} | |||
.ql-editor ol li.ql-indent-4:before { | |||
content: counter(list-4, lower-alpha) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-4 { | |||
counter-reset: list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-5 { | |||
counter-increment: list-5; | |||
} | |||
.ql-editor ol li.ql-indent-5:before { | |||
content: counter(list-5, lower-roman) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-5 { | |||
counter-reset: list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-6 { | |||
counter-increment: list-6; | |||
} | |||
.ql-editor ol li.ql-indent-6:before { | |||
content: counter(list-6, decimal) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-6 { | |||
counter-reset: list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-7 { | |||
counter-increment: list-7; | |||
} | |||
.ql-editor ol li.ql-indent-7:before { | |||
content: counter(list-7, lower-alpha) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-7 { | |||
counter-reset: list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-8 { | |||
counter-increment: list-8; | |||
} | |||
.ql-editor ol li.ql-indent-8:before { | |||
content: counter(list-8, lower-roman) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-8 { | |||
counter-reset: list-9; | |||
} | |||
.ql-editor ol li.ql-indent-9 { | |||
counter-increment: list-9; | |||
} | |||
.ql-editor ol li.ql-indent-9:before { | |||
content: counter(list-9, decimal) '. '; | |||
} | |||
.ql-editor .ql-indent-1:not(.ql-direction-rtl) { | |||
padding-left: 3em; | |||
} | |||
.ql-editor li.ql-indent-1:not(.ql-direction-rtl) { | |||
padding-left: 4.5em; | |||
} | |||
.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right { | |||
padding-right: 3em; | |||
} | |||
.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right { | |||
padding-right: 4.5em; | |||
} | |||
.ql-editor .ql-indent-2:not(.ql-direction-rtl) { | |||
padding-left: 6em; | |||
} | |||
.ql-editor li.ql-indent-2:not(.ql-direction-rtl) { | |||
padding-left: 7.5em; | |||
} | |||
.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right { | |||
padding-right: 6em; | |||
} | |||
.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right { | |||
padding-right: 7.5em; | |||
} | |||
.ql-editor .ql-indent-3:not(.ql-direction-rtl) { | |||
padding-left: 9em; | |||
} | |||
.ql-editor li.ql-indent-3:not(.ql-direction-rtl) { | |||
padding-left: 10.5em; | |||
} | |||
.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right { | |||
padding-right: 9em; | |||
} | |||
.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right { | |||
padding-right: 10.5em; | |||
} | |||
.ql-editor .ql-indent-4:not(.ql-direction-rtl) { | |||
padding-left: 12em; | |||
} | |||
.ql-editor li.ql-indent-4:not(.ql-direction-rtl) { | |||
padding-left: 13.5em; | |||
} | |||
.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right { | |||
padding-right: 12em; | |||
} | |||
.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right { | |||
padding-right: 13.5em; | |||
} | |||
.ql-editor .ql-indent-5:not(.ql-direction-rtl) { | |||
padding-left: 15em; | |||
} | |||
.ql-editor li.ql-indent-5:not(.ql-direction-rtl) { | |||
padding-left: 16.5em; | |||
} | |||
.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right { | |||
padding-right: 15em; | |||
} | |||
.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right { | |||
padding-right: 16.5em; | |||
} | |||
.ql-editor .ql-indent-6:not(.ql-direction-rtl) { | |||
padding-left: 18em; | |||
} | |||
.ql-editor li.ql-indent-6:not(.ql-direction-rtl) { | |||
padding-left: 19.5em; | |||
} | |||
.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right { | |||
padding-right: 18em; | |||
} | |||
.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right { | |||
padding-right: 19.5em; | |||
} | |||
.ql-editor .ql-indent-7:not(.ql-direction-rtl) { | |||
padding-left: 21em; | |||
} | |||
.ql-editor li.ql-indent-7:not(.ql-direction-rtl) { | |||
padding-left: 22.5em; | |||
} | |||
.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right { | |||
padding-right: 21em; | |||
} | |||
.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right { | |||
padding-right: 22.5em; | |||
} | |||
.ql-editor .ql-indent-8:not(.ql-direction-rtl) { | |||
padding-left: 24em; | |||
} | |||
.ql-editor li.ql-indent-8:not(.ql-direction-rtl) { | |||
padding-left: 25.5em; | |||
} | |||
.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right { | |||
padding-right: 24em; | |||
} | |||
.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right { | |||
padding-right: 25.5em; | |||
} | |||
.ql-editor .ql-indent-9:not(.ql-direction-rtl) { | |||
padding-left: 27em; | |||
} | |||
.ql-editor li.ql-indent-9:not(.ql-direction-rtl) { | |||
padding-left: 28.5em; | |||
} | |||
.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right { | |||
padding-right: 27em; | |||
} | |||
.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right { | |||
padding-right: 28.5em; | |||
} | |||
.ql-editor .ql-video { | |||
display: block; | |||
max-width: 100%; | |||
} | |||
.ql-editor .ql-video.ql-align-center { | |||
margin: 0 auto; | |||
} | |||
.ql-editor .ql-video.ql-align-right { | |||
margin: 0 0 0 auto; | |||
} | |||
.ql-editor .ql-bg-black { | |||
background-color: #000; | |||
} | |||
.ql-editor .ql-bg-red { | |||
background-color: #e60000; | |||
} | |||
.ql-editor .ql-bg-orange { | |||
background-color: #f90; | |||
} | |||
.ql-editor .ql-bg-yellow { | |||
background-color: #ff0; | |||
} | |||
.ql-editor .ql-bg-green { | |||
background-color: #008a00; | |||
} | |||
.ql-editor .ql-bg-blue { | |||
background-color: #06c; | |||
} | |||
.ql-editor .ql-bg-purple { | |||
background-color: #93f; | |||
} | |||
.ql-editor .ql-color-white { | |||
color: #fff; | |||
} | |||
.ql-editor .ql-color-red { | |||
color: #e60000; | |||
} | |||
.ql-editor .ql-color-orange { | |||
color: #f90; | |||
} | |||
.ql-editor .ql-color-yellow { | |||
color: #ff0; | |||
} | |||
.ql-editor .ql-color-green { | |||
color: #008a00; | |||
} | |||
.ql-editor .ql-color-blue { | |||
color: #06c; | |||
} | |||
.ql-editor .ql-color-purple { | |||
color: #93f; | |||
} | |||
.ql-editor .ql-font-serif { | |||
font-family: Georgia, Times New Roman, serif; | |||
} | |||
.ql-editor .ql-font-monospace { | |||
font-family: Monaco, Courier New, monospace; | |||
} | |||
.ql-editor .ql-size-small { | |||
font-size: 0.75em; | |||
} | |||
.ql-editor .ql-size-large { | |||
font-size: 1.5em; | |||
} | |||
.ql-editor .ql-size-huge { | |||
font-size: 2.5em; | |||
} | |||
.ql-editor .ql-direction-rtl { | |||
direction: rtl; | |||
text-align: inherit; | |||
} | |||
.ql-editor .ql-align-center { | |||
text-align: center; | |||
} | |||
.ql-editor .ql-align-justify { | |||
text-align: justify; | |||
} | |||
.ql-editor .ql-align-right { | |||
text-align: right; | |||
} | |||
.ql-editor.ql-blank::before { | |||
color: rgba(0,0,0,0.6); | |||
content: attr(data-placeholder); | |||
font-style: italic; | |||
left: 15px; | |||
pointer-events: none; | |||
position: absolute; | |||
right: 15px; | |||
} |
@@ -0,0 +1,945 @@ | |||
/*! | |||
* Quill Editor v1.3.7 | |||
* https://quilljs.com/ | |||
* Copyright (c) 2014, Jason Chen | |||
* Copyright (c) 2013, salesforce.com | |||
*/ | |||
.ql-container { | |||
box-sizing: border-box; | |||
font-family: Helvetica, Arial, sans-serif; | |||
font-size: 13px; | |||
height: 100%; | |||
margin: 0px; | |||
position: relative; | |||
} | |||
.ql-container.ql-disabled .ql-tooltip { | |||
visibility: hidden; | |||
} | |||
.ql-container.ql-disabled .ql-editor ul[data-checked] > li::before { | |||
pointer-events: none; | |||
} | |||
.ql-clipboard { | |||
left: -100000px; | |||
height: 1px; | |||
overflow-y: hidden; | |||
position: absolute; | |||
top: 50%; | |||
} | |||
.ql-clipboard p { | |||
margin: 0; | |||
padding: 0; | |||
} | |||
.ql-editor { | |||
box-sizing: border-box; | |||
line-height: 1.42; | |||
height: 100%; | |||
outline: none; | |||
overflow-y: auto; | |||
padding: 12px 15px; | |||
tab-size: 4; | |||
-moz-tab-size: 4; | |||
text-align: left; | |||
white-space: pre-wrap; | |||
word-wrap: break-word; | |||
} | |||
.ql-editor > * { | |||
cursor: text; | |||
} | |||
.ql-editor p, | |||
.ql-editor ol, | |||
.ql-editor ul, | |||
.ql-editor pre, | |||
.ql-editor blockquote, | |||
.ql-editor h1, | |||
.ql-editor h2, | |||
.ql-editor h3, | |||
.ql-editor h4, | |||
.ql-editor h5, | |||
.ql-editor h6 { | |||
margin: 0; | |||
padding: 0; | |||
counter-reset: list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol, | |||
.ql-editor ul { | |||
padding-left: 1.5em; | |||
} | |||
.ql-editor ol > li, | |||
.ql-editor ul > li { | |||
list-style-type: none; | |||
} | |||
.ql-editor ul > li::before { | |||
content: '\2022'; | |||
} | |||
.ql-editor ul[data-checked=true], | |||
.ql-editor ul[data-checked=false] { | |||
pointer-events: none; | |||
} | |||
.ql-editor ul[data-checked=true] > li *, | |||
.ql-editor ul[data-checked=false] > li * { | |||
pointer-events: all; | |||
} | |||
.ql-editor ul[data-checked=true] > li::before, | |||
.ql-editor ul[data-checked=false] > li::before { | |||
color: #777; | |||
cursor: pointer; | |||
pointer-events: all; | |||
} | |||
.ql-editor ul[data-checked=true] > li::before { | |||
content: '\2611'; | |||
} | |||
.ql-editor ul[data-checked=false] > li::before { | |||
content: '\2610'; | |||
} | |||
.ql-editor li::before { | |||
display: inline-block; | |||
white-space: nowrap; | |||
width: 1.2em; | |||
} | |||
.ql-editor li:not(.ql-direction-rtl)::before { | |||
margin-left: -1.5em; | |||
margin-right: 0.3em; | |||
text-align: right; | |||
} | |||
.ql-editor li.ql-direction-rtl::before { | |||
margin-left: 0.3em; | |||
margin-right: -1.5em; | |||
} | |||
.ql-editor ol li:not(.ql-direction-rtl), | |||
.ql-editor ul li:not(.ql-direction-rtl) { | |||
padding-left: 1.5em; | |||
} | |||
.ql-editor ol li.ql-direction-rtl, | |||
.ql-editor ul li.ql-direction-rtl { | |||
padding-right: 1.5em; | |||
} | |||
.ql-editor ol li { | |||
counter-reset: list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
counter-increment: list-0; | |||
} | |||
.ql-editor ol li:before { | |||
content: counter(list-0, decimal) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-1 { | |||
counter-increment: list-1; | |||
} | |||
.ql-editor ol li.ql-indent-1:before { | |||
content: counter(list-1, lower-alpha) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-1 { | |||
counter-reset: list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-2 { | |||
counter-increment: list-2; | |||
} | |||
.ql-editor ol li.ql-indent-2:before { | |||
content: counter(list-2, lower-roman) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-2 { | |||
counter-reset: list-3 list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-3 { | |||
counter-increment: list-3; | |||
} | |||
.ql-editor ol li.ql-indent-3:before { | |||
content: counter(list-3, decimal) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-3 { | |||
counter-reset: list-4 list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-4 { | |||
counter-increment: list-4; | |||
} | |||
.ql-editor ol li.ql-indent-4:before { | |||
content: counter(list-4, lower-alpha) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-4 { | |||
counter-reset: list-5 list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-5 { | |||
counter-increment: list-5; | |||
} | |||
.ql-editor ol li.ql-indent-5:before { | |||
content: counter(list-5, lower-roman) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-5 { | |||
counter-reset: list-6 list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-6 { | |||
counter-increment: list-6; | |||
} | |||
.ql-editor ol li.ql-indent-6:before { | |||
content: counter(list-6, decimal) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-6 { | |||
counter-reset: list-7 list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-7 { | |||
counter-increment: list-7; | |||
} | |||
.ql-editor ol li.ql-indent-7:before { | |||
content: counter(list-7, lower-alpha) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-7 { | |||
counter-reset: list-8 list-9; | |||
} | |||
.ql-editor ol li.ql-indent-8 { | |||
counter-increment: list-8; | |||
} | |||
.ql-editor ol li.ql-indent-8:before { | |||
content: counter(list-8, lower-roman) '. '; | |||
} | |||
.ql-editor ol li.ql-indent-8 { | |||
counter-reset: list-9; | |||
} | |||
.ql-editor ol li.ql-indent-9 { | |||
counter-increment: list-9; | |||
} | |||
.ql-editor ol li.ql-indent-9:before { | |||
content: counter(list-9, decimal) '. '; | |||
} | |||
.ql-editor .ql-indent-1:not(.ql-direction-rtl) { | |||
padding-left: 3em; | |||
} | |||
.ql-editor li.ql-indent-1:not(.ql-direction-rtl) { | |||
padding-left: 4.5em; | |||
} | |||
.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right { | |||
padding-right: 3em; | |||
} | |||
.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right { | |||
padding-right: 4.5em; | |||
} | |||
.ql-editor .ql-indent-2:not(.ql-direction-rtl) { | |||
padding-left: 6em; | |||
} | |||
.ql-editor li.ql-indent-2:not(.ql-direction-rtl) { | |||
padding-left: 7.5em; | |||
} | |||
.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right { | |||
padding-right: 6em; | |||
} | |||
.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right { | |||
padding-right: 7.5em; | |||
} | |||
.ql-editor .ql-indent-3:not(.ql-direction-rtl) { | |||
padding-left: 9em; | |||
} | |||
.ql-editor li.ql-indent-3:not(.ql-direction-rtl) { | |||
padding-left: 10.5em; | |||
} | |||
.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right { | |||
padding-right: 9em; | |||
} | |||
.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right { | |||
padding-right: 10.5em; | |||
} | |||
.ql-editor .ql-indent-4:not(.ql-direction-rtl) { | |||
padding-left: 12em; | |||
} | |||
.ql-editor li.ql-indent-4:not(.ql-direction-rtl) { | |||
padding-left: 13.5em; | |||
} | |||
.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right { | |||
padding-right: 12em; | |||
} | |||
.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right { | |||
padding-right: 13.5em; | |||
} | |||
.ql-editor .ql-indent-5:not(.ql-direction-rtl) { | |||
padding-left: 15em; | |||
} | |||
.ql-editor li.ql-indent-5:not(.ql-direction-rtl) { | |||
padding-left: 16.5em; | |||
} | |||
.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right { | |||
padding-right: 15em; | |||
} | |||
.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right { | |||
padding-right: 16.5em; | |||
} | |||
.ql-editor .ql-indent-6:not(.ql-direction-rtl) { | |||
padding-left: 18em; | |||
} | |||
.ql-editor li.ql-indent-6:not(.ql-direction-rtl) { | |||
padding-left: 19.5em; | |||
} | |||
.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right { | |||
padding-right: 18em; | |||
} | |||
.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right { | |||
padding-right: 19.5em; | |||
} | |||
.ql-editor .ql-indent-7:not(.ql-direction-rtl) { | |||
padding-left: 21em; | |||
} | |||
.ql-editor li.ql-indent-7:not(.ql-direction-rtl) { | |||
padding-left: 22.5em; | |||
} | |||
.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right { | |||
padding-right: 21em; | |||
} | |||
.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right { | |||
padding-right: 22.5em; | |||
} | |||
.ql-editor .ql-indent-8:not(.ql-direction-rtl) { | |||
padding-left: 24em; | |||
} | |||
.ql-editor li.ql-indent-8:not(.ql-direction-rtl) { | |||
padding-left: 25.5em; | |||
} | |||
.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right { | |||
padding-right: 24em; | |||
} | |||
.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right { | |||
padding-right: 25.5em; | |||
} | |||
.ql-editor .ql-indent-9:not(.ql-direction-rtl) { | |||
padding-left: 27em; | |||
} | |||
.ql-editor li.ql-indent-9:not(.ql-direction-rtl) { | |||
padding-left: 28.5em; | |||
} | |||
.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right { | |||
padding-right: 27em; | |||
} | |||
.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right { | |||
padding-right: 28.5em; | |||
} | |||
.ql-editor .ql-video { | |||
display: block; | |||
max-width: 100%; | |||
} | |||
.ql-editor .ql-video.ql-align-center { | |||
margin: 0 auto; | |||
} | |||
.ql-editor .ql-video.ql-align-right { | |||
margin: 0 0 0 auto; | |||
} | |||
.ql-editor .ql-bg-black { | |||
background-color: #000; | |||
} | |||
.ql-editor .ql-bg-red { | |||
background-color: #e60000; | |||
} | |||
.ql-editor .ql-bg-orange { | |||
background-color: #f90; | |||
} | |||
.ql-editor .ql-bg-yellow { | |||
background-color: #ff0; | |||
} | |||
.ql-editor .ql-bg-green { | |||
background-color: #008a00; | |||
} | |||
.ql-editor .ql-bg-blue { | |||
background-color: #06c; | |||
} | |||
.ql-editor .ql-bg-purple { | |||
background-color: #93f; | |||
} | |||
.ql-editor .ql-color-white { | |||
color: #fff; | |||
} | |||
.ql-editor .ql-color-red { | |||
color: #e60000; | |||
} | |||
.ql-editor .ql-color-orange { | |||
color: #f90; | |||
} | |||
.ql-editor .ql-color-yellow { | |||
color: #ff0; | |||
} | |||
.ql-editor .ql-color-green { | |||
color: #008a00; | |||
} | |||
.ql-editor .ql-color-blue { | |||
color: #06c; | |||
} | |||
.ql-editor .ql-color-purple { | |||
color: #93f; | |||
} | |||
.ql-editor .ql-font-serif { | |||
font-family: Georgia, Times New Roman, serif; | |||
} | |||
.ql-editor .ql-font-monospace { | |||
font-family: Monaco, Courier New, monospace; | |||
} | |||
.ql-editor .ql-size-small { | |||
font-size: 0.75em; | |||
} | |||
.ql-editor .ql-size-large { | |||
font-size: 1.5em; | |||
} | |||
.ql-editor .ql-size-huge { | |||
font-size: 2.5em; | |||
} | |||
.ql-editor .ql-direction-rtl { | |||
direction: rtl; | |||
text-align: inherit; | |||
} | |||
.ql-editor .ql-align-center { | |||
text-align: center; | |||
} | |||
.ql-editor .ql-align-justify { | |||
text-align: justify; | |||
} | |||
.ql-editor .ql-align-right { | |||
text-align: right; | |||
} | |||
.ql-editor.ql-blank::before { | |||
color: rgba(0,0,0,0.6); | |||
content: attr(data-placeholder); | |||
font-style: italic; | |||
left: 15px; | |||
pointer-events: none; | |||
position: absolute; | |||
right: 15px; | |||
} | |||
.ql-snow.ql-toolbar:after, | |||
.ql-snow .ql-toolbar:after { | |||
clear: both; | |||
content: ''; | |||
display: table; | |||
} | |||
.ql-snow.ql-toolbar button, | |||
.ql-snow .ql-toolbar button { | |||
background: none; | |||
border: none; | |||
cursor: pointer; | |||
display: inline-block; | |||
float: left; | |||
height: 24px; | |||
padding: 3px 5px; | |||
width: 28px; | |||
} | |||
.ql-snow.ql-toolbar button svg, | |||
.ql-snow .ql-toolbar button svg { | |||
float: left; | |||
height: 100%; | |||
} | |||
.ql-snow.ql-toolbar button:active:hover, | |||
.ql-snow .ql-toolbar button:active:hover { | |||
outline: none; | |||
} | |||
.ql-snow.ql-toolbar input.ql-image[type=file], | |||
.ql-snow .ql-toolbar input.ql-image[type=file] { | |||
display: none; | |||
} | |||
.ql-snow.ql-toolbar button:hover, | |||
.ql-snow .ql-toolbar button:hover, | |||
.ql-snow.ql-toolbar button:focus, | |||
.ql-snow .ql-toolbar button:focus, | |||
.ql-snow.ql-toolbar button.ql-active, | |||
.ql-snow .ql-toolbar button.ql-active, | |||
.ql-snow.ql-toolbar .ql-picker-label:hover, | |||
.ql-snow .ql-toolbar .ql-picker-label:hover, | |||
.ql-snow.ql-toolbar .ql-picker-label.ql-active, | |||
.ql-snow .ql-toolbar .ql-picker-label.ql-active, | |||
.ql-snow.ql-toolbar .ql-picker-item:hover, | |||
.ql-snow .ql-toolbar .ql-picker-item:hover, | |||
.ql-snow.ql-toolbar .ql-picker-item.ql-selected, | |||
.ql-snow .ql-toolbar .ql-picker-item.ql-selected { | |||
color: #06c; | |||
} | |||
.ql-snow.ql-toolbar button:hover .ql-fill, | |||
.ql-snow .ql-toolbar button:hover .ql-fill, | |||
.ql-snow.ql-toolbar button:focus .ql-fill, | |||
.ql-snow .ql-toolbar button:focus .ql-fill, | |||
.ql-snow.ql-toolbar button.ql-active .ql-fill, | |||
.ql-snow .ql-toolbar button.ql-active .ql-fill, | |||
.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill, | |||
.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill, | |||
.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill, | |||
.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill, | |||
.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill, | |||
.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill, | |||
.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill, | |||
.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill, | |||
.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill, | |||
.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill, | |||
.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill, | |||
.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill, | |||
.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill, | |||
.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill, | |||
.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill, | |||
.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill, | |||
.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill, | |||
.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill, | |||
.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill, | |||
.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill, | |||
.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill, | |||
.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill { | |||
fill: #06c; | |||
} | |||
.ql-snow.ql-toolbar button:hover .ql-stroke, | |||
.ql-snow .ql-toolbar button:hover .ql-stroke, | |||
.ql-snow.ql-toolbar button:focus .ql-stroke, | |||
.ql-snow .ql-toolbar button:focus .ql-stroke, | |||
.ql-snow.ql-toolbar button.ql-active .ql-stroke, | |||
.ql-snow .ql-toolbar button.ql-active .ql-stroke, | |||
.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke, | |||
.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke, | |||
.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke, | |||
.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke, | |||
.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke, | |||
.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke, | |||
.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke, | |||
.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke, | |||
.ql-snow.ql-toolbar button:hover .ql-stroke-miter, | |||
.ql-snow .ql-toolbar button:hover .ql-stroke-miter, | |||
.ql-snow.ql-toolbar button:focus .ql-stroke-miter, | |||
.ql-snow .ql-toolbar button:focus .ql-stroke-miter, | |||
.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter, | |||
.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter, | |||
.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter, | |||
.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter, | |||
.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter, | |||
.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter, | |||
.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter, | |||
.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter, | |||
.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter, | |||
.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter { | |||
stroke: #06c; | |||
} | |||
@media (pointer: coarse) { | |||
.ql-snow.ql-toolbar button:hover:not(.ql-active), | |||
.ql-snow .ql-toolbar button:hover:not(.ql-active) { | |||
color: #444; | |||
} | |||
.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill, | |||
.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill, | |||
.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill, | |||
.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill { | |||
fill: #444; | |||
} | |||
.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke, | |||
.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke, | |||
.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter, | |||
.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter { | |||
stroke: #444; | |||
} | |||
} | |||
.ql-snow { | |||
box-sizing: border-box; | |||
} | |||
.ql-snow * { | |||
box-sizing: border-box; | |||
} | |||
.ql-snow .ql-hidden { | |||
display: none; | |||
} | |||
.ql-snow .ql-out-bottom, | |||
.ql-snow .ql-out-top { | |||
visibility: hidden; | |||
} | |||
.ql-snow .ql-tooltip { | |||
position: absolute; | |||
transform: translateY(10px); | |||
} | |||
.ql-snow .ql-tooltip a { | |||
cursor: pointer; | |||
text-decoration: none; | |||
} | |||
.ql-snow .ql-tooltip.ql-flip { | |||
transform: translateY(-10px); | |||
} | |||
.ql-snow .ql-formats { | |||
display: inline-block; | |||
vertical-align: middle; | |||
} | |||
.ql-snow .ql-formats:after { | |||
clear: both; | |||
content: ''; | |||
display: table; | |||
} | |||
.ql-snow .ql-stroke { | |||
fill: none; | |||
stroke: #444; | |||
stroke-linecap: round; | |||
stroke-linejoin: round; | |||
stroke-width: 2; | |||
} | |||
.ql-snow .ql-stroke-miter { | |||
fill: none; | |||
stroke: #444; | |||
stroke-miterlimit: 10; | |||
stroke-width: 2; | |||
} | |||
.ql-snow .ql-fill, | |||
.ql-snow .ql-stroke.ql-fill { | |||
fill: #444; | |||
} | |||
.ql-snow .ql-empty { | |||
fill: none; | |||
} | |||
.ql-snow .ql-even { | |||
fill-rule: evenodd; | |||
} | |||
.ql-snow .ql-thin, | |||
.ql-snow .ql-stroke.ql-thin { | |||
stroke-width: 1; | |||
} | |||
.ql-snow .ql-transparent { | |||
opacity: 0.4; | |||
} | |||
.ql-snow .ql-direction svg:last-child { | |||
display: none; | |||
} | |||
.ql-snow .ql-direction.ql-active svg:last-child { | |||
display: inline; | |||
} | |||
.ql-snow .ql-direction.ql-active svg:first-child { | |||
display: none; | |||
} | |||
.ql-snow .ql-editor h1 { | |||
font-size: 2em; | |||
} | |||
.ql-snow .ql-editor h2 { | |||
font-size: 1.5em; | |||
} | |||
.ql-snow .ql-editor h3 { | |||
font-size: 1.17em; | |||
} | |||
.ql-snow .ql-editor h4 { | |||
font-size: 1em; | |||
} | |||
.ql-snow .ql-editor h5 { | |||
font-size: 0.83em; | |||
} | |||
.ql-snow .ql-editor h6 { | |||
font-size: 0.67em; | |||
} | |||
.ql-snow .ql-editor a { | |||
text-decoration: underline; | |||
} | |||
.ql-snow .ql-editor blockquote { | |||
border-left: 4px solid #ccc; | |||
margin-bottom: 5px; | |||
margin-top: 5px; | |||
padding-left: 16px; | |||
} | |||
.ql-snow .ql-editor code, | |||
.ql-snow .ql-editor pre { | |||
background-color: #f0f0f0; | |||
border-radius: 3px; | |||
} | |||
.ql-snow .ql-editor pre { | |||
white-space: pre-wrap; | |||
margin-bottom: 5px; | |||
margin-top: 5px; | |||
padding: 5px 10px; | |||
} | |||
.ql-snow .ql-editor code { | |||
font-size: 85%; | |||
padding: 2px 4px; | |||
} | |||
.ql-snow .ql-editor pre.ql-syntax { | |||
background-color: #23241f; | |||
color: #f8f8f2; | |||
overflow: visible; | |||
} | |||
.ql-snow .ql-editor img { | |||
max-width: 100%; | |||
} | |||
.ql-snow .ql-picker { | |||
color: #444; | |||
display: inline-block; | |||
float: left; | |||
font-size: 14px; | |||
font-weight: 500; | |||
height: 24px; | |||
position: relative; | |||
vertical-align: middle; | |||
} | |||
.ql-snow .ql-picker-label { | |||
cursor: pointer; | |||
display: inline-block; | |||
height: 100%; | |||
padding-left: 8px; | |||
padding-right: 2px; | |||
position: relative; | |||
width: 100%; | |||
} | |||
.ql-snow .ql-picker-label::before { | |||
display: inline-block; | |||
line-height: 22px; | |||
} | |||
.ql-snow .ql-picker-options { | |||
background-color: #fff; | |||
display: none; | |||
min-width: 100%; | |||
padding: 4px 8px; | |||
position: absolute; | |||
white-space: nowrap; | |||
} | |||
.ql-snow .ql-picker-options .ql-picker-item { | |||
cursor: pointer; | |||
display: block; | |||
padding-bottom: 5px; | |||
padding-top: 5px; | |||
} | |||
.ql-snow .ql-picker.ql-expanded .ql-picker-label { | |||
color: #ccc; | |||
z-index: 2; | |||
} | |||
.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill { | |||
fill: #ccc; | |||
} | |||
.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke { | |||
stroke: #ccc; | |||
} | |||
.ql-snow .ql-picker.ql-expanded .ql-picker-options { | |||
display: block; | |||
margin-top: -1px; | |||
top: 100%; | |||
z-index: 1; | |||
} | |||
.ql-snow .ql-color-picker, | |||
.ql-snow .ql-icon-picker { | |||
width: 28px; | |||
} | |||
.ql-snow .ql-color-picker .ql-picker-label, | |||
.ql-snow .ql-icon-picker .ql-picker-label { | |||
padding: 2px 4px; | |||
} | |||
.ql-snow .ql-color-picker .ql-picker-label svg, | |||
.ql-snow .ql-icon-picker .ql-picker-label svg { | |||
right: 4px; | |||
} | |||
.ql-snow .ql-icon-picker .ql-picker-options { | |||
padding: 4px 0px; | |||
} | |||
.ql-snow .ql-icon-picker .ql-picker-item { | |||
height: 24px; | |||
width: 24px; | |||
padding: 2px 4px; | |||
} | |||
.ql-snow .ql-color-picker .ql-picker-options { | |||
padding: 3px 5px; | |||
width: 152px; | |||
} | |||
.ql-snow .ql-color-picker .ql-picker-item { | |||
border: 1px solid transparent; | |||
float: left; | |||
height: 16px; | |||
margin: 2px; | |||
padding: 0px; | |||
width: 16px; | |||
} | |||
.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg { | |||
position: absolute; | |||
margin-top: -9px; | |||
right: 0; | |||
top: 50%; | |||
width: 18px; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=''])::before, | |||
.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=''])::before, | |||
.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=''])::before, | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=''])::before, | |||
.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=''])::before, | |||
.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=''])::before { | |||
content: attr(data-label); | |||
} | |||
.ql-snow .ql-picker.ql-header { | |||
width: 98px; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-label::before, | |||
.ql-snow .ql-picker.ql-header .ql-picker-item::before { | |||
content: 'Normal'; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]::before, | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before { | |||
content: 'Heading 1'; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]::before, | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before { | |||
content: 'Heading 2'; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]::before, | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before { | |||
content: 'Heading 3'; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]::before, | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before { | |||
content: 'Heading 4'; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]::before, | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before { | |||
content: 'Heading 5'; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]::before, | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]::before { | |||
content: 'Heading 6'; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before { | |||
font-size: 2em; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before { | |||
font-size: 1.5em; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before { | |||
font-size: 1.17em; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before { | |||
font-size: 1em; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before { | |||
font-size: 0.83em; | |||
} | |||
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]::before { | |||
font-size: 0.67em; | |||
} | |||
.ql-snow .ql-picker.ql-font { | |||
width: 108px; | |||
} | |||
.ql-snow .ql-picker.ql-font .ql-picker-label::before, | |||
.ql-snow .ql-picker.ql-font .ql-picker-item::before { | |||
content: 'Sans Serif'; | |||
} | |||
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]::before, | |||
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]::before { | |||
content: 'Serif'; | |||
} | |||
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]::before, | |||
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]::before { | |||
content: 'Monospace'; | |||
} | |||
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]::before { | |||
font-family: Georgia, Times New Roman, serif; | |||
} | |||
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]::before { | |||
font-family: Monaco, Courier New, monospace; | |||
} | |||
.ql-snow .ql-picker.ql-size { | |||
width: 98px; | |||
} | |||
.ql-snow .ql-picker.ql-size .ql-picker-label::before, | |||
.ql-snow .ql-picker.ql-size .ql-picker-item::before { | |||
content: 'Normal'; | |||
} | |||
.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]::before, | |||
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]::before { | |||
content: 'Small'; | |||
} | |||
.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]::before, | |||
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]::before { | |||
content: 'Large'; | |||
} | |||
.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]::before, | |||
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]::before { | |||
content: 'Huge'; | |||
} | |||
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]::before { | |||
font-size: 10px; | |||
} | |||
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]::before { | |||
font-size: 18px; | |||
} | |||
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]::before { | |||
font-size: 32px; | |||
} | |||
.ql-snow .ql-color-picker.ql-background .ql-picker-item { | |||
background-color: #fff; | |||
} | |||
.ql-snow .ql-color-picker.ql-color .ql-picker-item { | |||
background-color: #000; | |||
} | |||
.ql-toolbar.ql-snow { | |||
border: 1px solid #ccc; | |||
box-sizing: border-box; | |||
font-family: 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif; | |||
padding: 8px; | |||
} | |||
.ql-toolbar.ql-snow .ql-formats { | |||
margin-right: 15px; | |||
} | |||
.ql-toolbar.ql-snow .ql-picker-label { | |||
border: 1px solid transparent; | |||
} | |||
.ql-toolbar.ql-snow .ql-picker-options { | |||
border: 1px solid transparent; | |||
box-shadow: rgba(0,0,0,0.2) 0 2px 8px; | |||
} | |||
.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label { | |||
border-color: #ccc; | |||
} | |||
.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options { | |||
border-color: #ccc; | |||
} | |||
.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected, | |||
.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover { | |||
border-color: #000; | |||
} | |||
.ql-toolbar.ql-snow + .ql-container.ql-snow { | |||
border-top: 0px; | |||
} | |||
.ql-snow .ql-tooltip { | |||
background-color: #fff; | |||
border: 1px solid #ccc; | |||
box-shadow: 0px 0px 5px #ddd; | |||
color: #444; | |||
padding: 5px 12px; | |||
white-space: nowrap; | |||
} | |||
.ql-snow .ql-tooltip::before { | |||
content: "Visit URL:"; | |||
line-height: 26px; | |||
margin-right: 8px; | |||
} | |||
.ql-snow .ql-tooltip input[type=text] { | |||
display: none; | |||
border: 1px solid #ccc; | |||
font-size: 13px; | |||
height: 26px; | |||
margin: 0px; | |||
padding: 3px 5px; | |||
width: 170px; | |||
} | |||
.ql-snow .ql-tooltip a.ql-preview { | |||
display: inline-block; | |||
max-width: 200px; | |||
overflow-x: hidden; | |||
text-overflow: ellipsis; | |||
vertical-align: top; | |||
} | |||
.ql-snow .ql-tooltip a.ql-action::after { | |||
border-right: 1px solid #ccc; | |||
content: 'Edit'; | |||
margin-left: 16px; | |||
padding-right: 8px; | |||
} | |||
.ql-snow .ql-tooltip a.ql-remove::before { | |||
content: 'Remove'; | |||
margin-left: 8px; | |||
} | |||
.ql-snow .ql-tooltip a { | |||
line-height: 26px; | |||
} | |||
.ql-snow .ql-tooltip.ql-editing a.ql-preview, | |||
.ql-snow .ql-tooltip.ql-editing a.ql-remove { | |||
display: none; | |||
} | |||
.ql-snow .ql-tooltip.ql-editing input[type=text] { | |||
display: inline-block; | |||
} | |||
.ql-snow .ql-tooltip.ql-editing a.ql-action::after { | |||
border-right: 0px; | |||
content: 'Save'; | |||
padding-right: 0px; | |||
} | |||
.ql-snow .ql-tooltip[data-mode=link]::before { | |||
content: "Enter link:"; | |||
} | |||
.ql-snow .ql-tooltip[data-mode=formula]::before { | |||
content: "Enter formula:"; | |||
} | |||
.ql-snow .ql-tooltip[data-mode=video]::before { | |||
content: "Enter video:"; | |||
} | |||
.ql-snow a { | |||
color: #06c; | |||
} | |||
.ql-container.ql-snow { | |||
border: 1px solid #ccc; | |||
} |
@@ -1,10 +1,10 @@ | |||
// const base = 'http://81.70.55.170:9999' ;// 测试站 | |||
const base = 'http://81.70.55.170:9999' ;// 测试站 | |||
// const base = 'http://8kdmng.natappfree.cc' ;// 佳豪 | |||
// const base = 'http://192.168.31.134:9999' ;// 佳豪 | |||
// const base = 'http://192.168.31.86:9999' ;// 胜浩 | |||
// const base = 'http://192.168.31.167:9999' // 长龙 | |||
// const base = 'https://zanyong.hfju.com';// 正式 AI销管 | |||
const base = 'https://hxz.quhouse.com';// 正式 AI销讲助手 | |||
// const base = 'https://hxz.quhouse.com';// 正式 AI销讲助手 | |||
// http.js使用 | |||
const baseUrl = `${base}/autoSR/api`; | |||