<template> <div class="app-auth-org-picker"> <app-orgsector v-if="containerType === 'APPINDEXVIEW' || Object.is(sourceMode, selectMode)" dropdownClass="auth-org-picker-dropdown" ></app-orgsector> <div class="app-org-sector-remote" v-else> <dropdown @on-click="orgSelect" @on-visible-change="visibleChange"> <div class="org-sector"> <Input :value="getSelectedOrgName" placeholder="请选择部门" readonly :icon="iconClass" /> </div> <dropdown-menu slot="list"> <dropdown-item :class="{ 'org-sector-choice': Object.is(item.srforgsectorid, getSelectedOrgName) }" :name="item.srforgsectorid" v-for="(item, index) in selectedOrgArray" :key="index" > {{ item.srforgsectorname }} </dropdown-item> <div class="menu-item-no-data" v-show="!selectedOrgArray.length">暂无数据</div> </dropdown-menu> </dropdown> </div> </div> </template> <script lang='ts'> import { Vue, Component, Inject, Prop } from 'vue-property-decorator'; import { LogUtil } from 'ibiz-core'; @Component({}) export default class AppAuthOrgPicker extends Vue { /** * 注入加载行为 * * @memberof AppAuthOrgPicker */ @Inject('reload') reload!: any; /** * 组织数据 * * @type {any} * @memberof AppAuthOrgPicker */ @Prop() public editorInstance!: any; /** * 输入值 * * @type {*} * @memberof AppAuthOrgPicker */ @Prop() public value!: any; /** * 名称 * * @type {string} * @memberof AppAuthOrgPicker */ @Prop() public name!: string; /** * 数据来源模式 * * @type {string} * @memberof AppAuthOrgPicker */ @Prop() public sourceMode?: string; /** * 应用上下文 * * @type {string} * @memberof AppAuthOrgPicker */ @Prop() public context!: any; /** * 容器类型 * * @type {string} * @memberof AppAuthOrgPicker */ @Prop() public containerType?: string; /** * 默认数据来源模式 * * @type {string} * @memberof AppAuthOrgPicker * */ public selectMode: 'REMOTE' | 'LOCAL' = 'LOCAL'; /** * 选中组织部门id * * @type {string} * @memberof AppAuthOrgPicker */ public selectedOrgId: string = ''; /** * 图标名称 * * @type {boolean} * @memberof AppAuthOrgPicker */ public iconClass: string = 'ios-arrow-down'; /** * 选中组织部门名称 * * @type {string} * @memberof AppAuthOrgPicker */ get getSelectedOrgName() { if (this.value) { const selectedValue = this.selectedOrgArray.find((item: any) => { return item.srforgsectorid == this.value; }); return selectedValue?.srforgsectorname; } } /** * 组织部门名称数组 * * @type {Array<any>} * @memberof AppAuthOrgPicker */ public selectedOrgArray: Array<any> = []; /** * 组件初始化数据,vue生命周期 * * @memberof AppAuthOrgPicker */ public created() { //暂时写死的获取远程数据的request this.getOrgData(); } /** * 选择组织部门回调 * * @memberof AppAuthOrgPicker */ public orgSelect(data: string) { if (Object.is(data, this.selectedOrgId)) { return; } let item: any = this.selectedOrgArray.find((_item: any) => Object.is(_item.srforgsectorid, data)); this.$emit('valueChange', { name: this.name, value: item.srforgsectorid }); } /** * 下拉框打开或收起回调 * * @memberof AppAuthOrgPicker */ visibleChange(data: boolean) { this.iconClass = data ? 'ios-arrow-up' : 'ios-arrow-down'; } /** * 获取数据 * * @memberof AppAuthOrgPicker */ public async getOrgData() { LogUtil.warn('获取数据暂未实现'); } } </script> <style lang="less"> @import './app-preset-org-picker.less'; </style>