163 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Vue
		
	
	
| <template>
 | |
|   <section :class="['code-box', isOpen ? 'expand': '']">
 | |
|     <section class="code-box-demo">
 | |
|       <slot name="component"></slot>
 | |
|     </section>
 | |
|     <section class="code-box-meta markdown">
 | |
|       <slot v-if="lang === 'cn'" name="description"></slot>
 | |
|       <slot v-else name="us-description"></slot>
 | |
|       <span class="btn-toggle" :class="{open: isOpen}" @click="toggle"><i class="anticon anticon-down-circle-o"></i></span>
 | |
|     </section>
 | |
|     <transition appear :css="false" @enter="enter" @leave="leave">
 | |
|       <section class="highlight-wrapper" style="position: relative;" v-show="isOpen">
 | |
|         <a-tooltip
 | |
|           :title="copied ? 'ๅคๅถๆๅ' : 'ๅคๅถไปฃ็ '"
 | |
|           :visible="copyTooltipVisible"
 | |
|           @change="onCopyTooltipVisibleChange"
 | |
|         >
 | |
|           <a-icon
 | |
|             :type="copied && copyTooltipVisible ? 'check' : 'copy'"
 | |
|             class="code-box-code-copy"
 | |
|             v-clipboard:copy="sourceCode"
 | |
|             v-clipboard:success="handleCodeCopied"
 | |
|           />
 | |
|         </a-tooltip>
 | |
|         <slot name="code"></slot>
 | |
|       </section>
 | |
|     </transition>
 | |
|   </section>
 | |
| </template>
 | |
| <script>
 | |
| import animate from 'antd/_util/openAnimation'
 | |
| import BaseMixin from 'antd/_util/BaseMixin'
 | |
| export default {
 | |
|   mixins: [BaseMixin],
 | |
|   name: 'demoBox',
 | |
|   props: {
 | |
|     jsfiddle: Object,
 | |
|   },
 | |
|   data () {
 | |
|     const { lang } = this.$route.params
 | |
|     const { html, script, style } = this.jsfiddle
 | |
|     let sourceCode = `<template>${html}</template>\n`
 | |
|     sourceCode = script ? sourceCode + '\<script>' + script + '<\/script>' : sourceCode
 | |
|     sourceCode = style ? sourceCode + '\<style>' + style + '<\/style>' : sourceCode
 | |
|     return {
 | |
|       isOpen: false,
 | |
|       lang,
 | |
|       copied: false,
 | |
|       copyTooltipVisible: false,
 | |
|       sourceCode,
 | |
|     }
 | |
|   },
 | |
|   methods: {
 | |
|     toggle () {
 | |
|       this.isOpen = !this.isOpen
 | |
|     },
 | |
|     enter: animate.enter,
 | |
|     leave: animate.leave,
 | |
|     handleCodeCopied () {
 | |
|       this.setState({ copied: true })
 | |
|     },
 | |
| 
 | |
|     onCopyTooltipVisibleChange (visible) {
 | |
|       if (visible) {
 | |
|         this.setState({
 | |
|           copyTooltipVisible: visible,
 | |
|           copied: false,
 | |
|         })
 | |
|         return
 | |
|       }
 | |
|       this.setState({
 | |
|         copyTooltipVisible: visible,
 | |
|       })
 | |
|     },
 | |
|   },
 | |
| }
 | |
| </script>
 | |
| <style scoped lang="less">
 | |
| .box-demo{
 | |
|   padding: 0;
 | |
|   border: 1px solid #e9e9e9;
 | |
|   border-radius: 4px;
 | |
|   box-shadow: none;
 | |
|   margin-top: 20px;
 | |
|   margin-bottom: 20px;
 | |
| }
 | |
| .box-demo-show{
 | |
|   padding: 20px 25px 30px;
 | |
|   border-bottom: 1px solid #e9e9e9;
 | |
| }
 | |
| .box-demo-description{
 | |
|   position: relative;
 | |
|   padding: 17px 16px 15px 20px;
 | |
|   border-radius: 0 0 6px 6px;
 | |
|   -webkit-transition: background-color 0.4s ease;
 | |
|   transition: background-color 0.4s ease;
 | |
|   width: 100%;
 | |
|   font-size: 12px;
 | |
|   &.bordered{
 | |
|     border-bottom: 1px dashed #e9e9e9;
 | |
|   }
 | |
|   h3, h4{
 | |
|     position: absolute;
 | |
|     top: -14px;
 | |
|     padding: 1px 8px;
 | |
|     margin-left: -8px;
 | |
|     margin-top: 0;
 | |
|     margin-bottom: 0;
 | |
|     color: #777;
 | |
|     border-radius: 4px;
 | |
|     border-top-left-radius: 0;
 | |
|     background: #fff;
 | |
|     -webkit-transition: background-color 0.4s ease;
 | |
|     transition: background-color 0.4s ease;
 | |
|     .header-anchor{
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
|   li{
 | |
|     line-height: 21px;
 | |
|   }
 | |
| }
 | |
| .box-demo-code{
 | |
|   -webkit-transition: height .2s ease-in-out;
 | |
|   transition: height .2s ease-in-out;
 | |
|   overflow: auto;
 | |
|   border-top: 1px dashed #e9e9e9;
 | |
|   pre {
 | |
|     margin: 0;
 | |
|   }
 | |
|   code{
 | |
|     margin: 0;
 | |
|     background: #f7f7f7;
 | |
|     padding: .2em .4em;
 | |
|     border-radius: 3px;
 | |
|     font-size: .9em;
 | |
|     border: 1px solid #eee;
 | |
|   }
 | |
| }
 | |
| .btn-toggle{
 | |
|   position: absolute;
 | |
|   right: 16px;
 | |
|   bottom: 17px;
 | |
|   cursor: pointer;
 | |
|   width: 18px;
 | |
|   height: 18px;
 | |
|   font-size: 18px;
 | |
|   line-height: 18px;
 | |
|   color: #999;
 | |
|   i{
 | |
|     -webkit-transition: all 0.3s;
 | |
|     transition: all 0.3s;
 | |
|   }
 | |
|   &.open{
 | |
|     i{
 | |
|       -webkit-transform: rotate(-180deg);
 | |
|       -ms-transform: rotate(-180deg);
 | |
|       transform: rotate(-180deg);
 | |
|     }
 | |
|   }
 | |
| }
 | |
| </style>
 |