gitea/web_src/js/webcomponents
silverwind 08579d6cbb
Add initial typescript config and use it for eslint,vitest,playwright (#31186)
This enables eslint to use the typescript parser and resolver which
brings some benefits that eslint rules now have type information
available and a tsconfig.json is required for the upcoming typescript
migration as well. Notable changes done:

- Add typescript parser and resolver
- Move the vue-specific config into the root file
- Enable `vue-scoped-css/enforce-style-type` rule, there was only one
violation and I added a inline disable there.
- Fix new lint errors that were detected because of the parser change
- Update `i/no-unresolved` to remove now-unnecessary workaround for the
resolver
- Disable `i/no-named-as-default` as it seems to raise bogus issues in
the webpack config
- Change vitest config to typescript
- Change playwright config to typescript
- Add `eslint-plugin-playwright` and fix issues
- Add `tsc` linting to `make lint-js`
2024-06-28 16:15:51 +00:00
..
README.md Add `<overflow-menu>`, rename webcomponents (#29400) 2024-03-15 02:05:31 +00:00
absolute-date.js Use `Temporal.PlainDate` for absolute dates (#29804) 2024-03-15 09:13:01 +00:00
absolute-date.test.js Use `Temporal.PlainDate` for absolute dates (#29804) 2024-03-15 09:13:01 +00:00
index.js Add `<overflow-menu>`, rename webcomponents (#29400) 2024-03-15 02:05:31 +00:00
origin-url.js Add `<overflow-menu>`, rename webcomponents (#29400) 2024-03-15 02:05:31 +00:00
origin-url.test.js Add `<overflow-menu>`, rename webcomponents (#29400) 2024-03-15 02:05:31 +00:00
overflow-menu.js Add initial typescript config and use it for eslint,vitest,playwright (#31186) 2024-06-28 16:15:51 +00:00
polyfills.js Enforce trailing comma in JS on multiline (#30002) 2024-03-22 14:06:53 +00:00

README.md

Web Components

This webcomponents directory contains the source code for the web components used in the Gitea Web UI.

https://developer.mozilla.org/en-US/docs/Web/Web_Components

Guidelines

  • These components are loaded in <head> (before DOM body) in a separate entry point, they need to be lightweight to not affect the page loading time too much.
  • Do not import svg.js into a web component because that file is currently not tree-shakeable, import svg files individually insteat.
  • All our components must be added to webpack.config.js so they work correctly in Vue.