mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/RelatedArticles
synced 2025-01-11 14:34:29 +00:00
ac97092078
Bug: T345281 Change-Id: I65829811ff0027017d4f91b0dedf7957177f47b5
86 lines
1.8 KiB
JavaScript
86 lines
1.8 KiB
JavaScript
/* eslint-disable no-underscore-dangle */
|
|
'use strict';
|
|
|
|
/**
|
|
* Renders a Card model and updates when it does.
|
|
*
|
|
* @class mw.cards.CardView
|
|
* @param {mw.cards.CardModel} model
|
|
*/
|
|
function CardView( model ) {
|
|
/**
|
|
* @property {mw.cards.CardModel}
|
|
*/
|
|
this.model = model;
|
|
|
|
// listen to model changes and re-render the view
|
|
this.model.on( 'change', this.render.bind( this ) );
|
|
|
|
/**
|
|
* @property {jQuery}
|
|
*/
|
|
this.$el = $( this._render() );
|
|
}
|
|
OO.initClass( CardView );
|
|
|
|
/**
|
|
* Replace the html of this.$el with a newly rendered html using the model
|
|
* attributes.
|
|
*/
|
|
CardView.prototype.render = function () {
|
|
this.$el.replaceWith( this._render() );
|
|
};
|
|
|
|
/**
|
|
* Renders the template using the model attributes.
|
|
*
|
|
* @ignore
|
|
* @return {string}
|
|
*/
|
|
CardView.prototype._render = function () {
|
|
const $listItem = $( '<li>' ),
|
|
attributes = $.extend( {}, this.model.attributes );
|
|
|
|
attributes.thumbnailUrl = CSS.escape( attributes.thumbnailUrl );
|
|
|
|
$listItem.attr( {
|
|
title: attributes.title,
|
|
class: 'ext-related-articles-card'
|
|
} );
|
|
|
|
$listItem.append(
|
|
$( '<div>' )
|
|
.addClass( 'ext-related-articles-card-thumb' )
|
|
.addClass( attributes.hasThumbnail ?
|
|
'mw-no-invert' :
|
|
'ext-related-articles-card-thumb-placeholder'
|
|
)
|
|
.css( 'background-image', attributes.hasThumbnail ?
|
|
'url(' + attributes.thumbnailUrl + ')' :
|
|
null
|
|
),
|
|
$( '<a>' )
|
|
.attr( {
|
|
href: attributes.url,
|
|
'aria-hidden': 'true',
|
|
tabindex: -1
|
|
} ),
|
|
$( '<div>' )
|
|
.attr( { class: 'ext-related-articles-card-detail' } )
|
|
.append(
|
|
$( '<h3>' ).append(
|
|
$( '<a>' )
|
|
.attr( { href: attributes.url } )
|
|
.text( attributes.title )
|
|
),
|
|
$( '<p>' )
|
|
.attr( { class: 'ext-related-articles-card-extract' } )
|
|
.text( attributes.extract )
|
|
)
|
|
);
|
|
|
|
return $listItem;
|
|
};
|
|
|
|
module.exports = CardView;
|