├── .gitignore ├── .npmignore ├── CODE_OF_CONDUCT.md ├── README.md ├── example ├── .gitignore ├── favicon.svg ├── index.html ├── package.json ├── pnpm-lock.yaml ├── pubspec.lock ├── pubspec.yaml ├── src │ ├── icons.js │ ├── index.dart │ ├── main.js │ └── style.scss └── vite.config.mjs ├── index.d.ts ├── package.json ├── renovate.json └── src └── index.js /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | yarn.lock 3 | pnpm-lock.yaml 4 | package-lock.json 5 | .pnpm-debug.log 6 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | example/ 2 | CODE_OF_CONDUCT.md 3 | renovate.json 4 | -------------------------------------------------------------------------------- /CODE_OF_CONDUCT.md: -------------------------------------------------------------------------------- 1 | # Contributor Covenant Code of Conduct 2 | 3 | ## Our Pledge 4 | 5 | We as members, contributors, and leaders pledge to make participation in our 6 | community a harassment-free experience for everyone, regardless of age, body 7 | size, visible or invisible disability, ethnicity, sex characteristics, gender 8 | identity and expression, level of experience, education, socio-economic status, 9 | nationality, personal appearance, race, caste, color, religion, or sexual identity 10 | and orientation. 11 | 12 | We pledge to act and interact in ways that contribute to an open, welcoming, 13 | diverse, inclusive, and healthy community. 14 | 15 | ## Our Standards 16 | 17 | Examples of behavior that contributes to a positive environment for our 18 | community include: 19 | 20 | * Demonstrating empathy and kindness toward other people 21 | * Being respectful of differing opinions, viewpoints, and experiences 22 | * Giving and gracefully accepting constructive feedback 23 | * Accepting responsibility and apologizing to those affected by our mistakes, 24 | and learning from the experience 25 | * Focusing on what is best not just for us as individuals, but for the 26 | overall community 27 | 28 | Examples of unacceptable behavior include: 29 | 30 | * The use of sexualized language or imagery, and sexual attention or 31 | advances of any kind 32 | * Trolling, insulting or derogatory comments, and personal or political attacks 33 | * Public or private harassment 34 | * Publishing others' private information, such as a physical or email 35 | address, without their explicit permission 36 | * Other conduct which could reasonably be considered inappropriate in a 37 | professional setting 38 | 39 | ## Enforcement Responsibilities 40 | 41 | Community leaders are responsible for clarifying and enforcing our standards of 42 | acceptable behavior and will take appropriate and fair corrective action in 43 | response to any behavior that they deem inappropriate, threatening, offensive, 44 | or harmful. 45 | 46 | Community leaders have the right and responsibility to remove, edit, or reject 47 | comments, commits, code, wiki edits, issues, and other contributions that are 48 | not aligned to this Code of Conduct, and will communicate reasons for moderation 49 | decisions when appropriate. 50 | 51 | ## Scope 52 | 53 | This Code of Conduct applies within all community spaces, and also applies when 54 | an individual is officially representing the community in public spaces. 55 | Examples of representing our community include using an official e-mail address, 56 | posting via an official social media account, or acting as an appointed 57 | representative at an online or offline event. 58 | 59 | ## Enforcement 60 | 61 | Instances of abusive, harassing, or otherwise unacceptable behavior may be 62 | reported to the community leaders responsible for enforcement at 63 | coc@geopjr.dev. 64 | All complaints will be reviewed and investigated promptly and fairly. 65 | 66 | All community leaders are obligated to respect the privacy and security of the 67 | reporter of any incident. 68 | 69 | ## Enforcement Guidelines 70 | 71 | Community leaders will follow these Community Impact Guidelines in determining 72 | the consequences for any action they deem in violation of this Code of Conduct: 73 | 74 | ### 1. Correction 75 | 76 | **Community Impact**: Use of inappropriate language or other behavior deemed 77 | unprofessional or unwelcome in the community. 78 | 79 | **Consequence**: A private, written warning from community leaders, providing 80 | clarity around the nature of the violation and an explanation of why the 81 | behavior was inappropriate. A public apology may be requested. 82 | 83 | ### 2. Warning 84 | 85 | **Community Impact**: A violation through a single incident or series 86 | of actions. 87 | 88 | **Consequence**: A warning with consequences for continued behavior. No 89 | interaction with the people involved, including unsolicited interaction with 90 | those enforcing the Code of Conduct, for a specified period of time. This 91 | includes avoiding interactions in community spaces as well as external channels 92 | like social media. Violating these terms may lead to a temporary or 93 | permanent ban. 94 | 95 | ### 3. Temporary Ban 96 | 97 | **Community Impact**: A serious violation of community standards, including 98 | sustained inappropriate behavior. 99 | 100 | **Consequence**: A temporary ban from any sort of interaction or public 101 | communication with the community for a specified period of time. No public or 102 | private interaction with the people involved, including unsolicited interaction 103 | with those enforcing the Code of Conduct, is allowed during this period. 104 | Violating these terms may lead to a permanent ban. 105 | 106 | ### 4. Permanent Ban 107 | 108 | **Community Impact**: Demonstrating a pattern of violation of community 109 | standards, including sustained inappropriate behavior, harassment of an 110 | individual, or aggression toward or disparagement of classes of individuals. 111 | 112 | **Consequence**: A permanent ban from any sort of public interaction within 113 | the community. 114 | 115 | ## Attribution 116 | 117 | This Code of Conduct is adapted from the [Contributor Covenant][homepage], 118 | version 2.1, available at 119 | [https://www.contributor-covenant.org/version/2/1/code_of_conduct.html][v2.1]. 120 | 121 | Community Impact Guidelines were inspired by 122 | [Mozilla's code of conduct enforcement ladder][Mozilla CoC]. 123 | 124 | For answers to common questions about this code of conduct, see the FAQ at 125 | [https://www.contributor-covenant.org/faq][FAQ]. Translations are available 126 | at [https://www.contributor-covenant.org/translations][translations]. 127 | 128 | [homepage]: https://www.contributor-covenant.org 129 | [v2.1]: https://www.contributor-covenant.org/version/2/1/code_of_conduct.html 130 | [Mozilla CoC]: https://github.com/mozilla/diversity 131 | [FAQ]: https://www.contributor-covenant.org/faq 132 | [translations]: https://www.contributor-covenant.org/translations 133 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |

2 | vite plugin dart logo 3 |

4 |

vite-plugin-dart

5 |

Import .dart files effortlessly.

6 |

7 |
8 | Code Of Conduct 9 |

10 | 11 | # 12 | 13 | ## Install 14 | 15 | - Install the plugin: 16 | 17 | ```bash 18 | pnpm i -D vite-plugin-dart # npm, yarn 19 | ``` 20 | 21 | - Install [Dart](https://dart.dev/get-dart) 22 | 23 | - Add `vite-plugin-dart` to your `vite.config.mjs`: 24 | 25 | ```js 26 | // vite.config.mjs (or .ts) 27 | import Dart from "vite-plugin-dart"; 28 | 29 | export default { 30 | plugins: [Dart()], 31 | }; 32 | ``` 33 | 34 | # 35 | 36 | ## Importing 37 | 38 | It's as simple as: 39 | 40 | ```js 41 | import "./index.dart"; 42 | ``` 43 | 44 | All your Pub packages should work as expected! For an example take a look at the [example](./example) folder. 45 | 46 | # 47 | 48 | ## Options 49 | 50 | Here's the default options: 51 | 52 | ```js 53 | const defaultConfig = { 54 | dart: "dart", 55 | minify: false, 56 | "enable-asserts": false, 57 | verbose: false, 58 | define: [], 59 | packages: "", 60 | "suppress-warnings": false, 61 | "fatal-warnings": false, 62 | "suppress-hints": false, 63 | "enable-diagnostic-colors": false, 64 | terse: false, 65 | "show-package-warnings": false, 66 | csp: false, 67 | "no-source-maps": false, 68 | "omit-late-names": false, 69 | O: 1, 70 | "omit-implicit-checks": false, 71 | "trust-primitives": false, 72 | "lax-runtime-type-to-string": false, 73 | verbosity: "warning", 74 | stdio: true, 75 | }; 76 | ``` 77 | 78 | For most, you can read their description by running `dart compile js -h -v`. 79 | 80 | The ones that are not there are: 81 | 82 | ``` 83 | dart: Dart binary location 84 | verbosity: Verbosity level (all, info, warning, error) 85 | stdio: Whether or not to pass the dart stdio to parent 86 | ``` 87 | 88 | It uses JSDoc, so make sure to follow your IDE's annotations. 89 | 90 | # 91 | 92 | ## Example 93 | 94 | See the [example](./example) folder. 95 | 96 | All tools used there are Dart packages! 97 | 98 | # 99 | 100 | ## How does it work? 101 | 102 | Dart can compile to JS using `dart2js`. This plugin compiles your Dart files using that at your OS' tmp folder and then after cleaning the generated sourcemaps, returns it to Vite which imports it. 103 | 104 | # 105 | 106 | ## Deploying 107 | 108 | Most platforms do not provide `dart` pre-installed so you need to install it. 109 | 110 | The general workflow is: `Install Dart => npm i => dart pub get => npm run build`. 111 | 112 | For example, here's the Vercel config for this repo: 113 | 114 | ```bash 115 | Build Command: cd example && npm run build 116 | 117 | Output Dir: ./example/dist 118 | 119 | Install Command: yum install unzip -y && cd example && if [ ! -d "./dart-sdk/" ]; then curl -L https://storage.googleapis.com/dart-archive/channels/be/raw/latest/sdk/dartsdk-linux-x64-release.zip > dart.zip; fi && unzip -qq dart.zip && npm i && ./dart-sdk/bin/dart pub get 120 | ``` 121 | 122 | At the same time, [vite.config.mjs](./example/vite.config.mjs) has some options for this plugin based on the current environment: 123 | 124 | ```js 125 | Dart({ 126 | // Optimizations set to 2 on prod 127 | O: mode === "development" ? 1 : 2, 128 | // Dart location when on Vercel (This is a custom env var on Vercel, set to true) 129 | dart: process.env.VERCEL ? "./dart-sdk/bin/dart" : "dart", 130 | }), 131 | ``` 132 | 133 | # 134 | 135 | ## Contributing 136 | 137 | 1. Read the [Code of Conduct](https://github.com/GeopJr/vite-plugin-dart/blob/main/CODE_OF_CONDUCT.md) 138 | 2. Fork it ( https://github.com/GeopJr/vite-plugin-dart/fork ) 139 | 3. Create your feature branch (git checkout -b my-new-feature) 140 | 4. Commit your changes (git commit -am 'Add some feature') 141 | 5. Push to the branch (git push origin my-new-feature) 142 | 6. Create a new Pull Request 143 | 144 | > Dart and the related logo are trademarks of Google LLC. We are not endorsed by or affiliated with Google LLC. 145 | -------------------------------------------------------------------------------- /example/.gitignore: -------------------------------------------------------------------------------- 1 | .dart_tool/ 2 | .packages 3 | dist/ 4 | -------------------------------------------------------------------------------- /example/favicon.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /example/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Vite Plugin Dart 8 | 9 | 13 | 14 | 15 |
16 |
17 |
20 | Vite Plugin Dart 21 |
22 |
23 |
24 |
25 |
26 |
27 | 33 | 34 | GitHub 35 | 36 |
37 |

QRCode Generator

38 |
39 |
44 |
45 | 62 |
63 |
64 |

UUIDv4 Generator

65 |
66 |
67 | 68 |
69 |
70 | 75 |
76 |
77 | 78 |

Text Art Generator

79 |
80 | 97 |
98 | 105 |
106 |
107 |
108 |
109 | 110 | 111 | 112 | 113 | -------------------------------------------------------------------------------- /example/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "vite_plugin_dart_example", 3 | "version": "1.0.0", 4 | "scripts": { 5 | "dev": "vite", 6 | "build": "vite build", 7 | "serve": "vite preview" 8 | }, 9 | "devDependencies": { 10 | "sass": "1.58.0", 11 | "vite": "4.1.1" 12 | }, 13 | "dependencies": { 14 | "@iconify/icons-logos": "1.2.23", 15 | "@material/button": "14.0.0", 16 | "@material/card": "14.0.0", 17 | "@material/ripple": "14.0.0", 18 | "@material/textfield": "14.0.0", 19 | "@material/top-app-bar": "14.0.0", 20 | "@material/typography": "14.0.0", 21 | "ress": "5.0.2" 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /example/pnpm-lock.yaml: -------------------------------------------------------------------------------- 1 | lockfileVersion: 5.4 2 | 3 | specifiers: 4 | '@iconify/icons-logos': 1.2.23 5 | '@material/button': 14.0.0 6 | '@material/card': 14.0.0 7 | '@material/ripple': 14.0.0 8 | '@material/textfield': 14.0.0 9 | '@material/top-app-bar': 14.0.0 10 | '@material/typography': 14.0.0 11 | ress: 5.0.2 12 | sass: 1.58.0 13 | vite: 4.1.1 14 | 15 | dependencies: 16 | '@iconify/icons-logos': 1.2.23 17 | '@material/button': 14.0.0 18 | '@material/card': 14.0.0 19 | '@material/ripple': 14.0.0 20 | '@material/textfield': 14.0.0 21 | '@material/top-app-bar': 14.0.0 22 | '@material/typography': 14.0.0 23 | ress: 5.0.2 24 | 25 | devDependencies: 26 | sass: 1.58.0 27 | vite: 4.1.1_sass@1.58.0 28 | 29 | packages: 30 | 31 | /@esbuild/android-arm/0.16.17: 32 | resolution: {integrity: sha512-N9x1CMXVhtWEAMS7pNNONyA14f71VPQN9Cnavj1XQh6T7bskqiLLrSca4O0Vr8Wdcga943eThxnVp3JLnBMYtw==} 33 | engines: {node: '>=12'} 34 | cpu: [arm] 35 | os: [android] 36 | requiresBuild: true 37 | dev: true 38 | optional: true 39 | 40 | /@esbuild/android-arm64/0.16.17: 41 | resolution: {integrity: sha512-MIGl6p5sc3RDTLLkYL1MyL8BMRN4tLMRCn+yRJJmEDvYZ2M7tmAf80hx1kbNEUX2KJ50RRtxZ4JHLvCfuB6kBg==} 42 | engines: {node: '>=12'} 43 | cpu: [arm64] 44 | os: [android] 45 | requiresBuild: true 46 | dev: true 47 | optional: true 48 | 49 | /@esbuild/android-x64/0.16.17: 50 | resolution: {integrity: sha512-a3kTv3m0Ghh4z1DaFEuEDfz3OLONKuFvI4Xqczqx4BqLyuFaFkuaG4j2MtA6fuWEFeC5x9IvqnX7drmRq/fyAQ==} 51 | engines: {node: '>=12'} 52 | cpu: [x64] 53 | os: [android] 54 | requiresBuild: true 55 | dev: true 56 | optional: true 57 | 58 | /@esbuild/darwin-arm64/0.16.17: 59 | resolution: {integrity: sha512-/2agbUEfmxWHi9ARTX6OQ/KgXnOWfsNlTeLcoV7HSuSTv63E4DqtAc+2XqGw1KHxKMHGZgbVCZge7HXWX9Vn+w==} 60 | engines: {node: '>=12'} 61 | cpu: [arm64] 62 | os: [darwin] 63 | requiresBuild: true 64 | dev: true 65 | optional: true 66 | 67 | /@esbuild/darwin-x64/0.16.17: 68 | resolution: {integrity: sha512-2By45OBHulkd9Svy5IOCZt376Aa2oOkiE9QWUK9fe6Tb+WDr8hXL3dpqi+DeLiMed8tVXspzsTAvd0jUl96wmg==} 69 | engines: {node: '>=12'} 70 | cpu: [x64] 71 | os: [darwin] 72 | requiresBuild: true 73 | dev: true 74 | optional: true 75 | 76 | /@esbuild/freebsd-arm64/0.16.17: 77 | resolution: {integrity: sha512-mt+cxZe1tVx489VTb4mBAOo2aKSnJ33L9fr25JXpqQqzbUIw/yzIzi+NHwAXK2qYV1lEFp4OoVeThGjUbmWmdw==} 78 | engines: {node: '>=12'} 79 | cpu: [arm64] 80 | os: [freebsd] 81 | requiresBuild: true 82 | dev: true 83 | optional: true 84 | 85 | /@esbuild/freebsd-x64/0.16.17: 86 | resolution: {integrity: sha512-8ScTdNJl5idAKjH8zGAsN7RuWcyHG3BAvMNpKOBaqqR7EbUhhVHOqXRdL7oZvz8WNHL2pr5+eIT5c65kA6NHug==} 87 | engines: {node: '>=12'} 88 | cpu: [x64] 89 | os: [freebsd] 90 | requiresBuild: true 91 | dev: true 92 | optional: true 93 | 94 | /@esbuild/linux-arm/0.16.17: 95 | resolution: {integrity: sha512-iihzrWbD4gIT7j3caMzKb/RsFFHCwqqbrbH9SqUSRrdXkXaygSZCZg1FybsZz57Ju7N/SHEgPyaR0LZ8Zbe9gQ==} 96 | engines: {node: '>=12'} 97 | cpu: [arm] 98 | os: [linux] 99 | requiresBuild: true 100 | dev: true 101 | optional: true 102 | 103 | /@esbuild/linux-arm64/0.16.17: 104 | resolution: {integrity: sha512-7S8gJnSlqKGVJunnMCrXHU9Q8Q/tQIxk/xL8BqAP64wchPCTzuM6W3Ra8cIa1HIflAvDnNOt2jaL17vaW+1V0g==} 105 | engines: {node: '>=12'} 106 | cpu: [arm64] 107 | os: [linux] 108 | requiresBuild: true 109 | dev: true 110 | optional: true 111 | 112 | /@esbuild/linux-ia32/0.16.17: 113 | resolution: {integrity: sha512-kiX69+wcPAdgl3Lonh1VI7MBr16nktEvOfViszBSxygRQqSpzv7BffMKRPMFwzeJGPxcio0pdD3kYQGpqQ2SSg==} 114 | engines: {node: '>=12'} 115 | cpu: [ia32] 116 | os: [linux] 117 | requiresBuild: true 118 | dev: true 119 | optional: true 120 | 121 | /@esbuild/linux-loong64/0.16.17: 122 | resolution: {integrity: sha512-dTzNnQwembNDhd654cA4QhbS9uDdXC3TKqMJjgOWsC0yNCbpzfWoXdZvp0mY7HU6nzk5E0zpRGGx3qoQg8T2DQ==} 123 | engines: {node: '>=12'} 124 | cpu: [loong64] 125 | os: [linux] 126 | requiresBuild: true 127 | dev: true 128 | optional: true 129 | 130 | /@esbuild/linux-mips64el/0.16.17: 131 | resolution: {integrity: sha512-ezbDkp2nDl0PfIUn0CsQ30kxfcLTlcx4Foz2kYv8qdC6ia2oX5Q3E/8m6lq84Dj/6b0FrkgD582fJMIfHhJfSw==} 132 | engines: {node: '>=12'} 133 | cpu: [mips64el] 134 | os: [linux] 135 | requiresBuild: true 136 | dev: true 137 | optional: true 138 | 139 | /@esbuild/linux-ppc64/0.16.17: 140 | resolution: {integrity: sha512-dzS678gYD1lJsW73zrFhDApLVdM3cUF2MvAa1D8K8KtcSKdLBPP4zZSLy6LFZ0jYqQdQ29bjAHJDgz0rVbLB3g==} 141 | engines: {node: '>=12'} 142 | cpu: [ppc64] 143 | os: [linux] 144 | requiresBuild: true 145 | dev: true 146 | optional: true 147 | 148 | /@esbuild/linux-riscv64/0.16.17: 149 | resolution: {integrity: sha512-ylNlVsxuFjZK8DQtNUwiMskh6nT0vI7kYl/4fZgV1llP5d6+HIeL/vmmm3jpuoo8+NuXjQVZxmKuhDApK0/cKw==} 150 | engines: {node: '>=12'} 151 | cpu: [riscv64] 152 | os: [linux] 153 | requiresBuild: true 154 | dev: true 155 | optional: true 156 | 157 | /@esbuild/linux-s390x/0.16.17: 158 | resolution: {integrity: sha512-gzy7nUTO4UA4oZ2wAMXPNBGTzZFP7mss3aKR2hH+/4UUkCOyqmjXiKpzGrY2TlEUhbbejzXVKKGazYcQTZWA/w==} 159 | engines: {node: '>=12'} 160 | cpu: [s390x] 161 | os: [linux] 162 | requiresBuild: true 163 | dev: true 164 | optional: true 165 | 166 | /@esbuild/linux-x64/0.16.17: 167 | resolution: {integrity: sha512-mdPjPxfnmoqhgpiEArqi4egmBAMYvaObgn4poorpUaqmvzzbvqbowRllQ+ZgzGVMGKaPkqUmPDOOFQRUFDmeUw==} 168 | engines: {node: '>=12'} 169 | cpu: [x64] 170 | os: [linux] 171 | requiresBuild: true 172 | dev: true 173 | optional: true 174 | 175 | /@esbuild/netbsd-x64/0.16.17: 176 | resolution: {integrity: sha512-/PzmzD/zyAeTUsduZa32bn0ORug+Jd1EGGAUJvqfeixoEISYpGnAezN6lnJoskauoai0Jrs+XSyvDhppCPoKOA==} 177 | engines: {node: '>=12'} 178 | cpu: [x64] 179 | os: [netbsd] 180 | requiresBuild: true 181 | dev: true 182 | optional: true 183 | 184 | /@esbuild/openbsd-x64/0.16.17: 185 | resolution: {integrity: sha512-2yaWJhvxGEz2RiftSk0UObqJa/b+rIAjnODJgv2GbGGpRwAfpgzyrg1WLK8rqA24mfZa9GvpjLcBBg8JHkoodg==} 186 | engines: {node: '>=12'} 187 | cpu: [x64] 188 | os: [openbsd] 189 | requiresBuild: true 190 | dev: true 191 | optional: true 192 | 193 | /@esbuild/sunos-x64/0.16.17: 194 | resolution: {integrity: sha512-xtVUiev38tN0R3g8VhRfN7Zl42YCJvyBhRKw1RJjwE1d2emWTVToPLNEQj/5Qxc6lVFATDiy6LjVHYhIPrLxzw==} 195 | engines: {node: '>=12'} 196 | cpu: [x64] 197 | os: [sunos] 198 | requiresBuild: true 199 | dev: true 200 | optional: true 201 | 202 | /@esbuild/win32-arm64/0.16.17: 203 | resolution: {integrity: sha512-ga8+JqBDHY4b6fQAmOgtJJue36scANy4l/rL97W+0wYmijhxKetzZdKOJI7olaBaMhWt8Pac2McJdZLxXWUEQw==} 204 | engines: {node: '>=12'} 205 | cpu: [arm64] 206 | os: [win32] 207 | requiresBuild: true 208 | dev: true 209 | optional: true 210 | 211 | /@esbuild/win32-ia32/0.16.17: 212 | resolution: {integrity: sha512-WnsKaf46uSSF/sZhwnqE4L/F89AYNMiD4YtEcYekBt9Q7nj0DiId2XH2Ng2PHM54qi5oPrQ8luuzGszqi/veig==} 213 | engines: {node: '>=12'} 214 | cpu: [ia32] 215 | os: [win32] 216 | requiresBuild: true 217 | dev: true 218 | optional: true 219 | 220 | /@esbuild/win32-x64/0.16.17: 221 | resolution: {integrity: sha512-y+EHuSchhL7FjHgvQL/0fnnFmO4T1bhvWANX6gcnqTjtnKWbTvUMCpGnv2+t+31d7RzyEAYAd4u2fnIhHL6N/Q==} 222 | engines: {node: '>=12'} 223 | cpu: [x64] 224 | os: [win32] 225 | requiresBuild: true 226 | dev: true 227 | optional: true 228 | 229 | /@iconify/icons-logos/1.2.23: 230 | resolution: {integrity: sha512-XQZyfF4AiXgQjZYN12LPymGhd9UMG0666hIzTYecM+d+jNqdLcs2zJLxNmBnTtPi+3t5JsHW+TSus7k9YydQzw==} 231 | dependencies: 232 | '@iconify/types': 1.0.12 233 | dev: false 234 | 235 | /@iconify/types/1.0.12: 236 | resolution: {integrity: sha512-6er6wSGF3hgc1JEZqiGpg21CTCjHBYOUwqLmb2Idzkjiw6ogalGP0ZMLVutCzah+0WB4yP+Zd2oVPN8jvJ+Ftg==} 237 | dev: false 238 | 239 | /@material/animation/14.0.0: 240 | resolution: {integrity: sha512-VlYSfUaIj/BBVtRZI8Gv0VvzikFf+XgK0Zdgsok5c1v5DDnNz5tpB8mnGrveWz0rHbp1X4+CWLKrTwNmjrw3Xw==} 241 | dependencies: 242 | tslib: 2.3.1 243 | dev: false 244 | 245 | /@material/base/14.0.0: 246 | resolution: {integrity: sha512-Ou7vS7n1H4Y10MUZyYAbt6H0t67c6urxoCgeVT7M38aQlaNUwFMODp7KT/myjYz2YULfhu3PtfSV3Sltgac9mA==} 247 | dependencies: 248 | tslib: 2.3.1 249 | dev: false 250 | 251 | /@material/button/14.0.0: 252 | resolution: {integrity: sha512-dqqHaJq0peyXBZupFzCjmvScrfljyVU66ZCS3oldsaaj5iz8sn33I/45Z4zPzdR5F5z8ExToHkRcXhakj1UEAA==} 253 | dependencies: 254 | '@material/density': 14.0.0 255 | '@material/dom': 14.0.0 256 | '@material/elevation': 14.0.0 257 | '@material/feature-targeting': 14.0.0 258 | '@material/focus-ring': 14.0.0 259 | '@material/ripple': 14.0.0 260 | '@material/rtl': 14.0.0 261 | '@material/shape': 14.0.0 262 | '@material/theme': 14.0.0 263 | '@material/tokens': 14.0.0 264 | '@material/touch-target': 14.0.0 265 | '@material/typography': 14.0.0 266 | tslib: 2.3.1 267 | dev: false 268 | 269 | /@material/card/14.0.0: 270 | resolution: {integrity: sha512-SnpYWUrCb92meGYLXV7qa/k40gnHR6rPki6A1wz0OAyG2twY48f0HLscAqxBLvbbm1LuRaqjz0RLKGH3VzxZHw==} 271 | dependencies: 272 | '@material/dom': 14.0.0 273 | '@material/elevation': 14.0.0 274 | '@material/feature-targeting': 14.0.0 275 | '@material/ripple': 14.0.0 276 | '@material/rtl': 14.0.0 277 | '@material/shape': 14.0.0 278 | '@material/theme': 14.0.0 279 | tslib: 2.3.1 280 | dev: false 281 | 282 | /@material/density/14.0.0: 283 | resolution: {integrity: sha512-NlxXBV5XjNsKd8UXF4K/+fOXLxoFNecKbsaQO6O2u+iG8QBfFreKRmkhEBb2hPPwC3w8nrODwXX0lHV+toICQw==} 284 | dependencies: 285 | tslib: 2.3.1 286 | dev: false 287 | 288 | /@material/dom/14.0.0: 289 | resolution: {integrity: sha512-8t88XyacclTj8qsIw9q0vEj4PI2KVncLoIsIMzwuMx49P2FZg6TsLjor262MI3Qs00UWAifuLMrhnOnfyrbe7Q==} 290 | dependencies: 291 | '@material/feature-targeting': 14.0.0 292 | tslib: 2.3.1 293 | dev: false 294 | 295 | /@material/elevation/14.0.0: 296 | resolution: {integrity: sha512-Di3tkxTpXwvf1GJUmaC8rd+zVh5dB2SWMBGagL4+kT8UmjSISif/OPRGuGnXs3QhF6nmEjkdC0ijdZLcYQkepw==} 297 | dependencies: 298 | '@material/animation': 14.0.0 299 | '@material/base': 14.0.0 300 | '@material/feature-targeting': 14.0.0 301 | '@material/rtl': 14.0.0 302 | '@material/theme': 14.0.0 303 | tslib: 2.3.1 304 | dev: false 305 | 306 | /@material/feature-targeting/14.0.0: 307 | resolution: {integrity: sha512-a5WGgHEq5lJeeNL5yevtgoZjBjXWy6+klfVWQEh8oyix/rMJygGgO7gEc52uv8fB8uAIoYEB3iBMOv8jRq8FeA==} 308 | dependencies: 309 | tslib: 2.3.1 310 | dev: false 311 | 312 | /@material/floating-label/14.0.0: 313 | resolution: {integrity: sha512-Aq8BboP1sbNnOtsV72AfaYirHyOrQ/GKFoLrZ1Jt+ZGIAuXPETcj9z7nQDznst0ZeKcz420PxNn9tsybTbeL/Q==} 314 | dependencies: 315 | '@material/animation': 14.0.0 316 | '@material/base': 14.0.0 317 | '@material/dom': 14.0.0 318 | '@material/feature-targeting': 14.0.0 319 | '@material/rtl': 14.0.0 320 | '@material/theme': 14.0.0 321 | '@material/typography': 14.0.0 322 | tslib: 2.3.1 323 | dev: false 324 | 325 | /@material/focus-ring/14.0.0: 326 | resolution: {integrity: sha512-fqqka6iSfQGJG3Le48RxPCtnOiaLGPDPikhktGbxlyW9srBVMgeCiONfHM7IT/1eu80O0Y67Lh/4ohu5+C+VAQ==} 327 | dependencies: 328 | '@material/dom': 14.0.0 329 | '@material/feature-targeting': 14.0.0 330 | '@material/rtl': 14.0.0 331 | dev: false 332 | 333 | /@material/line-ripple/14.0.0: 334 | resolution: {integrity: sha512-Rx9eSnfp3FcsNz4O+fobNNq2PSm5tYHC3hRpY2ZK3ghTvgp3Y40/soaGEi/Vdg0F7jJXRaBSNOe6p5t9CVfy8Q==} 335 | dependencies: 336 | '@material/animation': 14.0.0 337 | '@material/base': 14.0.0 338 | '@material/feature-targeting': 14.0.0 339 | '@material/theme': 14.0.0 340 | tslib: 2.3.1 341 | dev: false 342 | 343 | /@material/notched-outline/14.0.0: 344 | resolution: {integrity: sha512-6S58DlWmhCDr4RQF2RuwqANxlmLdHtWy2mF4JQLD9WOiCg4qY9eCQnMXu3Tbhr7f/nOZ0vzc7AtA3vfJoZmCSw==} 345 | dependencies: 346 | '@material/base': 14.0.0 347 | '@material/feature-targeting': 14.0.0 348 | '@material/floating-label': 14.0.0 349 | '@material/rtl': 14.0.0 350 | '@material/shape': 14.0.0 351 | '@material/theme': 14.0.0 352 | tslib: 2.3.1 353 | dev: false 354 | 355 | /@material/ripple/14.0.0: 356 | resolution: {integrity: sha512-9XoGBFd5JhFgELgW7pqtiLy+CnCIcV2s9cQ2BWbOQeA8faX9UZIDUx/g76nHLZ7UzKFtsULJxZTwORmsEt2zvw==} 357 | dependencies: 358 | '@material/animation': 14.0.0 359 | '@material/base': 14.0.0 360 | '@material/dom': 14.0.0 361 | '@material/feature-targeting': 14.0.0 362 | '@material/rtl': 14.0.0 363 | '@material/theme': 14.0.0 364 | tslib: 2.3.1 365 | dev: false 366 | 367 | /@material/rtl/14.0.0: 368 | resolution: {integrity: sha512-xl6OZYyRjuiW2hmbjV2omMV8sQtfmKAjeWnD1RMiAPLCTyOW9Lh/PYYnXjxUrNa0cRwIIbOn5J7OYXokja8puA==} 369 | dependencies: 370 | '@material/theme': 14.0.0 371 | tslib: 2.3.1 372 | dev: false 373 | 374 | /@material/shape/14.0.0: 375 | resolution: {integrity: sha512-o0mJB0+feOv473KckI8gFnUo8IQAaEA6ynXzw3VIYFjPi48pJwrxa0mZcJP/OoTXrCbDzDeFJfDPXEmRioBb9A==} 376 | dependencies: 377 | '@material/feature-targeting': 14.0.0 378 | '@material/rtl': 14.0.0 379 | '@material/theme': 14.0.0 380 | tslib: 2.3.1 381 | dev: false 382 | 383 | /@material/textfield/14.0.0: 384 | resolution: {integrity: sha512-HGbtAlvlIB2vWBq85yw5wQeeP3Kndl6Z0TJzQ6piVtcfdl2mPyWhuuVHQRRAOis3rCIaAAaxCQYYTJh8wIi0XQ==} 385 | dependencies: 386 | '@material/animation': 14.0.0 387 | '@material/base': 14.0.0 388 | '@material/density': 14.0.0 389 | '@material/dom': 14.0.0 390 | '@material/feature-targeting': 14.0.0 391 | '@material/floating-label': 14.0.0 392 | '@material/line-ripple': 14.0.0 393 | '@material/notched-outline': 14.0.0 394 | '@material/ripple': 14.0.0 395 | '@material/rtl': 14.0.0 396 | '@material/shape': 14.0.0 397 | '@material/theme': 14.0.0 398 | '@material/tokens': 14.0.0 399 | '@material/typography': 14.0.0 400 | tslib: 2.3.1 401 | dev: false 402 | 403 | /@material/theme/14.0.0: 404 | resolution: {integrity: sha512-6/SENWNIFuXzeHMPHrYwbsXKgkvCtWuzzQ3cUu4UEt3KcQ5YpViazIM6h8ByYKZP8A9d8QpkJ0WGX5btGDcVoA==} 405 | dependencies: 406 | '@material/feature-targeting': 14.0.0 407 | tslib: 2.3.1 408 | dev: false 409 | 410 | /@material/tokens/14.0.0: 411 | resolution: {integrity: sha512-SXgB9VwsKW4DFkHmJfDIS0x0cGdMWC1D06m6z/WQQ5P5j6/m0pKrbHVlrLzXcRjau+mFhXGvj/KyPo9Pp/Rc8Q==} 412 | dependencies: 413 | '@material/elevation': 14.0.0 414 | dev: false 415 | 416 | /@material/top-app-bar/14.0.0: 417 | resolution: {integrity: sha512-uPej5vHgZnlSB1+koiA9FnabXrHh3O/Npl2ifpUgDVwHDSOxKvLp2LNjyCO71co1QLNnNHIU0xXv3B97Gb0rpA==} 418 | dependencies: 419 | '@material/animation': 14.0.0 420 | '@material/base': 14.0.0 421 | '@material/elevation': 14.0.0 422 | '@material/ripple': 14.0.0 423 | '@material/rtl': 14.0.0 424 | '@material/shape': 14.0.0 425 | '@material/theme': 14.0.0 426 | '@material/typography': 14.0.0 427 | tslib: 2.3.1 428 | dev: false 429 | 430 | /@material/touch-target/14.0.0: 431 | resolution: {integrity: sha512-o3kvxmS4HkmZoQTvtzLJrqSG+ezYXkyINm3Uiwio1PTg67pDgK5FRwInkz0VNaWPcw9+5jqjUQGjuZMtjQMq8w==} 432 | dependencies: 433 | '@material/base': 14.0.0 434 | '@material/feature-targeting': 14.0.0 435 | '@material/rtl': 14.0.0 436 | tslib: 2.3.1 437 | dev: false 438 | 439 | /@material/typography/14.0.0: 440 | resolution: {integrity: sha512-/QtHBYiTR+TPMryM/CT386B2WlAQf/Ae32V324Z7P40gHLKY/YBXx7FDutAWZFeOerq/two4Nd2aAHBcMM2wMw==} 441 | dependencies: 442 | '@material/feature-targeting': 14.0.0 443 | '@material/theme': 14.0.0 444 | tslib: 2.3.1 445 | dev: false 446 | 447 | /anymatch/3.1.2: 448 | resolution: {integrity: sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==} 449 | engines: {node: '>= 8'} 450 | dependencies: 451 | normalize-path: 3.0.0 452 | picomatch: 2.3.0 453 | dev: true 454 | 455 | /binary-extensions/2.2.0: 456 | resolution: {integrity: sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==} 457 | engines: {node: '>=8'} 458 | dev: true 459 | 460 | /braces/3.0.2: 461 | resolution: {integrity: sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==} 462 | engines: {node: '>=8'} 463 | dependencies: 464 | fill-range: 7.0.1 465 | dev: true 466 | 467 | /chokidar/3.5.2: 468 | resolution: {integrity: sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==} 469 | engines: {node: '>= 8.10.0'} 470 | dependencies: 471 | anymatch: 3.1.2 472 | braces: 3.0.2 473 | glob-parent: 5.1.2 474 | is-binary-path: 2.1.0 475 | is-glob: 4.0.2 476 | normalize-path: 3.0.0 477 | readdirp: 3.6.0 478 | optionalDependencies: 479 | fsevents: 2.3.2 480 | dev: true 481 | 482 | /esbuild/0.16.17: 483 | resolution: {integrity: sha512-G8LEkV0XzDMNwXKgM0Jwu3nY3lSTwSGY6XbxM9cr9+s0T/qSV1q1JVPBGzm3dcjhCic9+emZDmMffkwgPeOeLg==} 484 | engines: {node: '>=12'} 485 | hasBin: true 486 | requiresBuild: true 487 | optionalDependencies: 488 | '@esbuild/android-arm': 0.16.17 489 | '@esbuild/android-arm64': 0.16.17 490 | '@esbuild/android-x64': 0.16.17 491 | '@esbuild/darwin-arm64': 0.16.17 492 | '@esbuild/darwin-x64': 0.16.17 493 | '@esbuild/freebsd-arm64': 0.16.17 494 | '@esbuild/freebsd-x64': 0.16.17 495 | '@esbuild/linux-arm': 0.16.17 496 | '@esbuild/linux-arm64': 0.16.17 497 | '@esbuild/linux-ia32': 0.16.17 498 | '@esbuild/linux-loong64': 0.16.17 499 | '@esbuild/linux-mips64el': 0.16.17 500 | '@esbuild/linux-ppc64': 0.16.17 501 | '@esbuild/linux-riscv64': 0.16.17 502 | '@esbuild/linux-s390x': 0.16.17 503 | '@esbuild/linux-x64': 0.16.17 504 | '@esbuild/netbsd-x64': 0.16.17 505 | '@esbuild/openbsd-x64': 0.16.17 506 | '@esbuild/sunos-x64': 0.16.17 507 | '@esbuild/win32-arm64': 0.16.17 508 | '@esbuild/win32-ia32': 0.16.17 509 | '@esbuild/win32-x64': 0.16.17 510 | dev: true 511 | 512 | /fill-range/7.0.1: 513 | resolution: {integrity: sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==} 514 | engines: {node: '>=8'} 515 | dependencies: 516 | to-regex-range: 5.0.1 517 | dev: true 518 | 519 | /fsevents/2.3.2: 520 | resolution: {integrity: sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==} 521 | engines: {node: ^8.16.0 || ^10.6.0 || >=11.0.0} 522 | os: [darwin] 523 | requiresBuild: true 524 | dev: true 525 | optional: true 526 | 527 | /function-bind/1.1.1: 528 | resolution: {integrity: sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==} 529 | dev: true 530 | 531 | /glob-parent/5.1.2: 532 | resolution: {integrity: sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==} 533 | engines: {node: '>= 6'} 534 | dependencies: 535 | is-glob: 4.0.2 536 | dev: true 537 | 538 | /has/1.0.3: 539 | resolution: {integrity: sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==} 540 | engines: {node: '>= 0.4.0'} 541 | dependencies: 542 | function-bind: 1.1.1 543 | dev: true 544 | 545 | /immutable/4.0.0: 546 | resolution: {integrity: sha512-zIE9hX70qew5qTUjSS7wi1iwj/l7+m54KWU247nhM3v806UdGj1yDndXj+IOYxxtW9zyLI+xqFNZjTuDaLUqFw==} 547 | dev: true 548 | 549 | /is-binary-path/2.1.0: 550 | resolution: {integrity: sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==} 551 | engines: {node: '>=8'} 552 | dependencies: 553 | binary-extensions: 2.2.0 554 | dev: true 555 | 556 | /is-core-module/2.9.0: 557 | resolution: {integrity: sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A==} 558 | dependencies: 559 | has: 1.0.3 560 | dev: true 561 | 562 | /is-extglob/2.1.1: 563 | resolution: {integrity: sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==} 564 | engines: {node: '>=0.10.0'} 565 | dev: true 566 | 567 | /is-glob/4.0.2: 568 | resolution: {integrity: sha512-ZZTOjRcDjuAAAv2cTBQP/lL59ZTArx77+7UzHdWW/XB1mrfp7DEaVpKmZ0XIzx+M7AxfhKcqV+nMetUQmFifwg==} 569 | engines: {node: '>=0.10.0'} 570 | dependencies: 571 | is-extglob: 2.1.1 572 | dev: true 573 | 574 | /is-number/7.0.0: 575 | resolution: {integrity: sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==} 576 | engines: {node: '>=0.12.0'} 577 | dev: true 578 | 579 | /nanoid/3.3.4: 580 | resolution: {integrity: sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==} 581 | engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} 582 | hasBin: true 583 | dev: true 584 | 585 | /normalize-path/3.0.0: 586 | resolution: {integrity: sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==} 587 | engines: {node: '>=0.10.0'} 588 | dev: true 589 | 590 | /path-parse/1.0.7: 591 | resolution: {integrity: sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==} 592 | dev: true 593 | 594 | /picocolors/1.0.0: 595 | resolution: {integrity: sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==} 596 | dev: true 597 | 598 | /picomatch/2.3.0: 599 | resolution: {integrity: sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==} 600 | engines: {node: '>=8.6'} 601 | dev: true 602 | 603 | /postcss/8.4.21: 604 | resolution: {integrity: sha512-tP7u/Sn/dVxK2NnruI4H9BG+x+Wxz6oeZ1cJ8P6G/PZY0IKk4k/63TDsQf2kQq3+qoJeLm2kIBUNlZe3zgb4Zg==} 605 | engines: {node: ^10 || ^12 || >=14} 606 | dependencies: 607 | nanoid: 3.3.4 608 | picocolors: 1.0.0 609 | source-map-js: 1.0.2 610 | dev: true 611 | 612 | /readdirp/3.6.0: 613 | resolution: {integrity: sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==} 614 | engines: {node: '>=8.10.0'} 615 | dependencies: 616 | picomatch: 2.3.0 617 | dev: true 618 | 619 | /resolve/1.22.1: 620 | resolution: {integrity: sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==} 621 | hasBin: true 622 | dependencies: 623 | is-core-module: 2.9.0 624 | path-parse: 1.0.7 625 | supports-preserve-symlinks-flag: 1.0.0 626 | dev: true 627 | 628 | /ress/5.0.2: 629 | resolution: {integrity: sha512-oHBtOWo/Uc8SzQMbQNIKTcgi8wKmAs7IlNlRywmXudbOtF+c27FlOIq7tnwLDVcTywe6JXYo1pDXHO6kABwNYA==} 630 | dev: false 631 | 632 | /rollup/3.12.1: 633 | resolution: {integrity: sha512-t9elERrz2i4UU9z7AwISj3CQcXP39cWxgRWLdf4Tm6aKm1eYrqHIgjzXBgb67GNY1sZckTFFi0oMozh3/S++Ig==} 634 | engines: {node: '>=14.18.0', npm: '>=8.0.0'} 635 | hasBin: true 636 | optionalDependencies: 637 | fsevents: 2.3.2 638 | dev: true 639 | 640 | /sass/1.58.0: 641 | resolution: {integrity: sha512-PiMJcP33DdKtZ/1jSjjqVIKihoDc6yWmYr9K/4r3fVVIEDAluD0q7XZiRKrNJcPK3qkLRF/79DND1H5q1LBjgg==} 642 | engines: {node: '>=12.0.0'} 643 | hasBin: true 644 | dependencies: 645 | chokidar: 3.5.2 646 | immutable: 4.0.0 647 | source-map-js: 1.0.2 648 | dev: true 649 | 650 | /source-map-js/1.0.2: 651 | resolution: {integrity: sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==} 652 | engines: {node: '>=0.10.0'} 653 | dev: true 654 | 655 | /supports-preserve-symlinks-flag/1.0.0: 656 | resolution: {integrity: sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==} 657 | engines: {node: '>= 0.4'} 658 | dev: true 659 | 660 | /to-regex-range/5.0.1: 661 | resolution: {integrity: sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==} 662 | engines: {node: '>=8.0'} 663 | dependencies: 664 | is-number: 7.0.0 665 | dev: true 666 | 667 | /tslib/2.3.1: 668 | resolution: {integrity: sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==} 669 | dev: false 670 | 671 | /vite/4.1.1_sass@1.58.0: 672 | resolution: {integrity: sha512-LM9WWea8vsxhr782r9ntg+bhSFS06FJgCvvB0+8hf8UWtvaiDagKYWXndjfX6kGl74keHJUcpzrQliDXZlF5yg==} 673 | engines: {node: ^14.18.0 || >=16.0.0} 674 | hasBin: true 675 | peerDependencies: 676 | '@types/node': '>= 14' 677 | less: '*' 678 | sass: '*' 679 | stylus: '*' 680 | sugarss: '*' 681 | terser: ^5.4.0 682 | peerDependenciesMeta: 683 | '@types/node': 684 | optional: true 685 | less: 686 | optional: true 687 | sass: 688 | optional: true 689 | stylus: 690 | optional: true 691 | sugarss: 692 | optional: true 693 | terser: 694 | optional: true 695 | dependencies: 696 | esbuild: 0.16.17 697 | postcss: 8.4.21 698 | resolve: 1.22.1 699 | rollup: 3.12.1 700 | sass: 1.58.0 701 | optionalDependencies: 702 | fsevents: 2.3.2 703 | dev: true 704 | -------------------------------------------------------------------------------- /example/pubspec.lock: -------------------------------------------------------------------------------- 1 | # Generated by pub 2 | # See https://dart.dev/tools/pub/glossary#lockfile 3 | packages: 4 | barcode: 5 | dependency: "direct main" 6 | description: 7 | name: barcode 8 | url: "https://pub.dartlang.org" 9 | source: hosted 10 | version: "2.1.0" 11 | collection: 12 | dependency: transitive 13 | description: 14 | name: collection 15 | url: "https://pub.dartlang.org" 16 | source: hosted 17 | version: "1.15.0" 18 | crypto: 19 | dependency: transitive 20 | description: 21 | name: crypto 22 | url: "https://pub.dartlang.org" 23 | source: hosted 24 | version: "3.0.1" 25 | js: 26 | dependency: "direct main" 27 | description: 28 | name: js 29 | url: "https://pub.dartlang.org" 30 | source: hosted 31 | version: "0.6.3" 32 | meta: 33 | dependency: transitive 34 | description: 35 | name: meta 36 | url: "https://pub.dartlang.org" 37 | source: hosted 38 | version: "1.7.0" 39 | qr: 40 | dependency: transitive 41 | description: 42 | name: qr 43 | url: "https://pub.dartlang.org" 44 | source: hosted 45 | version: "2.1.0" 46 | textifier: 47 | dependency: "direct main" 48 | description: 49 | name: textifier 50 | url: "https://pub.dartlang.org" 51 | source: hosted 52 | version: "1.0.0" 53 | typed_data: 54 | dependency: transitive 55 | description: 56 | name: typed_data 57 | url: "https://pub.dartlang.org" 58 | source: hosted 59 | version: "1.3.0" 60 | uuid: 61 | dependency: "direct main" 62 | description: 63 | name: uuid 64 | url: "https://pub.dartlang.org" 65 | source: hosted 66 | version: "3.0.4" 67 | sdks: 68 | dart: ">=2.12.0 <4.0.0" 69 | -------------------------------------------------------------------------------- /example/pubspec.yaml: -------------------------------------------------------------------------------- 1 | name: vite_plugin_dart_example 2 | description: Just an example for vite-plugin-dart 3 | version: 1.0.0 4 | environment: 5 | sdk: ">=2.10.0 <4.0.0" 6 | dependencies: 7 | barcode: ^2.1.0 8 | js: ^0.6.3 9 | textifier: ^1.0.0 10 | uuid: ^3.0.4 11 | -------------------------------------------------------------------------------- /example/src/icons.js: -------------------------------------------------------------------------------- 1 | import "./style.scss"; 2 | import viteLogo from "@iconify/icons-logos/vitejs"; 3 | import dartLogo from "@iconify/icons-logos/dart"; 4 | import svelteLogo from "@iconify/icons-logos/svelte-icon"; 5 | import vueLogo from "@iconify/icons-logos/vue"; 6 | import crystalLogo from "@iconify/icons-logos/crystal"; 7 | import flutterLogo from "@iconify/icons-logos/flutter"; 8 | import nuxtLogo from "@iconify/icons-logos/nuxt-icon"; 9 | import kemalLogo from "@iconify/icons-logos/kemal"; 10 | import nodeLogo from "@iconify/icons-logos/nodejs-icon"; 11 | import phoenixLogo from "@iconify/icons-logos/phoenix"; 12 | import rubyLogo from "@iconify/icons-logos/ruby"; 13 | import sassLogo from "@iconify/icons-logos/sass"; 14 | import lessLogo from "@iconify/icons-logos/less"; 15 | import nativeScriptLogo from "@iconify/icons-logos/nativescript"; 16 | import archLogo from "@iconify/icons-logos/archlinux"; 17 | import kdeLogo from "@iconify/icons-logos/kde"; 18 | import copyleftLogo from "@iconify/icons-logos/copyleft"; 19 | import firefoxLogo from "@iconify/icons-logos/firefox"; 20 | import mozillaLogo from "@iconify/icons-logos/mozilla"; 21 | import apacheLogo from "@iconify/icons-logos/apache"; 22 | 23 | const icons = { 24 | vite: viteLogo, 25 | dart: dartLogo, 26 | svelte: svelteLogo, 27 | vue: vueLogo, 28 | crystal: crystalLogo, 29 | flutter: flutterLogo, 30 | nuxt: nuxtLogo, 31 | kemal: kemalLogo, 32 | node: nodeLogo, 33 | phoenix: phoenixLogo, 34 | ruby: rubyLogo, 35 | sass: sassLogo, 36 | less: lessLogo, 37 | nativescript: nativeScriptLogo, 38 | arch: archLogo, 39 | kde: kdeLogo, 40 | copyleft: copyleftLogo, 41 | firefox: firefoxLogo, 42 | mozilla: mozillaLogo, 43 | apache: apacheLogo, 44 | }; 45 | 46 | const iconsParent = document.getElementById("icons"); 47 | Object.keys(icons).forEach((icon) => { 48 | const img = document.createElement("img"); 49 | img.id = icon; 50 | img.src = 51 | "data:image/svg+xml;base64," + 52 | btoa( 53 | '' + 54 | icons[icon].body + 55 | "" 56 | ); 57 | iconsParent.appendChild(img); 58 | }); 59 | 60 | console.log("[bonk!] Here's all the available text art logos!"); 61 | console.log(Object.keys(icons)); 62 | -------------------------------------------------------------------------------- /example/src/index.dart: -------------------------------------------------------------------------------- 1 | @JS() 2 | library callable_function; 3 | 4 | import 'dart:html'; 5 | import 'package:js/js.dart'; 6 | import 'package:barcode/barcode.dart'; 7 | import 'package:textifier/textifier.dart'; 8 | import 'package:uuid/uuid.dart'; 9 | 10 | final uuid = Uuid(); 11 | final dm = Barcode.qrCode(); 12 | final qrCodeDiv = querySelector('#qrcode') as DivElement; 13 | final qrCodeTextInput = querySelector('#source') as InputElement; 14 | final textArt = querySelector('#textart') as DivElement; 15 | final textArtInput = querySelector('#textArtText') as InputElement; 16 | final viteLogo = querySelector("#vite") as ImageElement; 17 | final dartLogo = querySelector("#dart") as ImageElement; 18 | final uuidHolder = querySelector("#uuid") as SpanElement; 19 | final uuidBtn = querySelector("#uuidBtn") as ButtonElement; 20 | 21 | class AllowAllElements implements NodeValidator { 22 | @override 23 | bool allowsAttribute(Element element, String attributeName, String value) { 24 | return true; 25 | } 26 | 27 | @override 28 | bool allowsElement(Element element) { 29 | return true; 30 | } 31 | } 32 | 33 | void createQrCode(String input) { 34 | final qrcode = dm.toSvg(input, width: 200, height: 200); 35 | qrCodeDiv.setInnerHtml(qrcode, validator: AllowAllElements()); 36 | } 37 | 38 | void createViteText(String input) async { 39 | final cleanInput = input.replaceAll(new RegExp(r'[^\w\s]+'), ''); 40 | final characters = 41 | cleanInput.length == 0 || cleanInput.replaceAll(" ", "").length == 0 42 | ? "vite" 43 | : cleanInput; 44 | final icon = (querySelector("#" + characters.toLowerCase()) ?? viteLogo) 45 | as ImageElement; 46 | await new Textifier(maxWidth: 100, characters: characters, ordered: true) 47 | .write(icon.src, textArt); 48 | textArt.setInnerHtml(textArt.innerHtml.replaceAll(new RegExp(r'\s+\n'), '\n'), 49 | validator: AllowAllElements()); 50 | } 51 | 52 | void createUUID() { 53 | uuidHolder.innerText = uuid.v4(); 54 | } 55 | 56 | // Example function export 57 | @JS('helloWorld') 58 | external set _helloWorld(void Function() f); 59 | 60 | void _printHW() { 61 | print('Hello from Dart!'); 62 | } 63 | 64 | void main() { 65 | // You should now be able to call helloWorld() 66 | // from outside Dart! 67 | _helloWorld = allowInterop(_printHW); 68 | 69 | // Set initial values 70 | qrCodeTextInput.value = "Hello Vite!"; 71 | textArtInput.value = "vite"; 72 | 73 | // Run initial functions 74 | createQrCode(qrCodeTextInput.value); 75 | createViteText(textArtInput.value); 76 | new Textifier(maxWidth: 100, characters: 'You found me! ', ordered: true).log( 77 | ""); 78 | createUUID(); 79 | 80 | // Bind events 81 | textArtInput.onInput.listen((event) => createViteText(textArtInput.value)); 82 | qrCodeTextInput.onInput 83 | .listen((event) => createQrCode(qrCodeTextInput.value)); 84 | uuidBtn.onClick.listen((event) => createUUID()); 85 | } 86 | -------------------------------------------------------------------------------- /example/src/main.js: -------------------------------------------------------------------------------- 1 | import "./index.dart"; 2 | import { MDCTopAppBar } from "@material/top-app-bar"; 3 | import { MDCTextField } from "@material/textfield"; 4 | import { MDCRipple } from "@material/ripple"; 5 | 6 | const topAppBarElement = document.querySelector(".mdc-top-app-bar"); 7 | 8 | new MDCTopAppBar(topAppBarElement); 9 | new MDCTextField(document.querySelector(".mdc-text-field1")); 10 | new MDCTextField(document.querySelector(".mdc-text-field2")); 11 | new MDCRipple(document.querySelector(".mdc-button1")); 12 | new MDCRipple(document.querySelector(".mdc-button2")); 13 | 14 | const app = document.getElementById("app"); 15 | 16 | app.innerHTML = ` 17 |

Hello Vite!

18 | `; 19 | -------------------------------------------------------------------------------- /example/src/style.scss: -------------------------------------------------------------------------------- 1 | @use "ress/dist/ress.min.css"; 2 | @use "@material/typography/mdc-typography"; 3 | @use "@material/top-app-bar/mdc-top-app-bar"; 4 | @use "@material/card/mdc-card"; 5 | @use "@material/button/mdc-button"; 6 | @use "@material/textfield/mdc-text-field"; 7 | 8 | html, 9 | body { 10 | overflow-x: hidden; 11 | } 12 | 13 | main > div { 14 | margin: 2rem 0; 15 | } 16 | 17 | .vpd-center { 18 | display: flex; 19 | justify-content: center; 20 | align-items: center; 21 | flex-direction: column; 22 | } 23 | 24 | #qrcode { 25 | max-width: 200px; 26 | align-self: center; 27 | } 28 | 29 | #uuidcard { 30 | flex-direction: row; 31 | flex-wrap: wrap; 32 | padding: 16px; 33 | max-width: 512px; 34 | justify-content: space-between; 35 | .mdc-card.mdc-card--outlined { 36 | padding: 16px; 37 | } 38 | span { 39 | text-align: center; 40 | } 41 | .mdc-touch-target-wrapper { 42 | display: inline-flex; 43 | } 44 | button { 45 | margin-left: 16px; 46 | } 47 | } 48 | 49 | #canvascard { 50 | padding: 16px; 51 | } 52 | 53 | #textart { 54 | display: flex; 55 | align-content: center; 56 | justify-content: center; 57 | margin: 2rem 0; 58 | } 59 | -------------------------------------------------------------------------------- /example/vite.config.mjs: -------------------------------------------------------------------------------- 1 | import { defineConfig } from "vite"; 2 | import Dart from "../src/index.js"; 3 | 4 | export default defineConfig(({ _, mode }) => { 5 | return { 6 | plugins: [ 7 | Dart({ 8 | O: mode === "development" ? 1 : 2, 9 | dart: process.env.VERCEL ? "./dart-sdk/bin/dart" : "dart", 10 | }), 11 | ], 12 | base: "./", 13 | build: { 14 | rollupOptions: { 15 | input: "./index.html", 16 | }, 17 | }, 18 | }; 19 | }); 20 | -------------------------------------------------------------------------------- /index.d.ts: -------------------------------------------------------------------------------- 1 | declare module "vite-plugin-dart" { 2 | import { Plugin } from "vite"; 3 | 4 | interface IConfig { 5 | dart: string; 6 | minify: boolean; 7 | "enable-asserts": boolean; 8 | verbose: boolean; 9 | define: Array; 10 | packages: string; 11 | "suppress-warnings": boolean; 12 | "fatal-warnings": boolean; 13 | "suppress-hints": boolean; 14 | "enable-diagnostic-colors": boolean; 15 | terse: boolean; 16 | "show-package-warnings": boolean; 17 | csp: boolean; 18 | "no-source-maps": boolean; 19 | "omit-late-names": boolean; 20 | O: 0 | 1 | 2 | 3 | 4; 21 | "omit-implicit-checks": boolean; 22 | "trust-primitives": boolean; 23 | "lax-runtime-type-to-string": boolean; 24 | verbosity: "warning" | "all" | "error" | "info", 25 | stdio: boolean; 26 | } 27 | 28 | export default function Dart(config?: Partial): Plugin; 29 | } -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "vite-plugin-dart", 3 | "version": "1.0.3", 4 | "description": "Vite Dart Plugin", 5 | "main": "src/index.js", 6 | "type": "module", 7 | "repository": { 8 | "type": "git", 9 | "url": "git+https://github.com/GeopJr/vite-plugin-dart.git" 10 | }, 11 | "keywords": [ 12 | "vite", 13 | "plugin", 14 | "dart" 15 | ], 16 | "author": "GeopJr", 17 | "license": "MIT", 18 | "bugs": { 19 | "url": "https://github.com/GeopJr/vite-plugin-dart/issues" 20 | }, 21 | "homepage": "https://github.com/GeopJr/vite-plugin-dart#readme", 22 | "devDependencies": { 23 | "vite": "4.1.1" 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /renovate.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": ["config:base"] 3 | } 4 | -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | import { execSync } from "child_process"; 2 | import { readFileSync, mkdtempSync, rmSync } from "fs"; 3 | import { tmpdir } from "os"; 4 | import { join, parse } from "path"; 5 | 6 | const fileRegex = /\.(dart)$/; 7 | 8 | /** 9 | * @typedef {Object} Config 10 | * @property {Number} [O] - Only numbers between <0,1,2,3,4> allowed. 11 | * @property {Boolean} [csp] 12 | * @property {String} [dart=dart] - Dart binary path. 13 | * @property {String[]} [define] - Array items in the "=" fromat each. 14 | * @property {Boolean} [enable-asserts] 15 | * @property {Boolean} [enable-diagnostic-colors] 16 | * @property {Boolean} [fatal-warnings] 17 | * @property {Boolean} [lax-runtime-type-to-string] 18 | * @property {Boolean} [minify] 19 | * @property {Boolean} [no-source-maps] 20 | * @property {Boolean} [omit-implicit-checks] 21 | * @property {Boolean} [omit-late-names] 22 | * @property {String} [packages] 23 | * @property {Boolean} [show-package-warnings] 24 | * @property {Boolean} [suppress-hints] 25 | * @property {Boolean} [suppress-warnings] 26 | * @property {Boolean} [terse] 27 | * @property {Boolean} [trust-primitives] 28 | * @property {Boolean} [verbose] 29 | * @property {String} [verbosity=warning] - Available: all, error, info, warning. 30 | * @property {Boolean} [stdio=true] - Whether or not to pass the dart stdio to parent. 31 | */ 32 | const defaultConfig = { 33 | dart: "dart", 34 | minify: false, 35 | "enable-asserts": false, 36 | verbose: false, 37 | define: [], 38 | packages: "", 39 | "suppress-warnings": false, 40 | "fatal-warnings": false, 41 | "suppress-hints": false, 42 | "enable-diagnostic-colors": false, 43 | terse: false, 44 | "show-package-warnings": false, 45 | csp: false, 46 | "no-source-maps": false, 47 | "omit-late-names": false, 48 | O: 1, 49 | "omit-implicit-checks": false, 50 | "trust-primitives": false, 51 | "lax-runtime-type-to-string": false, 52 | verbosity: "warning", 53 | stdio: true, 54 | }; 55 | 56 | const nonFlagBool = ["stdio"]; 57 | 58 | /** 59 | * @param {Config} options 60 | */ 61 | export default function dartPlugin(options = defaultConfig) { 62 | options = {...defaultConfig, ...options} 63 | // Create the dart args 64 | const execArgs = []; 65 | 66 | if (options.dart.length === 0) options.dart = "dart"; 67 | if (options.packages.length > 0) 68 | execArgs.push(`--packages=${options.packages}`); 69 | if (options.O >= 0 && options.O <= 4 && options.O % 1 === 0) 70 | execArgs.push(`-O${options.O}`); 71 | 72 | execArgs.push( 73 | `--verbosity=${ 74 | ["info", "error", "warning", "all"].includes( 75 | options.verbosity.toLowerCase() 76 | ) 77 | ? options.verbosity.toLowerCase() 78 | : "warning" 79 | }` 80 | ); 81 | 82 | execArgs.push( 83 | ...Object.keys(options) 84 | .filter((x) => options[x] === true && !nonFlagBool.includes(x)) 85 | .map((x) => `--${x}`) 86 | ); 87 | 88 | if (options.define.length > 0) 89 | execArgs.push( 90 | ...options.define 91 | .filter((x) => x.includes("=")) 92 | .map((x) => `--define=${x}`) 93 | ); 94 | 95 | return { 96 | name: "vite-plugin-dart", 97 | 98 | transform(_, path) { 99 | if (!fileRegex.test(path)) return; 100 | // Create a tmp folder to hold the dart compile 101 | // output 102 | const tmpFolder = mkdtempSync(join(tmpdir(), "vite-plugin-dart-")); 103 | const parsedPath = parse(path); 104 | const compiledDartFilename = parsedPath.name + ".js"; 105 | const compiledDartOutput = join(tmpFolder, compiledDartFilename); 106 | 107 | // Construct the dart command & execute 108 | const command = `"${options.dart}" compile js ${execArgs 109 | .map((x) => `"${x}"`) 110 | .join(" ")} -o "${compiledDartOutput}" "${path}"`; 111 | 112 | execSync(command, { 113 | stdio: `${options.stdio === true ? "inherit" : "ignore"}`, 114 | }); 115 | 116 | let compiledDart = readFileSync(compiledDartOutput, "utf8"); 117 | let compiledDartMap = null; 118 | 119 | if (options["no-source-maps"] === false) { 120 | // Remove the included sourcemap (Vite handles it) 121 | compiledDart = compiledDart.replace( 122 | `//# sourceMappingURL=${encodeURIComponent( 123 | compiledDartFilename 124 | )}.map`, 125 | "" 126 | ); 127 | // Patch the sourcemap so it points to the correct files 128 | compiledDartMap = JSON.parse( 129 | readFileSync(compiledDartOutput + ".map", "utf8") 130 | ); 131 | compiledDartMap.sources = compiledDartMap.sources.map((x) => { 132 | if (!x.startsWith(".")) return; 133 | x.replace(/^(?:\.\.(\/|\\))+/, ""); 134 | x = "file://" + x; 135 | }); 136 | compiledDartMap = JSON.stringify(compiledDartMap); 137 | } 138 | 139 | // Delete the tmp folder 140 | rmSync(tmpFolder, { recursive: true, force: true }); 141 | 142 | return { 143 | code: compiledDart, 144 | map: compiledDartMap, 145 | }; 146 | }, 147 | }; 148 | } 149 | --------------------------------------------------------------------------------