Skip to content

Commit

Permalink
fix: doc errors
Browse files Browse the repository at this point in the history
  • Loading branch information
Vattghern203 committed Dec 11, 2023
1 parent 9627b12 commit 9cc7225
Show file tree
Hide file tree
Showing 4 changed files with 418 additions and 359 deletions.
340 changes: 32 additions & 308 deletions INSTRUCOES(PT-BR).md
Original file line number Diff line number Diff line change
@@ -1,328 +1,52 @@
# Akatsuki CSS

Akatsuki CSS is a flexible and highly customizable CSS framework with a wide range of presets. It is designed to cater to developers of all skill levels, providing an intuitive way to style elements without the need for additional tools like PostCSS or JavaScript.
O Akatsuki CSS é um framework CSS flexível e altamente personalizável com uma ampla gama de predefinições. Ele foi projetado para atender a desenvolvedores de todos os níveis de habilidade, proporcionando uma maneira intuitiva de estilizar elementos sem a necessidade de ferramentas adicionais como PostCSS ou JavaScript.

## Features
## Recursos

- Easily customizable elements
- Rich collection of presets
- No reliance on PostCSS or JavaScript for customization
- Dependency free
- Elementos facilmente personalizáveis
- Rica coleção de predefinições
- Sem dependência de PostCSS ou JavaScript para personalização
- Livre de dependências

## Getting Started
## Como Começar

To get started with Akatsuki CSS, follow these steps:
Para começar a usar o Akatsuki-CSS, siga estas etapas:

1. [Download](https://www.npmjs.com/package/yonaka) on NPM, clone the repository or use the [Jsdelivr](https://www.jsdelivr.com/package/npm/yonaka).
### JsDelivr

2. Add the `akatsuki.css` file to your project by importing it on your global CSS file.
```css
@import "node_modules/akatsuki-css/akatsuki.css"
```
1. Acesse o site [JsDelivr](https://www.jsdelivr.com/package/npm/yonaka)
2. Copie a tag HTML ou apenas a URL
3. Adicione ao seu código

or in the HTML
* HTML

```html
<link rel="stylesheet" href="node_modules/akatsuki-css/akatsuki.css" />
```
```html
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="stylesheet" href="src/styles/yonaka.css" /> <!--JsDelivr Here on top of the personal CSS-->
<link rel="stylesheet" href="src/styles/personal.css" /> <!--Personal CSS below here-->
<title>Cool Example 😎</title>
</head>
```

## Customizing
* CSS

- You can overwrite the default values of the variables, by simpling rewriting it in the `:root` or `html` selector. The default specifity is equals to 0
```css
@import url("https://cdn.jsdelivr.net/npm/yonaka/dist/yonaka.min.css");

- Also you can customize a variable for a single tag with the inline css
/*Sobrescreva os Estilos Aqui*/

* Ex: ```html <div style="--spacing: var(--lg)">Dummy Text</div>```

- Or you can use the inheritance on the parent selector

### Global Scoped Variables

#### Overview

Some of the variables used in the project.

```css
:where(:root) {
// GLOBAL SCOPED VARS

--roundness: auto; // The border-radius to everything
--spacing: .8rem; // the spacing between elements
--spacing-y: auto;
--spacing-x: auto;
--jump: .4rem; // the jump value between elements
--theme: dark; // the actual theme in the page
--width: auto; // the witdth of an element
--height: auto; // the height of an element

// SPACING VARS ---------------------------------

--xxs: .2rem; // 0.5 Extra Extra Small
--xs: .4rem; // 1.0 Extra Small
--sm: .8rem; // 2.0 Small
--md: 1.6rem; // 4.0 Medium
--lg: 3.2rem; // 6.0 Large
--xl: 6.4rem; // 8.0 Extra Large
--hg: 12.8rem; // 10.0 Huge

// COLOR PALETTE ---------------------------------

--text: #d9e5f7;
--background: #03070d;
--primary: #173c73;
--secondary: #081426;
--accent: #296cd1;

// Color created with the palette

--destructive: #772626;

// Blend Colors

--blend-text-color: #000;
--blend-back-color: #FFF;
--blend-highlight-color: #FFF;


// BREAKPOINTS ---------------------------------

--bp-sm: 40em;
--bp-md: 48em;
--bp-lg: 64em;
--bp-hg: 80em;

// TYPOGRAPHY ---------------------------------

--font-family: system-ui, 'Inter', 'Roboto';
--font-weight: 400;
--font-size: 1.6rem;
--line-height: 1.15;

}

// LIGHT THEME

[data-theme="light"] {
--text: #081426;
--background: #f3f6fc;
--primary: #8cb1e8;
--secondary: #d9e5f7;
--accent: #2e71d6;

--blend-text-color: #FFF;
--blend-back-color: #000;
--blend-highlight-color: #000;
}
```

#### Usage and Pattern

The framework uses variables for almost everithing, allowing the user to customize a big portion of the Akatsuki-CSS default styling, simulating a mini design system.

I've create a pattern that works like this.
1. I create the sub variables for example, to a border(color, width and it's style) _Experimental_

```css
--border-color: var(--primary) // red;
--border-size: var(--md) // 16px;
--border-style: solid;
```

2. Then I created the 'shorthand' border variable

```css
--border: var(--border-color) var(--border-size) var(--border-style);
```

3. After this I can create variations by changing the value of any of the above variables in the HTML element or even in the global CSS.

```html
<section style="--border-style: dotted">
<p>Lorem</p>
</section>
```

#### List of customizable variables

in progress

##### Customizing colors

To customize colors, I highly recommend using [realtimecolors](https://www.realtimecolors.com/?colors=e2f7f8-092425-41cbd2-061819-2db7be&fonts=Poppins-Poppins).

1. First go the site and use the dark mode option, then generate your desired palette(HEX colors recommended).
2. Click to export and toggle the option themes and copy the code.
3. Change it in the framework by overwritting it.

```css
:root {
--text: #e2f7f8;
--background: #092425;
--primary: #41cbd2;
--secondary: #061819;
--accent: #2db7be;
}

@media (prefers-color-scheme: light) {
:root {
--text: #071c1d;
--background: #daf5f6;
--primary: #2db7be;
--secondary: #e6f8f9;
--accent: #41cbd2;
--background: tomato;
}
}
```

with these colors, the framework will generate variants as: muted, foreground and etc...

```css
:where(:root) {
// Color created with the palette

--destructive: #772626;

// Blend Colors

--blend-text-color: #000;
--blend-back-color: #FFF;
--blend-highlight-color: #FFF;

// Content / Text

--content-text: color-mix(in oklab, var(--text), var(--blend-text-color) 20%);

//--inverted-text: filter:invert(1)

// Foregrounds

--muted-text: color-mix(in oklab, var(--text), var(--blend-text-color) 35%);

--foreground-text: color-mix(in oklab, var(--text), var(--blend-text-color) 35%);

--foreground-primary: color-mix(in oklab, var(--primary), var(--blend-text-color) 35%);

--foreground-background: color-mix(in oklab, var(--background), var(--blend-back-color) 15%);

--foreground-secondary: color-mix(in oklab, var(--secondary), var(--blend-back-color) 30%);

--foreground-accent: color-mix(in oklab, var(--accent), var(--blend-text-color) 35%);

--foreground-destructive: color-mix(in oklab, var(--destructive), var(--blend-back-color) 15%);
}
```

## Components

Akatsuki has a decent amount of components as: switches, headers, navs, buttons, accordions, drropdowns and cards.

To create them, the user must follow some "rules", because the css is very specific to avoid conflict with others selectors.

### Switch

```html
<label for="input__switch">

Default Switch

<input type="checkbox" id="input__switch" role="switch" aria-checked="false" />
</label>
```

- class variants: ```.squished and .squared```

### Accordion

```html
<details>
<summary>Accordion</summary>

<p>Accordion Text</p>
</details>
```

### Select

```html
<select>
<option value="" selected>Select</option>
<option value="">option 1</option>
<option value="">option 2</option>
<option value="">option 3</option>
<option value="">option 4</option>
</select>
```

### Dropdown

```html
<details role="listbox" >
<summary>Dropdown</summary>

<ul>
<li><a href="#">item 1</a></li>
<li><a href="#">item 2</a></li>
<li><a href="#">item 3</a></li>
<li><a href="#">item 4</a></li>
</ul>
</details>
```

### Header with Nav

```html
<header class="header-sticky">
<a href="#" role="img" aria-label="">
<img src="https://1000logos.net/wp-content/uploads/2021/12/Akatsuki-Logo.png" alt="logo" class="logo" /> <!--the logo must have the logo class-->
</a>

<nav role="navigation">
<ul>
<li>
<a href="#">components</a>
</li>
<li>
<a href="#">examples</a>
</li>
<li>
<a href="#about">about</a>
</li>
</ul>
</nav>
</header>
```

- class variants: ```.sticky```

In this case the nav and the header are together, but you can use them separately.

### Hero

```html
<div class="hero">
<h1>Yonaka</h1>
<p>the best framework in the world</p>

<section>
<button class="cta">Get Started</button>
<button class="ghost">Go Out</button>
</section>
</div>
```

Variables:
```

```css
.hero {
--bg-img-url: url(https://images.unsplash.com/photo-1528353518104-dbd48bee7bc4?ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D&auto=format&fit=crop&w=1332&q=80);
--bg-img-size: cover;
--bg-img-repeat: no-repeat;
--bg-img-pos: center;
}
```
### NPM

A div with the clas wraps everything, you can pass the --bg-img-url to change the background as you please in the inline css or in another stylesheet above in the cascade.
1. Execute no seu terminal `npm i -D yonaka`

___
* Se desejar ver o que será baixado, vá para NPM

[playground](https://codepen.io/Vattghern203/pen/XWOpQgw?editors=1100)
**Observação:**
Loading

0 comments on commit 9cc7225

Please sign in to comment.