All files / mobile.startup/watchstar watchstar.js

84.21% Statements 16/19
50% Branches 4/8
50% Functions 1/2
84.21% Lines 16/19

Press n or j to go to the next uncovered block, b, p or k for the previous block.

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 371x                     1x 9x 9x 9x 9x     9x 9x 9x 9x 9x 9x 9x 9x               9x 9x    
const icons = require( '../icons' );
 
/**
 * A clickable watchstar for logged in users.
 * Should not be used for anonymous users.
 *
 * @param {Object} options Configuration options
 * @param {Page} options.page
 * @param {boolean} options.isWatched is the article watched?
 * @return {IconButton}
 */
module.exports = function ( options ) {
	const isWatched = options.isWatched,
		watchstar = __non_webpack_require__( 'mediawiki.page.watch.ajax' ).watchstar,
		action = isWatched ? 'unwatch' : 'watch',
		iconProps = {
			href: mw.Title.newFromText( options.page.title ).getUrl( { action } )
		},
		watchButton = icons.watch( iconProps ),
		watchedButton = icons.watched( iconProps ),
		WATCH_BUTTON_CLASS = watchButton.getClassName(),
		WATCHED_BUTTON_CLASS = watchedButton.getClassName(),
		WATCH_CLASS = watchButton.getIcon().getClassName(),
		WATCHED_CLASS = watchedButton.getIcon().getClassName(),
		activeIcon = isWatched ? watchedButton : watchButton,
		callback = ( $link, watched ) => {
			$link.attr( 'class', watched ?
				WATCHED_BUTTON_CLASS : WATCH_BUTTON_CLASS );
			const $icon = $link.find( '.mf-icon' );
			$icon.attr( 'class', watched ?
				WATCHED_CLASS : WATCH_CLASS );
		};
 
	watchstar( activeIcon.$el, options.page.title, callback );
	return activeIcon;
};