mirror of
https://gitee.com/element-plus/element-plus.git
synced 2024-12-03 11:47:48 +08:00
feat(components): [message-box] add autofocus attribute (#8445)
* feat(components): [message-box] add autofocus attribute * fix: autofocus to be true by default * docs: message-box autofocus default value * chore: remove useless comment * fix: focusStartRef value el
This commit is contained in:
parent
db766ac310
commit
5d88f628bb
@ -55,7 +55,7 @@
|
||||
--content-min-width: 16rem;
|
||||
--content-max-width: 48rem;
|
||||
|
||||
--nav-z-index: 20;
|
||||
--nav-z-index: 10;
|
||||
--sub-nav-z-index: 10;
|
||||
--sidebar-z-index: 40;
|
||||
--overlay-z-index: 30;
|
||||
|
@ -154,6 +154,7 @@ The corresponding methods are: `ElMessageBox`, `ElMessageBox.alert`, `ElMessageB
|
||||
|
||||
| Attribute | Description | Type | Accepted Values | Default |
|
||||
| ---------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------- | ------------------------------------------------ |
|
||||
| autofocus | auto focus when open MessageBox | boolean | — | true |
|
||||
| title | title of the MessageBox | string | — | — |
|
||||
| message | content of the MessageBox | string | — | — |
|
||||
| dangerouslyUseHTMLString | whether `message` is treated as HTML string | boolean | — | false |
|
||||
|
@ -8,6 +8,8 @@ import type { Action } from 'element-plus'
|
||||
|
||||
const open = () => {
|
||||
ElMessageBox.alert('This is a message', 'Title', {
|
||||
// if you want to disable its autofocus
|
||||
// autofocus: false,
|
||||
confirmButtonText: 'OK',
|
||||
callback: (action: Action) => {
|
||||
ElMessage({
|
||||
|
@ -144,6 +144,19 @@ describe('MessageBox', () => {
|
||||
expect(msgbox).toBe(null)
|
||||
})
|
||||
|
||||
test('autofocus', async () => {
|
||||
MessageBox.alert('这是一段内容', {
|
||||
autofocus: false,
|
||||
title: '标题名称',
|
||||
})
|
||||
await rAF()
|
||||
const btnElm = document.querySelector(
|
||||
'.el-message-box__btns .el-button--primary'
|
||||
)
|
||||
const haveFocus = btnElm.isSameNode(document.activeElement)
|
||||
expect(haveFocus).toBe(false)
|
||||
})
|
||||
|
||||
test('prompt', async () => {
|
||||
MessageBox.prompt('这是一段内容', {
|
||||
title: '标题名称',
|
||||
|
@ -259,6 +259,8 @@ export default defineComponent({
|
||||
const { nextZIndex } = useZIndex()
|
||||
// s represents state
|
||||
const state = reactive<MessageBoxState>({
|
||||
// autofocus element when open message-box
|
||||
autofocus: true,
|
||||
beforeClose: null,
|
||||
callback: null,
|
||||
cancelButtonText: '',
|
||||
@ -337,7 +339,11 @@ export default defineComponent({
|
||||
(val) => {
|
||||
if (val) {
|
||||
if (props.boxType !== 'prompt') {
|
||||
focusStartRef.value = confirmRef.value?.$el ?? rootRef.value
|
||||
if (state.autofocus) {
|
||||
focusStartRef.value = confirmRef.value?.$el ?? rootRef.value
|
||||
} else {
|
||||
focusStartRef.value = rootRef.value
|
||||
}
|
||||
}
|
||||
state.zIndex = nextZIndex()
|
||||
}
|
||||
@ -345,7 +351,11 @@ export default defineComponent({
|
||||
if (val) {
|
||||
nextTick().then(() => {
|
||||
if (inputRef.value && inputRef.value.$el) {
|
||||
focusStartRef.value = getInputElement() ?? rootRef.value
|
||||
if (state.autofocus) {
|
||||
focusStartRef.value = getInputElement() ?? rootRef.value
|
||||
} else {
|
||||
focusStartRef.value = rootRef.value
|
||||
}
|
||||
}
|
||||
})
|
||||
} else {
|
||||
|
@ -16,6 +16,7 @@ export interface MessageBoxInputValidator {
|
||||
}
|
||||
|
||||
export declare interface MessageBoxState {
|
||||
autofocus: boolean
|
||||
title: string
|
||||
message: string
|
||||
type: MessageType
|
||||
@ -62,6 +63,11 @@ export type Callback =
|
||||
|
||||
/** Options used in MessageBox */
|
||||
export interface ElMessageBoxOptions {
|
||||
/**
|
||||
* auto focus when open message-box
|
||||
*/
|
||||
autofocus?: boolean
|
||||
|
||||
/** Callback before MessageBox closes, and it will prevent MessageBox from closing */
|
||||
beforeClose?: (
|
||||
action: Action,
|
||||
|
Loading…
Reference in New Issue
Block a user