mirror of
https://github.com/compiler-explorer/compiler-explorer.git
synced 2025-12-27 09:23:52 -05:00
TSfy static/motd
This commit is contained in:
43
static/motd.interfaces.ts
Normal file
43
static/motd.interfaces.ts
Normal file
@@ -0,0 +1,43 @@
|
||||
// Copyright (c) 2022, Compiler Explorer Authors
|
||||
// All rights reserved.
|
||||
//
|
||||
// Redistribution and use in source and binary forms, with or without
|
||||
// modification, are permitted provided that the following conditions are met:
|
||||
//
|
||||
// * Redistributions of source code must retain the above copyright notice,
|
||||
// this list of conditions and the following disclaimer.
|
||||
// * Redistributions in binary form must reproduce the above copyright
|
||||
// notice, this list of conditions and the following disclaimer in the
|
||||
// documentation and/or other materials provided with the distribution.
|
||||
//
|
||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
// POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
import { editor } from 'monaco-editor/';
|
||||
|
||||
interface Decoration {
|
||||
decoration: editor.IModelDecorationOptions;
|
||||
filter: string[];
|
||||
name: string;
|
||||
regex: string;
|
||||
}
|
||||
|
||||
interface Ad {
|
||||
filter?: string;
|
||||
html: string;
|
||||
}
|
||||
|
||||
export interface Motd {
|
||||
ads?: Ad[];
|
||||
motd?: string;
|
||||
decorations?: Decoration[];
|
||||
}
|
||||
@@ -1,4 +1,4 @@
|
||||
// Copyright (c) 2021, Compiler Explorer Authors
|
||||
// Copyright (c) 2022, Compiler Explorer Authors
|
||||
// All rights reserved.
|
||||
//
|
||||
// Redistribution and use in source and binary forms, with or without
|
||||
@@ -22,28 +22,30 @@
|
||||
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
// POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
'use strict';
|
||||
var $ = require('jquery'),
|
||||
_ = require('underscore'),
|
||||
ga = require('analytics').ga;
|
||||
import $ from 'jquery';
|
||||
import {ga} from './analytics';
|
||||
|
||||
function handleMotd(motd, motdNode, subLang, adsEnabled, onHide) {
|
||||
import {Motd} from './motd.interfaces';
|
||||
|
||||
|
||||
function handleMotd(motd: Motd, motdNode: JQuery, subLang: string, adsEnabled: boolean, onHide: () => void) {
|
||||
if (motd.motd) {
|
||||
motdNode.find('.content').html(motd.motd);
|
||||
motdNode.removeClass('d-none');
|
||||
motdNode.find('.close')
|
||||
.on('click', function () {
|
||||
.on('click', () => {
|
||||
motdNode.addClass('d-none');
|
||||
})
|
||||
.prop('title', 'Hide message');
|
||||
} else if (adsEnabled) {
|
||||
var applicableAds = _.filter(motd.ads, function (ad) {
|
||||
const applicableAds = motd.ads?.filter((ad) => {
|
||||
return !subLang || !ad.filter || ad.filter.length === 0 || ad.filter.indexOf(subLang) >= 0;
|
||||
});
|
||||
var randomAd = applicableAds[_.random(applicableAds.length - 1)];
|
||||
if (randomAd) {
|
||||
|
||||
if (applicableAds !== null && applicableAds.length > 0) {
|
||||
const randomAd = applicableAds[Math.floor(Math.random() * applicableAds.length)];
|
||||
motdNode.find('.content').html(randomAd.html);
|
||||
motdNode.find('.close').on('click', function () {
|
||||
motdNode.find('.close').on('click', () => {
|
||||
ga.proxy('send', {
|
||||
hitType: 'event',
|
||||
eventCategory: 'Ads',
|
||||
@@ -53,7 +55,7 @@ function handleMotd(motd, motdNode, subLang, adsEnabled, onHide) {
|
||||
motdNode.addClass('d-none');
|
||||
onHide();
|
||||
});
|
||||
motdNode.find('a').on('click', function () {
|
||||
motdNode.find('a').on('click', function() {
|
||||
ga.proxy('send', {
|
||||
hitType: 'event',
|
||||
eventCategory: 'Ads',
|
||||
@@ -66,20 +68,17 @@ function handleMotd(motd, motdNode, subLang, adsEnabled, onHide) {
|
||||
}
|
||||
}
|
||||
|
||||
function initialise(url, motdNode, defaultLanguage, adsEnabled, onMotd, onHide) {
|
||||
export function initialise(url: string, motdNode: JQuery, defaultLanguage: string, adsEnabled: boolean, onMotd: (res?: Motd) => void, onHide: () => void) {
|
||||
if (!url) return;
|
||||
$.getJSON(url)
|
||||
.then(function (res) {
|
||||
.then((res: Motd) => {
|
||||
console.log(res);
|
||||
onMotd(res);
|
||||
handleMotd(res, motdNode, defaultLanguage, adsEnabled, onHide);
|
||||
})
|
||||
.catch(function () {
|
||||
.catch(() => {
|
||||
// do nothing! we've long tried to find out why this might fail, and it seems page load cancels or ad
|
||||
// blockers might reasonably cause a failure here, and it's no big deal.
|
||||
// Some history at https://github.com/compiler-explorer/compiler-explorer/issues/1057
|
||||
});
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
initialise: initialise,
|
||||
};
|
||||
|
||||
@@ -5,6 +5,6 @@
|
||||
"target": "es5",
|
||||
"rootDirs": ["./static", "./types"],
|
||||
/* Code generation */
|
||||
"inlineSources": true,
|
||||
"inlineSources": true
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user