Compare commits
	
		
			No commits in common. "1f9f9bb56af622f32a2ea594c4a8bc3577957b69" and "47c9d3b46bcd90d53945e83f87fe2bde0eb0768d" have entirely different histories.
		
	
	
		
			1f9f9bb56a
			...
			47c9d3b46b
		
	
		
| @ -55,13 +55,6 @@ | ||||
| 
 | ||||
|     <uni-popup ref="popup" background-color="#fff"> | ||||
|       <view class="popup-content" style="padding: 15px;"> | ||||
|         <view class="dl-avatar-box"> | ||||
|           <uni-section title="领料人" type="line"> | ||||
|             <view class="uni-px-5 uni-pb-5"> | ||||
|               <uni-data-checkbox multiple v-model="chooseStaff" :localdata="staffs"></uni-data-checkbox> | ||||
|             </view> | ||||
|           </uni-section> | ||||
|         </view> | ||||
|         <view class="dl-avatar-box"> | ||||
|           <uni-file-picker :value="fileList" :sizeType="sizeType" @select="afterRead" @delete="deleteFile" | ||||
|                            limit="9" title="请上传配件申请单照片(最多选择9张图片)"></uni-file-picker> | ||||
| @ -100,10 +93,6 @@ export default { | ||||
|       selectRows: [], | ||||
|       fileList: [], | ||||
|       sizeType: ['compressed'], | ||||
|       chooseStaff: [], | ||||
|       staffs: [], | ||||
|       ticketId: null, | ||||
|       nowStaffId: null, | ||||
|     }; | ||||
|   }, | ||||
|   onLoad(data) { | ||||
| @ -111,8 +100,6 @@ export default { | ||||
|       this.formData = getJSONData("applyWaresForm") | ||||
|       this.isReceive = this.formData.isReceive | ||||
|       this.twId = this.formData.id | ||||
|       this.ticketId = this.formData.ticketId | ||||
|       this.nowStaffId = this.formData.repairId | ||||
|       this.init() | ||||
|     } | ||||
|     if (data.isToBeReviewed) { | ||||
| @ -122,7 +109,7 @@ export default { | ||||
| 
 | ||||
|   computed: {}, | ||||
|   methods: { | ||||
|     async submitBefore(){ | ||||
|     submitBefore(){ | ||||
|       if (this.isReceive){ | ||||
|         if (!this.selectRows || this.selectRows.length === 0){ | ||||
|           uni.showToast({ | ||||
| @ -131,21 +118,7 @@ export default { | ||||
|           }) | ||||
|           return | ||||
|         } | ||||
|         request({ | ||||
|           url: '/admin-api/repair/worker/listByTicketId?ticketId=' + this.ticketId, | ||||
|           method: 'get' | ||||
|         }).then(res => { | ||||
|           this.chooseStaff = [] | ||||
|           const data = res.data | ||||
|           this.staffs = data.map(item => { | ||||
|             return { | ||||
|               text: item.userName, | ||||
|               value: item.userId | ||||
|             } | ||||
|           }) | ||||
|           this.chooseStaff.push(this.nowStaffId) | ||||
|         this.$refs.popup.open() | ||||
|         }) | ||||
|       }else { | ||||
|         this.submit() | ||||
|       } | ||||
| @ -315,14 +288,6 @@ export default { | ||||
|           return item.path.replace(config.baseImageUrl, "") | ||||
|         }).join(",") | ||||
|       } | ||||
|       if (this.isReceive && (!this.chooseStaff || this.chooseStaff.length === 0)){ | ||||
|         uni.showToast({ | ||||
|           title: '请选择领料人!', | ||||
|           icon: 'none' | ||||
|         }) | ||||
|         return | ||||
|       } | ||||
|       this.formData.repairSo.userIds = this.chooseStaff.join(",") | ||||
|       request({ | ||||
|         url: '/admin-api/repair/tw/pass', | ||||
|         method: 'post', | ||||
|  | ||||
| @ -1,51 +0,0 @@ | ||||
| ## 1.0.6(2024-10-22) | ||||
| - 新增 当 multiple 为 false 且传递的 value 为 数组时,使用数组第一项用作反显 | ||||
| ## 1.0.5(2024-03-20) | ||||
| - 修复 单选模式下选中样式不生效的bug | ||||
| ## 1.0.4(2024-01-27) | ||||
| - 修复 修复错别字chagne为change | ||||
| ## 1.0.3(2022-09-16) | ||||
| - 可以使用 uni-scss 控制主题色 | ||||
| ## 1.0.2(2022-06-30) | ||||
| - 优化 在 uni-forms 中的依赖注入方式 | ||||
| ## 1.0.1(2022-02-07) | ||||
| - 修复 multiple 为 true 时,v-model 的值为 null 报错的 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-data-checkbox](https://uniapp.dcloud.io/component/uniui/uni-data-checkbox) | ||||
| ## 0.2.5(2021-08-23) | ||||
| - 修复 在uni-forms中 modelValue 中不存在当前字段,当前字段必填写也不参与校验的问题 | ||||
| ## 0.2.4(2021-08-17) | ||||
| - 修复 单选 list 模式下 ,icon 为 left 时,选中图标不显示的问题 | ||||
| ## 0.2.3(2021-08-11) | ||||
| - 修复 在 uni-forms 中重置表单,错误信息无法清除的问题 | ||||
| ## 0.2.2(2021-07-30) | ||||
| - 优化 在uni-forms组件,与label不对齐的问题 | ||||
| ## 0.2.1(2021-07-27) | ||||
| - 修复 单选默认值为0不能选中的Bug | ||||
| ## 0.2.0(2021-07-13) | ||||
| - 组件兼容 vue3,如何创建vue3项目,详见 [uni-app 项目支持 vue3 介绍](https://ask.dcloud.net.cn/article/37834) | ||||
| ## 0.1.11(2021-07-06) | ||||
| - 优化 删除无用日志 | ||||
| ## 0.1.10(2021-07-05) | ||||
| - 修复 由 0.1.9 引起的非 nvue 端图标不显示的问题 | ||||
| ## 0.1.9(2021-07-05) | ||||
| - 修复 nvue 黑框样式问题 | ||||
| ## 0.1.8(2021-06-28) | ||||
| - 修复 selectedTextColor 属性不生效的Bug | ||||
| ## 0.1.7(2021-06-02) | ||||
| - 新增 map 属性,可以方便映射text/value属性 | ||||
| ## 0.1.6(2021-05-26) | ||||
| - 修复 不关联服务空间的情况下组件报错的Bug | ||||
| ## 0.1.5(2021-05-12) | ||||
| - 新增 组件示例地址 | ||||
| ## 0.1.4(2021-04-09) | ||||
| - 修复 nvue 下无法选中的问题 | ||||
| ## 0.1.3(2021-03-22) | ||||
| - 新增 disabled属性 | ||||
| ## 0.1.2(2021-02-24) | ||||
| - 优化 默认颜色显示 | ||||
| ## 0.1.1(2021-02-24) | ||||
| - 新增 支持nvue | ||||
| ## 0.1.0(2021-02-18) | ||||
| - “暂无数据”显示居中 | ||||
| @ -1,316 +0,0 @@ | ||||
| 
 | ||||
| const events = { | ||||
| 	load: 'load', | ||||
| 	error: 'error' | ||||
| } | ||||
| const pageMode = { | ||||
| 	add: 'add', | ||||
| 	replace: 'replace' | ||||
| } | ||||
| 
 | ||||
| const attrs = [ | ||||
| 	'pageCurrent', | ||||
| 	'pageSize', | ||||
| 	'collection', | ||||
| 	'action', | ||||
| 	'field', | ||||
| 	'getcount', | ||||
| 	'orderby', | ||||
| 	'where' | ||||
| ] | ||||
| 
 | ||||
| export default { | ||||
| 	data() { | ||||
| 		return { | ||||
| 			loading: false, | ||||
| 			listData: this.getone ? {} : [], | ||||
| 			paginationInternal: { | ||||
| 				current: this.pageCurrent, | ||||
| 				size: this.pageSize, | ||||
| 				count: 0 | ||||
| 			}, | ||||
| 			errorMessage: '' | ||||
| 		} | ||||
| 	}, | ||||
| 	created() { | ||||
| 		let db = null; | ||||
| 		let dbCmd = null; | ||||
| 
 | ||||
| 		if(this.collection){ | ||||
| 			this.db = uniCloud.database(); | ||||
| 			this.dbCmd = this.db.command; | ||||
| 		} | ||||
| 
 | ||||
| 		this._isEnded = false | ||||
| 
 | ||||
| 		this.$watch(() => { | ||||
| 			let al = [] | ||||
| 			attrs.forEach(key => { | ||||
| 				al.push(this[key]) | ||||
| 			}) | ||||
| 			return al | ||||
| 		}, (newValue, oldValue) => { | ||||
| 			this.paginationInternal.pageSize = this.pageSize | ||||
| 
 | ||||
| 			let needReset = false | ||||
| 			for (let i = 2; i < newValue.length; i++) { | ||||
| 				if (newValue[i] != oldValue[i]) { | ||||
| 					needReset = true | ||||
| 					break | ||||
| 				} | ||||
| 			} | ||||
| 			if (needReset) { | ||||
| 				this.clear() | ||||
| 				this.reset() | ||||
| 			} | ||||
| 			if (newValue[0] != oldValue[0]) { | ||||
| 				this.paginationInternal.current = this.pageCurrent | ||||
| 			} | ||||
| 
 | ||||
| 			this._execLoadData() | ||||
| 		}) | ||||
| 
 | ||||
| 		// #ifdef H5
 | ||||
| 		if (process.env.NODE_ENV === 'development') { | ||||
| 			this._debugDataList = [] | ||||
| 			if (!window.unidev) { | ||||
| 				window.unidev = { | ||||
| 					clientDB: { | ||||
| 						data: [] | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 			unidev.clientDB.data.push(this._debugDataList) | ||||
| 		} | ||||
| 		// #endif
 | ||||
| 
 | ||||
| 		// #ifdef MP-TOUTIAO
 | ||||
| 		let changeName | ||||
| 		let events = this.$scope.dataset.eventOpts | ||||
| 		for (let i = 0; i < events.length; i++) { | ||||
| 			let event = events[i] | ||||
| 			if (event[0].includes('^load')) { | ||||
| 				changeName = event[1][0][0] | ||||
| 			} | ||||
| 		} | ||||
| 		if (changeName) { | ||||
| 			let parent = this.$parent | ||||
| 			let maxDepth = 16 | ||||
| 			this._changeDataFunction = null | ||||
| 			while (parent && maxDepth > 0) { | ||||
| 				let fun = parent[changeName] | ||||
| 				if (fun && typeof fun === 'function') { | ||||
| 					this._changeDataFunction = fun | ||||
| 					maxDepth = 0 | ||||
| 					break | ||||
| 				} | ||||
| 				parent = parent.$parent | ||||
| 				maxDepth--; | ||||
| 			} | ||||
| 		} | ||||
| 		// #endif
 | ||||
| 
 | ||||
| 		// if (!this.manual) {
 | ||||
| 		// 	this.loadData()
 | ||||
| 		// }
 | ||||
| 	}, | ||||
| 	// #ifdef H5
 | ||||
| 	beforeDestroy() { | ||||
| 		if (process.env.NODE_ENV === 'development' && window.unidev) { | ||||
| 			let cd = this._debugDataList | ||||
| 			let dl = unidev.clientDB.data | ||||
| 			for (let i = dl.length - 1; i >= 0; i--) { | ||||
| 				if (dl[i] === cd) { | ||||
| 					dl.splice(i, 1) | ||||
| 					break | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
| 	// #endif
 | ||||
| 	methods: { | ||||
| 		loadData(args1, args2) { | ||||
| 			let callback = null | ||||
| 			if (typeof args1 === 'object') { | ||||
| 				if (args1.clear) { | ||||
| 					this.clear() | ||||
| 					this.reset() | ||||
| 				} | ||||
| 				if (args1.current !== undefined) { | ||||
| 					this.paginationInternal.current = args1.current | ||||
| 				} | ||||
| 				if (typeof args2 === 'function') { | ||||
| 					callback = args2 | ||||
| 				} | ||||
| 			} else if (typeof args1 === 'function') { | ||||
| 				callback = args1 | ||||
| 			} | ||||
| 
 | ||||
| 			this._execLoadData(callback) | ||||
| 		}, | ||||
| 		loadMore() { | ||||
| 			if (this._isEnded) { | ||||
| 				return | ||||
| 			} | ||||
| 			this._execLoadData() | ||||
| 		}, | ||||
| 		refresh() { | ||||
| 			this.clear() | ||||
| 			this._execLoadData() | ||||
| 		}, | ||||
| 		clear() { | ||||
| 			this._isEnded = false | ||||
| 			this.listData = [] | ||||
| 		}, | ||||
| 		reset() { | ||||
| 			this.paginationInternal.current = 1 | ||||
| 		}, | ||||
| 		remove(id, { | ||||
| 			action, | ||||
| 			callback, | ||||
| 			confirmTitle, | ||||
| 			confirmContent | ||||
| 		} = {}) { | ||||
| 			if (!id || !id.length) { | ||||
| 				return | ||||
| 			} | ||||
| 			uni.showModal({ | ||||
| 				title: confirmTitle || '提示', | ||||
| 				content: confirmContent || '是否删除该数据', | ||||
| 				showCancel: true, | ||||
| 				success: (res) => { | ||||
| 					if (!res.confirm) { | ||||
| 						return | ||||
| 					} | ||||
| 					this._execRemove(id, action, callback) | ||||
| 				} | ||||
| 			}) | ||||
| 		}, | ||||
| 		_execLoadData(callback) { | ||||
| 			if (this.loading) { | ||||
| 				return | ||||
| 			} | ||||
| 			this.loading = true | ||||
| 			this.errorMessage = '' | ||||
| 
 | ||||
| 			this._getExec().then((res) => { | ||||
| 				this.loading = false | ||||
| 				const { | ||||
| 					data, | ||||
| 					count | ||||
| 				} = res.result | ||||
| 				this._isEnded = data.length < this.pageSize | ||||
| 
 | ||||
| 				callback && callback(data, this._isEnded) | ||||
| 				this._dispatchEvent(events.load, data) | ||||
| 
 | ||||
| 				if (this.getone) { | ||||
| 					this.listData = data.length ? data[0] : undefined | ||||
| 				} else if (this.pageData === pageMode.add) { | ||||
| 					this.listData.push(...data) | ||||
| 					if (this.listData.length) { | ||||
| 						this.paginationInternal.current++ | ||||
| 					} | ||||
| 				} else if (this.pageData === pageMode.replace) { | ||||
| 					this.listData = data | ||||
| 					this.paginationInternal.count = count | ||||
| 				} | ||||
| 
 | ||||
| 				// #ifdef H5
 | ||||
| 				if (process.env.NODE_ENV === 'development') { | ||||
| 					this._debugDataList.length = 0 | ||||
| 					this._debugDataList.push(...JSON.parse(JSON.stringify(this.listData))) | ||||
| 				} | ||||
| 				// #endif
 | ||||
| 			}).catch((err) => { | ||||
| 				this.loading = false | ||||
| 				this.errorMessage = err | ||||
| 				callback && callback() | ||||
| 				this.$emit(events.error, err) | ||||
| 			}) | ||||
| 		}, | ||||
| 		_getExec() { | ||||
| 			let exec = this.db | ||||
| 			if (this.action) { | ||||
| 				exec = exec.action(this.action) | ||||
| 			} | ||||
| 
 | ||||
| 			exec = exec.collection(this.collection) | ||||
| 
 | ||||
| 			if (!(!this.where || !Object.keys(this.where).length)) { | ||||
| 				exec = exec.where(this.where) | ||||
| 			} | ||||
| 			if (this.field) { | ||||
| 				exec = exec.field(this.field) | ||||
| 			} | ||||
| 			if (this.orderby) { | ||||
| 				exec = exec.orderBy(this.orderby) | ||||
| 			} | ||||
| 
 | ||||
| 			const { | ||||
| 				current, | ||||
| 				size | ||||
| 			} = this.paginationInternal | ||||
| 			exec = exec.skip(size * (current - 1)).limit(size).get({ | ||||
| 				getCount: this.getcount | ||||
| 			}) | ||||
| 
 | ||||
| 			return exec | ||||
| 		}, | ||||
| 		_execRemove(id, action, callback) { | ||||
| 			if (!this.collection || !id) { | ||||
| 				return | ||||
| 			} | ||||
| 
 | ||||
| 			const ids = Array.isArray(id) ? id : [id] | ||||
| 			if (!ids.length) { | ||||
| 				return | ||||
| 			} | ||||
| 
 | ||||
| 			uni.showLoading({ | ||||
| 				mask: true | ||||
| 			}) | ||||
| 
 | ||||
| 			let exec = this.db | ||||
| 			if (action) { | ||||
| 				exec = exec.action(action) | ||||
| 			} | ||||
| 
 | ||||
| 			exec.collection(this.collection).where({ | ||||
| 				_id: dbCmd.in(ids) | ||||
| 			}).remove().then((res) => { | ||||
| 				callback && callback(res.result) | ||||
| 				if (this.pageData === pageMode.replace) { | ||||
| 					this.refresh() | ||||
| 				} else { | ||||
| 					this.removeData(ids) | ||||
| 				} | ||||
| 			}).catch((err) => { | ||||
| 				uni.showModal({ | ||||
| 					content: err.message, | ||||
| 					showCancel: false | ||||
| 				}) | ||||
| 			}).finally(() => { | ||||
| 				uni.hideLoading() | ||||
| 			}) | ||||
| 		}, | ||||
| 		removeData(ids) { | ||||
| 			let il = ids.slice(0) | ||||
| 			let dl = this.listData | ||||
| 			for (let i = dl.length - 1; i >= 0; i--) { | ||||
| 				let index = il.indexOf(dl[i]._id) | ||||
| 				if (index >= 0) { | ||||
| 					dl.splice(i, 1) | ||||
| 					il.splice(index, 1) | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
| 		_dispatchEvent(type, data) { | ||||
| 			if (this._changeDataFunction) { | ||||
| 				this._changeDataFunction(data, this._isEnded) | ||||
| 			} else { | ||||
| 				this.$emit(type, data, this._isEnded) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -1,853 +0,0 @@ | ||||
| <template> | ||||
| 	<view class="uni-data-checklist" :style="{'margin-top':isTop+'px'}"> | ||||
| 		<template v-if="!isLocal"> | ||||
| 			<view class="uni-data-loading"> | ||||
| 				<uni-load-more v-if="!mixinDatacomErrorMessage" status="loading" iconType="snow" :iconSize="18" | ||||
| 					:content-text="contentText"></uni-load-more> | ||||
| 				<text v-else>{{mixinDatacomErrorMessage}}</text> | ||||
| 			</view> | ||||
| 		</template> | ||||
| 		<template v-else> | ||||
| 			<checkbox-group v-if="multiple" class="checklist-group" :class="{'is-list':mode==='list' || wrap}" | ||||
| 				@change="change"> | ||||
| 				<label class="checklist-box" | ||||
| 					:class="['is--'+mode,item.selected?'is-checked':'',(disabled || !!item.disabled)?'is-disable':'',index!==0&&mode==='list'?'is-list-border':'']" | ||||
| 					:style="item.styleBackgroud" v-for="(item,index) in dataList" :key="index"> | ||||
| 					<checkbox class="hidden" hidden :disabled="disabled || !!item.disabled" :value="item[map.value]+''" | ||||
| 						:checked="item.selected" /> | ||||
| 					<view v-if="(mode !=='tag' && mode !== 'list') || ( mode === 'list' && icon === 'left')" | ||||
| 						class="checkbox__inner" :style="item.styleIcon"> | ||||
| 						<view class="checkbox__inner-icon"></view> | ||||
| 					</view> | ||||
| 					<view class="checklist-content" :class="{'list-content':mode === 'list' && icon ==='left'}"> | ||||
| 						<text class="checklist-text" :style="item.styleIconText">{{item[map.text]}}</text> | ||||
| 						<view v-if="mode === 'list' && icon === 'right'" class="checkobx__list" :style="item.styleBackgroud"></view> | ||||
| 					</view> | ||||
| 				</label> | ||||
| 			</checkbox-group> | ||||
| 			<radio-group v-else class="checklist-group" :class="{'is-list':mode==='list','is-wrap':wrap}" @change="change"> | ||||
| 				<label class="checklist-box" | ||||
| 					:class="['is--'+mode,item.selected?'is-checked':'',(disabled || !!item.disabled)?'is-disable':'',index!==0&&mode==='list'?'is-list-border':'']" | ||||
| 					:style="item.styleBackgroud" v-for="(item,index) in dataList" :key="index"> | ||||
| 					<radio class="hidden" hidden :disabled="disabled || item.disabled" :value="item[map.value]+''" | ||||
| 						:checked="item.selected" /> | ||||
| 					<view v-if="(mode !=='tag' && mode !== 'list') || ( mode === 'list' && icon === 'left')" class="radio__inner" | ||||
| 						:style="item.styleBackgroud"> | ||||
| 						<view class="radio__inner-icon" :style="item.styleIcon"></view> | ||||
| 					</view> | ||||
| 					<view class="checklist-content" :class="{'list-content':mode === 'list' && icon ==='left'}"> | ||||
| 						<text class="checklist-text" :style="item.styleIconText">{{item[map.text]}}</text> | ||||
| 						<view v-if="mode === 'list' && icon === 'right'" :style="item.styleRightIcon" class="checkobx__list"></view> | ||||
| 					</view> | ||||
| 				</label> | ||||
| 			</radio-group> | ||||
| 		</template> | ||||
| 	</view> | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| 	/** | ||||
| 	 * DataChecklist 数据选择器 | ||||
| 	 * @description 通过数据渲染 checkbox 和 radio | ||||
| 	 * @tutorial https://ext.dcloud.net.cn/plugin?id=xxx | ||||
| 	 * @property {String} mode = [default| list | button | tag] 显示模式 | ||||
| 	 * @value default  	默认横排模式 | ||||
| 	 * @value list		列表模式 | ||||
| 	 * @value button	按钮模式 | ||||
| 	 * @value tag 		标签模式 | ||||
| 	 * @property {Boolean} multiple = [true|false] 是否多选 | ||||
| 	 * @property {Array|String|Number} value 默认值 | ||||
| 	 * @property {Array} localdata 本地数据 ,格式 [{text:'',value:''}] | ||||
| 	 * @property {Number|String} min 最小选择个数 ,multiple为true时生效 | ||||
| 	 * @property {Number|String} max 最大选择个数 ,multiple为true时生效 | ||||
| 	 * @property {Boolean} wrap 是否换行显示 | ||||
| 	 * @property {String} icon = [left|right]  list 列表模式下icon显示位置 | ||||
| 	 * @property {Boolean} selectedColor 选中颜色 | ||||
| 	 * @property {Boolean} emptyText 没有数据时显示的文字 ,本地数据无效 | ||||
| 	 * @property {Boolean} selectedTextColor 选中文本颜色,如不填写则自动显示 | ||||
| 	 * @property {Object} map 字段映射, 默认 map={text:'text',value:'value'} | ||||
| 	 * @value left 左侧显示 | ||||
| 	 * @value right 右侧显示 | ||||
| 	 * @event {Function} change  选中发生变化触发 | ||||
| 	 */ | ||||
| 
 | ||||
| 	export default { | ||||
| 		name: 'uniDataChecklist', | ||||
| 		mixins: [uniCloud.mixinDatacom || {}], | ||||
| 		emits: ['input', 'update:modelValue', 'change'], | ||||
| 		props: { | ||||
| 			mode: { | ||||
| 				type: String, | ||||
| 				default: 'default' | ||||
| 			}, | ||||
| 
 | ||||
| 			multiple: { | ||||
| 				type: Boolean, | ||||
| 				default: false | ||||
| 			}, | ||||
| 			value: { | ||||
| 				type: [Array, String, Number], | ||||
| 				default () { | ||||
| 					return '' | ||||
| 				} | ||||
| 			}, | ||||
| 			// TODO vue3 | ||||
| 			modelValue: { | ||||
| 				type: [Array, String, Number], | ||||
| 				default () { | ||||
| 					return ''; | ||||
| 				} | ||||
| 			}, | ||||
| 			localdata: { | ||||
| 				type: Array, | ||||
| 				default () { | ||||
| 					return [] | ||||
| 				} | ||||
| 			}, | ||||
| 			min: { | ||||
| 				type: [Number, String], | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			max: { | ||||
| 				type: [Number, String], | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			wrap: { | ||||
| 				type: Boolean, | ||||
| 				default: false | ||||
| 			}, | ||||
| 			icon: { | ||||
| 				type: String, | ||||
| 				default: 'left' | ||||
| 			}, | ||||
| 			selectedColor: { | ||||
| 				type: String, | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			selectedTextColor: { | ||||
| 				type: String, | ||||
| 				default: '' | ||||
| 			}, | ||||
| 			emptyText: { | ||||
| 				type: String, | ||||
| 				default: '暂无数据' | ||||
| 			}, | ||||
| 			disabled: { | ||||
| 				type: Boolean, | ||||
| 				default: false | ||||
| 			}, | ||||
| 			map: { | ||||
| 				type: Object, | ||||
| 				default () { | ||||
| 					return { | ||||
| 						text: 'text', | ||||
| 						value: 'value' | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
| 		watch: { | ||||
| 			localdata: { | ||||
| 				handler(newVal) { | ||||
| 					this.range = newVal | ||||
| 					this.dataList = this.getDataList(this.getSelectedValue(newVal)) | ||||
| 				}, | ||||
| 				deep: true | ||||
| 			}, | ||||
| 			mixinDatacomResData(newVal) { | ||||
| 				this.range = newVal | ||||
| 				this.dataList = this.getDataList(this.getSelectedValue(newVal)) | ||||
| 			}, | ||||
| 			value(newVal) { | ||||
| 				this.dataList = this.getDataList(newVal) | ||||
| 				// fix by mehaotian is_reset 在 uni-forms 中定义 | ||||
| 				// if(!this.is_reset){ | ||||
| 				// 	this.is_reset = false | ||||
| 				// 	this.formItem && this.formItem.setValue(newVal) | ||||
| 				// } | ||||
| 			}, | ||||
| 			modelValue(newVal) { | ||||
| 				this.dataList = this.getDataList(newVal); | ||||
| 				// if(!this.is_reset){ | ||||
| 				// 	this.is_reset = false | ||||
| 				// 	this.formItem && this.formItem.setValue(newVal) | ||||
| 				// } | ||||
| 			} | ||||
| 		}, | ||||
| 		data() { | ||||
| 			return { | ||||
| 				dataList: [], | ||||
| 				range: [], | ||||
| 				contentText: { | ||||
| 					contentdown: '查看更多', | ||||
| 					contentrefresh: '加载中', | ||||
| 					contentnomore: '没有更多' | ||||
| 				}, | ||||
| 				isLocal: true, | ||||
| 				styles: { | ||||
| 					selectedColor: '#2979ff', | ||||
| 					selectedTextColor: '#666', | ||||
| 				}, | ||||
| 				isTop: 0 | ||||
| 			}; | ||||
| 		}, | ||||
| 		computed: { | ||||
| 			dataValue() { | ||||
| 				if (this.value === '') return this.modelValue | ||||
| 				if (this.modelValue === '') return this.value | ||||
| 				return this.value | ||||
| 			} | ||||
| 		}, | ||||
| 		created() { | ||||
| 			// this.form = this.getForm('uniForms') | ||||
| 			// this.formItem = this.getForm('uniFormsItem') | ||||
| 			// this.formItem && this.formItem.setValue(this.value) | ||||
| 
 | ||||
| 			// if (this.formItem) { | ||||
| 			// 	this.isTop = 6 | ||||
| 			// 	if (this.formItem.name) { | ||||
| 			// 		// 如果存在name添加默认值,否则formData 中不存在这个字段不校验 | ||||
| 			// 		if(!this.is_reset){ | ||||
| 			// 			this.is_reset = false | ||||
| 			// 			this.formItem.setValue(this.dataValue) | ||||
| 			// 		} | ||||
| 			// 		this.rename = this.formItem.name | ||||
| 			// 		this.form.inputChildrens.push(this) | ||||
| 			// 	} | ||||
| 			// } | ||||
| 
 | ||||
| 			if (this.localdata && this.localdata.length !== 0) { | ||||
| 				this.isLocal = true | ||||
| 				this.range = this.localdata | ||||
| 				this.dataList = this.getDataList(this.getSelectedValue(this.range)) | ||||
| 			} else { | ||||
| 				if (this.collection) { | ||||
| 					this.isLocal = false | ||||
| 					this.loadData() | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
| 		methods: { | ||||
| 			loadData() { | ||||
| 				this.mixinDatacomGet().then(res => { | ||||
| 					this.mixinDatacomResData = res.result.data | ||||
| 					if (this.mixinDatacomResData.length === 0) { | ||||
| 						this.isLocal = false | ||||
| 						this.mixinDatacomErrorMessage = this.emptyText | ||||
| 					} else { | ||||
| 						this.isLocal = true | ||||
| 					} | ||||
| 				}).catch(err => { | ||||
| 					this.mixinDatacomErrorMessage = err.message | ||||
| 				}) | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 获取父元素实例 | ||||
| 			 */ | ||||
| 			getForm(name = 'uniForms') { | ||||
| 				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; | ||||
| 			}, | ||||
| 			change(e) { | ||||
| 				const values = e.detail.value | ||||
| 
 | ||||
| 				let detail = { | ||||
| 					value: [], | ||||
| 					data: [] | ||||
| 				} | ||||
| 
 | ||||
| 				if (this.multiple) { | ||||
| 					this.range.forEach(item => { | ||||
| 
 | ||||
| 						if (values.includes(item[this.map.value] + '')) { | ||||
| 							detail.value.push(item[this.map.value]) | ||||
| 							detail.data.push(item) | ||||
| 						} | ||||
| 					}) | ||||
| 				} else { | ||||
| 					const range = this.range.find(item => (item[this.map.value] + '') === values) | ||||
| 					if (range) { | ||||
| 						detail = { | ||||
| 							value: range[this.map.value], | ||||
| 							data: range | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 				// this.formItem && this.formItem.setValue(detail.value) | ||||
| 				// TODO 兼容 vue2 | ||||
| 				this.$emit('input', detail.value); | ||||
| 				// // TOTO 兼容 vue3 | ||||
| 				this.$emit('update:modelValue', detail.value); | ||||
| 				this.$emit('change', { | ||||
| 					detail | ||||
| 				}) | ||||
| 				if (this.multiple) { | ||||
| 					// 如果 v-model 没有绑定 ,则走内部逻辑 | ||||
| 					// if (this.value.length === 0) { | ||||
| 					this.dataList = this.getDataList(detail.value, true) | ||||
| 					// } | ||||
| 				} else { | ||||
| 					this.dataList = this.getDataList(detail.value) | ||||
| 				} | ||||
| 			}, | ||||
| 
 | ||||
| 			/** | ||||
| 			 * 获取渲染的新数组 | ||||
| 			 * @param {Object} value 选中内容 | ||||
| 			 */ | ||||
| 			getDataList(value) { | ||||
| 				// 解除引用关系,破坏原引用关系,避免污染源数据 | ||||
| 				let dataList = JSON.parse(JSON.stringify(this.range)) | ||||
| 				let list = [] | ||||
| 				if (this.multiple) { | ||||
| 					if (!Array.isArray(value)) { | ||||
| 						value = [] | ||||
| 					} | ||||
| 				} else { | ||||
| 					if (Array.isArray(value) && value.length) { | ||||
| 						value = value[0] | ||||
| 					} | ||||
| 				} | ||||
| 				dataList.forEach((item, index) => { | ||||
| 					item.disabled = item.disable || item.disabled || false | ||||
| 					if (this.multiple) { | ||||
| 						if (value.length > 0) { | ||||
| 							let have = value.find(val => val === item[this.map.value]) | ||||
| 							item.selected = have !== undefined | ||||
| 						} else { | ||||
| 							item.selected = false | ||||
| 						} | ||||
| 					} else { | ||||
| 						item.selected = value === item[this.map.value] | ||||
| 					} | ||||
| 
 | ||||
| 					list.push(item) | ||||
| 				}) | ||||
| 				return this.setRange(list) | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 处理最大最小值 | ||||
| 			 * @param {Object} list | ||||
| 			 */ | ||||
| 			setRange(list) { | ||||
| 				let selectList = list.filter(item => item.selected) | ||||
| 				let min = Number(this.min) || 0 | ||||
| 				let max = Number(this.max) || '' | ||||
| 				list.forEach((item, index) => { | ||||
| 					if (this.multiple) { | ||||
| 						if (selectList.length <= min) { | ||||
| 							let have = selectList.find(val => val[this.map.value] === item[this.map.value]) | ||||
| 							if (have !== undefined) { | ||||
| 								item.disabled = true | ||||
| 							} | ||||
| 						} | ||||
| 
 | ||||
| 						if (selectList.length >= max && max !== '') { | ||||
| 							let have = selectList.find(val => val[this.map.value] === item[this.map.value]) | ||||
| 							if (have === undefined) { | ||||
| 								item.disabled = true | ||||
| 							} | ||||
| 						} | ||||
| 					} | ||||
| 					this.setStyles(item, index) | ||||
| 					list[index] = item | ||||
| 				}) | ||||
| 				return list | ||||
| 			}, | ||||
| 			/** | ||||
| 			 * 设置 class | ||||
| 			 * @param {Object} item | ||||
| 			 * @param {Object} index | ||||
| 			 */ | ||||
| 			setStyles(item, index) { | ||||
| 				//  设置自定义样式 | ||||
| 				item.styleBackgroud = this.setStyleBackgroud(item) | ||||
| 				item.styleIcon = this.setStyleIcon(item) | ||||
| 				item.styleIconText = this.setStyleIconText(item) | ||||
| 				item.styleRightIcon = this.setStyleRightIcon(item) | ||||
| 			}, | ||||
| 
 | ||||
| 			/** | ||||
| 			 * 获取选中值 | ||||
| 			 * @param {Object} range | ||||
| 			 */ | ||||
| 			getSelectedValue(range) { | ||||
| 				if (!this.multiple) return this.dataValue | ||||
| 				let selectedArr = [] | ||||
| 				range.forEach((item) => { | ||||
| 					if (item.selected) { | ||||
| 						selectedArr.push(item[this.map.value]) | ||||
| 					} | ||||
| 				}) | ||||
| 				return this.dataValue.length > 0 ? this.dataValue : selectedArr | ||||
| 			}, | ||||
| 
 | ||||
| 			/** | ||||
| 			 * 设置背景样式 | ||||
| 			 */ | ||||
| 			setStyleBackgroud(item) { | ||||
| 				let styles = {} | ||||
| 				let selectedColor = this.selectedColor ? this.selectedColor : '#2979ff' | ||||
| 				if (this.selectedColor) { | ||||
| 					if (this.mode !== 'list') { | ||||
| 						styles['border-color'] = item.selected ? selectedColor : '#DCDFE6' | ||||
| 					} | ||||
| 					if (this.mode === 'tag') { | ||||
| 						styles['background-color'] = item.selected ? selectedColor : '#f5f5f5' | ||||
| 					} | ||||
| 				} | ||||
| 				let classles = '' | ||||
| 				for (let i in styles) { | ||||
| 					classles += `${i}:${styles[i]};` | ||||
| 				} | ||||
| 				return classles | ||||
| 			}, | ||||
| 			setStyleIcon(item) { | ||||
| 				let styles = {} | ||||
| 				let classles = '' | ||||
| 				if (this.selectedColor) { | ||||
| 					let selectedColor = this.selectedColor ? this.selectedColor : '#2979ff' | ||||
| 					styles['background-color'] = item.selected ? selectedColor : '#fff' | ||||
| 					styles['border-color'] = item.selected ? selectedColor : '#DCDFE6' | ||||
| 
 | ||||
| 					if (!item.selected && item.disabled) { | ||||
| 						styles['background-color'] = '#F2F6FC' | ||||
| 						styles['border-color'] = item.selected ? selectedColor : '#DCDFE6' | ||||
| 					} | ||||
| 				} | ||||
| 				for (let i in styles) { | ||||
| 					classles += `${i}:${styles[i]};` | ||||
| 				} | ||||
| 				return classles | ||||
| 			}, | ||||
| 			setStyleIconText(item) { | ||||
| 				let styles = {} | ||||
| 				let classles = '' | ||||
| 				if (this.selectedColor) { | ||||
| 					let selectedColor = this.selectedColor ? this.selectedColor : '#2979ff' | ||||
| 					if (this.mode === 'tag') { | ||||
| 						styles.color = item.selected ? (this.selectedTextColor ? this.selectedTextColor : '#fff') : '#666' | ||||
| 					} else { | ||||
| 						styles.color = item.selected ? (this.selectedTextColor ? this.selectedTextColor : selectedColor) : '#666' | ||||
| 					} | ||||
| 					if (!item.selected && item.disabled) { | ||||
| 						styles.color = '#999' | ||||
| 					} | ||||
| 				} | ||||
| 				for (let i in styles) { | ||||
| 					classles += `${i}:${styles[i]};` | ||||
| 				} | ||||
| 				return classles | ||||
| 			}, | ||||
| 			setStyleRightIcon(item) { | ||||
| 				let styles = {} | ||||
| 				let classles = '' | ||||
| 				if (this.mode === 'list') { | ||||
| 					styles['border-color'] = item.selected ? this.styles.selectedColor : '#DCDFE6' | ||||
| 				} | ||||
| 				for (let i in styles) { | ||||
| 					classles += `${i}:${styles[i]};` | ||||
| 				} | ||||
| 
 | ||||
| 				return classles | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| </script> | ||||
| 
 | ||||
| <style lang="scss"> | ||||
| 	$uni-primary: #2979ff !default; | ||||
| 	$border-color: #DCDFE6; | ||||
| 	$disable: 0.4; | ||||
| 
 | ||||
| 	@mixin flex { | ||||
| 		/* #ifndef APP-NVUE */ | ||||
| 		display: flex; | ||||
| 		/* #endif */ | ||||
| 	} | ||||
| 
 | ||||
| 	.uni-data-loading { | ||||
| 		@include flex; | ||||
| 		flex-direction: row; | ||||
| 		justify-content: center; | ||||
| 		align-items: center; | ||||
| 		height: 36px; | ||||
| 		padding-left: 10px; | ||||
| 		color: #999; | ||||
| 	} | ||||
| 
 | ||||
| 	.uni-data-checklist { | ||||
| 		position: relative; | ||||
| 		z-index: 0; | ||||
| 		flex: 1; | ||||
| 
 | ||||
| 		// 多选样式 | ||||
| 		.checklist-group { | ||||
| 			@include flex; | ||||
| 			flex-direction: row; | ||||
| 			flex-wrap: wrap; | ||||
| 
 | ||||
| 			&.is-list { | ||||
| 				flex-direction: column; | ||||
| 			} | ||||
| 
 | ||||
| 			.checklist-box { | ||||
| 				@include flex; | ||||
| 				flex-direction: row; | ||||
| 				align-items: center; | ||||
| 				position: relative; | ||||
| 				margin: 5px 0; | ||||
| 				margin-right: 25px; | ||||
| 
 | ||||
| 				.hidden { | ||||
| 					position: absolute; | ||||
| 					opacity: 0; | ||||
| 				} | ||||
| 
 | ||||
| 				// 文字样式 | ||||
| 				.checklist-content { | ||||
| 					@include flex; | ||||
| 					flex: 1; | ||||
| 					flex-direction: row; | ||||
| 					align-items: center; | ||||
| 					justify-content: space-between; | ||||
| 
 | ||||
| 					.checklist-text { | ||||
| 						font-size: 14px; | ||||
| 						color: #666; | ||||
| 						margin-left: 5px; | ||||
| 						line-height: 14px; | ||||
| 					} | ||||
| 
 | ||||
| 					.checkobx__list { | ||||
| 						border-right-width: 1px; | ||||
| 						border-right-color: #007aff; | ||||
| 						border-right-style: solid; | ||||
| 						border-bottom-width: 1px; | ||||
| 						border-bottom-color: #007aff; | ||||
| 						border-bottom-style: solid; | ||||
| 						height: 12px; | ||||
| 						width: 6px; | ||||
| 						left: -5px; | ||||
| 						transform-origin: center; | ||||
| 						transform: rotate(45deg); | ||||
| 						opacity: 0; | ||||
| 					} | ||||
| 				} | ||||
| 
 | ||||
| 				// 多选样式 | ||||
| 				.checkbox__inner { | ||||
| 					/* #ifndef APP-NVUE */ | ||||
| 					flex-shrink: 0; | ||||
| 					box-sizing: border-box; | ||||
| 					/* #endif */ | ||||
| 					position: relative; | ||||
| 					width: 16px; | ||||
| 					height: 16px; | ||||
| 					border: 1px solid $border-color; | ||||
| 					border-radius: 4px; | ||||
| 					background-color: #fff; | ||||
| 					z-index: 1; | ||||
| 
 | ||||
| 					.checkbox__inner-icon { | ||||
| 						position: absolute; | ||||
| 						/* #ifdef APP-NVUE */ | ||||
| 						top: 2px; | ||||
| 						/* #endif */ | ||||
| 						/* #ifndef APP-NVUE */ | ||||
| 						top: 1px; | ||||
| 						/* #endif */ | ||||
| 						left: 5px; | ||||
| 						height: 8px; | ||||
| 						width: 4px; | ||||
| 						border-right-width: 1px; | ||||
| 						border-right-color: #fff; | ||||
| 						border-right-style: solid; | ||||
| 						border-bottom-width: 1px; | ||||
| 						border-bottom-color: #fff; | ||||
| 						border-bottom-style: solid; | ||||
| 						opacity: 0; | ||||
| 						transform-origin: center; | ||||
| 						transform: rotate(40deg); | ||||
| 					} | ||||
| 				} | ||||
| 
 | ||||
| 				// 单选样式 | ||||
| 				.radio__inner { | ||||
| 					@include flex; | ||||
| 					/* #ifndef APP-NVUE */ | ||||
| 					flex-shrink: 0; | ||||
| 					box-sizing: border-box; | ||||
| 					/* #endif */ | ||||
| 					justify-content: center; | ||||
| 					align-items: center; | ||||
| 					position: relative; | ||||
| 					width: 16px; | ||||
| 					height: 16px; | ||||
| 					border: 1px solid $border-color; | ||||
| 					border-radius: 16px; | ||||
| 					background-color: #fff; | ||||
| 					z-index: 1; | ||||
| 
 | ||||
| 					.radio__inner-icon { | ||||
| 						width: 8px; | ||||
| 						height: 8px; | ||||
| 						border-radius: 10px; | ||||
| 						opacity: 0; | ||||
| 					} | ||||
| 				} | ||||
| 
 | ||||
| 				// 默认样式 | ||||
| 				&.is--default { | ||||
| 
 | ||||
| 					// 禁用 | ||||
| 					&.is-disable { | ||||
| 						/* #ifdef H5 */ | ||||
| 						cursor: not-allowed; | ||||
| 
 | ||||
| 						/* #endif */ | ||||
| 						.checkbox__inner { | ||||
| 							background-color: #F2F6FC; | ||||
| 							border-color: $border-color; | ||||
| 							/* #ifdef H5 */ | ||||
| 							cursor: not-allowed; | ||||
| 							/* #endif */ | ||||
| 						} | ||||
| 
 | ||||
| 						.radio__inner { | ||||
| 							background-color: #F2F6FC; | ||||
| 							border-color: $border-color; | ||||
| 						} | ||||
| 
 | ||||
| 						.checklist-text { | ||||
| 							color: #999; | ||||
| 						} | ||||
| 					} | ||||
| 
 | ||||
| 					// 选中 | ||||
| 					&.is-checked { | ||||
| 						.checkbox__inner { | ||||
| 							border-color: $uni-primary; | ||||
| 							background-color: $uni-primary; | ||||
| 
 | ||||
| 							.checkbox__inner-icon { | ||||
| 								opacity: 1; | ||||
| 								transform: rotate(45deg); | ||||
| 							} | ||||
| 						} | ||||
| 
 | ||||
| 						.radio__inner { | ||||
| 							border-color: $uni-primary; | ||||
| 
 | ||||
| 							.radio__inner-icon { | ||||
| 								opacity: 1; | ||||
| 								background-color: $uni-primary; | ||||
| 							} | ||||
| 						} | ||||
| 
 | ||||
| 						.checklist-text { | ||||
| 							color: $uni-primary; | ||||
| 						} | ||||
| 
 | ||||
| 						// 选中禁用 | ||||
| 						&.is-disable { | ||||
| 							.checkbox__inner { | ||||
| 								opacity: $disable; | ||||
| 							} | ||||
| 
 | ||||
| 							.checklist-text { | ||||
| 								opacity: $disable; | ||||
| 							} | ||||
| 
 | ||||
| 							.radio__inner { | ||||
| 								opacity: $disable; | ||||
| 							} | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 
 | ||||
| 				// 按钮样式 | ||||
| 				&.is--button { | ||||
| 					margin-right: 10px; | ||||
| 					padding: 5px 10px; | ||||
| 					border: 1px $border-color solid; | ||||
| 					border-radius: 3px; | ||||
| 					transition: border-color 0.2s; | ||||
| 
 | ||||
| 					// 禁用 | ||||
| 					&.is-disable { | ||||
| 						/* #ifdef H5 */ | ||||
| 						cursor: not-allowed; | ||||
| 						/* #endif */ | ||||
| 						border: 1px #eee solid; | ||||
| 						opacity: $disable; | ||||
| 
 | ||||
| 						.checkbox__inner { | ||||
| 							background-color: #F2F6FC; | ||||
| 							border-color: $border-color; | ||||
| 							/* #ifdef H5 */ | ||||
| 							cursor: not-allowed; | ||||
| 							/* #endif */ | ||||
| 						} | ||||
| 
 | ||||
| 						.radio__inner { | ||||
| 							background-color: #F2F6FC; | ||||
| 							border-color: $border-color; | ||||
| 							/* #ifdef H5 */ | ||||
| 							cursor: not-allowed; | ||||
| 							/* #endif */ | ||||
| 						} | ||||
| 
 | ||||
| 						.checklist-text { | ||||
| 							color: #999; | ||||
| 						} | ||||
| 					} | ||||
| 
 | ||||
| 					&.is-checked { | ||||
| 						border-color: $uni-primary; | ||||
| 
 | ||||
| 						.checkbox__inner { | ||||
| 							border-color: $uni-primary; | ||||
| 							background-color: $uni-primary; | ||||
| 
 | ||||
| 							.checkbox__inner-icon { | ||||
| 								opacity: 1; | ||||
| 								transform: rotate(45deg); | ||||
| 							} | ||||
| 						} | ||||
| 
 | ||||
| 						.radio__inner { | ||||
| 							border-color: $uni-primary; | ||||
| 
 | ||||
| 							.radio__inner-icon { | ||||
| 								opacity: 1; | ||||
| 								background-color: $uni-primary; | ||||
| 							} | ||||
| 						} | ||||
| 
 | ||||
| 						.checklist-text { | ||||
| 							color: $uni-primary; | ||||
| 						} | ||||
| 
 | ||||
| 						// 选中禁用 | ||||
| 						&.is-disable { | ||||
| 							opacity: $disable; | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 
 | ||||
| 				// 标签样式 | ||||
| 				&.is--tag { | ||||
| 					margin-right: 10px; | ||||
| 					padding: 5px 10px; | ||||
| 					border: 1px $border-color solid; | ||||
| 					border-radius: 3px; | ||||
| 					background-color: #f5f5f5; | ||||
| 
 | ||||
| 					.checklist-text { | ||||
| 						margin: 0; | ||||
| 						color: #666; | ||||
| 					} | ||||
| 
 | ||||
| 					// 禁用 | ||||
| 					&.is-disable { | ||||
| 						/* #ifdef H5 */ | ||||
| 						cursor: not-allowed; | ||||
| 						/* #endif */ | ||||
| 						opacity: $disable; | ||||
| 					} | ||||
| 
 | ||||
| 					&.is-checked { | ||||
| 						background-color: $uni-primary; | ||||
| 						border-color: $uni-primary; | ||||
| 
 | ||||
| 						.checklist-text { | ||||
| 							color: #fff; | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 
 | ||||
| 				// 列表样式 | ||||
| 				&.is--list { | ||||
| 					/* #ifndef APP-NVUE */ | ||||
| 					display: flex; | ||||
| 					/* #endif */ | ||||
| 					padding: 10px 15px; | ||||
| 					padding-left: 0; | ||||
| 					margin: 0; | ||||
| 
 | ||||
| 					&.is-list-border { | ||||
| 						border-top: 1px #eee solid; | ||||
| 					} | ||||
| 
 | ||||
| 					// 禁用 | ||||
| 					&.is-disable { | ||||
| 						/* #ifdef H5 */ | ||||
| 						cursor: not-allowed; | ||||
| 
 | ||||
| 						/* #endif */ | ||||
| 						.checkbox__inner { | ||||
| 							background-color: #F2F6FC; | ||||
| 							border-color: $border-color; | ||||
| 							/* #ifdef H5 */ | ||||
| 							cursor: not-allowed; | ||||
| 							/* #endif */ | ||||
| 						} | ||||
| 
 | ||||
| 						.checklist-text { | ||||
| 							color: #999; | ||||
| 						} | ||||
| 					} | ||||
| 
 | ||||
| 					&.is-checked { | ||||
| 						.checkbox__inner { | ||||
| 							border-color: $uni-primary; | ||||
| 							background-color: $uni-primary; | ||||
| 
 | ||||
| 							.checkbox__inner-icon { | ||||
| 								opacity: 1; | ||||
| 								transform: rotate(45deg); | ||||
| 							} | ||||
| 						} | ||||
| 
 | ||||
| 						.radio__inner { | ||||
| 							border-color: $uni-primary; | ||||
| 							.radio__inner-icon { | ||||
| 								opacity: 1; | ||||
| 								background-color: $uni-primary; | ||||
| 							} | ||||
| 						} | ||||
| 
 | ||||
| 						.checklist-text { | ||||
| 							color: $uni-primary; | ||||
| 						} | ||||
| 
 | ||||
| 						.checklist-content { | ||||
| 							.checkobx__list { | ||||
| 								opacity: 1; | ||||
| 								border-color: $uni-primary; | ||||
| 							} | ||||
| 						} | ||||
| 
 | ||||
| 						// 选中禁用 | ||||
| 						&.is-disable { | ||||
| 							.checkbox__inner { | ||||
| 								opacity: $disable; | ||||
| 							} | ||||
| 
 | ||||
| 							.checklist-text { | ||||
| 								opacity: $disable; | ||||
| 							} | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| </style> | ||||
| @ -1,87 +0,0 @@ | ||||
| { | ||||
|   "id": "uni-data-checkbox", | ||||
|   "displayName": "uni-data-checkbox 数据选择器", | ||||
|   "version": "1.0.6", | ||||
|   "description": "通过数据驱动的单选框和复选框", | ||||
|   "keywords": [ | ||||
|     "uni-ui", | ||||
|     "checkbox", | ||||
|     "单选", | ||||
|     "多选", | ||||
|     "单选多选" | ||||
| ], | ||||
|   "repository": "https://github.com/dcloudio/uni-ui", | ||||
|   "engines": { | ||||
|     "HBuilderX": "^3.1.1" | ||||
|   }, | ||||
|   "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-load-more","uni-scss"], | ||||
|     "encrypt": [], | ||||
|     "platforms": { | ||||
|       "cloud": { | ||||
|         "tcb": "y", | ||||
|         "aliyun": "y", | ||||
|         "alipay": "n" | ||||
|       }, | ||||
|       "client": { | ||||
|         "App": { | ||||
|             "app-vue": "y", | ||||
|             "app-nvue": "y", | ||||
|             "app-harmony": "u", | ||||
|             "app-uvue": "u" | ||||
|         }, | ||||
|         "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" | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -1,18 +0,0 @@ | ||||
| 
 | ||||
| 
 | ||||
| ## DataCheckbox 数据驱动的单选复选框 | ||||
| > **组件名:uni-data-checkbox** | ||||
| > 代码块: `uDataCheckbox` | ||||
| 
 | ||||
| 
 | ||||
| 本组件是基于uni-app基础组件checkbox的封装。本组件要解决问题包括: | ||||
| 
 | ||||
| 1. 数据绑定型组件:给本组件绑定一个data,会自动渲染一组候选内容。再以往,开发者需要编写不少代码实现类似功能 | ||||
| 2. 自动的表单校验:组件绑定了data,且符合[uni-forms](https://ext.dcloud.net.cn/plugin?id=2773)组件的表单校验规范,搭配使用会自动实现表单校验 | ||||
| 3. 本组件合并了单选多选 | ||||
| 4. 本组件有若干风格选择,如普通的单选多选框、并列button风格、tag风格。开发者可以快速选择需要的风格。但作为一个封装组件,样式代码虽然不用自己写了,却会牺牲一定的样式自定义性 | ||||
| 
 | ||||
| 在uniCloud开发中,`DB Schema`中配置了enum枚举等类型后,在web控制台的[自动生成表单](https://uniapp.dcloud.io/uniCloud/schema?id=autocode)功能中,会自动生成``uni-data-checkbox``组件并绑定好data | ||||
| 
 | ||||
| ### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-data-checkbox) | ||||
| #### 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839  | ||||
| @ -1,25 +0,0 @@ | ||||
| ## 1.3.6(2024-10-15) | ||||
| - 修复 微信小程序中的getSystemInfo警告 | ||||
| ## 1.3.5(2024-10-12) | ||||
| - 修复 微信小程序中的getSystemInfo警告 | ||||
| ## 1.3.4(2024-10-12) | ||||
| - 修复 微信小程序中的getSystemInfo警告 | ||||
| ## 1.3.3(2022-01-20) | ||||
| - 新增 showText属性 ,是否显示文本 | ||||
| ## 1.3.2(2022-01-19) | ||||
| - 修复 nvue 平台下不显示文本的bug | ||||
| ## 1.3.1(2022-01-19) | ||||
| - 修复 微信小程序平台样式选择器报警告的问题 | ||||
| ## 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-load-more](https://uniapp.dcloud.io/component/uniui/uni-load-more) | ||||
| ## 1.2.1(2021-08-24) | ||||
| - 新增 支持国际化 | ||||
| ## 1.2.0(2021-07-30) | ||||
| - 组件兼容 vue3,如何创建vue3项目,详见 [uni-app 项目支持 vue3 介绍](https://ask.dcloud.net.cn/article/37834) | ||||
| ## 1.1.8(2021-05-12) | ||||
| - 新增 组件示例地址 | ||||
| ## 1.1.7(2021-03-30) | ||||
| - 修复 uni-load-more 在首页使用时,h5 平台报 'uni is not defined' 的 bug | ||||
| ## 1.1.6(2021-02-05) | ||||
| - 调整为uni_modules目录规范 | ||||
| @ -1,5 +0,0 @@ | ||||
| { | ||||
| 	"uni-load-more.contentdown": "Pull up to show more", | ||||
| 	"uni-load-more.contentrefresh": "loading...", | ||||
| 	"uni-load-more.contentnomore": "No more data" | ||||
| } | ||||
| @ -1,8 +0,0 @@ | ||||
| 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 | ||||
| } | ||||
| @ -1,5 +0,0 @@ | ||||
| { | ||||
| 	"uni-load-more.contentdown": "上拉显示更多", | ||||
| 	"uni-load-more.contentrefresh": "正在加载...", | ||||
| 	"uni-load-more.contentnomore": "没有更多数据了" | ||||
| } | ||||
| @ -1,5 +0,0 @@ | ||||
| { | ||||
| 	"uni-load-more.contentdown": "上拉顯示更多", | ||||
| 	"uni-load-more.contentrefresh": "正在加載...", | ||||
| 	"uni-load-more.contentnomore": "沒有更多數據了" | ||||
| } | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,84 +0,0 @@ | ||||
| { | ||||
|   "id": "uni-load-more", | ||||
|   "displayName": "uni-load-more 加载更多", | ||||
|   "version": "1.3.6", | ||||
|   "description": "LoadMore 组件,常用在列表里面,做滚动加载使用。", | ||||
|   "keywords": [ | ||||
|     "uni-ui", | ||||
|     "uniui", | ||||
|     "加载更多", | ||||
|     "load-more" | ||||
| ], | ||||
|   "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"], | ||||
|     "encrypt": [], | ||||
|     "platforms": { | ||||
|       "cloud": { | ||||
|         "tcb": "y", | ||||
|         "aliyun": "y", | ||||
|         "alipay": "n" | ||||
|       }, | ||||
|       "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" | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -1,14 +0,0 @@ | ||||
| 
 | ||||
| 
 | ||||
| ### LoadMore 加载更多 | ||||
| > **组件名:uni-load-more** | ||||
| > 代码块: `uLoadMore` | ||||
| 
 | ||||
| 
 | ||||
| 用于列表中,做滚动加载使用,展示 loading 的各种状态。 | ||||
| 
 | ||||
| 
 | ||||
| ### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-load-more) | ||||
| #### 如使用过程中有任何问题,或者您对uni-ui有一些好的建议,欢迎加入 uni-ui 交流群:871950839  | ||||
| 
 | ||||
| 
 | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user