Separate css & js into text variants
Signed-off-by: Nikolaos Karaolidis <nick@karaolidis.com>
This commit is contained in:
3
.gitignore
vendored
3
.gitignore
vendored
@@ -1,3 +1,2 @@
|
|||||||
node_modules/
|
node_modules/
|
||||||
assets/built/
|
**/dist/
|
||||||
dist/
|
|
||||||
|
@@ -29,7 +29,7 @@
|
|||||||
margin-left: 0.8rem;
|
margin-left: 0.8rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (min-width: 768px) and (max-width: 991px) {
|
@media (min-width: 768px) and (max-width: 1321px) {
|
||||||
.gh-author-meta {
|
.gh-author-meta {
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
align-items: center;
|
align-items: center;
|
@@ -27,13 +27,13 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (min-width: 768px) and (max-width: 991px) {
|
@media (min-width: 768px) and (max-width: 1321px) {
|
||||||
.gh-pagehead {
|
.gh-pagehead {
|
||||||
margin-bottom: 8rem;
|
margin-bottom: 8rem;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (max-width: 991px) {
|
@media (max-width: 1321px) {
|
||||||
.gh-pagehead {
|
.gh-pagehead {
|
||||||
position: static;
|
position: static;
|
||||||
grid-column: main-start / main-end;
|
grid-column: main-start / main-end;
|
7
assets/css/common/root.css
Normal file
7
assets/css/common/root.css
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
:root {
|
||||||
|
--font-sans: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif;
|
||||||
|
--font-serif: Lora, Times, serif;
|
||||||
|
--color-primary-text: var(--color-black);
|
||||||
|
--color-darker-gray: var(--color-black);
|
||||||
|
--head-nav-gap: 3.2rem;
|
||||||
|
}
|
@@ -1,23 +0,0 @@
|
|||||||
@import "@tryghost/shared-theme-assets/assets/css/v1/screen.css";
|
|
||||||
|
|
||||||
@import "main/article.css";
|
|
||||||
@import "main/author.css";
|
|
||||||
@import "main/card.css";
|
|
||||||
@import "main/gscan.css";
|
|
||||||
@import "main/head.css";
|
|
||||||
@import "main/navigation.css";
|
|
||||||
@import "main/pagehead.css";
|
|
||||||
@import "main/section.css";
|
|
||||||
@import "main/tag.css";
|
|
||||||
|
|
||||||
@import "lib/prism.css";
|
|
||||||
@import "lib/commento.css";
|
|
||||||
@import "lib/tocbot.css";
|
|
||||||
|
|
||||||
:root {
|
|
||||||
--font-sans: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif;
|
|
||||||
--font-serif: Lora, Times, serif;
|
|
||||||
--color-primary-text: var(--color-black);
|
|
||||||
--color-darker-gray: var(--color-black);
|
|
||||||
--head-nav-gap: 3.2rem;
|
|
||||||
}
|
|
17
assets/css/text/main.css
Normal file
17
assets/css/text/main.css
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
@import "@tryghost/shared-theme-assets/assets/css/v1/screen.css";
|
||||||
|
|
||||||
|
@import "../common/article.css";
|
||||||
|
@import "../common/author.css";
|
||||||
|
@import "../common/gscan.css";
|
||||||
|
@import "../common/head.css";
|
||||||
|
@import "../common/pagehead.css";
|
||||||
|
@import "../common/root.css";
|
||||||
|
@import "../common/section.css";
|
||||||
|
@import "../common/tag.css";
|
||||||
|
|
||||||
|
@import "../lib/prism.css";
|
||||||
|
@import "../lib/commento.css";
|
||||||
|
@import "../lib/tocbot.css";
|
||||||
|
|
||||||
|
@import "card.css";
|
||||||
|
@import "navigation.css";
|
7
assets/js/common/tabs.js
Normal file
7
assets/js/common/tabs.js
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
function tabsInNewPage() {
|
||||||
|
var links = document.getElementsByTagName("article")[0].querySelectorAll('a');
|
||||||
|
var a = new RegExp('/' + window.location.host + '/');
|
||||||
|
links.forEach(link => !a.test(link.href) && link.setAttribute("target", "_blank"));
|
||||||
|
}
|
||||||
|
|
||||||
|
tabsInNewPage();
|
@@ -1,9 +1,3 @@
|
|||||||
function tabsInNewPage() {
|
|
||||||
var links = document.getElementsByTagName("article")[0].querySelectorAll('a');
|
|
||||||
var a = new RegExp('/' + window.location.host + '/');
|
|
||||||
links.forEach(link => !a.test(link.href) && link.setAttribute("target", "_blank"));
|
|
||||||
}
|
|
||||||
|
|
||||||
function tableOfContents() {
|
function tableOfContents() {
|
||||||
var elements = document.getElementsByClassName('kg-toggle-card');
|
var elements = document.getElementsByClassName('kg-toggle-card');
|
||||||
|
|
||||||
@@ -27,6 +21,4 @@ function tableOfContents() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tabsInNewPage();
|
|
||||||
tableOfContents();
|
tableOfContents();
|
||||||
pagination(true);
|
|
1
assets/js/text/main.js
Normal file
1
assets/js/text/main.js
Normal file
@@ -0,0 +1 @@
|
|||||||
|
pagination(true);
|
@@ -7,7 +7,7 @@
|
|||||||
<title>{{meta_title}}</title>
|
<title>{{meta_title}}</title>
|
||||||
|
|
||||||
{{> common/lib/header/fonts}}
|
{{> common/lib/header/fonts}}
|
||||||
<link rel="stylesheet" href="{{asset "built/main.css"}}">
|
<link rel="stylesheet" href="{{asset "dist/text/main.css"}}">
|
||||||
{{> common/lib/header/prism}}
|
{{> common/lib/header/prism}}
|
||||||
|
|
||||||
{{ghost_head}}
|
{{ghost_head}}
|
||||||
@@ -31,7 +31,7 @@
|
|||||||
{{> common/pswp}}
|
{{> common/pswp}}
|
||||||
|
|
||||||
{{> common/lib/footer/tocbot}}
|
{{> common/lib/footer/tocbot}}
|
||||||
<script src="{{asset "built/main.min.js"}}"></script>
|
<script src="{{asset "dist/text/main.min.js"}}"></script>
|
||||||
{{> common/lib/footer/prism}}
|
{{> common/lib/footer/prism}}
|
||||||
|
|
||||||
{{ghost_foot}}
|
{{ghost_foot}}
|
||||||
|
49
gulpfile.js
49
gulpfile.js
@@ -1,6 +1,5 @@
|
|||||||
const { series, parallel, watch, src, dest } = require('gulp');
|
const { series, parallel, watch, src, dest } = require('gulp');
|
||||||
const pump = require('pump');
|
const pump = require('pump');
|
||||||
const fs = require('fs');
|
|
||||||
const order = require('ordered-read-streams');
|
const order = require('ordered-read-streams');
|
||||||
|
|
||||||
const livereload = require('gulp-livereload');
|
const livereload = require('gulp-livereload');
|
||||||
@@ -13,57 +12,52 @@ const easyimport = require('postcss-easy-import');
|
|||||||
const autoprefixer = require('autoprefixer');
|
const autoprefixer = require('autoprefixer');
|
||||||
const cssnano = require('cssnano');
|
const cssnano = require('cssnano');
|
||||||
|
|
||||||
function serve(done) {
|
const serve = (done) => {
|
||||||
livereload.listen();
|
livereload.listen();
|
||||||
done();
|
done();
|
||||||
}
|
}
|
||||||
|
|
||||||
function hbs(done) {
|
const hbs = (done) => {
|
||||||
pump([
|
pump([
|
||||||
src(['*.hbs', 'partials/**/*.hbs']),
|
src(['*.hbs', 'partials/**/*.hbs']),
|
||||||
livereload()
|
livereload()
|
||||||
], done);
|
], done);
|
||||||
}
|
}
|
||||||
|
|
||||||
function css(done) {
|
const css = (variant) => (done) => {
|
||||||
pump([
|
pump([
|
||||||
src('assets/css/main.css', { sourcemaps: true }),
|
src(`assets/css/${variant}/main.css`, { sourcemaps: true }),
|
||||||
postcss([
|
postcss([
|
||||||
easyimport,
|
easyimport,
|
||||||
autoprefixer(),
|
autoprefixer(),
|
||||||
cssnano()
|
cssnano()
|
||||||
]),
|
]),
|
||||||
dest('assets/built/', { sourcemaps: '.' }),
|
dest(`assets/dist/${variant}/`, { sourcemaps: '.' }),
|
||||||
livereload()
|
livereload()
|
||||||
], done);
|
], done);
|
||||||
}
|
}
|
||||||
|
|
||||||
function getJsFiles(version) {
|
const js = (variant) => (done) => {
|
||||||
const jsFiles = [
|
const sources = [
|
||||||
src(`node_modules/@tryghost/shared-theme-assets/assets/js/${version}/lib/**/*.js`),
|
src(`node_modules/@tryghost/shared-theme-assets/assets/js/v1/lib/**/*.js`),
|
||||||
src(`node_modules/@tryghost/shared-theme-assets/assets/js/${version}/main.js`),
|
src(`node_modules/@tryghost/shared-theme-assets/assets/js/v1/main.js`),
|
||||||
|
src(`assets/js/common/*.js`),
|
||||||
|
src(`assets/js/${variant}/main.js`)
|
||||||
];
|
];
|
||||||
|
|
||||||
if (fs.existsSync(`assets/js/lib`)) {
|
|
||||||
jsFiles.push(src(`assets/js/lib/*.js`));
|
|
||||||
}
|
|
||||||
|
|
||||||
jsFiles.push(src(`assets/js/main.js`));
|
|
||||||
|
|
||||||
return jsFiles;
|
|
||||||
}
|
|
||||||
|
|
||||||
function js(done) {
|
|
||||||
pump([
|
pump([
|
||||||
order(getJsFiles('v1'), { sourcemaps: true }),
|
order(sources, { sourcemaps: true }),
|
||||||
concat('main.min.js'),
|
concat(`main.min.js`),
|
||||||
uglify(),
|
uglify(),
|
||||||
dest('assets/built/', { sourcemaps: '.' }),
|
dest(`assets/dist/${variant}/`, { sourcemaps: '.' }),
|
||||||
livereload()
|
livereload()
|
||||||
], done);
|
], done);
|
||||||
}
|
}
|
||||||
|
|
||||||
function zipper(done) {
|
const allCss = parallel(css('text'));
|
||||||
|
const allJs = parallel(js('text'));
|
||||||
|
|
||||||
|
const zipper = (done) => {
|
||||||
const filename = require('./package.json').name + '.zip';
|
const filename = require('./package.json').name + '.zip';
|
||||||
|
|
||||||
pump([
|
pump([
|
||||||
@@ -83,10 +77,11 @@ function zipper(done) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const hbsWatcher = () => watch(['*.hbs', 'partials/**/*.hbs'], hbs);
|
const hbsWatcher = () => watch(['*.hbs', 'partials/**/*.hbs'], hbs);
|
||||||
const cssWatcher = () => watch('assets/css/**/*.css', css);
|
const cssWatcher = () => parallel(watch('assets/css/**/*.css', allCss));
|
||||||
const jsWatcher = () => watch('assets/js/**/*.js', js);
|
const jsWatcher = () => parallel(watch('assets/js/**/*.js', allJs));
|
||||||
|
|
||||||
const watcher = parallel(hbsWatcher, cssWatcher, jsWatcher);
|
const watcher = parallel(hbsWatcher, cssWatcher, jsWatcher);
|
||||||
const build = series(css, js);
|
const build = series(allCss, allJs);
|
||||||
|
|
||||||
exports.build = build;
|
exports.build = build;
|
||||||
exports.zip = series(build, zipper);
|
exports.zip = series(build, zipper);
|
||||||
|
Reference in New Issue
Block a user