1
Fork 0
mirror of https://github.com/Steffo99/bluelib.git synced 2025-01-03 00:54:20 +00:00

First (?) commit (0.10.4)

This commit is contained in:
Steffo 2020-06-01 00:56:10 +02:00
parent f034bf23ba
commit 8e992a7ac8
Signed by: steffo
GPG key ID: 896A80F55F7C97F0
13 changed files with 1589 additions and 685 deletions

1
.gitignore vendored
View file

@ -2,3 +2,4 @@ node_modules
/*.log
.idea/
size-plugin.json
dist/

1799
package-lock.json generated

File diff suppressed because it is too large Load diff

View file

@ -1,32 +1,38 @@
{
"private": false,
"name": "bluelib",
"version": "0.8.1",
"version": "0.10.3",
"license": "AGPL-3.0-or-later",
"main": "src/index.js",
"source": "src/index.js",
"main": "dist/index.js",
"module": "dist/index.module.js",
"unpkg": "dist/index.umd.js",
"files": ["dist/*"],
"scripts": {
"start": "preact watch",
"build": "preact build --no-prerender --dest docs && git add docs",
"ghpages": "npm run -s build && git add . && cross-env-shell git commit -m \"$npm_package_version\" && git push && cross-env-shell hub release create -m \"$npm_package_version\" \"$npm_package_version\" && cross-env-shell sentry-cli releases set-commits \"$npm_package_version\" --auto && cross-env-shell sentry-cli releases deploys \"$npm_package_version\" new --env production -n \"gh-pages\""
"dist": "microbundle && npm publish"
},
"devDependencies": {
"cross-env": "^7.0.2",
"preact-cli": "^3.0.0-rc.14"
"preact-cli": "^3.0.0-rc.14",
"webpack-cli": "^3.3.11",
"microbundle": "^0.12.1"
},
"dependencies": {
"@fortawesome/fontawesome-svg-core": "^1.2.28",
"@fortawesome/free-brands-svg-icons": "^5.13.0",
"@fortawesome/free-regular-svg-icons": "^5.13.0",
"@fortawesome/free-solid-svg-icons": "^5.13.0",
"@fortawesome/react-fontawesome": "^0.1.9",
"css-loader": "^3.5.3",
"@fortawesome/react-fontawesome": "^0.1.11",
"css-loader": "^3.6.0",
"file-loader": "^5.0.2",
"less": "^3.11.1",
"less": "^3.11.3",
"less-loader": "^5.0.0",
"preact": "^10.4.4",
"preact-render-to-string": "^5.1.8",
"react-syntax-highlighter": "^12.2.1",
"showdown": "^1.9.1",
"style-loader": "^1.2.1"
"style-loader": "^1.2.1",
"webpack": "^4.43.0"
}
}

View file

@ -1,6 +1,3 @@
const DefinePlugin = require("webpack/lib/DefinePlugin");
export default function (config, env, helpers) {
// noinspection JSUnresolvedVariable
config.resolve.alias["react"] = "preact/compat";

View file

@ -1,4 +1,4 @@
@import "../../styles/constants";
@import "../../styles/constants.less";
.timer {
display: grid;
@ -42,6 +42,7 @@
.unknown {
color: @magenta;
border: 2px solid fade(@magenta, 20%);
.count {
color: @magenta;
@ -50,6 +51,7 @@
.expired {
color: @red;
border: 2px solid fade(@red, 20%);
.count {
color: @red;

View file

@ -1,18 +0,0 @@
import style from './Footer.less';
import { Component } from 'preact';
export default function(props) {
return (
<div class={style.footer}>
© {new Date().getFullYear()}
&nbsp;-&nbsp;
<a href={"https://steffo.eu/"}>Stefano Pigozzi</a>
&nbsp;-&nbsp;
<a href="https://creativecommons.org/licenses/by-sa/4.0/">CC BY-SA 4.0</a>
&nbsp;-&nbsp;
<a href="https://github.com/Steffo99/appuntiweb">uni.steffo.eu {process.env.RELEASE}</a>
&nbsp;-&nbsp;
<a href={"https://ko-fi.com/steffo"}>Supportami</a>
</div>
);
}

View file

@ -1,8 +0,0 @@
@import "../../styles/constants.less";
.footer {
margin-top: 8px;
color: @accent;
text-align: center;
font-size: x-small;
}

View file

@ -1,7 +1,7 @@
import Latex from "./Latex";
import Latex, {LatexDisplay} from "./Latex";
export default function (props) {
return (
<Latex inline={false}>{props.children}</Latex>
<Latex inline={false} display={LatexDisplay.BLOCK}>{props.children}</Latex>
);
}

View file

@ -1,7 +1,7 @@
import Latex from "./Latex";
import Latex, {LatexDisplay} from "./Latex";
export default function (props) {
return (
<Latex inline={true}>{props.children}</Latex>
<Latex inline={true} display={LatexDisplay.INLINE}>{props.children}</Latex>
);
}

View file

@ -2,37 +2,60 @@ import style from './Latex.less';
import {useContext} from "preact/hooks";
import LatexRenderColor from "../../contexts/LatexRenderColor";
import LatexDefaultInline from "../../contexts/LatexDefaultInline";
import LatexDefaultDisplay from "../../contexts/LatexDefaultDisplay";
import stripTabs from "../../utils/stripTabs";
export const LatexDisplay = Object.freeze({
INLINE: style.inline,
BLOCK: style.block,
})
export default function(props) {
// black, blue, brown, cyan, darkgray, gray, green, lightgray, lime, magenta, olive, orange, pink, purple, red, teal, violet, white, yellow
let renderColor = useContext(LatexRenderColor);
let defaultInline = useContext(LatexDefaultInline);
let defaultDisplay = useContext(LatexDefaultDisplay);
let is_inline;
let inline;
if(props.inline === undefined) {
is_inline = defaultInline;
inline = defaultInline;
}
else {
is_inline = props.inline;
inline = props.inline;
}
if(is_inline) {
let equation = `\\inline {\\color{${renderColor}} ${props.children} }`;
let display;
if(props.display === undefined) {
if(defaultDisplay === null) {
display = LatexDisplay.INLINE;
}
else {
display = defaultDisplay;
}
}
else {
display = props.display;
}
let contents = stripTabs(props.children);
if(inline) {
let equation = `\\inline {\\color{${renderColor}} ${contents} }`;
return (
<img src={`https://latex.codecogs.com/svg.latex?${equation}`}
alt={props.children}
title={props.children}
class={style.latex + " " + style.inline}
alt={contents}
title={contents}
class={style.latex + " " + display}
/>
);
}
else {
let equation = `{\\color{${renderColor}} ${props.children} }`;
let equation = `{\\color{${renderColor}} ${contents} }`;
return (
<img src={`https://latex.codecogs.com/svg.latex?${equation}`}
alt={props.children}
title={props.children}
class={style.latex + " " + style.block}
alt={contents}
title={contents}
class={style.latex + " " + display}
/>
);
}

View file

@ -0,0 +1,3 @@
import {createContext} from "preact";
export default createContext(null);

View file

@ -1,21 +1,30 @@
import Box from "./components/Elements/Box"
import Box from "./components/Elements/Box";
import {BoxColors} from "./components/Elements/Box";
import Image from "./components/Elements/Image"
import Image from "./components/Elements/Image";
import Panel from "./components/Elements/Panel";
import Section from "./components/Elements/Section";
import TablePanel from "./components/Elements/TablePanel";
import Timer from "./components/Elements/Timer";
import Todo from "./components/Elements/Todo";
import Footer from "./components/Layout/Footer";
import Split from "./components/Layout/Split";
import Code from "./components/Rendering/Code";
import Latex from "./components/Rendering/Latex";
import BLatex from "./components/Rendering/BLatex";
import Code from "./components/Rendering/Code";
import ILatex from "./components/Rendering/ILatex";
import Latex from "./components/Rendering/Latex";
import {LatexDisplay} from "./components/Rendering/Latex";
import Markdown from "./components/Rendering/Markdown";
import PLatex from "./components/Rendering/PLatex";
import LatexDefaultDisplay from "./contexts/LatexDefaultDisplay";
import LatexDefaultInline from "./contexts/LatexDefaultInline";
import LatexRenderColor from "./contexts/LatexRenderColor";
import Markdown from "./components/Rendering/Markdown";
import theme from "./styles/theme.less";
import stripTabs from "./utils/stripTabs";
export {
Box,
@ -26,39 +35,17 @@ export {
TablePanel,
Timer,
Todo,
Footer,
Split,
Code,
Latex,
BLatex,
Code,
ILatex,
Latex,
LatexDisplay,
Markdown,
PLatex,
LatexDefaultDisplay,
LatexDefaultInline,
LatexRenderColor,
Markdown,
};
import {Fragment} from "preact";
// noinspection JSUnusedGlobalSymbols
export default function() {
require("./styles/theme.less");
return (
<Fragment>
<h1>
bluelib
</h1>
<Split>
<Box>
Hi. I'm a box!
</Box>
<Box color={BoxColors.RED}>
Hi. I'm a box, but I'm red!
</Box>
<Box color={BoxColors.LIME}>
Hi. I was here third!
</Box>
</Split>
</Fragment>
)
theme,
stripTabs
}

View file

@ -1,30 +1,31 @@
@import "constants.less";
* {
.bluelib {
* {
box-sizing: border-box;
}
}
body {
body {
background-color: @bg;
color: @fg;
font-family: @sans;
}
}
h1, h2, h3, h4, h5, h6 {
h1, h2, h3, h4, h5, h6 {
margin-top: 4px;
margin-bottom: 4px;
color: @accent;
font-family: @title;
font-weight: normal;
text-align: center;
}
}
// By default h1 are as large as h2
h1 {
// By default h1 are as large as h2
h1 {
font-size: xx-large;
}
}
a {
a {
color: @link;
text-decoration: none;
@ -35,28 +36,28 @@ a {
&:active {
color: @linkactive;
}
}
}
img, iframe {
img, iframe {
max-width: 100%;
max-height: 300px;
border-radius: 4px;
}
}
pre, code {
pre, code {
font-family: @mono;
font-size: 14px;
}
}
blockquote {
blockquote {
color: @fg;
border-left: 3px solid @plusplusplusplus;
background-color: @plus;
padding: 4px 4px 4px 8px;
margin: 8px 0;
}
}
input[type="text"], input[type="password"] {
input[type="text"], input[type="password"] {
color: @fg;
background-color: @bg;
border: 1px solid @plusplus;
@ -70,9 +71,9 @@ input[type="text"], input[type="password"] {
border-style: dotted;
cursor: not-allowed;
}
}
}
button {
button {
color: @fg;
background-color: @bg;
border: 1px solid @plusplus;
@ -98,15 +99,15 @@ button {
border-style: dotted;
cursor: not-allowed;
}
}
}
hr {
hr {
border: 1px solid @plusplusplusplus;
margin-top: 24px;
margin-bottom: 24px;
}
}
table {
table {
border-spacing: 0;
border: 2px solid @plusplus;
background-color: @plus;
@ -123,32 +124,33 @@ table {
background-color: @plusplus;
color: @accent;
}
}
}
li {
li {
margin: 10px 0;
}
}
p:first-child {
p:first-child {
margin-top: 0;
}
}
p:last-child {
p:last-child {
margin-bottom: 0;
}
}
b {
b {
color: @accent;
}
}
abbr {
abbr[title] {
cursor: help;
}
}
aside {
aside {
margin: 4px 0;
padding: 4px;
font-size: smaller;
background-color: @plus;
border-radius: 4px;
}
}