├── .github
├── CODEOWNERS
└── workflows
│ ├── pr-build.yml
│ ├── pr-merged.yml
│ └── version-tag-build-master.yml
├── .gitignore
├── .sassrc
├── LICENSE
├── README.md
├── build.cmd
├── examples
├── blog-post.html
└── index.html
├── images
├── alignment.png
├── animation.gif
├── fish-skeleton.png
├── fish-skeleton.svg
├── headers.png
├── image-shapes.png
├── images.png
├── line-widths.png
├── paragraphs.png
├── skeleton-cards.png
├── skellyCSS__full-logo.svg
└── skellyCSS__logo.svg
├── index.html
├── main.js
├── package-lock.json
├── package.json
├── package
├── LICENSE
├── README.md
└── package.json
├── postcss.config.js
├── src
├── index.js
└── style.scss
└── vite.config.js
/.github/CODEOWNERS:
--------------------------------------------------------------------------------
1 | # https://docs.github.com/en/repositories/managing-your-repositorys-settings-and-features/customizing-your-repository/about-code-owners
2 |
3 | /.github/** @ritterim/GitGuardians
4 |
--------------------------------------------------------------------------------
/.github/workflows/pr-build.yml:
--------------------------------------------------------------------------------
1 | name: PR Build
2 |
3 | permissions:
4 | contents: read
5 | packages: read
6 |
7 | on:
8 |
9 | # https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows#pull_request
10 | # By default, a workflow only runs when a pull_request event's activity type is opened, synchronize, or reopened.
11 | pull_request:
12 | types: [ opened, synchronize, reopened, labeled, unlabeled ]
13 | branches:
14 | - main
15 |
16 | jobs:
17 |
18 | pr-build:
19 | uses: ritterim/public-github-actions/.github/workflows/npm-packages-pr-build.yml@v1.16.5
20 | #uses: ./.github/workflows/npm-packages-pr-build.yml
21 | with:
22 | always_increment_patch_version: true
23 | npm_package_name: skellycss
24 | run_tests: false
25 |
--------------------------------------------------------------------------------
/.github/workflows/pr-merged.yml:
--------------------------------------------------------------------------------
1 | name: PR Merged
2 |
3 | permissions:
4 | contents: read
5 | id-token: write
6 | packages: read
7 |
8 | on:
9 |
10 | # https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows#pull_request
11 | # By default, a workflow only runs when a pull_request event's activity type is opened, synchronize, or reopened.
12 | # We want to run on 'closed' to trigger, but we also have to check if it was merged.
13 | # That check is: if: github.event.pull_request.merged == true
14 | pull_request_target:
15 | types: [ closed ]
16 | branches:
17 | - main
18 |
19 | jobs:
20 |
21 | npm-packages-pr-create-tag:
22 | uses: ritterim/public-github-actions/.github/workflows/npm-packages-pr-create-tag-jfrog.yml@v1.16.5
23 | #uses: ./.github/workflows/npm-packages-pr-create-tag-jfrog.yml
24 | if: github.event.pull_request.merged == true
25 | secrets:
26 | gh_actions_secret_passing_passphrase: ${{ secrets.ACTIONS_SECRET_PASSING_PASSPHRASE }}
27 | gh_app_private_key: ${{ secrets.RIMDEV_NPM_RELEASES_APP_PRIVATE_KEY }}
28 | with:
29 | always_increment_patch_version: true
30 | gh_app_id: ${{ vars.RIMDEV_NPM_RELEASES_APP_APPID }}
31 | jfrog_api_base_url: ${{ vars.JFROG_API_BASE_URL }}
32 | jfrog_artifactory_repository: "${{ vars.JFROG_NPM_PACKAGE_REPO_BASENAME }}-draft"
33 | jfrog_audit_xray_watch_list: ${{ vars.JFROG_AUDIT_XRAY_WATCH_LIST }}
34 | jfrog_build_basename: ${{ vars.JFROG_BUILD_BASENAME }}
35 | jfrog_npm_feed_repo: ${{ vars.JFROG_ARTIFACTORY_VIRTUAL_REPO_NPM }}
36 | jfrog_npm_package_repo_basename: ${{ vars.JFROG_NPM_PACKAGE_REPO_BASENAME }}
37 | jfrog_oidc_provider_name: ${{ vars.JFROG_GHA_OIDC_PROVIDER_NAME }}
38 | npm_package_name: skellycss
39 | run_tests: false
40 |
--------------------------------------------------------------------------------
/.github/workflows/version-tag-build-master.yml:
--------------------------------------------------------------------------------
1 | name: Version Tag Build
2 |
3 | permissions:
4 | contents: write
5 | id-token: write
6 | packages: write
7 |
8 | on:
9 | push:
10 | # To limit whether this executes on a specific branch, you must adjust the allowed_branches input.
11 | # Specifying 'branches' here is a logical 'OR', not a logical 'AND'.
12 | tags:
13 | - v0.*
14 |
15 | jobs:
16 |
17 | version-tag-build:
18 | uses: ritterim/public-github-actions/.github/workflows/npm-packages-release-on-tag-jfrog.yml@v1.16.5
19 | #uses: ./.github/workflows/npm-packages-release-on-tag-jfrog.yml
20 | secrets:
21 | npmjs_org_api_key: ${{ secrets.RITTERIM_NPMJS_PUBLISH_TOKEN }}
22 | with:
23 | allowed_branches: |
24 | main
25 | jfrog_api_base_url: ${{ vars.JFROG_API_BASE_URL }}
26 | jfrog_artifactory_repository: "${{ vars.JFROG_NPM_PACKAGE_REPO_BASENAME }}-prod"
27 | jfrog_audit_xray_watch_list: ${{ vars.JFROG_AUDIT_XRAY_WATCH_LIST }}
28 | jfrog_build_basename: ${{ vars.JFROG_BUILD_BASENAME }}
29 | jfrog_npm_feed_repo: ${{ vars.JFROG_ARTIFACTORY_VIRTUAL_REPO_NPM }}
30 | jfrog_npm_package_repo_basename: ${{ vars.JFROG_NPM_PACKAGE_REPO_BASENAME }}
31 | jfrog_oidc_provider_name: ${{ vars.JFROG_GHA_OIDC_PROVIDER_NAME }}
32 | npm_package_name: skellycss
33 | run_tests: false
34 | npmjs_org_access_public: true
35 | publish_to_npmjs_org: true
36 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | #Distribution
2 | dist/
3 |
4 | # Logs
5 | logs
6 | *.log
7 | npm-debug.log*
8 | yarn-debug.log*
9 | yarn-error.log*
10 | lerna-debug.log*
11 |
12 | # Diagnostic reports (https://nodejs.org/api/report.html)
13 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json
14 |
15 | # Runtime data
16 | pids
17 | *.pid
18 | *.seed
19 | *.pid.lock
20 |
21 | # Directory for instrumented libs generated by jscoverage/JSCover
22 | lib-cov
23 |
24 | # Coverage directory used by tools like istanbul
25 | coverage
26 | *.lcov
27 |
28 | # nyc test coverage
29 | .nyc_output
30 |
31 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files)
32 | .grunt
33 |
34 | # Bower dependency directory (https://bower.io/)
35 | bower_components
36 |
37 | # node-waf configuration
38 | .lock-wscript
39 |
40 | # Compiled binary addons (https://nodejs.org/api/addons.html)
41 | build/Release
42 |
43 | # Dependency directories
44 | node_modules/
45 | jspm_packages/
46 |
47 | # TypeScript v1 declaration files
48 | typings/
49 |
50 | # TypeScript cache
51 | *.tsbuildinfo
52 |
53 | # Optional npm cache directory
54 | .npm
55 |
56 | # Optional eslint cache
57 | .eslintcache
58 |
59 | # Microbundle cache
60 | .rpt2_cache/
61 | .rts2_cache_cjs/
62 | .rts2_cache_es/
63 | .rts2_cache_umd/
64 |
65 | # Optional REPL history
66 | .node_repl_history
67 |
68 | # Output of 'npm pack'
69 | *.tgz
70 |
71 | # Yarn Integrity file
72 | .yarn-integrity
73 |
74 | # dotenv environment variables file
75 | .env
76 | .env.test
77 |
78 | # parcel-bundler cache (https://parceljs.org/)
79 | .cache
80 |
81 | # Next.js build output
82 | .next
83 |
84 | # Nuxt.js build / generate output
85 | .nuxt
86 |
87 | # Gatsby files
88 | .cache/
89 | # Comment in the public line in if your project uses Gatsby and *not* Next.js
90 | # https://nextjs.org/blog/next-9-1#public-directory-support
91 | # public
92 |
93 | # vuepress build output
94 | .vuepress/dist
95 |
96 | # Serverless directories
97 | .serverless/
98 |
99 | # FuseBox cache
100 | .fusebox/
101 |
102 | # DynamoDB Local files
103 | .dynamodb/
104 |
105 | # TernJS port file
106 | .tern-port
107 |
108 | #Other Files
109 | .DS_store
--------------------------------------------------------------------------------
/.sassrc:
--------------------------------------------------------------------------------
1 | {
2 | "includePaths": ["node_modules"]
3 | }
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2020 Ritter Insurance Marketing
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | # skellyCSS
6 | A light-weight CSS framework to quickly implement skeletons into your projects.
7 |
8 |
9 | Table of Contents
10 |
11 | - [skellyCSS](#skellycss)
12 | - [Installation](#installation)
13 | - [npm](#npm)
14 | - [CSS](#css)
15 | - [JavaScript](#javascript)
16 | - [Quick Usage](#quick-usage)
17 | - [Usage](#usage)
18 | - [Headers](#headers)
19 | - [Paragraphs](#paragraphs)
20 | - [Line Width](#line-width)
21 | - [Alignment](#alignment)
22 | - [Images](#images)
23 | - [Sizes](#sizes)
24 | - [Shapes](#shapes)
25 | - [Animation](#animation)
26 | - [JavaScript Utility](#javascript-utility)
27 | - [JavaScript Data Attributes](#javascript-data-attributes)
28 | - [All Data Attributes](#all-data-attributes)
29 |
30 |
31 |
32 | ## Installation
33 |
34 | ### npm
35 | To install via node package manager:
36 | ```shell
37 | npm install @ritterim/skellycss
38 | ```
39 |
40 | ### CSS
41 | Include the Skelly css file wherever you add your CSS:
42 | ``` html
43 |
44 | ```
45 |
46 | ### JavaScript
47 | Include the skelly.js file wherever you add your JavaScript:
48 | ``` html
49 |
50 | ```
51 |
52 |
53 |
54 | ## Quick Usage
55 | You can quickly get started using skellyCSS using the JavaScript utility, like so:
56 | ``` html
57 |
58 |
59 | ```
60 | **See full [JavaScript Utility](#javascript-utility) docs below**
61 |
62 |
63 |
64 | ## Usage
65 | Skeletons can be quickly added to any project with a few simple lines of code.
66 |
67 | ### Headers
68 | Apply the `skeleton` class to any type of header and it will automatically adjust to the font-size of the header stylings:
69 |
70 | 
71 |
72 | ``` html
73 |
74 |
75 |
76 |
77 |
78 |
79 | ```
80 |
81 |
82 |
83 | ### Paragraphs
84 | You can create paragraph skeletons by applying the `skeleton` class to the paragraph tag, then including however many span tags you'd like with the `skeleton__line` class within the paragraph. In order to make the paragraph skeleton look more like a paragraph, the last line is set to 50% width.
85 |
86 | 
87 | ```html
88 |
89 |
90 |
91 |
92 |
93 |
94 |
95 |
96 | ```
97 |
98 |
99 |
100 | ### Line Width
101 | You can adjust the line width by applying a size modifier class:
102 | | Width | Modifier Class |
103 | | ------------ | ------------|
104 | | Small, 25% | `.skeleton--sm` |
105 | | Medium, 50% | `.skeleton--md` |
106 | | Large, 75% | `.skeleton--lg` |
107 | | Full, 100% | `.skeleton--full` |
108 |
109 | 
110 |
111 | ``` html
112 |
113 |
114 |
115 |
116 | ```
117 |
118 |
119 |
120 | ### Alignment
121 | You can text align the skeleton using alignment modifier classes:
122 |
123 | | Alignment | Modifier Class |
124 | | ------------ | ------------|
125 | | Left | `.skeleton--left` |
126 | | Center | `.skeleton--center` |
127 | | Right | `.skeleton--right` |
128 |
129 | 
130 |
131 | ``` html
132 |
133 |
134 |
135 |
136 |
137 |
138 |
139 |
140 |
141 |
142 |
143 |
144 |
145 |
146 |
147 |
148 |
149 |
150 |
151 |
152 |
153 |
154 |
155 | ```
156 |
157 |
158 |
159 | ### Images
160 | You can create an image skeleton by using the `.skeleton-image` class. By default this will apply the image skeleton at 100% height and width of the parent container.
161 |
162 | #### Sizes
163 | Here are some default sizes we have included for skeleton images:
164 |
165 | | Size | Modifier Class |
166 | | ------------ | ------------|
167 | | Small, 50x50 | `.skeleton-image--sm` |
168 | | Medium, 100x100 | `.skeleton-image--md` |
169 | | Large, 200x200 | `.skeleton-image--lg` |
170 | | X-Large, 400x400 | `.skeleton-image--xl` |
171 | | Full, 100% x 100% | `.skeleton-image--full` |
172 |
173 | 
174 |
175 | ``` html
176 |
177 |
178 |
179 |
180 | ```
181 |
182 |
183 |
184 | #### Shapes
185 | You can also make different image shapes using shape modifier classes:
186 |
187 | | Shape | Description | Modifier Class |
188 | | ------------ |------------ | ------------|
189 | | Square | Sets the image aspect ratio to 1/1 (default) | `.skeleton-image--square` |
190 | | Circle | Sets the border radius to 50% | `.skeleton-image--circle` |
191 | | Landscape Rectangle | Sets the image aspect ratio to 4/3 | `.skeleton-image--landscape` |
192 | | Portrait Rectangle | Sets the image aspect ratio to 3/4| `.skeleton-image--portrait` |
193 | | Wide Rectangle | Sets the image aspect ratio to 16/9 | `.skeleton-image--wide` |
194 | | Tall Rectangle | Sets the image aspect ratio to 9/16 | `.skeleton-image--tall` |
195 |
196 | ``` html
197 |
198 |
199 |
200 |
201 |
202 |
203 | ```
204 |
205 |
206 |
207 | ### Animation
208 | To add animation, add a `span.skeleton--animation` within the `.skeleton__line` elements in headers or paragaphs.
209 |
210 | 
211 |
212 | ``` html
213 |
214 |
215 |
216 |
217 |
218 |
219 |
220 |
221 |
222 |
223 |
224 |
225 |
226 |
227 |
228 |
229 | ```
230 |
231 |
232 |
233 | ## JavaScript Utility
234 | The easiest and our preferred way to add Skeletons is by using the included JavaScript utilities.
235 |
236 | On either a header tag or a paragraph tag, add the `skeleton` class and a `data-lines` attribute with the number of lines you'd like the skeleton to have:
237 |
238 | ``` html
239 |
240 |
241 | ```
242 |
243 |
244 |
245 | You can also give the skeleton animation by adding the `data-animation` attribute and setting it to `true`:
246 |
247 | ``` html
248 |
249 |
250 | ```
251 |
252 |
253 |
254 | ### JavaScript Data Attributes
255 | You can alter the way skeleton looks by utilizing other data-attributes as well, including opacity and color:
256 | ``` html
257 |
258 |
259 |
260 |
261 |
262 |
263 |
264 | ```
265 |
266 | #### All Data Attributes
267 | | Attribute | Description | Type |
268 | | ------------ |------------ | ------------|
269 | | `data-lines` | Determines how many lines to output | Integer |
270 | | `data-animation` | Adds animation to the skeleton lines | Boolean |
271 | | `data-opacity` | Sets the opacity of the skeleton lines (sets opacity between 0 and 1) | Float |
272 | | `data-color` | Sets the color of the skeleton lines | Color |
273 |
--------------------------------------------------------------------------------
/build.cmd:
--------------------------------------------------------------------------------
1 | @echo Off
2 | pushd %~dp0
3 | setlocal
4 |
5 | :Build
6 | call npm install
7 | if %ERRORLEVEL% neq 0 goto BuildFail
8 |
9 | if "%APPVEYOR%" equ "True" (
10 | echo *** Building Production [%APPVEYOR_REPO_BRANCH%] ***
11 | call npm run build
12 |
13 | ) else (
14 | echo *** Building Default ***
15 | call npm run serve
16 | )
17 |
18 | if %ERRORLEVEL% neq 0 goto BuildFail
19 |
20 | goto BuildSuccess
21 |
22 | :BuildFail
23 | echo.
24 | echo *** BUILD FAILED ***
25 | goto End
26 |
27 | :BuildSuccess
28 | echo.
29 | echo *** BUILD SUCCEEDED ***
30 | goto End
31 |
32 | :End
33 | echo.
34 | popd
35 | exit /B %ERRORLEVEL%
--------------------------------------------------------------------------------
/examples/blog-post.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | Blog Post
7 |
8 |
9 |
56 |
57 |
58 |
59 |
60 |
61 |
62 |
63 |
64 |
65 |
66 |
67 |
78 |
79 |
80 |
81 |
82 |
83 |
84 |
85 |
86 |
87 |
88 |
89 |
90 |
91 |
92 |
93 |
94 |
95 |
96 |
97 |
98 |
99 |
100 |
--------------------------------------------------------------------------------
/examples/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | Document
7 |
80 |
81 |
82 |
83 |
84 |
92 |
93 |
94 |
95 |
96 |
97 |
98 |
99 |
100 |
101 |
102 |
103 |
104 |
105 |
106 |
107 |
108 |
109 |
110 |
111 |
112 |
113 |
114 |
115 |
116 |
117 |
118 |
119 |
120 |
121 |
122 |
123 |
124 |
125 |
126 |
127 |
128 |
129 |
130 |
131 |
132 |
133 |
134 |
135 |
136 |
137 |
138 |
139 |
140 |
141 |
142 |
143 |
144 |
145 |
146 |
147 |
150 |
151 |
152 |
153 |
156 |
157 |
158 |
159 |
162 |
163 |
164 |
165 |
166 |
167 |
168 |
169 |
170 |
171 |
172 |
173 |
174 |
175 |
176 |
177 |
178 |
179 |
180 |
181 |
182 |
183 |
184 |
185 |
186 |
187 |
188 |
--------------------------------------------------------------------------------
/images/alignment.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ritterim/skellyCSS/fffd04428ed856f4b088d09cd7fedb9fd32e5cf1/images/alignment.png
--------------------------------------------------------------------------------
/images/animation.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ritterim/skellyCSS/fffd04428ed856f4b088d09cd7fedb9fd32e5cf1/images/animation.gif
--------------------------------------------------------------------------------
/images/fish-skeleton.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ritterim/skellyCSS/fffd04428ed856f4b088d09cd7fedb9fd32e5cf1/images/fish-skeleton.png
--------------------------------------------------------------------------------
/images/fish-skeleton.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/images/headers.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ritterim/skellyCSS/fffd04428ed856f4b088d09cd7fedb9fd32e5cf1/images/headers.png
--------------------------------------------------------------------------------
/images/image-shapes.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ritterim/skellyCSS/fffd04428ed856f4b088d09cd7fedb9fd32e5cf1/images/image-shapes.png
--------------------------------------------------------------------------------
/images/images.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ritterim/skellyCSS/fffd04428ed856f4b088d09cd7fedb9fd32e5cf1/images/images.png
--------------------------------------------------------------------------------
/images/line-widths.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ritterim/skellyCSS/fffd04428ed856f4b088d09cd7fedb9fd32e5cf1/images/line-widths.png
--------------------------------------------------------------------------------
/images/paragraphs.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ritterim/skellyCSS/fffd04428ed856f4b088d09cd7fedb9fd32e5cf1/images/paragraphs.png
--------------------------------------------------------------------------------
/images/skeleton-cards.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ritterim/skellyCSS/fffd04428ed856f4b088d09cd7fedb9fd32e5cf1/images/skeleton-cards.png
--------------------------------------------------------------------------------
/images/skellyCSS__full-logo.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/images/skellyCSS__logo.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 | Document
8 |
105 |
106 |
107 |
108 |
SkellyCSS
109 |
110 |
Headers
111 |
119 |
120 |
121 |
Paragraphs
122 |
125 |
126 |
127 |
Line Widths
128 |
129 |
Small
130 |
131 | Medium
132 |
133 | Large
134 |
135 | Full
136 |
137 |
138 |
139 |
140 |
Alignment
141 |
142 |
143 |
144 |
145 |
146 |
147 |
148 |
149 |
150 |
151 |
152 |
153 |
154 |
155 |
156 |
157 |
158 |
159 |
160 |
161 |
162 |
163 |
164 |
165 |
166 |
167 |
Images
168 |
169 |
170 |
171 |
172 |
173 |
174 |
175 |
Image Shapes
176 |
177 |
183 |
184 |
190 |
191 |
192 |
Landscape
193 |
196 |
197 |
198 |
199 |
Portrait
200 |
203 |
204 |
205 |
211 |
212 |
218 |
219 |
220 |
Animation
221 |
222 |
223 |
224 |
225 |
226 |
227 |
228 |
229 |
230 |
231 |
232 |
233 |
234 |
235 |
236 |
237 |
238 |
Opacity
239 |
242 |
243 |
Color
244 |
247 |
248 |
249 |
250 |
251 |
252 |
253 |
--------------------------------------------------------------------------------
/main.js:
--------------------------------------------------------------------------------
1 | import './src/style.scss';
2 | import './src/index.js';
3 |
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@ritterim/skellycss",
3 | "version": "0.1.6",
4 | "lockfileVersion": 3,
5 | "requires": true,
6 | "packages": {
7 | "": {
8 | "name": "@ritterim/skellycss",
9 | "version": "0.1.6",
10 | "license": "MIT",
11 | "devDependencies": {
12 | "autoprefixer": "^10.4.15",
13 | "postcss": "^8.4.29",
14 | "postcss-cli": "^10.1.0",
15 | "sass": "^1.66.1",
16 | "vite": "^4.4.9",
17 | "vite-plugin-banner": "^0.7.0"
18 | }
19 | },
20 | "node_modules/@esbuild/android-arm": {
21 | "version": "0.18.20",
22 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.18.20.tgz",
23 | "integrity": "sha512-fyi7TDI/ijKKNZTUJAQqiG5T7YjJXgnzkURqmGj13C6dCqckZBLdl4h7bkhHt/t0WP+zO9/zwroDvANaOqO5Sw==",
24 | "cpu": [
25 | "arm"
26 | ],
27 | "dev": true,
28 | "optional": true,
29 | "os": [
30 | "android"
31 | ],
32 | "engines": {
33 | "node": ">=12"
34 | }
35 | },
36 | "node_modules/@esbuild/android-arm64": {
37 | "version": "0.18.20",
38 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.18.20.tgz",
39 | "integrity": "sha512-Nz4rJcchGDtENV0eMKUNa6L12zz2zBDXuhj/Vjh18zGqB44Bi7MBMSXjgunJgjRhCmKOjnPuZp4Mb6OKqtMHLQ==",
40 | "cpu": [
41 | "arm64"
42 | ],
43 | "dev": true,
44 | "optional": true,
45 | "os": [
46 | "android"
47 | ],
48 | "engines": {
49 | "node": ">=12"
50 | }
51 | },
52 | "node_modules/@esbuild/android-x64": {
53 | "version": "0.18.20",
54 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.18.20.tgz",
55 | "integrity": "sha512-8GDdlePJA8D6zlZYJV/jnrRAi6rOiNaCC/JclcXpB+KIuvfBN4owLtgzY2bsxnx666XjJx2kDPUmnTtR8qKQUg==",
56 | "cpu": [
57 | "x64"
58 | ],
59 | "dev": true,
60 | "optional": true,
61 | "os": [
62 | "android"
63 | ],
64 | "engines": {
65 | "node": ">=12"
66 | }
67 | },
68 | "node_modules/@esbuild/darwin-arm64": {
69 | "version": "0.18.20",
70 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.18.20.tgz",
71 | "integrity": "sha512-bxRHW5kHU38zS2lPTPOyuyTm+S+eobPUnTNkdJEfAddYgEcll4xkT8DB9d2008DtTbl7uJag2HuE5NZAZgnNEA==",
72 | "cpu": [
73 | "arm64"
74 | ],
75 | "dev": true,
76 | "optional": true,
77 | "os": [
78 | "darwin"
79 | ],
80 | "engines": {
81 | "node": ">=12"
82 | }
83 | },
84 | "node_modules/@esbuild/darwin-x64": {
85 | "version": "0.18.20",
86 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.18.20.tgz",
87 | "integrity": "sha512-pc5gxlMDxzm513qPGbCbDukOdsGtKhfxD1zJKXjCCcU7ju50O7MeAZ8c4krSJcOIJGFR+qx21yMMVYwiQvyTyQ==",
88 | "cpu": [
89 | "x64"
90 | ],
91 | "dev": true,
92 | "optional": true,
93 | "os": [
94 | "darwin"
95 | ],
96 | "engines": {
97 | "node": ">=12"
98 | }
99 | },
100 | "node_modules/@esbuild/freebsd-arm64": {
101 | "version": "0.18.20",
102 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.18.20.tgz",
103 | "integrity": "sha512-yqDQHy4QHevpMAaxhhIwYPMv1NECwOvIpGCZkECn8w2WFHXjEwrBn3CeNIYsibZ/iZEUemj++M26W3cNR5h+Tw==",
104 | "cpu": [
105 | "arm64"
106 | ],
107 | "dev": true,
108 | "optional": true,
109 | "os": [
110 | "freebsd"
111 | ],
112 | "engines": {
113 | "node": ">=12"
114 | }
115 | },
116 | "node_modules/@esbuild/freebsd-x64": {
117 | "version": "0.18.20",
118 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.18.20.tgz",
119 | "integrity": "sha512-tgWRPPuQsd3RmBZwarGVHZQvtzfEBOreNuxEMKFcd5DaDn2PbBxfwLcj4+aenoh7ctXcbXmOQIn8HI6mCSw5MQ==",
120 | "cpu": [
121 | "x64"
122 | ],
123 | "dev": true,
124 | "optional": true,
125 | "os": [
126 | "freebsd"
127 | ],
128 | "engines": {
129 | "node": ">=12"
130 | }
131 | },
132 | "node_modules/@esbuild/linux-arm": {
133 | "version": "0.18.20",
134 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.18.20.tgz",
135 | "integrity": "sha512-/5bHkMWnq1EgKr1V+Ybz3s1hWXok7mDFUMQ4cG10AfW3wL02PSZi5kFpYKrptDsgb2WAJIvRcDm+qIvXf/apvg==",
136 | "cpu": [
137 | "arm"
138 | ],
139 | "dev": true,
140 | "optional": true,
141 | "os": [
142 | "linux"
143 | ],
144 | "engines": {
145 | "node": ">=12"
146 | }
147 | },
148 | "node_modules/@esbuild/linux-arm64": {
149 | "version": "0.18.20",
150 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.18.20.tgz",
151 | "integrity": "sha512-2YbscF+UL7SQAVIpnWvYwM+3LskyDmPhe31pE7/aoTMFKKzIc9lLbyGUpmmb8a8AixOL61sQ/mFh3jEjHYFvdA==",
152 | "cpu": [
153 | "arm64"
154 | ],
155 | "dev": true,
156 | "optional": true,
157 | "os": [
158 | "linux"
159 | ],
160 | "engines": {
161 | "node": ">=12"
162 | }
163 | },
164 | "node_modules/@esbuild/linux-ia32": {
165 | "version": "0.18.20",
166 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.18.20.tgz",
167 | "integrity": "sha512-P4etWwq6IsReT0E1KHU40bOnzMHoH73aXp96Fs8TIT6z9Hu8G6+0SHSw9i2isWrD2nbx2qo5yUqACgdfVGx7TA==",
168 | "cpu": [
169 | "ia32"
170 | ],
171 | "dev": true,
172 | "optional": true,
173 | "os": [
174 | "linux"
175 | ],
176 | "engines": {
177 | "node": ">=12"
178 | }
179 | },
180 | "node_modules/@esbuild/linux-loong64": {
181 | "version": "0.18.20",
182 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.18.20.tgz",
183 | "integrity": "sha512-nXW8nqBTrOpDLPgPY9uV+/1DjxoQ7DoB2N8eocyq8I9XuqJ7BiAMDMf9n1xZM9TgW0J8zrquIb/A7s3BJv7rjg==",
184 | "cpu": [
185 | "loong64"
186 | ],
187 | "dev": true,
188 | "optional": true,
189 | "os": [
190 | "linux"
191 | ],
192 | "engines": {
193 | "node": ">=12"
194 | }
195 | },
196 | "node_modules/@esbuild/linux-mips64el": {
197 | "version": "0.18.20",
198 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.18.20.tgz",
199 | "integrity": "sha512-d5NeaXZcHp8PzYy5VnXV3VSd2D328Zb+9dEq5HE6bw6+N86JVPExrA6O68OPwobntbNJ0pzCpUFZTo3w0GyetQ==",
200 | "cpu": [
201 | "mips64el"
202 | ],
203 | "dev": true,
204 | "optional": true,
205 | "os": [
206 | "linux"
207 | ],
208 | "engines": {
209 | "node": ">=12"
210 | }
211 | },
212 | "node_modules/@esbuild/linux-ppc64": {
213 | "version": "0.18.20",
214 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.18.20.tgz",
215 | "integrity": "sha512-WHPyeScRNcmANnLQkq6AfyXRFr5D6N2sKgkFo2FqguP44Nw2eyDlbTdZwd9GYk98DZG9QItIiTlFLHJHjxP3FA==",
216 | "cpu": [
217 | "ppc64"
218 | ],
219 | "dev": true,
220 | "optional": true,
221 | "os": [
222 | "linux"
223 | ],
224 | "engines": {
225 | "node": ">=12"
226 | }
227 | },
228 | "node_modules/@esbuild/linux-riscv64": {
229 | "version": "0.18.20",
230 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.18.20.tgz",
231 | "integrity": "sha512-WSxo6h5ecI5XH34KC7w5veNnKkju3zBRLEQNY7mv5mtBmrP/MjNBCAlsM2u5hDBlS3NGcTQpoBvRzqBcRtpq1A==",
232 | "cpu": [
233 | "riscv64"
234 | ],
235 | "dev": true,
236 | "optional": true,
237 | "os": [
238 | "linux"
239 | ],
240 | "engines": {
241 | "node": ">=12"
242 | }
243 | },
244 | "node_modules/@esbuild/linux-s390x": {
245 | "version": "0.18.20",
246 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.18.20.tgz",
247 | "integrity": "sha512-+8231GMs3mAEth6Ja1iK0a1sQ3ohfcpzpRLH8uuc5/KVDFneH6jtAJLFGafpzpMRO6DzJ6AvXKze9LfFMrIHVQ==",
248 | "cpu": [
249 | "s390x"
250 | ],
251 | "dev": true,
252 | "optional": true,
253 | "os": [
254 | "linux"
255 | ],
256 | "engines": {
257 | "node": ">=12"
258 | }
259 | },
260 | "node_modules/@esbuild/linux-x64": {
261 | "version": "0.18.20",
262 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.18.20.tgz",
263 | "integrity": "sha512-UYqiqemphJcNsFEskc73jQ7B9jgwjWrSayxawS6UVFZGWrAAtkzjxSqnoclCXxWtfwLdzU+vTpcNYhpn43uP1w==",
264 | "cpu": [
265 | "x64"
266 | ],
267 | "dev": true,
268 | "optional": true,
269 | "os": [
270 | "linux"
271 | ],
272 | "engines": {
273 | "node": ">=12"
274 | }
275 | },
276 | "node_modules/@esbuild/netbsd-x64": {
277 | "version": "0.18.20",
278 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.18.20.tgz",
279 | "integrity": "sha512-iO1c++VP6xUBUmltHZoMtCUdPlnPGdBom6IrO4gyKPFFVBKioIImVooR5I83nTew5UOYrk3gIJhbZh8X44y06A==",
280 | "cpu": [
281 | "x64"
282 | ],
283 | "dev": true,
284 | "optional": true,
285 | "os": [
286 | "netbsd"
287 | ],
288 | "engines": {
289 | "node": ">=12"
290 | }
291 | },
292 | "node_modules/@esbuild/openbsd-x64": {
293 | "version": "0.18.20",
294 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.18.20.tgz",
295 | "integrity": "sha512-e5e4YSsuQfX4cxcygw/UCPIEP6wbIL+se3sxPdCiMbFLBWu0eiZOJ7WoD+ptCLrmjZBK1Wk7I6D/I3NglUGOxg==",
296 | "cpu": [
297 | "x64"
298 | ],
299 | "dev": true,
300 | "optional": true,
301 | "os": [
302 | "openbsd"
303 | ],
304 | "engines": {
305 | "node": ">=12"
306 | }
307 | },
308 | "node_modules/@esbuild/sunos-x64": {
309 | "version": "0.18.20",
310 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.18.20.tgz",
311 | "integrity": "sha512-kDbFRFp0YpTQVVrqUd5FTYmWo45zGaXe0X8E1G/LKFC0v8x0vWrhOWSLITcCn63lmZIxfOMXtCfti/RxN/0wnQ==",
312 | "cpu": [
313 | "x64"
314 | ],
315 | "dev": true,
316 | "optional": true,
317 | "os": [
318 | "sunos"
319 | ],
320 | "engines": {
321 | "node": ">=12"
322 | }
323 | },
324 | "node_modules/@esbuild/win32-arm64": {
325 | "version": "0.18.20",
326 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.18.20.tgz",
327 | "integrity": "sha512-ddYFR6ItYgoaq4v4JmQQaAI5s7npztfV4Ag6NrhiaW0RrnOXqBkgwZLofVTlq1daVTQNhtI5oieTvkRPfZrePg==",
328 | "cpu": [
329 | "arm64"
330 | ],
331 | "dev": true,
332 | "optional": true,
333 | "os": [
334 | "win32"
335 | ],
336 | "engines": {
337 | "node": ">=12"
338 | }
339 | },
340 | "node_modules/@esbuild/win32-ia32": {
341 | "version": "0.18.20",
342 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.18.20.tgz",
343 | "integrity": "sha512-Wv7QBi3ID/rROT08SABTS7eV4hX26sVduqDOTe1MvGMjNd3EjOz4b7zeexIR62GTIEKrfJXKL9LFxTYgkyeu7g==",
344 | "cpu": [
345 | "ia32"
346 | ],
347 | "dev": true,
348 | "optional": true,
349 | "os": [
350 | "win32"
351 | ],
352 | "engines": {
353 | "node": ">=12"
354 | }
355 | },
356 | "node_modules/@esbuild/win32-x64": {
357 | "version": "0.18.20",
358 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.18.20.tgz",
359 | "integrity": "sha512-kTdfRcSiDfQca/y9QIkng02avJ+NCaQvrMejlsB3RRv5sE9rRoeBPISaZpKxHELzRxZyLvNts1P27W3wV+8geQ==",
360 | "cpu": [
361 | "x64"
362 | ],
363 | "dev": true,
364 | "optional": true,
365 | "os": [
366 | "win32"
367 | ],
368 | "engines": {
369 | "node": ">=12"
370 | }
371 | },
372 | "node_modules/@nodelib/fs.scandir": {
373 | "version": "2.1.5",
374 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
375 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==",
376 | "dev": true,
377 | "dependencies": {
378 | "@nodelib/fs.stat": "2.0.5",
379 | "run-parallel": "^1.1.9"
380 | },
381 | "engines": {
382 | "node": ">= 8"
383 | }
384 | },
385 | "node_modules/@nodelib/fs.stat": {
386 | "version": "2.0.5",
387 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz",
388 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==",
389 | "dev": true,
390 | "engines": {
391 | "node": ">= 8"
392 | }
393 | },
394 | "node_modules/@nodelib/fs.walk": {
395 | "version": "1.2.8",
396 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz",
397 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==",
398 | "dev": true,
399 | "dependencies": {
400 | "@nodelib/fs.scandir": "2.1.5",
401 | "fastq": "^1.6.0"
402 | },
403 | "engines": {
404 | "node": ">= 8"
405 | }
406 | },
407 | "node_modules/ansi-regex": {
408 | "version": "5.0.1",
409 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
410 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
411 | "dev": true,
412 | "engines": {
413 | "node": ">=8"
414 | }
415 | },
416 | "node_modules/ansi-styles": {
417 | "version": "4.3.0",
418 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
419 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
420 | "dev": true,
421 | "dependencies": {
422 | "color-convert": "^2.0.1"
423 | },
424 | "engines": {
425 | "node": ">=8"
426 | },
427 | "funding": {
428 | "url": "https://github.com/chalk/ansi-styles?sponsor=1"
429 | }
430 | },
431 | "node_modules/anymatch": {
432 | "version": "3.1.1",
433 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz",
434 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==",
435 | "dev": true,
436 | "dependencies": {
437 | "normalize-path": "^3.0.0",
438 | "picomatch": "^2.0.4"
439 | },
440 | "engines": {
441 | "node": ">= 8"
442 | }
443 | },
444 | "node_modules/autoprefixer": {
445 | "version": "10.4.15",
446 | "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.15.tgz",
447 | "integrity": "sha512-KCuPB8ZCIqFdA4HwKXsvz7j6gvSDNhDP7WnUjBleRkKjPdvCmHFuQ77ocavI8FT6NdvlBnE2UFr2H4Mycn8Vew==",
448 | "dev": true,
449 | "funding": [
450 | {
451 | "type": "opencollective",
452 | "url": "https://opencollective.com/postcss/"
453 | },
454 | {
455 | "type": "tidelift",
456 | "url": "https://tidelift.com/funding/github/npm/autoprefixer"
457 | },
458 | {
459 | "type": "github",
460 | "url": "https://github.com/sponsors/ai"
461 | }
462 | ],
463 | "dependencies": {
464 | "browserslist": "^4.21.10",
465 | "caniuse-lite": "^1.0.30001520",
466 | "fraction.js": "^4.2.0",
467 | "normalize-range": "^0.1.2",
468 | "picocolors": "^1.0.0",
469 | "postcss-value-parser": "^4.2.0"
470 | },
471 | "bin": {
472 | "autoprefixer": "bin/autoprefixer"
473 | },
474 | "engines": {
475 | "node": "^10 || ^12 || >=14"
476 | },
477 | "peerDependencies": {
478 | "postcss": "^8.1.0"
479 | }
480 | },
481 | "node_modules/binary-extensions": {
482 | "version": "2.1.0",
483 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.1.0.tgz",
484 | "integrity": "sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ==",
485 | "dev": true,
486 | "engines": {
487 | "node": ">=8"
488 | }
489 | },
490 | "node_modules/braces": {
491 | "version": "3.0.2",
492 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
493 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
494 | "dev": true,
495 | "dependencies": {
496 | "fill-range": "^7.0.1"
497 | },
498 | "engines": {
499 | "node": ">=8"
500 | }
501 | },
502 | "node_modules/browserslist": {
503 | "version": "4.21.10",
504 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.10.tgz",
505 | "integrity": "sha512-bipEBdZfVH5/pwrvqc+Ub0kUPVfGUhlKxbvfD+z1BDnPEO/X98ruXGA1WP5ASpAFKan7Qr6j736IacbZQuAlKQ==",
506 | "dev": true,
507 | "funding": [
508 | {
509 | "type": "opencollective",
510 | "url": "https://opencollective.com/browserslist"
511 | },
512 | {
513 | "type": "tidelift",
514 | "url": "https://tidelift.com/funding/github/npm/browserslist"
515 | },
516 | {
517 | "type": "github",
518 | "url": "https://github.com/sponsors/ai"
519 | }
520 | ],
521 | "dependencies": {
522 | "caniuse-lite": "^1.0.30001517",
523 | "electron-to-chromium": "^1.4.477",
524 | "node-releases": "^2.0.13",
525 | "update-browserslist-db": "^1.0.11"
526 | },
527 | "bin": {
528 | "browserslist": "cli.js"
529 | },
530 | "engines": {
531 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
532 | }
533 | },
534 | "node_modules/caniuse-lite": {
535 | "version": "1.0.30001529",
536 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001529.tgz",
537 | "integrity": "sha512-n2pUQYGAkrLG4QYj2desAh+NqsJpHbNmVZz87imptDdxLAtjxary7Df/psdfyDGmskJK/9Dt9cPnx5RZ3CU4Og==",
538 | "dev": true,
539 | "funding": [
540 | {
541 | "type": "opencollective",
542 | "url": "https://opencollective.com/browserslist"
543 | },
544 | {
545 | "type": "tidelift",
546 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite"
547 | },
548 | {
549 | "type": "github",
550 | "url": "https://github.com/sponsors/ai"
551 | }
552 | ]
553 | },
554 | "node_modules/chokidar": {
555 | "version": "3.4.3",
556 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.4.3.tgz",
557 | "integrity": "sha512-DtM3g7juCXQxFVSNPNByEC2+NImtBuxQQvWlHunpJIS5Ocr0lG306cC7FCi7cEA0fzmybPUIl4txBIobk1gGOQ==",
558 | "dev": true,
559 | "dependencies": {
560 | "anymatch": "~3.1.1",
561 | "braces": "~3.0.2",
562 | "glob-parent": "~5.1.0",
563 | "is-binary-path": "~2.1.0",
564 | "is-glob": "~4.0.1",
565 | "normalize-path": "~3.0.0",
566 | "readdirp": "~3.5.0"
567 | },
568 | "engines": {
569 | "node": ">= 8.10.0"
570 | },
571 | "optionalDependencies": {
572 | "fsevents": "~2.1.2"
573 | }
574 | },
575 | "node_modules/cliui": {
576 | "version": "7.0.4",
577 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz",
578 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==",
579 | "dev": true,
580 | "dependencies": {
581 | "string-width": "^4.2.0",
582 | "strip-ansi": "^6.0.0",
583 | "wrap-ansi": "^7.0.0"
584 | }
585 | },
586 | "node_modules/color-convert": {
587 | "version": "2.0.1",
588 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
589 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
590 | "dev": true,
591 | "dependencies": {
592 | "color-name": "~1.1.4"
593 | },
594 | "engines": {
595 | "node": ">=7.0.0"
596 | }
597 | },
598 | "node_modules/color-name": {
599 | "version": "1.1.4",
600 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
601 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
602 | "dev": true
603 | },
604 | "node_modules/dependency-graph": {
605 | "version": "0.11.0",
606 | "resolved": "https://registry.npmjs.org/dependency-graph/-/dependency-graph-0.11.0.tgz",
607 | "integrity": "sha512-JeMq7fEshyepOWDfcfHK06N3MhyPhz++vtqWhMT5O9A3K42rdsEDpfdVqjaqaAhsw6a+ZqeDvQVtD0hFHQWrzg==",
608 | "dev": true,
609 | "engines": {
610 | "node": ">= 0.6.0"
611 | }
612 | },
613 | "node_modules/dir-glob": {
614 | "version": "3.0.1",
615 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz",
616 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==",
617 | "dev": true,
618 | "dependencies": {
619 | "path-type": "^4.0.0"
620 | },
621 | "engines": {
622 | "node": ">=8"
623 | }
624 | },
625 | "node_modules/electron-to-chromium": {
626 | "version": "1.4.512",
627 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.512.tgz",
628 | "integrity": "sha512-1W8wRbYlQE4ph7eoj3TJ+uqwO6+xvAE/L+KGU7WTQQvX3tnSIGZAb90MTsMoJqzntamiwJhBAj4WZmygXhsOUg==",
629 | "dev": true
630 | },
631 | "node_modules/emoji-regex": {
632 | "version": "8.0.0",
633 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
634 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
635 | "dev": true
636 | },
637 | "node_modules/esbuild": {
638 | "version": "0.18.20",
639 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.18.20.tgz",
640 | "integrity": "sha512-ceqxoedUrcayh7Y7ZX6NdbbDzGROiyVBgC4PriJThBKSVPWnnFHZAkfI1lJT8QFkOwH4qOS2SJkS4wvpGl8BpA==",
641 | "dev": true,
642 | "hasInstallScript": true,
643 | "bin": {
644 | "esbuild": "bin/esbuild"
645 | },
646 | "engines": {
647 | "node": ">=12"
648 | },
649 | "optionalDependencies": {
650 | "@esbuild/android-arm": "0.18.20",
651 | "@esbuild/android-arm64": "0.18.20",
652 | "@esbuild/android-x64": "0.18.20",
653 | "@esbuild/darwin-arm64": "0.18.20",
654 | "@esbuild/darwin-x64": "0.18.20",
655 | "@esbuild/freebsd-arm64": "0.18.20",
656 | "@esbuild/freebsd-x64": "0.18.20",
657 | "@esbuild/linux-arm": "0.18.20",
658 | "@esbuild/linux-arm64": "0.18.20",
659 | "@esbuild/linux-ia32": "0.18.20",
660 | "@esbuild/linux-loong64": "0.18.20",
661 | "@esbuild/linux-mips64el": "0.18.20",
662 | "@esbuild/linux-ppc64": "0.18.20",
663 | "@esbuild/linux-riscv64": "0.18.20",
664 | "@esbuild/linux-s390x": "0.18.20",
665 | "@esbuild/linux-x64": "0.18.20",
666 | "@esbuild/netbsd-x64": "0.18.20",
667 | "@esbuild/openbsd-x64": "0.18.20",
668 | "@esbuild/sunos-x64": "0.18.20",
669 | "@esbuild/win32-arm64": "0.18.20",
670 | "@esbuild/win32-ia32": "0.18.20",
671 | "@esbuild/win32-x64": "0.18.20"
672 | }
673 | },
674 | "node_modules/escalade": {
675 | "version": "3.1.1",
676 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
677 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==",
678 | "dev": true,
679 | "engines": {
680 | "node": ">=6"
681 | }
682 | },
683 | "node_modules/fast-glob": {
684 | "version": "3.3.1",
685 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.1.tgz",
686 | "integrity": "sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg==",
687 | "dev": true,
688 | "dependencies": {
689 | "@nodelib/fs.stat": "^2.0.2",
690 | "@nodelib/fs.walk": "^1.2.3",
691 | "glob-parent": "^5.1.2",
692 | "merge2": "^1.3.0",
693 | "micromatch": "^4.0.4"
694 | },
695 | "engines": {
696 | "node": ">=8.6.0"
697 | }
698 | },
699 | "node_modules/fastq": {
700 | "version": "1.15.0",
701 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz",
702 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==",
703 | "dev": true,
704 | "dependencies": {
705 | "reusify": "^1.0.4"
706 | }
707 | },
708 | "node_modules/fill-range": {
709 | "version": "7.0.1",
710 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
711 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
712 | "dev": true,
713 | "dependencies": {
714 | "to-regex-range": "^5.0.1"
715 | },
716 | "engines": {
717 | "node": ">=8"
718 | }
719 | },
720 | "node_modules/fraction.js": {
721 | "version": "4.3.6",
722 | "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.6.tgz",
723 | "integrity": "sha512-n2aZ9tNfYDwaHhvFTkhFErqOMIb8uyzSQ+vGJBjZyanAKZVbGUQ1sngfk9FdkBw7G26O7AgNjLcecLffD1c7eg==",
724 | "dev": true,
725 | "engines": {
726 | "node": "*"
727 | },
728 | "funding": {
729 | "type": "patreon",
730 | "url": "https://github.com/sponsors/rawify"
731 | }
732 | },
733 | "node_modules/fs-extra": {
734 | "version": "11.1.1",
735 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.1.1.tgz",
736 | "integrity": "sha512-MGIE4HOvQCeUCzmlHs0vXpih4ysz4wg9qiSAu6cd42lVwPbTM1TjV7RusoyQqMmk/95gdQZX72u+YW+c3eEpFQ==",
737 | "dev": true,
738 | "dependencies": {
739 | "graceful-fs": "^4.2.0",
740 | "jsonfile": "^6.0.1",
741 | "universalify": "^2.0.0"
742 | },
743 | "engines": {
744 | "node": ">=14.14"
745 | }
746 | },
747 | "node_modules/fsevents": {
748 | "version": "2.1.3",
749 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz",
750 | "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==",
751 | "deprecated": "\"Please update to latest v2.3 or v2.2\"",
752 | "dev": true,
753 | "hasInstallScript": true,
754 | "optional": true,
755 | "os": [
756 | "darwin"
757 | ],
758 | "engines": {
759 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
760 | }
761 | },
762 | "node_modules/get-caller-file": {
763 | "version": "2.0.5",
764 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz",
765 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
766 | "dev": true,
767 | "engines": {
768 | "node": "6.* || 8.* || >= 10.*"
769 | }
770 | },
771 | "node_modules/get-stdin": {
772 | "version": "9.0.0",
773 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-9.0.0.tgz",
774 | "integrity": "sha512-dVKBjfWisLAicarI2Sf+JuBE/DghV4UzNAVe9yhEJuzeREd3JhOTE9cUaJTeSa77fsbQUK3pcOpJfM59+VKZaA==",
775 | "dev": true,
776 | "engines": {
777 | "node": ">=12"
778 | },
779 | "funding": {
780 | "url": "https://github.com/sponsors/sindresorhus"
781 | }
782 | },
783 | "node_modules/glob-parent": {
784 | "version": "5.1.2",
785 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
786 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
787 | "dev": true,
788 | "dependencies": {
789 | "is-glob": "^4.0.1"
790 | },
791 | "engines": {
792 | "node": ">= 6"
793 | }
794 | },
795 | "node_modules/globby": {
796 | "version": "13.2.2",
797 | "resolved": "https://registry.npmjs.org/globby/-/globby-13.2.2.tgz",
798 | "integrity": "sha512-Y1zNGV+pzQdh7H39l9zgB4PJqjRNqydvdYCDG4HFXM4XuvSaQQlEc91IU1yALL8gUTDomgBAfz3XJdmUS+oo0w==",
799 | "dev": true,
800 | "dependencies": {
801 | "dir-glob": "^3.0.1",
802 | "fast-glob": "^3.3.0",
803 | "ignore": "^5.2.4",
804 | "merge2": "^1.4.1",
805 | "slash": "^4.0.0"
806 | },
807 | "engines": {
808 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
809 | },
810 | "funding": {
811 | "url": "https://github.com/sponsors/sindresorhus"
812 | }
813 | },
814 | "node_modules/globby/node_modules/slash": {
815 | "version": "4.0.0",
816 | "resolved": "https://registry.npmjs.org/slash/-/slash-4.0.0.tgz",
817 | "integrity": "sha512-3dOsAHXXUkQTpOYcoAxLIorMTp4gIQr5IW3iVb7A7lFIp0VHhnynm9izx6TssdrIcVIESAlVjtnO2K8bg+Coew==",
818 | "dev": true,
819 | "engines": {
820 | "node": ">=12"
821 | },
822 | "funding": {
823 | "url": "https://github.com/sponsors/sindresorhus"
824 | }
825 | },
826 | "node_modules/graceful-fs": {
827 | "version": "4.2.11",
828 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz",
829 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==",
830 | "dev": true
831 | },
832 | "node_modules/ignore": {
833 | "version": "5.2.4",
834 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz",
835 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==",
836 | "dev": true,
837 | "engines": {
838 | "node": ">= 4"
839 | }
840 | },
841 | "node_modules/immutable": {
842 | "version": "4.0.0",
843 | "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.0.0.tgz",
844 | "integrity": "sha512-zIE9hX70qew5qTUjSS7wi1iwj/l7+m54KWU247nhM3v806UdGj1yDndXj+IOYxxtW9zyLI+xqFNZjTuDaLUqFw==",
845 | "dev": true
846 | },
847 | "node_modules/is-binary-path": {
848 | "version": "2.1.0",
849 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
850 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
851 | "dev": true,
852 | "dependencies": {
853 | "binary-extensions": "^2.0.0"
854 | },
855 | "engines": {
856 | "node": ">=8"
857 | }
858 | },
859 | "node_modules/is-extglob": {
860 | "version": "2.1.1",
861 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
862 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
863 | "dev": true,
864 | "engines": {
865 | "node": ">=0.10.0"
866 | }
867 | },
868 | "node_modules/is-fullwidth-code-point": {
869 | "version": "3.0.0",
870 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
871 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
872 | "dev": true,
873 | "engines": {
874 | "node": ">=8"
875 | }
876 | },
877 | "node_modules/is-glob": {
878 | "version": "4.0.1",
879 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
880 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
881 | "dev": true,
882 | "dependencies": {
883 | "is-extglob": "^2.1.1"
884 | },
885 | "engines": {
886 | "node": ">=0.10.0"
887 | }
888 | },
889 | "node_modules/is-number": {
890 | "version": "7.0.0",
891 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
892 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
893 | "dev": true,
894 | "engines": {
895 | "node": ">=0.12.0"
896 | }
897 | },
898 | "node_modules/jsonfile": {
899 | "version": "6.1.0",
900 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.1.0.tgz",
901 | "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==",
902 | "dev": true,
903 | "dependencies": {
904 | "universalify": "^2.0.0"
905 | },
906 | "optionalDependencies": {
907 | "graceful-fs": "^4.1.6"
908 | }
909 | },
910 | "node_modules/lilconfig": {
911 | "version": "2.1.0",
912 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.1.0.tgz",
913 | "integrity": "sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ==",
914 | "dev": true,
915 | "engines": {
916 | "node": ">=10"
917 | }
918 | },
919 | "node_modules/merge2": {
920 | "version": "1.4.1",
921 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz",
922 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==",
923 | "dev": true,
924 | "engines": {
925 | "node": ">= 8"
926 | }
927 | },
928 | "node_modules/micromatch": {
929 | "version": "4.0.5",
930 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz",
931 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==",
932 | "dev": true,
933 | "dependencies": {
934 | "braces": "^3.0.2",
935 | "picomatch": "^2.3.1"
936 | },
937 | "engines": {
938 | "node": ">=8.6"
939 | }
940 | },
941 | "node_modules/nanoid": {
942 | "version": "3.3.6",
943 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz",
944 | "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==",
945 | "dev": true,
946 | "funding": [
947 | {
948 | "type": "github",
949 | "url": "https://github.com/sponsors/ai"
950 | }
951 | ],
952 | "bin": {
953 | "nanoid": "bin/nanoid.cjs"
954 | },
955 | "engines": {
956 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
957 | }
958 | },
959 | "node_modules/node-releases": {
960 | "version": "2.0.13",
961 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.13.tgz",
962 | "integrity": "sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ==",
963 | "dev": true
964 | },
965 | "node_modules/normalize-path": {
966 | "version": "3.0.0",
967 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
968 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
969 | "dev": true,
970 | "engines": {
971 | "node": ">=0.10.0"
972 | }
973 | },
974 | "node_modules/normalize-range": {
975 | "version": "0.1.2",
976 | "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz",
977 | "integrity": "sha1-LRDAa9/TEuqXd2laTShDlFa3WUI=",
978 | "dev": true,
979 | "engines": {
980 | "node": ">=0.10.0"
981 | }
982 | },
983 | "node_modules/path-type": {
984 | "version": "4.0.0",
985 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
986 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
987 | "dev": true,
988 | "engines": {
989 | "node": ">=8"
990 | }
991 | },
992 | "node_modules/picocolors": {
993 | "version": "1.0.0",
994 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz",
995 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==",
996 | "dev": true
997 | },
998 | "node_modules/picomatch": {
999 | "version": "2.3.1",
1000 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
1001 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
1002 | "dev": true,
1003 | "engines": {
1004 | "node": ">=8.6"
1005 | },
1006 | "funding": {
1007 | "url": "https://github.com/sponsors/jonschlinkert"
1008 | }
1009 | },
1010 | "node_modules/pify": {
1011 | "version": "2.3.0",
1012 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz",
1013 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=",
1014 | "dev": true,
1015 | "engines": {
1016 | "node": ">=0.10.0"
1017 | }
1018 | },
1019 | "node_modules/postcss": {
1020 | "version": "8.4.29",
1021 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.29.tgz",
1022 | "integrity": "sha512-cbI+jaqIeu/VGqXEarWkRCCffhjgXc0qjBtXpqJhTBohMUjUQnbBr0xqX3vEKudc4iviTewcJo5ajcec5+wdJw==",
1023 | "dev": true,
1024 | "funding": [
1025 | {
1026 | "type": "opencollective",
1027 | "url": "https://opencollective.com/postcss/"
1028 | },
1029 | {
1030 | "type": "tidelift",
1031 | "url": "https://tidelift.com/funding/github/npm/postcss"
1032 | },
1033 | {
1034 | "type": "github",
1035 | "url": "https://github.com/sponsors/ai"
1036 | }
1037 | ],
1038 | "dependencies": {
1039 | "nanoid": "^3.3.6",
1040 | "picocolors": "^1.0.0",
1041 | "source-map-js": "^1.0.2"
1042 | },
1043 | "engines": {
1044 | "node": "^10 || ^12 || >=14"
1045 | }
1046 | },
1047 | "node_modules/postcss-cli": {
1048 | "version": "10.1.0",
1049 | "resolved": "https://registry.npmjs.org/postcss-cli/-/postcss-cli-10.1.0.tgz",
1050 | "integrity": "sha512-Zu7PLORkE9YwNdvOeOVKPmWghprOtjFQU3srMUGbdz3pHJiFh7yZ4geiZFMkjMfB0mtTFR3h8RemR62rPkbOPA==",
1051 | "dev": true,
1052 | "dependencies": {
1053 | "chokidar": "^3.3.0",
1054 | "dependency-graph": "^0.11.0",
1055 | "fs-extra": "^11.0.0",
1056 | "get-stdin": "^9.0.0",
1057 | "globby": "^13.0.0",
1058 | "picocolors": "^1.0.0",
1059 | "postcss-load-config": "^4.0.0",
1060 | "postcss-reporter": "^7.0.0",
1061 | "pretty-hrtime": "^1.0.3",
1062 | "read-cache": "^1.0.0",
1063 | "slash": "^5.0.0",
1064 | "yargs": "^17.0.0"
1065 | },
1066 | "bin": {
1067 | "postcss": "index.js"
1068 | },
1069 | "engines": {
1070 | "node": ">=14"
1071 | },
1072 | "peerDependencies": {
1073 | "postcss": "^8.0.0"
1074 | }
1075 | },
1076 | "node_modules/postcss-load-config": {
1077 | "version": "4.0.1",
1078 | "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-4.0.1.tgz",
1079 | "integrity": "sha512-vEJIc8RdiBRu3oRAI0ymerOn+7rPuMvRXslTvZUKZonDHFIczxztIyJ1urxM1x9JXEikvpWWTUUqal5j/8QgvA==",
1080 | "dev": true,
1081 | "dependencies": {
1082 | "lilconfig": "^2.0.5",
1083 | "yaml": "^2.1.1"
1084 | },
1085 | "engines": {
1086 | "node": ">= 14"
1087 | },
1088 | "funding": {
1089 | "type": "opencollective",
1090 | "url": "https://opencollective.com/postcss/"
1091 | },
1092 | "peerDependencies": {
1093 | "postcss": ">=8.0.9",
1094 | "ts-node": ">=9.0.0"
1095 | },
1096 | "peerDependenciesMeta": {
1097 | "postcss": {
1098 | "optional": true
1099 | },
1100 | "ts-node": {
1101 | "optional": true
1102 | }
1103 | }
1104 | },
1105 | "node_modules/postcss-reporter": {
1106 | "version": "7.0.5",
1107 | "resolved": "https://registry.npmjs.org/postcss-reporter/-/postcss-reporter-7.0.5.tgz",
1108 | "integrity": "sha512-glWg7VZBilooZGOFPhN9msJ3FQs19Hie7l5a/eE6WglzYqVeH3ong3ShFcp9kDWJT1g2Y/wd59cocf9XxBtkWA==",
1109 | "dev": true,
1110 | "dependencies": {
1111 | "picocolors": "^1.0.0",
1112 | "thenby": "^1.3.4"
1113 | },
1114 | "engines": {
1115 | "node": ">=10"
1116 | },
1117 | "funding": {
1118 | "type": "opencollective",
1119 | "url": "https://opencollective.com/postcss/"
1120 | },
1121 | "peerDependencies": {
1122 | "postcss": "^8.1.0"
1123 | }
1124 | },
1125 | "node_modules/postcss-value-parser": {
1126 | "version": "4.2.0",
1127 | "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz",
1128 | "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==",
1129 | "dev": true
1130 | },
1131 | "node_modules/pretty-hrtime": {
1132 | "version": "1.0.3",
1133 | "resolved": "https://registry.npmjs.org/pretty-hrtime/-/pretty-hrtime-1.0.3.tgz",
1134 | "integrity": "sha1-t+PqQkNaTJsnWdmeDyAesZWALuE=",
1135 | "dev": true,
1136 | "engines": {
1137 | "node": ">= 0.8"
1138 | }
1139 | },
1140 | "node_modules/queue-microtask": {
1141 | "version": "1.2.3",
1142 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz",
1143 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==",
1144 | "dev": true,
1145 | "funding": [
1146 | {
1147 | "type": "github",
1148 | "url": "https://github.com/sponsors/feross"
1149 | },
1150 | {
1151 | "type": "patreon",
1152 | "url": "https://www.patreon.com/feross"
1153 | },
1154 | {
1155 | "type": "consulting",
1156 | "url": "https://feross.org/support"
1157 | }
1158 | ]
1159 | },
1160 | "node_modules/read-cache": {
1161 | "version": "1.0.0",
1162 | "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz",
1163 | "integrity": "sha1-5mTvMRYRZsl1HNvo28+GtftY93Q=",
1164 | "dev": true,
1165 | "dependencies": {
1166 | "pify": "^2.3.0"
1167 | }
1168 | },
1169 | "node_modules/readdirp": {
1170 | "version": "3.5.0",
1171 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.5.0.tgz",
1172 | "integrity": "sha512-cMhu7c/8rdhkHXWsY+osBhfSy0JikwpHK/5+imo+LpeasTF8ouErHrlYkwT0++njiyuDvc7OFY5T3ukvZ8qmFQ==",
1173 | "dev": true,
1174 | "dependencies": {
1175 | "picomatch": "^2.2.1"
1176 | },
1177 | "engines": {
1178 | "node": ">=8.10.0"
1179 | }
1180 | },
1181 | "node_modules/require-directory": {
1182 | "version": "2.1.1",
1183 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
1184 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=",
1185 | "dev": true,
1186 | "engines": {
1187 | "node": ">=0.10.0"
1188 | }
1189 | },
1190 | "node_modules/reusify": {
1191 | "version": "1.0.4",
1192 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz",
1193 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==",
1194 | "dev": true,
1195 | "engines": {
1196 | "iojs": ">=1.0.0",
1197 | "node": ">=0.10.0"
1198 | }
1199 | },
1200 | "node_modules/rollup": {
1201 | "version": "3.29.0",
1202 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.29.0.tgz",
1203 | "integrity": "sha512-nszM8DINnx1vSS+TpbWKMkxem0CDWk3cSit/WWCBVs9/JZ1I/XLwOsiUglYuYReaeWWSsW9kge5zE5NZtf/a4w==",
1204 | "dev": true,
1205 | "bin": {
1206 | "rollup": "dist/bin/rollup"
1207 | },
1208 | "engines": {
1209 | "node": ">=14.18.0",
1210 | "npm": ">=8.0.0"
1211 | },
1212 | "optionalDependencies": {
1213 | "fsevents": "~2.3.2"
1214 | }
1215 | },
1216 | "node_modules/rollup/node_modules/fsevents": {
1217 | "version": "2.3.3",
1218 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
1219 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
1220 | "dev": true,
1221 | "hasInstallScript": true,
1222 | "optional": true,
1223 | "os": [
1224 | "darwin"
1225 | ],
1226 | "engines": {
1227 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
1228 | }
1229 | },
1230 | "node_modules/run-parallel": {
1231 | "version": "1.2.0",
1232 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz",
1233 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==",
1234 | "dev": true,
1235 | "funding": [
1236 | {
1237 | "type": "github",
1238 | "url": "https://github.com/sponsors/feross"
1239 | },
1240 | {
1241 | "type": "patreon",
1242 | "url": "https://www.patreon.com/feross"
1243 | },
1244 | {
1245 | "type": "consulting",
1246 | "url": "https://feross.org/support"
1247 | }
1248 | ],
1249 | "dependencies": {
1250 | "queue-microtask": "^1.2.2"
1251 | }
1252 | },
1253 | "node_modules/sass": {
1254 | "version": "1.66.1",
1255 | "resolved": "https://registry.npmjs.org/sass/-/sass-1.66.1.tgz",
1256 | "integrity": "sha512-50c+zTsZOJVgFfTgwwEzkjA3/QACgdNsKueWPyAR0mRINIvLAStVQBbPg14iuqEQ74NPDbXzJARJ/O4SI1zftA==",
1257 | "dev": true,
1258 | "dependencies": {
1259 | "chokidar": ">=3.0.0 <4.0.0",
1260 | "immutable": "^4.0.0",
1261 | "source-map-js": ">=0.6.2 <2.0.0"
1262 | },
1263 | "bin": {
1264 | "sass": "sass.js"
1265 | },
1266 | "engines": {
1267 | "node": ">=14.0.0"
1268 | }
1269 | },
1270 | "node_modules/slash": {
1271 | "version": "5.1.0",
1272 | "resolved": "https://registry.npmjs.org/slash/-/slash-5.1.0.tgz",
1273 | "integrity": "sha512-ZA6oR3T/pEyuqwMgAKT0/hAv8oAXckzbkmR0UkUosQ+Mc4RxGoJkRmwHgHufaenlyAgE1Mxgpdcrf75y6XcnDg==",
1274 | "dev": true,
1275 | "engines": {
1276 | "node": ">=14.16"
1277 | },
1278 | "funding": {
1279 | "url": "https://github.com/sponsors/sindresorhus"
1280 | }
1281 | },
1282 | "node_modules/source-map-js": {
1283 | "version": "1.0.2",
1284 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
1285 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==",
1286 | "dev": true,
1287 | "engines": {
1288 | "node": ">=0.10.0"
1289 | }
1290 | },
1291 | "node_modules/string-width": {
1292 | "version": "4.2.3",
1293 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
1294 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
1295 | "dev": true,
1296 | "dependencies": {
1297 | "emoji-regex": "^8.0.0",
1298 | "is-fullwidth-code-point": "^3.0.0",
1299 | "strip-ansi": "^6.0.1"
1300 | },
1301 | "engines": {
1302 | "node": ">=8"
1303 | }
1304 | },
1305 | "node_modules/strip-ansi": {
1306 | "version": "6.0.1",
1307 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
1308 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
1309 | "dev": true,
1310 | "dependencies": {
1311 | "ansi-regex": "^5.0.1"
1312 | },
1313 | "engines": {
1314 | "node": ">=8"
1315 | }
1316 | },
1317 | "node_modules/thenby": {
1318 | "version": "1.3.4",
1319 | "resolved": "https://registry.npmjs.org/thenby/-/thenby-1.3.4.tgz",
1320 | "integrity": "sha512-89Gi5raiWA3QZ4b2ePcEwswC3me9JIg+ToSgtE0JWeCynLnLxNr/f9G+xfo9K+Oj4AFdom8YNJjibIARTJmapQ==",
1321 | "dev": true
1322 | },
1323 | "node_modules/to-regex-range": {
1324 | "version": "5.0.1",
1325 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
1326 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
1327 | "dev": true,
1328 | "dependencies": {
1329 | "is-number": "^7.0.0"
1330 | },
1331 | "engines": {
1332 | "node": ">=8.0"
1333 | }
1334 | },
1335 | "node_modules/universalify": {
1336 | "version": "2.0.0",
1337 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.0.tgz",
1338 | "integrity": "sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ==",
1339 | "dev": true,
1340 | "engines": {
1341 | "node": ">= 10.0.0"
1342 | }
1343 | },
1344 | "node_modules/update-browserslist-db": {
1345 | "version": "1.0.11",
1346 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz",
1347 | "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==",
1348 | "dev": true,
1349 | "funding": [
1350 | {
1351 | "type": "opencollective",
1352 | "url": "https://opencollective.com/browserslist"
1353 | },
1354 | {
1355 | "type": "tidelift",
1356 | "url": "https://tidelift.com/funding/github/npm/browserslist"
1357 | },
1358 | {
1359 | "type": "github",
1360 | "url": "https://github.com/sponsors/ai"
1361 | }
1362 | ],
1363 | "dependencies": {
1364 | "escalade": "^3.1.1",
1365 | "picocolors": "^1.0.0"
1366 | },
1367 | "bin": {
1368 | "update-browserslist-db": "cli.js"
1369 | },
1370 | "peerDependencies": {
1371 | "browserslist": ">= 4.21.0"
1372 | }
1373 | },
1374 | "node_modules/vite": {
1375 | "version": "4.4.9",
1376 | "resolved": "https://registry.npmjs.org/vite/-/vite-4.4.9.tgz",
1377 | "integrity": "sha512-2mbUn2LlUmNASWwSCNSJ/EG2HuSRTnVNaydp6vMCm5VIqJsjMfbIWtbH2kDuwUVW5mMUKKZvGPX/rqeqVvv1XA==",
1378 | "dev": true,
1379 | "dependencies": {
1380 | "esbuild": "^0.18.10",
1381 | "postcss": "^8.4.27",
1382 | "rollup": "^3.27.1"
1383 | },
1384 | "bin": {
1385 | "vite": "bin/vite.js"
1386 | },
1387 | "engines": {
1388 | "node": "^14.18.0 || >=16.0.0"
1389 | },
1390 | "funding": {
1391 | "url": "https://github.com/vitejs/vite?sponsor=1"
1392 | },
1393 | "optionalDependencies": {
1394 | "fsevents": "~2.3.2"
1395 | },
1396 | "peerDependencies": {
1397 | "@types/node": ">= 14",
1398 | "less": "*",
1399 | "lightningcss": "^1.21.0",
1400 | "sass": "*",
1401 | "stylus": "*",
1402 | "sugarss": "*",
1403 | "terser": "^5.4.0"
1404 | },
1405 | "peerDependenciesMeta": {
1406 | "@types/node": {
1407 | "optional": true
1408 | },
1409 | "less": {
1410 | "optional": true
1411 | },
1412 | "lightningcss": {
1413 | "optional": true
1414 | },
1415 | "sass": {
1416 | "optional": true
1417 | },
1418 | "stylus": {
1419 | "optional": true
1420 | },
1421 | "sugarss": {
1422 | "optional": true
1423 | },
1424 | "terser": {
1425 | "optional": true
1426 | }
1427 | }
1428 | },
1429 | "node_modules/vite-plugin-banner": {
1430 | "version": "0.7.0",
1431 | "resolved": "https://registry.npmjs.org/vite-plugin-banner/-/vite-plugin-banner-0.7.0.tgz",
1432 | "integrity": "sha512-g0cm0wbrR6b6wR8FWtfD1RSDPacdumKEOAnneXv+NpJ9ez+j6rklRv6lMOO+aPf+Y6Zb8OzgIk0FXBZ6h+DeZQ==",
1433 | "dev": true
1434 | },
1435 | "node_modules/vite/node_modules/fsevents": {
1436 | "version": "2.3.2",
1437 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
1438 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
1439 | "dev": true,
1440 | "hasInstallScript": true,
1441 | "optional": true,
1442 | "os": [
1443 | "darwin"
1444 | ],
1445 | "engines": {
1446 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
1447 | }
1448 | },
1449 | "node_modules/wrap-ansi": {
1450 | "version": "7.0.0",
1451 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
1452 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
1453 | "dev": true,
1454 | "dependencies": {
1455 | "ansi-styles": "^4.0.0",
1456 | "string-width": "^4.1.0",
1457 | "strip-ansi": "^6.0.0"
1458 | },
1459 | "engines": {
1460 | "node": ">=10"
1461 | },
1462 | "funding": {
1463 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
1464 | }
1465 | },
1466 | "node_modules/y18n": {
1467 | "version": "5.0.8",
1468 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz",
1469 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==",
1470 | "dev": true,
1471 | "engines": {
1472 | "node": ">=10"
1473 | }
1474 | },
1475 | "node_modules/yaml": {
1476 | "version": "2.3.2",
1477 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.2.tgz",
1478 | "integrity": "sha512-N/lyzTPaJasoDmfV7YTrYCI0G/3ivm/9wdG0aHuheKowWQwGTsK0Eoiw6utmzAnI6pkJa0DUVygvp3spqqEKXg==",
1479 | "dev": true,
1480 | "engines": {
1481 | "node": ">= 14"
1482 | }
1483 | },
1484 | "node_modules/yargs": {
1485 | "version": "17.3.1",
1486 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.3.1.tgz",
1487 | "integrity": "sha512-WUANQeVgjLbNsEmGk20f+nlHgOqzRFpiGWVaBrYGYIGANIIu3lWjoyi0fNlFmJkvfhCZ6BXINe7/W2O2bV4iaA==",
1488 | "dev": true,
1489 | "dependencies": {
1490 | "cliui": "^7.0.2",
1491 | "escalade": "^3.1.1",
1492 | "get-caller-file": "^2.0.5",
1493 | "require-directory": "^2.1.1",
1494 | "string-width": "^4.2.3",
1495 | "y18n": "^5.0.5",
1496 | "yargs-parser": "^21.0.0"
1497 | },
1498 | "engines": {
1499 | "node": ">=12"
1500 | }
1501 | },
1502 | "node_modules/yargs-parser": {
1503 | "version": "21.0.0",
1504 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.0.0.tgz",
1505 | "integrity": "sha512-z9kApYUOCwoeZ78rfRYYWdiU/iNL6mwwYlkkZfJoyMR1xps+NEBX5X7XmRpxkZHhXJ6+Ey00IwKxBBSW9FIjyA==",
1506 | "dev": true,
1507 | "engines": {
1508 | "node": ">=12"
1509 | }
1510 | }
1511 | }
1512 | }
1513 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@ritterim/skellycss",
3 | "version": "0.1.6",
4 | "description": "A light-weight CSS framework to quickly implement skeletons into your projects.",
5 | "main": "dist/skelly.js",
6 | "files": [
7 | "dist/"
8 | ],
9 | "scripts": {
10 | "start": "vite",
11 | "build": "vite build",
12 | "preview": "vite preview"
13 | },
14 | "repository": {
15 | "type": "git",
16 | "url": "git+https://github.com/ritterim/skellyCSS.git"
17 | },
18 | "keywords": [
19 | "skeleton screens",
20 | "skeletons",
21 | "loading skeleton"
22 | ],
23 | "author": "Ritter Insurance Marketing (https://rimdev.io)",
24 | "license": "MIT",
25 | "bugs": {
26 | "url": "https://github.com/ritterim/skellyCSS/issues"
27 | },
28 | "browserslist": [
29 | "defaults",
30 | "not IE 11",
31 | "maintained node versions"
32 | ],
33 | "homepage": "https://github.com/ritterim/skellyCSS#readme",
34 | "devDependencies": {
35 | "autoprefixer": "^10.4.15",
36 | "postcss": "^8.4.29",
37 | "postcss-cli": "^10.1.0",
38 | "sass": "^1.66.1",
39 | "vite": "^4.4.9",
40 | "vite-plugin-banner": "^0.7.0"
41 | }
42 | }
43 |
--------------------------------------------------------------------------------
/package/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2020 Ritter Insurance Marketing
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/package/README.md:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | # skellyCSS
6 | A light-weight CSS framework to quickly implement skeletons into your projects.
7 |
8 |
9 | Table of Contents
10 |
11 | - [skellyCSS](#skellycss)
12 | - [Installation](#installation)
13 | - [CSS](#css)
14 | - [JavaScript](#javascript)
15 | - [Quick Usage](#quick-usage)
16 | - [Usage](#usage)
17 | - [Headers](#headers)
18 | - [Paragraphs](#paragraphs)
19 | - [Line Width](#line-width)
20 | - [Alignment](#alignment)
21 | - [Images](#images)
22 | - [Sizes](#sizes)
23 | - [Shapes](#shapes)
24 | - [Animation](#animation)
25 | - [JavaScript Utility](#javascript-utility)
26 |
27 |
28 |
29 | ## Installation
30 | ### CSS
31 | Include the skelly.css file wherever you add your CSS:
32 | ``` html
33 |
34 | ```
35 |
36 | ### JavaScript
37 | Include the skelly.js file wherever you add your JavaScript:
38 | ``` html
39 |
40 | ```
41 |
42 |
43 |
44 | ## Quick Usage
45 | You can quickly get started using skellyCSS using the JavaScript utility, like so:
46 | ``` html
47 |
48 |
49 | ```
50 | **See full [JavaScript Utility](#javascript-utility) docs below**
51 |
52 |
53 |
54 | ## Usage
55 | Skeletons can be quickly added to any project with a few simple lines of code.
56 |
57 | ### Headers
58 | Apply the `skeleton` class to any type of header and it will automatically adjust to the font-size of the header stylings:
59 |
60 | 
61 |
62 | ``` html
63 |
64 |
65 |
66 |
67 |
68 |
69 | ```
70 |
71 |
72 |
73 | ### Paragraphs
74 | You can create paragraph skeletons by applying the `skeleton` class to the paragraph tag, then including however many span tags you'd like with the `skeleton__line` class within the paragraph. In order to make the paragraph skeleton look more like a paragraph, the last line is set to 50% width.
75 |
76 | 
77 | ```html
78 |
79 |
80 |
81 |
82 |
83 |
84 |
85 |
86 | ```
87 |
88 |
89 |
90 | ### Line Width
91 | You can adjust the line width by applying a size modifier class:
92 | | Width | Modifier Class |
93 | | ------------ | ------------|
94 | | Small, 25% | `.skeleton--sm` |
95 | | Medium, 50% | `.skeleton--md` |
96 | | Large, 75% | `.skeleton--lg` |
97 | | Full, 100% | `.skeleton--full` |
98 |
99 | 
100 |
101 | ``` html
102 |
103 |
104 |
105 |
106 | ```
107 |
108 |
109 |
110 | ### Alignment
111 | You can text align the skeleton using alignment modifier classes:
112 |
113 | | Alignment | Modifier Class |
114 | | ------------ | ------------|
115 | | Left | `.skeleton--left` |
116 | | Center | `.skeleton--center` |
117 | | Right | `.skeleton--right` |
118 |
119 | 
120 |
121 | ``` html
122 |
123 |
124 |
125 |
126 |
127 |
128 |
129 |
130 |
131 |
132 |
133 |
134 |
135 |
136 |
137 |
138 |
139 |
140 |
141 |
142 |
143 |
144 |
145 | ```
146 |
147 |
148 |
149 | ### Images
150 | You can create an image skeleton by adding the `.skeleton-image` class to an img tag -- do not include the `src` attribute. By default this will apply the image skeleton at 100% height and width of the parent container.
151 |
152 | #### Sizes
153 | Here are some default sizes we have included for skeleton images:
154 |
155 | | Size | Modifier Class |
156 | | ------------ | ------------|
157 | | Small, 50x50 | `.skeleton-image--sm` |
158 | | Medium, 100x100 | `.skeleton-image--md` |
159 | | Large, 200x200 | `.skeleton-image--lg` |
160 | | X-Large, 400x400 | `.skeleton-image--xl` |
161 | | Full, 100% x 100% | `.skeleton-image--full` |
162 |
163 | 
164 |
165 | ``` html
166 |
167 |
168 |
169 |
170 | ```
171 |
172 |
173 |
174 | #### Shapes
175 | You can also make different image shapes using shape modifier classes:
176 |
177 | | Shape | Description | Modifier Class |
178 | | ------------ |------------ | ------------|
179 | | Landscape Rectangle | Sets the width of the image to 100% | `.skeleton-image--landscape` |
180 | | Portrait Rectangle | Sets the height of the image to 100% | `.skeleton-image--portrait` |
181 | | Circle | Sets the border radius to 50% | `.skeleton-image--circle` |
182 |
183 | 
184 |
185 | ``` html
186 |
187 |
188 |
189 | ```
190 |
191 |
192 |
193 | ### Animation
194 | To add animation, add a `span.skeleton--animation` within the `.skeleton__line` elements in headers or paragaphs.
195 |
196 | 
197 |
198 | ``` html
199 |
200 |
201 |
202 |
203 |
204 |
205 |
206 |
207 |
208 |
209 |
210 |
211 |
212 |
213 |
214 |
215 | ```
216 |
217 |
218 |
219 | ## JavaScript Utility
220 | The easiest and our preferred way to add Skeletons is by using the included JavaScript utilities.
221 |
222 | On either a header tag or a paragraph tag, add the `skeleton` class and a `data-lines` attribute with the number of lines you'd like the skeleton to have:
223 |
224 | ``` html
225 |
226 |
227 | ```
228 |
229 |
230 |
231 | You can also give the skeleton animation by adding the `data-animation` attribute and setting it to `true`:
232 |
233 | ``` html
234 |
235 |
236 | ```
--------------------------------------------------------------------------------
/package/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@ritterim/skellycss",
3 | "version": "0.0.1",
4 | "description": "A light-weight CSS framework to quickly implement skeletons into your projects.",
5 | "main": "dist/skelly.js",
6 | "files":[
7 | "dist/"
8 | ],
9 | "scripts": {
10 | "test": "echo \"Error: no test specified\" && exit 1",
11 | "dev": "parcel src/skelly.js",
12 | "build": "parcel build src/skelly.js"
13 | },
14 | "repository": {
15 | "type": "git",
16 | "url": "git+https://github.com/ritterim/skellyCSS.git"
17 | },
18 | "keywords": ["skeleton screens", "skeletons", "loading skeleton"],
19 | "author": "Ritter Insurance Marketing (https://rimdev.io)",
20 | "license": "MIT",
21 | "bugs": {
22 | "url": "https://github.com/ritterim/skellyCSS/issues"
23 | },
24 | "homepage": "https://github.com/ritterim/skellyCSS#readme",
25 | "devDependencies": {
26 | "cssnano": "^4.1.10",
27 | "sass": "^1.30.0"
28 | },
29 | "dependencies": {
30 | "assets": "^3.0.1"
31 | }
32 | }
33 |
--------------------------------------------------------------------------------
/postcss.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | plugins: [require('autoprefixer')]
3 | };
4 |
--------------------------------------------------------------------------------
/src/index.js:
--------------------------------------------------------------------------------
1 | const skeletons = document.querySelectorAll('.skeleton');
2 |
3 | if (skeletons) {
4 | skeletons.forEach((skelly) => {
5 | let lineCount = parseInt(skelly.dataset.lines);
6 | let opacity = skelly.dataset.opacity
7 | ? parseFloat(skelly.dataset.opacity)
8 | : null;
9 |
10 | let color = skelly.dataset.color ? skelly.dataset.color : null;
11 |
12 | if (!lineCount && skelly.innerHTML.trim().length == 0) {
13 | lineCount = 1;
14 | }
15 |
16 | for (let i = 0; i < lineCount; i++) {
17 | const line = document.createElement('span');
18 | line.classList.add('skeleton__line');
19 |
20 | if (skelly.dataset.animation === 'true') {
21 | const animationElement = document.createElement('span');
22 | animationElement.classList.add('skeleton--animation');
23 | line.append(animationElement);
24 | }
25 |
26 | skelly.append(line);
27 | }
28 |
29 | if (opacity && opacity <= 1) {
30 | const lines = skelly.querySelectorAll('.skeleton__line');
31 | lines.forEach((line) => (line.style.opacity = opacity));
32 | }
33 |
34 | if (color) {
35 | const lines = skelly.querySelectorAll('.skeleton__line');
36 | lines.forEach(line => line.style.setProperty('--skelly-color', color));
37 |
38 | }
39 | });
40 | }
41 |
42 | const skeletonImages = document.querySelectorAll('.skeleton-image');
43 |
44 | if (skeletonImages) {
45 | skeletonImages.forEach((skelly) => {
46 | let animation = skelly.dataset.animation === 'true';
47 | let opacity = skelly.dataset.opacity
48 | ? parseFloat(skelly.dataset.opacity)
49 | : null;
50 |
51 | if (animation === true) {
52 | const animationElement = document.createElement('span');
53 | animationElement.classList.add('skeleton--animation');
54 | skelly.append(animationElement);
55 | }
56 |
57 | if (opacity && opacity <= 1) skelly.style.opacity = opacity;
58 | });
59 | }
60 |
--------------------------------------------------------------------------------
/src/style.scss:
--------------------------------------------------------------------------------
1 | $skelly-color: #EFEFEF;
2 |
3 | :root{
4 | --skelly-color: #EFEFEF;
5 | } ;
6 |
7 | $skelly-line-widths: (
8 | "sm": 25%,
9 | "md": 50%,
10 | "lg": 75%,
11 | "full": 100%,
12 | );
13 |
14 | $skelly-image-sizes: (
15 | "sm": 50px,
16 | "md": 100px,
17 | "lg": 200px,
18 | "xl": 400px,
19 | "full": 100%,
20 | );
21 |
22 | .skeleton {
23 | position: relative;
24 | box-sizing: border-box;
25 | display: flex;
26 | flex-flow: column;
27 | width: 100%;
28 |
29 | &__line {
30 | overflow: hidden;
31 | position: relative;
32 | box-sizing: border-box;
33 | display: block;
34 | height: 1em;
35 | width: 100%;
36 | background: var(--skelly-color);
37 | border-radius: 3px;
38 | }
39 |
40 | &__line + &__line:last-child {
41 | width: 50%;
42 | }
43 |
44 | @each $width-label, $width in $skelly-line-widths {
45 | &--#{$width-label} {
46 | width: $width;
47 | }
48 | }
49 |
50 | &--left {
51 | display: flex;
52 | flex-flow: column;
53 | align-items: flex-start;
54 | }
55 |
56 | &--center {
57 | display: flex;
58 | flex-flow: column;
59 | align-items: center;
60 | }
61 |
62 | &--right {
63 | display: flex;
64 | flex-flow: column;
65 | align-items: flex-end;
66 | }
67 |
68 | &--animation {
69 | position: abosolute;
70 | display: flex;
71 | height: 100%;
72 | background: rgb(255, 255, 255);
73 | background: linear-gradient(
74 | 90deg,
75 | rgba(255, 255, 255, 0) 0%,
76 | rgba(255, 255, 255, 0) 10%,
77 | rgba(255, 255, 255, 0.5) 50%,
78 | rgba(255, 255, 255, 0) 90%,
79 | rgba(255, 255, 255, 0) 100%
80 | );
81 |
82 | animation: shine 3s infinite cubic-bezier(0.55, 0.055, 0.675, 0.19);
83 | }
84 |
85 | &:last-child {
86 | margin-bottom: 0;
87 | }
88 | }
89 |
90 | p {
91 | .skeleton__line {
92 | margin-bottom: 0.6em;
93 | }
94 | }
95 |
96 | .skeleton-image {
97 | overflow: hidden;
98 | display: block;
99 | background-color: var(--skelly-color);
100 | background-image: url("");
101 | background-blend-mode: overlay;
102 | background-repeat: no-repeat;
103 | background-position: center;
104 | background-size: 15px;
105 | aspect-ratio: 1;
106 |
107 | @each $size-label, $size in $skelly-image-sizes {
108 | &--#{$size-label} {
109 | height: $size;
110 | width: $size;
111 | }
112 | }
113 |
114 | &--square{
115 | aspect-ratio: 1;
116 | }
117 |
118 | &--landscape {
119 | aspect-ratio: 4/3;
120 | height:auto;
121 | }
122 |
123 | &--portrait {
124 | aspect-ratio: 3/4;
125 | width:auto;
126 | }
127 |
128 | &--wide {
129 | aspect-ratio: 16/9;
130 | height:auto;
131 | }
132 |
133 | &--tall {
134 | aspect-ratio: 9/16;
135 | width:auto;
136 | }
137 |
138 | &--circle {
139 | border-radius: 50%;
140 | }
141 | }
142 |
143 | .skeleton:is(h1, h2, h3, h4, h5, h6) {
144 | margin: 0;
145 | padding: 0;
146 | .skeleton__line {
147 | margin-bottom: 0.2em;
148 | background: var(--skelly-color);
149 | }
150 | &.skeleton--center{
151 | margin:0 auto;
152 | }
153 | &.skeleton--left{
154 | margin:0 auto 0 0;
155 | }
156 | &.skeleton--right{
157 | margin:0 0 0 auto;
158 | }
159 | }
160 |
161 | @keyframes shine {
162 | 0% {
163 | transform: translateX(-100%);
164 | }
165 |
166 | 30% {
167 | transform: translateX(100%);
168 | }
169 |
170 | 100% {
171 | transform: translateX(100%);
172 | }
173 | }
174 |
--------------------------------------------------------------------------------
/vite.config.js:
--------------------------------------------------------------------------------
1 | // vite.config.js
2 | const { defineConfig } = require('vite');
3 | const path = require('path');
4 | import banner from 'vite-plugin-banner';
5 | // import copy from 'rollup-plugin-copy';
6 | const pjson = require('./package.json');
7 | const year = new Date().getFullYear();
8 |
9 | const puiHeader = [
10 | '/*',
11 | ' SkellyCSS v' + pjson.version + ' | ' + pjson.name + '\n',
12 | ' ' + pjson.description + ' (' + pjson.homepage + ')',
13 | ' ©' + year + ' ' + pjson.author,
14 | ' ' + pjson.bugs.url,
15 | ' Released under the ' + pjson.license + ' license.',
16 | '*/',
17 | '',
18 | ].join('\n');
19 |
20 | export default defineConfig({
21 | plugins: [
22 | banner(puiHeader)
23 | ],
24 | build: {
25 | lib: {
26 | entry: path.resolve(__dirname, 'main.js'),
27 | name: 'SkellyCSS',
28 | fileName: () => `skelly.js`,
29 | },
30 | },
31 | });
32 |
--------------------------------------------------------------------------------