2019-02-10 20:48:16 +09:00
|
|
|
// app.jsの名はモジュールバンドラーを投入する日まで予約しておく。CSSも同じ。
|
|
|
|
|
|
|
|
(function ($) {
|
|
|
|
|
|
|
|
$.fn.linkCard = function (options) {
|
|
|
|
var settings = $.extend({
|
|
|
|
endpoint: '/api/checkin/card'
|
|
|
|
}, options);
|
|
|
|
|
|
|
|
return this.each(function () {
|
|
|
|
var $this = $(this);
|
|
|
|
$.ajax({
|
|
|
|
url: settings.endpoint,
|
|
|
|
method: 'get',
|
|
|
|
type: 'json',
|
|
|
|
data: {
|
|
|
|
url: $this.find('a').attr('href')
|
|
|
|
}
|
|
|
|
}).then(function (data) {
|
2019-02-28 00:00:23 +09:00
|
|
|
var $metaColumn = $this.find('.col-12:last-of-type');
|
|
|
|
var $imageColumn = $this.find('.col-12:first-of-type');
|
2019-02-10 20:48:16 +09:00
|
|
|
var $title = $this.find('.card-title');
|
|
|
|
var $desc = $this.find('.card-text');
|
2019-02-28 00:00:23 +09:00
|
|
|
var $image = $imageColumn.find('img');
|
2019-02-10 20:48:16 +09:00
|
|
|
|
|
|
|
if (data.title === '') {
|
|
|
|
$title.hide();
|
|
|
|
} else {
|
|
|
|
$title.text(data.title);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (data.description === '') {
|
|
|
|
$desc.hide();
|
|
|
|
} else {
|
|
|
|
$desc.text(data.description);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (data.image === '') {
|
2019-02-28 00:00:23 +09:00
|
|
|
$imageColumn.hide();
|
|
|
|
$metaColumn.removeClass('col-md-6');
|
2019-02-10 20:48:16 +09:00
|
|
|
} else {
|
|
|
|
$image.attr('src', data.image);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (data.title !== '' || data.description !== '' || data.image !== '') {
|
|
|
|
$this.removeClass('d-none');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2019-02-16 23:02:53 +09:00
|
|
|
$.fn.pageSelector = function () {
|
|
|
|
return this.on('change', function () {
|
|
|
|
location.href = $(this).find(':selected').data('href');
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2019-02-10 20:48:16 +09:00
|
|
|
})(jQuery);
|