1
0
forked from SPC/spc-site

Fix rendering for masters

This commit is contained in:
Alexander Nozik 2024-03-03 18:28:58 +03:00
parent be2a9499c6
commit 183f02f26f
3 changed files with 436 additions and 416 deletions

View File

@ -20,7 +20,7 @@
});
// Hack: Enable IE flexbox workarounds.
if (browser.name == 'ie')
if (browser.name === 'ie')
$body.addClass('is-ie');
// Play initial animations on page load.
@ -48,7 +48,7 @@
if ($sidebar.length > 0) {
//adding exclusion for home link
var $sidebar_a = $sidebar.find('a').not('.spc-home');
let $sidebar_a = $sidebar.find('a').not('.spc-home');
$sidebar_a
.addClass('scrolly')
@ -57,7 +57,7 @@
var $this = $(this);
// External link? Bail.
if ($this.attr('href').charAt(0) != '#')
if ($this.attr('href').charAt(0) !== '#')
return;
// Deactivate all links.
@ -71,7 +71,7 @@
})
.each(function () {
var $this = $(this),
let $this = $(this),
id = $this.attr('href'),
$section = $(id);
@ -81,7 +81,7 @@
// Scrollex.
$section.scrollex({
mode: 'middle',
// mode: 'middle',
top: '-20vh',
bottom: '-20vh',
initialize: function () {
@ -96,7 +96,7 @@
$section.removeClass('inactive');
// No locked links? Deactivate all links and activate this section's one.
if ($sidebar_a.filter('.active-locked').length == 0) {
if ($sidebar_a.filter('.active-locked').length === 0) {
$sidebar_a.removeClass('active');
$this.addClass('active');
@ -133,13 +133,13 @@
// Spotlights.
$('.spotlights > section')
.scrollex({
mode: 'middle',
// mode: 'middle',
top: '-10vh',
bottom: '-10vh',
initialize: function () {
// Deactivate section.
// $(this).addClass('inactive');
$(this).addClass('inactive');
},
enter: function () {
@ -151,7 +151,7 @@
})
.each(function () {
var $this = $(this),
let $this = $(this),
$image = $this.find('.image'),
$img = $image.find('img'),
x;
@ -160,7 +160,7 @@
$image.css('background-image', 'url(' + $img.attr('src') + ')');
// Set background position.
if (x = $img.data('position'))
if (x === $img.data('position'))
$image.css('background-position', x);
// Hide <img>.
@ -171,7 +171,7 @@
// Features.
$('.features')
.scrollex({
mode: 'middle',
// mode: 'middle',
top: '-20vh',
bottom: '-20vh',
initialize: function () {
@ -189,3 +189,20 @@
});
})(jQuery);
//From https://www.w3schools.com/howto/howto_js_collapsible.asp
let collapsibles = document.getElementsByClassName("collapsible");
Array.from(collapsibles).forEach(item => {
item.addEventListener("click", function () {
this.classList.toggle("collapsible-expanded");
let target = item.attributes.getNamedItem("data-target").value;
let content = document.getElementById(target);
if (content.style.maxHeight) {
content.style.maxHeight = null;
} else {
content.style.maxHeight = content.scrollHeight + "px";
}
});
})

View File

@ -1,18 +1,18 @@
(function($) {
(function ($) {
/**
* Generate an indented list of links from a nav. Meant for use with panel().
* @return {jQuery} jQuery object.
*/
$.fn.navList = function() {
$.fn.navList = function () {
var $this = $(this);
const $this = $(this);
$a = $this.find('a'),
b = [];
$a.each(function() {
$a.each(function () {
var $this = $(this),
const $this = $(this),
indent = Math.max(0, $this.parents('li').length - 1),
href = $this.attr('href'),
target = $this.attr('target');
@ -20,8 +20,8 @@
b.push(
'<a ' +
'class="link depth-' + indent + '"' +
( (typeof target !== 'undefined' && target != '') ? ' target="' + target + '"' : '') +
( (typeof href !== 'undefined' && href != '') ? ' href="' + href + '"' : '') +
((typeof target !== 'undefined' && target !== '') ? ' target="' + target + '"' : '') +
((typeof href !== 'undefined' && href !== '') ? ' href="' + href + '"' : '') +
'>' +
'<span class="indent-' + indent + '"></span>' +
$this.text() +
@ -39,16 +39,17 @@
* @param {object} userConfig User config.
* @return {jQuery} jQuery object.
*/
$.fn.panel = function(userConfig) {
$.fn.panel = function (userConfig) {
// No elements?
if (this.length == 0)
let $this = $(this);
// No elements?
if (this.length === 0)
return $this;
// Multiple elements?
if (this.length > 1) {
for (var i=0; i < this.length; i++)
for (let i = 0; i < this.length; i++)
$(this[i]).panel(userConfig);
return $this;
@ -56,8 +57,7 @@
}
// Vars.
var $this = $(this),
$body = $('body'),
let $body = $('body'),
$window = $(window),
id = $this.attr('id'),
config;
@ -101,7 +101,7 @@
// Panel.
// Methods.
$this._hide = function(event) {
$this._hide = function (event) {
// Already hidden? Bail.
if (!config.target.hasClass(config.visibleClass))
@ -119,7 +119,7 @@
config.target.removeClass(config.visibleClass);
// Post-hide stuff.
window.setTimeout(function() {
window.setTimeout(function () {
// Reset scroll position.
if (config.resetScroll)
@ -127,7 +127,7 @@
// Reset forms.
if (config.resetForms)
$this.find('form').each(function() {
$this.find('form').each(function () {
this.reset();
});
@ -147,13 +147,13 @@
.css('-webkit-tap-highlight-color', 'rgba(0,0,0,0)');
$this
.on('click', 'a', function(event) {
.on('click', 'a', function (event) {
var $a = $(this),
const $a = $(this),
href = $a.attr('href'),
target = $a.attr('target');
if (!href || href == '#' || href == '' || href == '#' + id)
if (!href || href === '#' || href === '' || href === '#' + id)
return;
// Cancel original event.
@ -164,9 +164,9 @@
$this._hide();
// Redirect to href.
window.setTimeout(function() {
window.setTimeout(function () {
if (target == '_blank')
if (target === '_blank')
window.open(href);
else
window.location.href = href;
@ -178,20 +178,20 @@
}
// Event: Touch stuff.
$this.on('touchstart', function(event) {
$this.on('touchstart', function (event) {
$this.touchPosX = event.originalEvent.touches[0].pageX;
$this.touchPosY = event.originalEvent.touches[0].pageY;
})
$this.on('touchmove', function(event) {
$this.on('touchmove', function (event) {
if ($this.touchPosX === null
|| $this.touchPosY === null)
return;
var diffX = $this.touchPosX - event.originalEvent.touches[0].pageX,
const diffX = $this.touchPosX - event.originalEvent.touches[0].pageX,
diffY = $this.touchPosY - event.originalEvent.touches[0].pageY,
th = $this.outerHeight(),
ts = ($this.get(0).scrollHeight - $this.scrollTop());
@ -199,8 +199,8 @@
// Hide on swipe?
if (config.hideOnSwipe) {
var result = false,
boundary = 20,
let result = false;
const boundary = 20,
delta = 50;
switch (config.side) {
@ -250,12 +250,12 @@
});
// Event: Prevent certain events inside the panel from bubbling.
$this.on('click touchend touchstart touchmove', function(event) {
$this.on('click touchend touchstart touchmove', function (event) {
event.stopPropagation();
});
// Event: Hide panel if a child anchor tag pointing to its ID is clicked.
$this.on('click', 'a[href="#' + id + '"]', function(event) {
$this.on('click', 'a[href="#' + id + '"]', function (event) {
event.preventDefault();
event.stopPropagation();
@ -267,12 +267,12 @@
// Body.
// Event: Hide panel on body click/tap.
$body.on('click touchend', function(event) {
$body.on('click touchend', function (event) {
$this._hide(event);
});
// Event: Toggle.
$body.on('click', 'a[href="#' + id + '"]', function(event) {
$body.on('click', 'a[href="#' + id + '"]', function (event) {
event.preventDefault();
event.stopPropagation();
@ -285,9 +285,9 @@
// Event: Hide on ESC.
if (config.hideOnEscape)
$window.on('keydown', function(event) {
$window.on('keydown', function (event) {
if (event.keyCode == 27)
if (event.keyCode === 27)
$this._hide(event);
});
@ -300,20 +300,20 @@
* Apply "placeholder" attribute polyfill to one or more forms.
* @return {jQuery} jQuery object.
*/
$.fn.placeholder = function() {
$.fn.placeholder = function () {
// Browser natively supports placeholders? Bail.
if (typeof (document.createElement('input')).placeholder != 'undefined')
return $(this);
// No elements?
if (this.length == 0)
if (this.length === 0)
return $this;
// Multiple elements?
if (this.length > 1) {
for (var i=0; i < this.length; i++)
for (let i = 0; i < this.length; i++)
$(this[i]).placeholder();
return $this;
@ -325,38 +325,38 @@
// Text, TextArea.
$this.find('input[type=text],textarea')
.each(function() {
.each(function () {
var i = $(this);
const i = $(this);
if (i.val() == ''
|| i.val() == i.attr('placeholder'))
if (i.val() === ''
|| i.val() === i.attr('placeholder'))
i
.addClass('polyfill-placeholder')
.val(i.attr('placeholder'));
})
.on('blur', function() {
.on('blur', function () {
var i = $(this);
const i = $(this);
if (i.attr('name').match(/-polyfill-field$/))
return;
if (i.val() == '')
if (i.val() === '')
i
.addClass('polyfill-placeholder')
.val(i.attr('placeholder'));
})
.on('focus', function() {
.on('focus', function () {
var i = $(this);
const i = $(this);
if (i.attr('name').match(/-polyfill-field$/))
return;
if (i.val() == i.attr('placeholder'))
if (i.val() === i.attr('placeholder'))
i
.removeClass('polyfill-placeholder')
.val('');
@ -365,10 +365,10 @@
// Password.
$this.find('input[type=password]')
.each(function() {
.each(function () {
var i = $(this);
var x = $(
const i = $(this);
const x = $(
$('<div>')
.append(i.clone())
.remove()
@ -377,28 +377,28 @@
.replace(/type=password/i, 'type=text')
);
if (i.attr('id') != '')
if (i.attr('id') !== '')
x.attr('id', i.attr('id') + '-polyfill-field');
if (i.attr('name') != '')
if (i.attr('name') !== '')
x.attr('name', i.attr('name') + '-polyfill-field');
x.addClass('polyfill-placeholder')
.val(x.attr('placeholder')).insertAfter(i);
if (i.val() == '')
if (i.val() === '')
i.hide();
else
x.hide();
i
.on('blur', function(event) {
.on('blur', function (event) {
event.preventDefault();
var x = i.parent().find('input[name=' + i.attr('name') + '-polyfill-field]');
const x = i.parent().find('input[name=' + i.attr('name') + '-polyfill-field]');
if (i.val() == '') {
if (i.val() === '') {
i.hide();
x.show();
@ -408,11 +408,11 @@
});
x
.on('focus', function(event) {
.on('focus', function (event) {
event.preventDefault();
var i = x.parent().find('input[name=' + x.attr('name').replace('-polyfill-field', '') + ']');
const i = x.parent().find('input[name=' + x.attr('name').replace('-polyfill-field', '') + ']');
x.hide();
@ -421,7 +421,7 @@
.focus();
})
.on('keypress', function(event) {
.on('keypress', function (event) {
event.preventDefault();
x.val('');
@ -432,17 +432,17 @@
// Events.
$this
.on('submit', function() {
.on('submit', function () {
$this.find('input[type=text],input[type=password],textarea')
.each(function(event) {
.each(function (event) {
var i = $(this);
const i = $(this);
if (i.attr('name').match(/-polyfill-field$/))
i.attr('name', '');
if (i.val() == i.attr('placeholder')) {
if (i.val() === i.attr('placeholder')) {
i.removeClass('polyfill-placeholder');
i.val('');
@ -452,7 +452,7 @@
});
})
.on('reset', function(event) {
.on('reset', function (event) {
event.preventDefault();
@ -460,10 +460,10 @@
.val($('option:first').val());
$this.find('input,textarea')
.each(function() {
.each(function () {
var i = $(this),
x;
const i = $(this);
let x;
i.removeClass('polyfill-placeholder');
@ -478,11 +478,10 @@
x = i.parent().find('input[name=' + i.attr('name') + '-polyfill-field]');
if (i.val() == '') {
if (i.val() === '') {
i.hide();
x.show();
}
else {
} else {
i.show();
x.hide();
}
@ -498,7 +497,7 @@
case 'textarea':
i.val(i.attr('defaultValue'));
if (i.val() == '') {
if (i.val() === '') {
i.addClass('polyfill-placeholder');
i.val(i.attr('placeholder'));
}
@ -523,22 +522,23 @@
* @param {jQuery} $elements Elements (or selector) to move.
* @param {bool} condition If true, moves elements to the top. Otherwise, moves elements back to their original locations.
*/
$.prioritize = function($elements, condition) {
$.prioritize = function ($elements, condition) {
var key = '__prioritize';
const key = '__prioritize';
// Expand $elements if it's not already a jQuery object.
if (typeof $elements != 'jQuery')
$elements = $($elements);
// Step through elements.
$elements.each(function() {
$elements.each(function () {
var $e = $(this), $p,
$parent = $e.parent();
const $e = $(this);
let $p;
const $parent = $e.parent();
// No parent? Bail.
if ($parent.length == 0)
if ($parent.length === 0)
return;
// Not moved? Move it.
@ -552,7 +552,7 @@
$p = $e.prev();
// Couldn't find anything? Means this element's already at the top, so bail.
if ($p.length == 0)
if ($p.length === 0)
return;
// Move element to top of parent.

View File

@ -322,7 +322,7 @@ internal val spcMasters = HtmlSite {
MagProgSection(
id = "partners",
title = "Партнеры",
style = "wrapper style3 fullscreen"
style = "wrapper style3 fullscreen fade-up"
) {
fragment(partners)
},
@ -330,14 +330,14 @@ internal val spcMasters = HtmlSite {
MagProgSection(
id = "mentors",
title = "Научные руководители",
style = "wrapper style2 spotlights",
style = "wrapper style2 spotlights fade-up",
) {
fragment(mentors)
},
MagProgSection(
id = "program",
title = "Учебная программа",
style = "wrapper style3 fullscreen"
style = "wrapper style3 fullscreen fade-up"
) {
fragment(programSection)
},
@ -358,7 +358,10 @@ internal val spcMasters = HtmlSite {
li {
a(
classes = "spc-home",
href = "/" //TODO provide a way to navigate out-of-site
href = resolvePageRef(
Name.EMPTY,
site.parent!!
)
) {
i("fa fa-home") {
attributes["aria-hidden"] = "true"