mirror of
https://github.com/owncast/owncast.git
synced 2024-10-10 19:16:02 +00:00
![dependabot[bot]](/assets/img/avatar_default.png)
* Commit updated Javascript packages * Bump preact from 10.5.4 to 10.5.5 in /build/javascript (#265) * Trying a new github workflow to install javascript packages * Bump tailwindcss from 1.9.2 to 1.9.4 in /build/javascript (#266) Bumps [tailwindcss](https://github.com/tailwindlabs/tailwindcss) from 1.9.2 to 1.9.4. - [Release notes](https://github.com/tailwindlabs/tailwindcss/releases) - [Changelog](https://github.com/tailwindlabs/tailwindcss/blob/master/CHANGELOG.md) - [Commits](https://github.com/tailwindlabs/tailwindcss/compare/v1.9.2...v1.9.4) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Commit updated Javascript packages * Bump preact from 10.5.4 to 10.5.5 in /build/javascript Bumps [preact](https://github.com/preactjs/preact) from 10.5.4 to 10.5.5. - [Release notes](https://github.com/preactjs/preact/releases) - [Commits](https://github.com/preactjs/preact/compare/10.5.4...10.5.5) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Gabe Kangas <gabek@real-ity.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Owncast <owncast@owncast.online> * Bump @justinribeiro/lite-youtube in /build/javascript Bumps [@justinribeiro/lite-youtube](https://github.com/justinribeiro/lite-youtube) from 0.9.0 to 0.9.1. - [Release notes](https://github.com/justinribeiro/lite-youtube/releases) - [Commits](https://github.com/justinribeiro/lite-youtube/commits) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Owncast <owncast@owncast.online> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Gabe Kangas <gabek@real-ity.com>
110 lines
2.8 KiB
JavaScript
110 lines
2.8 KiB
JavaScript
"use strict";
|
|
|
|
var _lodash = _interopRequireDefault(require("lodash"));
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
|
|
/* eslint-disable no-shadow */
|
|
function extractMinWidths(breakpoints) {
|
|
return _lodash.default.flatMap(breakpoints, breakpoints => {
|
|
if (_lodash.default.isString(breakpoints)) {
|
|
breakpoints = {
|
|
min: breakpoints
|
|
};
|
|
}
|
|
|
|
if (!Array.isArray(breakpoints)) {
|
|
breakpoints = [breakpoints];
|
|
}
|
|
|
|
return (0, _lodash.default)(breakpoints).filter(breakpoint => {
|
|
return _lodash.default.has(breakpoint, 'min') || _lodash.default.has(breakpoint, 'min-width');
|
|
}).map(breakpoint => {
|
|
return _lodash.default.get(breakpoint, 'min-width', breakpoint.min);
|
|
}).value();
|
|
});
|
|
}
|
|
|
|
function mapMinWidthsToPadding(minWidths, screens, paddings) {
|
|
if (typeof paddings === 'undefined') {
|
|
return [];
|
|
}
|
|
|
|
if (!_lodash.default.isObject(paddings)) {
|
|
return [{
|
|
screen: 'default',
|
|
minWidth: 0,
|
|
padding: paddings
|
|
}];
|
|
}
|
|
|
|
const mapping = [];
|
|
|
|
if (paddings.default) {
|
|
mapping.push({
|
|
screen: 'default',
|
|
minWidth: 0,
|
|
padding: paddings.default
|
|
});
|
|
}
|
|
|
|
_lodash.default.each(minWidths, minWidth => {
|
|
Object.keys(screens).forEach(screen => {
|
|
const screenMinWidth = _lodash.default.isPlainObject(screens[screen]) ? screens[screen].min || screens[screen]['min-width'] : screens[screen];
|
|
|
|
if (`${screenMinWidth}` === `${minWidth}`) {
|
|
mapping.push({
|
|
screen,
|
|
minWidth,
|
|
padding: paddings[screen]
|
|
});
|
|
}
|
|
});
|
|
});
|
|
|
|
return mapping;
|
|
}
|
|
|
|
module.exports = function () {
|
|
return function ({
|
|
addComponents,
|
|
theme,
|
|
variants
|
|
}) {
|
|
const screens = theme('container.screens', theme('screens'));
|
|
const minWidths = extractMinWidths(screens);
|
|
const paddings = mapMinWidthsToPadding(minWidths, screens, theme('container.padding'));
|
|
|
|
const generatePaddingFor = minWidth => {
|
|
const paddingConfig = _lodash.default.find(paddings, padding => `${padding.minWidth}` === `${minWidth}`);
|
|
|
|
if (!paddingConfig) {
|
|
return {};
|
|
}
|
|
|
|
return {
|
|
paddingRight: paddingConfig.padding,
|
|
paddingLeft: paddingConfig.padding
|
|
};
|
|
};
|
|
|
|
const atRules = (0, _lodash.default)(minWidths).sortBy(minWidth => parseInt(minWidth)).sortedUniq().map(minWidth => {
|
|
return {
|
|
[`@media (min-width: ${minWidth})`]: {
|
|
'.container': {
|
|
'max-width': minWidth,
|
|
...generatePaddingFor(minWidth)
|
|
}
|
|
}
|
|
};
|
|
}).value();
|
|
addComponents([{
|
|
'.container': Object.assign({
|
|
width: '100%'
|
|
}, theme('container.center', false) ? {
|
|
marginRight: 'auto',
|
|
marginLeft: 'auto'
|
|
} : {}, generatePaddingFor(0))
|
|
}, ...atRules], variants('container'));
|
|
};
|
|
}; |