import $ from 'jquery'; import unique from 'mout/array/unique'; import { config, translations } from 'grav-config'; import formatBytes from '../utils/formatbytes'; import { Instance as gpm } from '../utils/gpm'; import Notifications from './notifications'; import Feed from './feed'; import './check'; import './update'; import './channel-switcher'; export default class Updates { constructor(payload = {}) { this.setPayload(payload); this.task = `task${config.param_sep}`; } setPayload(payload = {}) { this.payload = payload; return this; } fetch(force = false) { gpm.fetch((response) => this.setPayload(response), force); return this; } maintenance(mode = 'hide') { let element = $('#updates [data-update-packages]'); element[mode === 'show' ? 'fadeIn' : 'fadeOut'](); if (mode === 'hide') { $('.badges.with-updates').removeClass('with-updates').find('.badge.updates').remove(); } return this; } grav() { let payload = this.payload.grav; if (payload && payload.isUpdatable) { let task = this.task; let bar = ''; if (!payload.isSymlink) { bar += ``; } else { bar += ``; } bar += ` Grav v${payload.available} ${translations.PLUGIN_ADMIN.IS_NOW_AVAILABLE}! (${translations.PLUGIN_ADMIN.CURRENT} v${payload.version}) `; let element = $('[data-gpm-grav]').removeClass('hidden'); if (element.is(':empty')) { element.hide(); } element .addClass('grav') .html(`${bar}`) .slideDown(150) .parent('#messages').addClass('default-box-shadow'); } $('#grav-update-button').on('click', function() { $(this).html(`${translations.PLUGIN_ADMIN.UPDATING_PLEASE_WAIT} ${formatBytes(payload.assets['grav-update'].size)}..`); }); return this; } resources() { if (!this.payload || !this.payload.resources || !this.payload.resources.total) { return this.maintenance('hide'); } let is_current_package_latest = true; let map = ['plugins', 'themes']; let singles = ['plugin', 'theme']; let { plugins, themes } = this.payload.resources; if (!this.payload.resources.total) { return this; } [plugins, themes].forEach(function(resources, index) { if (!resources || Array.isArray(resources)) { return; } let length = Object.keys(resources).length; let type = map[index]; // sidebar $(`#admin-menu a[href$="/${map[index]}"]`) .find('.badges') .addClass('with-updates') .find('.badge.updates').text(length); var type_translation = ''; // update all if (type === 'plugins') { type_translation = translations.PLUGIN_ADMIN.PLUGINS; } else { type_translation = translations.PLUGIN_ADMIN.THEMES; } let updateAll = $(`.grav-update.${type}`); updateAll.css('display', 'block').html(`

${translations.PLUGIN_ADMIN.UPDATE} ${translations.PLUGIN_ADMIN.ALL} ${type_translation} ${length} ${translations.PLUGIN_ADMIN.OF_YOUR} ${type_translation.toLowerCase()} ${translations.PLUGIN_ADMIN.HAVE_AN_UPDATE_AVAILABLE}

`); let existing_slugs = $('[data-update-packages]').attr('data-packages-slugs') || ''; if (existing_slugs) { existing_slugs = existing_slugs.split(','); } else { existing_slugs = []; } let slugs = unique(existing_slugs.concat(Object.keys(resources))).join(); $('[data-update-packages]').attr('data-packages-slugs', `${slugs}`); Object.keys(resources).forEach(function(item) { // listing page let container = $(`[data-gpm-${singles[index]}="${item}"]`); let element = container.find('.gpm-name'); let url = element.find('a'); let content_wrapper = container.parents('.content-wrapper'); if (type === 'plugins' && !element.find('.badge.update').length) { element.append(`${translations.PLUGIN_ADMIN.UPDATE_AVAILABLE}!`); content_wrapper.addClass('has-updates'); } else if (type === 'themes') { element.append(`
${translations.PLUGIN_ADMIN.UPDATE.toUpperCase()}
`); content_wrapper.addClass('has-updates'); } // details page if (container.length) { let details = $(`.grav-update.${singles[index]}`); if (details.length) { let releaseType = resources[item].type === 'testing' ? 'test release' : ''; details.html(`

${translations.PLUGIN_ADMIN.UPDATE} ${singles[index].charAt(0).toUpperCase() + singles[index].substr(1).toLowerCase()} v${resources[item].available} ${releaseType} ${translations.PLUGIN_ADMIN.OF_THIS} ${singles[index]} ${translations.PLUGIN_ADMIN.IS_NOW_AVAILABLE}!

`).css('display', 'block'); is_current_package_latest = false; } } }); $('[data-update-packages]').removeClass('hidden'); }); $('.content-wrapper').addClass('updates-checked'); if (!is_current_package_latest) { $('.warning-reinstall-not-latest-release').removeClass('hidden'); } } } let Instance = new Updates(); export { Instance, Notifications, Feed }; // automatically refresh UI for updates (graph, sidebar, plugin/themes pages) after every fetch gpm.on('fetched', (response, raw) => { Instance.setPayload(response.payload || {}); Instance.grav().resources(); }); if (config.enable_auto_updates_check === '1') { gpm.fetch(); }