Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/panoply/esthetic
Æ ~ New generation beautification support for multiple languages (pre-release)
https://github.com/panoply/esthetic
aesthetic beautification beautifier beautify esthetic format formatter formatting liquid liquify prettier prettydiff shopify sparser typescript
Last synced: 3 days ago
JSON representation
Æ ~ New generation beautification support for multiple languages (pre-release)
- Host: GitHub
- URL: https://github.com/panoply/esthetic
- Owner: panoply
- License: mit
- Created: 2022-02-06T15:54:25.000Z (almost 3 years ago)
- Default Branch: next
- Last Pushed: 2024-09-30T17:26:43.000Z (4 months ago)
- Last Synced: 2025-01-17T04:07:12.707Z (10 days ago)
- Topics: aesthetic, beautification, beautifier, beautify, esthetic, format, formatter, formatting, liquid, liquify, prettier, prettydiff, shopify, sparser, typescript
- Language: TypeScript
- Homepage: https://aesthetic.js.org
- Size: 13.4 MB
- Stars: 35
- Watchers: 8
- Forks: 2
- Open Issues: 7
-
Metadata Files:
- Readme: docs/readme.md
- License: LICENSE
Awesome Lists containing this project
README
# Æsthetic Documentation
The Æsthetic documentation website is built using [11ty](https://www.11ty.dev/docs/) and served via [Netlify](https://netlify.com/).
Visit the docs: [æsthetic.dev](https://æsthetic.dev)
# Development
All dependencies are included within the `package.json` file. ESLint, Prettier and Stylelint is assumed to be installed globally but available as optional dependencies. Documentation is written in markdown and views are composed in Liquid. Frontmatter and JSON data files are used for the order of navigation and various other reference specific information.
### Commands
After installing, run `pnpm dev` to start in development mode. Documentation will build and be deployed via Github actions.
```cli
pnpm dev Starts development in watch mode
pnpm build Builds documentation for production
pnpm 11ty:build Triggers an 11ty build
pnpm 11ty:watch Starts 11ty in watch mode with server
pnpm scss:build Compiles SASS into CSS
pnpm scss:watch Start SASS in watch mode
pnpm ts:build Build production JS bundle
pnpm ts:watch Start ESBuild in watch mode
```# Markdown Customizations
Markdown files will are processed using [markdown-it](https://github.com/markdown-it/markdown-it) and a couple of custom plugins. Frontmatter and JSON data files are used to the order of navigation and various other reference specific information.
- [Grid Container](#grid-container)
- [Rule Heading](#rule-heading)
- [Rule Showcase](#rule-showcase)## Grid Container
Grid access is made possible using fenced containers in the markdown. The `grid` keyword along with triple `:::` markers will result in encapsulate content being wrapped. The [Brixtol Bootstrap](https://brixtol.github.io/bootstrap/) variation grid system and CSS framework class utilities are available.
### INPUT
```md
:::: grid row jc-center ai-center::: grid col-sm-6 col-md-4
Lorem ipsum dolor sit...
:::::: grid col-6 col-md-8
Lorem ipsum dolor sit...
:::::::
```### OUTPUT
```html
Lorem ipsum dolor sit...
Lorem ipsum dolor sit...
```## Rule Heading
Rule documentation files, specifically rule example titles are wrapped within a custom container with annotation emoji. These containers will render tooltips and are required when describing rule behaviors. Different emoji types will result in different tooltip hovers.
### INPUT
```md
::: rule 🙌
#### choice
:::
```
### OUTPUT
```html
🙌
choice
```### TOOLTIPS
| Emoji | Tooltip |
| ----- | --------------------------------------- |
| 🙌 | Authors Recommendation |
| 👍 | Good choice |
| 👎 | Not Recommended |
| 😳 | We live in a society, we're not animals |
| 🤌 | Delightful. Your mother is proud of you |
| 🤡 | The choice of a clown |
| 💡 | Showing an example of the rule |
| 🧐 | You gotta do, what you gotta do |> The [src/rules/strap.md](/docs//src/rules/strap.md) markdown file can be used as a strap.
# Rule Showcasing
Rule documentation files generate interactive demos/examples to showcase how code will be formatted. There are 2 different showcase types (`demo` and `example`) for describing formatting rules. The markdown files for formatting rules use a common structure to achieve this.
Whenever a JSON codeblock uses an annotation identifier of `json:rules` then a standard codeblock show immediately follow. The contents of the `json:rules` is parsed during the 11ty build process (via markdown-it) and used as a reference point. The `json:rules` contents inform upon how and what the showcase should generate.
## Demo Showcase
The below structure is used for generating a rule demo type showcase. Æsthetic formatting rules are provided and the resulting output will be a split pane editor. The left pane is the `input` and the right is `output`. An additional tab is also made available which will inject the rules provided.
The below is a basic example of how a demo showcase is generated and expressed:
```md
```json:rules
{
"language": "liquid",
"liquid": {
"indentAttributes": true
}
}
``````liquid
```md
```json:rules
{
"example": {}, // example config
"esthetic": {} // formatting rules
}
``````liquid
```md
```json:rules
{
"papyrus": {}, // papyrus config
"esthetic": {} // formatting rules
}
``````liquid