- Delete old Vite+Svelte frontend - Initialize new SvelteKit project with TypeScript - Configure Tailwind CSS v4 + DaisyUI - Implement JWT authentication with auto-refresh - Create login page with form validation (Zod) - Add protected route guards - Update Docker configuration for single-stage build - Add E2E tests with Playwright (6/11 passing) - Fix Svelte 5 reactivity with $state() runes Known issues: - 5 E2E tests failing (timing/async issues) - Token refresh implementation needs debugging - Validation error display timing
50 lines
1.2 KiB
Markdown
50 lines
1.2 KiB
Markdown
# postcss-selector-parser [](https://github.com/postcss/postcss-selector-parser/actions/workflows/test.yml)
|
|
|
|
> Selector parser with built in methods for working with selector strings.
|
|
|
|
## Install
|
|
|
|
With [npm](https://npmjs.com/package/postcss-selector-parser) do:
|
|
|
|
```
|
|
npm install postcss-selector-parser
|
|
```
|
|
|
|
## Quick Start
|
|
|
|
```js
|
|
const parser = require('postcss-selector-parser');
|
|
const transform = selectors => {
|
|
selectors.walk(selector => {
|
|
// do something with the selector
|
|
console.log(String(selector))
|
|
});
|
|
};
|
|
|
|
const transformed = parser(transform).processSync('h1, h2, h3');
|
|
```
|
|
|
|
To normalize selector whitespace:
|
|
|
|
```js
|
|
const parser = require('postcss-selector-parser');
|
|
const normalized = parser().processSync('h1, h2, h3', {lossless: false});
|
|
// -> h1,h2,h3
|
|
```
|
|
|
|
Async support is provided through `parser.process` and will resolve a Promise
|
|
with the resulting selector string.
|
|
|
|
## API
|
|
|
|
Please see [API.md](API.md).
|
|
|
|
## Credits
|
|
|
|
* Huge thanks to Andrey Sitnik (@ai) for work on PostCSS which helped
|
|
accelerate this module's development.
|
|
|
|
## License
|
|
|
|
MIT
|