145 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
		
		
			
		
	
	
			145 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
|   | <template> | ||
|  | 	<view v-show="isShow"> | ||
|  | 		<view class="shade" @tap="hide"> | ||
|  | 			<view class="pop"> | ||
|  | 				<view class="list flex_col" v-for="(item,index) in colorArr" :key="index"> | ||
|  | 					<view v-for="(v,i) in item" :key="i" :style="{'backgroundColor':v}" :data-color="v" | ||
|  | 						:data-index="index" :data-i="i" :class="{'active':(index==pickerArr[0] && i==pickerArr[1])}" | ||
|  | 						@tap.stop="picker"></view> | ||
|  | 				</view> | ||
|  | 			</view> | ||
|  | 		</view> | ||
|  | 
 | ||
|  | 	</view> | ||
|  | </template> | ||
|  | 
 | ||
|  | <script> | ||
|  | 	export default { | ||
|  | 		name: 'picker-color', | ||
|  | 		props: { | ||
|  | 			isShow: { | ||
|  | 				type: Boolean, | ||
|  | 				default: false, | ||
|  | 			}, | ||
|  | 			bottom: { | ||
|  | 				type: Number, | ||
|  | 				default: 0, | ||
|  | 			} | ||
|  | 		}, | ||
|  | 		data() { | ||
|  | 			return { | ||
|  | 				colorArr: [ | ||
|  | 					['#000000', '#111111', '#222222', '#333333', '#444444', '#666666', '#999999', '#CCCCCC', '#EEEEEE', | ||
|  | 						'#FFFFFF' | ||
|  | 					], | ||
|  | 					['#ff0000', '#ff0033', '#ff3399', '#ff33cc', '#cc00ff', '#9900ff', '#cc00cc', '#cc0099', '#cc3399', | ||
|  | 						'#cc0066' | ||
|  | 					], | ||
|  | 					['#cc3300', '#cc6600', '#ff9933', '#ff9966', '#ff9999', '#ff99cc', '#ff99ff', '#cc66ff', '#9966ff', | ||
|  | 						'#cc33ff' | ||
|  | 					], | ||
|  | 					['#663300', '#996600', '#996633', '#cc9900', '#a58800', '#cccc00', '#ffff66', '#ffff99', '#ffffcc', | ||
|  | 						'#ffcccc' | ||
|  | 					], | ||
|  | 					['#336600', '#669900', '#009900', '#009933', '#00cc00', '#66ff66', '#339933', '#339966', '#009999', | ||
|  | 						'#33cccc' | ||
|  | 					], | ||
|  | 					['#003366', '#336699', '#3366cc', '#0099ff', '#000099', '#0000cc', '#660066', '#993366', '#993333', | ||
|  | 						'#800000' | ||
|  | 					] | ||
|  | 				], | ||
|  | 				pickerColor: '', | ||
|  | 				pickerArr: [-1, -1] | ||
|  | 			}; | ||
|  | 		}, | ||
|  | 		methods: { | ||
|  | 			picker(e) { | ||
|  | 				let data = e.currentTarget.dataset; | ||
|  | 				this.pickerColor = data.color; | ||
|  | 				this.pickerArr = [data.index, data.i]; | ||
|  | 				this.$emit("callback", this.pickerColor); | ||
|  | 			}, | ||
|  | 			hide() { | ||
|  | 				this.$emit("callback", ''); | ||
|  | 			}, | ||
|  | 		}, | ||
|  | 
 | ||
|  | 	} | ||
|  | </script> | ||
|  | 
 | ||
|  | <style scoped> | ||
|  | 	.shade { | ||
|  | 		position: fixed; | ||
|  | 		top: 0; | ||
|  | 		right: 0; | ||
|  | 		bottom: 0; | ||
|  | 		left: 0; | ||
|  | 		background-color: rgba(0, 0, 0, 0.5); | ||
|  | 		z-index: 99; | ||
|  | 		display: flex; | ||
|  | 		justify-content: center; | ||
|  | 		align-items: center | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.pop { | ||
|  | 		border-radius: 8px; | ||
|  | 		background-color: #fff; | ||
|  | 		z-index: 100; | ||
|  | 		padding: 12upx; | ||
|  | 		font-size: 32upx; | ||
|  | 		transform: rotate(90deg); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.flex_col { | ||
|  | 		display: flex; | ||
|  | 		flex-direction: row; | ||
|  | 		flex-wrap: nowrap; | ||
|  | 		justify-content: flex-start; | ||
|  | 		align-items: center; | ||
|  | 		align-content: center; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.list { | ||
|  | 		justify-content: space-between; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.list>view { | ||
|  | 		width: 60upx; | ||
|  | 		height: 60upx; | ||
|  | 		margin: 5upx; | ||
|  | 		box-sizing: border-box; | ||
|  | 		border-radius: 3px; | ||
|  | 		box-shadow: 0 0 2px #ccc; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.list .active { | ||
|  | 		box-shadow: 0 0 2px #09f; | ||
|  | 		transform: scale(1.05, 1.05); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.preview { | ||
|  | 		width: 180upx; | ||
|  | 		height: 60upx; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.value { | ||
|  | 		margin: 0 40upx; | ||
|  | 		flex-grow: 1; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.ok { | ||
|  | 		width: 160upx; | ||
|  | 		height: 60upx; | ||
|  | 		line-height: 60upx; | ||
|  | 		text-align: center; | ||
|  | 		background-color: #ff9933; | ||
|  | 		color: #fff; | ||
|  | 		border-radius: 4px; | ||
|  | 		letter-spacing: 3px; | ||
|  | 		font-size: 32upx; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.ok:active { | ||
|  | 		background-color: rgb(255, 107, 34); | ||
|  | 	} | ||
|  | </style> |