lint code
This commit is contained in:
		| @@ -22,6 +22,7 @@ module.exports = { | ||||
|       } | ||||
|     }], | ||||
|     "vue/name-property-casing": ["error", "PascalCase"], | ||||
|     "vue/no-v-html": "off", | ||||
|     'accessor-pairs': 2, | ||||
|     'arrow-spacing': [2, { | ||||
|       'before': true, | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| <template> | ||||
|   <div id="app"> | ||||
|     <router-view/> | ||||
|     <router-view /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| export default{ | ||||
| export default { | ||||
|   name: 'App' | ||||
| } | ||||
| </script> | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|       <svg width="16" height="16" viewBox="0 0 17 17" xmlns="http://www.w3.org/2000/svg" class="Icon Icon--backToTopArrow" aria-hidden="true" style="height: 16px; width: 16px;"> | ||||
|         <title>回到顶部</title> | ||||
|         <g> | ||||
|           <path d="M12.036 15.59c0 .55-.453.995-.997.995H5.032c-.55 0-.997-.445-.997-.996V8.584H1.03c-1.1 0-1.36-.633-.578-1.416L7.33.29c.39-.39 1.026-.385 1.412 0l6.878 6.88c.782.78.523 1.415-.58 1.415h-3.004v7.004z" fill-rule="evenodd"/> | ||||
|           <path d="M12.036 15.59c0 .55-.453.995-.997.995H5.032c-.55 0-.997-.445-.997-.996V8.584H1.03c-1.1 0-1.36-.633-.578-1.416L7.33.29c.39-.39 1.026-.385 1.412 0l6.878 6.88c.782.78.523 1.415-.58 1.415h-3.004v7.004z" fill-rule="evenodd" /> | ||||
|         </g> | ||||
|       </svg> | ||||
|     </div> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <div :class="className" :id="id" :style="{height:height,width:width}"/> | ||||
|   <div :id="id" :class="className" :style="{height:height,width:width}" /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <div :class="className" :id="id" :style="{height:height,width:width}"/> | ||||
|   <div :id="id" :class="className" :style="{height:height,width:width}" /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <div :class="className" :id="id" :style="{height:height,width:width}"/> | ||||
|   <div :id="id" :class="className" :style="{height:height,width:width}" /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -4,10 +4,12 @@ | ||||
|       <h3>{{ list1Title }}</h3> | ||||
|       <draggable :list="list1" :options="{group:'article'}" class="dragArea"> | ||||
|         <div v-for="element in list1" :key="element.id" class="list-complete-item"> | ||||
|           <div class="list-complete-item-handle">{{ element.id }}[{{ element.author }}] {{ element.title }}</div> | ||||
|           <div class="list-complete-item-handle"> | ||||
|             {{ element.id }}[{{ element.author }}] {{ element.title }} | ||||
|           </div> | ||||
|           <div style="position:absolute;right:0px;"> | ||||
|             <span style="float: right ;margin-top: -20px;margin-right:5px;" @click="deleteEle(element)"> | ||||
|               <i style="color:#ff4949" class="el-icon-delete"/> | ||||
|               <i style="color:#ff4949" class="el-icon-delete" /> | ||||
|             </span> | ||||
|           </div> | ||||
|         </div> | ||||
| @@ -17,7 +19,9 @@ | ||||
|       <h3>{{ list2Title }}</h3> | ||||
|       <draggable :list="list2" :options="{group:'article'}" class="dragArea"> | ||||
|         <div v-for="element in list2" :key="element.id" class="list-complete-item"> | ||||
|           <div class="list-complete-item-handle2" @click="pushEle(element)">{{ element.id }} [{{ element.author }}] {{ element.title }}</div> | ||||
|           <div class="list-complete-item-handle2" @click="pushEle(element)"> | ||||
|             {{ element.id }} [{{ element.author }}] {{ element.title }} | ||||
|           </div> | ||||
|         </div> | ||||
|       </draggable> | ||||
|     </div> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
|   <el-select ref="dragSelect" v-model="selectVal" v-bind="$attrs" class="drag-select" multiple v-on="$listeners"> | ||||
|     <slot/> | ||||
|     <slot /> | ||||
|   </el-select> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <div :ref="id" :action="url" :id="id" class="dropzone"> | ||||
|   <div :id="id" :ref="id" :action="url" class="dropzone"> | ||||
|     <input type="file" name="file"> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -12,17 +12,23 @@ | ||||
|           <template slot-scope="scope"> | ||||
|             <div> | ||||
|               <span class="message-title">Msg:</span> | ||||
|               <el-tag type="danger">{{ scope.row.err.message }}</el-tag> | ||||
|               <el-tag type="danger"> | ||||
|                 {{ scope.row.err.message }} | ||||
|               </el-tag> | ||||
|             </div> | ||||
|             <br> | ||||
|             <div> | ||||
|               <span class="message-title" style="padding-right: 10px;">Info: </span> | ||||
|               <el-tag type="warning">{{ scope.row.vm.$vnode.tag }} error in {{ scope.row.info }}</el-tag> | ||||
|               <el-tag type="warning"> | ||||
|                 {{ scope.row.vm.$vnode.tag }} error in {{ scope.row.info }} | ||||
|               </el-tag> | ||||
|             </div> | ||||
|             <br> | ||||
|             <div> | ||||
|               <span class="message-title" style="padding-right: 16px;">Url: </span> | ||||
|               <el-tag type="success">{{ scope.row.url }}</el-tag> | ||||
|               <el-tag type="success"> | ||||
|                 {{ scope.row.url }} | ||||
|               </el-tag> | ||||
|             </div> | ||||
|           </template> | ||||
|         </el-table-column> | ||||
| @@ -33,7 +39,6 @@ | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
|     </el-dialog> | ||||
|  | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -5,17 +5,20 @@ | ||||
|       height="80" | ||||
|       viewBox="0 0 250 250" | ||||
|       style="fill:#40c9c6; color:#fff;" | ||||
|       aria-hidden="true"> | ||||
|       <path d="M0,0 L115,115 L130,115 L142,142 L250,250 L250,0 Z"/> | ||||
|       aria-hidden="true" | ||||
|     > | ||||
|       <path d="M0,0 L115,115 L130,115 L142,142 L250,250 L250,0 Z" /> | ||||
|       <path | ||||
|         d="M128.3,109.0 C113.8,99.7 119.0,89.6 119.0,89.6 C122.0,82.7 120.5,78.6 120.5,78.6 C119.2,72.0 123.4,76.3 123.4,76.3 C127.3,80.9 125.5,87.3 125.5,87.3 C122.9,97.6 130.6,101.9 134.4,103.2" | ||||
|         fill="currentColor" | ||||
|         style="transform-origin: 130px 106px;" | ||||
|         class="octo-arm"/> | ||||
|         class="octo-arm" | ||||
|       /> | ||||
|       <path | ||||
|         d="M115.0,115.0 C114.9,115.1 118.7,116.5 119.8,115.4 L133.7,101.6 C136.9,99.2 139.9,98.4 142.2,98.6 C133.8,88.0 127.5,74.4 143.8,58.0 C148.5,53.4 154.0,51.2 159.7,51.0 C160.3,49.4 163.2,43.6 171.4,40.1 C171.4,40.1 176.1,42.5 178.8,56.2 C183.1,58.6 187.2,61.8 190.9,65.4 C194.5,69.0 197.7,73.2 200.1,77.6 C213.8,80.2 216.3,84.9 216.3,84.9 C212.7,93.1 206.9,96.0 205.4,96.6 C205.1,102.4 203.0,107.8 198.3,112.5 C181.9,128.9 168.3,122.5 157.7,114.1 C157.9,116.9 156.7,120.9 152.7,124.9 L141.0,136.5 C139.8,137.7 141.6,141.9 141.8,141.8 Z" | ||||
|         fill="currentColor" | ||||
|         class="octo-body"/> | ||||
|         class="octo-body" | ||||
|       /> | ||||
|     </svg> | ||||
|   </a> | ||||
| </template> | ||||
|   | ||||
| @@ -10,8 +10,9 @@ | ||||
|       remote | ||||
|       placeholder="Search" | ||||
|       class="header-search-select" | ||||
|       @change="change"> | ||||
|       <el-option v-for="item in options" :key="item.path" :value="item" :label="item.title.join(' > ')"/> | ||||
|       @change="change" | ||||
|     > | ||||
|       <el-option v-for="item in options" :key="item.path" :value="item" :label="item.title.join(' > ')" /> | ||||
|     </el-select> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -2,22 +2,22 @@ | ||||
|   <div v-show="value" class="vue-image-crop-upload"> | ||||
|     <div class="vicp-wrap"> | ||||
|       <div class="vicp-close" @click="off"> | ||||
|         <i class="vicp-icon4"/> | ||||
|         <i class="vicp-icon4" /> | ||||
|       </div> | ||||
|  | ||||
|       <div v-show="step == 1" class="vicp-step1"> | ||||
|         <div class="vicp-drop-area" @dragleave="preventDefault" @dragover="preventDefault" @dragenter="preventDefault" @click="handleClick" @drop="handleChange"> | ||||
|           <i v-show="loading != 1" class="vicp-icon1"> | ||||
|             <i class="vicp-icon1-arrow"/> | ||||
|             <i class="vicp-icon1-body"/> | ||||
|             <i class="vicp-icon1-bottom"/> | ||||
|             <i class="vicp-icon1-arrow" /> | ||||
|             <i class="vicp-icon1-body" /> | ||||
|             <i class="vicp-icon1-bottom" /> | ||||
|           </i> | ||||
|           <span v-show="loading !== 1" class="vicp-hint">{{ lang.hint }}</span> | ||||
|           <span v-show="!isSupported" class="vicp-no-supported-hint">{{ lang.noSupported }}</span> | ||||
|           <input v-show="false" v-if="step == 1" ref="fileinput" type="file" @change="handleChange"> | ||||
|         </div> | ||||
|         <div v-show="hasError" class="vicp-error"> | ||||
|           <i class="vicp-icon2"/> {{ errorMsg }} | ||||
|           <i class="vicp-icon2" /> {{ errorMsg }} | ||||
|         </div> | ||||
|         <div class="vicp-operate"> | ||||
|           <a @click="off" @mousedown="ripple">{{ lang.btn.off }}</a> | ||||
| @@ -48,15 +48,16 @@ | ||||
|                 @mousedown="imgStartMove" | ||||
|                 @mousemove="imgMove" | ||||
|                 @mouseup="createImg" | ||||
|                 @mouseout="createImg"> | ||||
|               <div :style="sourceImgShadeStyle" class="vicp-img-shade vicp-img-shade-1"/> | ||||
|               <div :style="sourceImgShadeStyle" class="vicp-img-shade vicp-img-shade-2"/> | ||||
|                 @mouseout="createImg" | ||||
|               > | ||||
|               <div :style="sourceImgShadeStyle" class="vicp-img-shade vicp-img-shade-1" /> | ||||
|               <div :style="sourceImgShadeStyle" class="vicp-img-shade vicp-img-shade-2" /> | ||||
|             </div> | ||||
|  | ||||
|             <div class="vicp-range"> | ||||
|               <input :value="scale.range" type="range" step="1" min="0" max="100" @input="zoomChange"> | ||||
|               <i class="vicp-icon5" @mousedown="startZoomSub" @mouseout="endZoomSub" @mouseup="endZoomSub"/> | ||||
|               <i class="vicp-icon6" @mousedown="startZoomAdd" @mouseout="endZoomAdd" @mouseup="endZoomAdd"/> | ||||
|               <i class="vicp-icon5" @mousedown="startZoomSub" @mouseout="endZoomSub" @mouseup="endZoomSub" /> | ||||
|               <i class="vicp-icon6" @mousedown="startZoomAdd" @mouseout="endZoomAdd" @mouseup="endZoomAdd" /> | ||||
|             </div> | ||||
|  | ||||
|             <div v-if="!noRotate" class="vicp-rotate"> | ||||
| @@ -87,13 +88,13 @@ | ||||
|         <div class="vicp-upload"> | ||||
|           <span v-show="loading === 1" class="vicp-loading">{{ lang.loading }}</span> | ||||
|           <div class="vicp-progress-wrap"> | ||||
|             <span v-show="loading === 1" :style="progressStyle" class="vicp-progress"/> | ||||
|             <span v-show="loading === 1" :style="progressStyle" class="vicp-progress" /> | ||||
|           </div> | ||||
|           <div v-show="hasError" class="vicp-error"> | ||||
|             <i class="vicp-icon2"/> {{ errorMsg }} | ||||
|             <i class="vicp-icon2" /> {{ errorMsg }} | ||||
|           </div> | ||||
|           <div v-show="loading === 2" class="vicp-success"> | ||||
|             <i class="vicp-icon3"/> {{ lang.success }} | ||||
|             <i class="vicp-icon3" /> {{ lang.success }} | ||||
|           </div> | ||||
|         </div> | ||||
|         <div class="vicp-operate"> | ||||
| @@ -101,7 +102,7 @@ | ||||
|           <a @click="off" @mousedown="ripple">{{ lang.btn.close }}</a> | ||||
|         </div> | ||||
|       </div> | ||||
|       <canvas v-show="false" ref="canvas" :width="width" :height="height"/> | ||||
|       <canvas v-show="false" ref="canvas" :width="width" :height="height" /> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
|   <div class="json-editor"> | ||||
|     <textarea ref="textarea"/> | ||||
|     <textarea ref="textarea" /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -6,7 +6,8 @@ | ||||
|     <draggable | ||||
|       :list="list" | ||||
|       :options="options" | ||||
|       class="board-column-content"> | ||||
|       class="board-column-content" | ||||
|     > | ||||
|       <div v-for="element in list" :key="element.id" class="board-item"> | ||||
|         {{ element.name }} {{ element.id }} | ||||
|       </div> | ||||
|   | ||||
| @@ -4,9 +4,15 @@ | ||||
|       <svg-icon class-name="international-icon" icon-class="language" /> | ||||
|     </div> | ||||
|     <el-dropdown-menu slot="dropdown"> | ||||
|       <el-dropdown-item :disabled="language==='zh'" command="zh">中文</el-dropdown-item> | ||||
|       <el-dropdown-item :disabled="language==='en'" command="en">English</el-dropdown-item> | ||||
|       <el-dropdown-item :disabled="language==='es'" command="es">Español</el-dropdown-item> | ||||
|       <el-dropdown-item :disabled="language==='zh'" command="zh"> | ||||
|         中文 | ||||
|       </el-dropdown-item> | ||||
|       <el-dropdown-item :disabled="language==='en'" command="en"> | ||||
|         English | ||||
|       </el-dropdown-item> | ||||
|       <el-dropdown-item :disabled="language==='es'" command="es"> | ||||
|         Español | ||||
|       </el-dropdown-item> | ||||
|     </el-dropdown-menu> | ||||
|   </el-dropdown> | ||||
| </template> | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| <template> | ||||
|   <div :class="computedClasses" class="material-input__component"> | ||||
|     <div :class="{iconClass:icon}"> | ||||
|       <i v-if="icon" :class="['el-icon-' + icon]" class="el-input__icon material-input__icon"/> | ||||
|       <i v-if="icon" :class="['el-icon-' + icon]" class="el-input__icon material-input__icon" /> | ||||
|       <input | ||||
|         v-if="type === 'email'" | ||||
|         v-model="currentValue" | ||||
|         :name="name" | ||||
|         :placeholder="fillPlaceHolder" | ||||
|         v-model="currentValue" | ||||
|         :readonly="readonly" | ||||
|         :disabled="disabled" | ||||
|         :autoComplete="autoComplete" | ||||
| @@ -15,12 +15,13 @@ | ||||
|         class="material-input" | ||||
|         @focus="handleMdFocus" | ||||
|         @blur="handleMdBlur" | ||||
|         @input="handleModelInput"> | ||||
|         @input="handleModelInput" | ||||
|       > | ||||
|       <input | ||||
|         v-if="type === 'url'" | ||||
|         v-model="currentValue" | ||||
|         :name="name" | ||||
|         :placeholder="fillPlaceHolder" | ||||
|         v-model="currentValue" | ||||
|         :readonly="readonly" | ||||
|         :disabled="disabled" | ||||
|         :autoComplete="autoComplete" | ||||
| @@ -29,12 +30,13 @@ | ||||
|         class="material-input" | ||||
|         @focus="handleMdFocus" | ||||
|         @blur="handleMdBlur" | ||||
|         @input="handleModelInput"> | ||||
|         @input="handleModelInput" | ||||
|       > | ||||
|       <input | ||||
|         v-if="type === 'number'" | ||||
|         v-model="currentValue" | ||||
|         :name="name" | ||||
|         :placeholder="fillPlaceHolder" | ||||
|         v-model="currentValue" | ||||
|         :step="step" | ||||
|         :readonly="readonly" | ||||
|         :disabled="disabled" | ||||
| @@ -48,12 +50,13 @@ | ||||
|         class="material-input" | ||||
|         @focus="handleMdFocus" | ||||
|         @blur="handleMdBlur" | ||||
|         @input="handleModelInput"> | ||||
|         @input="handleModelInput" | ||||
|       > | ||||
|       <input | ||||
|         v-if="type === 'password'" | ||||
|         v-model="currentValue" | ||||
|         :name="name" | ||||
|         :placeholder="fillPlaceHolder" | ||||
|         v-model="currentValue" | ||||
|         :readonly="readonly" | ||||
|         :disabled="disabled" | ||||
|         :autoComplete="autoComplete" | ||||
| @@ -64,12 +67,13 @@ | ||||
|         class="material-input" | ||||
|         @focus="handleMdFocus" | ||||
|         @blur="handleMdBlur" | ||||
|         @input="handleModelInput"> | ||||
|         @input="handleModelInput" | ||||
|       > | ||||
|       <input | ||||
|         v-if="type === 'tel'" | ||||
|         v-model="currentValue" | ||||
|         :name="name" | ||||
|         :placeholder="fillPlaceHolder" | ||||
|         v-model="currentValue" | ||||
|         :readonly="readonly" | ||||
|         :disabled="disabled" | ||||
|         :autoComplete="autoComplete" | ||||
| @@ -78,12 +82,13 @@ | ||||
|         class="material-input" | ||||
|         @focus="handleMdFocus" | ||||
|         @blur="handleMdBlur" | ||||
|         @input="handleModelInput"> | ||||
|         @input="handleModelInput" | ||||
|       > | ||||
|       <input | ||||
|         v-if="type === 'text'" | ||||
|         v-model="currentValue" | ||||
|         :name="name" | ||||
|         :placeholder="fillPlaceHolder" | ||||
|         v-model="currentValue" | ||||
|         :readonly="readonly" | ||||
|         :disabled="disabled" | ||||
|         :autoComplete="autoComplete" | ||||
| @@ -94,10 +99,11 @@ | ||||
|         class="material-input" | ||||
|         @focus="handleMdFocus" | ||||
|         @blur="handleMdBlur" | ||||
|         @input="handleModelInput"> | ||||
|       <span class="material-input-bar"/> | ||||
|         @input="handleModelInput" | ||||
|       > | ||||
|       <span class="material-input-bar" /> | ||||
|       <label class="material-label"> | ||||
|         <slot/> | ||||
|         <slot /> | ||||
|       </label> | ||||
|     </div> | ||||
|   </div> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <div :id="id"/> | ||||
|   <div :id="id" /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -9,7 +9,8 @@ | ||||
|       :total="total" | ||||
|       v-bind="$attrs" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange"/> | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|   <div :style="{zIndex:zIndex,height:height,width:width}" class="pan-item"> | ||||
|     <div class="pan-info"> | ||||
|       <div class="pan-info-roles-container"> | ||||
|         <slot/> | ||||
|         <slot /> | ||||
|       </div> | ||||
|     </div> | ||||
|     <img :src="image" class="pan-thumb"> | ||||
|   | ||||
| @@ -4,8 +4,10 @@ | ||||
|       <svg-icon class-name="size-icon" icon-class="size" /> | ||||
|     </div> | ||||
|     <el-dropdown-menu slot="dropdown"> | ||||
|       <el-dropdown-item v-for="item of sizeOptions" :key="item.value" :disabled="size===item.value" :command="item.value">{{ | ||||
|       item.label }}</el-dropdown-item> | ||||
|       <el-dropdown-item v-for="item of sizeOptions" :key="item.value" :disabled="size===item.value" :command="item.value"> | ||||
|         {{ | ||||
|           item.label }} | ||||
|       </el-dropdown-item> | ||||
|     </el-dropdown-menu> | ||||
|   </el-dropdown> | ||||
| </template> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
|   <svg :class="svgClass" aria-hidden="true" v-on="$listeners"> | ||||
|     <use :xlink:href="iconName"/> | ||||
|     <use :xlink:href="iconName" /> | ||||
|   </svg> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| <template> | ||||
|   <a :class="className" class="link--mallki" href="#"> | ||||
|     {{ text }} | ||||
|     <span :data-letters="text"/> | ||||
|     <span :data-letters="text"/> | ||||
|     <span :data-letters="text" /> | ||||
|     <span :data-letters="text" /> | ||||
|   </a> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -2,7 +2,8 @@ | ||||
|   <el-color-picker | ||||
|     v-model="theme" | ||||
|     class="theme-picker" | ||||
|     popper-class="theme-picker-dropdown"/> | ||||
|     popper-class="theme-picker-dropdown" | ||||
|   /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| <template> | ||||
|   <div class="upload-container"> | ||||
|     <el-button :style="{background:color,borderColor:color}" icon="el-icon-upload" size="mini" type="primary" @click=" dialogVisible=true">上传图片 | ||||
|     <el-button :style="{background:color,borderColor:color}" icon="el-icon-upload" size="mini" type="primary" @click=" dialogVisible=true"> | ||||
|       上传图片 | ||||
|     </el-button> | ||||
|     <el-dialog :visible.sync="dialogVisible"> | ||||
|       <el-upload | ||||
| @@ -12,11 +13,18 @@ | ||||
|         :before-upload="beforeUpload" | ||||
|         class="editor-slide-upload" | ||||
|         action="https://httpbin.org/post" | ||||
|         list-type="picture-card"> | ||||
|         <el-button size="small" type="primary">点击上传</el-button> | ||||
|         list-type="picture-card" | ||||
|       > | ||||
|         <el-button size="small" type="primary"> | ||||
|           点击上传 | ||||
|         </el-button> | ||||
|       </el-upload> | ||||
|       <el-button @click="dialogVisible = false">取 消</el-button> | ||||
|       <el-button type="primary" @click="handleSubmit">确 定</el-button> | ||||
|       <el-button @click="dialogVisible = false"> | ||||
|         取 消 | ||||
|       </el-button> | ||||
|       <el-button type="primary" @click="handleSubmit"> | ||||
|         确 定 | ||||
|       </el-button> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| <template> | ||||
|   <div :class="{fullscreen:fullscreen}" class="tinymce-container editor-container"> | ||||
|     <textarea :id="tinymceId" class="tinymce-textarea"/> | ||||
|     <textarea :id="tinymceId" class="tinymce-textarea" /> | ||||
|     <div class="editor-custom-btn-container"> | ||||
|       <editorImage color="#1890ff" class="editor-upload-btn" @successCBK="imageSuccessCBK"/> | ||||
|       <editorImage color="#1890ff" class="editor-upload-btn" @successCBK="imageSuccessCBK" /> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -1,18 +1,19 @@ | ||||
| <template> | ||||
|   <el-table :data="tableData" :row-style="showRow" v-bind="$attrs" v-on="$listeners" > | ||||
|   <el-table :data="tableData" :row-style="showRow" v-bind="$attrs" v-on="$listeners"> | ||||
|     <slot name="selection" /> | ||||
|     <slot name="pre-column" /> | ||||
|     <el-table-column | ||||
|       v-for="item in columns" | ||||
|       :label="item.label" | ||||
|       :key="item.key" | ||||
|       :label="item.label" | ||||
|       :width="item.width" | ||||
|       :align="item.align||'center'" | ||||
|       :header-align="item.headerAlign"> | ||||
|       :header-align="item.headerAlign" | ||||
|     > | ||||
|       <template slot-scope="scope"> | ||||
|         <slot :scope="scope" :name="item.key"> | ||||
|           <template v-if="item.expand"> | ||||
|             <span :style="{'padding-left':+scope.row._level*indent + 'px'} "/> | ||||
|             <span :style="{'padding-left':+scope.row._level*indent + 'px'} " /> | ||||
|             <span v-show="showSperadIcon(scope.row)" class="tree-ctrl" @click="toggleExpanded(scope.$index)"> | ||||
|               <i v-if="!scope.row._expand" class="el-icon-plus" /> | ||||
|               <i v-else class="el-icon-minus" /> | ||||
| @@ -21,15 +22,17 @@ | ||||
|           <template v-if="item.checkbox"> | ||||
|             <el-checkbox | ||||
|               v-if="scope.row[defaultChildren]&&scope.row[defaultChildren].length>0" | ||||
|               v-model="scope.row._select" | ||||
|               :style="{'padding-left':+scope.row._level*indent + 'px'} " | ||||
|               :indeterminate="scope.row._select" | ||||
|               v-model="scope.row._select" | ||||
|               @change="handleCheckAllChange(scope.row)" /> | ||||
|               @change="handleCheckAllChange(scope.row)" | ||||
|             /> | ||||
|             <el-checkbox | ||||
|               v-else | ||||
|               :style="{'padding-left':+scope.row._level*indent + 'px'} " | ||||
|               v-model="scope.row._select" | ||||
|               @change="handleCheckAllChange(scope.row)" /> | ||||
|               :style="{'padding-left':+scope.row._level*indent + 'px'} " | ||||
|               @change="handleCheckAllChange(scope.row)" | ||||
|             /> | ||||
|           </template> | ||||
|           {{ scope.row[item.key] }} | ||||
|         </slot> | ||||
|   | ||||
| @@ -7,15 +7,18 @@ | ||||
|       :on-success="handleImageSuccess" | ||||
|       class="image-uploader" | ||||
|       drag | ||||
|       action="https://httpbin.org/post"> | ||||
|       <i class="el-icon-upload"/> | ||||
|       <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div> | ||||
|       action="https://httpbin.org/post" | ||||
|     > | ||||
|       <i class="el-icon-upload" /> | ||||
|       <div class="el-upload__text"> | ||||
|         将文件拖到此处,或<em>点击上传</em> | ||||
|       </div> | ||||
|     </el-upload> | ||||
|     <div class="image-preview"> | ||||
|       <div v-show="imageUrl.length>1" class="image-preview-wrapper"> | ||||
|         <img :src="imageUrl+'?imageView2/1/w/200/h/200'"> | ||||
|         <div class="image-preview-action"> | ||||
|           <i class="el-icon-delete" @click="rmImage"/> | ||||
|           <i class="el-icon-delete" @click="rmImage" /> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|   | ||||
| @@ -7,15 +7,18 @@ | ||||
|       :on-success="handleImageSuccess" | ||||
|       class="image-uploader" | ||||
|       drag | ||||
|       action="https://httpbin.org/post"> | ||||
|       <i class="el-icon-upload"/> | ||||
|       <div class="el-upload__text">Drag或<em>点击上传</em></div> | ||||
|       action="https://httpbin.org/post" | ||||
|     > | ||||
|       <i class="el-icon-upload" /> | ||||
|       <div class="el-upload__text"> | ||||
|         Drag或<em>点击上传</em> | ||||
|       </div> | ||||
|     </el-upload> | ||||
|     <div v-show="imageUrl.length>0" class="image-preview"> | ||||
|       <div v-show="imageUrl.length>1" class="image-preview-wrapper"> | ||||
|         <img :src="imageUrl"> | ||||
|         <div class="image-preview-action"> | ||||
|           <i class="el-icon-delete" @click="rmImage"/> | ||||
|           <i class="el-icon-delete" @click="rmImage" /> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|   | ||||
| @@ -7,15 +7,18 @@ | ||||
|       :on-success="handleImageSuccess" | ||||
|       class="image-uploader" | ||||
|       drag | ||||
|       action="https://httpbin.org/post"> | ||||
|       <i class="el-icon-upload"/> | ||||
|       <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div> | ||||
|       action="https://httpbin.org/post" | ||||
|     > | ||||
|       <i class="el-icon-upload" /> | ||||
|       <div class="el-upload__text"> | ||||
|         将文件拖到此处,或<em>点击上传</em> | ||||
|       </div> | ||||
|     </el-upload> | ||||
|     <div class="image-preview image-app-preview"> | ||||
|       <div v-show="imageUrl.length>1" class="image-preview-wrapper"> | ||||
|         <img :src="imageUrl"> | ||||
|         <div class="image-preview-action"> | ||||
|           <i class="el-icon-delete" @click="rmImage"/> | ||||
|           <i class="el-icon-delete" @click="rmImage" /> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
| @@ -23,7 +26,7 @@ | ||||
|       <div v-show="imageUrl.length>1" class="image-preview-wrapper"> | ||||
|         <img :src="imageUrl"> | ||||
|         <div class="image-preview-action"> | ||||
|           <i class="el-icon-delete" @click="rmImage"/> | ||||
|           <i class="el-icon-delete" @click="rmImage" /> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|   | ||||
| @@ -3,7 +3,9 @@ | ||||
|     <input ref="excel-upload-input" class="excel-upload-input" type="file" accept=".xlsx, .xls" @change="handleClick"> | ||||
|     <div class="drop" @drop="handleDrop" @dragover="handleDragover" @dragenter="handleDragover"> | ||||
|       Drop excel file here or | ||||
|       <el-button :loading="loading" style="margin-left:16px;" size="mini" type="primary" @click="handleUpload">Browse</el-button> | ||||
|       <el-button :loading="loading" style="margin-left:16px;" size="mini" type="primary" @click="handleUpload"> | ||||
|         Browse | ||||
|       </el-button> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| export default{ | ||||
| export default { | ||||
|   bind(el, binding, vnode) { | ||||
|     const dialogHeaderEl = el.querySelector('.el-dialog__header') | ||||
|     const dragDom = el.querySelector('.el-dialog') | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
|  | ||||
| import store from '@/store' | ||||
|  | ||||
| export default{ | ||||
| export default { | ||||
|   inserted(el, binding, vnode) { | ||||
|     const { value } = binding | ||||
|     const roles = store.getters && store.getters.roles | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import './waves.css' | ||||
|  | ||||
| export default{ | ||||
| export default { | ||||
|   bind(el, binding) { | ||||
|     el.addEventListener('click', e => { | ||||
|       const customOpts = Object.assign({}, binding.value) | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
|   <div class="chart-container"> | ||||
|     <chart height="100%" width="100%"/> | ||||
|     <chart height="100%" width="100%" /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
|   <div class="chart-container"> | ||||
|     <chart height="100%" width="100%"/> | ||||
|     <chart height="100%" width="100%" /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
|   <div class="chart-container"> | ||||
|     <chart height="100%" width="100%"/> | ||||
|     <chart height="100%" width="100%" /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -2,12 +2,16 @@ | ||||
|   <div class="app-container"> | ||||
|     <el-tabs v-model="activeName"> | ||||
|       <el-tab-pane label="use clipboard  directly" name="directly"> | ||||
|         <el-input v-model="inputData" placeholder="Please input" style="width:400px;max-width:100%;"/> | ||||
|         <el-button type="primary" icon="document" @click="handleCopy(inputData,$event)">copy</el-button> | ||||
|         <el-input v-model="inputData" placeholder="Please input" style="width:400px;max-width:100%;" /> | ||||
|         <el-button type="primary" icon="document" @click="handleCopy(inputData,$event)"> | ||||
|           copy | ||||
|         </el-button> | ||||
|       </el-tab-pane> | ||||
|       <el-tab-pane label="use clipboard by v-directive" name="v-directive"> | ||||
|         <el-input v-model="inputData" placeholder="Please input" style="width:400px;max-width:100%;"/> | ||||
|         <el-button v-clipboard:copy="inputData" v-clipboard:success="clipboardSuccess" type="primary" icon="document">copy</el-button> | ||||
|         <el-input v-model="inputData" placeholder="Please input" style="width:400px;max-width:100%;" /> | ||||
|         <el-button v-clipboard:copy="inputData" v-clipboard:success="clipboardSuccess" type="primary" icon="document"> | ||||
|           copy | ||||
|         </el-button> | ||||
|       </el-tab-pane> | ||||
|     </el-tabs> | ||||
|   </div> | ||||
|   | ||||
| @@ -5,20 +5,22 @@ | ||||
|       {{ $t('components.imageUploadTips') }} | ||||
|     </code> | ||||
|  | ||||
|     <pan-thumb :image="image"/> | ||||
|     <pan-thumb :image="image" /> | ||||
|  | ||||
|     <el-button type="primary" icon="upload" style="position: absolute;bottom: 15px;margin-left: 40px;" @click="imagecropperShow=true">Change Avatar | ||||
|     <el-button type="primary" icon="upload" style="position: absolute;bottom: 15px;margin-left: 40px;" @click="imagecropperShow=true"> | ||||
|       Change Avatar | ||||
|     </el-button> | ||||
|  | ||||
|     <image-cropper | ||||
|       v-show="imagecropperShow" | ||||
|       :key="imagecropperKey" | ||||
|       :width="300" | ||||
|       :height="300" | ||||
|       :key="imagecropperKey" | ||||
|       url="https://httpbin.org/post" | ||||
|       lang-type="en" | ||||
|       @close="close" | ||||
|       @crop-upload-success="cropSuccess"/> | ||||
|       @crop-upload-success="cropSuccess" | ||||
|     /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -116,7 +116,7 @@ | ||||
|     <!--可自定义按钮的样式、show/hide临界点、返回的位置  --> | ||||
|     <!--如需文字提示,可在外部添加element的<el-tooltip></el-tooltip>元素  --> | ||||
|     <el-tooltip placement="top" content="tooltip"> | ||||
|       <back-to-top :custom-style="myBackToTopStyle" :visibility-height="300" :back-position="50" transition-name="fade"/> | ||||
|       <back-to-top :custom-style="myBackToTopStyle" :visibility-height="300" :back-position="50" transition-name="fade" /> | ||||
|     </el-tooltip> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -13,31 +13,36 @@ | ||||
|       :prefix="_prefix" | ||||
|       :suffix="_suffix" | ||||
|       :autoplay="false" | ||||
|       class="example"/> | ||||
|       class="example" | ||||
|     /> | ||||
|     <div style="margin-left: 25%;margin-top: 40px;"> | ||||
|       <label class="label" for="startValInput">startVal: | ||||
|         <input v-model.number="setStartVal" type="number" name="startValInput" > | ||||
|         <input v-model.number="setStartVal" type="number" name="startValInput"> | ||||
|       </label> | ||||
|       <label class="label" for="endValInput">endVal: | ||||
|         <input v-model.number="setEndVal" type="number" name="endVaInput" > | ||||
|         <input v-model.number="setEndVal" type="number" name="endVaInput"> | ||||
|       </label> | ||||
|       <label class="label" for="durationInput">duration: | ||||
|         <input v-model.number="setDuration" type="number" name="durationInput" > | ||||
|         <input v-model.number="setDuration" type="number" name="durationInput"> | ||||
|       </label> | ||||
|       <div class="startBtn example-btn" @click="start">开始</div> | ||||
|       <div class="pause-resume-btn example-btn" @click="pauseResume">暂停/恢复</div> | ||||
|       <div class="startBtn example-btn" @click="start"> | ||||
|         开始 | ||||
|       </div> | ||||
|       <div class="pause-resume-btn example-btn" @click="pauseResume"> | ||||
|         暂停/恢复 | ||||
|       </div> | ||||
|       <br> | ||||
|       <label class="label" for="decimalsInput">decimals: | ||||
|         <input v-model.number="setDecimals" type="number" name="decimalsInput" > | ||||
|         <input v-model.number="setDecimals" type="number" name="decimalsInput"> | ||||
|       </label> | ||||
|       <label class="label" for="separatorInput">separator: | ||||
|         <input v-model="setSeparator" name="separatorInput" > | ||||
|         <input v-model="setSeparator" name="separatorInput"> | ||||
|       </label> | ||||
|       <label class="label" for="prefixInput">prefix: | ||||
|         <input v-model="setPrefix" name="prefixInput" > | ||||
|         <input v-model="setPrefix" name="prefixInput"> | ||||
|       </label> | ||||
|       <label class="label" for="suffixInput">suffix: | ||||
|         <input v-model="setSuffix" name="suffixInput" > | ||||
|         <input v-model="setSuffix" name="suffixInput"> | ||||
|       </label> | ||||
|     </div> | ||||
|     <code><count-to :start-val='{{ _startVal }}' :end-val='{{ _endVal }}' :duration='{{ _duration }}' | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|       <a href="https://github.com/SortableJS/Vue.Draggable" target="_blank">Vue.Draggable</a> | ||||
|     </code> | ||||
|     <div class="editor-container"> | ||||
|       <dnd-list :list1="list1" :list2="list2" list1-title="List" list2-title="Article pool"/> | ||||
|       <dnd-list :list1="list1" :list2="list2" list1-title="List" list2-title="Article pool" /> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -1,14 +1,16 @@ | ||||
| <template> | ||||
|   <div class="components-container"> | ||||
|     <el-button type="primary" @click="dialogTableVisible = true">open a Drag Dialog</el-button> | ||||
|     <el-button type="primary" @click="dialogTableVisible = true"> | ||||
|       open a Drag Dialog | ||||
|     </el-button> | ||||
|     <el-dialog v-el-drag-dialog :visible.sync="dialogTableVisible" title="Shipping address" @dragDialog="handleDrag"> | ||||
|       <el-select ref="select" v-model="value" placeholder="请选择"> | ||||
|         <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value"/> | ||||
|         <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value" /> | ||||
|       </el-select> | ||||
|       <el-table :data="gridData"> | ||||
|         <el-table-column property="date" label="Date" width="150"/> | ||||
|         <el-table-column property="name" label="Name" width="200"/> | ||||
|         <el-table-column property="address" label="Address"/> | ||||
|         <el-table-column property="date" label="Date" width="150" /> | ||||
|         <el-table-column property="name" label="Name" width="200" /> | ||||
|         <el-table-column property="address" label="Address" /> | ||||
|       </el-table> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| <template> | ||||
|   <div class="components-container board"> | ||||
|     <Kanban :key="1" :list="list1" :options="options" class="kanban todo" header-text="Todo"/> | ||||
|     <Kanban :key="2" :list="list2" :options="options" class="kanban working" header-text="Working"/> | ||||
|     <Kanban :key="3" :list="list3" :options="options" class="kanban done" header-text="Done"/> | ||||
|     <Kanban :key="1" :list="list1" :options="options" class="kanban todo" header-text="Todo" /> | ||||
|     <Kanban :key="2" :list="list2" :options="options" class="kanban working" header-text="Working" /> | ||||
|     <Kanban :key="3" :list="list3" :options="options" class="kanban done" header-text="Done" /> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| <template> | ||||
|   <div class="components-container"> | ||||
|  | ||||
|     <el-drag-select v-model="value" style="width:500px;" multiple placeholder="请选择"> | ||||
|       <el-option v-for="item in options" :label="item.label" :value="item.value" :key="item.value" /> | ||||
|       <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value" /> | ||||
|     </el-drag-select> | ||||
|  | ||||
|     <div style="margin-top:30px;"> | ||||
|       <el-tag v-for="item of value" :key="item" style="margin-right:15px;">{{ item }}</el-tag> | ||||
|       <el-tag v-for="item of value" :key="item" style="margin-right:15px;"> | ||||
|         {{ item }} | ||||
|       </el-tag> | ||||
|     </div> | ||||
|  | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
|       {{ $t('components.dropzoneTips') }} | ||||
|     </code> | ||||
|     <div class="editor-container"> | ||||
|       <dropzone id="myVueDropzone" url="https://httpbin.org/post" @dropzone-removedFile="dropzoneR" @dropzone-success="dropzoneS"/> | ||||
|       <dropzone id="myVueDropzone" url="https://httpbin.org/post" @dropzone-removedFile="dropzoneR" @dropzone-success="dropzoneS" /> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|   <div class="components-container"> | ||||
|     <code>JsonEditor is base on  <a href="https://github.com/codemirror/CodeMirror" target="_blank">CodeMirrorr</a> , lint base on json-lint </code> | ||||
|     <div class="editor-container"> | ||||
|       <json-editor ref="jsonEditor" v-model="value"/> | ||||
|       <json-editor ref="jsonEditor" v-model="value" /> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| <template> | ||||
|   <div class="components-container"> | ||||
|  | ||||
|     <code>Markdown is based on | ||||
|       <a href="https://github.com/nhnent/tui.editor" target="_blank">tui.editor</a> ,Simply encapsulated in Vue. | ||||
|       <a target="_blank" href="https://panjiachen.github.io/vue-element-admin-site/feature/component/markdown-editor.html"> | ||||
| @@ -8,17 +7,23 @@ | ||||
|     </code> | ||||
|  | ||||
|     <div class="editor-container"> | ||||
|       <el-tag class="tag-title">Basic:</el-tag> | ||||
|       <markdown-editor v-model="content" height="300px"/> | ||||
|       <el-tag class="tag-title"> | ||||
|         Basic: | ||||
|       </el-tag> | ||||
|       <markdown-editor v-model="content" height="300px" /> | ||||
|     </div> | ||||
|  | ||||
|     <div class="editor-container"> | ||||
|       <el-tag class="tag-title">Markdown Mode:</el-tag> | ||||
|       <markdown-editor ref="markdownEditor" v-model="content" :options="{hideModeSwitch:true,previewStyle:'tab'}" height="200px"/> | ||||
|       <el-tag class="tag-title"> | ||||
|         Markdown Mode: | ||||
|       </el-tag> | ||||
|       <markdown-editor ref="markdownEditor" v-model="content" :options="{hideModeSwitch:true,previewStyle:'tab'}" height="200px" /> | ||||
|     </div> | ||||
|  | ||||
|     <div class="editor-container"> | ||||
|       <el-tag class="tag-title">Customize Toolbar:</el-tag> | ||||
|       <el-tag class="tag-title"> | ||||
|         Customize Toolbar: | ||||
|       </el-tag> | ||||
|       <markdown-editor | ||||
|         ref="markdownEditor" | ||||
|         v-model="content" | ||||
| @@ -27,14 +32,17 @@ | ||||
|     </div> | ||||
|  | ||||
|     <div class="editor-container"> | ||||
|       <el-tag class="tag-title">I18n:</el-tag> | ||||
|       <el-alert :closable="false" title="You can change the language of the admin system to see the effect" type="success"/> | ||||
|       <markdown-editor v-model="content" :language="language" height="300px"/> | ||||
|       <el-tag class="tag-title"> | ||||
|         I18n: | ||||
|       </el-tag> | ||||
|       <el-alert :closable="false" title="You can change the language of the admin system to see the effect" type="success" /> | ||||
|       <markdown-editor v-model="content" :language="language" height="300px" /> | ||||
|     </div> | ||||
|  | ||||
|     <el-button style="margin-top:80px;" type="primary" icon="el-icon-document" @click="getHtml">Get HTML</el-button> | ||||
|     <div v-html="html"/> | ||||
|  | ||||
|     <el-button style="margin-top:80px;" type="primary" icon="el-icon-document" @click="getHtml"> | ||||
|       Get HTML | ||||
|     </el-button> | ||||
|     <div v-html="html" /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -7,22 +7,34 @@ | ||||
|         </div> | ||||
|         <div style="margin-bottom:50px;"> | ||||
|           <el-col :span="4" class="text-center"> | ||||
|             <router-link class="pan-btn blue-btn" to="/documentation/index">Documentation</router-link> | ||||
|             <router-link class="pan-btn blue-btn" to="/documentation/index"> | ||||
|               Documentation | ||||
|             </router-link> | ||||
|           </el-col> | ||||
|           <el-col :span="4" class="text-center"> | ||||
|             <router-link class="pan-btn light-blue-btn" to="/icon/index">Icons</router-link> | ||||
|             <router-link class="pan-btn light-blue-btn" to="/icon/index"> | ||||
|               Icons | ||||
|             </router-link> | ||||
|           </el-col> | ||||
|           <el-col :span="4" class="text-center"> | ||||
|             <router-link class="pan-btn pink-btn" to="/excel/export-excel">Excel</router-link> | ||||
|             <router-link class="pan-btn pink-btn" to="/excel/export-excel"> | ||||
|               Excel | ||||
|             </router-link> | ||||
|           </el-col> | ||||
|           <el-col :span="4" class="text-center"> | ||||
|             <router-link class="pan-btn green-btn" to="/table/complex-table">Table</router-link> | ||||
|             <router-link class="pan-btn green-btn" to="/table/complex-table"> | ||||
|               Table | ||||
|             </router-link> | ||||
|           </el-col> | ||||
|           <el-col :span="4" class="text-center"> | ||||
|             <router-link class="pan-btn tiffany-btn" to="/example/create">Form</router-link> | ||||
|             <router-link class="pan-btn tiffany-btn" to="/example/create"> | ||||
|               Form | ||||
|             </router-link> | ||||
|           </el-col> | ||||
|           <el-col :span="4" class="text-center"> | ||||
|             <router-link class="pan-btn yellow-btn" to="/theme/index">Theme</router-link> | ||||
|             <router-link class="pan-btn yellow-btn" to="/theme/index"> | ||||
|               Theme | ||||
|             </router-link> | ||||
|           </el-col> | ||||
|         </div> | ||||
|       </el-card> | ||||
| @@ -37,7 +49,9 @@ | ||||
|           <div style="height:100px;"> | ||||
|             <el-form :model="demo" :rules="demoRules"> | ||||
|               <el-form-item prop="title"> | ||||
|                 <md-input v-model="demo.title" icon="search" name="title" placeholder="输入标题">标题</md-input> | ||||
|                 <md-input v-model="demo.title" icon="search" name="title" placeholder="输入标题"> | ||||
|                   标题 | ||||
|                 </md-input> | ||||
|               </el-form-item> | ||||
|             </el-form> | ||||
|           </div> | ||||
| @@ -63,7 +77,9 @@ | ||||
|             <span>水波纹 waves v-directive</span> | ||||
|           </div> | ||||
|           <div class="component-item"> | ||||
|             <el-button v-waves type="primary">水波纹效果</el-button> | ||||
|             <el-button v-waves type="primary"> | ||||
|               水波纹效果 | ||||
|             </el-button> | ||||
|           </div> | ||||
|         </el-card> | ||||
|       </el-col> | ||||
| @@ -74,7 +90,7 @@ | ||||
|             <span>hover text</span> | ||||
|           </div> | ||||
|           <div class="component-item"> | ||||
|             <mallki class-name="mallki-text" text="vue-element-admin"/> | ||||
|             <mallki class-name="mallki-text" text="vue-element-admin" /> | ||||
|           </div> | ||||
|         </el-card> | ||||
|       </el-col> | ||||
| @@ -87,12 +103,11 @@ | ||||
|             <span>Share</span> | ||||
|           </div> | ||||
|           <div class="component-item" style="height:420px;"> | ||||
|             <dropdown-menu :items="articleList" style="margin:0 auto;" title="系列文章"/> | ||||
|             <dropdown-menu :items="articleList" style="margin:0 auto;" title="系列文章" /> | ||||
|           </div> | ||||
|         </el-card> | ||||
|       </el-col> | ||||
|     </el-row> | ||||
|  | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -7,15 +7,15 @@ | ||||
|     </code> | ||||
|     <split-pane split="vertical" @resize="resize"> | ||||
|       <template slot="paneL"> | ||||
|         <div class="left-container"/> | ||||
|         <div class="left-container" /> | ||||
|       </template> | ||||
|       <template slot="paneR"> | ||||
|         <split-pane split="horizontal"> | ||||
|           <template slot="paneL"> | ||||
|             <div class="top-container"/> | ||||
|             <div class="top-container" /> | ||||
|           </template> | ||||
|           <template slot="paneR"> | ||||
|             <div class="bottom-container"/> | ||||
|             <div class="bottom-container" /> | ||||
|           </template> | ||||
|         </split-pane> | ||||
|       </template> | ||||
|   | ||||
| @@ -3,11 +3,11 @@ | ||||
|     <sticky class-name="sub-navbar"> | ||||
|       <el-dropdown trigger="click"> | ||||
|         <el-button plain> | ||||
|           Platform<i class="el-icon-caret-bottom el-icon--right"/> | ||||
|           Platform<i class="el-icon-caret-bottom el-icon--right" /> | ||||
|         </el-button> | ||||
|         <el-dropdown-menu slot="dropdown" class="no-border"> | ||||
|           <el-checkbox-group v-model="platforms" style="padding: 5px 15px;"> | ||||
|             <el-checkbox v-for="item in platformsOptions" :label="item.key" :key="item.key"> | ||||
|             <el-checkbox v-for="item in platformsOptions" :key="item.key" :label="item.key"> | ||||
|               {{ item.name }} | ||||
|             </el-checkbox> | ||||
|           </el-checkbox-group> | ||||
| @@ -16,20 +16,23 @@ | ||||
|  | ||||
|       <el-dropdown trigger="click"> | ||||
|         <el-button plain> | ||||
|           Link<i class="el-icon-caret-bottom el-icon--right"/> | ||||
|           Link<i class="el-icon-caret-bottom el-icon--right" /> | ||||
|         </el-button> | ||||
|         <el-dropdown-menu slot="dropdown" class="no-padding no-border" style="width:300px"> | ||||
|           <el-input v-model="url" placeholder="Please enter the content"> | ||||
|             <template slot="prepend">Url</template> | ||||
|             <template slot="prepend"> | ||||
|               Url | ||||
|             </template> | ||||
|           </el-input> | ||||
|         </el-dropdown-menu> | ||||
|       </el-dropdown> | ||||
|  | ||||
|       <div class="time-container"> | ||||
|         <el-date-picker v-model="time" :picker-options="pickerOptions" type="datetime" format="yyyy-MM-dd HH:mm:ss" placeholder="Release time"/> | ||||
|         <el-date-picker v-model="time" :picker-options="pickerOptions" type="datetime" format="yyyy-MM-dd HH:mm:ss" placeholder="Release time" /> | ||||
|       </div> | ||||
|  | ||||
|       <el-button style="margin-left: 10px;" type="success">publish | ||||
|       <el-button style="margin-left: 10px;" type="success"> | ||||
|         publish | ||||
|       </el-button> | ||||
|     </sticky> | ||||
|  | ||||
|   | ||||
| @@ -5,9 +5,9 @@ | ||||
|       <a target="_blank" class="link-type" href="https://panjiachen.github.io/vue-element-admin-site/component/rich-editor.html"> {{ $t('components.documentation') }}</a> | ||||
|     </code> | ||||
|     <div> | ||||
|       <tinymce :height="300" v-model="content"/> | ||||
|       <tinymce v-model="content" :height="300" /> | ||||
|     </div> | ||||
|     <div class="editor-content" v-html="content"/> | ||||
|     <div class="editor-content" v-html="content" /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <div :class="className" :style="{height:height,width:width}"/> | ||||
|   <div :class="className" :style="{height:height,width:width}" /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -4,23 +4,23 @@ | ||||
|       <img src="https://wpimg.wallstcn.com/e7d23d71-cf19-4b90-a1cc-f56af8c0903d.png"> | ||||
|     </div> | ||||
|     <div style="position:relative;"> | ||||
|       <pan-thumb :image="avatar" class="panThumb"/> | ||||
|       <mallki class-name="mallki-text" text="vue-element-admin"/> | ||||
|       <pan-thumb :image="avatar" class="panThumb" /> | ||||
|       <mallki class-name="mallki-text" text="vue-element-admin" /> | ||||
|       <div style="padding-top:35px;" class="progress-item"> | ||||
|         <span>Vue</span> | ||||
|         <el-progress :percentage="70"/> | ||||
|         <el-progress :percentage="70" /> | ||||
|       </div> | ||||
|       <div class="progress-item"> | ||||
|         <span>JavaScript</span> | ||||
|         <el-progress :percentage="18"/> | ||||
|         <el-progress :percentage="18" /> | ||||
|       </div> | ||||
|       <div class="progress-item"> | ||||
|         <span>Css</span> | ||||
|         <el-progress :percentage="12"/> | ||||
|         <el-progress :percentage="12" /> | ||||
|       </div> | ||||
|       <div class="progress-item"> | ||||
|         <span>ESLint</span> | ||||
|         <el-progress :percentage="100" status="success"/> | ||||
|         <el-progress :percentage="100" status="success" /> | ||||
|       </div> | ||||
|     </div> | ||||
|   </el-card> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <div :class="className" :style="{height:height,width:width}"/> | ||||
|   <div :class="className" :style="{height:height,width:width}" /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -6,8 +6,10 @@ | ||||
|           <svg-icon icon-class="peoples" class-name="card-panel-icon" /> | ||||
|         </div> | ||||
|         <div class="card-panel-description"> | ||||
|           <div class="card-panel-text">New Visits</div> | ||||
|           <count-to :start-val="0" :end-val="102400" :duration="2600" class="card-panel-num"/> | ||||
|           <div class="card-panel-text"> | ||||
|             New Visits | ||||
|           </div> | ||||
|           <count-to :start-val="0" :end-val="102400" :duration="2600" class="card-panel-num" /> | ||||
|         </div> | ||||
|       </div> | ||||
|     </el-col> | ||||
| @@ -17,8 +19,10 @@ | ||||
|           <svg-icon icon-class="message" class-name="card-panel-icon" /> | ||||
|         </div> | ||||
|         <div class="card-panel-description"> | ||||
|           <div class="card-panel-text">Messages</div> | ||||
|           <count-to :start-val="0" :end-val="81212" :duration="3000" class="card-panel-num"/> | ||||
|           <div class="card-panel-text"> | ||||
|             Messages | ||||
|           </div> | ||||
|           <count-to :start-val="0" :end-val="81212" :duration="3000" class="card-panel-num" /> | ||||
|         </div> | ||||
|       </div> | ||||
|     </el-col> | ||||
| @@ -28,8 +32,10 @@ | ||||
|           <svg-icon icon-class="money" class-name="card-panel-icon" /> | ||||
|         </div> | ||||
|         <div class="card-panel-description"> | ||||
|           <div class="card-panel-text">Purchases</div> | ||||
|           <count-to :start-val="0" :end-val="9280" :duration="3200" class="card-panel-num"/> | ||||
|           <div class="card-panel-text"> | ||||
|             Purchases | ||||
|           </div> | ||||
|           <count-to :start-val="0" :end-val="9280" :duration="3200" class="card-panel-num" /> | ||||
|         </div> | ||||
|       </div> | ||||
|     </el-col> | ||||
| @@ -39,8 +45,10 @@ | ||||
|           <svg-icon icon-class="shopping" class-name="card-panel-icon" /> | ||||
|         </div> | ||||
|         <div class="card-panel-description"> | ||||
|           <div class="card-panel-text">Shoppings</div> | ||||
|           <count-to :start-val="0" :end-val="13600" :duration="3600" class="card-panel-num"/> | ||||
|           <div class="card-panel-text"> | ||||
|             Shoppings | ||||
|           </div> | ||||
|           <count-to :start-val="0" :end-val="13600" :duration="3600" class="card-panel-num" /> | ||||
|         </div> | ||||
|       </div> | ||||
|     </el-col> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <div :class="className" :style="{height:height,width:width}"/> | ||||
|   <div :class="className" :style="{height:height,width:width}" /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <div :class="className" :style="{height:height,width:width}"/> | ||||
|   <div :class="className" :style="{height:height,width:width}" /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -5,18 +5,20 @@ | ||||
|         :checked="todo.done" | ||||
|         class="toggle" | ||||
|         type="checkbox" | ||||
|         @change="toggleTodo( todo)"> | ||||
|       <label @dblclick="editing = true" v-text="todo.text"/> | ||||
|       <button class="destroy" @click="deleteTodo( todo )"/> | ||||
|         @change="toggleTodo( todo)" | ||||
|       > | ||||
|       <label @dblclick="editing = true" v-text="todo.text" /> | ||||
|       <button class="destroy" @click="deleteTodo( todo )" /> | ||||
|     </div> | ||||
|     <input | ||||
|       v-focus="editing" | ||||
|       v-show="editing" | ||||
|       v-focus="editing" | ||||
|       :value="todo.text" | ||||
|       class="edit" | ||||
|       @keyup.enter="doneEdit" | ||||
|       @keyup.esc="cancelEdit" | ||||
|       @blur="doneEdit"> | ||||
|       @blur="doneEdit" | ||||
|     > | ||||
|   </li> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <!-- main section --> | ||||
|     <section v-show="todos.length" class="main"> | ||||
|       <input id="toggle-all" :checked="allChecked" class="toggle-all" type="checkbox" @change="toggleAll({ done: !allChecked })"> | ||||
|       <label for="toggle-all"/> | ||||
|       <label for="toggle-all" /> | ||||
|       <ul class="todo-list"> | ||||
|         <todo | ||||
|           v-for="(todo, index) in filteredTodos" | ||||
| @@ -15,7 +15,8 @@ | ||||
|           :todo="todo" | ||||
|           @toggleTodo="toggleTodo" | ||||
|           @editTodo="editTodo" | ||||
|           @deleteTodo="deleteTodo"/> | ||||
|           @deleteTodo="deleteTodo" | ||||
|         /> | ||||
|       </ul> | ||||
|     </section> | ||||
|     <!-- footer --> | ||||
|   | ||||
| @@ -12,7 +12,9 @@ | ||||
|     </el-table-column> | ||||
|     <el-table-column label="Status" width="100" align="center"> | ||||
|       <template slot-scope="scope"> | ||||
|         <el-tag :type="scope.row.status | statusFilter"> {{ scope.row.status }}</el-tag> | ||||
|         <el-tag :type="scope.row.status | statusFilter"> | ||||
|           {{ scope.row.status }} | ||||
|         </el-tag> | ||||
|       </template> | ||||
|     </el-table-column> | ||||
|   </el-table> | ||||
|   | ||||
| @@ -1,44 +1,42 @@ | ||||
| <template> | ||||
|   <div class="dashboard-editor-container"> | ||||
|     <github-corner style="position: absolute; top: 0px; border: 0; right: 0;" /> | ||||
|  | ||||
|     <github-corner style="position: absolute; top: 0px; border: 0; right: 0;"/> | ||||
|  | ||||
|     <panel-group @handleSetLineChartData="handleSetLineChartData"/> | ||||
|     <panel-group @handleSetLineChartData="handleSetLineChartData" /> | ||||
|  | ||||
|     <el-row style="background:#fff;padding:16px 16px 0;margin-bottom:32px;"> | ||||
|       <line-chart :chart-data="lineChartData"/> | ||||
|       <line-chart :chart-data="lineChartData" /> | ||||
|     </el-row> | ||||
|  | ||||
|     <el-row :gutter="32"> | ||||
|       <el-col :xs="24" :sm="24" :lg="8"> | ||||
|         <div class="chart-wrapper"> | ||||
|           <raddar-chart/> | ||||
|           <raddar-chart /> | ||||
|         </div> | ||||
|       </el-col> | ||||
|       <el-col :xs="24" :sm="24" :lg="8"> | ||||
|         <div class="chart-wrapper"> | ||||
|           <pie-chart/> | ||||
|           <pie-chart /> | ||||
|         </div> | ||||
|       </el-col> | ||||
|       <el-col :xs="24" :sm="24" :lg="8"> | ||||
|         <div class="chart-wrapper"> | ||||
|           <bar-chart/> | ||||
|           <bar-chart /> | ||||
|         </div> | ||||
|       </el-col> | ||||
|     </el-row> | ||||
|  | ||||
|     <el-row :gutter="8"> | ||||
|       <el-col :xs="{span: 24}" :sm="{span: 24}" :md="{span: 24}" :lg="{span: 12}" :xl="{span: 12}" style="padding-right:8px;margin-bottom:30px;"> | ||||
|         <transaction-table/> | ||||
|         <transaction-table /> | ||||
|       </el-col> | ||||
|       <el-col :xs="{span: 24}" :sm="{span: 12}" :md="{span: 12}" :lg="{span: 6}" :xl="{span: 6}" style="margin-bottom:30px;"> | ||||
|         <todo-list/> | ||||
|         <todo-list /> | ||||
|       </el-col> | ||||
|       <el-col :xs="{span: 24}" :sm="{span: 12}" :md="{span: 12}" :lg="{span: 6}" :xl="{span: 6}" style="margin-bottom:30px;"> | ||||
|         <box-card/> | ||||
|         <box-card /> | ||||
|       </el-col> | ||||
|     </el-row> | ||||
|  | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,10 +1,11 @@ | ||||
| <template> | ||||
|   <div class="dashboard-editor-container"> | ||||
|     <div class=" clearfix"> | ||||
|       <pan-thumb :image="avatar" style="float: left"> Your roles: | ||||
|       <pan-thumb :image="avatar" style="float: left"> | ||||
|         Your roles: | ||||
|         <span v-for="item in roles" :key="item" class="pan-info-roles">{{ item }}</span> | ||||
|       </pan-thumb> | ||||
|       <github-corner style="position: absolute; top: 0px; border: 0; right: 0;"/> | ||||
|       <github-corner style="position: absolute; top: 0px; border: 0; right: 0;" /> | ||||
|       <div class="info-container"> | ||||
|         <span class="display_name">{{ name }}</span> | ||||
|         <span style="font-size:20px;padding-top:20px;display:inline-block;">Editor's Dashboard</span> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
|   <div class="dashboard-container"> | ||||
|     <component :is="currentRole"/> | ||||
|     <component :is="currentRole" /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
|     <a class="document-btn" target="_blank" href="https://panjiachen.github.io/vue-element-admin-site/">{{ $t('documentation.documentation') }}</a> | ||||
|     <a class="document-btn" target="_blank" href="https://github.com/PanJiaChen/vue-element-admin/">{{ $t('documentation.github') }}</a> | ||||
|     <a class="document-btn" target="_blank" href="https://panjiachen.gitee.io/vue-element-admin-site/zh/">国内文档</a> | ||||
|     <dropdown-menu :items="articleList" style="float:left;margin-left:50px;" title="系列文章"/> | ||||
|     <dropdown-menu :items="articleList" style="float:left;margin-left:50px;" title="系列文章" /> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <div/> | ||||
|   <div /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <template> | ||||
|   <div class="errPage-container"> | ||||
|     <errorA/> | ||||
|     <errorB/> | ||||
|     <errorA /> | ||||
|     <errorB /> | ||||
|     <!-- $t is vue-i18n global function to translate lang --> | ||||
|     <h3>{{ $t('errorLog.tips') }}</h3> | ||||
|     <code> | ||||
|   | ||||
| @@ -1,18 +1,26 @@ | ||||
| <template> | ||||
|   <div class="errPage-container"> | ||||
|     <el-button icon="arrow-left" class="pan-back-btn" @click="back">返回</el-button> | ||||
|     <el-button icon="arrow-left" class="pan-back-btn" @click="back"> | ||||
|       返回 | ||||
|     </el-button> | ||||
|     <el-row> | ||||
|       <el-col :span="12"> | ||||
|         <h1 class="text-jumbo text-ginormous">Oops!</h1> | ||||
|         <h1 class="text-jumbo text-ginormous"> | ||||
|           Oops! | ||||
|         </h1> | ||||
|         gif来源<a href="https://zh.airbnb.com/" target="_blank">airbnb</a> 页面 | ||||
|         <h2>你没有权限去该页面</h2> | ||||
|         <h6>如有不满请联系你领导</h6> | ||||
|         <ul class="list-unstyled"> | ||||
|           <li>或者你可以去:</li> | ||||
|           <li class="link-type"> | ||||
|             <router-link to="/dashboard">回首页</router-link> | ||||
|             <router-link to="/dashboard"> | ||||
|               回首页 | ||||
|             </router-link> | ||||
|           </li> | ||||
|           <li class="link-type"> | ||||
|             <a href="https://www.taobao.com/">随便看看</a> | ||||
|           </li> | ||||
|           <li class="link-type"><a href="https://www.taobao.com/">随便看看</a></li> | ||||
|           <li><a href="#" @click.prevent="dialogVisible=true">点我看图</a></li> | ||||
|         </ul> | ||||
|       </el-col> | ||||
|   | ||||
| @@ -8,13 +8,22 @@ | ||||
|         <img class="pic-404__child right" src="@/assets/404_images/404_cloud.png" alt="404"> | ||||
|       </div> | ||||
|       <div class="bullshit"> | ||||
|         <div class="bullshit__oops">OOPS!</div> | ||||
|         <div class="bullshit__info">版权所有 | ||||
|         <div class="bullshit__oops"> | ||||
|           OOPS! | ||||
|         </div> | ||||
|         <div class="bullshit__info"> | ||||
|           版权所有 | ||||
|           <a class="link-type" href="https://wallstreetcn.com" target="_blank">华尔街见闻</a> | ||||
|         </div> | ||||
|         <div class="bullshit__headline">{{ message }}</div> | ||||
|         <div class="bullshit__info">请检查您输入的网址是否正确,请点击以下按钮返回主页或者发送错误报告</div> | ||||
|         <router-link to="/" class="bullshit__return-home">返回首页</router-link> | ||||
|         <div class="bullshit__headline"> | ||||
|           {{ message }} | ||||
|         </div> | ||||
|         <div class="bullshit__info"> | ||||
|           请检查您输入的网址是否正确,请点击以下按钮返回主页或者发送错误报告 | ||||
|         </div> | ||||
|         <router-link to="/" class="bullshit__return-home"> | ||||
|           返回首页 | ||||
|         </router-link> | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
|   | ||||
| @@ -1,19 +1,20 @@ | ||||
| <template> | ||||
|   <div class="createPost-container"> | ||||
|     <el-form ref="postForm" :model="postForm" :rules="rules" class="form-container"> | ||||
|  | ||||
|       <sticky :class-name="'sub-navbar '+postForm.status"> | ||||
|         <CommentDropdown v-model="postForm.comment_disabled" /> | ||||
|         <PlatformDropdown v-model="postForm.platforms" /> | ||||
|         <SourceUrlDropdown v-model="postForm.source_uri" /> | ||||
|         <el-button v-loading="loading" style="margin-left: 10px;" type="success" @click="submitForm">发布 | ||||
|         <el-button v-loading="loading" style="margin-left: 10px;" type="success" @click="submitForm"> | ||||
|           发布 | ||||
|         </el-button> | ||||
|         <el-button v-loading="loading" type="warning" @click="draftForm"> | ||||
|           草稿 | ||||
|         </el-button> | ||||
|         <el-button v-loading="loading" type="warning" @click="draftForm">草稿</el-button> | ||||
|       </sticky> | ||||
|  | ||||
|       <div class="createPost-main-container"> | ||||
|         <el-row> | ||||
|  | ||||
|           <Warning /> | ||||
|  | ||||
|           <el-col :span="24"> | ||||
| @@ -28,14 +29,14 @@ | ||||
|                 <el-col :span="8"> | ||||
|                   <el-form-item label-width="45px" label="作者:" class="postInfo-container-item"> | ||||
|                     <el-select v-model="postForm.author" :remote-method="getRemoteUserList" filterable remote placeholder="搜索用户"> | ||||
|                       <el-option v-for="(item,index) in userListOptions" :key="item+index" :label="item" :value="item"/> | ||||
|                       <el-option v-for="(item,index) in userListOptions" :key="item+index" :label="item" :value="item" /> | ||||
|                     </el-select> | ||||
|                   </el-form-item> | ||||
|                 </el-col> | ||||
|  | ||||
|                 <el-col :span="10"> | ||||
|                   <el-form-item label-width="80px" label="发布时间:" class="postInfo-container-item"> | ||||
|                     <el-date-picker v-model="postForm.display_time" type="datetime" format="yyyy-MM-dd HH:mm:ss" placeholder="选择日期时间"/> | ||||
|                     <el-date-picker v-model="postForm.display_time" type="datetime" format="yyyy-MM-dd HH:mm:ss" placeholder="选择日期时间" /> | ||||
|                   </el-form-item> | ||||
|                 </el-col> | ||||
|  | ||||
| @@ -47,7 +48,8 @@ | ||||
|                       :colors="['#99A9BF', '#F7BA2A', '#FF9900']" | ||||
|                       :low-threshold="1" | ||||
|                       :high-threshold="3" | ||||
|                       style="margin-top:8px;"/> | ||||
|                       style="margin-top:8px;" | ||||
|                     /> | ||||
|                   </el-form-item> | ||||
|                 </el-col> | ||||
|               </el-row> | ||||
| @@ -56,12 +58,12 @@ | ||||
|         </el-row> | ||||
|  | ||||
|         <el-form-item style="margin-bottom: 40px;" label-width="45px" label="摘要:"> | ||||
|           <el-input :rows="1" v-model="postForm.content_short" type="textarea" class="article-textarea" autosize placeholder="请输入内容"/> | ||||
|           <el-input v-model="postForm.content_short" :rows="1" type="textarea" class="article-textarea" autosize placeholder="请输入内容" /> | ||||
|           <span v-show="contentShortLength" class="word-counter">{{ contentShortLength }}字</span> | ||||
|         </el-form-item> | ||||
|  | ||||
|         <el-form-item prop="content" style="margin-bottom: 30px;"> | ||||
|           <Tinymce ref="editor" :height="400" v-model="postForm.content" /> | ||||
|           <Tinymce ref="editor" v-model="postForm.content" :height="400" /> | ||||
|         </el-form-item> | ||||
|  | ||||
|         <el-form-item prop="image_uri" style="margin-bottom: 30px;"> | ||||
| @@ -69,7 +71,6 @@ | ||||
|         </el-form-item> | ||||
|       </div> | ||||
|     </el-form> | ||||
|  | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,13 +1,18 @@ | ||||
| <template> | ||||
|   <el-dropdown :show-timeout="100" trigger="click"> | ||||
|     <el-button plain>{{ !comment_disabled?'评论已打开':'评论已关闭' }} | ||||
|       <i class="el-icon-caret-bottom el-icon--right"/> | ||||
|     <el-button plain> | ||||
|       {{ !comment_disabled?'评论已打开':'评论已关闭' }} | ||||
|       <i class="el-icon-caret-bottom el-icon--right" /> | ||||
|     </el-button> | ||||
|     <el-dropdown-menu slot="dropdown" class="no-padding"> | ||||
|       <el-dropdown-item> | ||||
|         <el-radio-group v-model="comment_disabled" style="padding: 10px;"> | ||||
|           <el-radio :label="true">关闭评论</el-radio> | ||||
|           <el-radio :label="false">打开评论</el-radio> | ||||
|           <el-radio :label="true"> | ||||
|             关闭评论 | ||||
|           </el-radio> | ||||
|           <el-radio :label="false"> | ||||
|             打开评论 | ||||
|           </el-radio> | ||||
|         </el-radio-group> | ||||
|       </el-dropdown-item> | ||||
|     </el-dropdown-menu> | ||||
|   | ||||
| @@ -2,11 +2,11 @@ | ||||
|   <el-dropdown :hide-on-click="false" :show-timeout="100" trigger="click"> | ||||
|     <el-button plain> | ||||
|       平台({{ platforms.length }}) | ||||
|       <i class="el-icon-caret-bottom el-icon--right"/> | ||||
|       <i class="el-icon-caret-bottom el-icon--right" /> | ||||
|     </el-button> | ||||
|     <el-dropdown-menu slot="dropdown" class="no-border"> | ||||
|       <el-checkbox-group v-model="platforms" style="padding: 5px 15px;"> | ||||
|         <el-checkbox v-for="item in platformsOptions" :label="item.key" :key="item.key"> | ||||
|         <el-checkbox v-for="item in platformsOptions" :key="item.key" :label="item.key"> | ||||
|           {{ item.name }} | ||||
|         </el-checkbox> | ||||
|       </el-checkbox-group> | ||||
|   | ||||
| @@ -2,12 +2,14 @@ | ||||
|   <el-dropdown :show-timeout="100" trigger="click"> | ||||
|     <el-button plain> | ||||
|       外链 | ||||
|       <i class="el-icon-caret-bottom el-icon--right"/> | ||||
|       <i class="el-icon-caret-bottom el-icon--right" /> | ||||
|     </el-button> | ||||
|     <el-dropdown-menu slot="dropdown" class="no-padding no-border" style="width:400px"> | ||||
|       <el-form-item label-width="0px" style="margin-bottom: 0px" prop="source_uri"> | ||||
|         <el-input v-model="source_uri" placeholder="请输入内容"> | ||||
|           <template slot="prepend">填写url</template> | ||||
|           <template slot="prepend"> | ||||
|             填写url | ||||
|           </template> | ||||
|         </el-input> | ||||
|       </el-form-item> | ||||
|     </el-dropdown-menu> | ||||
|   | ||||
| @@ -4,7 +4,8 @@ | ||||
|     的include,直接缓存所有页面。详情见 | ||||
|     <a | ||||
|       href="https://panjiachen.github.io/vue-element-admin-site/guide/essentials/tags-view.html" | ||||
|       target="_blank">文档</a> | ||||
|       target="_blank" | ||||
|     >文档</a> | ||||
|   </p> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <article-detail :is-edit="false"/> | ||||
|   <article-detail :is-edit="false" /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <article-detail :is-edit="true"/> | ||||
|   <article-detail :is-edit="true" /> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| <template> | ||||
|   <div class="app-container"> | ||||
|  | ||||
|     <el-table v-loading="listLoading" :data="list" border fit highlight-current-row style="width: 100%"> | ||||
|       <el-table-column align="center" label="ID" width="80"> | ||||
|         <template slot-scope="scope"> | ||||
| @@ -22,19 +21,20 @@ | ||||
|  | ||||
|       <el-table-column width="100px" label="Importance"> | ||||
|         <template slot-scope="scope"> | ||||
|           <svg-icon v-for="n in +scope.row.importance" :key="n" icon-class="star" class="meta-item__icon"/> | ||||
|           <svg-icon v-for="n in +scope.row.importance" :key="n" icon-class="star" class="meta-item__icon" /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|  | ||||
|       <el-table-column class-name="status-col" label="Status" width="110"> | ||||
|         <template slot-scope="scope"> | ||||
|           <el-tag :type="scope.row.status | statusFilter">{{ scope.row.status }}</el-tag> | ||||
|           <el-tag :type="scope.row.status | statusFilter"> | ||||
|             {{ scope.row.status }} | ||||
|           </el-tag> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|  | ||||
|       <el-table-column min-width="300px" label="Title"> | ||||
|         <template slot-scope="scope"> | ||||
|  | ||||
|           <router-link :to="'/example/edit/'+scope.row.id" class="link-type"> | ||||
|             <span>{{ scope.row.title }}</span> | ||||
|           </router-link> | ||||
| @@ -44,14 +44,15 @@ | ||||
|       <el-table-column align="center" label="Actions" width="120"> | ||||
|         <template slot-scope="scope"> | ||||
|           <router-link :to="'/example/edit/'+scope.row.id"> | ||||
|             <el-button type="primary" size="small" icon="el-icon-edit">Edit</el-button> | ||||
|             <el-button type="primary" size="small" icon="el-icon-edit"> | ||||
|               Edit | ||||
|             </el-button> | ||||
|           </router-link> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | ||||
|     <pagination v-show="total>0" :total="total" :page.sync="listQuery.page" :limit.sync="listQuery.limit" @pagination="getList" /> | ||||
|  | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -2,8 +2,12 @@ | ||||
|   <div style="display:inline-block;"> | ||||
|     <label class="radio-label">Cell Auto-Width: </label> | ||||
|     <el-radio-group v-model="autoWidth"> | ||||
|       <el-radio :label="true" border>True</el-radio> | ||||
|       <el-radio :label="false" border>False</el-radio> | ||||
|       <el-radio :label="true" border> | ||||
|         True | ||||
|       </el-radio> | ||||
|       <el-radio :label="false" border> | ||||
|         False | ||||
|       </el-radio> | ||||
|     </el-radio-group> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -1,12 +1,13 @@ | ||||
| <template> | ||||
|   <div style="display:inline-block;"> | ||||
|     <label class="radio-label">Book Type: </label> | ||||
|     <el-select v-model="bookType" style="width:120px;" > | ||||
|     <el-select v-model="bookType" style="width:120px;"> | ||||
|       <el-option | ||||
|         v-for="item in options" | ||||
|         :key="item" | ||||
|         :label="item" | ||||
|         :value="item"/> | ||||
|         :value="item" | ||||
|       /> | ||||
|     </el-select> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|   <div style="display:inline-block;"> | ||||
|     <!-- $t is vue-i18n global function to translate lang --> | ||||
|     <label class="radio-label" style="padding-left:0;">Filename: </label> | ||||
|     <el-input :placeholder="$t('excel.placeholder')" v-model="filename" style="width:340px;" prefix-icon="el-icon-document"/> | ||||
|     <el-input v-model="filename" :placeholder="$t('excel.placeholder')" style="width:340px;" prefix-icon="el-icon-document" /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,13 @@ | ||||
| <template> | ||||
|   <!-- $t is vue-i18n global function to translate lang --> | ||||
|   <div class="app-container"> | ||||
|  | ||||
|     <div> | ||||
|       <FilenameOption v-model="filename" /> | ||||
|       <AutoWidthOption v-model="autoWidth" /> | ||||
|       <BookTypeOption v-model="bookType" /> | ||||
|       <el-button :loading="downloadLoading" style="margin:0 0 20px 20px;" type="primary" icon="document" @click="handleDownload">{{ $t('excel.export') }} Excel</el-button> | ||||
|       <el-button :loading="downloadLoading" style="margin:0 0 20px 20px;" type="primary" icon="document" @click="handleDownload"> | ||||
|         {{ $t('excel.export') }} Excel | ||||
|       </el-button> | ||||
|       <a href="https://panjiachen.github.io/vue-element-admin-site/feature/component/excel.html" target="_blank" style="margin-left:15px;"> | ||||
|         <el-tag type="info">Documentation</el-tag> | ||||
|       </a> | ||||
| @@ -35,7 +36,7 @@ | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="Date" width="220"> | ||||
|         <template slot-scope="scope"> | ||||
|           <i class="el-icon-time"/> | ||||
|           <i class="el-icon-time" /> | ||||
|           <span>{{ scope.row.timestamp | parseTime('{y}-{m}-{d} {h}:{i}') }}</span> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|   | ||||
| @@ -1,21 +1,24 @@ | ||||
| <template> | ||||
|   <div class="app-container"> | ||||
|     <!-- $t is vue-i18n global function to translate lang --> | ||||
|     <el-input :placeholder="$t('excel.placeholder')" v-model="filename" style="width:340px;" prefix-icon="el-icon-document"/> | ||||
|     <el-button :loading="downloadLoading" style="margin-bottom:20px" type="primary" icon="document" @click="handleDownload">{{ $t('excel.selectedExport') }}</el-button> | ||||
|     <el-input v-model="filename" :placeholder="$t('excel.placeholder')" style="width:340px;" prefix-icon="el-icon-document" /> | ||||
|     <el-button :loading="downloadLoading" style="margin-bottom:20px" type="primary" icon="document" @click="handleDownload"> | ||||
|       {{ $t('excel.selectedExport') }} | ||||
|     </el-button> | ||||
|     <a href="https://panjiachen.github.io/vue-element-admin-site/feature/component/excel.html" target="_blank" style="margin-left:15px;"> | ||||
|       <el-tag type="info">Documentation</el-tag> | ||||
|     </a> | ||||
|     <el-table | ||||
|       v-loading="listLoading" | ||||
|       ref="multipleTable" | ||||
|       v-loading="listLoading" | ||||
|       :data="list" | ||||
|       element-loading-text="拼命加载中" | ||||
|       border | ||||
|       fit | ||||
|       highlight-current-row | ||||
|       @selection-change="handleSelectionChange"> | ||||
|       <el-table-column type="selection" align="center"/> | ||||
|       @selection-change="handleSelectionChange" | ||||
|     > | ||||
|       <el-table-column type="selection" align="center" /> | ||||
|       <el-table-column align="center" label="Id" width="95"> | ||||
|         <template slot-scope="scope"> | ||||
|           {{ scope.$index }} | ||||
| @@ -38,7 +41,7 @@ | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="PDate" width="220"> | ||||
|         <template slot-scope="scope"> | ||||
|           <i class="el-icon-time"/> | ||||
|           <i class="el-icon-time" /> | ||||
|           <span>{{ scope.row.display_time }}</span> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| <template> | ||||
|   <div class="app-container"> | ||||
|     <upload-excel-component :on-success="handleSuccess" :before-upload="beforeUpload"/> | ||||
|     <upload-excel-component :on-success="handleSuccess" :before-upload="beforeUpload" /> | ||||
|     <el-table :data="tableData" border highlight-current-row style="width: 100%;margin-top:20px;"> | ||||
|       <el-table-column v-for="item of tableHeader" :prop="item" :label="item" :key="item"/> | ||||
|       <el-table-column v-for="item of tableHeader" :key="item" :prop="item" :label="item" /> | ||||
|     </el-table> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -5,7 +5,9 @@ | ||||
|       <a href="https://github.com/kamranahmedse/driver.js" target="_blank">driver.js. | ||||
|       </a> | ||||
|     </p> | ||||
|     <el-button icon="el-icon-question" type="primary" @click.prevent.stop="guide">{{ $t('guide.button') }}</el-button> | ||||
|     <el-button icon="el-icon-question" type="primary" @click.prevent.stop="guide"> | ||||
|       {{ $t('guide.button') }} | ||||
|     </el-button> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -7,18 +7,26 @@ | ||||
|       </div> | ||||
|       <div> | ||||
|         <el-radio-group v-model="lang" size="small"> | ||||
|           <el-radio label="zh" border>简体中文</el-radio> | ||||
|           <el-radio label="en" border>English</el-radio> | ||||
|           <el-radio label="es" border>Español</el-radio> | ||||
|           <el-radio label="zh" border> | ||||
|             简体中文 | ||||
|           </el-radio> | ||||
|           <el-radio label="en" border> | ||||
|             English | ||||
|           </el-radio> | ||||
|           <el-radio label="es" border> | ||||
|             Español | ||||
|           </el-radio> | ||||
|         </el-radio-group> | ||||
|         <el-tag style="margin-top:15px;display:block;" type="info">{{ $t('i18nView.note') }}</el-tag> | ||||
|         <el-tag style="margin-top:15px;display:block;" type="info"> | ||||
|           {{ $t('i18nView.note') }} | ||||
|         </el-tag> | ||||
|       </div> | ||||
|     </el-card> | ||||
|  | ||||
|     <el-row :gutter="20" style="margin:100px 15px 50px;"> | ||||
|       <el-col :span="12" :xs="24"> | ||||
|         <div class="block"> | ||||
|           <el-date-picker v-model="date" :placeholder="$t('i18nView.datePlaceholder')" type="date"/> | ||||
|           <el-date-picker v-model="date" :placeholder="$t('i18nView.datePlaceholder')" type="date" /> | ||||
|         </div> | ||||
|         <div class="block"> | ||||
|           <el-select v-model="value" :placeholder="$t('i18nView.selectPlaceholder')"> | ||||
| @@ -26,23 +34,36 @@ | ||||
|               v-for="item in options" | ||||
|               :key="item.value" | ||||
|               :label="item.label" | ||||
|               :value="item.value"/> | ||||
|               :value="item.value" | ||||
|             /> | ||||
|           </el-select> | ||||
|         </div> | ||||
|         <div class="block"> | ||||
|           <el-button class="item-btn" size="small">{{ $t('i18nView.default') }}</el-button> | ||||
|           <el-button class="item-btn" size="small" type="primary">{{ $t('i18nView.primary') }}</el-button> | ||||
|           <el-button class="item-btn" size="small" type="success">{{ $t('i18nView.success') }}</el-button> | ||||
|           <el-button class="item-btn" size="small" type="info">{{ $t('i18nView.info') }}</el-button> | ||||
|           <el-button class="item-btn" size="small" type="warning">{{ $t('i18nView.warning') }}</el-button> | ||||
|           <el-button class="item-btn" size="small" type="danger">{{ $t('i18nView.danger') }}</el-button> | ||||
|           <el-button class="item-btn" size="small"> | ||||
|             {{ $t('i18nView.default') }} | ||||
|           </el-button> | ||||
|           <el-button class="item-btn" size="small" type="primary"> | ||||
|             {{ $t('i18nView.primary') }} | ||||
|           </el-button> | ||||
|           <el-button class="item-btn" size="small" type="success"> | ||||
|             {{ $t('i18nView.success') }} | ||||
|           </el-button> | ||||
|           <el-button class="item-btn" size="small" type="info"> | ||||
|             {{ $t('i18nView.info') }} | ||||
|           </el-button> | ||||
|           <el-button class="item-btn" size="small" type="warning"> | ||||
|             {{ $t('i18nView.warning') }} | ||||
|           </el-button> | ||||
|           <el-button class="item-btn" size="small" type="danger"> | ||||
|             {{ $t('i18nView.danger') }} | ||||
|           </el-button> | ||||
|         </div> | ||||
|       </el-col> | ||||
|       <el-col :span="12" :xs="24"> | ||||
|         <el-table :data="tableData" fit highlight-current-row border style="width: 100%"> | ||||
|           <el-table-column :label="$t('i18nView.tableName')" prop="name" width="100" align="center"/> | ||||
|           <el-table-column :label="$t('i18nView.tableDate')" prop="date" width="120" align="center"/> | ||||
|           <el-table-column :label="$t('i18nView.tableAddress')" prop="address"/> | ||||
|           <el-table-column :label="$t('i18nView.tableName')" prop="name" width="100" align="center" /> | ||||
|           <el-table-column :label="$t('i18nView.tableDate')" prop="date" width="120" align="center" /> | ||||
|           <el-table-column :label="$t('i18nView.tableAddress')" prop="address" /> | ||||
|         </el-table> | ||||
|       </el-col> | ||||
|     </el-row> | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| <template> | ||||
|   <div :class="classObj" class="app-wrapper"> | ||||
|     <div v-if="device==='mobile'&&sidebar.opened" class="drawer-bg" @click="handleClickOutside"/> | ||||
|     <sidebar class="sidebar-container"/> | ||||
|     <div v-if="device==='mobile'&&sidebar.opened" class="drawer-bg" @click="handleClickOutside" /> | ||||
|     <sidebar class="sidebar-container" /> | ||||
|     <div class="main-container"> | ||||
|       <navbar/> | ||||
|       <tags-view/> | ||||
|       <app-main/> | ||||
|       <navbar /> | ||||
|       <tags-view /> | ||||
|       <app-main /> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|   <section class="app-main"> | ||||
|     <transition name="fade-transform" mode="out-in"> | ||||
|       <keep-alive :include="cachedViews"> | ||||
|         <router-view :key="key"/> | ||||
|         <router-view :key="key" /> | ||||
|       </keep-alive> | ||||
|     </transition> | ||||
|   </section> | ||||
|   | ||||
| @@ -1,32 +1,32 @@ | ||||
| <template> | ||||
|   <div class="navbar"> | ||||
|     <hamburger :is-active="sidebar.opened" class="hamburger-container" @toggleClick="toggleSideBar"/> | ||||
|     <hamburger :is-active="sidebar.opened" class="hamburger-container" @toggleClick="toggleSideBar" /> | ||||
|  | ||||
|     <breadcrumb class="breadcrumb-container"/> | ||||
|     <breadcrumb class="breadcrumb-container" /> | ||||
|  | ||||
|     <div class="right-menu"> | ||||
|       <template v-if="device!=='mobile'"> | ||||
|         <search class="right-menu-item" /> | ||||
|  | ||||
|         <error-log class="errLog-container right-menu-item hover-effect"/> | ||||
|         <error-log class="errLog-container right-menu-item hover-effect" /> | ||||
|  | ||||
|         <screenfull class="right-menu-item hover-effect"/> | ||||
|         <screenfull class="right-menu-item hover-effect" /> | ||||
|  | ||||
|         <el-tooltip :content="$t('navbar.size')" effect="dark" placement="bottom"> | ||||
|           <size-select class="right-menu-item hover-effect"/> | ||||
|           <size-select class="right-menu-item hover-effect" /> | ||||
|         </el-tooltip> | ||||
|  | ||||
|         <lang-select class="right-menu-item hover-effect"/> | ||||
|         <lang-select class="right-menu-item hover-effect" /> | ||||
|  | ||||
|         <el-tooltip :content="$t('navbar.theme')" effect="dark" placement="bottom"> | ||||
|           <theme-picker class="right-menu-item hover-effect"/> | ||||
|           <theme-picker class="right-menu-item hover-effect" /> | ||||
|         </el-tooltip> | ||||
|       </template> | ||||
|  | ||||
|       <el-dropdown class="avatar-container right-menu-item hover-effect" trigger="click"> | ||||
|         <div class="avatar-wrapper"> | ||||
|           <img :src="avatar+'?imageView2/1/w/80/h/80'" class="user-avatar"> | ||||
|           <i class="el-icon-caret-bottom"/> | ||||
|           <i class="el-icon-caret-bottom" /> | ||||
|         </div> | ||||
|         <el-dropdown-menu slot="dropdown"> | ||||
|           <router-link to="/"> | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| <template> | ||||
|   <!-- eslint-disable vue/require-component-is --> | ||||
|   <component v-bind="linkProps(to)"> | ||||
|     <slot/> | ||||
|     <slot /> | ||||
|   </component> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| <template> | ||||
|   <div v-if="!item.hidden" class="menu-wrapper"> | ||||
|  | ||||
|     <template v-if="hasOneShowingChild(item.children,item) && (!onlyOneChild.children||onlyOneChild.noShowingChildren)&&!item.alwaysShow"> | ||||
|       <app-link :to="resolvePath(onlyOneChild.path)"> | ||||
|         <el-menu-item :index="resolvePath(onlyOneChild.path)" :class="{'submenu-title-noDropdown':!isNest}"> | ||||
| @@ -15,13 +14,13 @@ | ||||
|       </template> | ||||
|       <sidebar-item | ||||
|         v-for="child in item.children" | ||||
|         :key="child.path" | ||||
|         :is-nest="true" | ||||
|         :item="child" | ||||
|         :key="child.path" | ||||
|         :base-path="resolvePath(child.path)" | ||||
|         class="nest-menu" /> | ||||
|         class="nest-menu" | ||||
|       /> | ||||
|     </el-submenu> | ||||
|  | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -8,7 +8,7 @@ | ||||
|       :active-text-color="variables.menuActiveText" | ||||
|       mode="vertical" | ||||
|     > | ||||
|       <sidebar-item v-for="route in permission_routers" :key="route.path" :item="route" :base-path="route.path"/> | ||||
|       <sidebar-item v-for="route in permission_routers" :key="route.path" :item="route" :base-path="route.path" /> | ||||
|     </el-menu> | ||||
|   </el-scrollbar> | ||||
| </template> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
|   <el-scrollbar ref="scrollContainer" :vertical="false" class="scroll-container" @wheel.native.prevent="handleScroll"> | ||||
|     <slot/> | ||||
|     <slot /> | ||||
|   </el-scrollbar> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -4,23 +4,32 @@ | ||||
|       <router-link | ||||
|         v-for="tag in visitedViews" | ||||
|         ref="tag" | ||||
|         :key="tag.path" | ||||
|         :class="isActive(tag)?'active':''" | ||||
|         :to="{ path: tag.path, query: tag.query, fullPath: tag.fullPath }" | ||||
|         :key="tag.path" | ||||
|         tag="span" | ||||
|         class="tags-view-item" | ||||
|         @click.middle.native="closeSelectedTag(tag)" | ||||
|         @contextmenu.prevent.native="openMenu(tag,$event)"> | ||||
|         @contextmenu.prevent.native="openMenu(tag,$event)" | ||||
|       > | ||||
|         {{ generateTitle(tag.title) }} | ||||
|         <span v-if="!tag.meta.affix" class="el-icon-close" @click.prevent.stop="closeSelectedTag(tag)" /> | ||||
|       </router-link> | ||||
|     </scroll-pane> | ||||
|     <ul v-show="visible" :style="{left:left+'px',top:top+'px'}" class="contextmenu"> | ||||
|       <li @click="refreshSelectedTag(selectedTag)">{{ $t('tagsView.refresh') }}</li> | ||||
|       <li v-if="!(selectedTag.meta&&selectedTag.meta.affix)" @click="closeSelectedTag(selectedTag)">{{ | ||||
|       $t('tagsView.close') }}</li> | ||||
|       <li @click="closeOthersTags">{{ $t('tagsView.closeOthers') }}</li> | ||||
|       <li @click="closeAllTags(selectedTag)">{{ $t('tagsView.closeAll') }}</li> | ||||
|       <li @click="refreshSelectedTag(selectedTag)"> | ||||
|         {{ $t('tagsView.refresh') }} | ||||
|       </li> | ||||
|       <li v-if="!(selectedTag.meta&&selectedTag.meta.affix)" @click="closeSelectedTag(selectedTag)"> | ||||
|         {{ | ||||
|           $t('tagsView.close') }} | ||||
|       </li> | ||||
|       <li @click="closeOthersTags"> | ||||
|         {{ $t('tagsView.closeOthers') }} | ||||
|       </li> | ||||
|       <li @click="closeAllTags(selectedTag)"> | ||||
|         {{ $t('tagsView.closeAll') }} | ||||
|       </li> | ||||
|     </ul> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
| <template> | ||||
|   <div class="social-signup-container"> | ||||
|     <div class="sign-btn" @click="wechatHandleClick('wechat')"> | ||||
|       <span class="wx-svg-container"><svg-icon icon-class="wechat" class="icon"/></span> 微信 | ||||
|       <span class="wx-svg-container"><svg-icon icon-class="wechat" class="icon" /></span> 微信 | ||||
|     </div> | ||||
|     <div class="sign-btn" @click="tencentHandleClick('tencent')"> | ||||
|       <span class="qq-svg-container"><svg-icon icon-class="qq" class="icon"/></span> QQ | ||||
|       <span class="qq-svg-container"><svg-icon icon-class="qq" class="icon" /></span> QQ | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| <template > | ||||
| <template> | ||||
|   <div style="padding:30px;"> | ||||
|     <el-alert :closable="false" title="menu 1"> | ||||
|       <router-view /> | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| <template > | ||||
| <template> | ||||
|   <div style="padding:30px;"> | ||||
|     <el-alert :closable="false" title="menu 1-1" type="success"> | ||||
|       <router-view /> | ||||
|   | ||||
| @@ -1,12 +1,14 @@ | ||||
| <template> | ||||
|   <div v-loading.fullscreen.lock="fullscreenLoading" class="main-article" element-loading-text="Efforts to generate PDF"> | ||||
|     <div class="article__heading"> | ||||
|       <div class="article__heading__title"> {{ article.title }}</div> | ||||
|       <div class="article__heading__title"> | ||||
|         {{ article.title }} | ||||
|       </div> | ||||
|     </div> | ||||
|     <div style="color: #ccc;"> | ||||
|       This article is from Evan You on <a target="_blank" href="https://medium.com/the-vue-point/plans-for-the-next-iteration-of-vue-js-777ffea6fabf">medium</a> | ||||
|     </div> | ||||
|     <div ref="content" class="node-article-content" v-html="article.content"/> | ||||
|     <div ref="content" class="node-article-content" v-html="article.content" /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -2,7 +2,9 @@ | ||||
|   <div class="app-container"> | ||||
|     <code style="margin-top:15px;">{{ $t('pdf.tips') }}</code> | ||||
|     <router-link target="_blank" to="/pdf/download"> | ||||
|       <el-button type="primary">Click to download PDF</el-button> | ||||
|       <el-button type="primary"> | ||||
|         Click to download PDF | ||||
|       </el-button> | ||||
|     </router-link> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -1,10 +1,12 @@ | ||||
| <template> | ||||
|   <div> | ||||
|     <div style="margin-bottom:15px;">{{ $t('permission.roles') }}: {{ roles }}</div> | ||||
|     <div style="margin-bottom:15px;"> | ||||
|       {{ $t('permission.roles') }}: {{ roles }} | ||||
|     </div> | ||||
|     {{ $t('permission.switchRoles') }}: | ||||
|     <el-radio-group v-model="switchRoles"> | ||||
|       <el-radio-button label="editor"/> | ||||
|       <el-radio-button label="admin"/> | ||||
|       <el-radio-button label="editor" /> | ||||
|       <el-radio-button label="admin" /> | ||||
|     </el-radio-group> | ||||
|   </div> | ||||
| </template> | ||||
|   | ||||
| @@ -7,7 +7,9 @@ | ||||
|           Only | ||||
|           <el-tag class="permission-tag" size="small">admin</el-tag> can see this | ||||
|         </span> | ||||
|         <el-tag v-permission="['admin']" class="permission-sourceCode" type="info">v-permission="['admin']"</el-tag> | ||||
|         <el-tag v-permission="['admin']" class="permission-sourceCode" type="info"> | ||||
|           v-permission="['admin']" | ||||
|         </el-tag> | ||||
|       </div> | ||||
|  | ||||
|       <div> | ||||
| @@ -15,7 +17,9 @@ | ||||
|           Only | ||||
|           <el-tag class="permission-tag" size="small">editor</el-tag> can see this | ||||
|         </span> | ||||
|         <el-tag v-permission="['editor']" class="permission-sourceCode" type="info">v-permission="['editor']"</el-tag> | ||||
|         <el-tag v-permission="['editor']" class="permission-sourceCode" type="info"> | ||||
|           v-permission="['editor']" | ||||
|         </el-tag> | ||||
|       </div> | ||||
|  | ||||
|       <div> | ||||
| @@ -24,7 +28,9 @@ | ||||
|           <el-tag class="permission-tag" size="small">admin</el-tag> and | ||||
|           <el-tag class="permission-tag" size="small">editor</el-tag> can see this | ||||
|         </span> | ||||
|         <el-tag v-permission="['admin','editor']" class="permission-sourceCode" type="info">v-permission="['admin','editor']"</el-tag> | ||||
|         <el-tag v-permission="['admin','editor']" class="permission-sourceCode" type="info"> | ||||
|           v-permission="['admin','editor']" | ||||
|         </el-tag> | ||||
|       </div> | ||||
|     </div> | ||||
|  | ||||
| @@ -37,17 +43,23 @@ | ||||
|       <el-tabs type="border-card" style="width:550px;"> | ||||
|         <el-tab-pane v-if="checkPermission(['admin'])" label="Admin"> | ||||
|           Admin can see this | ||||
|           <el-tag class="permission-sourceCode" type="info">v-if="checkPermission(['admin'])"</el-tag> | ||||
|           <el-tag class="permission-sourceCode" type="info"> | ||||
|             v-if="checkPermission(['admin'])" | ||||
|           </el-tag> | ||||
|         </el-tab-pane> | ||||
|  | ||||
|         <el-tab-pane v-if="checkPermission(['editor'])" label="Editor"> | ||||
|           Editor can see this | ||||
|           <el-tag class="permission-sourceCode" type="info">v-if="checkPermission(['editor'])"</el-tag> | ||||
|           <el-tag class="permission-sourceCode" type="info"> | ||||
|             v-if="checkPermission(['editor'])" | ||||
|           </el-tag> | ||||
|         </el-tab-pane> | ||||
|  | ||||
|         <el-tab-pane v-if="checkPermission(['admin','editor'])" label="Admin-OR-Editor"> | ||||
|           Both admin or editor can see this | ||||
|           <el-tag class="permission-sourceCode" type="info">v-if="checkPermission(['admin','editor'])"</el-tag> | ||||
|           <el-tag class="permission-sourceCode" type="info"> | ||||
|             v-if="checkPermission(['admin','editor'])" | ||||
|           </el-tag> | ||||
|         </el-tab-pane> | ||||
|       </el-tabs> | ||||
|     </div> | ||||
| @@ -59,7 +71,7 @@ import permission from '@/directive/permission/index.js' // 权限判断指令 | ||||
| import checkPermission from '@/utils/permission' // 权限判断函数 | ||||
| import SwitchRoles from './components/SwitchRoles' | ||||
|  | ||||
| export default{ | ||||
| export default { | ||||
|   name: 'DirectivePermission', | ||||
|   components: { SwitchRoles }, | ||||
|   directives: { permission }, | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user