2020-10-03 19:07:02 +08:00
|
|
|
<template>
|
|
|
|
<li
|
|
|
|
v-show="visible"
|
2022-02-11 03:58:02 +08:00
|
|
|
:class="[
|
|
|
|
ns.be('dropdown', 'item'),
|
|
|
|
ns.is('disabled', isDisabled),
|
|
|
|
{
|
|
|
|
selected: itemSelected,
|
|
|
|
hover,
|
|
|
|
},
|
|
|
|
]"
|
2020-10-03 19:07:02 +08:00
|
|
|
@mouseenter="hoverItem"
|
|
|
|
@click.stop="selectOptionClick"
|
|
|
|
>
|
|
|
|
<slot>
|
|
|
|
<span>{{ currentLabel }}</span>
|
|
|
|
</slot>
|
|
|
|
</li>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts">
|
2022-06-22 08:04:42 +08:00
|
|
|
// @ts-nocheck
|
2020-10-03 19:07:02 +08:00
|
|
|
import {
|
|
|
|
defineComponent,
|
|
|
|
getCurrentInstance,
|
2022-03-25 15:35:56 +08:00
|
|
|
nextTick,
|
2020-10-03 19:07:02 +08:00
|
|
|
onBeforeUnmount,
|
|
|
|
reactive,
|
2022-03-25 15:35:56 +08:00
|
|
|
toRefs,
|
2020-10-03 19:07:02 +08:00
|
|
|
} from 'vue'
|
2022-02-11 03:58:02 +08:00
|
|
|
import { useNamespace } from '@element-plus/hooks'
|
2020-10-03 19:07:02 +08:00
|
|
|
import { useOption } from './useOption'
|
2021-09-17 15:27:31 +08:00
|
|
|
import type { SelectOptionProxy } from './token'
|
2020-10-03 19:07:02 +08:00
|
|
|
|
|
|
|
export default defineComponent({
|
|
|
|
name: 'ElOption',
|
|
|
|
componentName: 'ElOption',
|
|
|
|
|
|
|
|
props: {
|
|
|
|
value: {
|
|
|
|
required: true,
|
2021-03-09 20:25:21 +08:00
|
|
|
type: [String, Number, Boolean, Object],
|
2020-10-03 19:07:02 +08:00
|
|
|
},
|
|
|
|
label: [String, Number],
|
|
|
|
created: Boolean,
|
|
|
|
disabled: {
|
|
|
|
type: Boolean,
|
|
|
|
default: false,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
2020-10-04 14:49:39 +08:00
|
|
|
setup(props) {
|
2022-02-11 03:58:02 +08:00
|
|
|
const ns = useNamespace('select')
|
2020-10-03 19:07:02 +08:00
|
|
|
const states = reactive({
|
|
|
|
index: -1,
|
|
|
|
groupDisabled: false,
|
|
|
|
visible: true,
|
|
|
|
hitState: false,
|
|
|
|
hover: false,
|
|
|
|
})
|
|
|
|
|
2021-09-04 19:29:28 +08:00
|
|
|
const { currentLabel, itemSelected, isDisabled, select, hoverItem } =
|
|
|
|
useOption(props, states)
|
2020-10-03 19:07:02 +08:00
|
|
|
|
2021-09-04 19:29:28 +08:00
|
|
|
const { visible, hover } = toRefs(states)
|
2020-10-03 19:07:02 +08:00
|
|
|
|
|
|
|
const vm = getCurrentInstance().proxy
|
2021-08-03 09:37:52 +08:00
|
|
|
const key = (vm as unknown as SelectOptionProxy).value
|
2021-02-27 16:21:50 +08:00
|
|
|
select.onOptionCreate(vm as unknown as SelectOptionProxy)
|
2020-10-03 19:07:02 +08:00
|
|
|
|
|
|
|
onBeforeUnmount(() => {
|
2020-11-02 11:05:08 +08:00
|
|
|
const { selected } = select
|
2021-09-04 19:29:28 +08:00
|
|
|
const selectedOptions = select.props.multiple ? selected : [selected]
|
|
|
|
const doesSelected = selectedOptions.some((item) => {
|
2021-01-31 18:47:52 +08:00
|
|
|
return item.value === (vm as unknown as SelectOptionProxy).value
|
|
|
|
})
|
2020-10-03 19:07:02 +08:00
|
|
|
// if option is not selected, remove it from cache
|
2022-07-20 20:47:34 +08:00
|
|
|
nextTick(() => {
|
|
|
|
if (select.cachedOptions.get(key) === vm && !doesSelected) {
|
2022-03-11 14:36:15 +08:00
|
|
|
select.cachedOptions.delete(key)
|
2022-07-20 20:47:34 +08:00
|
|
|
}
|
|
|
|
})
|
2022-03-10 15:50:46 +08:00
|
|
|
select.onOptionDestroy(key, vm)
|
2020-10-03 19:07:02 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
function selectOptionClick() {
|
|
|
|
if (props.disabled !== true && states.groupDisabled !== true) {
|
|
|
|
select.handleOptionSelect(vm, true)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
2022-02-11 03:58:02 +08:00
|
|
|
ns,
|
2020-10-03 19:07:02 +08:00
|
|
|
currentLabel,
|
|
|
|
itemSelected,
|
|
|
|
isDisabled,
|
|
|
|
select,
|
|
|
|
hoverItem,
|
|
|
|
visible,
|
|
|
|
hover,
|
|
|
|
selectOptionClick,
|
2021-11-21 19:14:29 +08:00
|
|
|
states,
|
2020-10-03 19:07:02 +08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
</script>
|