Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F99912526
useTab.js
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Mon, Jan 27, 06:15
Size
2 KB
Mime Type
text/x-java
Expires
Wed, Jan 29, 06:15 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
23808671
Attached To
rOACCT Open Access Compliance Check Tool (OACCT)
useTab.js
View Options
import
_extends
from
"@babel/runtime/helpers/esm/extends"
;
import
_objectWithoutPropertiesLoose
from
"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose"
;
const
_excluded
=
[
"getRootProps"
];
import
{
useTabContext
,
getTabId
,
getPanelId
}
from
'../TabsUnstyled'
;
import
{
useButton
}
from
'../ButtonUnstyled'
;
const
useTab
=
parameters
=>
{
var
_getPanelId
,
_getTabId
;
const
{
value
:
valueProp
,
onChange
,
onClick
,
onFocus
}
=
parameters
;
const
_useButton
=
useButton
(
parameters
),
{
getRootProps
:
getRootPropsButton
}
=
_useButton
,
otherButtonProps
=
_objectWithoutPropertiesLoose
(
_useButton
,
_excluded
);
const
context
=
useTabContext
();
if
(
context
===
null
)
{
throw
new
Error
(
'No TabContext provided'
);
}
const
value
=
valueProp
!=
null
?
valueProp
:
0
;
const
selected
=
context
.
value
===
value
;
const
selectionFollowsFocus
=
context
.
selectionFollowsFocus
;
const
a11yAttributes
=
{
role
:
'tab'
,
'aria-controls'
:
(
_getPanelId
=
getPanelId
(
context
,
value
))
!=
null
?
_getPanelId
:
undefined
,
id
:
(
_getTabId
=
getTabId
(
context
,
value
))
!=
null
?
_getTabId
:
undefined
,
'aria-selected'
:
selected
,
disabled
:
otherButtonProps
.
disabled
};
const
createHandleFocus
=
otherHandlers
=>
event
=>
{
var
_otherHandlers$onFocu
;
(
_otherHandlers$onFocu
=
otherHandlers
.
onFocus
)
==
null
?
void
0
:
_otherHandlers$onFocu
.
call
(
otherHandlers
,
event
);
if
(
event
.
defaultPrevented
)
{
return
;
}
if
(
selectionFollowsFocus
&&
!
selected
)
{
if
(
onChange
)
{
onChange
(
event
,
value
);
}
context
.
onSelected
(
event
,
value
);
}
if
(
onFocus
)
{
onFocus
(
event
);
}
};
const
createHandleClick
=
otherHandlers
=>
event
=>
{
var
_otherHandlers$onClic
;
(
_otherHandlers$onClic
=
otherHandlers
.
onClick
)
==
null
?
void
0
:
_otherHandlers$onClic
.
call
(
otherHandlers
,
event
);
if
(
event
.
defaultPrevented
)
{
return
;
}
if
(
!
selected
)
{
if
(
onChange
)
{
onChange
(
event
,
value
);
}
context
.
onSelected
(
event
,
value
);
}
if
(
onClick
)
{
onClick
(
event
);
}
};
const
getRootProps
=
(
otherHandlers
=
{})
=>
{
const
buttonResolvedProps
=
getRootPropsButton
(
_extends
({},
otherHandlers
,
{
onClick
:
createHandleClick
(
otherHandlers
),
onFocus
:
createHandleFocus
(
otherHandlers
)
}));
return
_extends
({},
buttonResolvedProps
,
a11yAttributes
);
};
return
_extends
({
getRootProps
},
otherButtonProps
,
{
selected
});
};
export
default
useTab
;
Event Timeline
Log In to Comment