59
									
								
								components/ywx-auth-model/ywx-auth-model.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								components/ywx-auth-model/ywx-auth-model.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| <template> | ||||
| 	<view> | ||||
| 		 | ||||
| 		 | ||||
| 		<button @click="open">关闭</button> | ||||
| 		<uni-popup ref="popup" :mask-click="false" type="bottom"> | ||||
| 			<text>Popup</text> | ||||
|  | ||||
| 			<button class="avatar-wrapper" open-type="chooseAvatar" @tap="onChooseAvatar"> | ||||
| 				<image class="avatar" :src="avatarUrl" style="width: 320rpx; height: 320rpx; margin: auto;"></image> | ||||
| 			</button> | ||||
|  | ||||
| 			<uni-easyinput placeholder="请输入昵称" v-model="nickname" type="nickname"></uni-easyinput> | ||||
| 			<button v-show="showPhone" type="primary" block open-type="getPhoneNumber" @getphonenumber="getPhone"> | ||||
| 				授权电话 | ||||
| 			</button> | ||||
| 		</uni-popup> | ||||
| 	</view> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| 	export default { | ||||
| 		name: "ywx-auth-model", | ||||
| 		data() { | ||||
| 			return { | ||||
| 				avatarUrl: 'https://mmbiz.qpic.cn/mmbiz/icTdbqWNOwNRna42FI242Lcia07jQodd2FJGIYQfG0LAJGFxM4FbnQP6yfMxBgJ0F3YRqJCJ1aPAK2dQagdusBZg/0', | ||||
| 				openid: "", | ||||
| 				loginstate: "0", | ||||
| 				openid: "", | ||||
| 				userEntity: null, | ||||
| 				terminal: "", | ||||
| 				osVersion: "", | ||||
| 				phoneNumber: "", | ||||
| 				showPhone:false, | ||||
| 				showModal: false, //定义登录弹窗   | ||||
| 			} | ||||
| 		}, | ||||
| 		onLoad: function() {}, | ||||
| 		methods: { | ||||
| 			onChooseAvatar(e) { | ||||
| 				console.log(e) | ||||
| 				const { | ||||
| 					avatarUrl | ||||
| 				} = e.detail | ||||
| 				this.avatarUrl = avatarUrl | ||||
| 			}, | ||||
| 			open() { | ||||
| 				this.$refs.popup.open('top') | ||||
| 			}, | ||||
| 			close() { | ||||
| 				this.$refs.popup.close() | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| </script> | ||||
|  | ||||
| <style> | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										11
									
								
								pages.json
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								pages.json
									
									
									
									
									
								
							| @@ -63,5 +63,14 @@ | ||||
| 			 | ||||
| 		} | ||||
| 	}, | ||||
| 	"uniIdRouter": {} | ||||
| 	"uniIdRouter": {}, | ||||
| 	"condition": { | ||||
| 		"current": 0, | ||||
| 		"list": [ | ||||
| 			{ | ||||
| 				"name": "login", | ||||
| 				"path": "pages/login/login" | ||||
| 			} | ||||
| 		] | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -1,25 +1,27 @@ | ||||
| <template> | ||||
| 	<view | ||||
| 		style="height: 100vh;display: flex;flex-direction: column;align-items: center;justify-content: center;box-sizing: border-box;"> | ||||
| 		<button class="avatar-wrapper" open-type="chooseAvatar" @tap="onChooseAvatar"> | ||||
| 			<image class="avatar" :src="avatarUrl"></image> | ||||
| 		</button> | ||||
| 		<input type="nickname" class="weui-input" placeholder="请输入昵称" /> | ||||
| 		style="height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;box-sizing:border-box;"> | ||||
| 		<ywx-auth-model></ywx-auth-model> | ||||
|  | ||||
| 		<button type="primary" block open-type="getUserInfo" @getuserinfo="appLoginWx"> | ||||
| 			微信一键登录 | ||||
| 		</button> | ||||
| 		<button v-show="showPhone" type="primary" block open-type="getPhoneNumber" @getphonenumber="getPhone"> | ||||
| 			授权电话 | ||||
| 		</button> | ||||
| 		<view style="padding: 35rpx;"> | ||||
| 			<button type="primary" block open-type="getUserInfo" @getuserinfo="appLoginWx"> | ||||
| 				微信一键登录 | ||||
| 			</button> | ||||
| 		</view> | ||||
| 	</view> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| 	//1.导入组件(这步属于传统vue规范,但在uni-app的easycom下可以省略这步) | ||||
| 	import ywxAuthModel from "@/components/ywx-auth-model/ywx-auth-model.vue"; | ||||
|  | ||||
| 	export default { | ||||
| 		//2.注册组件(这步属于传统vue规范,但在uni-app的easycom下可以省略这步)  | ||||
| 		components: { | ||||
| 			ywxAuthModel | ||||
| 		}, | ||||
| 		data() { | ||||
| 			return { | ||||
| 				avatarUrl: 'https://mmbiz.qpic.cn/mmbiz/icTdbqWNOwNRna42FI242Lcia07jQodd2FJGIYQfG0LAJGFxM4FbnQP6yfMxBgJ0F3YRqJCJ1aPAK2dQagdusBZg/0', | ||||
| 				openid: "", | ||||
| 				loginstate: "0", | ||||
| 				openid: "", | ||||
| @@ -32,13 +34,6 @@ | ||||
| 		}, | ||||
| 		onLoad: function() {}, | ||||
| 		methods: { | ||||
| 			onChooseAvatar(e) { | ||||
| 				console.log(e) | ||||
| 				const { | ||||
| 					avatarUrl | ||||
| 				} = e.detail | ||||
| 				this.avatarUrl = avatarUrl | ||||
| 			}, | ||||
| 			// 授权获取微信用户信息 | ||||
| 			appLoginWx(res) { | ||||
| 				console.log(res) | ||||
|   | ||||
							
								
								
									
										91
									
								
								uni_modules/uni-easyinput/changelog.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								uni_modules/uni-easyinput/changelog.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | ||||
| ## 1.1.6(2023-01-28) | ||||
| - 新增 keyboardheightchange 事件,可监听键盘高度变化 | ||||
| ## 1.1.5(2022-11-29) | ||||
| - 优化 主题样式 | ||||
| ## 1.1.4(2022-10-27) | ||||
| - 修复 props 中背景颜色无默认值的bug | ||||
| ## 1.1.0(2022-06-30) | ||||
|  | ||||
| - 新增 在 uni-forms 1.4.0 中使用可以在 blur 时校验内容 | ||||
| - 新增 clear 事件,点击右侧叉号图标触发 | ||||
| - 新增 change 事件 ,仅在输入框失去焦点或用户按下回车时触发 | ||||
| - 优化 组件样式,组件获取焦点时高亮显示,图标颜色调整等 | ||||
|  | ||||
| ## 1.0.5(2022-06-07) | ||||
|  | ||||
| - 优化 clearable 显示策略 | ||||
|  | ||||
| ## 1.0.4(2022-06-07) | ||||
|  | ||||
| - 优化 clearable 显示策略 | ||||
|  | ||||
| ## 1.0.3(2022-05-20) | ||||
|  | ||||
| - 修复 关闭图标某些情况下无法取消的 bug | ||||
|  | ||||
| ## 1.0.2(2022-04-12) | ||||
|  | ||||
| - 修复 默认值不生效的 bug | ||||
|  | ||||
| ## 1.0.1(2022-04-02) | ||||
|  | ||||
| - 修复 value 不能为 0 的 bug | ||||
|  | ||||
| ## 1.0.0(2021-11-19) | ||||
|  | ||||
| - 优化 组件 UI,并提供设计资源,详见:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource) | ||||
| - 文档迁移,详见:[https://uniapp.dcloud.io/component/uniui/uni-easyinput](https://uniapp.dcloud.io/component/uniui/uni-easyinput) | ||||
|  | ||||
| ## 0.1.4(2021-08-20) | ||||
|  | ||||
| - 修复 在 uni-forms 的动态表单中默认值校验不通过的 bug | ||||
|  | ||||
| ## 0.1.3(2021-08-11) | ||||
|  | ||||
| - 修复 在 uni-forms 中重置表单,错误信息无法清除的问题 | ||||
|  | ||||
| ## 0.1.2(2021-07-30) | ||||
|  | ||||
| - 优化 vue3 下事件警告的问题 | ||||
|  | ||||
| ## 0.1.1 | ||||
|  | ||||
| - 优化 errorMessage 属性支持 Boolean 类型 | ||||
|  | ||||
| ## 0.1.0(2021-07-13) | ||||
|  | ||||
| - 组件兼容 vue3,如何创建 vue3 项目,详见 [uni-app 项目支持 vue3 介绍](https://ask.dcloud.net.cn/article/37834) | ||||
|  | ||||
| ## 0.0.16(2021-06-29) | ||||
|  | ||||
| - 修复 confirmType 属性(仅 type="text" 生效)导致多行文本框无法换行的 bug | ||||
|  | ||||
| ## 0.0.15(2021-06-21) | ||||
|  | ||||
| - 修复 passwordIcon 属性拼写错误的 bug | ||||
|  | ||||
| ## 0.0.14(2021-06-18) | ||||
|  | ||||
| - 新增 passwordIcon 属性,当 type=password 时是否显示小眼睛图标 | ||||
| - 修复 confirmType 属性不生效的问题 | ||||
|  | ||||
| ## 0.0.13(2021-06-04) | ||||
|  | ||||
| - 修复 disabled 状态可清出内容的 bug | ||||
|  | ||||
| ## 0.0.12(2021-05-12) | ||||
|  | ||||
| - 新增 组件示例地址 | ||||
|  | ||||
| ## 0.0.11(2021-05-07) | ||||
|  | ||||
| - 修复 input-border 属性不生效的问题 | ||||
|  | ||||
| ## 0.0.10(2021-04-30) | ||||
|  | ||||
| - 修复 ios 遮挡文字、显示一半的问题 | ||||
|  | ||||
| ## 0.0.9(2021-02-05) | ||||
|  | ||||
| - 调整为 uni_modules 目录规范 | ||||
| - 优化 兼容 nvue 页面 | ||||
							
								
								
									
										56
									
								
								uni_modules/uni-easyinput/components/uni-easyinput/common.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								uni_modules/uni-easyinput/components/uni-easyinput/common.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | ||||
| /** | ||||
|  * @desc 函数防抖 | ||||
|  * @param func 目标函数 | ||||
|  * @param wait 延迟执行毫秒数 | ||||
|  * @param immediate true - 立即执行, false - 延迟执行 | ||||
|  */ | ||||
| export const debounce = function(func, wait = 1000, immediate = true) { | ||||
| 	let timer; | ||||
| 	console.log(1); | ||||
| 	return function() { | ||||
| 		console.log(123); | ||||
| 		let context = this, | ||||
| 			args = arguments; | ||||
| 		if (timer) clearTimeout(timer); | ||||
| 		if (immediate) { | ||||
| 			let callNow = !timer; | ||||
| 			timer = setTimeout(() => { | ||||
| 				timer = null; | ||||
| 			}, wait); | ||||
| 			if (callNow) func.apply(context, args); | ||||
| 		} else { | ||||
| 			timer = setTimeout(() => { | ||||
| 				func.apply(context, args); | ||||
| 			}, wait) | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| /** | ||||
|  * @desc 函数节流 | ||||
|  * @param func 函数 | ||||
|  * @param wait 延迟执行毫秒数 | ||||
|  * @param type 1 使用表时间戳,在时间段开始的时候触发 2 使用表定时器,在时间段结束的时候触发 | ||||
|  */ | ||||
| export const throttle = (func, wait = 1000, type = 1) => { | ||||
| 	let previous = 0; | ||||
| 	let timeout; | ||||
| 	return function() { | ||||
| 		let context = this; | ||||
| 		let args = arguments; | ||||
| 		if (type === 1) { | ||||
| 			let now = Date.now(); | ||||
|  | ||||
| 			if (now - previous > wait) { | ||||
| 				func.apply(context, args); | ||||
| 				previous = now; | ||||
| 			} | ||||
| 		} else if (type === 2) { | ||||
| 			if (!timeout) { | ||||
| 				timeout = setTimeout(() => { | ||||
| 					timeout = null; | ||||
| 					func.apply(context, args) | ||||
| 				}, wait) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @@ -0,0 +1,650 @@ | ||||
| <template> | ||||
| 	<view class="uni-easyinput" :class="{ 'uni-easyinput-error': msg }" :style="boxStyle"> | ||||
| 		<view class="uni-easyinput__content" :class="inputContentClass" :style="inputContentStyle"> | ||||
| 			<uni-icons v-if="prefixIcon" class="content-clear-icon" :type="prefixIcon" color="#c0c4cc" @click="onClickIcon('prefix')" size="22"></uni-icons> | ||||
| 			<textarea | ||||
| 				v-if="type === 'textarea'" | ||||
| 				class="uni-easyinput__content-textarea" | ||||
| 				:class="{ 'input-padding': inputBorder }" | ||||
| 				:name="name" | ||||
| 				:value="val" | ||||
| 				:placeholder="placeholder" | ||||
| 				:placeholderStyle="placeholderStyle" | ||||
| 				:disabled="disabled" | ||||
| 				placeholder-class="uni-easyinput__placeholder-class" | ||||
| 				:maxlength="inputMaxlength" | ||||
| 				:focus="focused" | ||||
| 				:autoHeight="autoHeight" | ||||
| 				@input="onInput" | ||||
| 				@blur="_Blur" | ||||
| 				@focus="_Focus" | ||||
| 				@confirm="onConfirm" | ||||
|         @keyboardheightchange="onkeyboardheightchange" | ||||
| 			></textarea> | ||||
| 			<input | ||||
| 				v-else | ||||
| 				:type="type === 'password' ? 'text' : type" | ||||
| 				class="uni-easyinput__content-input" | ||||
| 				:style="inputStyle" | ||||
| 				:name="name" | ||||
| 				:value="val" | ||||
| 				:password="!showPassword && type === 'password'" | ||||
| 				:placeholder="placeholder" | ||||
| 				:placeholderStyle="placeholderStyle" | ||||
| 				placeholder-class="uni-easyinput__placeholder-class" | ||||
| 				:disabled="disabled" | ||||
| 				:maxlength="inputMaxlength" | ||||
| 				:focus="focused" | ||||
| 				:confirmType="confirmType" | ||||
| 				@focus="_Focus" | ||||
| 				@blur="_Blur" | ||||
| 				@input="onInput" | ||||
| 				@confirm="onConfirm" | ||||
|         @keyboardheightchange="onkeyboardheightchange" | ||||
| 			/> | ||||
| 			<template v-if="type === 'password' && passwordIcon"> | ||||
| 				<!-- 开启密码时显示小眼睛 --> | ||||
| 				<uni-icons | ||||
| 					v-if="isVal" | ||||
| 					class="content-clear-icon" | ||||
| 					:class="{ 'is-textarea-icon': type === 'textarea' }" | ||||
| 					:type="showPassword ? 'eye-slash-filled' : 'eye-filled'" | ||||
| 					:size="22" | ||||
| 					:color="focusShow ? primaryColor : '#c0c4cc'" | ||||
| 					@click="onEyes" | ||||
| 				></uni-icons> | ||||
| 			</template> | ||||
| 			<template v-else-if="suffixIcon"> | ||||
| 				<uni-icons v-if="suffixIcon" class="content-clear-icon" :type="suffixIcon" color="#c0c4cc" @click="onClickIcon('suffix')" size="22"></uni-icons> | ||||
| 			</template> | ||||
| 			<template v-else> | ||||
| 				<uni-icons | ||||
| 					v-if="clearable && isVal && !disabled && type !== 'textarea'" | ||||
| 					class="content-clear-icon" | ||||
| 					:class="{ 'is-textarea-icon': type === 'textarea' }" | ||||
| 					type="clear" | ||||
| 					:size="clearSize" | ||||
| 					:color="msg ? '#dd524d' : focusShow ? primaryColor : '#c0c4cc'" | ||||
| 					@click="onClear" | ||||
| 				></uni-icons> | ||||
| 			</template> | ||||
| 			<slot name="right"></slot> | ||||
| 		</view> | ||||
| 	</view> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| /** | ||||
|  * Easyinput 输入框 | ||||
|  * @description 此组件可以实现表单的输入与校验,包括 "text" 和 "textarea" 类型。 | ||||
|  * @tutorial https://ext.dcloud.net.cn/plugin?id=3455 | ||||
|  * @property {String}	value	输入内容 | ||||
|  * @property {String }	type	输入框的类型(默认text) password/text/textarea/.. | ||||
|  * 	@value text			文本输入键盘 | ||||
|  * 	@value textarea	多行文本输入键盘 | ||||
|  * 	@value password	密码输入键盘 | ||||
|  * 	@value number		数字输入键盘,注意iOS上app-vue弹出的数字键盘并非9宫格方式 | ||||
|  * 	@value idcard		身份证输入键盘,信、支付宝、百度、QQ小程序 | ||||
|  * 	@value digit		带小数点的数字键盘	,App的nvue页面、微信、支付宝、百度、头条、QQ小程序支持 | ||||
|  * @property {Boolean}	clearable	是否显示右侧清空内容的图标控件,点击可清空输入框内容(默认true) | ||||
|  * @property {Boolean}	autoHeight	是否自动增高输入区域,type为textarea时有效(默认true) | ||||
|  * @property {String }	placeholder	输入框的提示文字 | ||||
|  * @property {String }	placeholderStyle	placeholder的样式(内联样式,字符串),如"color: #ddd" | ||||
|  * @property {Boolean}	focus	是否自动获得焦点(默认false) | ||||
|  * @property {Boolean}	disabled	是否禁用(默认false) | ||||
|  * @property {Number }	maxlength	最大输入长度,设置为 -1 的时候不限制最大长度(默认140) | ||||
|  * @property {String }	confirmType	设置键盘右下角按钮的文字,仅在type="text"时生效(默认done) | ||||
|  * @property {Number }	clearSize	清除图标的大小,单位px(默认15) | ||||
|  * @property {String}	prefixIcon	输入框头部图标 | ||||
|  * @property {String}	suffixIcon	输入框尾部图标 | ||||
|  * @property {String}	primaryColor	设置主题色(默认#2979ff) | ||||
|  * @property {Boolean}	trim	是否自动去除两端的空格 | ||||
|  * @value both	去除两端空格 | ||||
|  * @value left	去除左侧空格 | ||||
|  * @value right	去除右侧空格 | ||||
|  * @value start	去除左侧空格 | ||||
|  * @value end		去除右侧空格 | ||||
|  * @value all		去除全部空格 | ||||
|  * @value none	不去除空格 | ||||
|  * @property {Boolean}	inputBorder	是否显示input输入框的边框(默认true) | ||||
|  * @property {Boolean}	passwordIcon	type=password时是否显示小眼睛图标 | ||||
|  * @property {Object}	styles	自定义颜色 | ||||
|  * @event {Function}	input	输入框内容发生变化时触发 | ||||
|  * @event {Function}	focus	输入框获得焦点时触发 | ||||
|  * @event {Function}	blur	输入框失去焦点时触发 | ||||
|  * @event {Function}	confirm	点击完成按钮时触发 | ||||
|  * @event {Function}	iconClick	点击图标时触发 | ||||
|  * @example <uni-easyinput v-model="mobile"></uni-easyinput> | ||||
|  */ | ||||
| function obj2strClass(obj) { | ||||
| 	let classess = ''; | ||||
| 	for (let key in obj) { | ||||
| 		const val = obj[key]; | ||||
| 		if (val) { | ||||
| 			classess += `${key} `; | ||||
| 		} | ||||
| 	} | ||||
| 	return classess; | ||||
| } | ||||
|  | ||||
| function obj2strStyle(obj) { | ||||
| 	let style = ''; | ||||
| 	for (let key in obj) { | ||||
| 		const val = obj[key]; | ||||
| 		style += `${key}:${val};`; | ||||
| 	} | ||||
| 	return style; | ||||
| } | ||||
| export default { | ||||
| 	name: 'uni-easyinput', | ||||
| 	emits: ['click', 'iconClick', 'update:modelValue', 'input', 'focus', 'blur', 'confirm', 'clear', 'eyes', 'change'], | ||||
| 	model: { | ||||
| 		prop: 'modelValue', | ||||
| 		event: 'update:modelValue' | ||||
| 	}, | ||||
| 	options: { | ||||
| 		virtualHost: true | ||||
| 	}, | ||||
| 	inject: { | ||||
| 		form: { | ||||
| 			from: 'uniForm', | ||||
| 			default: null | ||||
| 		}, | ||||
| 		formItem: { | ||||
| 			from: 'uniFormItem', | ||||
| 			default: null | ||||
| 		} | ||||
| 	}, | ||||
| 	props: { | ||||
| 		name: String, | ||||
| 		value: [Number, String], | ||||
| 		modelValue: [Number, String], | ||||
| 		type: { | ||||
| 			type: String, | ||||
| 			default: 'text' | ||||
| 		}, | ||||
| 		clearable: { | ||||
| 			type: Boolean, | ||||
| 			default: true | ||||
| 		}, | ||||
| 		autoHeight: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		placeholder: { | ||||
| 			type: String, | ||||
| 			default: ' ' | ||||
| 		}, | ||||
| 		placeholderStyle: String, | ||||
| 		focus: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		disabled: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		maxlength: { | ||||
| 			type: [Number, String], | ||||
| 			default: 140 | ||||
| 		}, | ||||
| 		confirmType: { | ||||
| 			type: String, | ||||
| 			default: 'done' | ||||
| 		}, | ||||
| 		clearSize: { | ||||
| 			type: [Number, String], | ||||
| 			default: 24 | ||||
| 		}, | ||||
| 		inputBorder: { | ||||
| 			type: Boolean, | ||||
| 			default: true | ||||
| 		}, | ||||
| 		prefixIcon: { | ||||
| 			type: String, | ||||
| 			default: '' | ||||
| 		}, | ||||
| 		suffixIcon: { | ||||
| 			type: String, | ||||
| 			default: '' | ||||
| 		}, | ||||
| 		trim: { | ||||
| 			type: [Boolean, String], | ||||
| 			default: true | ||||
| 		}, | ||||
| 		passwordIcon: { | ||||
| 			type: Boolean, | ||||
| 			default: true | ||||
| 		}, | ||||
| 		primaryColor: { | ||||
| 			type: String, | ||||
| 			default: '#2979ff' | ||||
| 		}, | ||||
| 		styles: { | ||||
| 			type: Object, | ||||
| 			default() { | ||||
| 				return { | ||||
| 					color: '#333', | ||||
| 					backgroundColor: '#fff', | ||||
| 					disableColor: '#F7F6F6', | ||||
| 					borderColor: '#e5e5e5' | ||||
| 				}; | ||||
| 			} | ||||
| 		}, | ||||
| 		errorMessage: { | ||||
| 			type: [String, Boolean], | ||||
| 			default: '' | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			focused: false, | ||||
| 			val: '', | ||||
| 			showMsg: '', | ||||
| 			border: false, | ||||
| 			isFirstBorder: false, | ||||
| 			showClearIcon: false, | ||||
| 			showPassword: false, | ||||
| 			focusShow: false, | ||||
| 			localMsg: '', | ||||
| 			isEnter: false // 用于判断当前是否是使用回车操作 | ||||
| 		}; | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		// 输入框内是否有值 | ||||
| 		isVal() { | ||||
| 			const val = this.val; | ||||
| 			// fixed by mehaotian 处理值为0的情况,字符串0不在处理范围 | ||||
| 			if (val || val === 0) { | ||||
| 				return true; | ||||
| 			} | ||||
| 			return false; | ||||
| 		}, | ||||
|  | ||||
| 		msg() { | ||||
| 			// console.log('computed', this.form, this.formItem); | ||||
| 			// if (this.form) { | ||||
| 			// 	return this.errorMessage || this.formItem.errMsg; | ||||
| 			// } | ||||
| 			// TODO 处理头条 formItem 中 errMsg 不更新的问题 | ||||
| 			return this.localMsg || this.errorMessage; | ||||
| 		}, | ||||
| 		// 因为uniapp的input组件的maxlength组件必须要数值,这里转为数值,用户可以传入字符串数值 | ||||
| 		inputMaxlength() { | ||||
| 			return Number(this.maxlength); | ||||
| 		}, | ||||
|  | ||||
| 		// 处理外层样式的style | ||||
| 		boxStyle() { | ||||
| 			return `color:${this.inputBorder && this.msg ? '#e43d33' : this.styles.color};`; | ||||
| 		}, | ||||
| 		// input 内容的类和样式处理 | ||||
| 		inputContentClass() { | ||||
| 			return obj2strClass({ | ||||
| 				'is-input-border': this.inputBorder, | ||||
| 				'is-input-error-border': this.inputBorder && this.msg, | ||||
| 				'is-textarea': this.type === 'textarea', | ||||
| 				'is-disabled': this.disabled, | ||||
| 				'is-focused': this.focusShow | ||||
| 			}); | ||||
| 		}, | ||||
| 		inputContentStyle() { | ||||
| 			const focusColor = this.focusShow ? this.primaryColor : this.styles.borderColor; | ||||
| 			const borderColor = this.inputBorder && this.msg ? '#dd524d' : focusColor; | ||||
| 			return obj2strStyle({ | ||||
| 				'border-color': borderColor || '#e5e5e5', | ||||
| 				'background-color': this.disabled ? this.styles.disableColor : this.styles.backgroundColor | ||||
| 			}); | ||||
| 		}, | ||||
| 		// input右侧样式 | ||||
| 		inputStyle() { | ||||
| 			const paddingRight = this.type === 'password' || this.clearable || this.prefixIcon ? '' : '10px'; | ||||
| 			return obj2strStyle({ | ||||
| 				'padding-right': paddingRight, | ||||
| 				'padding-left': this.prefixIcon ? '' : '10px' | ||||
| 			}); | ||||
| 		} | ||||
| 	}, | ||||
| 	watch: { | ||||
| 		value(newVal) { | ||||
| 			this.val = newVal; | ||||
| 		}, | ||||
| 		modelValue(newVal) { | ||||
| 			this.val = newVal; | ||||
| 		}, | ||||
| 		focus(newVal) { | ||||
| 			this.$nextTick(() => { | ||||
| 				this.focused = this.focus; | ||||
| 				this.focusShow = this.focus; | ||||
| 			}); | ||||
| 		} | ||||
| 	}, | ||||
| 	created() { | ||||
| 		this.init(); | ||||
| 		// TODO 处理头条vue3 computed 不监听 inject 更改的问题(formItem.errMsg) | ||||
| 		if (this.form && this.formItem) { | ||||
| 			this.$watch('formItem.errMsg', newVal => { | ||||
| 				this.localMsg = newVal; | ||||
| 			}); | ||||
| 		} | ||||
| 	}, | ||||
| 	mounted() { | ||||
| 		this.$nextTick(() => { | ||||
| 			this.focused = this.focus; | ||||
| 			this.focusShow = this.focus; | ||||
| 		}); | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		/** | ||||
| 		 * 初始化变量值 | ||||
| 		 */ | ||||
| 		init() { | ||||
| 			if (this.value || this.value === 0) { | ||||
| 				this.val = this.value; | ||||
| 			} else if (this.modelValue || this.modelValue === 0 || this.modelValue === '') { | ||||
| 				this.val = this.modelValue; | ||||
| 			} else { | ||||
| 				this.val = null; | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		/** | ||||
| 		 * 点击图标时触发 | ||||
| 		 * @param {Object} type | ||||
| 		 */ | ||||
| 		onClickIcon(type) { | ||||
| 			this.$emit('iconClick', type); | ||||
| 		}, | ||||
|  | ||||
| 		/** | ||||
| 		 * 显示隐藏内容,密码框时生效 | ||||
| 		 */ | ||||
| 		onEyes() { | ||||
| 			this.showPassword = !this.showPassword; | ||||
| 			this.$emit('eyes', this.showPassword); | ||||
| 		}, | ||||
|  | ||||
| 		/** | ||||
| 		 * 输入时触发 | ||||
| 		 * @param {Object} event | ||||
| 		 */ | ||||
| 		onInput(event) { | ||||
| 			let value = event.detail.value; | ||||
| 			// 判断是否去除空格 | ||||
| 			if (this.trim) { | ||||
| 				if (typeof this.trim === 'boolean' && this.trim) { | ||||
| 					value = this.trimStr(value); | ||||
| 				} | ||||
| 				if (typeof this.trim === 'string') { | ||||
| 					value = this.trimStr(value, this.trim); | ||||
| 				} | ||||
| 			} | ||||
| 			if (this.errMsg) this.errMsg = ''; | ||||
| 			this.val = value; | ||||
| 			// TODO 兼容 vue2 | ||||
| 			this.$emit('input', value); | ||||
| 			// TODO 兼容 vue3 | ||||
| 			this.$emit('update:modelValue', value); | ||||
| 		}, | ||||
|  | ||||
| 		/** | ||||
| 		 * 外部调用方法 | ||||
| 		 * 获取焦点时触发 | ||||
| 		 * @param {Object} event | ||||
| 		 */ | ||||
| 		onFocus() { | ||||
| 			this.$nextTick(() => { | ||||
| 				this.focused = true; | ||||
| 			}); | ||||
| 			this.$emit('focus', null); | ||||
| 		}, | ||||
|  | ||||
| 		_Focus(event) { | ||||
| 			this.focusShow = true; | ||||
| 			this.$emit('focus', event); | ||||
| 		}, | ||||
|  | ||||
| 		/** | ||||
| 		 * 外部调用方法 | ||||
| 		 * 失去焦点时触发 | ||||
| 		 * @param {Object} event | ||||
| 		 */ | ||||
| 		onBlur() { | ||||
| 			this.focused = false; | ||||
| 			this.$emit('focus', null); | ||||
| 		}, | ||||
| 		_Blur(event) { | ||||
| 			let value = event.detail.value; | ||||
| 			this.focusShow = false; | ||||
| 			this.$emit('blur', event); | ||||
| 			// 根据类型返回值,在event中获取的值理论上讲都是string | ||||
| 			if (this.isEnter === false) { | ||||
| 				this.$emit('change', this.val); | ||||
| 			} | ||||
| 			// 失去焦点时参与表单校验 | ||||
| 			if (this.form && this.formItem) { | ||||
| 				const { validateTrigger } = this.form; | ||||
| 				if (validateTrigger === 'blur') { | ||||
| 					this.formItem.onFieldChange(); | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		/** | ||||
| 		 * 按下键盘的发送键 | ||||
| 		 * @param {Object} e | ||||
| 		 */ | ||||
| 		onConfirm(e) { | ||||
| 			this.$emit('confirm', this.val); | ||||
| 			this.isEnter = true; | ||||
| 			this.$emit('change', this.val); | ||||
| 			this.$nextTick(() => { | ||||
| 				this.isEnter = false; | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		/** | ||||
| 		 * 清理内容 | ||||
| 		 * @param {Object} event | ||||
| 		 */ | ||||
| 		onClear(event) { | ||||
| 			this.val = ''; | ||||
| 			// TODO 兼容 vue2 | ||||
| 			this.$emit('input', ''); | ||||
| 			// TODO 兼容 vue2 | ||||
| 			// TODO 兼容 vue3 | ||||
| 			this.$emit('update:modelValue', ''); | ||||
| 			// 点击叉号触发 | ||||
| 			this.$emit('clear'); | ||||
| 		}, | ||||
|  | ||||
|     /** | ||||
|      * 键盘高度发生变化的时候触发此事件 | ||||
|      * 兼容性:微信小程序2.7.0+、App 3.1.0+ | ||||
|      * @param {Object} event | ||||
|      */ | ||||
|     onkeyboardheightchange(event) { | ||||
|       this.$emit("keyboardheightchange",event); | ||||
|     }, | ||||
|  | ||||
| 		/** | ||||
| 		 * 去除空格 | ||||
| 		 */ | ||||
| 		trimStr(str, pos = 'both') { | ||||
| 			if (pos === 'both') { | ||||
| 				return str.trim(); | ||||
| 			} else if (pos === 'left') { | ||||
| 				return str.trimLeft(); | ||||
| 			} else if (pos === 'right') { | ||||
| 				return str.trimRight(); | ||||
| 			} else if (pos === 'start') { | ||||
| 				return str.trimStart(); | ||||
| 			} else if (pos === 'end') { | ||||
| 				return str.trimEnd(); | ||||
| 			} else if (pos === 'all') { | ||||
| 				return str.replace(/\s+/g, ''); | ||||
| 			} else if (pos === 'none') { | ||||
| 				return str; | ||||
| 			} | ||||
| 			return str; | ||||
| 		} | ||||
| 	} | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style lang="scss"> | ||||
| $uni-error: #e43d33; | ||||
| $uni-border-1: #dcdfe6 !default; | ||||
|  | ||||
| .uni-easyinput { | ||||
| 	/* #ifndef APP-NVUE */ | ||||
| 	width: 100%; | ||||
| 	/* #endif */ | ||||
| 	flex: 1; | ||||
| 	position: relative; | ||||
| 	text-align: left; | ||||
| 	color: #333; | ||||
| 	font-size: 14px; | ||||
| } | ||||
|  | ||||
| .uni-easyinput__content { | ||||
| 	flex: 1; | ||||
| 	/* #ifndef APP-NVUE */ | ||||
| 	width: 100%; | ||||
| 	display: flex; | ||||
| 	box-sizing: border-box; | ||||
| 	// min-height: 36px; | ||||
| 	/* #endif */ | ||||
| 	flex-direction: row; | ||||
| 	align-items: center; | ||||
| 	// 处理border动画刚开始显示黑色的问题 | ||||
| 	border-color: #fff; | ||||
| 	transition-property: border-color; | ||||
| 	transition-duration: 0.3s; | ||||
| } | ||||
|  | ||||
| .uni-easyinput__content-input { | ||||
| 	/* #ifndef APP-NVUE */ | ||||
| 	width: auto; | ||||
| 	/* #endif */ | ||||
| 	position: relative; | ||||
| 	overflow: hidden; | ||||
| 	flex: 1; | ||||
| 	line-height: 1; | ||||
| 	font-size: 14px; | ||||
| 	height: 35px; | ||||
| 	// min-height: 36px; | ||||
| } | ||||
|  | ||||
| .uni-easyinput__placeholder-class { | ||||
| 	color: #999; | ||||
| 	font-size: 12px; | ||||
| 	// font-weight: 200; | ||||
| } | ||||
|  | ||||
| .is-textarea { | ||||
| 	align-items: flex-start; | ||||
| } | ||||
|  | ||||
| .is-textarea-icon { | ||||
| 	margin-top: 5px; | ||||
| } | ||||
|  | ||||
| .uni-easyinput__content-textarea { | ||||
| 	position: relative; | ||||
| 	overflow: hidden; | ||||
| 	flex: 1; | ||||
| 	line-height: 1.5; | ||||
| 	font-size: 14px; | ||||
| 	margin: 6px; | ||||
| 	margin-left: 0; | ||||
| 	height: 80px; | ||||
| 	min-height: 80px; | ||||
| 	/* #ifndef APP-NVUE */ | ||||
| 	min-height: 80px; | ||||
| 	width: auto; | ||||
| 	/* #endif */ | ||||
| } | ||||
|  | ||||
| .input-padding { | ||||
| 	padding-left: 10px; | ||||
| } | ||||
|  | ||||
| .content-clear-icon { | ||||
| 	padding: 0 5px; | ||||
| } | ||||
|  | ||||
| .label-icon { | ||||
| 	margin-right: 5px; | ||||
| 	margin-top: -1px; | ||||
| } | ||||
|  | ||||
| // 显示边框 | ||||
| .is-input-border { | ||||
| 	/* #ifndef APP-NVUE */ | ||||
| 	display: flex; | ||||
| 	box-sizing: border-box; | ||||
| 	/* #endif */ | ||||
| 	flex-direction: row; | ||||
| 	align-items: center; | ||||
| 	border: 1px solid $uni-border-1; | ||||
| 	border-radius: 4px; | ||||
| 	/* #ifdef MP-ALIPAY */ | ||||
| 	overflow: hidden; | ||||
| 	/* #endif */ | ||||
| } | ||||
|  | ||||
| .uni-error-message { | ||||
| 	position: absolute; | ||||
| 	bottom: -17px; | ||||
| 	left: 0; | ||||
| 	line-height: 12px; | ||||
| 	color: $uni-error; | ||||
| 	font-size: 12px; | ||||
| 	text-align: left; | ||||
| } | ||||
|  | ||||
| .uni-error-msg--boeder { | ||||
| 	position: relative; | ||||
| 	bottom: 0; | ||||
| 	line-height: 22px; | ||||
| } | ||||
|  | ||||
| .is-input-error-border { | ||||
| 	border-color: $uni-error; | ||||
|  | ||||
| 	.uni-easyinput__placeholder-class { | ||||
| 		color: mix(#fff, $uni-error, 50%); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| .uni-easyinput--border { | ||||
| 	margin-bottom: 0; | ||||
| 	padding: 10px 15px; | ||||
| 	// padding-bottom: 0; | ||||
| 	border-top: 1px #eee solid; | ||||
| } | ||||
|  | ||||
| .uni-easyinput-error { | ||||
| 	padding-bottom: 0; | ||||
| } | ||||
|  | ||||
| .is-first-border { | ||||
| 	/* #ifndef APP-NVUE */ | ||||
| 	border: none; | ||||
| 	/* #endif */ | ||||
| 	/* #ifdef APP-NVUE */ | ||||
| 	border-width: 0; | ||||
| 	/* #endif */ | ||||
| } | ||||
|  | ||||
| .is-disabled { | ||||
| 	background-color: #f7f6f6; | ||||
| 	color: #d5d5d5; | ||||
|  | ||||
| 	.uni-easyinput__placeholder-class { | ||||
| 		color: #d5d5d5; | ||||
| 		font-size: 12px; | ||||
| 	} | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										87
									
								
								uni_modules/uni-easyinput/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								uni_modules/uni-easyinput/package.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| { | ||||
|   "id": "uni-easyinput", | ||||
|   "displayName": "uni-easyinput 增强输入框", | ||||
|   "version": "1.1.6", | ||||
|   "description": "Easyinput 组件是对原生input组件的增强", | ||||
|   "keywords": [ | ||||
|     "uni-ui", | ||||
|     "uniui", | ||||
|     "input", | ||||
|     "uni-easyinput", | ||||
|     "输入框" | ||||
| ], | ||||
|   "repository": "https://github.com/dcloudio/uni-ui", | ||||
|   "engines": { | ||||
|     "HBuilderX": "" | ||||
|   }, | ||||
|   "directories": { | ||||
|     "example": "../../temps/example_temps" | ||||
|   }, | ||||
| "dcloudext": { | ||||
|     "sale": { | ||||
|       "regular": { | ||||
|         "price": "0.00" | ||||
|       }, | ||||
|       "sourcecode": { | ||||
|         "price": "0.00" | ||||
|       } | ||||
|     }, | ||||
|     "contact": { | ||||
|       "qq": "" | ||||
|     }, | ||||
|     "declaration": { | ||||
|       "ads": "无", | ||||
|       "data": "无", | ||||
|       "permissions": "无" | ||||
|     }, | ||||
|     "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui", | ||||
|     "type": "component-vue" | ||||
|   }, | ||||
|   "uni_modules": { | ||||
|     "dependencies": [ | ||||
| 			"uni-scss", | ||||
|       "uni-icons" | ||||
|     ], | ||||
|     "encrypt": [], | ||||
|     "platforms": { | ||||
|       "cloud": { | ||||
|         "tcb": "y", | ||||
|         "aliyun": "y" | ||||
|       }, | ||||
|       "client": { | ||||
|         "App": { | ||||
|           "app-vue": "y", | ||||
|           "app-nvue": "y" | ||||
|         }, | ||||
|         "H5-mobile": { | ||||
|           "Safari": "y", | ||||
|           "Android Browser": "y", | ||||
|           "微信浏览器(Android)": "y", | ||||
|           "QQ浏览器(Android)": "y" | ||||
|         }, | ||||
|         "H5-pc": { | ||||
|           "Chrome": "y", | ||||
|           "IE": "y", | ||||
|           "Edge": "y", | ||||
|           "Firefox": "y", | ||||
|           "Safari": "y" | ||||
|         }, | ||||
|         "小程序": { | ||||
|           "微信": "y", | ||||
|           "阿里": "y", | ||||
|           "百度": "y", | ||||
|           "字节跳动": "y", | ||||
|           "QQ": "y" | ||||
|         }, | ||||
|         "快应用": { | ||||
|           "华为": "u", | ||||
|           "联盟": "u" | ||||
|         }, | ||||
|         "Vue": { | ||||
|             "vue2": "y", | ||||
|             "vue3": "y" | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										11
									
								
								uni_modules/uni-easyinput/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								uni_modules/uni-easyinput/readme.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
|  | ||||
|  | ||||
| ### Easyinput 增强输入框 | ||||
| > **组件名:uni-easyinput** | ||||
| > 代码块: `uEasyinput` | ||||
|  | ||||
|  | ||||
| easyinput 组件是对原生input组件的增强 ,是专门为配合表单组件[uni-forms](https://ext.dcloud.net.cn/plugin?id=2773)而设计的,easyinput 内置了边框,图标等,同时包含 input 所有功能 | ||||
|  | ||||
| ### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-easyinput) | ||||
| #### 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839  | ||||
							
								
								
									
										66
									
								
								uni_modules/uni-popup/changelog.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								uni_modules/uni-popup/changelog.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | ||||
| ## 1.8.2(2023-02-02) | ||||
| - uni-popup-dialog 组件新增 inputType 属性 | ||||
| ## 1.8.1(2022-12-01) | ||||
| - 修复 nvue 下 v-show 报错 | ||||
| ## 1.8.0(2022-11-29) | ||||
| - 优化 主题样式 | ||||
| ## 1.7.9(2022-04-02) | ||||
| - 修复 弹出层内部无法滚动的bug | ||||
| ## 1.7.8(2022-03-28) | ||||
| - 修复 小程序中高度错误的bug | ||||
| ## 1.7.7(2022-03-17) | ||||
| - 修复 快速调用open出现问题的Bug | ||||
| ## 1.7.6(2022-02-14) | ||||
| - 修复 safeArea 属性不能设置为false的bug | ||||
| ## 1.7.5(2022-01-19) | ||||
| - 修复 isMaskClick 失效的bug | ||||
| ## 1.7.4(2022-01-19) | ||||
| - 新增 cancelText \ confirmText 属性 ,可自定义文本 | ||||
| - 新增 maskBackgroundColor 属性 ,可以修改蒙版颜色 | ||||
| - 优化 maskClick属性 更新为 isMaskClick ,解决微信小程序警告的问题 | ||||
| ## 1.7.3(2022-01-13) | ||||
| - 修复 设置 safeArea 属性不生效的bug | ||||
| ## 1.7.2(2021-11-26) | ||||
| - 优化 组件示例 | ||||
| ## 1.7.1(2021-11-26) | ||||
| - 修复 vuedoc 文字错误 | ||||
| ## 1.7.0(2021-11-19) | ||||
| - 优化 组件UI,并提供设计资源,详见:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource) | ||||
| - 文档迁移,详见:[https://uniapp.dcloud.io/component/uniui/uni-popup](https://uniapp.dcloud.io/component/uniui/uni-popup) | ||||
| ## 1.6.2(2021-08-24) | ||||
| - 新增 支持国际化 | ||||
| ## 1.6.1(2021-07-30) | ||||
| - 优化 vue3下事件警告的问题 | ||||
| ## 1.6.0(2021-07-13) | ||||
| - 组件兼容 vue3,如何创建vue3项目,详见 [uni-app 项目支持 vue3 介绍](https://ask.dcloud.net.cn/article/37834) | ||||
| ## 1.5.0(2021-06-23) | ||||
| - 新增 mask-click 遮罩层点击事件 | ||||
| ## 1.4.5(2021-06-22) | ||||
| - 修复 nvue 平台中间弹出后,点击内容,再点击遮罩无法关闭的Bug | ||||
| ## 1.4.4(2021-06-18) | ||||
| - 修复 H5平台中间弹出后,点击内容,再点击遮罩无法关闭的Bug | ||||
| ## 1.4.3(2021-06-08) | ||||
| - 修复 错误的 watch 字段 | ||||
| - 修复 safeArea 属性不生效的问题 | ||||
| - 修复 点击内容,再点击遮罩无法关闭的Bug | ||||
| ## 1.4.2(2021-05-12) | ||||
| - 新增 组件示例地址 | ||||
| ## 1.4.1(2021-04-29) | ||||
| - 修复 组件内放置 input 、textarea 组件,无法聚焦的问题 | ||||
| ## 1.4.0 (2021-04-29) | ||||
| - 新增 type 属性的 left\right 值,支持左右弹出 | ||||
| - 新增 open(String:type) 方法参数 ,可以省略 type 属性 ,直接传入类型打开指定弹窗 | ||||
| - 新增 backgroundColor 属性,可定义主窗口背景色,默认不显示背景色 | ||||
| - 新增 safeArea 属性,是否适配底部安全区 | ||||
| - 修复 App\h5\微信小程序底部安全区占位不对的Bug | ||||
| - 修复 App 端弹出等待的Bug | ||||
| - 优化 提升低配设备性能,优化动画卡顿问题 | ||||
| - 优化 更简单的组件自定义方式 | ||||
| ## 1.2.9(2021-02-05) | ||||
| - 优化 组件引用关系,通过uni_modules引用组件 | ||||
| ## 1.2.8(2021-02-05) | ||||
| - 调整为uni_modules目录规范 | ||||
| ## 1.2.7(2021-02-05) | ||||
| - 调整为uni_modules目录规范 | ||||
| - 新增 支持 PC 端 | ||||
| - 新增 uni-popup-message 、uni-popup-dialog扩展组件支持 PC 端 | ||||
| @@ -0,0 +1,45 @@ | ||||
| // #ifdef H5 | ||||
| export default { | ||||
|   name: 'Keypress', | ||||
|   props: { | ||||
|     disable: { | ||||
|       type: Boolean, | ||||
|       default: false | ||||
|     } | ||||
|   }, | ||||
|   mounted () { | ||||
|     const keyNames = { | ||||
|       esc: ['Esc', 'Escape'], | ||||
|       tab: 'Tab', | ||||
|       enter: 'Enter', | ||||
|       space: [' ', 'Spacebar'], | ||||
|       up: ['Up', 'ArrowUp'], | ||||
|       left: ['Left', 'ArrowLeft'], | ||||
|       right: ['Right', 'ArrowRight'], | ||||
|       down: ['Down', 'ArrowDown'], | ||||
|       delete: ['Backspace', 'Delete', 'Del'] | ||||
|     } | ||||
|     const listener = ($event) => { | ||||
|       if (this.disable) { | ||||
|         return | ||||
|       } | ||||
|       const keyName = Object.keys(keyNames).find(key => { | ||||
|         const keyName = $event.key | ||||
|         const value = keyNames[key] | ||||
|         return value === keyName || (Array.isArray(value) && value.includes(keyName)) | ||||
|       }) | ||||
|       if (keyName) { | ||||
|         // 避免和其他按键事件冲突 | ||||
|         setTimeout(() => { | ||||
|           this.$emit(keyName, {}) | ||||
|         }, 0) | ||||
|       } | ||||
|     } | ||||
|     document.addEventListener('keyup', listener) | ||||
|     this.$once('hook:beforeDestroy', () => { | ||||
|       document.removeEventListener('keyup', listener) | ||||
|     }) | ||||
|   }, | ||||
| 	render: () => {} | ||||
| } | ||||
| // #endif | ||||
| @@ -0,0 +1,275 @@ | ||||
| <template> | ||||
| 	<view class="uni-popup-dialog"> | ||||
| 		<view class="uni-dialog-title"> | ||||
| 			<text class="uni-dialog-title-text" :class="['uni-popup__'+dialogType]">{{titleText}}</text> | ||||
| 		</view> | ||||
| 		<view v-if="mode === 'base'" class="uni-dialog-content"> | ||||
| 			<slot> | ||||
| 				<text class="uni-dialog-content-text">{{content}}</text> | ||||
| 			</slot> | ||||
| 		</view> | ||||
| 		<view v-else class="uni-dialog-content"> | ||||
| 			<slot> | ||||
| 				<input class="uni-dialog-input" v-model="val" :type="inputType" :placeholder="placeholderText" :focus="focus" > | ||||
| 			</slot> | ||||
| 		</view> | ||||
| 		<view class="uni-dialog-button-group"> | ||||
| 			<view class="uni-dialog-button" @click="closeDialog"> | ||||
| 				<text class="uni-dialog-button-text">{{closeText}}</text> | ||||
| 			</view> | ||||
| 			<view class="uni-dialog-button uni-border-left" @click="onOk"> | ||||
| 				<text class="uni-dialog-button-text uni-button-color">{{okText}}</text> | ||||
| 			</view> | ||||
| 		</view> | ||||
|  | ||||
| 	</view> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| 	import popup from '../uni-popup/popup.js' | ||||
| 	import { | ||||
| 	initVueI18n | ||||
| 	} from '@dcloudio/uni-i18n' | ||||
| 	import messages from '../uni-popup/i18n/index.js' | ||||
| 	const {	t } = initVueI18n(messages) | ||||
| 	/** | ||||
| 	 * PopUp 弹出层-对话框样式 | ||||
| 	 * @description 弹出层-对话框样式 | ||||
| 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=329 | ||||
| 	 * @property {String} value input 模式下的默认值 | ||||
| 	 * @property {String} placeholder input 模式下输入提示 | ||||
| 	 * @property {String} type = [success|warning|info|error] 主题样式 | ||||
| 	 *  @value success 成功 | ||||
| 	 * 	@value warning 提示 | ||||
| 	 * 	@value info 消息 | ||||
| 	 * 	@value error 错误 | ||||
| 	 * @property {String} mode = [base|input] 模式、 | ||||
| 	 * 	@value base 基础对话框 | ||||
| 	 * 	@value input 可输入对话框 | ||||
| 	 * @property {String} content 对话框内容 | ||||
| 	 * @property {Boolean} beforeClose 是否拦截取消事件 | ||||
| 	 * @event {Function} confirm 点击确认按钮触发 | ||||
| 	 * @event {Function} close 点击取消按钮触发 | ||||
| 	 */ | ||||
|  | ||||
| 	export default { | ||||
| 		name: "uniPopupDialog", | ||||
| 		mixins: [popup], | ||||
| 		emits:['confirm','close'], | ||||
| 		props: { | ||||
| 			inputType:{ | ||||
| 				type: String, | ||||
| 				default: 'text' | ||||
| 			}, | ||||
| 			value: { | ||||
| 				type: [String, Number], | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			placeholder: { | ||||
| 				type: [String, Number], | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			type: { | ||||
| 				type: String, | ||||
| 				default: 'error' | ||||
| 			}, | ||||
| 			mode: { | ||||
| 				type: String, | ||||
| 				default: 'base' | ||||
| 			}, | ||||
| 			title: { | ||||
| 				type: String, | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			content: { | ||||
| 				type: String, | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			beforeClose: { | ||||
| 				type: Boolean, | ||||
| 				default: false | ||||
| 			}, | ||||
| 			cancelText:{ | ||||
| 				type: String, | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			confirmText:{ | ||||
| 				type: String, | ||||
| 				default: '' | ||||
| 			} | ||||
| 		}, | ||||
| 		data() { | ||||
| 			return { | ||||
| 				dialogType: 'error', | ||||
| 				focus: false, | ||||
| 				val: "" | ||||
| 			} | ||||
| 		}, | ||||
| 		computed: { | ||||
| 			okText() { | ||||
| 				return this.confirmText || t("uni-popup.ok") | ||||
| 			}, | ||||
| 			closeText() { | ||||
| 				return this.cancelText || t("uni-popup.cancel") | ||||
| 			}, | ||||
| 			placeholderText() { | ||||
| 				return this.placeholder || t("uni-popup.placeholder") | ||||
| 			}, | ||||
| 			titleText() { | ||||
| 				return this.title || t("uni-popup.title") | ||||
| 			} | ||||
| 		}, | ||||
| 		watch: { | ||||
| 			type(val) { | ||||
| 				this.dialogType = val | ||||
| 			}, | ||||
| 			mode(val) { | ||||
| 				if (val === 'input') { | ||||
| 					this.dialogType = 'info' | ||||
| 				} | ||||
| 			}, | ||||
| 			value(val) { | ||||
| 				this.val = val | ||||
| 			} | ||||
| 		}, | ||||
| 		created() { | ||||
| 			// 对话框遮罩不可点击 | ||||
| 			this.popup.disableMask() | ||||
| 			// this.popup.closeMask() | ||||
| 			if (this.mode === 'input') { | ||||
| 				this.dialogType = 'info' | ||||
| 				this.val = this.value | ||||
| 			} else { | ||||
| 				this.dialogType = this.type | ||||
| 			} | ||||
| 		}, | ||||
| 		mounted() { | ||||
| 			this.focus = true | ||||
| 		}, | ||||
| 		methods: { | ||||
| 			/** | ||||
| 			 * 点击确认按钮 | ||||
| 			 */ | ||||
| 			onOk() { | ||||
| 				if (this.mode === 'input'){ | ||||
| 					this.$emit('confirm', this.val) | ||||
| 				}else{ | ||||
| 					this.$emit('confirm') | ||||
| 				} | ||||
| 				if(this.beforeClose) return | ||||
| 				this.popup.close() | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 点击取消按钮 | ||||
| 			 */ | ||||
| 			closeDialog() { | ||||
| 				this.$emit('close') | ||||
| 				if(this.beforeClose) return | ||||
| 				this.popup.close() | ||||
| 			}, | ||||
| 			close(){ | ||||
| 				this.popup.close() | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" > | ||||
| 	.uni-popup-dialog { | ||||
| 		width: 300px; | ||||
| 		border-radius: 11px; | ||||
| 		background-color: #fff; | ||||
| 	} | ||||
|  | ||||
| 	.uni-dialog-title { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
| 		flex-direction: row; | ||||
| 		justify-content: center; | ||||
| 		padding-top: 25px; | ||||
| 	} | ||||
|  | ||||
| 	.uni-dialog-title-text { | ||||
| 		font-size: 16px; | ||||
| 		font-weight: 500; | ||||
| 	} | ||||
|  | ||||
| 	.uni-dialog-content { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
| 		flex-direction: row; | ||||
| 		justify-content: center; | ||||
| 		align-items: center; | ||||
| 		padding: 20px; | ||||
| 	} | ||||
|  | ||||
| 	.uni-dialog-content-text { | ||||
| 		font-size: 14px; | ||||
| 		color: #6C6C6C; | ||||
| 	} | ||||
|  | ||||
| 	.uni-dialog-button-group { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
| 		flex-direction: row; | ||||
| 		border-top-color: #f5f5f5; | ||||
| 		border-top-style: solid; | ||||
| 		border-top-width: 1px; | ||||
| 	} | ||||
|  | ||||
| 	.uni-dialog-button { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
|  | ||||
| 		flex: 1; | ||||
| 		flex-direction: row; | ||||
| 		justify-content: center; | ||||
| 		align-items: center; | ||||
| 		height: 45px; | ||||
| 	} | ||||
|  | ||||
| 	.uni-border-left { | ||||
| 		border-left-color: #f0f0f0; | ||||
| 		border-left-style: solid; | ||||
| 		border-left-width: 1px; | ||||
| 	} | ||||
|  | ||||
| 	.uni-dialog-button-text { | ||||
| 		font-size: 16px; | ||||
| 		color: #333; | ||||
| 	} | ||||
|  | ||||
| 	.uni-button-color { | ||||
| 		color: #007aff; | ||||
| 	} | ||||
|  | ||||
| 	.uni-dialog-input { | ||||
| 		flex: 1; | ||||
| 		font-size: 14px; | ||||
| 		border: 1px #eee solid; | ||||
| 		height: 40px; | ||||
| 		padding: 0 10px; | ||||
| 		border-radius: 5px; | ||||
| 		color: #555; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__success { | ||||
| 		color: #4cd964; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__warn { | ||||
| 		color: #f0ad4e; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__error { | ||||
| 		color: #dd524d; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__info { | ||||
| 		color: #909399; | ||||
| 	} | ||||
| </style> | ||||
| @@ -0,0 +1,143 @@ | ||||
| <template> | ||||
| 	<view class="uni-popup-message"> | ||||
| 		<view class="uni-popup-message__box fixforpc-width" :class="'uni-popup__'+type"> | ||||
| 			<slot> | ||||
| 				<text class="uni-popup-message-text" :class="'uni-popup__'+type+'-text'">{{message}}</text> | ||||
| 			</slot> | ||||
| 		</view> | ||||
| 	</view> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| 	import popup from '../uni-popup/popup.js' | ||||
| 	/** | ||||
| 	 * PopUp 弹出层-消息提示 | ||||
| 	 * @description 弹出层-消息提示 | ||||
| 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=329 | ||||
| 	 * @property {String} type = [success|warning|info|error] 主题样式 | ||||
| 	 *  @value success 成功 | ||||
| 	 * 	@value warning 提示 | ||||
| 	 * 	@value info 消息 | ||||
| 	 * 	@value error 错误 | ||||
| 	 * @property {String} message 消息提示文字 | ||||
| 	 * @property {String} duration 显示时间,设置为 0 则不会自动关闭 | ||||
| 	 */ | ||||
|  | ||||
| 	export default { | ||||
| 		name: 'uniPopupMessage', | ||||
| 		mixins:[popup], | ||||
| 		props: { | ||||
| 			/** | ||||
| 			 * 主题 success/warning/info/error	  默认 success | ||||
| 			 */ | ||||
| 			type: { | ||||
| 				type: String, | ||||
| 				default: 'success' | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 消息文字 | ||||
| 			 */ | ||||
| 			message: { | ||||
| 				type: String, | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 显示时间,设置为 0 则不会自动关闭 | ||||
| 			 */ | ||||
| 			duration: { | ||||
| 				type: Number, | ||||
| 				default: 3000 | ||||
| 			}, | ||||
| 			maskShow:{ | ||||
| 				type:Boolean, | ||||
| 				default:false | ||||
| 			} | ||||
| 		}, | ||||
| 		data() { | ||||
| 			return {} | ||||
| 		}, | ||||
| 		created() { | ||||
| 			this.popup.maskShow = this.maskShow | ||||
| 			this.popup.messageChild = this | ||||
| 		}, | ||||
| 		methods: { | ||||
| 			timerClose(){ | ||||
| 				if(this.duration === 0) return | ||||
| 				clearTimeout(this.timer)  | ||||
| 				this.timer = setTimeout(()=>{ | ||||
| 					this.popup.close() | ||||
| 				},this.duration) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| </script> | ||||
| <style lang="scss" > | ||||
| 	.uni-popup-message { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
| 		flex-direction: row; | ||||
| 		justify-content: center; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup-message__box { | ||||
| 		background-color: #e1f3d8; | ||||
| 		padding: 10px 15px; | ||||
| 		border-color: #eee; | ||||
| 		border-style: solid; | ||||
| 		border-width: 1px; | ||||
| 		flex: 1; | ||||
| 	} | ||||
|  | ||||
| 	@media screen and (min-width: 500px) { | ||||
| 		.fixforpc-width { | ||||
| 			margin-top: 20px; | ||||
| 			border-radius: 4px; | ||||
| 			flex: none; | ||||
| 			min-width: 380px; | ||||
| 			/* #ifndef APP-NVUE */ | ||||
| 			max-width: 50%; | ||||
| 			/* #endif */ | ||||
| 			/* #ifdef APP-NVUE */ | ||||
| 			max-width: 500px; | ||||
| 			/* #endif */ | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup-message-text { | ||||
| 		font-size: 14px; | ||||
| 		padding: 0; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__success { | ||||
| 		background-color: #e1f3d8; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__success-text { | ||||
| 		color: #67C23A; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__warn { | ||||
| 		background-color: #faecd8; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__warn-text { | ||||
| 		color: #E6A23C; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__error { | ||||
| 		background-color: #fde2e2; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__error-text { | ||||
| 		color: #F56C6C; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__info { | ||||
| 		background-color: #F2F6FC; | ||||
| 	} | ||||
|  | ||||
| 	.uni-popup__info-text { | ||||
| 		color: #909399; | ||||
| 	} | ||||
| </style> | ||||
| @@ -0,0 +1,187 @@ | ||||
| <template> | ||||
| 	<view class="uni-popup-share"> | ||||
| 		<view class="uni-share-title"><text class="uni-share-title-text">{{shareTitleText}}</text></view> | ||||
| 		<view class="uni-share-content"> | ||||
| 			<view class="uni-share-content-box"> | ||||
| 				<view class="uni-share-content-item" v-for="(item,index) in bottomData" :key="index" @click.stop="select(item,index)"> | ||||
| 					<image class="uni-share-image" :src="item.icon" mode="aspectFill"></image> | ||||
| 					<text class="uni-share-text">{{item.text}}</text> | ||||
| 				</view> | ||||
|  | ||||
| 			</view> | ||||
| 		</view> | ||||
| 		<view class="uni-share-button-box"> | ||||
| 			<button class="uni-share-button" @click="close">{{cancelText}}</button> | ||||
| 		</view> | ||||
| 	</view> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| 	import popup from '../uni-popup/popup.js' | ||||
| 	import { | ||||
| 	initVueI18n | ||||
| 	} from '@dcloudio/uni-i18n' | ||||
| 	import messages from '../uni-popup/i18n/index.js' | ||||
| 	const {	t	} = initVueI18n(messages) | ||||
| 	export default { | ||||
| 		name: 'UniPopupShare', | ||||
| 		mixins:[popup], | ||||
| 		emits:['select'], | ||||
| 		props: { | ||||
| 			title: { | ||||
| 				type: String, | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			beforeClose: { | ||||
| 				type: Boolean, | ||||
| 				default: false | ||||
| 			} | ||||
| 		}, | ||||
| 		data() { | ||||
| 			return { | ||||
| 				bottomData: [{ | ||||
| 						text: '微信', | ||||
| 						icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/c2b17470-50be-11eb-b680-7980c8a877b8.png', | ||||
| 						name: 'wx' | ||||
| 					}, | ||||
| 					{ | ||||
| 						text: '支付宝', | ||||
| 						icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/d684ae40-50be-11eb-8ff1-d5dcf8779628.png', | ||||
| 						name: 'wx' | ||||
| 					}, | ||||
| 					{ | ||||
| 						text: 'QQ', | ||||
| 						icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/e7a79520-50be-11eb-b997-9918a5dda011.png', | ||||
| 						name: 'qq' | ||||
| 					}, | ||||
| 					{ | ||||
| 						text: '新浪', | ||||
| 						icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/0dacdbe0-50bf-11eb-8ff1-d5dcf8779628.png', | ||||
| 						name: 'sina' | ||||
| 					}, | ||||
| 					// { | ||||
| 					// 	text: '百度', | ||||
| 					// 	icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/1ec6e920-50bf-11eb-8a36-ebb87efcf8c0.png', | ||||
| 					// 	name: 'copy' | ||||
| 					// }, | ||||
| 					// { | ||||
| 					// 	text: '其他', | ||||
| 					// 	icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/2e0fdfe0-50bf-11eb-b997-9918a5dda011.png', | ||||
| 					// 	name: 'more' | ||||
| 					// } | ||||
| 				] | ||||
| 			} | ||||
| 		}, | ||||
| 		created() {}, | ||||
| 		computed: { | ||||
| 			cancelText() { | ||||
| 				return t("uni-popup.cancel") | ||||
| 			}, | ||||
| 		shareTitleText() { | ||||
| 				return this.title || t("uni-popup.shareTitle") | ||||
| 			} | ||||
| 		}, | ||||
| 		methods: { | ||||
| 			/** | ||||
| 			 * 选择内容 | ||||
| 			 */ | ||||
| 			select(item, index) { | ||||
| 				this.$emit('select', { | ||||
| 					item, | ||||
| 					index | ||||
| 				}) | ||||
| 				this.close() | ||||
|  | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 关闭窗口 | ||||
| 			 */ | ||||
| 			close() { | ||||
| 				if(this.beforeClose) return | ||||
| 				this.popup.close() | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| </script> | ||||
| <style lang="scss" > | ||||
| 	.uni-popup-share { | ||||
| 		background-color: #fff; | ||||
| 		border-top-left-radius: 11px; | ||||
| 		border-top-right-radius: 11px; | ||||
| 	} | ||||
| 	.uni-share-title { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
| 		flex-direction: row; | ||||
| 		align-items: center; | ||||
| 		justify-content: center; | ||||
| 		height: 40px; | ||||
| 	} | ||||
| 	.uni-share-title-text { | ||||
| 		font-size: 14px; | ||||
| 		color: #666; | ||||
| 	} | ||||
| 	.uni-share-content { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
| 		flex-direction: row; | ||||
| 		justify-content: center; | ||||
| 		padding-top: 10px; | ||||
| 	} | ||||
|  | ||||
| 	.uni-share-content-box { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
| 		flex-direction: row; | ||||
| 		flex-wrap: wrap; | ||||
| 		width: 360px; | ||||
| 	} | ||||
|  | ||||
| 	.uni-share-content-item { | ||||
| 		width: 90px; | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
| 		flex-direction: column; | ||||
| 		justify-content: center; | ||||
| 		padding: 10px 0; | ||||
| 		align-items: center; | ||||
| 	} | ||||
|  | ||||
| 	.uni-share-content-item:active { | ||||
| 		background-color: #f5f5f5; | ||||
| 	} | ||||
|  | ||||
| 	.uni-share-image { | ||||
| 		width: 30px; | ||||
| 		height: 30px; | ||||
| 	} | ||||
|  | ||||
| 	.uni-share-text { | ||||
| 		margin-top: 10px; | ||||
| 		font-size: 14px; | ||||
| 		color: #3B4144; | ||||
| 	} | ||||
|  | ||||
| 	.uni-share-button-box { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
| 		flex-direction: row; | ||||
| 		padding: 10px 15px; | ||||
| 	} | ||||
|  | ||||
| 	.uni-share-button { | ||||
| 		flex: 1; | ||||
| 		border-radius: 50px; | ||||
| 		color: #666; | ||||
| 		font-size: 16px; | ||||
| 	} | ||||
|  | ||||
| 	.uni-share-button::after { | ||||
| 		border-radius: 50px; | ||||
| 	} | ||||
| </style> | ||||
							
								
								
									
										7
									
								
								uni_modules/uni-popup/components/uni-popup/i18n/en.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								uni_modules/uni-popup/components/uni-popup/i18n/en.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| { | ||||
| 	"uni-popup.cancel": "cancel", | ||||
| 	"uni-popup.ok": "ok", | ||||
| 	"uni-popup.placeholder": "pleace enter", | ||||
| 	"uni-popup.title": "Hint", | ||||
| 	"uni-popup.shareTitle": "Share to" | ||||
| } | ||||
							
								
								
									
										8
									
								
								uni_modules/uni-popup/components/uni-popup/i18n/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								uni_modules/uni-popup/components/uni-popup/i18n/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| import en from './en.json' | ||||
| import zhHans from './zh-Hans.json' | ||||
| import zhHant from './zh-Hant.json' | ||||
| export default { | ||||
| 	en, | ||||
| 	'zh-Hans': zhHans, | ||||
| 	'zh-Hant': zhHant | ||||
| } | ||||
| @@ -0,0 +1,7 @@ | ||||
| { | ||||
| 	"uni-popup.cancel": "取消", | ||||
| 	"uni-popup.ok": "确定", | ||||
| 	"uni-popup.placeholder": "请输入", | ||||
| 		"uni-popup.title": "提示", | ||||
| 		"uni-popup.shareTitle": "分享到" | ||||
| } | ||||
| @@ -0,0 +1,7 @@ | ||||
| { | ||||
| 	"uni-popup.cancel": "取消", | ||||
| 	"uni-popup.ok": "確定", | ||||
| 	"uni-popup.placeholder": "請輸入", | ||||
| 	"uni-popup.title": "提示", | ||||
| 	"uni-popup.shareTitle": "分享到" | ||||
| } | ||||
							
								
								
									
										45
									
								
								uni_modules/uni-popup/components/uni-popup/keypress.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								uni_modules/uni-popup/components/uni-popup/keypress.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| // #ifdef H5 | ||||
| export default { | ||||
|   name: 'Keypress', | ||||
|   props: { | ||||
|     disable: { | ||||
|       type: Boolean, | ||||
|       default: false | ||||
|     } | ||||
|   }, | ||||
|   mounted () { | ||||
|     const keyNames = { | ||||
|       esc: ['Esc', 'Escape'], | ||||
|       tab: 'Tab', | ||||
|       enter: 'Enter', | ||||
|       space: [' ', 'Spacebar'], | ||||
|       up: ['Up', 'ArrowUp'], | ||||
|       left: ['Left', 'ArrowLeft'], | ||||
|       right: ['Right', 'ArrowRight'], | ||||
|       down: ['Down', 'ArrowDown'], | ||||
|       delete: ['Backspace', 'Delete', 'Del'] | ||||
|     } | ||||
|     const listener = ($event) => { | ||||
|       if (this.disable) { | ||||
|         return | ||||
|       } | ||||
|       const keyName = Object.keys(keyNames).find(key => { | ||||
|         const keyName = $event.key | ||||
|         const value = keyNames[key] | ||||
|         return value === keyName || (Array.isArray(value) && value.includes(keyName)) | ||||
|       }) | ||||
|       if (keyName) { | ||||
|         // 避免和其他按键事件冲突 | ||||
|         setTimeout(() => { | ||||
|           this.$emit(keyName, {}) | ||||
|         }, 0) | ||||
|       } | ||||
|     } | ||||
|     document.addEventListener('keyup', listener) | ||||
|     // this.$once('hook:beforeDestroy', () => { | ||||
|     //   document.removeEventListener('keyup', listener) | ||||
|     // }) | ||||
|   }, | ||||
| 	render: () => {} | ||||
| } | ||||
| // #endif | ||||
							
								
								
									
										26
									
								
								uni_modules/uni-popup/components/uni-popup/popup.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								uni_modules/uni-popup/components/uni-popup/popup.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
|  | ||||
| export default { | ||||
| 	data() { | ||||
| 		return { | ||||
| 			 | ||||
| 		} | ||||
| 	}, | ||||
| 	created(){ | ||||
| 		this.popup = this.getParent() | ||||
| 	}, | ||||
| 	methods:{ | ||||
| 		/** | ||||
| 		 * 获取父元素实例 | ||||
| 		 */ | ||||
| 		getParent(name = 'uniPopup') { | ||||
| 			let parent = this.$parent; | ||||
| 			let parentName = parent.$options.name; | ||||
| 			while (parentName !== name) { | ||||
| 				parent = parent.$parent; | ||||
| 				if (!parent) return false | ||||
| 				parentName = parent.$options.name; | ||||
| 			} | ||||
| 			return parent; | ||||
| 		}, | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										474
									
								
								uni_modules/uni-popup/components/uni-popup/uni-popup.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										474
									
								
								uni_modules/uni-popup/components/uni-popup/uni-popup.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,474 @@ | ||||
| <template> | ||||
| 	<view v-if="showPopup" class="uni-popup" :class="[popupstyle, isDesktop ? 'fixforpc-z-index' : '']"> | ||||
| 		<view @touchstart="touchstart"> | ||||
| 			<uni-transition key="1" v-if="maskShow" name="mask" mode-class="fade" :styles="maskClass" | ||||
| 				:duration="duration" :show="showTrans" @click="onTap" /> | ||||
| 			<uni-transition key="2" :mode-class="ani" name="content" :styles="transClass" :duration="duration" | ||||
| 				:show="showTrans" @click="onTap"> | ||||
| 				<view class="uni-popup__wrapper" :style="{ backgroundColor: bg }" :class="[popupstyle]" @click="clear"> | ||||
| 					<slot /> | ||||
| 				</view> | ||||
| 			</uni-transition> | ||||
| 		</view> | ||||
| 		<!-- #ifdef H5 --> | ||||
| 		<keypress v-if="maskShow" @esc="onTap" /> | ||||
| 		<!-- #endif --> | ||||
| 	</view> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| 	// #ifdef H5 | ||||
| 	import keypress from './keypress.js' | ||||
| 	// #endif | ||||
|  | ||||
| 	/** | ||||
| 	 * PopUp 弹出层 | ||||
| 	 * @description 弹出层组件,为了解决遮罩弹层的问题 | ||||
| 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=329 | ||||
| 	 * @property {String} type = [top|center|bottom|left|right|message|dialog|share] 弹出方式 | ||||
| 	 * 	@value top 顶部弹出 | ||||
| 	 * 	@value center 中间弹出 | ||||
| 	 * 	@value bottom 底部弹出 | ||||
| 	 * 	@value left		左侧弹出 | ||||
| 	 * 	@value right  右侧弹出 | ||||
| 	 * 	@value message 消息提示 | ||||
| 	 * 	@value dialog 对话框 | ||||
| 	 * 	@value share 底部分享示例 | ||||
| 	 * @property {Boolean} animation = [true|false] 是否开启动画 | ||||
| 	 * @property {Boolean} maskClick = [true|false] 蒙版点击是否关闭弹窗(废弃) | ||||
| 	 * @property {Boolean} isMaskClick = [true|false] 蒙版点击是否关闭弹窗 | ||||
| 	 * @property {String}  backgroundColor 主窗口背景色 | ||||
| 	 * @property {String}  maskBackgroundColor 蒙版颜色 | ||||
| 	 * @property {Boolean} safeArea		   是否适配底部安全区 | ||||
| 	 * @event {Function} change 打开关闭弹窗触发,e={show: false} | ||||
| 	 * @event {Function} maskClick 点击遮罩触发 | ||||
| 	 */ | ||||
|  | ||||
| 	export default { | ||||
| 		name: 'uniPopup', | ||||
| 		components: { | ||||
| 			// #ifdef H5 | ||||
| 			keypress | ||||
| 			// #endif | ||||
| 		}, | ||||
| 		emits: ['change', 'maskClick'], | ||||
| 		props: { | ||||
| 			// 开启动画 | ||||
| 			animation: { | ||||
| 				type: Boolean, | ||||
| 				default: true | ||||
| 			}, | ||||
| 			// 弹出层类型,可选值,top: 顶部弹出层;bottom:底部弹出层;center:全屏弹出层 | ||||
| 			// message: 消息提示 ; dialog : 对话框 | ||||
| 			type: { | ||||
| 				type: String, | ||||
| 				default: 'center' | ||||
| 			}, | ||||
| 			// maskClick | ||||
| 			isMaskClick: { | ||||
| 				type: Boolean, | ||||
| 				default: null | ||||
| 			}, | ||||
| 			// TODO 2 个版本后废弃属性 ,使用 isMaskClick | ||||
| 			maskClick: { | ||||
| 				type: Boolean, | ||||
| 				default: null | ||||
| 			}, | ||||
| 			backgroundColor: { | ||||
| 				type: String, | ||||
| 				default: 'none' | ||||
| 			}, | ||||
| 			safeArea: { | ||||
| 				type: Boolean, | ||||
| 				default: true | ||||
| 			}, | ||||
| 			maskBackgroundColor: { | ||||
| 				type: String, | ||||
| 				default: 'rgba(0, 0, 0, 0.4)' | ||||
| 			}, | ||||
| 		}, | ||||
|  | ||||
| 		watch: { | ||||
| 			/** | ||||
| 			 * 监听type类型 | ||||
| 			 */ | ||||
| 			type: { | ||||
| 				handler: function(type) { | ||||
| 					if (!this.config[type]) return | ||||
| 					this[this.config[type]](true) | ||||
| 				}, | ||||
| 				immediate: true | ||||
| 			}, | ||||
| 			isDesktop: { | ||||
| 				handler: function(newVal) { | ||||
| 					if (!this.config[newVal]) return | ||||
| 					this[this.config[this.type]](true) | ||||
| 				}, | ||||
| 				immediate: true | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 监听遮罩是否可点击 | ||||
| 			 * @param {Object} val | ||||
| 			 */ | ||||
| 			maskClick: { | ||||
| 				handler: function(val) { | ||||
| 					this.mkclick = val | ||||
| 				}, | ||||
| 				immediate: true | ||||
| 			}, | ||||
| 			isMaskClick: { | ||||
| 				handler: function(val) { | ||||
| 					this.mkclick = val | ||||
| 				}, | ||||
| 				immediate: true | ||||
| 			}, | ||||
| 			// H5 下禁止底部滚动 | ||||
| 			showPopup(show) { | ||||
| 				// #ifdef H5 | ||||
| 				// fix by mehaotian 处理 h5 滚动穿透的问题 | ||||
| 				document.getElementsByTagName('body')[0].style.overflow = show ? 'hidden' : 'visible' | ||||
| 				// #endif | ||||
| 			} | ||||
| 		}, | ||||
| 		data() { | ||||
| 			return { | ||||
| 				duration: 300, | ||||
| 				ani: [], | ||||
| 				showPopup: false, | ||||
| 				showTrans: false, | ||||
| 				popupWidth: 0, | ||||
| 				popupHeight: 0, | ||||
| 				config: { | ||||
| 					top: 'top', | ||||
| 					bottom: 'bottom', | ||||
| 					center: 'center', | ||||
| 					left: 'left', | ||||
| 					right: 'right', | ||||
| 					message: 'top', | ||||
| 					dialog: 'center', | ||||
| 					share: 'bottom' | ||||
| 				}, | ||||
| 				maskClass: { | ||||
| 					position: 'fixed', | ||||
| 					bottom: 0, | ||||
| 					top: 0, | ||||
| 					left: 0, | ||||
| 					right: 0, | ||||
| 					backgroundColor: 'rgba(0, 0, 0, 0.4)' | ||||
| 				}, | ||||
| 				transClass: { | ||||
| 					position: 'fixed', | ||||
| 					left: 0, | ||||
| 					right: 0 | ||||
| 				}, | ||||
| 				maskShow: true, | ||||
| 				mkclick: true, | ||||
| 				popupstyle: this.isDesktop ? 'fixforpc-top' : 'top' | ||||
| 			} | ||||
| 		}, | ||||
| 		computed: { | ||||
| 			isDesktop() { | ||||
| 				return this.popupWidth >= 500 && this.popupHeight >= 500 | ||||
| 			}, | ||||
| 			bg() { | ||||
| 				if (this.backgroundColor === '' || this.backgroundColor === 'none') { | ||||
| 					return 'transparent' | ||||
| 				} | ||||
| 				return this.backgroundColor | ||||
| 			} | ||||
| 		}, | ||||
| 		mounted() { | ||||
| 			const fixSize = () => { | ||||
| 				const { | ||||
| 					windowWidth, | ||||
| 					windowHeight, | ||||
| 					windowTop, | ||||
| 					safeArea, | ||||
| 					screenHeight, | ||||
| 					safeAreaInsets | ||||
| 				} = uni.getSystemInfoSync() | ||||
| 				this.popupWidth = windowWidth | ||||
| 				this.popupHeight = windowHeight + (windowTop || 0) | ||||
| 				// TODO fix by mehaotian 是否适配底部安全区 ,目前微信ios 、和 app ios 计算有差异,需要框架修复 | ||||
| 				if (safeArea && this.safeArea) { | ||||
| 					// #ifdef MP-WEIXIN | ||||
| 					this.safeAreaInsets = screenHeight - safeArea.bottom | ||||
| 					// #endif | ||||
| 					// #ifndef MP-WEIXIN | ||||
| 					this.safeAreaInsets = safeAreaInsets.bottom | ||||
| 					// #endif | ||||
| 				} else { | ||||
| 					this.safeAreaInsets = 0 | ||||
| 				} | ||||
| 			} | ||||
| 			fixSize() | ||||
| 			// #ifdef H5 | ||||
| 			// window.addEventListener('resize', fixSize) | ||||
| 			// this.$once('hook:beforeDestroy', () => { | ||||
| 			// 	window.removeEventListener('resize', fixSize) | ||||
| 			// }) | ||||
| 			// #endif | ||||
| 		}, | ||||
| 		// #ifndef VUE3 | ||||
| 		// TODO vue2 | ||||
| 		destroyed() { | ||||
| 			this.setH5Visible() | ||||
| 		}, | ||||
| 		// #endif | ||||
| 		// #ifdef VUE3 | ||||
| 		// TODO vue3 | ||||
| 		unmounted() { | ||||
| 			this.setH5Visible() | ||||
| 		}, | ||||
| 		// #endif | ||||
| 		created() { | ||||
| 			// this.mkclick =  this.isMaskClick || this.maskClick | ||||
| 			if (this.isMaskClick === null && this.maskClick === null) { | ||||
| 				this.mkclick = true | ||||
| 			} else { | ||||
| 				this.mkclick = this.isMaskClick !== null ? this.isMaskClick : this.maskClick | ||||
| 			} | ||||
| 			if (this.animation) { | ||||
| 				this.duration = 300 | ||||
| 			} else { | ||||
| 				this.duration = 0 | ||||
| 			} | ||||
| 			// TODO 处理 message 组件生命周期异常的问题 | ||||
| 			this.messageChild = null | ||||
| 			// TODO 解决头条冒泡的问题 | ||||
| 			this.clearPropagation = false | ||||
| 			this.maskClass.backgroundColor = this.maskBackgroundColor | ||||
| 		}, | ||||
| 		methods: { | ||||
| 			setH5Visible() { | ||||
| 				// #ifdef H5 | ||||
| 				// fix by mehaotian 处理 h5 滚动穿透的问题 | ||||
| 				document.getElementsByTagName('body')[0].style.overflow = 'visible' | ||||
| 				// #endif | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 公用方法,不显示遮罩层 | ||||
| 			 */ | ||||
| 			closeMask() { | ||||
| 				this.maskShow = false | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 公用方法,遮罩层禁止点击 | ||||
| 			 */ | ||||
| 			disableMask() { | ||||
| 				this.mkclick = false | ||||
| 			}, | ||||
| 			// TODO nvue 取消冒泡 | ||||
| 			clear(e) { | ||||
| 				// #ifndef APP-NVUE | ||||
| 				e.stopPropagation() | ||||
| 				// #endif | ||||
| 				this.clearPropagation = true | ||||
| 			}, | ||||
|  | ||||
| 			open(direction) { | ||||
| 				// fix by mehaotian 处理快速打开关闭的情况 | ||||
| 				if (this.showPopup) { | ||||
| 					clearTimeout(this.timer) | ||||
| 					this.showPopup = false | ||||
| 				} | ||||
| 				let innerType = ['top', 'center', 'bottom', 'left', 'right', 'message', 'dialog', 'share'] | ||||
| 				if (!(direction && innerType.indexOf(direction) !== -1)) { | ||||
| 					direction = this.type | ||||
| 				} | ||||
| 				if (!this.config[direction]) { | ||||
| 					console.error('缺少类型:', direction) | ||||
| 					return | ||||
| 				} | ||||
| 				this[this.config[direction]]() | ||||
| 				this.$emit('change', { | ||||
| 					show: true, | ||||
| 					type: direction | ||||
| 				}) | ||||
| 			}, | ||||
| 			close(type) { | ||||
| 				this.showTrans = false | ||||
| 				this.$emit('change', { | ||||
| 					show: false, | ||||
| 					type: this.type | ||||
| 				}) | ||||
| 				clearTimeout(this.timer) | ||||
| 				// // 自定义关闭事件 | ||||
| 				// this.customOpen && this.customClose() | ||||
| 				this.timer = setTimeout(() => { | ||||
| 					this.showPopup = false | ||||
| 				}, 300) | ||||
| 			}, | ||||
| 			// TODO 处理冒泡事件,头条的冒泡事件有问题 ,先这样兼容 | ||||
| 			touchstart() { | ||||
| 				this.clearPropagation = false | ||||
| 			}, | ||||
|  | ||||
| 			onTap() { | ||||
| 				if (this.clearPropagation) { | ||||
| 					// fix by mehaotian 兼容 nvue | ||||
| 					this.clearPropagation = false | ||||
| 					return | ||||
| 				} | ||||
| 				this.$emit('maskClick') | ||||
| 				if (!this.mkclick) return | ||||
| 				this.close() | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 顶部弹出样式处理 | ||||
| 			 */ | ||||
| 			top(type) { | ||||
| 				this.popupstyle = this.isDesktop ? 'fixforpc-top' : 'top' | ||||
| 				this.ani = ['slide-top'] | ||||
| 				this.transClass = { | ||||
| 					position: 'fixed', | ||||
| 					left: 0, | ||||
| 					right: 0, | ||||
| 					backgroundColor: this.bg | ||||
| 				} | ||||
| 				// TODO 兼容 type 属性 ,后续会废弃 | ||||
| 				if (type) return | ||||
| 				this.showPopup = true | ||||
| 				this.showTrans = true | ||||
| 				this.$nextTick(() => { | ||||
| 					if (this.messageChild && this.type === 'message') { | ||||
| 						this.messageChild.timerClose() | ||||
| 					} | ||||
| 				}) | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 底部弹出样式处理 | ||||
| 			 */ | ||||
| 			bottom(type) { | ||||
| 				this.popupstyle = 'bottom' | ||||
| 				this.ani = ['slide-bottom'] | ||||
| 				this.transClass = { | ||||
| 					position: 'fixed', | ||||
| 					left: 0, | ||||
| 					right: 0, | ||||
| 					bottom: 0, | ||||
| 					paddingBottom: this.safeAreaInsets + 'px', | ||||
| 					backgroundColor: this.bg | ||||
| 				} | ||||
| 				// TODO 兼容 type 属性 ,后续会废弃 | ||||
| 				if (type) return | ||||
| 				this.showPopup = true | ||||
| 				this.showTrans = true | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 中间弹出样式处理 | ||||
| 			 */ | ||||
| 			center(type) { | ||||
| 				this.popupstyle = 'center' | ||||
| 				this.ani = ['zoom-out', 'fade'] | ||||
| 				this.transClass = { | ||||
| 					position: 'fixed', | ||||
| 					/* #ifndef APP-NVUE */ | ||||
| 					display: 'flex', | ||||
| 					flexDirection: 'column', | ||||
| 					/* #endif */ | ||||
| 					bottom: 0, | ||||
| 					left: 0, | ||||
| 					right: 0, | ||||
| 					top: 0, | ||||
| 					justifyContent: 'center', | ||||
| 					alignItems: 'center' | ||||
| 				} | ||||
| 				// TODO 兼容 type 属性 ,后续会废弃 | ||||
| 				if (type) return | ||||
| 				this.showPopup = true | ||||
| 				this.showTrans = true | ||||
| 			}, | ||||
| 			left(type) { | ||||
| 				this.popupstyle = 'left' | ||||
| 				this.ani = ['slide-left'] | ||||
| 				this.transClass = { | ||||
| 					position: 'fixed', | ||||
| 					left: 0, | ||||
| 					bottom: 0, | ||||
| 					top: 0, | ||||
| 					backgroundColor: this.bg, | ||||
| 					/* #ifndef APP-NVUE */ | ||||
| 					display: 'flex', | ||||
| 					flexDirection: 'column' | ||||
| 					/* #endif */ | ||||
| 				} | ||||
| 				// TODO 兼容 type 属性 ,后续会废弃 | ||||
| 				if (type) return | ||||
| 				this.showPopup = true | ||||
| 				this.showTrans = true | ||||
| 			}, | ||||
| 			right(type) { | ||||
| 				this.popupstyle = 'right' | ||||
| 				this.ani = ['slide-right'] | ||||
| 				this.transClass = { | ||||
| 					position: 'fixed', | ||||
| 					bottom: 0, | ||||
| 					right: 0, | ||||
| 					top: 0, | ||||
| 					backgroundColor: this.bg, | ||||
| 					/* #ifndef APP-NVUE */ | ||||
| 					display: 'flex', | ||||
| 					flexDirection: 'column' | ||||
| 					/* #endif */ | ||||
| 				} | ||||
| 				// TODO 兼容 type 属性 ,后续会废弃 | ||||
| 				if (type) return | ||||
| 				this.showPopup = true | ||||
| 				this.showTrans = true | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| </script> | ||||
| <style lang="scss"> | ||||
| 	.uni-popup { | ||||
| 		position: fixed; | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		z-index: 99; | ||||
|  | ||||
| 		/* #endif */ | ||||
| 		&.top, | ||||
| 		&.left, | ||||
| 		&.right { | ||||
| 			/* #ifdef H5 */ | ||||
| 			top: var(--window-top); | ||||
| 			/* #endif */ | ||||
| 			/* #ifndef H5 */ | ||||
| 			top: 0; | ||||
| 			/* #endif */ | ||||
| 		} | ||||
|  | ||||
| 		.uni-popup__wrapper { | ||||
| 			/* #ifndef APP-NVUE */ | ||||
| 			display: block; | ||||
| 			/* #endif */ | ||||
| 			position: relative; | ||||
|  | ||||
| 			/* iphonex 等安全区设置,底部安全区适配 */ | ||||
| 			/* #ifndef APP-NVUE */ | ||||
| 			// padding-bottom: constant(safe-area-inset-bottom); | ||||
| 			// padding-bottom: env(safe-area-inset-bottom); | ||||
| 			/* #endif */ | ||||
| 			&.left, | ||||
| 			&.right { | ||||
| 				/* #ifdef H5 */ | ||||
| 				padding-top: var(--window-top); | ||||
| 				/* #endif */ | ||||
| 				/* #ifndef H5 */ | ||||
| 				padding-top: 0; | ||||
| 				/* #endif */ | ||||
| 				flex: 1; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	.fixforpc-z-index { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		z-index: 999; | ||||
| 		/* #endif */ | ||||
| 	} | ||||
|  | ||||
| 	.fixforpc-top { | ||||
| 		top: 0; | ||||
| 	} | ||||
| </style> | ||||
							
								
								
									
										87
									
								
								uni_modules/uni-popup/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								uni_modules/uni-popup/package.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| { | ||||
| 	"id": "uni-popup", | ||||
| 	"displayName": "uni-popup 弹出层", | ||||
| 	"version": "1.8.2", | ||||
| 	"description": " Popup 组件,提供常用的弹层", | ||||
| 	"keywords": [ | ||||
|         "uni-ui", | ||||
|         "弹出层", | ||||
|         "弹窗", | ||||
|         "popup", | ||||
|         "弹框" | ||||
|     ], | ||||
| 	"repository": "https://github.com/dcloudio/uni-ui", | ||||
| 	"engines": { | ||||
| 		"HBuilderX": "" | ||||
| 	}, | ||||
| 	"directories": { | ||||
| 		"example": "../../temps/example_temps" | ||||
| 	}, | ||||
|     "dcloudext": { | ||||
|         "sale": { | ||||
| 			"regular": { | ||||
| 				"price": "0.00" | ||||
| 			}, | ||||
| 			"sourcecode": { | ||||
| 				"price": "0.00" | ||||
| 			} | ||||
| 		}, | ||||
| 		"contact": { | ||||
| 			"qq": "" | ||||
| 		}, | ||||
| 		"declaration": { | ||||
| 			"ads": "无", | ||||
| 			"data": "无", | ||||
| 			"permissions": "无" | ||||
| 		}, | ||||
|         "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui", | ||||
|         "type": "component-vue" | ||||
| 	}, | ||||
| 	"uni_modules": { | ||||
| 		"dependencies": [ | ||||
| 			"uni-scss", | ||||
| 			"uni-transition" | ||||
| 		], | ||||
| 		"encrypt": [], | ||||
| 		"platforms": { | ||||
| 			"cloud": { | ||||
| 				"tcb": "y", | ||||
| 				"aliyun": "y" | ||||
| 			}, | ||||
| 			"client": { | ||||
| 				"App": { | ||||
| 					"app-vue": "y", | ||||
| 					"app-nvue": "y" | ||||
| 				}, | ||||
| 				"H5-mobile": { | ||||
| 					"Safari": "y", | ||||
| 					"Android Browser": "y", | ||||
| 					"微信浏览器(Android)": "y", | ||||
| 					"QQ浏览器(Android)": "y" | ||||
| 				}, | ||||
| 				"H5-pc": { | ||||
| 					"Chrome": "y", | ||||
| 					"IE": "y", | ||||
| 					"Edge": "y", | ||||
| 					"Firefox": "y", | ||||
| 					"Safari": "y" | ||||
| 				}, | ||||
| 				"小程序": { | ||||
| 					"微信": "y", | ||||
| 					"阿里": "y", | ||||
| 					"百度": "y", | ||||
| 					"字节跳动": "y", | ||||
| 					"QQ": "y" | ||||
| 				}, | ||||
| 				"快应用": { | ||||
| 					"华为": "u", | ||||
| 					"联盟": "u" | ||||
|                 }, | ||||
|                 "Vue": { | ||||
|                     "vue2": "y", | ||||
|                     "vue3": "y" | ||||
|                 } | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										17
									
								
								uni_modules/uni-popup/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								uni_modules/uni-popup/readme.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
|  | ||||
|  | ||||
| ## Popup 弹出层 | ||||
| > **组件名:uni-popup** | ||||
| > 代码块: `uPopup` | ||||
| > 关联组件:`uni-transition` | ||||
|  | ||||
|  | ||||
| 弹出层组件,在应用中弹出一个消息提示窗口、提示框等 | ||||
|  | ||||
| ### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-popup) | ||||
| #### 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										20
									
								
								uni_modules/uni-transition/changelog.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								uni_modules/uni-transition/changelog.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| ## 1.3.1(2021-11-23) | ||||
| - 修复 init 方法初始化问题 | ||||
| ## 1.3.0(2021-11-19) | ||||
| - 优化 组件UI,并提供设计资源,详见:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource) | ||||
| - 文档迁移,详见:[https://uniapp.dcloud.io/component/uniui/uni-transition](https://uniapp.dcloud.io/component/uniui/uni-transition) | ||||
| ## 1.2.1(2021-09-27) | ||||
| - 修复 init 方法不生效的 Bug | ||||
| ## 1.2.0(2021-07-30) | ||||
| - 组件兼容 vue3,如何创建 vue3 项目,详见 [uni-app 项目支持 vue3 介绍](https://ask.dcloud.net.cn/article/37834) | ||||
| ## 1.1.1(2021-05-12) | ||||
| - 新增 示例地址 | ||||
| - 修复 示例项目缺少组件的 Bug | ||||
| ## 1.1.0(2021-04-22) | ||||
| - 新增 通过方法自定义动画 | ||||
| - 新增 custom-class 非 NVUE 平台支持自定义 class 定制样式 | ||||
| - 优化 动画触发逻辑,使动画更流畅 | ||||
| - 优化 支持单独的动画类型 | ||||
| - 优化 文档示例 | ||||
| ## 1.0.2(2021-02-05) | ||||
| - 调整为 uni_modules 目录规范 | ||||
| @@ -0,0 +1,128 @@ | ||||
| // const defaultOption = { | ||||
| // 	duration: 300, | ||||
| // 	timingFunction: 'linear', | ||||
| // 	delay: 0, | ||||
| // 	transformOrigin: '50% 50% 0' | ||||
| // } | ||||
| // #ifdef APP-NVUE | ||||
| const nvueAnimation = uni.requireNativePlugin('animation') | ||||
| // #endif | ||||
| class MPAnimation { | ||||
| 	constructor(options, _this) { | ||||
| 		this.options = options | ||||
| 		this.animation = uni.createAnimation(options) | ||||
| 		this.currentStepAnimates = {} | ||||
| 		this.next = 0 | ||||
| 		this.$ = _this | ||||
|  | ||||
| 	} | ||||
|  | ||||
| 	_nvuePushAnimates(type, args) { | ||||
| 		let aniObj = this.currentStepAnimates[this.next] | ||||
| 		let styles = {} | ||||
| 		if (!aniObj) { | ||||
| 			styles = { | ||||
| 				styles: {}, | ||||
| 				config: {} | ||||
| 			} | ||||
| 		} else { | ||||
| 			styles = aniObj | ||||
| 		} | ||||
| 		if (animateTypes1.includes(type)) { | ||||
| 			if (!styles.styles.transform) { | ||||
| 				styles.styles.transform = '' | ||||
| 			} | ||||
| 			let unit = '' | ||||
| 			if(type === 'rotate'){ | ||||
| 				unit = 'deg' | ||||
| 			} | ||||
| 			styles.styles.transform += `${type}(${args+unit}) ` | ||||
| 		} else { | ||||
| 			styles.styles[type] = `${args}` | ||||
| 		} | ||||
| 		this.currentStepAnimates[this.next] = styles | ||||
| 	} | ||||
| 	_animateRun(styles = {}, config = {}) { | ||||
| 		let ref = this.$.$refs['ani'].ref | ||||
| 		if (!ref) return | ||||
| 		return new Promise((resolve, reject) => { | ||||
| 			nvueAnimation.transition(ref, { | ||||
| 				styles, | ||||
| 				...config | ||||
| 			}, res => { | ||||
| 				resolve() | ||||
| 			}) | ||||
| 		}) | ||||
| 	} | ||||
|  | ||||
| 	_nvueNextAnimate(animates, step = 0, fn) { | ||||
| 		let obj = animates[step] | ||||
| 		if (obj) { | ||||
| 			let { | ||||
| 				styles, | ||||
| 				config | ||||
| 			} = obj | ||||
| 			this._animateRun(styles, config).then(() => { | ||||
| 				step += 1 | ||||
| 				this._nvueNextAnimate(animates, step, fn) | ||||
| 			}) | ||||
| 		} else { | ||||
| 			this.currentStepAnimates = {} | ||||
| 			typeof fn === 'function' && fn() | ||||
| 			this.isEnd = true | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	step(config = {}) { | ||||
| 		// #ifndef APP-NVUE | ||||
| 		this.animation.step(config) | ||||
| 		// #endif | ||||
| 		// #ifdef APP-NVUE | ||||
| 		this.currentStepAnimates[this.next].config = Object.assign({}, this.options, config) | ||||
| 		this.currentStepAnimates[this.next].styles.transformOrigin = this.currentStepAnimates[this.next].config.transformOrigin | ||||
| 		this.next++ | ||||
| 		// #endif | ||||
| 		return this | ||||
| 	} | ||||
|  | ||||
| 	run(fn) { | ||||
| 		// #ifndef APP-NVUE | ||||
| 		this.$.animationData = this.animation.export() | ||||
| 		this.$.timer = setTimeout(() => { | ||||
| 			typeof fn === 'function' && fn() | ||||
| 		}, this.$.durationTime) | ||||
| 		// #endif | ||||
| 		// #ifdef APP-NVUE | ||||
| 		this.isEnd = false | ||||
| 		let ref = this.$.$refs['ani'] && this.$.$refs['ani'].ref | ||||
| 		if(!ref) return | ||||
| 		this._nvueNextAnimate(this.currentStepAnimates, 0, fn) | ||||
| 		this.next = 0 | ||||
| 		// #endif | ||||
| 	} | ||||
| } | ||||
|  | ||||
|  | ||||
| const animateTypes1 = ['matrix', 'matrix3d', 'rotate', 'rotate3d', 'rotateX', 'rotateY', 'rotateZ', 'scale', 'scale3d', | ||||
| 	'scaleX', 'scaleY', 'scaleZ', 'skew', 'skewX', 'skewY', 'translate', 'translate3d', 'translateX', 'translateY', | ||||
| 	'translateZ' | ||||
| ] | ||||
| const animateTypes2 = ['opacity', 'backgroundColor'] | ||||
| const animateTypes3 = ['width', 'height', 'left', 'right', 'top', 'bottom'] | ||||
| animateTypes1.concat(animateTypes2, animateTypes3).forEach(type => { | ||||
| 	MPAnimation.prototype[type] = function(...args) { | ||||
| 		// #ifndef APP-NVUE | ||||
| 		this.animation[type](...args) | ||||
| 		// #endif | ||||
| 		// #ifdef APP-NVUE | ||||
| 		this._nvuePushAnimates(type, args) | ||||
| 		// #endif | ||||
| 		return this | ||||
| 	} | ||||
| }) | ||||
|  | ||||
| export function createAnimation(option, _this) { | ||||
| 	if(!_this) return | ||||
| 	clearTimeout(_this.timer) | ||||
| 	return new MPAnimation(option, _this) | ||||
| } | ||||
| @@ -0,0 +1,277 @@ | ||||
| <template> | ||||
| 	<view v-if="isShow" ref="ani" :animation="animationData" :class="customClass" :style="transformStyles" @click="onClick"><slot></slot></view> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { createAnimation } from './createAnimation' | ||||
|  | ||||
| /** | ||||
|  * Transition 过渡动画 | ||||
|  * @description 简单过渡动画组件 | ||||
|  * @tutorial https://ext.dcloud.net.cn/plugin?id=985 | ||||
|  * @property {Boolean} show = [false|true] 控制组件显示或隐藏 | ||||
|  * @property {Array|String} modeClass = [fade|slide-top|slide-right|slide-bottom|slide-left|zoom-in|zoom-out] 过渡动画类型 | ||||
|  *  @value fade 渐隐渐出过渡 | ||||
|  *  @value slide-top 由上至下过渡 | ||||
|  *  @value slide-right 由右至左过渡 | ||||
|  *  @value slide-bottom 由下至上过渡 | ||||
|  *  @value slide-left 由左至右过渡 | ||||
|  *  @value zoom-in 由小到大过渡 | ||||
|  *  @value zoom-out 由大到小过渡 | ||||
|  * @property {Number} duration 过渡动画持续时间 | ||||
|  * @property {Object} styles 组件样式,同 css 样式,注意带’-‘连接符的属性需要使用小驼峰写法如:`backgroundColor:red` | ||||
|  */ | ||||
| export default { | ||||
| 	name: 'uniTransition', | ||||
| 	emits:['click','change'], | ||||
| 	props: { | ||||
| 		show: { | ||||
| 			type: Boolean, | ||||
| 			default: false | ||||
| 		}, | ||||
| 		modeClass: { | ||||
| 			type: [Array, String], | ||||
| 			default() { | ||||
| 				return 'fade' | ||||
| 			} | ||||
| 		}, | ||||
| 		duration: { | ||||
| 			type: Number, | ||||
| 			default: 300 | ||||
| 		}, | ||||
| 		styles: { | ||||
| 			type: Object, | ||||
| 			default() { | ||||
| 				return {} | ||||
| 			} | ||||
| 		}, | ||||
| 		customClass:{ | ||||
| 			type: String, | ||||
| 			default: '' | ||||
| 		} | ||||
| 	}, | ||||
| 	data() { | ||||
| 		return { | ||||
| 			isShow: false, | ||||
| 			transform: '', | ||||
| 			opacity: 1, | ||||
| 			animationData: {}, | ||||
| 			durationTime: 300, | ||||
| 			config: {} | ||||
| 		} | ||||
| 	}, | ||||
| 	watch: { | ||||
| 		show: { | ||||
| 			handler(newVal) { | ||||
| 				if (newVal) { | ||||
| 					this.open() | ||||
| 				} else { | ||||
| 					// 避免上来就执行 close,导致动画错乱 | ||||
| 					if (this.isShow) { | ||||
| 						this.close() | ||||
| 					} | ||||
| 				} | ||||
| 			}, | ||||
| 			immediate: true | ||||
| 		} | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		// 生成样式数据 | ||||
| 		stylesObject() { | ||||
| 			let styles = { | ||||
| 				...this.styles, | ||||
| 				'transition-duration': this.duration / 1000 + 's' | ||||
| 			} | ||||
| 			let transform = '' | ||||
| 			for (let i in styles) { | ||||
| 				let line = this.toLine(i) | ||||
| 				transform += line + ':' + styles[i] + ';' | ||||
| 			} | ||||
| 			return transform | ||||
| 		}, | ||||
| 		// 初始化动画条件 | ||||
| 		transformStyles() { | ||||
| 			return 'transform:' + this.transform + ';' + 'opacity:' + this.opacity + ';' + this.stylesObject | ||||
| 		} | ||||
| 	}, | ||||
| 	created() { | ||||
| 		// 动画默认配置 | ||||
| 		this.config = { | ||||
| 			duration: this.duration, | ||||
| 			timingFunction: 'ease', | ||||
| 			transformOrigin: '50% 50%', | ||||
| 			delay: 0 | ||||
| 		} | ||||
| 		this.durationTime = this.duration | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		/** | ||||
| 		 *  ref 触发 初始化动画 | ||||
| 		 */ | ||||
| 		init(obj = {}) { | ||||
| 			if (obj.duration) { | ||||
| 				this.durationTime = obj.duration | ||||
| 			} | ||||
| 			this.animation = createAnimation(Object.assign(this.config, obj),this) | ||||
| 		}, | ||||
| 		/** | ||||
| 		 * 点击组件触发回调 | ||||
| 		 */ | ||||
| 		onClick() { | ||||
| 			this.$emit('click', { | ||||
| 				detail: this.isShow | ||||
| 			}) | ||||
| 		}, | ||||
| 		/** | ||||
| 		 * ref 触发 动画分组 | ||||
| 		 * @param {Object} obj | ||||
| 		 */ | ||||
| 		step(obj, config = {}) { | ||||
| 			if (!this.animation) return | ||||
| 			for (let i in obj) { | ||||
| 				try { | ||||
| 					if(typeof obj[i] === 'object'){ | ||||
| 						this.animation[i](...obj[i]) | ||||
| 					}else{ | ||||
| 						this.animation[i](obj[i]) | ||||
| 					} | ||||
| 				} catch (e) { | ||||
| 					console.error(`方法 ${i} 不存在`) | ||||
| 				} | ||||
| 			} | ||||
| 			this.animation.step(config) | ||||
| 			return this | ||||
| 		}, | ||||
| 		/** | ||||
| 		 *  ref 触发 执行动画 | ||||
| 		 */ | ||||
| 		run(fn) { | ||||
| 			if (!this.animation) return | ||||
| 			this.animation.run(fn) | ||||
| 		}, | ||||
| 		// 开始过度动画 | ||||
| 		open() { | ||||
| 			clearTimeout(this.timer) | ||||
| 			this.transform = '' | ||||
| 			this.isShow = true | ||||
| 			let { opacity, transform } = this.styleInit(false) | ||||
| 			if (typeof opacity !== 'undefined') { | ||||
| 				this.opacity = opacity | ||||
| 			} | ||||
| 			this.transform = transform | ||||
| 			// 确保动态样式已经生效后,执行动画,如果不加 nextTick ,会导致 wx 动画执行异常 | ||||
| 			this.$nextTick(() => { | ||||
| 				// TODO 定时器保证动画完全执行,目前有些问题,后面会取消定时器 | ||||
| 				this.timer = setTimeout(() => { | ||||
| 					this.animation = createAnimation(this.config, this) | ||||
| 					this.tranfromInit(false).step() | ||||
| 					this.animation.run() | ||||
| 					this.$emit('change', { | ||||
| 						detail: this.isShow | ||||
| 					}) | ||||
| 				}, 20) | ||||
| 			}) | ||||
| 		}, | ||||
| 		// 关闭过度动画 | ||||
| 		close(type) { | ||||
| 			if (!this.animation) return | ||||
| 			this.tranfromInit(true) | ||||
| 				.step() | ||||
| 				.run(() => { | ||||
| 					this.isShow = false | ||||
| 					this.animationData = null | ||||
| 					this.animation = null | ||||
| 					let { opacity, transform } = this.styleInit(false) | ||||
| 					this.opacity = opacity || 1 | ||||
| 					this.transform = transform | ||||
| 					this.$emit('change', { | ||||
| 						detail: this.isShow | ||||
| 					}) | ||||
| 				}) | ||||
| 		}, | ||||
| 		// 处理动画开始前的默认样式 | ||||
| 		styleInit(type) { | ||||
| 			let styles = { | ||||
| 				transform: '' | ||||
| 			} | ||||
| 			let buildStyle = (type, mode) => { | ||||
| 				if (mode === 'fade') { | ||||
| 					styles.opacity = this.animationType(type)[mode] | ||||
| 				} else { | ||||
| 					styles.transform += this.animationType(type)[mode] + ' ' | ||||
| 				} | ||||
| 			} | ||||
| 			if (typeof this.modeClass === 'string') { | ||||
| 				buildStyle(type, this.modeClass) | ||||
| 			} else { | ||||
| 				this.modeClass.forEach(mode => { | ||||
| 					buildStyle(type, mode) | ||||
| 				}) | ||||
| 			} | ||||
| 			return styles | ||||
| 		}, | ||||
| 		// 处理内置组合动画 | ||||
| 		tranfromInit(type) { | ||||
| 			let buildTranfrom = (type, mode) => { | ||||
| 				let aniNum = null | ||||
| 				if (mode === 'fade') { | ||||
| 					aniNum = type ? 0 : 1 | ||||
| 				} else { | ||||
| 					aniNum = type ? '-100%' : '0' | ||||
| 					if (mode === 'zoom-in') { | ||||
| 						aniNum = type ? 0.8 : 1 | ||||
| 					} | ||||
| 					if (mode === 'zoom-out') { | ||||
| 						aniNum = type ? 1.2 : 1 | ||||
| 					} | ||||
| 					if (mode === 'slide-right') { | ||||
| 						aniNum = type ? '100%' : '0' | ||||
| 					} | ||||
| 					if (mode === 'slide-bottom') { | ||||
| 						aniNum = type ? '100%' : '0' | ||||
| 					} | ||||
| 				} | ||||
| 				this.animation[this.animationMode()[mode]](aniNum) | ||||
| 			} | ||||
| 			if (typeof this.modeClass === 'string') { | ||||
| 				buildTranfrom(type, this.modeClass) | ||||
| 			} else { | ||||
| 				this.modeClass.forEach(mode => { | ||||
| 					buildTranfrom(type, mode) | ||||
| 				}) | ||||
| 			} | ||||
|  | ||||
| 			return this.animation | ||||
| 		}, | ||||
| 		animationType(type) { | ||||
| 			return { | ||||
| 				fade: type ? 1 : 0, | ||||
| 				'slide-top': `translateY(${type ? '0' : '-100%'})`, | ||||
| 				'slide-right': `translateX(${type ? '0' : '100%'})`, | ||||
| 				'slide-bottom': `translateY(${type ? '0' : '100%'})`, | ||||
| 				'slide-left': `translateX(${type ? '0' : '-100%'})`, | ||||
| 				'zoom-in': `scaleX(${type ? 1 : 0.8}) scaleY(${type ? 1 : 0.8})`, | ||||
| 				'zoom-out': `scaleX(${type ? 1 : 1.2}) scaleY(${type ? 1 : 1.2})` | ||||
| 			} | ||||
| 		}, | ||||
| 		// 内置动画类型与实际动画对应字典 | ||||
| 		animationMode() { | ||||
| 			return { | ||||
| 				fade: 'opacity', | ||||
| 				'slide-top': 'translateY', | ||||
| 				'slide-right': 'translateX', | ||||
| 				'slide-bottom': 'translateY', | ||||
| 				'slide-left': 'translateX', | ||||
| 				'zoom-in': 'scale', | ||||
| 				'zoom-out': 'scale' | ||||
| 			} | ||||
| 		}, | ||||
| 		// 驼峰转中横线 | ||||
| 		toLine(name) { | ||||
| 			return name.replace(/([A-Z])/g, '-$1').toLowerCase() | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| </script> | ||||
|  | ||||
| <style></style> | ||||
							
								
								
									
										87
									
								
								uni_modules/uni-transition/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								uni_modules/uni-transition/package.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| { | ||||
|   "id": "uni-transition", | ||||
|   "displayName": "uni-transition 过渡动画", | ||||
|   "version": "1.3.1", | ||||
|   "description": "元素的简单过渡动画", | ||||
|   "keywords": [ | ||||
|     "uni-ui", | ||||
|     "uniui", | ||||
|     "动画", | ||||
|     "过渡", | ||||
|     "过渡动画" | ||||
| ], | ||||
|   "repository": "https://github.com/dcloudio/uni-ui", | ||||
|   "engines": { | ||||
|     "HBuilderX": "" | ||||
|   }, | ||||
|   "directories": { | ||||
|     "example": "../../temps/example_temps" | ||||
|   }, | ||||
|   "dcloudext": { | ||||
|     "category": [ | ||||
|       "前端组件", | ||||
|       "通用组件" | ||||
|     ], | ||||
|     "sale": { | ||||
|       "regular": { | ||||
|         "price": "0.00" | ||||
|       }, | ||||
|       "sourcecode": { | ||||
|         "price": "0.00" | ||||
|       } | ||||
|     }, | ||||
|     "contact": { | ||||
|       "qq": "" | ||||
|     }, | ||||
|     "declaration": { | ||||
|       "ads": "无", | ||||
|       "data": "无", | ||||
|       "permissions": "无" | ||||
|     }, | ||||
|     "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui" | ||||
|   }, | ||||
|   "uni_modules": { | ||||
|     "dependencies": ["uni-scss"], | ||||
|     "encrypt": [], | ||||
|     "platforms": { | ||||
|       "cloud": { | ||||
|         "tcb": "y", | ||||
|         "aliyun": "y" | ||||
|       }, | ||||
|       "client": { | ||||
|         "App": { | ||||
|           "app-vue": "y", | ||||
|           "app-nvue": "y" | ||||
|         }, | ||||
|         "H5-mobile": { | ||||
|           "Safari": "y", | ||||
|           "Android Browser": "y", | ||||
|           "微信浏览器(Android)": "y", | ||||
|           "QQ浏览器(Android)": "y" | ||||
|         }, | ||||
|         "H5-pc": { | ||||
|           "Chrome": "y", | ||||
|           "IE": "y", | ||||
|           "Edge": "y", | ||||
|           "Firefox": "y", | ||||
|           "Safari": "y" | ||||
|         }, | ||||
|         "小程序": { | ||||
|           "微信": "y", | ||||
|           "阿里": "y", | ||||
|           "百度": "y", | ||||
|           "字节跳动": "y", | ||||
|           "QQ": "y" | ||||
|         }, | ||||
|         "快应用": { | ||||
|           "华为": "u", | ||||
|           "联盟": "u" | ||||
|         }, | ||||
|         "Vue": { | ||||
|             "vue2": "y", | ||||
|             "vue3": "y" | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										11
									
								
								uni_modules/uni-transition/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								uni_modules/uni-transition/readme.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
|  | ||||
|  | ||||
| ## Transition 过渡动画 | ||||
| > **组件名:uni-transition** | ||||
| > 代码块: `uTransition` | ||||
|  | ||||
|  | ||||
| 元素过渡动画 | ||||
|  | ||||
| ### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-transition) | ||||
| #### 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839  | ||||
		Reference in New Issue
	
	Block a user