|  |  | @ -0,0 +1,255 @@ | 
			
		
	
		
			
				
					|  |  |  | <template> | 
			
		
	
		
			
				
					|  |  |  | <view class="page"> | 
			
		
	
		
			
				
					|  |  |  | <navbar title="工种选择组件示例" leftClick @leftClick="$utils.navigateBack" /> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <view class="content"> | 
			
		
	
		
			
				
					|  |  |  | <view class="demo-section"> | 
			
		
	
		
			
				
					|  |  |  | <view class="section-title">单选模式</view> | 
			
		
	
		
			
				
					|  |  |  | <view class="demo-item"> | 
			
		
	
		
			
				
					|  |  |  | <uv-cell | 
			
		
	
		
			
				
					|  |  |  | title="选择工种(单选)" | 
			
		
	
		
			
				
					|  |  |  | rightIconStyle="fontSize: 30rpx;" | 
			
		
	
		
			
				
					|  |  |  | :value="singleResult.fullJobType || '请选择工种'" | 
			
		
	
		
			
				
					|  |  |  | @click="openSinglePicker" | 
			
		
	
		
			
				
					|  |  |  | isLink | 
			
		
	
		
			
				
					|  |  |  | ></uv-cell> | 
			
		
	
		
			
				
					|  |  |  | <view v-if="singleResult.selectedId" class="result-info"> | 
			
		
	
		
			
				
					|  |  |  | <text>选中ID: {{ singleResult.selectedId }}</text> | 
			
		
	
		
			
				
					|  |  |  | <text>选中工种: {{ singleResult.selectedJobType?.name }}</text> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <view class="demo-section"> | 
			
		
	
		
			
				
					|  |  |  | <view class="section-title">多选模式</view> | 
			
		
	
		
			
				
					|  |  |  | <view class="demo-item"> | 
			
		
	
		
			
				
					|  |  |  | <uv-cell | 
			
		
	
		
			
				
					|  |  |  | title="选择工种(多选)" | 
			
		
	
		
			
				
					|  |  |  | rightIconStyle="fontSize: 30rpx;" | 
			
		
	
		
			
				
					|  |  |  | :value="multipleResult.fullJobType || '请选择工种'" | 
			
		
	
		
			
				
					|  |  |  | @click="openMultiplePicker" | 
			
		
	
		
			
				
					|  |  |  | isLink | 
			
		
	
		
			
				
					|  |  |  | ></uv-cell> | 
			
		
	
		
			
				
					|  |  |  | <view v-if="multipleResult.selectedIds && multipleResult.selectedIds.length > 0" class="result-info"> | 
			
		
	
		
			
				
					|  |  |  | <text>选中ID数组: {{ multipleResult.selectedIds.join(',') }}</text> | 
			
		
	
		
			
				
					|  |  |  | <text>选中数量: {{ multipleResult.selectedIds.length }}</text> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <view class="demo-section"> | 
			
		
	
		
			
				
					|  |  |  | <view class="section-title">只选择到二级工种</view> | 
			
		
	
		
			
				
					|  |  |  | <view class="demo-item"> | 
			
		
	
		
			
				
					|  |  |  | <uv-cell | 
			
		
	
		
			
				
					|  |  |  | title="选择工种(二级)" | 
			
		
	
		
			
				
					|  |  |  | rightIconStyle="fontSize: 30rpx;" | 
			
		
	
		
			
				
					|  |  |  | :value="subTypeResult.fullJobType || '请选择工种'" | 
			
		
	
		
			
				
					|  |  |  | @click="openSubTypePicker" | 
			
		
	
		
			
				
					|  |  |  | isLink | 
			
		
	
		
			
				
					|  |  |  | ></uv-cell> | 
			
		
	
		
			
				
					|  |  |  | <view v-if="subTypeResult.selectedId" class="result-info"> | 
			
		
	
		
			
				
					|  |  |  | <text>选中ID: {{ subTypeResult.selectedId }}</text> | 
			
		
	
		
			
				
					|  |  |  | <text>选中工种: {{ subTypeResult.selectedJobType?.name }}</text> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <view class="demo-section"> | 
			
		
	
		
			
				
					|  |  |  | <view class="section-title">带"选择整个工种"选项</view> | 
			
		
	
		
			
				
					|  |  |  | <view class="demo-item"> | 
			
		
	
		
			
				
					|  |  |  | <uv-cell | 
			
		
	
		
			
				
					|  |  |  | title="选择工种(整个工种)" | 
			
		
	
		
			
				
					|  |  |  | rightIconStyle="fontSize: 30rpx;" | 
			
		
	
		
			
				
					|  |  |  | :value="wholeTypeResult.fullJobType || '请选择工种'" | 
			
		
	
		
			
				
					|  |  |  | @click="openWholeTypePicker" | 
			
		
	
		
			
				
					|  |  |  | isLink | 
			
		
	
		
			
				
					|  |  |  | ></uv-cell> | 
			
		
	
		
			
				
					|  |  |  | <view v-if="wholeTypeResult.selectedId" class="result-info"> | 
			
		
	
		
			
				
					|  |  |  | <text>选中ID: {{ wholeTypeResult.selectedId }}</text> | 
			
		
	
		
			
				
					|  |  |  | <text>选中工种: {{ wholeTypeResult.selectedJobType?.name }}</text> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <view class="demo-section"> | 
			
		
	
		
			
				
					|  |  |  | <view class="section-title">使用说明</view> | 
			
		
	
		
			
				
					|  |  |  | <view class="usage-info"> | 
			
		
	
		
			
				
					|  |  |  | <text class="usage-title">组件属性:</text> | 
			
		
	
		
			
				
					|  |  |  | <text>• multiple: 是否支持多选</text> | 
			
		
	
		
			
				
					|  |  |  | <text>• onlySubType: 是否只选择到二级工种</text> | 
			
		
	
		
			
				
					|  |  |  | <text>• showSelectWholeType: 是否显示"选择整个工种"选项</text> | 
			
		
	
		
			
				
					|  |  |  | <text class="usage-title">返回数据:</text> | 
			
		
	
		
			
				
					|  |  |  | <text>• selectedId: 单选时的工种ID</text> | 
			
		
	
		
			
				
					|  |  |  | <text>• selectedIds: 多选时的工种ID数组</text> | 
			
		
	
		
			
				
					|  |  |  | <text>• fullJobType: 完整的工种名称文本</text> | 
			
		
	
		
			
				
					|  |  |  | <text>• selectedJobType: 选中的工种对象</text> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <!-- 工种选择组件 --> | 
			
		
	
		
			
				
					|  |  |  | <JobTypePicker | 
			
		
	
		
			
				
					|  |  |  | ref="singlePicker" | 
			
		
	
		
			
				
					|  |  |  | @confirm="onSingleConfirm" | 
			
		
	
		
			
				
					|  |  |  | /> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <JobTypePicker | 
			
		
	
		
			
				
					|  |  |  | ref="multiplePicker" | 
			
		
	
		
			
				
					|  |  |  | :multiple="true" | 
			
		
	
		
			
				
					|  |  |  | @confirm="onMultipleConfirm" | 
			
		
	
		
			
				
					|  |  |  | /> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <JobTypePicker | 
			
		
	
		
			
				
					|  |  |  | ref="subTypePicker" | 
			
		
	
		
			
				
					|  |  |  | :onlySubType="true" | 
			
		
	
		
			
				
					|  |  |  | @confirm="onSubTypeConfirm" | 
			
		
	
		
			
				
					|  |  |  | /> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <JobTypePicker | 
			
		
	
		
			
				
					|  |  |  | ref="wholeTypePicker" | 
			
		
	
		
			
				
					|  |  |  | :showSelectWholeType="true" | 
			
		
	
		
			
				
					|  |  |  | @confirm="onWholeTypeConfirm" | 
			
		
	
		
			
				
					|  |  |  | /> | 
			
		
	
		
			
				
					|  |  |  | </view> | 
			
		
	
		
			
				
					|  |  |  | </template> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <script> | 
			
		
	
		
			
				
					|  |  |  | import JobTypePicker from '@/components/JobTypePicker.vue' | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | export default { | 
			
		
	
		
			
				
					|  |  |  | components: { | 
			
		
	
		
			
				
					|  |  |  | JobTypePicker | 
			
		
	
		
			
				
					|  |  |  | }, | 
			
		
	
		
			
				
					|  |  |  | data() { | 
			
		
	
		
			
				
					|  |  |  | return { | 
			
		
	
		
			
				
					|  |  |  | singleResult: {}, // 单选结果 | 
			
		
	
		
			
				
					|  |  |  | multipleResult: {}, // 多选结果 | 
			
		
	
		
			
				
					|  |  |  | subTypeResult: {}, // 二级工种结果 | 
			
		
	
		
			
				
					|  |  |  | wholeTypeResult: {} // 整个工种结果 | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | }, | 
			
		
	
		
			
				
					|  |  |  | onLoad() { | 
			
		
	
		
			
				
					|  |  |  | // 确保工种数据已加载 | 
			
		
	
		
			
				
					|  |  |  | this.$store.commit('getJobTypeList') | 
			
		
	
		
			
				
					|  |  |  | }, | 
			
		
	
		
			
				
					|  |  |  | methods: { | 
			
		
	
		
			
				
					|  |  |  | // 打开单选工种选择器 | 
			
		
	
		
			
				
					|  |  |  | openSinglePicker() { | 
			
		
	
		
			
				
					|  |  |  | this.$refs.singlePicker.open() | 
			
		
	
		
			
				
					|  |  |  | }, | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | // 打开多选工种选择器 | 
			
		
	
		
			
				
					|  |  |  | openMultiplePicker() { | 
			
		
	
		
			
				
					|  |  |  | this.$refs.multiplePicker.open() | 
			
		
	
		
			
				
					|  |  |  | }, | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | // 打开二级工种选择器 | 
			
		
	
		
			
				
					|  |  |  | openSubTypePicker() { | 
			
		
	
		
			
				
					|  |  |  | this.$refs.subTypePicker.open() | 
			
		
	
		
			
				
					|  |  |  | }, | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | // 打开整个工种选择器 | 
			
		
	
		
			
				
					|  |  |  | openWholeTypePicker() { | 
			
		
	
		
			
				
					|  |  |  | this.$refs.wholeTypePicker.open() | 
			
		
	
		
			
				
					|  |  |  | }, | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | // 单选确认回调 | 
			
		
	
		
			
				
					|  |  |  | onSingleConfirm(result) { | 
			
		
	
		
			
				
					|  |  |  | console.log('单选结果:', result) | 
			
		
	
		
			
				
					|  |  |  | this.singleResult = result | 
			
		
	
		
			
				
					|  |  |  | }, | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | // 多选确认回调 | 
			
		
	
		
			
				
					|  |  |  | onMultipleConfirm(result) { | 
			
		
	
		
			
				
					|  |  |  | console.log('多选结果:', result) | 
			
		
	
		
			
				
					|  |  |  | this.multipleResult = result | 
			
		
	
		
			
				
					|  |  |  | }, | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | // 二级工种确认回调 | 
			
		
	
		
			
				
					|  |  |  | onSubTypeConfirm(result) { | 
			
		
	
		
			
				
					|  |  |  | console.log('二级工种结果:', result) | 
			
		
	
		
			
				
					|  |  |  | this.subTypeResult = result | 
			
		
	
		
			
				
					|  |  |  | }, | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | // 整个工种确认回调 | 
			
		
	
		
			
				
					|  |  |  | onWholeTypeConfirm(result) { | 
			
		
	
		
			
				
					|  |  |  | console.log('整个工种结果:', result) | 
			
		
	
		
			
				
					|  |  |  | this.wholeTypeResult = result | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | </script> | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | <style scoped lang="scss"> | 
			
		
	
		
			
				
					|  |  |  | .page { | 
			
		
	
		
			
				
					|  |  |  | background: #f5f5f5; | 
			
		
	
		
			
				
					|  |  |  | min-height: 100vh; | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | .content { | 
			
		
	
		
			
				
					|  |  |  | padding: 20rpx; | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | .demo-section { | 
			
		
	
		
			
				
					|  |  |  | margin-bottom: 40rpx; | 
			
		
	
		
			
				
					|  |  |  | background: #fff; | 
			
		
	
		
			
				
					|  |  |  | border-radius: 20rpx; | 
			
		
	
		
			
				
					|  |  |  | overflow: hidden; | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | .section-title { | 
			
		
	
		
			
				
					|  |  |  | padding: 30rpx 30rpx 20rpx; | 
			
		
	
		
			
				
					|  |  |  | font-size: 32rpx; | 
			
		
	
		
			
				
					|  |  |  | font-weight: bold; | 
			
		
	
		
			
				
					|  |  |  | color: #333; | 
			
		
	
		
			
				
					|  |  |  | border-bottom: 1px solid #f0f0f0; | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | .demo-item { | 
			
		
	
		
			
				
					|  |  |  | padding: 0; | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | .result-info { | 
			
		
	
		
			
				
					|  |  |  | padding: 20rpx 30rpx; | 
			
		
	
		
			
				
					|  |  |  | background: #f8f9fa; | 
			
		
	
		
			
				
					|  |  |  | border-top: 1px solid #f0f0f0; | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | text { | 
			
		
	
		
			
				
					|  |  |  | display: block; | 
			
		
	
		
			
				
					|  |  |  | font-size: 26rpx; | 
			
		
	
		
			
				
					|  |  |  | color: #666; | 
			
		
	
		
			
				
					|  |  |  | margin-bottom: 10rpx; | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | &:last-child { | 
			
		
	
		
			
				
					|  |  |  | margin-bottom: 0; | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | .usage-info { | 
			
		
	
		
			
				
					|  |  |  | padding: 30rpx; | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | text { | 
			
		
	
		
			
				
					|  |  |  | display: block; | 
			
		
	
		
			
				
					|  |  |  | font-size: 26rpx; | 
			
		
	
		
			
				
					|  |  |  | color: #666; | 
			
		
	
		
			
				
					|  |  |  | line-height: 1.6; | 
			
		
	
		
			
				
					|  |  |  | margin-bottom: 10rpx; | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | &.usage-title { | 
			
		
	
		
			
				
					|  |  |  | font-weight: bold; | 
			
		
	
		
			
				
					|  |  |  | color: #333; | 
			
		
	
		
			
				
					|  |  |  | margin-top: 20rpx; | 
			
		
	
		
			
				
					|  |  |  | margin-bottom: 15rpx; | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | &:first-child { | 
			
		
	
		
			
				
					|  |  |  | margin-top: 0; | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  |  | 
			
		
	
		
			
				
					|  |  |  | &:last-child { | 
			
		
	
		
			
				
					|  |  |  | margin-bottom: 0; | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | </style> |