| @@ -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> | ||||
		Reference in New Issue
	
	Block a user