Commit c8ce20d8 authored by Nature's avatar Nature

genx模版工程

parent 2635147b
<template>
<h-view class="public-style hls-popup" style="height: 100%">
<h-header class="bar-custom">
<div slot="left" class="h-header-btn" @click="$routeGo()">
<i class="ion-ios-arrow-back"/>
</div>
<div slot="center">封装测试</div>
<div slot="right" class="h-header-btn">
操作
</div>
</h-header>
<!-- <s-tab @tabClick="stablick" cusClass="popup-tab">
<tab-item>测试</tab-item>
<tab-item>你好</tab-item>
<tab-item>再见</tab-item>
<tab-item>按钮</tab-item>
</s-tab>-->
<h-content
class="has-header has-footer">
<h-button class="button-class" type="primary" @click.native="showLoading">showLoading</h-button>
<h-button class="button-class" type="primary" @click.native="hideLoading">hideLoading</h-button>
<h-button class="button-class" type="primary" @click.native="showLongTop">showLongTop</h-button>
<h-button class="button-class" type="primary" @click.native="showLongCenter">showLongCenter</h-button>
<h-button class="button-class" type="primary" @click.native="showLongBottom">showLongBottom</h-button>
<h-button class="button-class" type="primary" @click.native="showSuccess">showSuccess</h-button>
<h-button class="button-class" type="primary" @click.native="showError">showError</h-button>
<h-button class="button-class" type="primary" @click.native="showConfirm">showConfirm</h-button>
<h-button class="button-class" type="primary" @click.native="showPopup">showPopup</h-button>
<h-button class="button-class" type="primary" @click.native="showActionSheet">showActionSheet</h-button>
<h-button class="button-class" type="primary" @click.native="showActionSheetButton">showActionSheet 区分按钮颜色
</h-button>
<h-button class="button-class" type="primary" @click.native="showTime('YYYY')">showTime YYYY</h-button>
<h-button class="button-class" type="primary" @click.native="showTime('YYYY-MM')">showTime YYYY-MM</h-button>
<h-button class="button-class" type="primary" @click.native="showTime('YYYY-MM-DD')">showTime YYYY-MM-DD
</h-button>
<h-button class="button-class" type="primary" @click.native="showTime('YYYY-MM-DD HH')">showTime YYYY-MM-DD HH
</h-button>
<h-button class="button-class" type="primary" @click.native="showTime('YYYY-MM-DD HH:mm')">showTime YYYY-MM-DD
HH:mm
</h-button>
<h-button class="button-class" type="primary" @click.native="showBigPicture">showBigPicture</h-button>
<h-button class="button-class" type="primary" @click.native="selectListOne">selectList 普通下拉框</h-button>
<h-button class="button-class" type="primary" @click.native="selectListTwo">selectList 二级联动</h-button>
<h-button class="button-class" type="primary" @click.native="selectList">selectList 三级联动</h-button>
<h2 class="item-title">按钮类型</h2>
<h-button class="button-class" type="rimless">rimless 按钮</h-button>
<h-button class="button-class" type="default">default 按钮</h-button>
<h-button class="button-class" type="primary">primary 按钮</h-button>
<h-button class="button-class" type="safety">safety 按钮</h-button>
<h-button class="button-class" type="warning">warning 按钮</h-button>
<h-button class="button-class" type="danger">danger 按钮</h-button>
<h2 class="item-title">按钮尺寸</h2>
<h-button class="button-class" size="mini">mini 按钮</h-button>
<h-button class="button-class" size="small">small 按钮</h-button>
<h-button class="button-class" size="normal">normal 按钮</h-button>
<h-button class="button-class" size="large">large 按钮</h-button>
<h-button class="button-class" size="huge">huge 按钮</h-button>
<h2 class="item-title">自定义圆角 (直接通过class设置)</h2>
<h-button class="button-class radius-small">rimless 按钮</h-button>
<h-button class="button-class radius-normal">default 按钮</h-button>
<h-button class="button-class radius-large">primary 按钮</h-button>
<h2 class="item-title">默认点击效果</h2>
<h-button class="button-class radius-small" type="rimless">基础按钮(无边框)</h-button>
<h-button class="button-class radius-small" type="rimless" shadow>基础按钮(无边框、有阴影效果)</h-button>
<h-button class="button-class radius-small purple">基础按钮(有背景色)</h-button>
<h2 class="item-title">禁用效果</h2>
<h-button class="button-class radius-small" disabled>基础按钮(禁用)</h-button>
<h2 class="item-title">Swip基础使用</h2>
<swipe :interval="5000" @start="start" @move="move" @change="change">
<swipe-item>
<div :style="{'background': bgColor[0]}" class="item-bg">0</div>
</swipe-item>
<swipe-item>
<div :style="{'background': bgColor[1]}" class="item-bg">1</div>
</swipe-item>
<swipe-item>
<div :style="{'background': bgColor[2]}" class="item-bg">2</div>
</swipe-item>
</swipe>
<h2 class="item-title">纵向滚动</h2>
<swipe :vertical="true" style="height: 200px">
<swipe-item v-for="key in count" :key="key" :style="{'background': bgColor[key-1]}">
<div class="item-bg">{{ key-1 }}</div>
</swipe-item>
</swipe>
<h2 class="item-title">定制indicators</h2>
<swipe :index.sync="index">
<swipe-item v-for="key in count" :key="key" :style="{'background': bgColor[key-1]}">
<div class="item-bg">{{ key-1 }}</div>
</swipe-item>
<div v-for="key in count" slot="indicators" :key="key" :class="['indicators', {'active': key-1 === index}]"/>
</swipe>
<h2 class="item-title">Spin-CSS</h2>
<div class="spin-container">
<spin size="20px" color="#ccc"/>
<spin size="30px" color="#999"/>
<spin size="40px" color="#666"/>
<spin size="50px" color="#333"/>
</div>
<h2 class="item-title">SVG</h2>
<div class="spin-container">
&lt;!&ndash; 颜色要通过修改svg来实现,无法通过属性修改 &ndash;&gt;
<spin :svg-src="svgSrc" size="40px"/>
<spin :svg-src="svgSrc" size="50px"/>
<spin :svg-src="svgSrc" size="60px"/>
<spin :svg-src="svgSrc" size="70px"/>
</div>
<h2 class="item-title">top-tip</h2>
<div class="local-region">
<top-tip v-model="show" entry-direction="down" content="顶部消息提示内容"/>
参考文案
</div>
<h-button class="button-class" type="rimless" shadow @click.native="showTopTip">TopTip</h-button>
<h2 class="item-title">notify</h2>
<div class="local-region">
<notify v-model="show1" content="提示内容" type="success"/>
<notify v-model="show2" :time="3000" position="bottom" content="提示内容"/>
</div>
<h2 class="item-title">notify标签用法 (通常在局部显示时使用)</h2>
<h-button class="button-class" type="rimless" shadow @click.native="showNotifyAtTop">Notify (top)</h-button>
<h-button class="button-class" type="rimless" shadow @click.native="showNotifyAtBottom">Notify (bottom)</h-button>
<h2 class="item-title">notify 插件用法</h2>
<h-button class="button-class purple" type="rimless" shadow @click.native="handleNotify">NotifyPlugin</h-button>
<h2 class="item-title">数字键盘</h2>
<div class="list">
<div class="item">
<div class="contents">
<div class="add-name">
<div>数字键盘</div>
</div>
<div class="add-content readonly" @click="keyboradShow">
<input v-model="value" type="number" placeholder="输入" readonly>
</div>
</div>
</div>
</div>
<list-item :item-height="45">
<item>
<div slot="name">数字键盘</div>
<input
slot="content" v-model="value" type="number" placeholder="输入"
readonly @click="keyboradShow">
</item>
</list-item>
<div class="list">
<item-option
v-for="(color,index) in colors" :key="index"
class="mySlider">
<div>{{ color.name }}</div>
<div>{{ color.hex }}</div>
<div slot="buttons">
<option-button type="default" text="默认" @click.native="deleteFun"/>
<option-button type="primary" text="编辑" @click.native="deleteFun"/>
<option-button type="warn" text="删除" @click.native="deleteFun"/>
</div>
</item-option>
</div>
<h2>picker</h2>
<picker
ref="picker1" :data="year7" :columns="3" v-model="year7Value"
style="width: 100%"
@on-change="change"/>
<list-item :item-height="45">
<item>
<img slot="left-icon" src="../assets/image/warning@2x.png" class="left-icon">
<div slot="name" class="required">检查更新</div>
<div slot="content">检查更新</div>
<img slot="right-icon" src="../assets/image/arrow-down@2x.png" style="width: 8px" class="right-icon">
</item>
<item>
<img slot="left" src="../assets/image/warning@2x.png" class="left-icon">
<div slot="name" class="required">字数测试</div>
<div slot="content">我是一段很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长很长的文字</div>
</item>
<item :showArrow="true">
<img slot="left" src="../assets/image/warning@2x.png" class="left-icon">
<div slot="name">客户名称</div>
<input slot="content" v-model="bp_name" type="text" placeholder="请输入">
</item>
<item :show-arrow="true">
<img slot="left-icon" src="../assets/image/warning@2x.png" class="left-icon">
<div slot="name">保存照片</div>
<label slot="right" class="toggle toggle-positive toggle-check" @click="savePhotoFun">
<input :checked="savePhoto" type="checkbox" >
<div class="track">
<div class="handle"/>
</div>
</label>
<check-box slot="content" v-model="savePhoto" @checkClick="savePhotoFun"/>
</item>
</list-item>
<h2 class="item-title">s-tab</h2>
<div class="local-region">
<s-tab :show-divider="true" @tabClick="stabClick">
<tab-item>测试</tab-item>
<tab-item>你好</tab-item>
<tab-item>再见</tab-item>
<tab-item>按钮</tab-item>
</s-tab>
<s-tab :default-active="2" position="bottom" cusClass="class" @tabClick="stabClick">
<tab-item><img src="../assets/image/warning@2x.png" style="width: 18px"></tab-item>
<tab-item><img src="../assets/image/warning@2x.png" style="width: 18px"></tab-item>
<tab-item><img src="../assets/image/warning@2x.png" style="width: 18px"></tab-item>
<tab-item><img src="../assets/image/warning@2x.png" style="width: 18px"></tab-item>
</s-tab>
</div>
<h2 class="item-title">Modal</h2>
<h-button class="button-class" type="primary" @click.native="showModal">Modal</h-button>
</h-content>
<bottom-tab :show-divider="true">
<tab-button cusClass="button-exit" @click.native="showConfirm"><img
src="../assets/image/warning@2x.png">退出
</tab-button>
<tab-button :disable="true" @click.native="showSuccess">登陆</tab-button>
</bottom-tab>
<!-- <number-keyboard
:show="true"
title="数字键盘"
extra-key="."
@input="onInput"
@delete="onDelete"/>-->
<h-modal ref="modal" v-model="showModalValue" position="bottom" cus-class="sign-modal">
<h-view>
<h-header style="height: 43px !important;padding-top:0px">
<div slot="left" class="h-header-btn">确定</div>
<div slot="right" class="h-header-btn">清除</div>
</h-header>
<h-content style="top:44px !important;">
<div id="draw" class="draw"/>
</h-content>
</h-view>
</h-modal>
</h-view>
</template>
<script>
import svg from '@/assets/image/loading/rolling.svg'
export default {
data () {
return {
index: 0,
count: 3,
value: '',
show: false,
items: [],
infiniteCount: 0,
deleteText: '删除',
editText: '编辑',
colors: [{name: 'Yellow', hex: '#f4d03f'}, {name: 'Green', hex: '#229954'}, {name: 'Purple', hex: '#9b59b6'}],
svgSrc: svg,
show1: false,
show2: false,
bp_name: '',
savePhoto: new Boolean(window.localStorage.savePhoto) || false,
year7Value: [],
year7: [{
name: '中国',
value: 'china',
parent: '0', // 为一级时可以不写 parent,但是此时允许为数字 0、空字符串或者字符串 '0'
}, {
name: '美国',
value: 'USA',
parent: '0',
}, {
name: '广东',
value: 'china001',
parent: 'china',
}, {
name: '广西',
value: 'china002',
parent: 'china',
}, {
name: '美国001',
value: 'usa001',
parent: 'USA',
}, {
name: '美国002',
value: 'usa002',
parent: 'USA',
}, {
name: '广州',
value: 'gz',
parent: 'china001',
}, {
name: '深圳',
value: 'sz',
parent: 'china001',
}, {
name: '广西001',
value: 'gx001',
parent: 'china002',
}, {
name: '广西002',
value: 'gx002',
parent: 'china002',
}, {
name: '美国001_001',
value: '0003',
parent: 'usa001',
}, {
name: '美国001_002',
value: '0004',
parent: 'usa001',
}, {
name: '美国002_001',
value: '0005',
parent: 'usa002',
}, {
name: '美国002_002',
value: '0006',
parent: 'usa002',
}],
modal: '',
showModalValue: false,
}
},
watch: {
bp_name (value) {
console.log('bp_name:' + value)
},
},
activated () {
for (let i = 1; i <= 20; i++) {
this.items.push(i + ' - keep walking, be 2 with you.')
}
this.top = 1
// this.bottom = 20;
},
created: function () {
this.bgColor = ['#5D98F6', '#1aad19', '#eebe41']
},
mounted () {
/* HlsModal.fromComponent(popup, {
cusClass:"login-modal",
onHide: () => {
console.log('modal hide')
},
onShow: () => {
console.log('modal show')
}
}).then((modal) => {
this.modal = modal;
}) */
},
methods: {
stab () {
console.log('tab-click')
},
stabClick (index) {
console.log('tabClickIndex:' + index)
},
// 标签用法
showNotifyAtTop () {
if (this.show1) return
this.show1 = true
},
showNotifyAtBottom () {
if (this.show2) return
this.show2 = true
},
handleNotify () {
hlsPopup.showNotify({
content: '提示内容',
position: 'top',
time: 2000,
type: 'warning',
})
},
showTopTip () {
if (this.show) return
this.show = true
},
start (i) {
console.log(`start: ${i}`)
},
move (i) {
console.log(`move: ${i}`)
},
change (i) {
// console.log(`change: ${i}`)
},
showLoading () {
hlsPopup.showLoading('请稍等!')
},
hideLoading () {
hlsPopup.hideLoading()
},
showLongTop () {
hlsPopup.showLongTop('操作成功操作成功操作成功操作成功操作成功操作成功操作成功操作成功操作成功')
},
showLongCenter () {
hlsPopup.showLongCenter('操作成功操作成功操作成功')
},
showLongBottom () {
hlsPopup.showLongBottom('操作成功操作成功操作成功操作成功')
},
showSuccess () {
hlsPopup.showSuccess('操作成功')
},
showError () {
hlsPopup.showError('操作失败')
},
showConfirm () {
hlsPopup.showConfirm({
title: '确定退出',
content: '退出后需从新登录',
onConfirm: function (index) {
alert(index)
},
})
},
showPopup () {
hlsPopup.showPopup({
title: '确定退出',
content: '退出后需从新登录',
onConfirm: function () {
alert('to do something')
},
})
},
showActionSheet () {
hlsPopup.showActionSheet({
titleText: '请选择照片',
buttonArray: ['拍照', '从相册取'],
callback: (index) => {
alert(index)
},
})
},
showActionSheetButton () {
hlsPopup.showActionSheet({
titleText: '照片',
buttonArray: [{text: '拍照', type: 'warn'}, {text: '从相册取', type: 'primary'}],
callback: (index) => {
alert(index)
},
})
},
showTime (format) {
hlsPopup.showTime({
nowDate: '2017-08-12',
format: format,
callback: (date) => {
alert(date)
},
})
},
showBigPicture () {
hlsPopup.showBigPicture({
imgUrl: 'http://hlsapp.hand-china.com/hls_file/2018/05/F1B6D85E409A4714A8540504B2D133AD',
})
},
selectListOne () {
var bpClassList = [
{
'code': 'NP',
'code_name': '个人',
}, {
'code': 'NP1',
'code_name': '个人1',
}, {
'code': 'NP2',
'code_name': '个人2',
},
]
hlsPopup.selectList({
list: bpClassList,
code: 'bp_type',
object: {},
returnItem: function (index, obj, child) {
console.log('index:' + index + ',object:' + vum.toJson(obj) + ',:child' + vum.toJson(child))
},
})
},
selectListTwo () {
var bpClassList = [
{
'code': 'NP',
'code_name': '个人',
}, {
'code': 'NP1',
'code_name': '个人1',
}, {
'code': 'NP2',
'code_name': '个人2',
}, {
'code': 'NP3',
'code_name': '个人3',
'parent': 'NP',
}, {
'code': 'NP4',
'code_name': '个人4',
'parent': 'NP1',
}, {
'code': 'NP5',
'code_name': '个人5',
'parent': 'NP2',
},
]
hlsPopup.selectList({
list: bpClassList,
code: 'bp_type',
object: {},
returnItem: function (index, obj, child) {
console.log('index:' + index + ',object:' + vum.toJson(obj) + ',:child' + vum.toJson(child))
},
})
},
selectList () {
var bpClassList = [
{
'code': 'NP',
'code_name': '个人',
}, {
'code': 'NP1',
'code_name': '个人1',
}, {
'code': 'NP2',
'code_name': '个人2',
}, {
'code': 'NP3',
'code_name': '个人3',
'parent': 'NP',
}, {
'code': 'NP4',
'code_name': '个人4',
'parent': 'NP',
}, {
'code': 'NP5',
'code_name': '个人5',
'parent': 'NP2',
}, {
'code': 'NP6',
'code_name': '个人6',
'parent': 'NP3',
}, {
'code': 'NP7',
'code_name': '个人7',
'parent': 'NP4',
},
{
'code': 'NP8',
'code_name': '个人8',
'parent': 'NP1',
},
]
hlsPopup.selectList({
list: bpClassList,
code: 'bp_type',
object: {},
returnItem: function (index, obj, child) {
console.log('index:' + index + ',object:' + vum.toJson(obj) + ',:child' + vum.toJson(child))
},
})
},
onRefresh (done) {
setTimeout(() => {
let start = this.top - 1
for (let i = start; i > start - 10; i--) {
this.items.splice(0, 0, i + ' - keep walking, be 2 with you.')
}
this.top = this.top - 10
done()
}, 1500)
},
onInfinite (done) {
setTimeout(() => {
if (this.infiniteCount < 2) {
let start = this.bottom + 1
for (let i = start; i < start + 10; i++) {
this.items.push(i + ' - keep walking, be 2 with you.')
}
this.bottom = this.bottom + 10
this.infiniteCount++
}
done()
}, 1500)
},
onItemClick (index) {
console.log(index)
},
onInput (value) {
this.value += ('' + value)
console.log(value)
},
onDelete () {
this.value = ''
console.log('delete')
},
keyboradShow () {
let vm = this
hlsPopup.showNumberKeyborad({
title: '数字键盘',
keyDown: (text) => {
vm.onInput(text)
},
keyDelete: () => {
vm.onDelete()
},
})
},
// e为该元素在数组的下标
deleteFun (e) {
console.log(e)
},
// e为该元素在数组的下标
editFun (e) {
console.log(e)
},
savePhotoFun (value) {
this.savePhoto = value
window.localStorage.setItem('savePhoto', value)
},
showModal () {
this.showModalValue = true
},
},
}
</script>
<style lang="less" rel="stylesheet">
.hls-popup {
height: 100%;
width: 100%;
.vue-better-scroll__wrapper {
width: 100%;
}
.list {
width: 100%;
}
.content {
.scrollContent {
display: flex;
display: -webkit-flex;
align-items: center;
-webkit-align-items: center;
flex-direction: column;
-webkit-flex-direction: column;
}
.button-class {
width: 90%;
margin: 10px 5%;
display: block;
&.image {
width: auto;
margin-right: 0;
display: inline-block;
}
&.radius-small {
border-radius: 6px;
}
&.radius-normal {
border-radius: 16px;
}
&.radius-large {
border-radius: 40px;
}
.spin {
vertical-align: middle;
}
.text {
font-size: 28px;
margin-left: 16px;
vertical-align: middle;
}
}
.purple {
color: #fff;
background-color: #7e57c2;
border: 1px solid #7e57c2;
}
.button {
background-color: @theme-color;
color: #ffffff;
height: 100px;
width: 600px;
border: 20px;
margin-top: 20px;
}
}
.item-bg {
height: 200px;
line-height: 200px;
text-align: center;
font-size: 20px;
font-weight: 500;
}
.indicators {
height: 14px;
width: 14px;
background-image: url('../assets/image/logo.png');
background-position: center;
background-size: cover;
opacity: 0.5;
&.active {
opacity: 1;
}
}
.local-region {
overflow: hidden;
position: relative;
height: 200px;
background-color: #eee;
width: 90%;
}
.sign-modal {
top: 50%;
.content {
background-color: #fff;
}
}
}
.login-modal {
height: 50%;
top: 50%
}
</style>
......@@ -16,7 +16,7 @@
<tab-item>按钮</tab-item>
</s-tab>-->
<h-content
class="has-header has-footer">
class="has-footer">
<h-button class="button-class" type="primary" @click.native="showLoading">showLoading</h-button>
<h-button class="button-class" type="primary" @click.native="hideLoading">hideLoading</h-button>
<h-button class="button-class" type="primary" @click.native="showLongTop">showLongTop</h-button>
......@@ -218,6 +218,9 @@
<tab-item>你好</tab-item>
<tab-item>再见</tab-item>
<tab-item>按钮</tab-item>
<tab-item>按钮1</tab-item>
<tab-item>按钮2</tab-item>
<tab-item>按钮3</tab-item>
</s-tab>
<s-tab :default-active="2" position="bottom" cusClass="class" @tabClick="stabClick">
......@@ -660,6 +663,12 @@ export default {
.home {
height: 100%;
width: 100%;
.hls-switch-tab {
.tab-content .h-tab-item .h-item{
width: 80px;
}
}
.vue-better-scroll__wrapper {
width: 100%;
}
......
......@@ -3,9 +3,6 @@ import Router from 'vue-router'
import Home from '@/pages/home'
// test工具类
import HlsPopup from '@/pages/hlsPopup'
Vue.use(Router)
export default new Router({
......@@ -15,8 +12,6 @@ export default new Router({
redirect: '/home',
},
{path: '/home', component: Home, name: 'Home', meta: {keepAlive: true}},
// test工具类
{path: '/hls-popup', component: HlsPopup, name: 'HlsPopup', meta: {keepAlive: false}},
],
scrollBehavior (to, from, savedPosition) {
if (to.hash) {
......
......@@ -215,7 +215,7 @@
self.platforms = []
var grade = 'a'
if (self.isWebView()) {
/*if (self.isWebView()) {
self.platforms.push('webview')
if (!(!window.cordova && !window.PhoneGap && !window.phonegap)) {
self.platforms.push('cordova')
......@@ -225,13 +225,13 @@
} else {
self.platforms.push('browser')
}
if (self.isIPad()) self.platforms.push('ipad')
if (self.isIPad()) self.platforms.push('ipad')*/
var platform = self.platform()
if (platform) {
self.platforms.push(platform)
var version = self.version()
/*var version = self.version()
if (version) {
var v = version.toString()
if (v.indexOf('.') > 0) {
......@@ -247,10 +247,10 @@
} else if (self.isWindowsPhone()) {
grade = 'b'
}
}
}*/
}
self.setGrade(grade)
// self.setGrade(grade)
},
/**
......
......@@ -3814,8 +3814,8 @@ he@1.2.x, he@^1.1.0:
integrity sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==
"hls-easy-ui@https://hel.hand-china.com/easyUI/hls-easy-ui.git":
version "0.0.1"
resolved "https://hel.hand-china.com/easyUI/hls-easy-ui.git#1d9bc73a5851fb1e5c7da9a44d0abb864d1230b0"
version "0.0.2"
resolved "https://hel.hand-china.com/easyUI/hls-easy-ui.git#97c1d4977c4ba45219fe242c2bfeece022946de8"
dependencies:
autosize "^3.0.20"
better-scroll "^1.10.3"
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment