mirror of
https://github.com/roleypoly/roleypoly.git
synced 2025-06-15 17:19:10 +00:00
fix all linting issues, upgrade most packages
This commit is contained in:
parent
c7774ddca3
commit
3c3af304f7
45 changed files with 1148 additions and 1848 deletions
|
@ -5,4 +5,5 @@ storybook-static
|
||||||
worker
|
worker
|
||||||
**/dist
|
**/dist
|
||||||
terraform
|
terraform
|
||||||
.husky/_
|
.husky/_
|
||||||
|
.mf
|
16
.stylelintrc
16
.stylelintrc
|
@ -1,6 +1,16 @@
|
||||||
{
|
{
|
||||||
"extends": ["stylelint-config-standard", "stylelint-config-styled-components", "stylelint-prettier/recommended"],
|
"customSyntax": "@stylelint/postcss-css-in-js",
|
||||||
|
"extends": [
|
||||||
|
"stylelint-config-recommended",
|
||||||
|
"stylelint-config-styled-components"
|
||||||
|
],
|
||||||
"rules": {
|
"rules": {
|
||||||
"value-keyword-case": null
|
"color-function-notation": "modern",
|
||||||
|
"shorthand-property-no-redundant-values": true,
|
||||||
|
"font-weight-notation": "numeric",
|
||||||
|
"alpha-value-notation": "percentage",
|
||||||
|
"hue-degree-notation": "angle",
|
||||||
|
"function-calc-no-unspaced-operator": true,
|
||||||
|
"length-zero-no-unit": true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
39
package.json
39
package.json
|
@ -18,31 +18,34 @@
|
||||||
],
|
],
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "run-p -c build:*",
|
"build": "run-p -c build:*",
|
||||||
|
"build:api": "yarn workspace @roleypoly/api run build",
|
||||||
"build:design-system": "yarn workspace @roleypoly/design-system run build",
|
"build:design-system": "yarn workspace @roleypoly/design-system run build",
|
||||||
"build:web": "yarn workspace @roleypoly/web run build",
|
"build:web": "yarn workspace @roleypoly/web run build",
|
||||||
"create-component": "yarn workspace @roleypoly/design-system run create-component",
|
"create-component": "yarn workspace @roleypoly/design-system run create-component",
|
||||||
"lint": "run-p -c lint:* --",
|
"lint": "run-p -c lint:* --",
|
||||||
"lint:eslint": "eslint",
|
"lint:eslint": "eslint",
|
||||||
"lint:prettier": "cross-env prettier -c '**/*.{ts,tsx,css,yml,yaml,md,json,js,jsx,sh,gitignore,mdx,Dockerfile}'",
|
"lint:prettier": "cross-env prettier -c '**/*.{ts,tsx,css,yml,yaml,md,json,js,jsx,sh,gitignore,mdx,Dockerfile}'",
|
||||||
"lint:stylelint": "cross-env stylelint '**/*.{ts,tsx}'",
|
"lint:stylelint": "cross-env stylelint 'packages/{web,design-system}/**/*.{ts,tsx}'",
|
||||||
"lint:terraform": "terraform fmt -recursive -check ./terraform",
|
"lint:terraform": "terraform fmt -check -recursive",
|
||||||
"lint:types": "tsc --noEmit",
|
"lint:types": "tsc --noEmit",
|
||||||
"lint:types-api": "yarn workspace @roleypoly/api run lint:types",
|
"lint:types-api": "yarn workspace @roleypoly/api run lint:types",
|
||||||
"lint:types-interactions": "yarn workspace @roleypoly/interactions run lint:types",
|
|
||||||
"lint:types-worker-utils": "yarn workspace @roleypoly/worker-utils run lint:types",
|
|
||||||
"postinstall": "is-ci || husky install",
|
"postinstall": "is-ci || husky install",
|
||||||
"start": "run-p -c start:*",
|
"start": "run-p -c start:*",
|
||||||
"start:bot": "yarn workspace @roleypoly/bot start",
|
"start:bot": "yarn workspace @roleypoly/bot start",
|
||||||
"start:design-system": "yarn workspace @roleypoly/design-system start",
|
"start:design-system": "yarn workspace @roleypoly/design-system start",
|
||||||
"start:interactions": "yarn workspace @roleypoly/interactions start",
|
|
||||||
"start:web": "yarn workspace @roleypoly/web start",
|
"start:web": "yarn workspace @roleypoly/web start",
|
||||||
"start:worker": "yarn workspace @roleypoly/api start",
|
"start:worker": "yarn workspace @roleypoly/api start",
|
||||||
"test": "jest"
|
"test": "run-p -c test:* --",
|
||||||
|
"test:api": "yarn workspace @roleypoly/api run test",
|
||||||
|
"test:design-system": "yarn workspace @roleypoly/design-system run test",
|
||||||
|
"test:misc-utils": "yarn workspace @roleypoly/misc-utils run test",
|
||||||
|
"test:web": "yarn workspace @roleypoly/web run test"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/enzyme": "^3.10.9",
|
"@stylelint/postcss-css-in-js": "^0.37.2",
|
||||||
"@types/lodash": "^4.14.171",
|
"@types/enzyme": "^3.10.11",
|
||||||
"@wojtekmaj/enzyme-adapter-react-17": "^0.6.2",
|
"@types/lodash": "^4.14.178",
|
||||||
|
"@wojtekmaj/enzyme-adapter-react-17": "^0.6.6",
|
||||||
"enzyme": "^3.11.0",
|
"enzyme": "^3.11.0",
|
||||||
"enzyme-adapter-react-16": "^1.15.6",
|
"enzyme-adapter-react-16": "^1.15.6",
|
||||||
"husky": "^7.0.4",
|
"husky": "^7.0.4",
|
||||||
|
@ -51,17 +54,17 @@
|
||||||
"jest-enzyme": "^7.1.2",
|
"jest-enzyme": "^7.1.2",
|
||||||
"jest-react-hooks-shallow": "^1.5.1",
|
"jest-react-hooks-shallow": "^1.5.1",
|
||||||
"jest-styled-components": "^7.0.8",
|
"jest-styled-components": "^7.0.8",
|
||||||
"lint-staged": "^11.0.0",
|
"lint-staged": "^12.3.2",
|
||||||
"npm-run-all": "^4.1.5",
|
"npm-run-all": "^4.1.5",
|
||||||
"prettier": "^2.3.2",
|
"postcss-syntax": "^0.36.2",
|
||||||
"prettier-plugin-organize-imports": "^2.2.0",
|
"prettier": "^2.5.1",
|
||||||
"prettier-plugin-pkg": "^0.10.0",
|
"prettier-plugin-organize-imports": "^2.3.4",
|
||||||
"prettier-plugin-sh": "^0.7.1",
|
"prettier-plugin-pkg": "^0.11.1",
|
||||||
"stylelint": "^13.13.1",
|
"prettier-plugin-sh": "^0.8.1",
|
||||||
"stylelint-config-prettier": "^8.0.2",
|
"stylelint": "^14.3.0",
|
||||||
"stylelint-config-standard": "^22.0.0",
|
"stylelint-config-recommended": "^6.0.0",
|
||||||
"stylelint-config-styled-components": "^0.1.1",
|
"stylelint-config-styled-components": "^0.1.1",
|
||||||
"stylelint-prettier": "^1.2.0",
|
"stylelint-processor-styled-components": "^1.10.0",
|
||||||
"ts-jest": "^27.1.3",
|
"ts-jest": "^27.1.3",
|
||||||
"typescript": "^4.5.5"
|
"typescript": "^4.5.5"
|
||||||
},
|
},
|
||||||
|
|
|
@ -1,15 +1,13 @@
|
||||||
module.exports = {
|
module.exports = {
|
||||||
preset: 'ts-jest/presets/default-esm',
|
preset: 'ts-jest/presets/default-esm',
|
||||||
name: 'api',
|
name: 'api',
|
||||||
rootDir: '../../',
|
|
||||||
testEnvironment: 'miniflare',
|
testEnvironment: 'miniflare',
|
||||||
testEnvironmentOptions: {
|
testEnvironmentOptions: {
|
||||||
wranglerConfigPath: 'packages/api/wrangler.toml',
|
envPath: '../../.env',
|
||||||
envPath: '.env',
|
|
||||||
},
|
},
|
||||||
globals: {
|
globals: {
|
||||||
'ts-jest': {
|
'ts-jest': {
|
||||||
tsconfig: '<rootDir>/packages/api/tsconfig.test.json',
|
tsconfig: '<rootDir>/tsconfig.test.json',
|
||||||
useESM: true,
|
useESM: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -6,18 +6,16 @@
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "yarn build:dev --minify",
|
"build": "yarn build:dev --minify",
|
||||||
"build:dev": "esbuild --bundle --sourcemap --platform=node --format=esm --outdir=dist --out-extension:.js=.mjs ./src/index.ts",
|
"build:dev": "esbuild --bundle --sourcemap --platform=node --format=esm --outdir=dist --out-extension:.js=.mjs ./src/index.ts",
|
||||||
"dev": "miniflare --watch --debug",
|
"lint:types": "tsc --noEmit",
|
||||||
"lint:types": "tsc --noEmit"
|
"start": "miniflare --watch --debug",
|
||||||
|
"test": "jest"
|
||||||
},
|
},
|
||||||
"dependencies": {},
|
"dependencies": {},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@cloudflare/workers-types": "^3.3.1",
|
"@cloudflare/workers-types": "^3.3.1",
|
||||||
"@roleypoly/misc-utils": "*",
|
"@roleypoly/misc-utils": "*",
|
||||||
"@roleypoly/types": "*",
|
"@roleypoly/types": "*",
|
||||||
"@roleypoly/worker-utils": "*",
|
"@types/node": "^17.0.13",
|
||||||
"@types/deep-equal": "^1.0.1",
|
|
||||||
"@types/node": "^13.13.0",
|
|
||||||
"deep-equal": "^2.0.5",
|
|
||||||
"esbuild": "^0.14.14",
|
"esbuild": "^0.14.14",
|
||||||
"itty-router": "^2.4.10",
|
"itty-router": "^2.4.10",
|
||||||
"jest-environment-miniflare": "^2.2.0",
|
"jest-environment-miniflare": "^2.2.0",
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
export {};
|
|
@ -1,5 +0,0 @@
|
||||||
describe('GET /~template', () => {
|
|
||||||
it('returns Not Implemented when called', () => {
|
|
||||||
expect(true).toBe(true);
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,6 +0,0 @@
|
||||||
import { Context, RoleypolyHandler } from '@roleypoly/api/src/utils/context';
|
|
||||||
import { notImplemented } from '@roleypoly/api/src/utils/response';
|
|
||||||
|
|
||||||
export const template: RoleypolyHandler = async (request: Request, context: Context) => {
|
|
||||||
return notImplemented();
|
|
||||||
};
|
|
|
@ -1,102 +0,0 @@
|
||||||
const level = require('level');
|
|
||||||
const path = require('path');
|
|
||||||
const fs = require('fs');
|
|
||||||
|
|
||||||
let hasWarned = false;
|
|
||||||
|
|
||||||
const getConversion = {
|
|
||||||
text: (x) => x,
|
|
||||||
json: (x) => JSON.parse(x),
|
|
||||||
arrayBuffer: (x) => Buffer.from(x).buffer,
|
|
||||||
stream: (x) => Buffer.from(x),
|
|
||||||
};
|
|
||||||
|
|
||||||
class KVShim {
|
|
||||||
constructor(namespace) {
|
|
||||||
this.namespace = namespace;
|
|
||||||
|
|
||||||
fs.mkdirSync(path.resolve(__dirname, '../../.devdbs'), {
|
|
||||||
recursive: true,
|
|
||||||
});
|
|
||||||
|
|
||||||
(async () => {
|
|
||||||
this.level = level(path.resolve(__dirname, '../../.devdbs', namespace));
|
|
||||||
})();
|
|
||||||
}
|
|
||||||
|
|
||||||
makeValue(value, expirationTtl) {
|
|
||||||
if (!expirationTtl) {
|
|
||||||
return JSON.stringify({
|
|
||||||
value,
|
|
||||||
expires: false,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return JSON.stringify({
|
|
||||||
value,
|
|
||||||
expires: Date.now() + 1000 * expirationTtl,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
validate(value) {
|
|
||||||
if (!value) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (value.expires && value.expires < Date.now()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
async get(key, type = 'text') {
|
|
||||||
try {
|
|
||||||
const result = JSON.parse(await this.level.get(key));
|
|
||||||
|
|
||||||
if (!this.validate(result)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return getConversion[type](result.value);
|
|
||||||
} catch (e) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async getWithMetadata(key, type) {
|
|
||||||
return {
|
|
||||||
value: await this.get(key, type),
|
|
||||||
metadata: {},
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
async put(key, value, { expirationTtl, expiration, metadata }) {
|
|
||||||
if ((expiration || metadata) && !hasWarned) {
|
|
||||||
console.warn(
|
|
||||||
'expiration and metadata is lost in the emulator. Use expirationTtl, please.'
|
|
||||||
);
|
|
||||||
hasWarned = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return await this.level.put(key, this.makeValue(value, expirationTtl));
|
|
||||||
}
|
|
||||||
|
|
||||||
// This loses scope for some unknown reason
|
|
||||||
delete = async (key) => {
|
|
||||||
return this.level.del(key);
|
|
||||||
};
|
|
||||||
|
|
||||||
list() {
|
|
||||||
console.warn('List is frowned upon and will fail to fetch keys in the emulator.');
|
|
||||||
return {
|
|
||||||
keys: [],
|
|
||||||
cursor: '0',
|
|
||||||
list_complete: true,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
KVShim,
|
|
||||||
};
|
|
|
@ -1,212 +0,0 @@
|
||||||
#!/usr/bin/env node
|
|
||||||
const path = require('path');
|
|
||||||
require('dotenv').config({ path: path.resolve(__dirname, '../../.env') });
|
|
||||||
const vm = require('vm');
|
|
||||||
const http = require('http');
|
|
||||||
const fs = require('fs');
|
|
||||||
const chokidar = require('chokidar');
|
|
||||||
const webpack = require('webpack');
|
|
||||||
const { Crypto } = require('@peculiar/webcrypto');
|
|
||||||
const { KVShim } = require('./kv');
|
|
||||||
const crypto = new Crypto();
|
|
||||||
const fetch = require('node-fetch');
|
|
||||||
const args = require('minimist')(process.argv.slice(2));
|
|
||||||
|
|
||||||
const basePath = args.basePath || process.cwd();
|
|
||||||
if (!basePath) {
|
|
||||||
throw new Error('--basePath is not set.');
|
|
||||||
}
|
|
||||||
|
|
||||||
const workerConfig = require(`${basePath}/worker.config.js`);
|
|
||||||
|
|
||||||
const getKVs = (namespaces = []) =>
|
|
||||||
namespaces.reduce((acc, ns) => ({ ...acc, [ns]: new KVShim(ns) }), {});
|
|
||||||
|
|
||||||
const workerShims = {
|
|
||||||
...workerConfig.environment,
|
|
||||||
...getKVs(workerConfig.kv),
|
|
||||||
};
|
|
||||||
|
|
||||||
let listeners = [];
|
|
||||||
|
|
||||||
let isResponseConstructorAllowed = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* SafeResponse wraps a fetch Response to yell loudly if constructed at an unsafe time.
|
|
||||||
* Cloudflare will reject all Response objects that aren't created during a request, so no pre-generation is allowed.
|
|
||||||
*/
|
|
||||||
class SafeResponse extends fetch.Response {
|
|
||||||
constructor(...args) {
|
|
||||||
super(...args);
|
|
||||||
|
|
||||||
if (!isResponseConstructorAllowed) {
|
|
||||||
throw new Error(
|
|
||||||
'Response object created outside of request context. This will be rejected by Cloudflare.'
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const context = () =>
|
|
||||||
vm.createContext(
|
|
||||||
{
|
|
||||||
addEventListener: (a, fn) => {
|
|
||||||
if (a === 'fetch') {
|
|
||||||
console.log('addEventListeners: added fetch');
|
|
||||||
listeners.push(fn);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
Response: SafeResponse,
|
|
||||||
URL: URL,
|
|
||||||
crypto: crypto,
|
|
||||||
setTimeout: setTimeout,
|
|
||||||
setInterval: setInterval,
|
|
||||||
clearInterval: clearInterval,
|
|
||||||
clearTimeout: clearTimeout,
|
|
||||||
fetch: fetch,
|
|
||||||
console: console,
|
|
||||||
...workerShims,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
codeGeneration: {
|
|
||||||
strings: false,
|
|
||||||
wasm: false,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
const server = http.createServer((req, res) => {
|
|
||||||
const event = {
|
|
||||||
respondWith: async (value) => {
|
|
||||||
const timeStart = Date.now();
|
|
||||||
let loggedStatus;
|
|
||||||
try {
|
|
||||||
const response = await value;
|
|
||||||
if (!response) {
|
|
||||||
throw new Error(`response was invalid, got ${JSON.stringify(response)}`);
|
|
||||||
}
|
|
||||||
res.statusCode = response.status;
|
|
||||||
loggedStatus = String(response.status);
|
|
||||||
response.headers.forEach((value, key) => res.setHeader(key, value));
|
|
||||||
res.end(response.body);
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e);
|
|
||||||
res.statusCode = 500;
|
|
||||||
loggedStatus = '500';
|
|
||||||
res.end(JSON.stringify({ error: 'internal server error' }));
|
|
||||||
}
|
|
||||||
const timeEnd = Date.now();
|
|
||||||
console.log(
|
|
||||||
`${loggedStatus} [${timeEnd - timeStart}ms] - ${req.method} ${req.url}`
|
|
||||||
);
|
|
||||||
isResponseConstructorAllowed = false;
|
|
||||||
},
|
|
||||||
waitUntil: async (promise) => {
|
|
||||||
await promise;
|
|
||||||
},
|
|
||||||
request: new fetch.Request(
|
|
||||||
new URL(`http://${req.headers.host || 'localhost'}${req.url}`),
|
|
||||||
{
|
|
||||||
body: ['GET', 'HEAD'].includes(req.method) ? undefined : req,
|
|
||||||
headers: req.headers,
|
|
||||||
method: req.method,
|
|
||||||
}
|
|
||||||
),
|
|
||||||
};
|
|
||||||
|
|
||||||
event.request.headers.set('cf-client-ip', req.connection.remoteAddress);
|
|
||||||
|
|
||||||
if (listeners.length === 0) {
|
|
||||||
res.statusCode = 503;
|
|
||||||
res.end('No handlers are available.');
|
|
||||||
console.error('No handlers are available');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
isResponseConstructorAllowed = true;
|
|
||||||
for (let listener of listeners) {
|
|
||||||
try {
|
|
||||||
listener(event);
|
|
||||||
} catch (e) {
|
|
||||||
console.error('listener errored', e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const fork = async (fn) => fn();
|
|
||||||
|
|
||||||
const reload = () => {
|
|
||||||
// Clear listeners...
|
|
||||||
listeners = [];
|
|
||||||
|
|
||||||
// Fork and re-run
|
|
||||||
fork(async () =>
|
|
||||||
vm.runInContext(
|
|
||||||
fs.readFileSync(path.resolve(__dirname, `${basePath}/dist/worker.js`)),
|
|
||||||
context(),
|
|
||||||
{
|
|
||||||
displayErrors: true,
|
|
||||||
filename: 'worker.js',
|
|
||||||
}
|
|
||||||
)
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
const rebuild = () =>
|
|
||||||
new Promise((resolve, reject) => {
|
|
||||||
const webpackConfig = require(`${basePath}/webpack.config.js`);
|
|
||||||
webpackConfig.output.filename = 'worker.js';
|
|
||||||
webpack(webpackConfig).run((err, stats) => {
|
|
||||||
if (err) {
|
|
||||||
console.log('Compilation failed.', err);
|
|
||||||
reject(err);
|
|
||||||
} else {
|
|
||||||
if (stats.hasErrors()) {
|
|
||||||
console.error('Compilation errored:', stats.compilation.errors);
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log('Compilation done.');
|
|
||||||
resolve();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
const watcher = chokidar.watch(path.resolve(__dirname, basePath), {
|
|
||||||
ignoreInitial: true,
|
|
||||||
ignore: '**/dist',
|
|
||||||
});
|
|
||||||
|
|
||||||
let currentlyRebuilding = false;
|
|
||||||
|
|
||||||
watcher.on('all', async (type, path) => {
|
|
||||||
if (path.includes('node_modules') || path.includes('dist')) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (currentlyRebuilding) {
|
|
||||||
console.info('change skipped...', { type, path });
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
currentlyRebuilding = true;
|
|
||||||
|
|
||||||
if (path.includes('dist')) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log('change detected, rebuilding and reloading', { type, path });
|
|
||||||
|
|
||||||
await rebuild();
|
|
||||||
reload();
|
|
||||||
|
|
||||||
currentlyRebuilding = false;
|
|
||||||
});
|
|
||||||
|
|
||||||
fork(async () => {
|
|
||||||
await rebuild();
|
|
||||||
reload();
|
|
||||||
});
|
|
||||||
|
|
||||||
const port = args.port || 6609;
|
|
||||||
console.log(`starting on http://localhost:${port}`);
|
|
||||||
server.listen(port, '0.0.0.0');
|
|
|
@ -1,20 +0,0 @@
|
||||||
{
|
|
||||||
"name": "@roleypoly/worker-emulator",
|
|
||||||
"version": "0.1.0",
|
|
||||||
"bin": {
|
|
||||||
"cfw-emulator": "./main.js"
|
|
||||||
},
|
|
||||||
"scripts": {
|
|
||||||
"build": "node main.js --build",
|
|
||||||
"start": "node main.js"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"@peculiar/webcrypto": "^1.1.7",
|
|
||||||
"chokidar": "^3.5.2",
|
|
||||||
"dotenv": "^10.0.0",
|
|
||||||
"level": "^7.0.0",
|
|
||||||
"minimist": "^1.2.5",
|
|
||||||
"node-fetch": "^2.6.1",
|
|
||||||
"webpack": "4.44.2"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -16,7 +16,7 @@ export const Container = styled.div<ContainerProps>`
|
||||||
color: ${palette.grey100};
|
color: ${palette.grey100};
|
||||||
position: relative;
|
position: relative;
|
||||||
background-color: ${palette.grey500};
|
background-color: ${palette.grey500};
|
||||||
font-weight: bold;
|
font-weight: 700;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
line-height: 1;
|
line-height: 1;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
|
@ -24,7 +24,7 @@ export const Container = styled.div<ContainerProps>`
|
||||||
${(props) =>
|
${(props) =>
|
||||||
props.deliberatelyEmpty &&
|
props.deliberatelyEmpty &&
|
||||||
css`
|
css`
|
||||||
border: 4px solid rgba(0, 0, 0, 0.25);
|
border: 4px solid rgb(0 0 0 / 25%);
|
||||||
background-color: ${palette.taupe400};
|
background-color: ${palette.taupe400};
|
||||||
color: ${palette.taupe600};
|
color: ${palette.taupe600};
|
||||||
`}
|
`}
|
||||||
|
|
|
@ -25,7 +25,7 @@ const base = css`
|
||||||
background-color: ${palette.taupe300};
|
background-color: ${palette.taupe300};
|
||||||
color: ${palette.grey500};
|
color: ${palette.grey500};
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
border: 2px solid rgba(0, 0, 0, 0.55);
|
border: 2px solid rgb(0 0 0 / 55%);
|
||||||
transition: all 0.15s ease-in-out;
|
transition: all 0.15s ease-in-out;
|
||||||
outline: 0;
|
outline: 0;
|
||||||
position: relative;
|
position: relative;
|
||||||
|
@ -41,20 +41,20 @@ const base = css`
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
background-color: #000;
|
background-color: #000;
|
||||||
opacity: 0;
|
opacity: 0%;
|
||||||
transition: all 0.15s ease-in-out;
|
transition: all 0.15s ease-in-out;
|
||||||
}
|
}
|
||||||
|
|
||||||
:hover {
|
:hover {
|
||||||
transform: translateY(-1px);
|
transform: translateY(-1px);
|
||||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
|
box-shadow: 0 1px 2px rgb(0 0 0 / 15%);
|
||||||
}
|
}
|
||||||
|
|
||||||
:active {
|
:active {
|
||||||
transform: translateY(1px);
|
transform: translateY(1px);
|
||||||
box-shadow: 0 0 2px rgba(0, 0, 0, 0.25);
|
box-shadow: 0 0 2px rgb(0 0 0 / 25%);
|
||||||
::after {
|
::after {
|
||||||
opacity: 0.1;
|
opacity: 10%;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
@ -70,7 +70,7 @@ const colors = {
|
||||||
border: 2px solid ${palette.discord200};
|
border: 2px solid ${palette.discord200};
|
||||||
`,
|
`,
|
||||||
muted: css`
|
muted: css`
|
||||||
border: 2px solid rgba(0, 0, 0, 0.15);
|
border: 2px solid rgb(0 0 0 / 15%);
|
||||||
background: none;
|
background: none;
|
||||||
:hover {
|
:hover {
|
||||||
background-color: ${palette.taupe200};
|
background-color: ${palette.taupe200};
|
||||||
|
|
|
@ -15,7 +15,7 @@ export default {
|
||||||
};
|
};
|
||||||
|
|
||||||
const Swatch = styled.div`
|
const Swatch = styled.div`
|
||||||
box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.25);
|
box-shadow: 1px 1px 2px rgb(0 0 0 / 25%);
|
||||||
width: 250px;
|
width: 250px;
|
||||||
height: 100px;
|
height: 100px;
|
||||||
margin: 10px;
|
margin: 10px;
|
||||||
|
|
|
@ -3,7 +3,7 @@ import * as React from 'react';
|
||||||
import styled from 'styled-components';
|
import styled from 'styled-components';
|
||||||
|
|
||||||
const dotOverlayBase = styled.div`
|
const dotOverlayBase = styled.div`
|
||||||
opacity: 0.6;
|
opacity: 60%;
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
position: fixed;
|
position: fixed;
|
||||||
top: 0;
|
top: 0;
|
||||||
|
|
|
@ -7,7 +7,7 @@ export type FaderProps = {
|
||||||
};
|
};
|
||||||
|
|
||||||
const FaderOpacityStyled = styled.div<Pick<FaderProps, 'isVisible'>>`
|
const FaderOpacityStyled = styled.div<Pick<FaderProps, 'isVisible'>>`
|
||||||
opacity: ${(props) => (props.isVisible ? 1 : 0)};
|
opacity: ${(props) => (props.isVisible ? '100%' : '0%')};
|
||||||
pointer-events: ${(props) => (props.isVisible ? 'unset' : 'none')};
|
pointer-events: ${(props) => (props.isVisible ? 'unset' : 'none')};
|
||||||
transition: opacity 0.35s ease-in-out;
|
transition: opacity 0.35s ease-in-out;
|
||||||
`;
|
`;
|
||||||
|
|
|
@ -41,7 +41,7 @@ const StoryWrapper = ({ topSpacing, bottomSpacing, ...props }: WrapperProps) =>
|
||||||
<div
|
<div
|
||||||
style={{
|
style={{
|
||||||
height: topSpacing,
|
height: topSpacing,
|
||||||
backgroundColor: 'rgba(255,0,0,0.25)',
|
backgroundColor: 'rgb(255 0 0 / 25%)',
|
||||||
top: 0,
|
top: 0,
|
||||||
left: 0,
|
left: 0,
|
||||||
right: 0,
|
right: 0,
|
||||||
|
@ -54,7 +54,7 @@ const StoryWrapper = ({ topSpacing, bottomSpacing, ...props }: WrapperProps) =>
|
||||||
<div
|
<div
|
||||||
style={{
|
style={{
|
||||||
height: bottomSpacing,
|
height: bottomSpacing,
|
||||||
backgroundColor: 'rgba(0,0,255,0.25)',
|
backgroundColor: 'rgb(0 0 255 / 25%)',
|
||||||
bottom: 0,
|
bottom: 0,
|
||||||
left: 0,
|
left: 0,
|
||||||
right: 0,
|
right: 0,
|
||||||
|
|
|
@ -41,10 +41,10 @@ export const PlaceholderBox = styled.div<PlaceholderProps>`
|
||||||
|
|
||||||
export const opacityInOut = keyframes`
|
export const opacityInOut = keyframes`
|
||||||
from {
|
from {
|
||||||
opacity: 0.6;
|
opacity: 60%;
|
||||||
}
|
}
|
||||||
to {
|
to {
|
||||||
opacity: 0.3;
|
opacity: 30%;
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@ export const PopoverBase = styled.div<PopoverStyledProps>`
|
||||||
position: absolute;
|
position: absolute;
|
||||||
background-color: ${palette.taupe100};
|
background-color: ${palette.taupe100};
|
||||||
padding: 5px;
|
padding: 5px;
|
||||||
border: 2px solid rgba(0, 0, 0, 0.15);
|
border: 2px solid rgb(0 0 0 / 15%);
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
z-index: 10;
|
z-index: 10;
|
||||||
transition: opacity ${transitions.out2in}s ease-in,
|
transition: opacity ${transitions.out2in}s ease-in,
|
||||||
|
@ -24,7 +24,7 @@ export const PopoverBase = styled.div<PopoverStyledProps>`
|
||||||
!props.active &&
|
!props.active &&
|
||||||
css`
|
css`
|
||||||
transform: translateY(-2vh);
|
transform: translateY(-2vh);
|
||||||
opacity: 0;
|
opacity: 0%;
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
`}
|
`}
|
||||||
${onSmallScreen(
|
${onSmallScreen(
|
||||||
|
@ -40,11 +40,11 @@ export const PopoverBase = styled.div<PopoverStyledProps>`
|
||||||
z-index: 200;
|
z-index: 200;
|
||||||
margin: 0 !important;
|
margin: 0 !important;
|
||||||
`
|
`
|
||||||
)};
|
)}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const DefocusHandler = styled.div<PopoverStyledProps>`
|
export const DefocusHandler = styled.div<PopoverStyledProps>`
|
||||||
background-color: rgba(0, 0, 0, 0.01);
|
background-color: rgb(0 0 0 / 1%);
|
||||||
position: fixed;
|
position: fixed;
|
||||||
z-index: 0;
|
z-index: 0;
|
||||||
top: 0;
|
top: 0;
|
||||||
|
@ -82,7 +82,7 @@ export const PopoverHeadCloser = styled.div`
|
||||||
)}
|
)}
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background: rgba(0, 0, 0, 0.1);
|
background: rgb(0 0 0 / 10%);
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
|
|
|
@ -62,7 +62,7 @@ export const Outer = styled.div<StyledProps>`
|
||||||
? onTablet(css`
|
? onTablet(css`
|
||||||
&:hover {
|
&:hover {
|
||||||
transform: translateY(-2px);
|
transform: translateY(-2px);
|
||||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
|
box-shadow: 0 1px 2px rgb(0 0 0 / 15%);
|
||||||
${Circle} svg {
|
${Circle} svg {
|
||||||
fill-opacity: 1;
|
fill-opacity: 1;
|
||||||
}
|
}
|
||||||
|
@ -73,7 +73,7 @@ export const Outer = styled.div<StyledProps>`
|
||||||
box-shadow: 0 0 0 transparent;
|
box-shadow: 0 0 0 transparent;
|
||||||
}
|
}
|
||||||
`)
|
`)
|
||||||
: null};
|
: null}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const Text = styled.div`
|
export const Text = styled.div`
|
||||||
|
|
|
@ -65,7 +65,7 @@ export const TabContent = styled.div`
|
||||||
export const TabContentTitle = styled.div`
|
export const TabContentTitle = styled.div`
|
||||||
${text500}
|
${text500}
|
||||||
|
|
||||||
border-bottom: 1px solid rgba(0, 0, 0, 0.1);
|
border-bottom: 1px solid rgb(0 0 0 / 10%);
|
||||||
padding: 0.5em 7px;
|
padding: 0.5em 7px;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
|
|
|
@ -21,13 +21,13 @@ const common = css`
|
||||||
:focus {
|
:focus {
|
||||||
outline: none;
|
outline: none;
|
||||||
border-color: ${palette.grey100};
|
border-color: ${palette.grey100};
|
||||||
box-shadow: 1px 0 3px rgba(0, 0, 0, 0.25);
|
box-shadow: 1px 0 3px rgb(0 0 0 / 25%);
|
||||||
}
|
}
|
||||||
|
|
||||||
[disabled],
|
[disabled],
|
||||||
:disabled {
|
:disabled {
|
||||||
cursor: not-allowed;
|
cursor: not-allowed;
|
||||||
color: rgba(255, 255, 255, 0.75);
|
color: rgb(255 255 255 / 75%);
|
||||||
font-style: italic;
|
font-style: italic;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ const common = css`
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const StyledTextInput = styled.input`
|
export const StyledTextInput = styled.input`
|
||||||
${common};
|
${common}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
type TextInputProps<T extends HTMLInputElement | HTMLTextAreaElement> =
|
type TextInputProps<T extends HTMLInputElement | HTMLTextAreaElement> =
|
||||||
|
@ -87,8 +87,8 @@ export const TextInputWithIcon = (props: TextInputWithIconProps) => {
|
||||||
};
|
};
|
||||||
|
|
||||||
const StyledTextarea = styled.textarea`
|
const StyledTextarea = styled.textarea`
|
||||||
${common};
|
${common}
|
||||||
${fontCSS};
|
${fontCSS}
|
||||||
|
|
||||||
margin: 0.5em 0;
|
margin: 0.5em 0;
|
||||||
`;
|
`;
|
||||||
|
|
|
@ -24,7 +24,7 @@ export const ToggleSwitch = styled.div<{ state: boolean }>`
|
||||||
width: 2.675rem;
|
width: 2.675rem;
|
||||||
border-radius: 1.375rem;
|
border-radius: 1.375rem;
|
||||||
position: relative;
|
position: relative;
|
||||||
border: 1px solid rgba(0, 0, 0, 0.1);
|
border: 1px solid rgb(0 0 0 / 10%);
|
||||||
top: 0.23em;
|
top: 0.23em;
|
||||||
transition: background-color ${transitions.in2in}s ease-in-out;
|
transition: background-color ${transitions.in2in}s ease-in-out;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
|
|
|
@ -87,7 +87,7 @@ const SpacingHead = styled.p`
|
||||||
|
|
||||||
const SpacingSection = styled(Section)`
|
const SpacingSection = styled(Section)`
|
||||||
max-width: 50vw;
|
max-width: 50vw;
|
||||||
border-bottom: 1px solid rgba(0, 0, 0, 0.25);
|
border-bottom: 1px solid rgb(0 0 0 / 25%);
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const Spacing = () => (
|
export const Spacing = () => (
|
||||||
|
|
|
@ -14,55 +14,46 @@ const reset = css`
|
||||||
|
|
||||||
export const text900 = css`
|
export const text900 = css`
|
||||||
${reset}
|
${reset}
|
||||||
|
|
||||||
font-size: 2.3rem;
|
font-size: 2.3rem;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const text800 = css`
|
export const text800 = css`
|
||||||
${reset}
|
${reset}
|
||||||
|
|
||||||
font-size: 2rem;
|
font-size: 2rem;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const text700 = css`
|
export const text700 = css`
|
||||||
${reset}
|
${reset}
|
||||||
|
|
||||||
font-size: 1.7rem;
|
font-size: 1.7rem;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const text600 = css`
|
export const text600 = css`
|
||||||
${reset}
|
${reset}
|
||||||
|
|
||||||
font-size: 1.4rem;
|
font-size: 1.4rem;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const text500 = css`
|
export const text500 = css`
|
||||||
${reset}
|
${reset}
|
||||||
|
|
||||||
font-size: 1.2rem;
|
font-size: 1.2rem;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const text400 = css`
|
export const text400 = css`
|
||||||
${reset}
|
${reset}
|
||||||
|
|
||||||
font-size: 1rem;
|
font-size: 1rem;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const text300 = css`
|
export const text300 = css`
|
||||||
${reset}
|
${reset}
|
||||||
|
|
||||||
font-size: 0.9rem;
|
font-size: 0.9rem;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const text200 = css`
|
export const text200 = css`
|
||||||
${reset}
|
${reset}
|
||||||
|
|
||||||
font-size: 0.7rem;
|
font-size: 0.7rem;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const text100 = css`
|
export const text100 = css`
|
||||||
${reset}
|
${reset}
|
||||||
|
|
||||||
font-size: 0.5rem;
|
font-size: 0.5rem;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
module.exports = {
|
module.exports = {
|
||||||
|
name: 'design-system',
|
||||||
preset: 'ts-jest/presets/js-with-ts',
|
preset: 'ts-jest/presets/js-with-ts',
|
||||||
testEnvironment: 'jsdom',
|
testEnvironment: 'jsdom',
|
||||||
reporters: ['default'],
|
reporters: ['default'],
|
||||||
setupFilesAfterEnv: ['jest-styled-components', './hack/jestSetup.ts'],
|
setupFilesAfterEnv: ['jest-styled-components', '../../hack/jestSetup.ts'],
|
||||||
snapshotSerializers: ['enzyme-to-json/serializer'],
|
snapshotSerializers: ['enzyme-to-json/serializer'],
|
||||||
globals: {
|
globals: {
|
||||||
'ts-jest': {
|
'ts-jest': {
|
||||||
tsconfig: './tsconfig.test.json',
|
tsconfig: '../../tsconfig.test.json',
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
projects: ['packages/api/jest.config.js'],
|
|
||||||
};
|
};
|
|
@ -3,7 +3,7 @@ import styled, { keyframes } from 'styled-components';
|
||||||
|
|
||||||
export const Base = styled.div`
|
export const Base = styled.div`
|
||||||
background-color: ${palette.discord100};
|
background-color: ${palette.discord100};
|
||||||
border: solid 1px rgba(0, 0, 0, 0.15);
|
border: solid 1px rgb(0 0 0 / 15%);
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
user-select: none;
|
user-select: none;
|
||||||
|
@ -12,7 +12,7 @@ export const Base = styled.div`
|
||||||
export const Timestamp = styled.span`
|
export const Timestamp = styled.span`
|
||||||
padding: 0 5px;
|
padding: 0 5px;
|
||||||
font-size: 0.7em;
|
font-size: 0.7em;
|
||||||
opacity: 0.3;
|
opacity: 30%;
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const TextParts = styled.span`
|
export const TextParts = styled.span`
|
||||||
|
@ -35,19 +35,19 @@ export const InputBox = styled.div`
|
||||||
|
|
||||||
const lineBlink = keyframes`
|
const lineBlink = keyframes`
|
||||||
0% {
|
0% {
|
||||||
opacity: 1;
|
opacity: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
40% {
|
40% {
|
||||||
opacity: 1;
|
opacity: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
60% {
|
60% {
|
||||||
opacity: 0;
|
opacity: 0%;
|
||||||
}
|
}
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
opacity: 0;
|
opacity: 0%;
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
|
|
|
@ -19,11 +19,9 @@ const RoleWrap = styled.div`
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const DemoPicker = () => {
|
export const DemoPicker = () => {
|
||||||
const [selectedStates, setSelectedStates] = React.useState<
|
const [selectedStates, setSelectedStates] = React.useState<{
|
||||||
{
|
[key in RPCRole['id']]: boolean;
|
||||||
[key in RPCRole['id']]: boolean;
|
}>(demoData.reduce((acc, role) => ({ ...acc, [role.id]: false }), {}));
|
||||||
}
|
|
||||||
>(demoData.reduce((acc, role) => ({ ...acc, [role.id]: false }), {}));
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Container>
|
<Container>
|
||||||
|
|
|
@ -24,7 +24,7 @@ export const AddRoleButton = styled.div<{ long?: boolean }>`
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: ${palette.taupe100};
|
background-color: ${palette.taupe100};
|
||||||
transform: translateY(-2px);
|
transform: translateY(-2px);
|
||||||
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
|
box-shadow: 0 1px 1px rgb(0 0 0 / 10%);
|
||||||
}
|
}
|
||||||
|
|
||||||
&:active {
|
&:active {
|
||||||
|
@ -39,5 +39,5 @@ export const AddRoleButton = styled.div<{ long?: boolean }>`
|
||||||
`
|
`
|
||||||
: css`
|
: css`
|
||||||
width: 32px;
|
width: 32px;
|
||||||
`};
|
`}
|
||||||
`;
|
`;
|
||||||
|
|
|
@ -40,7 +40,7 @@ export const Section = styled.div<{ big?: boolean; actions?: boolean }>`
|
||||||
props.actions &&
|
props.actions &&
|
||||||
css`
|
css`
|
||||||
display: flex;
|
display: flex;
|
||||||
`};
|
`}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const RoleContainer = styled.div`
|
export const RoleContainer = styled.div`
|
||||||
|
@ -65,7 +65,7 @@ export const AddRoleButton = styled.div<{ long?: boolean }>`
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: ${palette.taupe100};
|
background-color: ${palette.taupe100};
|
||||||
transform: translateY(-2px);
|
transform: translateY(-2px);
|
||||||
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
|
box-shadow: 0 1px 1px rgb(0 0 0 / 10%);
|
||||||
}
|
}
|
||||||
|
|
||||||
&:active {
|
&:active {
|
||||||
|
@ -80,5 +80,5 @@ export const AddRoleButton = styled.div<{ long?: boolean }>`
|
||||||
`
|
`
|
||||||
: css`
|
: css`
|
||||||
width: 32px;
|
width: 32px;
|
||||||
`};
|
`}
|
||||||
`;
|
`;
|
||||||
|
|
|
@ -19,12 +19,12 @@ export const FooterWrapper = styled.div`
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const HoverColor = styled.div`
|
export const HoverColor = styled.div`
|
||||||
opacity: 0.3;
|
opacity: 30%;
|
||||||
filter: saturate(0);
|
filter: saturate(0);
|
||||||
transition: all ${transitions.in2in}s ease-in-out;
|
transition: all ${transitions.in2in}s ease-in-out;
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
opacity: 1;
|
opacity: 100%;
|
||||||
filter: none;
|
filter: none;
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
|
|
@ -75,11 +75,11 @@ export const CardBase = styled.div`
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
max-width: 98vw;
|
max-width: 98vw;
|
||||||
:hover {
|
:hover {
|
||||||
box-shadow: 0 2px 2px rgba(0, 0, 0, 0.25);
|
box-shadow: 0 2px 2px rgb(0 0 0 / 25%);
|
||||||
transform: translate(0, -1px);
|
transform: translate(0, -1px);
|
||||||
}
|
}
|
||||||
:active {
|
:active {
|
||||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
|
box-shadow: 0 1px 2px rgb(0 0 0 / 25%);
|
||||||
transform: translate(0);
|
transform: translate(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ export const ClickaleBlock = styled.a`
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const Title = styled.div`
|
export const Title = styled.div`
|
||||||
${text400};
|
${text400}
|
||||||
|
|
||||||
svg {
|
svg {
|
||||||
color: ${palette.taupe500};
|
color: ${palette.taupe500};
|
||||||
|
@ -30,7 +30,7 @@ export const Title = styled.div`
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const Description = styled.div`
|
export const Description = styled.div`
|
||||||
${text200};
|
${text200}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const MainSide = styled.div``;
|
export const MainSide = styled.div``;
|
||||||
|
|
|
@ -6,7 +6,7 @@ import styled, { css, keyframes } from 'styled-components';
|
||||||
|
|
||||||
export const DiscordBase = styled.div`
|
export const DiscordBase = styled.div`
|
||||||
background-color: ${palette.discord100};
|
background-color: ${palette.discord100};
|
||||||
border: solid 1px rgba(0, 0, 0, 0.15);
|
border: solid 1px rgb(0 0 0 / 15%);
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
user-select: none;
|
user-select: none;
|
||||||
|
@ -54,7 +54,7 @@ export const DiscordRole = styled.div<{
|
||||||
!props.isGood &&
|
!props.isGood &&
|
||||||
props.isRoleypoly &&
|
props.isRoleypoly &&
|
||||||
css`
|
css`
|
||||||
animation: ${isBadFlash} 0.5s 10s ease-in-out both;
|
animation: ${isBadFlash.getName()} 0.5s 10s ease-in-out both;
|
||||||
`}
|
`}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
|
@ -66,16 +66,13 @@ const bumpDown = css`
|
||||||
|
|
||||||
export const Dont = styled(GoX)`
|
export const Dont = styled(GoX)`
|
||||||
${bumpDown}
|
${bumpDown}
|
||||||
|
|
||||||
color: ${palette.red400};
|
color: ${palette.red400};
|
||||||
`;
|
`;
|
||||||
export const Do = styled(GoCheck)`
|
export const Do = styled(GoCheck)`
|
||||||
${bumpDown}
|
${bumpDown}
|
||||||
|
|
||||||
color: ${palette.green400};
|
color: ${palette.green400};
|
||||||
`;
|
`;
|
||||||
export const Why = styled(GoQuestion)`
|
export const Why = styled(GoQuestion)`
|
||||||
${bumpDown}
|
${bumpDown}
|
||||||
|
|
||||||
color: ${palette.discord400};
|
color: ${palette.discord400};
|
||||||
`;
|
`;
|
||||||
|
|
|
@ -10,7 +10,6 @@ export const HeroText = styled.div`
|
||||||
|
|
||||||
export const DemoSubtitle = styled.p`
|
export const DemoSubtitle = styled.p`
|
||||||
${text400}
|
${text400}
|
||||||
|
|
||||||
text-align: center;
|
text-align: center;
|
||||||
margin-top: 0.4em;
|
margin-top: 0.4em;
|
||||||
`;
|
`;
|
||||||
|
|
|
@ -59,10 +59,10 @@ export const InteractionBase = styled.div<InteractionBaseProps>`
|
||||||
padding: 0 5px;
|
padding: 0 5px;
|
||||||
transition: opacity ${transitions.actionable}s ease-in-out,
|
transition: opacity ${transitions.actionable}s ease-in-out,
|
||||||
background-color ${transitions.actionable}s ease-in-out;
|
background-color ${transitions.actionable}s ease-in-out;
|
||||||
opacity: ${(props) => (props.hide ? 1 : 0)};
|
opacity: ${(props) => (props.hide ? '100%' : '0%')};
|
||||||
|
|
||||||
:hover {
|
:hover {
|
||||||
background-color: rgba(0, 0, 0, 0.15);
|
background-color: rgb(0 0 0 / 15%);
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
@ -97,7 +97,7 @@ export const SecondaryBase = styled(MastheadBase)`
|
||||||
background-color: ${palette.taupe300};
|
background-color: ${palette.taupe300};
|
||||||
z-index: 99;
|
z-index: 99;
|
||||||
padding: 0 15px;
|
padding: 0 15px;
|
||||||
box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.05);
|
box-shadow: 1px 1px 3px rgb(0 0 0 / 5%);
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export const IconHolder = styled.div`
|
export const IconHolder = styled.div`
|
||||||
|
|
|
@ -14,7 +14,7 @@ export const CategoryActions = styled.div<{ right?: boolean }>`
|
||||||
`
|
`
|
||||||
: css`
|
: css`
|
||||||
margin-right: 5px;
|
margin-right: 5px;
|
||||||
`};
|
`}
|
||||||
}
|
}
|
||||||
|
|
||||||
${(props) =>
|
${(props) =>
|
||||||
|
@ -37,7 +37,7 @@ export const ReorderButton = styled.div`
|
||||||
transition: background-color ${transitions.actionable}s ease-in-out;
|
transition: background-color ${transitions.actionable}s ease-in-out;
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: rgba(0, 0, 0, 0.15);
|
background-color: rgb(0 0 0 / 15%);
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,5 @@ export const FlexLine = styled.div`
|
||||||
|
|
||||||
export const FlexWrap = styled.div`
|
export const FlexWrap = styled.div`
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-flow: wrap column;
|
||||||
flex-wrap: wrap;
|
|
||||||
`;
|
`;
|
||||||
|
|
|
@ -26,7 +26,6 @@ export const CardContainer = styled.div`
|
||||||
|
|
||||||
export const SectionHead = styled.div`
|
export const SectionHead = styled.div`
|
||||||
${text500}
|
${text500}
|
||||||
|
|
||||||
flex: 1 1 100%;
|
flex: 1 1 100%;
|
||||||
padding: 0.6em;
|
padding: 0.6em;
|
||||||
display: flex;
|
display: flex;
|
||||||
|
|
|
@ -4,45 +4,46 @@
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "build-storybook -o ../../dist/-/storybook",
|
"build": "build-storybook -o ../../dist/-/storybook",
|
||||||
"create-component": "node ./hack/create-component.js",
|
"create-component": "node ./hack/create-component.js",
|
||||||
"start": "start-storybook -p 6006"
|
"start": "start-storybook -p 6006",
|
||||||
|
"test": "jest"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@roleypoly/types": "*",
|
"@roleypoly/types": "*",
|
||||||
"chroma-js": "^2.1.2",
|
"chroma-js": "^2.3.0",
|
||||||
"deep-equal": "^2.0.5",
|
"deep-equal": "^2.0.5",
|
||||||
"isomorphic-unfetch": "^3.1.0",
|
"isomorphic-unfetch": "^3.1.0",
|
||||||
"ksuid": "^2.0.0",
|
"ksuid": "^3.0.0",
|
||||||
"lodash": "^4.17.21",
|
"lodash": "^4.17.21",
|
||||||
"react": "^17.0.2",
|
"react": "^17.0.2",
|
||||||
"react-beautiful-dnd": "^13.1.0",
|
"react-beautiful-dnd": "^13.1.0",
|
||||||
"react-custom-scrollbars": "^4.2.1",
|
"react-custom-scrollbars": "^4.2.1",
|
||||||
"react-dom": "^17.0.2",
|
"react-dom": "^17.0.2",
|
||||||
"react-helmet": "^6.1.0",
|
"react-helmet": "^6.1.0",
|
||||||
"react-icons": "^4.2.0",
|
"react-icons": "^4.3.1",
|
||||||
"react-is": "^17.0.2",
|
"react-is": "^17.0.2",
|
||||||
"react-tooltip": "^4.2.21",
|
"react-tooltip": "^4.2.21",
|
||||||
"styled-components": "^5.3.0",
|
"styled-components": "^5.3.3",
|
||||||
"styled-normalize": "^8.0.7"
|
"styled-normalize": "^8.0.7"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@icons/material": "^0.4.1",
|
"@icons/material": "^0.4.1",
|
||||||
"@storybook/addon-actions": "^6.3.3",
|
"@storybook/addon-actions": "^6.4.16",
|
||||||
"@storybook/addon-essentials": "^6.3.3",
|
"@storybook/addon-essentials": "^6.4.16",
|
||||||
"@storybook/addon-links": "^6.3.3",
|
"@storybook/addon-links": "^6.4.16",
|
||||||
"@storybook/addons": "^6.3.3",
|
"@storybook/addons": "^6.4.16",
|
||||||
"@storybook/react": "^6.3.3",
|
"@storybook/react": "^6.4.16",
|
||||||
"@storybook/theming": "^6.3.3",
|
"@storybook/theming": "^6.4.16",
|
||||||
"@types/chroma-js": "^2.1.3",
|
"@types/chroma-js": "^2.1.3",
|
||||||
"@types/deep-equal": "^1.0.1",
|
"@types/deep-equal": "^1.0.1",
|
||||||
"@types/node": "^16.0.1",
|
"@types/node": "^17.0.13",
|
||||||
"@types/react": "^17.0.14",
|
"@types/react": "^17.0.38",
|
||||||
"@types/react-beautiful-dnd": "^13.1.1",
|
"@types/react-beautiful-dnd": "^13.1.2",
|
||||||
"@types/react-custom-scrollbars": "^4.0.8",
|
"@types/react-custom-scrollbars": "^4.0.10",
|
||||||
"@types/react-dom": "^17.0.9",
|
"@types/react-dom": "^17.0.11",
|
||||||
"@types/react-helmet": "^6.1.2",
|
"@types/react-helmet": "^6.1.5",
|
||||||
"@types/styled-components": "^5.1.11",
|
"@types/styled-components": "^5.1.21",
|
||||||
"babel-loader": "8.1.0",
|
"babel-loader": "^8.2.3",
|
||||||
"babel-plugin-styled-components": "^1.13.1",
|
"babel-plugin-styled-components": "^2.0.2",
|
||||||
"change-case": "^4.1.2",
|
"change-case": "^4.1.2",
|
||||||
"tslint": "^6.1.3",
|
"tslint": "^6.1.3",
|
||||||
"typescript": "^4.5.5"
|
"typescript": "^4.5.5"
|
||||||
|
|
13
packages/misc-utils/jest.config.js
Normal file
13
packages/misc-utils/jest.config.js
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
module.exports = {
|
||||||
|
name: 'web',
|
||||||
|
preset: 'ts-jest/presets/js-with-ts',
|
||||||
|
testEnvironment: 'jsdom',
|
||||||
|
reporters: ['default'],
|
||||||
|
setupFilesAfterEnv: ['jest-styled-components', '../../hack/jestSetup.ts'],
|
||||||
|
snapshotSerializers: ['enzyme-to-json/serializer'],
|
||||||
|
globals: {
|
||||||
|
'ts-jest': {
|
||||||
|
tsconfig: '../../tsconfig.test.json',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
|
@ -1,6 +1,9 @@
|
||||||
{
|
{
|
||||||
"name": "@roleypoly/misc-utils",
|
"name": "@roleypoly/misc-utils",
|
||||||
"version": "0.1.0",
|
"version": "0.1.0",
|
||||||
|
"scripts": {
|
||||||
|
"test": "jest"
|
||||||
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@roleypoly/types": "*"
|
"@roleypoly/types": "*"
|
||||||
},
|
},
|
||||||
|
|
13
packages/web/jest.config.js
Normal file
13
packages/web/jest.config.js
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
module.exports = {
|
||||||
|
name: 'web',
|
||||||
|
preset: 'ts-jest/presets/js-with-ts',
|
||||||
|
testEnvironment: 'jsdom',
|
||||||
|
reporters: ['default'],
|
||||||
|
setupFilesAfterEnv: ['jest-styled-components', '../../hack/jestSetup.ts'],
|
||||||
|
snapshotSerializers: ['enzyme-to-json/serializer'],
|
||||||
|
globals: {
|
||||||
|
'ts-jest': {
|
||||||
|
tsconfig: '../../tsconfig.test.json',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
|
@ -5,13 +5,13 @@
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "cross-env BUILD_PATH=../../dist craco build",
|
"build": "cross-env BUILD_PATH=../../dist craco build",
|
||||||
"start": "cross-env PORT=6601 craco start",
|
"start": "cross-env PORT=6601 craco start",
|
||||||
"test": "craco test"
|
"test": "jest"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@reach/router": "^1.3.4",
|
"@reach/router": "^1.3.4",
|
||||||
"@roleypoly/design-system": "*",
|
"@roleypoly/design-system": "*",
|
||||||
"@roleypoly/misc-utils": "*",
|
"@roleypoly/misc-utils": "*",
|
||||||
"memoize-one": "^5.2.1",
|
"memoize-one": "^6.0.0",
|
||||||
"react": "^17.0.2",
|
"react": "^17.0.2",
|
||||||
"react-dom": "^17.0.2",
|
"react-dom": "^17.0.2",
|
||||||
"react-helmet": "^6.1.0",
|
"react-helmet": "^6.1.0",
|
||||||
|
@ -20,21 +20,21 @@
|
||||||
"web-vitals": "^2.1.4"
|
"web-vitals": "^2.1.4"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@plpaquin/craco": "5.0.0-next.1",
|
"@craco/craco": "^7.0.0-alpha.0",
|
||||||
"@roleypoly/types": "*",
|
"@roleypoly/types": "*",
|
||||||
"@testing-library/jest-dom": "^5.14.1",
|
"@testing-library/jest-dom": "^5.16.1",
|
||||||
"@testing-library/react": "^12.0.0",
|
"@testing-library/react": "^12.1.2",
|
||||||
"@testing-library/user-event": "^13.1.9",
|
"@testing-library/user-event": "^13.5.0",
|
||||||
"@types/jest": "^26.0.24",
|
"@types/jest": "^27.4.0",
|
||||||
"@types/node": "^16.0.1",
|
"@types/node": "^17.0.13",
|
||||||
"@types/react": "^17.0.14",
|
"@types/reach__router": "^1.3.10",
|
||||||
"@types/react-dom": "^17.0.9",
|
"@types/react": "^17.0.38",
|
||||||
"@types/react-helmet": "^6.1.2",
|
"@types/react-dom": "^17.0.11",
|
||||||
"babel-loader": "8.1.0",
|
"@types/react-helmet": "^6.1.5",
|
||||||
|
"babel-loader": "8.2.3",
|
||||||
"cross-env": "7.0.3",
|
"cross-env": "7.0.3",
|
||||||
"exponential-backoff": "^3.1.0",
|
"ts-loader": "^9.2.6",
|
||||||
"ts-loader": "^8.3.0",
|
"webpack": "5.67.0"
|
||||||
"webpack": "4.44.2"
|
|
||||||
},
|
},
|
||||||
"browserslist": {
|
"browserslist": {
|
||||||
"production": [
|
"production": [
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue