bootystrappy
This commit is contained in:
parent
96b246462a
commit
321173dfe6
23 changed files with 9410 additions and 1027 deletions
7
.gitignore
vendored
7
.gitignore
vendored
|
@ -17,3 +17,10 @@
|
||||||
###< phpunit/phpunit ###
|
###< phpunit/phpunit ###
|
||||||
|
|
||||||
.DS_Store
|
.DS_Store
|
||||||
|
|
||||||
|
###> symfony/webpack-encore-bundle ###
|
||||||
|
/node_modules/
|
||||||
|
/public/build/
|
||||||
|
npm-debug.log
|
||||||
|
yarn-error.log
|
||||||
|
###< symfony/webpack-encore-bundle ###
|
||||||
|
|
35
README.md
Normal file
35
README.md
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
# Asset Management with Webpack Encore
|
||||||
|
|
||||||
|
This project uses Webpack Encore for asset management including JavaScript and CSS minification.
|
||||||
|
|
||||||
|
## Setup
|
||||||
|
|
||||||
|
Before using the application, you need to set up the front-end assets:
|
||||||
|
|
||||||
|
1. Install Node.js dependencies:
|
||||||
|
```
|
||||||
|
npm install
|
||||||
|
```
|
||||||
|
|
||||||
|
2. Copy the existing static assets to the Encore assets directory:
|
||||||
|
```
|
||||||
|
mkdir -p assets/css assets/js
|
||||||
|
cp public/static/css/water.min.css assets/css/
|
||||||
|
cp public/static/js/htmx.min.js assets/js/
|
||||||
|
```
|
||||||
|
|
||||||
|
3. Build the assets:
|
||||||
|
|
||||||
|
For development:
|
||||||
|
```
|
||||||
|
npm run dev
|
||||||
|
```
|
||||||
|
|
||||||
|
For production (with minification):
|
||||||
|
```
|
||||||
|
npm run build
|
||||||
|
```
|
||||||
|
|
||||||
|
## Development
|
||||||
|
|
||||||
|
During development, you can use the watch command to automatically rebuild assets when files change:
|
11
assets/app.js
Normal file
11
assets/app.js
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
/*
|
||||||
|
* Welcome to your app's main JavaScript file!
|
||||||
|
*
|
||||||
|
* We recommend including the built version of this JavaScript file
|
||||||
|
* (and its CSS file) in your base layout (base.html.twig).
|
||||||
|
*/
|
||||||
|
|
||||||
|
// any CSS you import will output into a single css file (app.css in this case)
|
||||||
|
import './styles/app.scss';
|
||||||
|
|
||||||
|
import * as bootstrap from 'bootstrap';
|
4
assets/styles/app.scss
Normal file
4
assets/styles/app.scss
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
/* Import water.min.css */
|
||||||
|
@import "bootstrap/scss/bootstrap.scss";
|
||||||
|
|
||||||
|
/* You can add your other custom styles here */
|
|
@ -33,6 +33,7 @@
|
||||||
"symfony/twig-bundle": "7.1.*",
|
"symfony/twig-bundle": "7.1.*",
|
||||||
"symfony/uid": "7.1.*",
|
"symfony/uid": "7.1.*",
|
||||||
"symfony/validator": "7.1.*",
|
"symfony/validator": "7.1.*",
|
||||||
|
"symfony/webpack-encore-bundle": "^2.2",
|
||||||
"symfony/yaml": "7.1.*"
|
"symfony/yaml": "7.1.*"
|
||||||
},
|
},
|
||||||
"require-dev": {
|
"require-dev": {
|
||||||
|
|
74
composer.lock
generated
74
composer.lock
generated
|
@ -4,7 +4,7 @@
|
||||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
||||||
"This file is @generated automatically"
|
"This file is @generated automatically"
|
||||||
],
|
],
|
||||||
"content-hash": "d7745d305c728e9812365f75052d1031",
|
"content-hash": "cd54411ea8c59671cb4e98ae7fefbbcb",
|
||||||
"packages": [
|
"packages": [
|
||||||
{
|
{
|
||||||
"name": "api-platform/doctrine-common",
|
"name": "api-platform/doctrine-common",
|
||||||
|
@ -7036,6 +7036,78 @@
|
||||||
],
|
],
|
||||||
"time": "2024-09-25T14:21:43+00:00"
|
"time": "2024-09-25T14:21:43+00:00"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "symfony/webpack-encore-bundle",
|
||||||
|
"version": "v2.2.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/symfony/webpack-encore-bundle.git",
|
||||||
|
"reference": "e335394b68a775a9b2bd173a8ba4fd2001f3870c"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/symfony/webpack-encore-bundle/zipball/e335394b68a775a9b2bd173a8ba4fd2001f3870c",
|
||||||
|
"reference": "e335394b68a775a9b2bd173a8ba4fd2001f3870c",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": ">=8.1.0",
|
||||||
|
"symfony/asset": "^5.4 || ^6.2 || ^7.0",
|
||||||
|
"symfony/config": "^5.4 || ^6.2 || ^7.0",
|
||||||
|
"symfony/dependency-injection": "^5.4 || ^6.2 || ^7.0",
|
||||||
|
"symfony/http-kernel": "^5.4 || ^6.2 || ^7.0",
|
||||||
|
"symfony/service-contracts": "^1.1.9 || ^2.1.3 || ^3.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"symfony/framework-bundle": "^5.4 || ^6.2 || ^7.0",
|
||||||
|
"symfony/http-client": "^5.4 || ^6.2 || ^7.0",
|
||||||
|
"symfony/phpunit-bridge": "^5.4 || ^6.2 || ^7.0",
|
||||||
|
"symfony/twig-bundle": "^5.4 || ^6.2 || ^7.0",
|
||||||
|
"symfony/web-link": "^5.4 || ^6.2 || ^7.0"
|
||||||
|
},
|
||||||
|
"type": "symfony-bundle",
|
||||||
|
"extra": {
|
||||||
|
"thanks": {
|
||||||
|
"url": "https://github.com/symfony/webpack-encore",
|
||||||
|
"name": "symfony/webpack-encore"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Symfony\\WebpackEncoreBundle\\": "src"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"MIT"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Symfony Community",
|
||||||
|
"homepage": "https://symfony.com/contributors"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "Integration of your Symfony app with Webpack Encore",
|
||||||
|
"support": {
|
||||||
|
"issues": "https://github.com/symfony/webpack-encore-bundle/issues",
|
||||||
|
"source": "https://github.com/symfony/webpack-encore-bundle/tree/v2.2.0"
|
||||||
|
},
|
||||||
|
"funding": [
|
||||||
|
{
|
||||||
|
"url": "https://symfony.com/sponsor",
|
||||||
|
"type": "custom"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"url": "https://github.com/fabpot",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
|
||||||
|
"type": "tidelift"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"time": "2024-10-02T07:27:19+00:00"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "symfony/yaml",
|
"name": "symfony/yaml",
|
||||||
"version": "v7.1.11",
|
"version": "v7.1.11",
|
||||||
|
|
|
@ -11,6 +11,7 @@ use Symfony\Bundle\MakerBundle\MakerBundle;
|
||||||
use Symfony\Bundle\SecurityBundle\SecurityBundle;
|
use Symfony\Bundle\SecurityBundle\SecurityBundle;
|
||||||
use Symfony\Bundle\TwigBundle\TwigBundle;
|
use Symfony\Bundle\TwigBundle\TwigBundle;
|
||||||
use Symfony\Bundle\WebProfilerBundle\WebProfilerBundle;
|
use Symfony\Bundle\WebProfilerBundle\WebProfilerBundle;
|
||||||
|
use Symfony\WebpackEncoreBundle\WebpackEncoreBundle;
|
||||||
|
|
||||||
return [
|
return [
|
||||||
FrameworkBundle::class => [
|
FrameworkBundle::class => [
|
||||||
|
@ -49,4 +50,7 @@ return [
|
||||||
'dev' => true,
|
'dev' => true,
|
||||||
'test' => true,
|
'test' => true,
|
||||||
],
|
],
|
||||||
|
WebpackEncoreBundle::class => [
|
||||||
|
'all' => true,
|
||||||
|
],
|
||||||
];
|
];
|
||||||
|
|
|
@ -1,16 +1,13 @@
|
||||||
<?php declare(strict_types=1);
|
<?php declare(strict_types=1);
|
||||||
|
|
||||||
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
|
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
|
||||||
|
use Symfony\Config\Framework\RouterConfig;
|
||||||
|
|
||||||
return static function (ContainerConfigurator $containerConfigurator): void {
|
return static function (
|
||||||
$containerConfigurator->extension('framework', [
|
RouterConfig $routerConfig,
|
||||||
'router' => null,
|
ContainerConfigurator $containerConfigurator
|
||||||
]);
|
): void {
|
||||||
if ($containerConfigurator->env() === 'prod') {
|
if ($containerConfigurator->env() === 'prod') {
|
||||||
$containerConfigurator->extension('framework', [
|
$routerConfig->strictRequirements(false);
|
||||||
'router' => [
|
|
||||||
'strict_requirements' => null,
|
|
||||||
],
|
|
||||||
]);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,17 +1,13 @@
|
||||||
<?php declare(strict_types=1);
|
<?php declare(strict_types=1);
|
||||||
|
|
||||||
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
|
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
|
||||||
|
use Symfony\Config\TwigConfig;
|
||||||
|
|
||||||
return static function (ContainerConfigurator $containerConfigurator): void {
|
return static function (TwigConfig $twigConfig, ContainerConfigurator $c): void {
|
||||||
$containerConfigurator->extension('twig', [
|
$twigConfig->fileNamePattern('*.twig');
|
||||||
'file_name_pattern' => '*.twig',
|
$twigConfig->global('favicon', '@App\Service\Favicon');
|
||||||
'globals' => [
|
$twigConfig->formThemes(['bootstrap_5_layout.html.twig']);
|
||||||
'favicon' => '@App\Service\Favicon',
|
if ($c->env() === 'test') {
|
||||||
],
|
$twigConfig->strictVariables(true);
|
||||||
]);
|
|
||||||
if ($containerConfigurator->env() === 'test') {
|
|
||||||
$containerConfigurator->extension('twig', [
|
|
||||||
'strict_variables' => true,
|
|
||||||
]);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
10
config/packages/webpack_encore.php
Normal file
10
config/packages/webpack_encore.php
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
<?php declare(strict_types=1);
|
||||||
|
|
||||||
|
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
|
||||||
|
use Symfony\Config\WebpackEncoreConfig;
|
||||||
|
|
||||||
|
return static function (WebpackEncoreConfig $webpackEncoreConfig, ContainerConfigurator $containerConfigurator): void {
|
||||||
|
$webpackEncoreConfig->outputPath('%kernel.project_dir%/public/build');
|
||||||
|
$webpackEncoreConfig->scriptAttributes('defer', true);
|
||||||
|
$webpackEncoreConfig->cache('%kernel.debug%');
|
||||||
|
};
|
9051
package-lock.json
generated
Normal file
9051
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load diff
37
package.json
Normal file
37
package.json
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
{
|
||||||
|
"devDependencies": {
|
||||||
|
"@babel/core": "^7.24.0",
|
||||||
|
"@babel/preset-env": "^7.24.0",
|
||||||
|
"@symfony/webpack-encore": "^4.5.0",
|
||||||
|
"autoprefixer": "^10.4.21",
|
||||||
|
"core-js": "^3.36.0",
|
||||||
|
"css-loader": "^7.1.2",
|
||||||
|
"file-loader": "^6.2.0",
|
||||||
|
"postcss-loader": "^8.1.1",
|
||||||
|
"regenerator-runtime": "^0.14.1",
|
||||||
|
"sass": "^1.87.0",
|
||||||
|
"sass-loader": "^14.2.1",
|
||||||
|
"style-loader": "^4.0.0",
|
||||||
|
"webpack": "^5.90.3",
|
||||||
|
"webpack-cli": "^5.1.4",
|
||||||
|
"webpack-notifier": "^1.15.0"
|
||||||
|
},
|
||||||
|
"license": "UNLICENSED",
|
||||||
|
"private": true,
|
||||||
|
"scripts": {
|
||||||
|
"dev-server": "encore dev-server",
|
||||||
|
"dev": "encore dev",
|
||||||
|
"watch": "encore dev --watch",
|
||||||
|
"build": "encore production --progress"
|
||||||
|
},
|
||||||
|
"browserslist": [
|
||||||
|
"> 0.5%",
|
||||||
|
"last 2 versions",
|
||||||
|
"Firefox ESR",
|
||||||
|
"not dead"
|
||||||
|
],
|
||||||
|
"dependencies": {
|
||||||
|
"@popperjs/core": "^2.11.8",
|
||||||
|
"bootstrap": "^5.3.5"
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,965 +0,0 @@
|
||||||
/* SPDX-License-Identifier: MIT
|
|
||||||
SPDX-FileCopyrightText: Copyright (c) 2022-2025 zichy
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Custom properties
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
:root {
|
|
||||||
--f-sans: ui-sans-serif, sans-serif;
|
|
||||||
|
|
||||||
--f-body: ui-serif;
|
|
||||||
--f-heading: var(--f-sans);
|
|
||||||
--f-form: var(--f-sans);
|
|
||||||
--f-code: ui-monospace;
|
|
||||||
|
|
||||||
--f-size: clamp(1.6rem, 1.75vw, 2rem);
|
|
||||||
--f-size-small: 0.85em;
|
|
||||||
--f-size-large: 1.25em;
|
|
||||||
--f-line: 1.5;
|
|
||||||
|
|
||||||
--c-gray: #666;
|
|
||||||
--c-red: #b30;
|
|
||||||
--c-yellow: #fe9;
|
|
||||||
|
|
||||||
--i-triangle: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 10"%3E%3Cpolygon fill="black" points="5 10 10 0 0 0"/%3E%3C/svg%3E');
|
|
||||||
|
|
||||||
--w-body: 80ch;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Dark theme */
|
|
||||||
|
|
||||||
@media (prefers-color-scheme: dark) {
|
|
||||||
:root {
|
|
||||||
--c-gray: #999;
|
|
||||||
--c-red: #f99;
|
|
||||||
--c-yellow: #ff9;
|
|
||||||
|
|
||||||
--i-triangle: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 10"%3E%3Cpolygon fill="white" points="5 10 10 0 0 0"/%3E%3C/svg%3E');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Globals
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Box sizing */
|
|
||||||
|
|
||||||
*,
|
|
||||||
*::before,
|
|
||||||
*::after {
|
|
||||||
box-sizing: border-box;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Text rendering */
|
|
||||||
|
|
||||||
* {
|
|
||||||
-webkit-font-smoothing: antialiased;
|
|
||||||
text-rendering: optimizeLegibility;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Interaction */
|
|
||||||
|
|
||||||
::selection {
|
|
||||||
background: Highlight;
|
|
||||||
color: HighlightText;
|
|
||||||
text-shadow: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
*:focus {
|
|
||||||
outline: 2px solid LinkText;
|
|
||||||
outline-offset: 0.25rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Font size & Scrolling */
|
|
||||||
|
|
||||||
html {
|
|
||||||
font-size: 62.5%;
|
|
||||||
scroll-behavior: smooth;
|
|
||||||
scroll-padding-top: 2rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Backdrop */
|
|
||||||
|
|
||||||
::backdrop {
|
|
||||||
background-color: rgba(255, 255, 255, 0.6);
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (prefers-color-scheme: dark) {
|
|
||||||
::backdrop {
|
|
||||||
background-color: rgba(0, 0, 0, 0.6);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Hidden elements */
|
|
||||||
|
|
||||||
[hidden] {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Print spacing */
|
|
||||||
|
|
||||||
@page {
|
|
||||||
margin: 15mm 20mm;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Body
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Colors & Typography */
|
|
||||||
|
|
||||||
body {
|
|
||||||
background-color: Canvas;
|
|
||||||
color: CanvasText;
|
|
||||||
font-size: var(--f-size);
|
|
||||||
font-family: var(--f-body);
|
|
||||||
line-height: var(--f-line);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Body sizing */
|
|
||||||
|
|
||||||
@media screen {
|
|
||||||
body {
|
|
||||||
max-width: var(--w-body, 100%);
|
|
||||||
min-width: 320px;
|
|
||||||
padding: 2rem;
|
|
||||||
margin: 0 auto;
|
|
||||||
overflow-x: hidden;
|
|
||||||
overflow-y: scroll;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Print colors */
|
|
||||||
|
|
||||||
@media print {
|
|
||||||
body {
|
|
||||||
background-color: white;
|
|
||||||
color: black;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Links
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
a:any-link {
|
|
||||||
color: LinkText;
|
|
||||||
text-decoration: underline;
|
|
||||||
text-decoration-thickness: 0.125em;
|
|
||||||
}
|
|
||||||
|
|
||||||
a:any-link:hover {
|
|
||||||
background-color: LinkText;
|
|
||||||
color: Canvas;
|
|
||||||
text-decoration-line: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media print {
|
|
||||||
a[href^="http"]::after {
|
|
||||||
content: ' ('attr(href)')';
|
|
||||||
font-size: var(--f-size-small);
|
|
||||||
word-break: break-all;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Media
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Reset */
|
|
||||||
|
|
||||||
:where(iframe, img, svg, canvas, audio, video) {
|
|
||||||
display: block;
|
|
||||||
max-width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media print {
|
|
||||||
:where(audio, video) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
figure {
|
|
||||||
margin-inline: 0;
|
|
||||||
break-inside: avoid;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Image */
|
|
||||||
|
|
||||||
img {
|
|
||||||
height: auto;
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
|
|
||||||
img::before {
|
|
||||||
content: '';
|
|
||||||
background-color: Highlight;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen {
|
|
||||||
picture img {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Video */
|
|
||||||
|
|
||||||
video {
|
|
||||||
width: 100%;
|
|
||||||
height: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Iframe */
|
|
||||||
|
|
||||||
iframe {
|
|
||||||
border-style: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Headings
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
:where(h1, h2, h3, h4, h5, h6) {
|
|
||||||
font-family: var(--f-heading);
|
|
||||||
line-height: calc(var(--f-line) / 1.25);
|
|
||||||
hyphens: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
:where(h3, h5) {
|
|
||||||
color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
:where(h4, h5, h6) {
|
|
||||||
text-transform: uppercase;
|
|
||||||
}
|
|
||||||
|
|
||||||
:where(h2, h3, h4, h5, h6):target {
|
|
||||||
background-color: var(--c-yellow);
|
|
||||||
color: MarkText;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Lists
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
:where(ul, ol) {
|
|
||||||
padding-inline-start: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul {
|
|
||||||
list-style-type: disc;
|
|
||||||
}
|
|
||||||
|
|
||||||
li::marker {
|
|
||||||
color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
li p {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Description */
|
|
||||||
|
|
||||||
dt {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Navigation */
|
|
||||||
|
|
||||||
nav ul {
|
|
||||||
display: flex;
|
|
||||||
flex-wrap: wrap;
|
|
||||||
gap: 0.5rem 2rem;
|
|
||||||
list-style-type: none;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media print {
|
|
||||||
nav {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Inline elements
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Bold text */
|
|
||||||
|
|
||||||
:where(b, strong) {
|
|
||||||
font-weight: bolder;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Small text */
|
|
||||||
|
|
||||||
small {
|
|
||||||
font-size: var(--f-size-small);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Mark */
|
|
||||||
|
|
||||||
mark {
|
|
||||||
background-color: var(--c-yellow);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Abbreviation */
|
|
||||||
|
|
||||||
abbr[title] {
|
|
||||||
text-decoration-line: underline;
|
|
||||||
text-decoration-style: dotted;
|
|
||||||
cursor: help;
|
|
||||||
}
|
|
||||||
|
|
||||||
a abbr[title] {
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Subscript & Superscript */
|
|
||||||
|
|
||||||
:where(sub, sup) {
|
|
||||||
line-height: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Quote */
|
|
||||||
|
|
||||||
q {
|
|
||||||
font-style: italic;
|
|
||||||
quotes: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Keyboard input */
|
|
||||||
|
|
||||||
kbd {
|
|
||||||
background: linear-gradient(0deg, Canvas 0%, ButtonFace 100%);
|
|
||||||
font-size: var(--f-size-small);
|
|
||||||
font-family: var(--f-sans);
|
|
||||||
font-weight: bold;
|
|
||||||
padding: 0.2em 0.4em;
|
|
||||||
border-radius: 0.5rem;
|
|
||||||
box-shadow: 1px 1px 1px 0px var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Ruby annotation
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
rt {
|
|
||||||
color: var(--c-gray);
|
|
||||||
font-family: var(--f-sans);
|
|
||||||
letter-spacing: -0.05em;
|
|
||||||
padding: 0 0.25em;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Horizontal rule
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
hr {
|
|
||||||
height: 0;
|
|
||||||
margin: 2em 0;
|
|
||||||
border: 0;
|
|
||||||
border-top: 2px solid var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Blockquote
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
blockquote {
|
|
||||||
font-size: var(--f-size-large);
|
|
||||||
font-style: italic;
|
|
||||||
line-height: calc(var(--f-line) / 1.25);
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
blockquote > *:first-child {
|
|
||||||
margin-block-start: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
blockquote > *:last-child {
|
|
||||||
margin-block-end: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Captions
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
:where(caption, figcaption) {
|
|
||||||
color: var(--c-gray);
|
|
||||||
font-family: var(--f-heading);
|
|
||||||
font-size: var(--f-size-small);
|
|
||||||
font-style: italic;
|
|
||||||
margin-block-start: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
caption {
|
|
||||||
text-align: left;
|
|
||||||
caption-side: bottom;
|
|
||||||
}
|
|
||||||
|
|
||||||
[dir='rtl' i] caption {
|
|
||||||
text-align: right;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Code
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
:where(pre, code, samp, var) {
|
|
||||||
background-color: ButtonFace;
|
|
||||||
}
|
|
||||||
|
|
||||||
:where(code, samp, var) {
|
|
||||||
font-size: var(--f-size-small);
|
|
||||||
font-family: var(--f-code);
|
|
||||||
padding: 0.2em 0.4em;
|
|
||||||
}
|
|
||||||
|
|
||||||
pre {
|
|
||||||
font-size: var(--f-size-small);
|
|
||||||
padding: 2rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen {
|
|
||||||
pre {
|
|
||||||
overflow-x: scroll;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pre code {
|
|
||||||
background-color: transparent;
|
|
||||||
display: block;
|
|
||||||
white-space: pre-wrap;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Details
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
details {
|
|
||||||
background-color: ButtonFace;
|
|
||||||
padding: 2rem;
|
|
||||||
margin: 1em 0;
|
|
||||||
border-radius: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
details > *:nth-child(2) {
|
|
||||||
margin-block-start: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
details > *:last-child {
|
|
||||||
margin-block-end: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
summary {
|
|
||||||
color: LinkText;
|
|
||||||
font-family: var(--f-heading);
|
|
||||||
font-weight: bold;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
summary:hover {
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
|
|
||||||
details[open] summary {
|
|
||||||
margin-block-end: 2rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Aside
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
aside {
|
|
||||||
color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 769px) {
|
|
||||||
aside {
|
|
||||||
font-size: var(--f-size-small);
|
|
||||||
float: right;
|
|
||||||
width: calc(var(--w-body) / 2.5);
|
|
||||||
padding-block-end: 2rem;
|
|
||||||
padding-inline-start: 4rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
aside > *:first-child {
|
|
||||||
margin-block-start: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
aside > *:last-child {
|
|
||||||
margin-block-end: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Table
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
table {
|
|
||||||
width: 100%;
|
|
||||||
margin: 1em 0;
|
|
||||||
border-collapse: collapse;
|
|
||||||
border-spacing: 0;
|
|
||||||
break-inside: avoid;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (max-width: 768px) {
|
|
||||||
table {
|
|
||||||
display: block;
|
|
||||||
overflow-x: auto;
|
|
||||||
overflow-y: hidden;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
thead {
|
|
||||||
border-bottom: 2px solid var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
tbody tr:nth-child(odd) {
|
|
||||||
background-color: ButtonFace;
|
|
||||||
}
|
|
||||||
|
|
||||||
tfoot {
|
|
||||||
border-top: 2px solid var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
:where(th, td) {
|
|
||||||
padding: 0.5rem 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 768px) {
|
|
||||||
:where(th, td) {
|
|
||||||
min-width: 10rem;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
th {
|
|
||||||
font-family: var(--f-heading);
|
|
||||||
text-align: left;
|
|
||||||
vertical-align: bottom;
|
|
||||||
}
|
|
||||||
|
|
||||||
[dir='rtl' i] th {
|
|
||||||
text-align: right;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Forms & Inputs
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Reset */
|
|
||||||
|
|
||||||
:where(input, textarea, select, button, progress) {
|
|
||||||
-webkit-appearance: none;
|
|
||||||
background-color: transparent;
|
|
||||||
break-inside: avoid;
|
|
||||||
}
|
|
||||||
|
|
||||||
:where(input, textarea, select, button) {
|
|
||||||
font-family: var(--f-form);
|
|
||||||
font-size: 1em;
|
|
||||||
border-radius: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
:where(input:not([type='button' i]):not([type='submit' i]):not([type='reset' i]):not([type='checkbox' i]):not([type='radio' i]):not([type='image' i]), textarea, select) {
|
|
||||||
color: CanvasText;
|
|
||||||
font-size: var(--f-size-small);
|
|
||||||
display: block;
|
|
||||||
width: 100%;
|
|
||||||
padding: 0.75rem 1rem;
|
|
||||||
border: 2px solid LinkText;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Placeholder */
|
|
||||||
|
|
||||||
::placeholder {
|
|
||||||
color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Fieldset */
|
|
||||||
|
|
||||||
fieldset {
|
|
||||||
padding: 2rem;
|
|
||||||
border: 2px solid LinkText;
|
|
||||||
border-radius: 0.5rem;
|
|
||||||
break-inside: avoid;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Label & Legend */
|
|
||||||
|
|
||||||
:where(legend, label) {
|
|
||||||
font-family: var(--f-form);
|
|
||||||
font-weight: bold;
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
legend {
|
|
||||||
padding: 0 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
:where(legend, label) small {
|
|
||||||
color: var(--c-gray);
|
|
||||||
font-weight: normal;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Textarea */
|
|
||||||
|
|
||||||
textarea {
|
|
||||||
resize: vertical;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Checkbox & Radio input */
|
|
||||||
|
|
||||||
label:has([type='checkbox' i], [type='radio' i]) {
|
|
||||||
font-family: var(--f-form);
|
|
||||||
font-size: var(--f-size-small);
|
|
||||||
font-weight: normal;
|
|
||||||
display: grid;
|
|
||||||
grid-template-columns: 1.25em 1fr;
|
|
||||||
column-gap: 0.5em;
|
|
||||||
padding-block-end: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
label:has([type='checkbox' i][disabled], [type='radio' i][disabled]) {
|
|
||||||
color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
:where([type='checkbox' i], [type='radio' i]) {
|
|
||||||
width: 1.25em;
|
|
||||||
height: 1.25em;
|
|
||||||
position: relative;
|
|
||||||
margin: 0.2rem 0 0;
|
|
||||||
border: 2px solid LinkText;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
[type='radio' i] {
|
|
||||||
border-radius: 50%;
|
|
||||||
}
|
|
||||||
|
|
||||||
:where([type='checkbox' i], [type='radio' i]):checked {
|
|
||||||
background-color: LinkText;
|
|
||||||
}
|
|
||||||
|
|
||||||
[type='checkbox' i]:checked::after {
|
|
||||||
content: '\2713';
|
|
||||||
color: Canvas;
|
|
||||||
font-family: var(--f-form);
|
|
||||||
font-weight: bold;
|
|
||||||
line-height: 1;
|
|
||||||
position: absolute;
|
|
||||||
top: 50%;
|
|
||||||
left: 50%;
|
|
||||||
transform: translate(-50%, -50%);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Color input */
|
|
||||||
|
|
||||||
[type='color' i] {
|
|
||||||
height: 4rem;
|
|
||||||
padding: 0.5rem;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
::-webkit-color-swatch-wrapper {
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
::-webkit-color-swatch {
|
|
||||||
border: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
::-moz-color-swatch {
|
|
||||||
border: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Range input */
|
|
||||||
|
|
||||||
[type='range' i] {
|
|
||||||
margin: 1.25rem 0 0;
|
|
||||||
padding: 0;
|
|
||||||
border: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
[type='range' i]:focus {
|
|
||||||
outline: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
::-webkit-slider-runnable-track {
|
|
||||||
background-color: LinkText;
|
|
||||||
height: 4px;
|
|
||||||
border-radius: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
[disabled]::-webkit-slider-runnable-track {
|
|
||||||
background-color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
::-moz-range-track {
|
|
||||||
background-color: LinkText;
|
|
||||||
height: 4px;
|
|
||||||
border-radius: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
[disabled]::-moz-range-track {
|
|
||||||
background-color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
::-webkit-slider-thumb {
|
|
||||||
-webkit-appearance: none;
|
|
||||||
appearance: none;
|
|
||||||
background-color: Canvas;
|
|
||||||
height: 2rem;
|
|
||||||
width: 2rem;
|
|
||||||
margin-block-start: calc(-1rem + 2px);
|
|
||||||
border: 2px solid LinkText;
|
|
||||||
border-radius: 50%;
|
|
||||||
cursor: ew-resize;
|
|
||||||
}
|
|
||||||
|
|
||||||
[disabled]::-webkit-slider-thumb {
|
|
||||||
border-color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
[type='range' i]:focus::-webkit-slider-thumb {
|
|
||||||
outline: 2px solid LinkText;
|
|
||||||
outline-offset: 0.25rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
::-moz-range-thumb {
|
|
||||||
appearance: none;
|
|
||||||
background-color: Canvas;
|
|
||||||
height: 2rem;
|
|
||||||
width: 2rem;
|
|
||||||
margin-block-start: calc(-1rem + 2px);
|
|
||||||
border: 2px solid LinkText;
|
|
||||||
border-radius: 50%;
|
|
||||||
cursor: ew-resize;
|
|
||||||
}
|
|
||||||
|
|
||||||
[disabled]::-moz-range-thumb {
|
|
||||||
border-color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
[type='range' i]:focus::-moz-range-thumb {
|
|
||||||
outline: 2px solid LinkText;
|
|
||||||
outline-offset: 0.25rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Select */
|
|
||||||
|
|
||||||
select {
|
|
||||||
background: Canvas var(--i-triangle) no-repeat calc(100% - 1rem) center / 1.5rem;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
white-space: nowrap;
|
|
||||||
padding-inline-end: 3.5rem;
|
|
||||||
overflow: hidden;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
[dir='rtl' i] select {
|
|
||||||
background-position: 1rem center;
|
|
||||||
padding-inline: 3.5rem 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
select[multiple] {
|
|
||||||
background-image: none;
|
|
||||||
padding-inline-end: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Buttons */
|
|
||||||
|
|
||||||
:where(button, [type='button' i], [type='submit' i], [type='reset' i]) {
|
|
||||||
font-size: var(--f-size-small);
|
|
||||||
font-weight: bold;
|
|
||||||
text-align: center;
|
|
||||||
text-decoration: none;
|
|
||||||
line-height: 1;
|
|
||||||
display: inline-block;
|
|
||||||
min-width: 5rem;
|
|
||||||
padding: 0.2em 0.4em;
|
|
||||||
border: 2px solid LinkText;
|
|
||||||
-webkit-user-select: text;
|
|
||||||
user-select: text;
|
|
||||||
cursor: pointer;
|
|
||||||
touch-action: manipulation;
|
|
||||||
}
|
|
||||||
|
|
||||||
:where(button:not([disabled]), [type='button' i]:not([disabled]), [type='submit' i]:not([disabled]), [type='reset' i]:not([disabled])):hover {
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen {
|
|
||||||
:where(button, [type='button' i], [type='submit' i], [type='reset' i]) {
|
|
||||||
background-color: LinkText;
|
|
||||||
color: Canvas;
|
|
||||||
}
|
|
||||||
|
|
||||||
:where(button[disabled], [type='button' i][disabled], [type='submit' i][disabled], [type='reset' i][disabled]) {
|
|
||||||
background-color: var(--c-gray);
|
|
||||||
color: currentColor;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
form :where(button, [type='button' i], [type='submit' i], [type='reset' i]) {
|
|
||||||
padding: 1rem 1.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Meter & Progress */
|
|
||||||
|
|
||||||
:where(meter, progress) {
|
|
||||||
width: 100%;
|
|
||||||
height: 3rem;
|
|
||||||
border: 2px solid var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
label + :where(meter, progress) {
|
|
||||||
margin-block-start: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
meter {
|
|
||||||
background: transparent;
|
|
||||||
display: block;
|
|
||||||
margin-block-end: 1em;
|
|
||||||
border: 2px solid var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
::-webkit-meter-bar {
|
|
||||||
background: Canvas;
|
|
||||||
height: 3rem;
|
|
||||||
border: 2px solid var(--c-gray);
|
|
||||||
border-radius: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
::-webkit-progress-bar {
|
|
||||||
background-color: Canvas;
|
|
||||||
}
|
|
||||||
|
|
||||||
::-moz-progress-bar {
|
|
||||||
background-color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
::-webkit-progress-value {
|
|
||||||
background-color: var(--c-gray);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Disabled state */
|
|
||||||
|
|
||||||
[disabled] {
|
|
||||||
border-color: var(--c-gray);
|
|
||||||
cursor: not-allowed;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Error state */
|
|
||||||
|
|
||||||
[aria-invalid] {
|
|
||||||
border-color: var(--c-red) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
[aria-invalid]:focus {
|
|
||||||
outline-color: var(--c-red);
|
|
||||||
}
|
|
||||||
|
|
||||||
[aria-invalid] + p[id] {
|
|
||||||
color: var(--c-red);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Form spacing */
|
|
||||||
|
|
||||||
form label:not(:first-of-type) {
|
|
||||||
margin-block-start: 3rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
form label + :where(input, textarea, select) {
|
|
||||||
margin-block-start: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
form fieldset {
|
|
||||||
margin: 3rem 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
fieldset label:not(:first-of-type) {
|
|
||||||
margin-block-start: 2rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
form p[id] {
|
|
||||||
margin-block-start: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Dialog
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
dialog[open] {
|
|
||||||
background-color: Canvas;
|
|
||||||
color: currentColor;
|
|
||||||
display: block;
|
|
||||||
max-width: var(--w-body, 100%);
|
|
||||||
min-width: calc(var(--w-body) / 2);
|
|
||||||
padding: 2rem;
|
|
||||||
border: 2px solid var(--c-gray);
|
|
||||||
border-radius: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
body:has(dialog[open]) {
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
dialog:not([open]) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
dialog > *:first-child {
|
|
||||||
margin-block-start: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
dialog > *:last-child {
|
|
||||||
margin-block-end: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Opinionated layout
|
|
||||||
========================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
@media screen {
|
|
||||||
body > header {
|
|
||||||
margin-block-end: 4em;
|
|
||||||
}
|
|
||||||
|
|
||||||
main > :where(section, article),
|
|
||||||
body > footer {
|
|
||||||
margin-block-start: 4em;
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
body > footer {
|
|
||||||
margin-block-start: 4em;
|
|
||||||
}
|
|
||||||
}
|
|
1
public/static/css/new.min.css
vendored
1
public/static/css/new.min.css
vendored
|
@ -1 +0,0 @@
|
||||||
blockquote,header{background:var(--nc-bg-2)}dt,summary,table caption{font-weight:700}img,pre,textarea{max-width:100%}:root{--nc-font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,Cantarell,'Open Sans','Helvetica Neue',sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";--nc-font-mono:Consolas,monaco,'Ubuntu Mono','Liberation Mono','Courier New',Courier,monospace;--nc-tx-1:#000000;--nc-tx-2:#1A1A1A;--nc-bg-1:#FFFFFF;--nc-bg-2:#F6F8FA;--nc-bg-3:#E5E7EB;--nc-lk-1:#0070F3;--nc-lk-2:#0366D6;--nc-lk-tx:#FFFFFF;--nc-ac-1:#79FFE1;--nc-ac-tx:#0C4047;--nc-d-tx-1:#ffffff;--nc-d-tx-2:#eeeeee;--nc-d-bg-1:#000000;--nc-d-bg-2:#111111;--nc-d-bg-3:#222222;--nc-d-lk-1:#3291FF;--nc-d-lk-2:#0070F3;--nc-d-lk-tx:#FFFFFF;--nc-d-ac-1:#7928CA;--nc-d-ac-tx:#FFFFFF}@media (prefers-color-scheme:dark){:root{--nc-tx-1:var(--nc-d-tx-1);--nc-tx-2:var(--nc-d-tx-2);--nc-bg-1:var(--nc-d-bg-1);--nc-bg-2:var(--nc-d-bg-2);--nc-bg-3:var(--nc-d-bg-3);--nc-lk-1:var(--nc-d-lk-1);--nc-lk-2:var(--nc-d-lk-2);--nc-lk-tx:var(--nc--dlk-tx);--nc-ac-1:var(--nc-d-ac-1);--nc-ac-tx:var(--nc--dac-tx)}}*{margin:0;padding:0}address,area,article,aside,audio,blockquote,datalist,details,dl,fieldset,figure,form,iframe,img,input,meter,nav,ol,optgroup,option,output,p,pre,progress,ruby,section,table,textarea,ul,video{margin-bottom:1rem}button,html,input,select{font-family:var(--nc-font-sans)}body{margin:0 auto;max-width:750px;padding:2rem;border-radius:6px;overflow-x:hidden;word-break:break-word;overflow-wrap:break-word;background:var(--nc-bg-1);color:var(--nc-tx-2);font-size:1.03rem;line-height:1.5}::selection{background:var(--nc-ac-1);color:var(--nc-ac-tx)}h1,h2,h3,h4,h5,h6{line-height:1;color:var(--nc-tx-1);padding-top:.875rem}h1,h2,h3{color:var(--nc-tx-1);padding-bottom:2px;margin-bottom:8px;border-bottom:1px solid var(--nc-bg-2)}h4,h5,h6{margin-bottom:.3rem}h1{font-size:2.25rem}h2{font-size:1.85rem}h3{font-size:1.55rem}h4{font-size:1.25rem}h5{font-size:1rem}h6{font-size:.875rem}a{color:var(--nc-lk-1)}a:hover{color:var(--nc-lk-2)}abbr,abbr:hover{cursor:help}blockquote{padding:1.5rem;border-left:5px solid var(--nc-bg-3)}blockquote :last-child{padding-bottom:0;margin-bottom:0}header{border-bottom:1px solid var(--nc-bg-3);padding:2rem 1.5rem;margin:-2rem calc(50% - 50vw) 2rem;padding-left:calc(50vw - 50%);padding-right:calc(50vw - 50%)}header h1,header h2,header h3{padding-bottom:0;border-bottom:0}header>:first-child{margin-top:0;padding-top:0}a img,details[open]>:last-child,header>:last-child,ol ol,ol ul,ul ol,ul ul{margin-bottom:0}a button,button,input[type=button],input[type=reset],input[type=submit]{font-size:1rem;display:inline-block;padding:6px 12px;text-align:center;text-decoration:none;white-space:nowrap;background:var(--nc-lk-1);color:var(--nc-lk-tx);border:0;border-radius:4px;box-sizing:border-box;cursor:pointer;color:var(--nc-lk-tx)}a button[disabled],button[disabled],input[type=button][disabled],input[type=reset][disabled],input[type=submit][disabled]{opacity:.5;cursor:not-allowed}.button:enabled:hover,.button:focus,button:enabled:hover,button:focus,input[type=button]:enabled:hover,input[type=button]:focus,input[type=reset]:enabled:hover,input[type=reset]:focus,input[type=submit]:enabled:hover,input[type=submit]:focus{background:var(--nc-lk-2)}code,details,input,kbd,pre,samp,select,textarea,th,tr:nth-child(2n){background:var(--nc-bg-2)}code,kbd,pre,samp{font-family:var(--nc-font-mono);border:1px solid var(--nc-bg-3);border-radius:4px;padding:3px 6px;font-size:.9em}code pre,pre code{background:inherit;font-size:inherit;color:inherit;border:0;padding:0;margin:0}details,fieldset{border:1px solid var(--nc-bg-3)}kbd{border-bottom:3px solid var(--nc-bg-3)}pre{padding:1rem 1.4rem;overflow:auto}code pre{display:inline}details{padding:.6rem 1rem;border-radius:4px}summary{cursor:pointer}details[open]{padding-bottom:.75rem}details[open] summary{margin-bottom:6px}dd::before{content:'→ '}hr{border:0;border-bottom:1px solid var(--nc-bg-3);margin:1rem auto}fieldset{margin-top:1rem;padding:2rem;border-radius:4px}input,select,td,textarea,th{border:1px solid var(--nc-bg-3)}legend{padding:auto .5rem}table{border-collapse:collapse;width:100%}td,th{text-align:left;padding:.5rem}table caption{margin-bottom:.5rem}ol,ul{padding-left:2rem}li{margin-top:.4rem}mark{padding:3px 6px;background:var(--nc-ac-1);color:var(--nc-ac-tx)}input,select,textarea{padding:6px 12px;margin-bottom:.5rem;color:var(--nc-tx-2);border-radius:4px;box-shadow:none;box-sizing:border-box}
|
|
1
public/static/css/simple.min.css
vendored
1
public/static/css/simple.min.css
vendored
File diff suppressed because one or more lines are too long
1
public/static/css/water.min.css
vendored
1
public/static/css/water.min.css
vendored
File diff suppressed because one or more lines are too long
2
public/static/js/htmx.min.js
vendored
2
public/static/js/htmx.min.js
vendored
File diff suppressed because one or more lines are too long
16
symfony.lock
16
symfony.lock
|
@ -223,5 +223,21 @@
|
||||||
"config/packages/web_profiler.yaml",
|
"config/packages/web_profiler.yaml",
|
||||||
"config/routes/web_profiler.yaml"
|
"config/routes/web_profiler.yaml"
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
"symfony/webpack-encore-bundle": {
|
||||||
|
"version": "2.2",
|
||||||
|
"recipe": {
|
||||||
|
"repo": "github.com/symfony/recipes",
|
||||||
|
"branch": "main",
|
||||||
|
"version": "2.0",
|
||||||
|
"ref": "9ef5412a4a2a8415aca3a3f2b4edd3866aab9a19"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"assets/app.js",
|
||||||
|
"assets/styles/app.css",
|
||||||
|
"config/packages/webpack_encore.yaml",
|
||||||
|
"package.json",
|
||||||
|
"webpack.config.js"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,44 +2,59 @@
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
<meta name="color-scheme" content="dark light">
|
<meta name="color-scheme" content="dark light">
|
||||||
<meta name="theme-color" content="#0000ff" media="(prefers-color-scheme: light)">
|
<meta name="theme-color" content="#0000ff" media="(prefers-color-scheme: light)">
|
||||||
<meta name="theme-color" content="#222222" media="(prefers-color-scheme: dark)">
|
<meta name="theme-color" content="#222222" media="(prefers-color-scheme: dark)">
|
||||||
<title>{% block title %}Welcome!{% endblock %}</title>
|
<title>{% block title %}Welcome!{% endblock %}</title>
|
||||||
<link rel="icon" type="image/svg+xml"
|
<link rel="icon" type="image/svg+xml"
|
||||||
href="{{ favicon }}" />
|
href="{{ favicon }}" />
|
||||||
{% set currentDate = "now"|date("d") %}
|
{# Use Encore assets for CSS and JS #}
|
||||||
{% if currentDate % 4 == 0 %}
|
{% block stylesheets %}
|
||||||
<link rel="stylesheet" href="/static/css/new.min.css">
|
{{ encore_entry_link_tags('app') }}
|
||||||
{% elseif currentDate % 4 == 1 %}
|
{% endblock %}
|
||||||
<link rel="stylesheet" href="/static/css/simple.min.css">
|
|
||||||
{% elseif currentDate % 4 == 2 %}
|
{% block javascripts %}
|
||||||
<link rel="stylesheet" href="/static/css/water.min.css">
|
{{ encore_entry_script_tags('app') }}
|
||||||
{% else %}
|
{% endblock %}
|
||||||
<link rel="stylesheet" href="/static/css/fieber.css">
|
|
||||||
{% endif %}
|
|
||||||
<style>
|
|
||||||
label{
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
<script src="/static/js/htmx.min.js"></script>
|
<script src="/static/js/htmx.min.js"></script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<header>
|
<header>
|
||||||
<p>Hello {{ app.request.cookies.get('username', 'nobody') }} - <a href="{{ path('username') }}">change name</a></p>
|
<nav class="navbar navbar-expand-lg navbar-light bg-light">
|
||||||
<nav>
|
<div class="container">
|
||||||
<a href="{{ path('app_food_order_index') }}">Orders</a> /
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
|
||||||
<a href="{{ path('app_food_vendor_index') }}">Vendors</a> /
|
<span class="navbar-toggler-icon"></span>
|
||||||
<a
|
</button>
|
||||||
href="https://git.hannover.ccc.de/lubiana/futtern/issues/new"
|
<div class="collapse navbar-collapse" id="navbarSupportedContent">
|
||||||
target="_blank"
|
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
|
||||||
>Create Issue</a> /
|
<li class="nav-item">
|
||||||
<a href="/api">API</a>
|
<a class="nav-link" href="{{ path('app_food_order_index') }}">Orders</a>
|
||||||
|
</li>
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="nav-link" href="{{ path('app_food_vendor_index') }}">Vendors</a>
|
||||||
|
</li>
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="nav-link" href="https://git.hannover.ccc.de/lubiana/futtern/issues/new" target="_blank">Create Issue</a>
|
||||||
|
</li>
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="nav-link" href="/api" target="_blank">API</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<div class="d-flex">
|
||||||
|
<span class="navbar-text me-2">
|
||||||
|
Hello {{ app.request.cookies.get('username', 'nobody') }}
|
||||||
|
<a href="{{ path('username') }}">Change name</a>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</nav>
|
</nav>
|
||||||
</header>
|
</header>
|
||||||
<main>
|
<main class="py-4">
|
||||||
{% block body %}{% endblock %}
|
<div class="container">
|
||||||
|
{% block body %}{% endblock %}
|
||||||
|
</div>
|
||||||
</main>
|
</main>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
hx-get="{{ path('app_food_order_new') }}"
|
hx-get="{{ path('app_food_order_new') }}"
|
||||||
hx-trigger="click"
|
hx-trigger="click"
|
||||||
hx-target="closest div"
|
hx-target="closest div"
|
||||||
|
class="btn btn-primary"
|
||||||
>Create new</button>
|
>Create new</button>
|
||||||
</div>
|
</div>
|
||||||
<hr>
|
<hr>
|
||||||
|
|
|
@ -1,2 +1,10 @@
|
||||||
{{ include('_form.html.twig') }}
|
<div class="card shadow-sm mb-4">
|
||||||
|
<div class="card-body">
|
||||||
|
{{ include('_form.html.twig') }}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<a href="{{ path('app_food_order_index') }}" class="btn btn-secondary">
|
||||||
|
<i class="bi bi-arrow-left"></i> Back to list
|
||||||
|
</a>
|
||||||
|
|
||||||
|
|
|
@ -3,30 +3,32 @@
|
||||||
{% block title %}New OrderItem{% endblock %}
|
{% block title %}New OrderItem{% endblock %}
|
||||||
|
|
||||||
{% block body %}
|
{% block body %}
|
||||||
<h1>Create new OrderItem</h1>
|
<h1 class="mb-4">Create new OrderItem</h1>
|
||||||
|
|
||||||
{{ include('order_item/_form.html.twig') }}
|
{{ include('order_item/_form.html.twig') }}
|
||||||
|
|
||||||
<hr />
|
<hr class="my-4" />
|
||||||
|
|
||||||
{% if food_order.foodVendor.menuLink != '' %}
|
{% if food_order.foodVendor.menuLink != '' %}
|
||||||
<a href="{{ food_order.foodVendor.menuLink }}" target="_blank">
|
<a href="{{ food_order.foodVendor.menuLink }}" class="btn btn-info mb-3" target="_blank">
|
||||||
External link to Menu
|
<i class="bi bi-link-45deg"></i> External link to Menu
|
||||||
</a>
|
</a>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
<div>
|
<div class="mb-3">
|
||||||
<b>click a button to select a given menuitem</b>
|
<b>Click a button to select a given menu item:</b>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div class="mb-4">
|
||||||
{% for menuItem in menuItems %}
|
{% for menuItem in menuItems %}
|
||||||
<a href="#" data-menu-item>{{ menuItem.name }}</a>
|
<a href="#" class="btn btn-outline-secondary me-2 mb-2" data-menu-item>{{ menuItem.name }}</a>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<hr />
|
<hr class="my-4" />
|
||||||
|
|
||||||
<a class="button" href="{{ path('app_food_order_show', { 'id': food_order.id}) }}">back to list</a>
|
<a class="btn btn-secondary" href="{{ path('app_food_order_show', { 'id': food_order.id}) }}">
|
||||||
|
<i class="bi bi-arrow-left"></i> Back to list
|
||||||
|
</a>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
document.querySelectorAll('[data-menu-item]').forEach(function(element) {
|
document.querySelectorAll('[data-menu-item]').forEach(function(element) {
|
||||||
|
|
84
webpack.config.js
Normal file
84
webpack.config.js
Normal file
|
@ -0,0 +1,84 @@
|
||||||
|
const Encore = require('@symfony/webpack-encore');
|
||||||
|
|
||||||
|
// Manually configure the runtime environment if not already configured yet by the "encore" command.
|
||||||
|
// It's useful when you use tools that rely on webpack.config.js file.
|
||||||
|
if (!Encore.isRuntimeEnvironmentConfigured()) {
|
||||||
|
Encore.configureRuntimeEnvironment(process.env.NODE_ENV || 'dev');
|
||||||
|
}
|
||||||
|
|
||||||
|
Encore
|
||||||
|
// directory where compiled assets will be stored
|
||||||
|
.setOutputPath('public/build/')
|
||||||
|
// public path used by the web server to access the output path
|
||||||
|
.setPublicPath('/build')
|
||||||
|
|
||||||
|
// only needed for CDN's or subdirectory deploy
|
||||||
|
//.setManifestKeyPrefix('build/')
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ENTRY CONFIG
|
||||||
|
*
|
||||||
|
* Each entry will result in one JavaScript file (e.g. app.js)
|
||||||
|
* and one CSS file (e.g. app.css) if your JavaScript imports CSS.
|
||||||
|
*/
|
||||||
|
.addEntry('app', './assets/app.js')
|
||||||
|
|
||||||
|
// enables the Symfony UX Stimulus bridge (used in assets/bootstrap.js)
|
||||||
|
//.enableStimulusBridge('./assets/controllers.json')
|
||||||
|
|
||||||
|
// When enabled, Webpack "splits" your files into smaller pieces for greater optimization.
|
||||||
|
.splitEntryChunks()
|
||||||
|
|
||||||
|
// will require an extra script tag for runtime.js
|
||||||
|
// but, you probably want this, unless you're building a single-page app
|
||||||
|
.enableSingleRuntimeChunk()
|
||||||
|
|
||||||
|
/*
|
||||||
|
* FEATURE CONFIG
|
||||||
|
*
|
||||||
|
* Enable & configure other features below. For a full
|
||||||
|
* list of features, see:
|
||||||
|
* https://symfony.com/doc/current/frontend.html#adding-more-features
|
||||||
|
*/
|
||||||
|
.cleanupOutputBeforeBuild()
|
||||||
|
.enableBuildNotifications()
|
||||||
|
.enableSourceMaps(!Encore.isProduction())
|
||||||
|
// enables hashed filenames (e.g. app.abc123.css)
|
||||||
|
.enableVersioning(Encore.isProduction())
|
||||||
|
|
||||||
|
// configure Babel
|
||||||
|
// .configureBabel((config) => {
|
||||||
|
// config.plugins.push('@babel/plugin-proposal-class-properties');
|
||||||
|
// })
|
||||||
|
|
||||||
|
// enables and configure @babel/preset-env polyfills
|
||||||
|
.configureBabelPresetEnv((config) => {
|
||||||
|
config.useBuiltIns = 'usage';
|
||||||
|
config.corejs = '3.36';
|
||||||
|
})
|
||||||
|
|
||||||
|
// enables Sass/SCSS support
|
||||||
|
.enableSassLoader()
|
||||||
|
|
||||||
|
// uncomment if you use TypeScript
|
||||||
|
//.enableTypeScriptLoader()
|
||||||
|
|
||||||
|
// uncomment to get integrity="..." attributes on your script & link tags
|
||||||
|
// requires WebpackEncoreBundle 1.4 or higher
|
||||||
|
//.enableIntegrityHashes(Encore.isProduction())
|
||||||
|
|
||||||
|
// Enable CSS and JS minification in production
|
||||||
|
.enablePostCssLoader((options) => {
|
||||||
|
options.postcssOptions = {
|
||||||
|
plugins: [
|
||||||
|
require('autoprefixer')
|
||||||
|
]
|
||||||
|
};
|
||||||
|
})
|
||||||
|
|
||||||
|
// When in production, minify CSS and JS automatically
|
||||||
|
// uncomment if you're having problems with a jQuery plugin
|
||||||
|
//.autoProvidejQuery()
|
||||||
|
;
|
||||||
|
|
||||||
|
module.exports = Encore.getWebpackConfig();
|
Loading…
Add table
Add a link
Reference in a new issue