Page Menu
Home
WickedGov Phorge
Search
Configure Global Search
Log In
Files
F2752286
search.js
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Size
2 KB
Referenced Files
None
Subscribers
None
search.js
View Options
module
.
exports
=
function
()
{
const
mobile
=
require
(
'mobile.startup'
);
const
SearchOverlay
=
mobile
.
search
.
SearchOverlay
;
const
SearchGateway
=
mobile
.
search
.
SearchGateway
;
const
overlayManager
=
mobile
.
getOverlayManager
();
// eslint-disable-next-line no-jquery/no-global-selector
const
$searchInput
=
$
(
'#searchInput'
);
const
placeholder
=
$searchInput
.
attr
(
'placeholder'
);
const
defaultSearchPage
=
$searchInput
.
siblings
(
'input[name=title]'
).
val
();
// eslint-disable-next-line no-jquery/no-global-selector
const
$searchBar
=
$
(
'#searchInput, #searchIcon, .skin-minerva-search-trigger'
);
const
searchRoute
=
new
RegExp
(
/\/search/
);
let
searchOverlayInstance
;
// Only continue on mobile devices as it breaks desktop search
// See https://phabricator.wikimedia.org/T108432
if
(
mw
.
config
.
get
(
'skin'
)
!==
'minerva'
)
{
return
;
}
/**
* Hide the search overlay on pageload before the search route
* is registered with the overlayManager.
* Allows the usage of history.back() to close searchOverlay by
* preventing the situation described in https://phabricator.wikimedia.org/T102946
*/
function
removeSearchOnPageLoad
()
{
if
(
searchRoute
.
test
(
overlayManager
.
router
.
getPath
()
)
)
{
// TODO: replace when router supports replaceState https://phabricator.wikimedia.org/T189173
history
.
replaceState
(
''
,
document
.
title
,
window
.
location
.
pathname
);
}
}
function
getSearchOverlay
()
{
if
(
!
searchOverlayInstance
)
{
searchOverlayInstance
=
new
SearchOverlay
(
{
router
:
overlayManager
.
router
,
gatewayClass
:
SearchGateway
,
api
:
new
mw
.
Api
(),
autocapitalize
:
$searchInput
.
attr
(
'autocapitalize'
),
searchTerm
:
$searchInput
.
val
(),
placeholderMsg
:
placeholder
,
defaultSearchPage
:
defaultSearchPage
}
);
}
return
searchOverlayInstance
;
}
removeSearchOnPageLoad
();
overlayManager
.
add
(
searchRoute
,
getSearchOverlay
);
// Apparently needed for main menu to work correctly.
$searchBar
.
prop
(
'readonly'
,
true
);
/**
* Trigger overlay on touchstart so that the on-screen keyboard on iOS
* can be triggered immidiately after on touchend. The keyboard can't be
* triggered unless the element is already visible.
* Touchstart makes the overlay visible, touchend brings up the keyboard afterwards.
*/
$searchBar
.
on
(
'touchstart click'
,
(
ev
)
=>
{
ev
.
preventDefault
();
overlayManager
.
router
.
navigate
(
'/search'
);
}
);
$searchBar
.
on
(
'touchend'
,
(
ev
)
=>
{
ev
.
preventDefault
();
/**
* Manually triggering focus event because on-screen keyboard only
* opens when `focus()` is called from a "user context event",
* Calling it from the route callback above (which calls SearchOverlay#show)
* doesn't work.
* http://stackoverflow.com/questions/6837543/show-virtual-keyboard-on-mobile-phones-in-javascript
*/
getSearchOverlay
().
showKeyboard
();
}
);
};
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Fri, Jul 3, 19:50 (1 d, 8 h)
Storage Engine
local-disk
Storage Format
Raw Data
Storage Handle
4d/fe/47ed629f11344ba8e1afacc891bd
Default Alt Text
search.js (2 KB)
Attached To
Mode
rMWPROD MediaWiki Production
Attached
Detach File
Event Timeline
Log In to Comment