aboutsummaryrefslogtreecommitdiffstats
path: root/resources/src/mediawiki.special.search.commonsInterwikiWidget.js
blob: c607110dba23c857e2373ca613cb0da20162476e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
( function () {

	function itemTemplate( results ) {

		return results.map( ( result ) => {
			const imageThumbnailSrc = result.thumbnail ? result.thumbnail.source : '';

			return $( '<div>' ).addClass( 'iw-result__mini-gallery' ).append(
				$( '<a>' )
					.addClass( 'iw-result__mini-gallery__image' )
					.attr( {
						style: 'background-image: url(' + imageThumbnailSrc + ')',
						href: new mw.Title( result.title ).getUrl()
					} ).append(
						$( '<span>' ).addClass( 'iw-result__mini-gallery__caption' )
							.text( result.title )
					)
			);
		} );

	}

	function itemWrapperTemplate( pageQuery, itemTemplateOutput ) {

		return $( '<li>' ).addClass( 'iw-resultset iw-resultset--image' ).attr( 'data-iw-resultset-pos', 0 ).append(
			$( '<div>' ).addClass( 'iw-result__header' ).append(
				$( '<strong>' ).text( mw.msg( 'searchprofile-images' ) )
			),
			$( '<div>' ).addClass( 'iw-result__content' ).append(
				itemTemplateOutput
			),
			$( '<div>' ).addClass( 'iw-result__footer' ).append(
				$( '<a>' )
					.attr( 'href', new mw.Title( 'Special:Search' ).getUrl( {
						search: pageQuery,
						fulltext: 1,
						profile: 'images'
					} ) )
					.text( mw.msg( 'search-interwiki-more-results' ) )
			)
		);

	}

	const api = new mw.Api();
	const pageUrl = new URL( location.href );

	api.get( {
		action: 'query',
		generator: 'search',
		gsrsearch: pageUrl.searchParams.get( 'search' ),
		gsrnamespace: mw.config.get( 'wgNamespaceIds' ).file,
		gsrlimit: 3,
		prop: 'pageimages',
		pilimit: 3,
		piprop: 'thumbnail',
		pithumbsize: 300,
		formatversion: 2
	} ).done( ( resp ) => {
		const results = resp.query && resp.query.pages || false;

		if ( !results ) {
			return;
		}

		results.sort( ( a, b ) => a.index - b.index );

		const multimediaWidgetTemplate = itemWrapperTemplate(
			pageUrl.searchParams.get( 'search' ),
			itemTemplate( results )
		);
		/* we really only need to wait for document ready for DOM manipulation */
		$( () => {
			$( '.iw-results' ).append( multimediaWidgetTemplate );
		} );
	} );

}() );