12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757 |
- <template>
- <div id="app">
- <div class="scroll-top" @click="scrollToTop">🚀</div>
- <div class="logo">
- <div class="logo-text">
- <b>Lemon</b> IMUI<span class="logo-badge">{{
- this.packageData.version
- }}</span>
- </div>
- <div class="logo-sub">{{ this.packageData.description }}</div>
- <div class="link">
- <span>源码下载 </span>
- <a target="_blank" href="https://github.com/fanjyy/lemon-imui"
- >Github</a
- >
- <a target="_blank" href="https://gitee.com/june000/lemon-im">Gitee</a>
- <a
- target="_blank"
- href="https://qm.qq.com/cgi-bin/qm/qr?k=xzUa9CPYQ5KCNQ86h7ep4Z3TtkqJxRZE&jump_from=webapi"
- >QQ交流群:1081773406</a
- >
- </div>
- <br />
- <div><a style="font-size:14px;" href="#help1">1.如何创建消息?</a></div>
- <div>
- <a style="font-size:14px;" href="#help2">2.如何对接后端接口?</a>
- </div>
- </div>
- <div class="imui-center">
- <lemon-imui
- :user="user"
- ref="IMUI"
- :contextmenu="contextmenu"
- :contact-contextmenu="contactContextmenu"
- :theme="theme"
- :hide-menu="hideMenu"
- :hide-menu-avatar="hideMenuAvatar"
- :hide-message-name="hideMessageName"
- :hide-message-time="hideMessageTime"
- @change-menu="handleChangeMenu"
- @change-contact="handleChangeContact"
- @pull-messages="handlePullMessages"
- @message-click="handleMessageClick"
- @menu-avatar-click="handleMenuAvatarClick"
- @send="handleSend"
- >
- <template #cover>
- <div class="cover">
- <i class="lemon-icon-message"></i>
- <p><b>自定义封面 Lemon</b> IMUI</p>
- </div>
- </template>
- <template #message-title="contact">
- <span>{{ contact.displayName }}</span>
- <small class="more" @click="changeDrawer(contact, $refs.IMUI)"
- >{{
- ($refs.IMUI ? $refs.IMUI.drawerVisible : false) ? "关闭" : "打开"
- }}抽屉</small
- >
- <br />
- </template>
- </lemon-imui>
- <a
- target="_blank"
- style="font-size:14px"
- href="https://codesandbox.io/s/sweet-chaplygin-s24mb?fontsize=14&hidenavigation=1&theme=dark"
- >在线编辑代码</a
- >
- <div class="action">
- <lemon-button @click="appendMessage">发送消息</lemon-button>
- <lemon-button @click="appendEventMessage">发送 event 消息</lemon-button>
- <lemon-button @click="removeMessage">删除最近一条消息</lemon-button>
- <lemon-button @click="updateMessage">修改消息</lemon-button>
- <lemon-button @click="appendCustomMessage">发送消息</lemon-button>
- <br />
- <lemon-button @click="updateContact">修改联系人信息</lemon-button>
- <lemon-button @click="changeMenuVisible">切换导航显示</lemon-button>
- <lemon-button @click="changeMenuAvatarVisible"
- >切换头像显示</lemon-button
- >
- <lemon-button @click="changeMessageNameVisible"
- >切换聊天窗口内名字显示</lemon-button
- >
- <lemon-button @click="changeMessageTimeVisible"
- >切换聊天窗口内时间显示</lemon-button
- >
- <lemon-button @click="changeTheme"
- >切换主题,当前主题:{{ this.theme }}</lemon-button
- >
- </div>
- </div>
- <div style="display:flex;">
- <div>
- <div class="title">自定义</div>
- <div class="imui-center"><qq-imui>12312312</qq-imui></div>
- </div>
- <div style="margin:0 55px;">
- <div class="title">精简模式</div>
- <div class="imui-center">
- <lemon-imui
- class="lemon-simple"
- :user="user"
- ref="SimpleIMUI"
- width="340px"
- :avatar-cricle="true"
- simple
- @pull-messages="handlePullMessages"
- @message-click="handleMessageClick"
- @send="handleSend"
- ></lemon-imui>
- <a
- target="_blank"
- style="font-size:14px"
- href="https://codesandbox.io/s/lemon-imui-jingjianmoshi-forked-1lvoh?fontsize=14&hidenavigation=1&theme=dark"
- >在线编辑代码</a
- >
- </div>
- </div>
- </div>
- <div class="title">联系人 Contact</div>
- <table class="table">
- <tr class="table-head">
- <th>参数</th>
- <th>说明</th>
- <th>类型</th>
- <th>默认值</th>
- <th>示例</th>
- </tr>
- <tr>
- <td width="150">id</td>
- <td width="350">唯一ID</td>
- <td width="150">String/Number</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td>displayName</td>
- <td>名称</td>
- <td>String</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr></tr>
- <tr>
- <td>avatar</td>
- <td>头像</td>
- <td>String</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>index</td>
- <td>
- 通讯录索引,传入字母或数字进行排序,索引可以显示自定义文字“[1]群组”
- </td>
- <td>String</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>unread</td>
- <td>未读消息数</td>
- <td>Number</td>
- <td>0</td>
- <td></td>
- </tr>
- <tr>
- <td>lastSendTime</td>
- <td>最近一条消息的时间戳,13位毫秒</td>
- <td>timestamp</td>
- <td>0</td>
- <td></td>
- </tr>
- <tr>
- <td>lastContent</td>
- <td>最近一条消息的内容</td>
- <td>String | Vnode</td>
- <td></td>
- <td></td>
- </tr>
- </table>
- <div class="title">消息体 Message</div>
- <table class="table">
- <tr class="table-head">
- <th>参数</th>
- <th>说明</th>
- <th>类型</th>
- <th>默认值</th>
- <th>示例</th>
- </tr>
- <tr>
- <td width="150">id</td>
- <td width="350">唯一ID</td>
- <td width="150">String/Number</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td>status</td>
- <td>消息发送的状态:going | failed | succeed</td>
- <td>String</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr></tr>
- <tr>
- <td>type</td>
- <td>消息类型:file | image | text | event</td>
- <td>String | Vnode</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>sendTime</td>
- <td>消息发送时间,13位毫秒</td>
- <td>timestamp</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>content</td>
- <td>消息内容,如果type=file,此属性表示文件的URL地址</td>
- <td>String</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>fileSize</td>
- <td>文件大小</td>
- <td>Number</td>
- <td>0</td>
- <td></td>
- </tr>
- <tr>
- <td>fileName</td>
- <td>文件名称</td>
- <td>String</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>toContactId</td>
- <td>接收消息的联系人ID</td>
- <td>String | Number</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>fromUser</td>
- <td>消息发送人的信息</td>
- <td>Object</td>
- <td>-</td>
- <td>{id: "1",displayName: "测试",avatar: "url"};</td>
- </tr>
- </table>
- <div class="title">右键菜单 ContextmenuItem</div>
- <table class="table">
- <tr class="table-head">
- <th>名称</th>
- <th>说明</th>
- <th>类型</th>
- <th>示例</th>
- </tr>
- <tr>
- <td width="150">text</td>
- <td width="350">显示文字</td>
- <td width="150">String</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">color</td>
- <td width="350">颜色</td>
- <td width="150">String</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">icon</td>
- <td width="350">图标 class</td>
- <td width="150">String</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">click</td>
- <td width="350">点击事件,调用hide方法隐藏右键菜单。</td>
- <td width="150">Function(e,instance,hide)</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">visible</td>
- <td width="350">是否显示的判断函数</td>
- <td width="150">Function(instance)</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">render</td>
- <td width="350">
- 负责样式的渲染函数,使用render的时候text属性会失去作用,调用hide方法隐藏右键菜单。
- </td>
- <td width="150">Function(e,instance,hide)</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- </table>
- <div class="title">抽屉配置 DrawerOption</div>
- <table class="table">
- <tr class="table-head">
- <th>名称</th>
- <th>说明</th>
- <th>类型</th>
- <th>示例</th>
- </tr>
- <tr>
- <td width="150">width</td>
- <td width="350">宽度,可以设置百分比</td>
- <td width="150">String | Number</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">height</td>
- <td width="350">高度,可以设置百分比</td>
- <td width="150">String | Number</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">offsetX</td>
- <td width="350">X偏移值,可以设置百分比</td>
- <td width="150">String | Number</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">offsetY</td>
- <td width="350">Y偏移值,可以设置百分比</td>
- <td width="150">String | Number</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">position</td>
- <td width="350">位置</td>
- <td width="150">right | rightInside | center</td>
- <td width="100">-</td>
- <td></td>
- </tr>
- </table>
- <div class="title">组件属性</div>
- <table class="table">
- <tr class="table-head">
- <th>参数</th>
- <th>说明</th>
- <th>类型</th>
- <th>默认值</th>
- <th>示例</th>
- </tr>
- <tr>
- <td width="150">user</td>
- <td width="350">用户信息</td>
- <td width="150">Object</td>
- <td width="100">-</td>
- <td>{id: "1",displayName: "测试",avatar: "url"};</td>
- </tr>
- <tr>
- <td width="150">width</td>
- <td width="350">宽度</td>
- <td width="150">String</td>
- <td width="100">850px</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">height</td>
- <td width="350">高度</td>
- <td width="150">String</td>
- <td width="100">580px</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">theme</td>
- <td width="350">主题</td>
- <td width="150">default | blue</td>
- <td width="100">default</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">avatarCricle</td>
- <td width="350">使用圆形头像</td>
- <td width="150">Boolean</td>
- <td width="100">false</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">sendText</td>
- <td width="350">发送消息按钮的文字</td>
- <td width="150">String</td>
- <td width="100">发送消息</td>
- <td></td>
- </tr>
- <tr>
- <td width="150">sendKey</td>
- <td width="350">快捷发送键检查函数</td>
- <td width="150">Function(event)=>Boolean</td>
- <td width="100"></td>
- <td>(e)=>e.keyCode == 13 && e.ctrlKey</td>
- </tr>
- <tr>
- <td width="150">simple</td>
- <td width="350">精简模式</td>
- <td width="150">Boolean</td>
- <td width="100">false</td>
- <td>
- 精简模式下左侧的导航和联系人列表会隐藏,初始化时需要手动调用
- changeContact 切换到聊天视图。
- </td>
- </tr>
- <tr>
- <td>messageTimeFormat</td>
- <td>消息列表时间格式化函数</td>
- <td>Function(time)=>String</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>contactTimeFormat</td>
- <td>联系人时间格式化规则</td>
- <td>Function(time)=>String</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>hideDrawer</td>
- <td>是否隐藏抽屉</td>
- <td>Boolean</td>
- <td>true</td>
- <td></td>
- </tr>
- <tr>
- <td>hideMenuAvatar</td>
- <td>是否隐藏导航头像</td>
- <td>Boolean</td>
- <td>false</td>
- <td></td>
- </tr>
- <tr>
- <td>hideMenu</td>
- <td>是否隐藏左侧导航</td>
- <td>Boolean</td>
- <td>false</td>
- <td></td>
- </tr>
- <tr>
- <td>hideMessageName</td>
- <td>是否隐藏聊天窗口内的联系人名字</td>
- <td>Boolean</td>
- <td>false</td>
- <td></td>
- </tr>
- <tr>
- <td>hideMessageTime</td>
- <td>是否隐藏聊天窗口内的消息发送时间</td>
- <td>Boolean</td>
- <td>false</td>
- <td></td>
- </tr>
- <tr>
- <td>contextmenu</td>
- <td>聊天消息右键菜单配置</td>
- <td>[ContextmenuItem]</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>contactContextmenu</td>
- <td>联系人右键菜单配置</td>
- <td>[ContextmenuItem]</td>
- <td>-</td>
- <td></td>
- </tr>
- </table>
- <div class="title">组件方法</div>
- <table class="table">
- <tr class="table-head">
- <th>参数</th>
- <th>说明</th>
- <th>类型</th>
- <th>默认值</th>
- <th>示例</th>
- </tr>
- <tr>
- <td width="150">initMenus</td>
- <td width="350">初始化导航</td>
- <td width="150">Function([Object])</td>
- <td width="100">[ { name: "messages" }, { name: "contacts" }]</td>
- <td>
- { name: "custom2", title: "自定义按钮2", unread: 0, click: () => {
- alert("拦截导航点击事件"); }, render: menu => { return '...'; },
- isBottom: true }
- </td>
- </tr>
- <tr>
- <td>initContacts</td>
- <td>初始化联系人</td>
- <td>Function([Contact])</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>initEditorTools</td>
- <td>初始化工具栏</td>
- <td>Function([Object])</td>
- <td>[{name:'emoji'},{name:'uploadFile'},{name:'uploadImage'}]</td>
- <td>
- [{ name:"test2", isRight:true, title:'上传 Excel', click:()=>{
- alert('点击') }, render:()=>{ return '...' } }]
- </td>
- </tr>
- <tr>
- <td>initEmoji</td>
- <td>初始化表情数据</td>
- <td>Function([Object])</td>
- <td>-</td>
- <td>
- <div>
- 有分类:[{ label: '默认表情', children: [ { name: '1f62c', title:
- '微笑', src: 'https://twemoji.maxcdn.com/2/72x72/1f62c.png' } ] }]
- </div>
- <div>
- 无分类:[{ name: '1f62c', title: '微笑', src:
- 'https://twemoji.maxcdn.com/2/72x72/1f62c.png' }]
- </div>
- </td>
- </tr>
- <tr>
- <td>appendMessage</td>
- <td>
- 新增一条消息, 如果当前焦点在该联系人的聊天窗口,设置
- scrollToBottom=true 添加之后自动定位到消息窗口底部
- </td>
- <td>Function(Message,scrollToBottom=false)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>removeMessage</td>
- <td>删除聊天消息</td>
- <td>Function(Message.id)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>updateMessage</td>
- <td>
- 修改消息,根据 Message.id
- 查找聊天消息并覆盖传入的值(toContactId会被忽略)
- </td>
- <td>Function(Message)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>appendContact</td>
- <td>添加联系人</td>
- <td>Function(Contact)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>removeContact</td>
- <td>删除联系人</td>
- <td>Function(Contact.id)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>updateContact</td>
- <td>修改联系人,根据 Contact.id 查找联系人并覆盖传入的值</td>
- <td>Function(Contact)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>getMessages</td>
- <td>返回所有本地消息,传入 Contact.id 则只返回与该联系人的消息</td>
- <td>Function(Contact.id)=>[Message]</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>getCurrentContact</td>
- <td>返回当前聊天窗口的联系人信息</td>
- <td>Function()=>Contact</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>getCurrentMessages</td>
- <td>返回当前聊天窗口的所有消息</td>
- <td>Function()=>[Message]</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>getContacts</td>
- <td>返回所有本地联系人</td>
- <td>Function()=>[Contact]</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>openDrawer</td>
- <td>打开联系人右侧抽屉,vnode 为抽屉内容</td>
- <td>Function(vnode)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>changeDrawer</td>
- <td>切换右侧抽屉显示/隐藏,vnode 为抽屉内容</td>
- <td>Function(DrawerOption)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>closeDrawer</td>
- <td>关闭抽屉</td>
- <td>Function()</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>changeMenu</td>
- <td>切换左侧导航</td>
- <td>Function(Menu.name)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>changeContact</td>
- <td>切换聊天窗口</td>
- <td>Function(Contact.id,instance)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>messageViewToBottom</td>
- <td>将当前聊天窗口滚动到底部</td>
- <td>Function()</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>setLastContentRender</td>
- <td>设置左侧联系人最新消息的渲染函数</td>
- <td>Function(Message.type, (Message)=>vnode)</td>
- <td>-</td>
- <td>
- setLastContentRender('image', message => { return
- <span>[最新图片]</span>
- })
- </td>
- </tr>
- <tr>
- <td>lastContentRender</td>
- <td>用来生成 Message.lastContent 需要的vnode结构。</td>
- <td>Function(Message)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>setEditorValue</td>
- <td>设置编辑框内容</td>
- <td>Function(string)</td>
- <td>-</td>
- <td></td>
- </tr>
- <tr>
- <td>getEditorValue</td>
- <td>获取编辑框内容</td>
- <td>Function()=>string</td>
- <td>-</td>
- <td></td>
- </tr>
- </table>
- <div class="title">组件插槽</div>
- <table class="table">
- <tr class="table-head">
- <th>插槽名</th>
- <th>说明</th>
- <th>参数</th>
- </tr>
- <tr>
- <td width="150">cover</td>
- <td width="350">初始化时的封面</td>
- <td width="150">-</td>
- </tr>
- <tr>
- <td width="150">editor-footer</td>
- <td width="350">消息输入框底部</td>
- <td width="150">-</td>
- </tr>
- <tr>
- <td width="150">message-title</td>
- <td width="350">消息列表的标题</td>
- <td width="150">Contact</td>
- </tr>
- <tr>
- <td width="150">message-after</td>
- <td width="350">每条消息的尾部</td>
- <td width="150">Message</td>
- </tr>
- <tr>
- <td width="150">sidebar-message</td>
- <td width="350">左侧最新消息列表插槽</td>
- <td width="150">Contact</td>
- </tr>
- <tr>
- <td width="150">sidebar-contact</td>
- <td width="350">左侧联系人列表插槽</td>
- <td width="150">Contact</td>
- </tr>
- <tr>
- <td width="150">sidebar-message-top</td>
- <td width="350">左侧最新消息列表的顶部,会随列表滚动</td>
- <td width="150">instance</td>
- </tr>
- <tr>
- <td width="150">sidebar-contact-top</td>
- <td width="350">左侧联系人列表的顶部,会随列表滚动</td>
- <td width="150">instance</td>
- </tr>
- <tr>
- <td width="150">sidebar-message-fixedtop</td>
- <td width="350">固定在左侧最新消息列表的顶部</td>
- <td width="150">instance</td>
- </tr>
- <tr>
- <td width="150">sidebar-contact-fixedtop</td>
- <td width="350">固定在左侧联系人列表的顶部</td>
- <td width="150">instance</td>
- </tr>
- <tr>
- <td width="150">contact-info</td>
- <td width="350">左侧联系人详细页</td>
- <td width="150">Contact</td>
- </tr>
- </table>
- <div class="title">组件事件</div>
- <table class="table">
- <tr class="table-head">
- <th>事件名</th>
- <th>说明</th>
- <th>参数</th>
- </tr>
- <tr>
- <td width="150">change-menu</td>
- <td width="350">当左侧导航选项卡切换的时候会触发该事件</td>
- <td width="150">Menu.name</td>
- </tr>
- <tr>
- <td width="150">menu-avatar-click</td>
- <td width="350">当左侧导航内的头像被点击时回触发该事件</td>
- <td width="150">Contact</td>
- </tr>
- <tr>
- <td width="150">change-contact</td>
- <td width="350">当左侧联系人点击时会触发该事件</td>
- <td width="150">Contact</td>
- </tr>
- <tr>
- <td width="150">pull-messages</td>
- <td width="350">
- 当切换聊天对象或者聊天窗口滚动到顶部时会触发该事件,调用next方法结束loading状态,如果设置了isEnd=true,下次聊天窗口滚动到顶部将不会再触发该事件
- </td>
- <td width="150">Contact,next([Message],isEnd),instance</td>
- </tr>
- <tr>
- <td width="150">message-click</td>
- <td width="350">点击聊天窗口中的消息时会触发该事件</td>
- <td width="150">event,key,Message,instance</td>
- </tr>
- <tr>
- <td width="150">send</td>
- <td width="350">当发送新消息时会触发该事件</td>
- <td width="150">
- Message,Function(Message):调用该函数完成消息发送,可以传入Message来改变消息内容,file:上传时的文件
- </td>
- </tr>
- </table>
- <div class="title" id="help1">如何创建消息?</div>
- <div>
- <p>
- Lemon-IMUI
- 目前内置了file、image、text、event四种消息类型,在实际应用当中肯定是不够的哦,咋办?没事的,我们继续往下see。<br />要创建消息首先要确定新消息的
- Message 结构。
- </p>
- <pre>
- {
- //值为 voice,用于解析的组件 name 必须为 lemonMessageVoice
- type: "voice",
- content: '语音消息',
- //自定义参数
- params1:'参数1',
- params2:'参数2',
- //必传参数
- id: "message-id",
- //必传参数
- fromUser:{
- avatar: ""
- displayName: "June"
- id: "1"
- },
- //必传参数
- sendTime: 1610872045162
- //必传参数
- status: "succeed"
- //必传参数
- toContactId: "contact-id"
- }
- </pre
- >
- <p>创建用于解析该消息的组件。</p>
- <pre>{{ tip }}</pre>
- <p>IMUI初始化的时候,设置左侧联系人最新消息的渲染内容</p>
- <pre>
- IMUI.setLastContentRender('voice', message => {
- return <span>[语音]</span>
- })
- </pre
- >
- <p>最后一步,注册组件,必须使用全局注册的方式。</p>
- <pre>
- import Vue from 'vue';
- import LemonMessageVoice from './lemon-message-voice';
- Vue.component(LemonMessageVoice.name,LemonMessageVoice);
- </pre
- >
- <p>如果还有不明白的,可以到 examples/App.vue 查看示例代码</p>
- </div>
- <div class="title" id="help2">如何对接后端接口?</div>
- <p>1.初始化用户的信息</p>
- <pre
- v-text="
- `data(){
- return {
- user:{id:1:displayName:'June',avatar:''}
- }
- }`
- "
- ></pre>
- <pre
- v-text="`<lemon-imui :user='this.user' ref='IMUI'></lemon-imui>`"
- ></pre>
- <p>2.初始化联系人数据</p>
- <pre
- v-text="
- `mounted(){
- const { IMUI } = this.$refs;
- //初始化表情包。
- IMUI.initEmoji(...);
- //从后端请求联系人数据,包装成下面的样子
- const contacts = [{
- id: 2,
- displayName: '丽安娜',
- avatar:'',
- index: 'L',
- unread: 0,
- //最近一条消息的内容,如果值为空,不会出现在“聊天”列表里面。
- //lastContentRender 函数会将 file 消息转换为 '[文件]', image 消息转换为 '[图片]',对 text 会将文字里的表情标识替换为img标签,
- lastContent: IMUI.lastContentRender({type:'text',content:'你在干嘛呢?'})
- //最近一条消息的发送时间
- lastSendTime: 1566047865417,
- }];
- IMUI.initContacts(contacts);
- }`
- "
- ></pre>
- <p>3.拉取消息列表</p>
- <p>
- 现在刷新页面应该能够看到联系人了,但是点击联系人的话右边会一直处于加载中,这时需要监听
- pull-messages 事件。
- </p>
- <pre
- v-text="
- `<lemon-imui :user='this.user' ref='IMUI' @pull-messages='handlePullMessages'></lemon-imui>`
- "
- ></pre>
- <pre
- v-text="
- `methods:{
- handlePullMessages(contact, next) {
- //从后端请求消息数据,包装成下面的样子
- const messages = [{
- id: '唯一消息ID',
- status: 'succeed',
- type: 'text',
- sendTime: 1566047865417,
- content: '你什么才能对接完?',
- toContactId: contact.id,
- fromUser:this.user
- }]
- //将第二个参数设为true,表示已到末尾,聊天窗口顶部会显示“暂无更多消息”,不然会一直转圈。
- next(messages,true);
- },
- }`
- "
- ></pre>
- <p>4.发送消息</p>
- <p>现在在消息框发送新消息会一直转圈,这时需要监听 send 事件。</p>
- <pre
- v-text="
- `methods:{
- handleSend(message, next, file) {
- ... 调用你的消息发送业务接口
- //执行到next消息会停止转圈,如果接口调用失败,可以修改消息的状态 next({status:'failed'});
- next();
- },
- }`
- "
- ></pre>
- <p>5.接收消息</p>
- <pre
- v-text="
- `mounted(){
- WebSocket.onmessage = function(event) {
- //将接收到的数据包装成下面的样子
- const data = {
- id: '唯一消息ID',
- status: 'succeed',
- type: 'text',
- sendTime: 1566047865417,
- content: '马上就对接完了!',
- toContactId: 2,
- fromUser:{
- //如果 id == this.user.id消息会显示在右侧,否则在左侧
- id:2,
- displayName:'丽安娜',
- avatar:'',
- }
- };
- IMUI.appendMessage(data);
- };
-
- }`
- "
- ></pre>
- </div>
- </template>
- <script>
- import Vue from "vue";
- import LemonMessageVoice from "./lemon-message-voice";
- import QQIMUI from "./qq";
- import packageData from "../package.json";
- import EmojiData from "./database/emoji";
- Vue.component(LemonMessageVoice.name, LemonMessageVoice);
- Vue.component(QQIMUI.name, QQIMUI);
- const tip = `export default {
- //组件的name必须以lemonMessage开头,后面跟上 Message.type
- name: "lemonMessageVoice",
- inheritAttrs: false,
- //如果需要使用父组件的方法,可以使用注入。
- inject: ["IMUI"],
- render() {
- //lemon-message-basic 组件对气泡框、头像、事件等信息进行了公共的处理。
- return (
- <lemon-message-basic
- class="lemon-message-voice"
- props={{ ...this.$attrs }}
- scopedSlots={{
- content: props => {
- //返回HTML结构
- return <span>{props.content} 🔈</span>
- }
- }}
- />
- );
- }
- };
- <style lang="stylus">
- .lemon-message.lemon-message-voice
- user-select none
- .lemon-message__content
- border 2px solid #000
- font-size 12px
- cursor pointer
- &::before
- display none
- </style>`;
- const getTime = () => {
- return new Date().getTime();
- };
- const generateRandId = () => {
- return Math.random()
- .toString(36)
- .substr(-8);
- };
- const generateRandWord = () => {
- return Math.random()
- .toString(36)
- .substr(2);
- };
- const generateMessage = (toContactId = "", fromUser) => {
- if (!fromUser) {
- fromUser = {
- id: "system",
- displayName: "系统测试",
- avatar: "http://upload.qqbodys.com/allimg/1710/1035512943-0.jpg",
- };
- }
- return {
- id: generateRandId(),
- status: "succeed",
- type: "text",
- sendTime: getTime(),
- content: generateRandWord(),
- //fileSize: 1231,
- //fileName: "asdasd.doc",
- toContactId,
- fromUser,
- };
- };
- export default {
- name: "app",
- data() {
- return {
- theme: "default",
- contactContextmenu: [
- {
- text: "删除该聊天",
- click: (e, instance, hide) => {
- const { IMUI, contact } = instance;
- IMUI.updateContact({
- id: contact.id,
- lastContent: null,
- });
- if (IMUI.currentContactId == contact.id) IMUI.changeContact(null);
- hide();
- },
- },
- {
- text: "设置备注和标签",
- },
- {
- text: "投诉",
- },
- {
- icon: "lemon-icon-message",
- render: (h, instance, hide) => {
- return (
- <div style="display:flex;justify-content:space-between;align-items:center;width:130px">
- <span>加入黑名单</span>
- <span>
- <input type="checkbox" id="switch" />
- <label id="switch-label" for="switch">
- Toggle
- </label>
- </span>
- </div>
- );
- },
- },
- {
- click(e, instance, hide) {
- const { IMUI, contact } = instance;
- IMUI.removeContact(contact.id);
- if (IMUI.currentContactId == contact.id) IMUI.changeContact(null);
- hide();
- },
- color: "red",
- text: "删除好友",
- },
- ],
- contextmenu: [
- {
- click: (e, instance, hide) => {
- const { IMUI, message } = instance;
- const data = {
- id: generateRandId(),
- type: "event",
- //使用 jsx 时 click必须使用箭头函数(使上下文停留在vue内)
- content: (
- <div>
- <span>
- 你撤回了一条消息{" "}
- <span
- v-show={message.type == "text"}
- style="color:#333;cursor:pointer"
- content={message.content}
- on-click={e => {
- IMUI.setEditorValue(e.target.getAttribute("content"));
- }}
- >
- 重新编辑
- </span>
- </span>
- </div>
- ),
- toContactId: message.toContactId,
- sendTime: getTime(),
- };
- IMUI.removeMessage(message.id);
- IMUI.appendMessage(data, true);
- hide();
- },
- visible: instance => {
- return instance.message.fromUser.id == this.user.id;
- },
- text: "撤回消息",
- },
- {
- visible: instance => {
- return instance.message.fromUser.id != this.user.id;
- },
- text: "举报",
- },
- {
- text: "转发",
- },
- {
- visible: instance => {
- return instance.message.type == "text";
- },
- text: "复制文字",
- },
- {
- visible: instance => {
- return instance.message.type == "image";
- },
- text: "下载图片",
- },
- {
- visible: instance => {
- return instance.message.type == "file";
- },
- text: "下载文件",
- },
- {
- click: (e, instance, hide) => {
- const { IMUI, message } = instance;
- IMUI.removeMessage(message.id);
- hide();
- },
- icon: "lemon-icon-folder",
- color: "red",
- text: "删除",
- },
- ],
- tip: tip,
- packageData,
- hideMenuAvatar: false,
- hideMenu: false,
- hideMessageName: false,
- hideMessageTime: true,
- user: {
- id: "1",
- displayName: "June",
- avatar: "",
- },
- };
- },
- mounted() {
- const contactData1 = {
- id: "contact-1",
- displayName: "工作协作群",
- avatar: "http://upload.qqbodys.com/img/weixin/20170804/ji5qxg1am5ztm.jpg",
- index: "[1]群组",
- unread: 0,
- lastSendTime: 1566047865417,
- lastContent: "2",
- };
- const contactData2 = {
- id: "contact-2",
- displayName: "自定义内容",
- avatar: "http://upload.qqbodys.com/img/weixin/20170807/jibfvfd00npin.jpg",
- //index: "Z",
- click(next) {
- next();
- },
- renderContainer: () => {
- return <h1 style="text-indent:20px">自定义页面</h1>;
- },
- lastSendTime: 1345209465000,
- lastContent: "12312",
- unread: 2,
- };
- const contactData3 = {
- id: "contact-3",
- displayName: "铁牛",
- avatar: "http://upload.qqbodys.com/img/weixin/20170803/jiq4nzrkrnd0e.jpg",
- index: "T",
- unread: 32,
- lastSendTime: 3,
- lastContent: "你好123",
- };
- const contactData4 = {
- id: "contact-4",
- displayName: "如花",
- avatar:
- "https://dss2.bdstatic.com/70cFvnSh_Q1YnxGkpoWK1HF6hhy/it/u=4275424924,2201401076&fm=111&gp=0.jpg",
- index: "",
- unread: 1,
- lastSendTime: 3,
- lastContent: "吃饭了嘛",
- };
- const { IMUI } = this.$refs;
- setTimeout(() => {
- IMUI.changeContact("contact-1");
- }, 500);
- IMUI.setLastContentRender("event", message => {
- return `[自定义通知内容]`;
- });
- let contactList = [
- { ...contactData1 },
- { ...contactData2 },
- { ...contactData3 },
- //...Array(100).fill(contactData1)
- ];
- IMUI.initContacts(contactList);
- IMUI.initMenus([
- {
- name: "messages",
- },
- {
- name: "contacts",
- },
- {
- name: "custom1",
- title: "自定义按钮1",
- unread: 0,
- render: menu => {
- return <i class="lemon-icon-attah" />;
- },
- renderContainer: () => {
- return (
- <div class="article">
- <ul>
- <li class="article-item">
- <h2>人民日报谈网红带货:产品真的值得买吗?</h2>
- </li>
- <li class="article-item">
- 甘肃夏河县发生5.7级地震 暂未接到人员伤亡报告
- </li>
- <li class="article-item">
- 北方多地风力仍强沙尘相伴,东北内蒙古等地迎雨雪
- </li>
- <li class="article-item">
- 英货车案:越南警方采集疑死者家属DNA作比对
- </li>
- <li class="article-item">
- 知名连锁咖啡店的蛋糕吃出活虫 曝光内幕太震惊
- </li>
- </ul>
- <lemon-contact
- props={{ contact: contactData1 }}
- style="margin:20px"
- />
- <lemon-contact
- props={{ contact: contactData3 }}
- style="margin:20px"
- />
- </div>
- );
- },
- isBottom: true,
- },
- {
- name: "custom2",
- title: "自定义按钮2",
- unread: 0,
- click: () => {
- alert("拦截导航点击事件");
- },
- render: menu => {
- return <i class="lemon-icon-group" />;
- },
- isBottom: true,
- },
- ]);
- IMUI.initEditorTools([
- {
- name: "emoji",
- },
- {
- name: "uploadFile",
- },
- {
- name: "uploadImage",
- },
- {
- name: "test1",
- click: () => {
- IMUI.$refs.editor.selectFile("application/vnd.ms-excel");
- },
- render: () => {
- return <span>Excel</span>;
- },
- },
- {
- name: "test1",
- click: () => {
- IMUI.initEditorTools([{ name: "uploadFile" }, { name: "emoji" }]);
- },
- render: () => {
- return <span>重制工具栏</span>;
- },
- },
- {
- name: "test2",
- isRight: true,
- title: "上传 Excel",
- click: () => {
- alert("点击了 ··· ");
- },
- render: () => {
- return <b>···</b>;
- },
- },
- ]);
- IMUI.initEmoji(EmojiData);
- IMUI.setLastContentRender("voice", message => {
- return <span>[语音]</span>;
- });
- const { SimpleIMUI } = this.$refs;
- contactData1.id = "11";
- SimpleIMUI.initContacts([contactData1]);
- SimpleIMUI.initEmoji(EmojiData);
- SimpleIMUI.changeContact(contactData1.id);
- },
- methods: {
- changeTheme() {
- this.theme = this.theme == "default" ? "blue" : "default";
- },
- scrollToTop() {
- document.body.scrollIntoView();
- },
- handleMenuAvatarClick() {
- console.log("Event:menu-avatar-click");
- },
- handleMessageClick(e, key, message, instance) {
- console.log("点击了消息", e, key, message);
- if (key == "status") {
- instance.updateMessage({
- id: message.id,
- status: "going",
- content: "正在重新发送消息...",
- });
- setTimeout(() => {
- instance.updateMessage({
- id: message.id,
- status: "succeed",
- content: "发送成功",
- });
- }, 2000);
- }
- },
- changeMenuAvatarVisible() {
- this.hideMenuAvatar = !this.hideMenuAvatar;
- },
- changeMenuVisible() {
- this.hideMenu = !this.hideMenu;
- },
- changeMessageNameVisible() {
- this.hideMessageName = !this.hideMessageName;
- },
- changeMessageTimeVisible() {
- this.hideMessageTime = !this.hideMessageTime;
- },
- removeMessage() {
- const { IMUI } = this.$refs;
- const messages = IMUI.getCurrentMessages();
- const id = messages[messages.length - 1].id;
- if (messages.length > 0) {
- IMUI.removeMessage(id);
- }
- },
- updateMessage() {
- const { IMUI } = this.$refs;
- const messages = IMUI.getCurrentMessages();
- const message = messages[messages.length - 1];
- if (messages.length > 0) {
- const update = {
- id: message.id,
- status: "succeed",
- type: "file",
- fileName: "被修改成文件了.txt",
- fileSize: "4200000",
- };
- if (message.type == "event") {
- update.fromUser = this.user;
- }
- IMUI.updateMessage(update);
- IMUI.messageViewToBottom();
- }
- },
- appendCustomMessage() {
- const { IMUI } = this.$refs;
- const message = {
- id: generateRandId(),
- status: "succeed",
- type: "voice",
- sendTime: getTime(),
- content: "语音消息",
- params1: "1",
- params2: "2",
- toContactId: "contact-1",
- fromUser: this.user,
- };
- IMUI.appendMessage(message, true);
- },
- appendMessage() {
- const { IMUI } = this.$refs;
- const contact = IMUI.currentContact;
- const message = generateMessage("contact-3");
- message.fromUser = {
- ...message.fromUser,
- ...this.user,
- };
- IMUI.appendMessage(message, true);
- },
- appendEventMessage() {
- const { IMUI } = this.$refs;
- const message = {
- id: generateRandId(),
- type: "event",
- content: (
- <span>
- 邀请你加入群聊{" "}
- <span
- style="color:#333;cursor:pointer"
- on-click={() => alert("OK")}
- >
- 接受
- </span>
- </span>
- ),
- toContactId: "contact-3",
- sendTime: getTime(),
- };
- IMUI.appendMessage(message, true);
- },
- updateContact() {
- this.$refs.IMUI.updateContact({
- id: "contact-3",
- unread: 10,
- displayName: generateRandWord(),
- lastSendTime: getTime(),
- lastContent: "修改昵称为随机字母",
- });
- },
- changeDrawer(contact, instance) {
- instance.changeDrawer({
- //width: 240,
- //height: "90%",
- //offsetX:0 ,
- //offsetY: ,
- //position: "center",
- // inside: true,
- // offsetX: -280,
- // offsetY: -100,
- render: () => {
- return (
- <div class="drawer-content">
- <p>
- <b>自定义抽屉</b>
- </p>
- <p>{contact.displayName}</p>
- </div>
- );
- },
- });
- },
- handleChangeContact(contact, instance) {
- console.log("Event:change-contact");
- instance.updateContact({
- id: contact.id,
- unread: 0,
- });
- instance.closeDrawer();
- },
- handleSend(message, next, file) {
- console.log(message, next, file);
- setTimeout(() => {
- next();
- }, 1000);
- },
- handlePullMessages(contact, next, instance) {
- const otheruser = {
- id: contact.id,
- displayName: contact.displayName,
- avatar: contact.avatar,
- };
- setTimeout(() => {
- const messages = [
- generateMessage(instance.currentContactId, this.user),
- generateMessage(instance.currentContactId, otheruser),
- generateMessage(instance.currentContactId, this.user),
- generateMessage(instance.currentContactId, otheruser),
- generateMessage(instance.currentContactId, this.user),
- generateMessage(instance.currentContactId, this.user),
- generateMessage(instance.currentContactId, otheruser),
- {
- ...generateMessage(instance.currentContactId, this.user),
- ...{ status: "failed" },
- },
- ];
- let isEnd = false;
- if (
- instance.getMessages(instance.currentContactId).length +
- messages.length >
- 11
- )
- isEnd = true;
- next(messages, isEnd);
- }, 500);
- },
- handleChangeMenu() {
- console.log("Event:change-menu");
- },
- openCustomContainer() {},
- },
- };
- </script>
- <style lang="stylus">
- ::selection{background:#000;color:#fff;}
- body
- font-family "Microsoft YaHei"
- background #f6f6f6 !important
- #app
- width 90%
- margin 0 auto
- padding-bottom 100px
- .scroll-top
- cursor pointer
- position fixed
- bottom 40px
- left 50%
- border-radius 50%
- background #fff
- font-size 18px
- overflow hidden
- width 40px
- height 40px
- line-height 40px
- user-select none
- text-align center
- transform rotate(-45deg) translateX(-50%)
- box-shadow 0 0 30px rgba(0,0,0,0.1);
- &:hover
- font-size 22px
- a
- color #0c5ed9
- text-decoration none
- font-size 12px
- .action
- margin-top 20px
- .lemon-button
- margin-right 10px
- margin-bottom 10px
- .link
- font-size 14px
- margin-top 15px
- a
- display inline-block
- margin 0 5px
- text-decoration none
- background #ffba00
- border-radius 4px
- padding 5px 10px
- color rgba(0,0,0,0.8)
- .logo
- position relative
- display inline-block
- margin 60px auto
- user-select none
- .logo-text
- font-size 38px
- .logo-sub
- font-size 18px
- color #999
- font-weight 300
- .logo-badge
- position absolute
- top -10px
- left 230px
- background #000
- border-radius 16px
- color #f9f9f9
- font-size 12px
- padding 4px 8px
- .title
- font-size 24px
- line-height 26px
- border-left 1px solid #ffba00
- padding-left 15px
- margin-bottom 15px
- margin-top 30px
- user-select none
- .table
- width 100%
- border-radius 10px
- background #fff
- border-collapse collapse
- tr
- cursor pointer
- tr:not(.table-head):hover
- background #ffba00 !important
- tr:nth-of-type(even)
- background #f9f9f9
- th
- user-select none
- color #999
- td,
- th
- text-align left
- padding 10px 15px
- font-size 14px
- font-weight normal
- .imui-center
- margin-bottom 60px
- .lemon-wrapper
- border:1px solid #ddd;
- .lemon-drawer
- border:1px solid #ddd;
- border-left:0;
- .drawer-content
- padding 15px
- .more
- font-size 12px
- line-height 24px
- height 24px
- position absolute
- top 14px
- right 14px
- cursor pointer
- user-select none
- color #f1f1f1
- display inline-block
- border-radius 4px
- background #111
- padding 0 8px
- &:active
- background #999
- .bar
- text-align center
- line-height 30px
- background #fff
- margin 15px
- color #666
- user-select none
- font-size 12px
- .cover
- text-align center
- user-select none
- position absolute
- top 50%
- left 50%
- transform translate(-50%,-50%)
- i
- font-size 84px
- color #e6e6e6
- p
- font-size 18px
- color #ddd
- line-height 50px
- .article-item
- line-height 34px
- cursor pointer
- &:hover
- text-decoration underline
- color #318efd
- pre
- background #fff
- border-radius 8px
- padding 15px
- .lemon-simple .lemon-container{
- z-index:5
- }
- .lemon-simple .lemon-drawer{
- z-index:4
- }
- input#switch[type=checkbox]{
- height: 0;
- width: 0;
- display:none;
- }
- label#switch-label {
- cursor: pointer;
- text-indent: -9999px;
- width: 34px;
- height: 20px;
- background: #aaa;
- display: block;
- border-radius: 100px;
- position: relative;
- }
- label#switch-label:after {
- content: '';
- position: absolute;
- top: 2px;
- left: 2px;
- width: 16px;
- height: 16px;
- background: #fff;
- border-radius: 20px;
- transition: 0.3s;
- }
- input#switch:checked + label {
- background: #0fd547;
- }
- input#switch:checked + label:after {
- left: calc(100% - 2px);
- transform: translateX(-100%);
- }
- label#switch-label:active:after {
- width: 20px;
- }
- </style>
|