svelte-sitemap 3.2.0-next.1 → 3.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -9,7 +9,7 @@
9
9
  ---
10
10
 
11
11
  - ➡️ Designed for SvelteKit `adapter-static` with `prerender` option (SSG)
12
- - 🔷 TypeScript, JavaScript, CLI and **Vite plugin** version
12
+ - 🔷 TypeScript, JavaScript, CLI version
13
13
  - 🔧 Useful [options](#%EF%B8%8F-options) for customizing your sitemap
14
14
  - 📡 [Ping](#-ping-google-search-console) Google Search Console after deploy
15
15
  - 🗂️ Support for [sitemap index](https://developers.google.com/search/docs/crawling-indexing/sitemaps/large-sitemaps) for large sites (50K+ pages)
@@ -26,7 +26,7 @@ npm install svelte-sitemap --save-dev
26
26
 
27
27
  ## 🚀 Usage
28
28
 
29
- > There are four ways to use this library. Pick the one that suits you best.
29
+ > There are three ways to use this library. Pick the one that suits you best.
30
30
 
31
31
  ### ✨ Method 1: Config file (recommended)
32
32
 
@@ -94,30 +94,6 @@ node my-script.js
94
94
 
95
95
  ---
96
96
 
97
- ### ⚡ Method 4: Vite plugin
98
-
99
- If you're using SvelteKit with Vite (which is the default), you can integrate the sitemap generation directly into the Vite build pipeline — no extra `postbuild` script needed.
100
-
101
- Add the plugin to your `vite.config.ts`:
102
-
103
- ```typescript
104
- // vite.config.ts
105
- import { sveltekit } from '@sveltejs/kit/vite';
106
- import { svelteSitemap } from 'svelte-sitemap/vite'; // <-- Add svelte-sitemap vite plugin
107
- import { defineConfig } from 'vite';
108
-
109
- export default defineConfig({
110
- plugins: [
111
- sveltekit(),
112
- svelteSitemap({ domain: 'https://example.com' }) // <-- Configure the plugin with your options
113
- ]
114
- });
115
- ```
116
-
117
- The sitemap is generated automatically at the end of every `vite build`. All [options](#%EF%B8%8F-options) are supported.
118
-
119
- ---
120
-
121
97
  ## ⚙️ Options
122
98
 
123
99
  Options are defined as **config file keys** (camelCase). Use it in your `svelte-sitemap.config.ts` file.
package/cli.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"cli.js","names":["pkg.version"],"sources":["../src/cli.ts"],"sourcesContent":["#!/usr/bin/env node\nimport minimist from 'minimist';\nimport pkg from './../package.json' with { type: 'json' };\nimport { APP_NAME, CONFIG_FILES, REPO_URL } from './const.js';\nimport type { ChangeFreq, OptionsSvelteSitemap } from './dto/index.js';\nimport { defaultConfig, loadConfig, withDefaultConfig } from './helpers/config.js';\nimport { cliColors, errorMsgGeneration } from './helpers/vars.helper.js';\nimport { createSitemap } from './index.js';\nconst version = pkg.version;\n\nconst main = async () => {\n console.log(cliColors.cyanAndBold, `> Using ${APP_NAME}`);\n\n let stop = false;\n\n const config = await loadConfig(CONFIG_FILES);\n\n const args = minimist(process.argv.slice(2), {\n string: ['domain', 'out-dir', 'ignore', 'change-freq', 'additional'],\n boolean: ['attribution', 'reset-time', 'trailing-slashes', 'debug', 'version'],\n default: { attribution: true, 'trailing-slashes': false, default: false },\n alias: {\n d: 'domain',\n D: 'domain',\n h: 'help',\n H: 'help',\n v: 'version',\n V: 'version',\n O: 'out-dir',\n o: 'out-dir',\n r: 'reset-time',\n R: 'reset-time',\n c: 'change-freq',\n C: 'change-freq',\n i: 'ignore',\n I: 'ignore',\n t: 'trailing-slashes',\n T: 'trailing-slashes',\n a: 'additional',\n A: 'additional'\n },\n unknown: (err: string) => {\n if (config && Object.keys(config).length > 0) return false;\n console.log(cliColors.yellow, ' ⚠ This argument is not supported:', err);\n // console.log(cliColors.yellow, ' Use: `svelte-sitemap --help` for more options.');\n stop = true;\n return false;\n }\n });\n\n if (args.help || args.version === '' || args.version === true) {\n const log = args.help ? console.log : console.error;\n log('Svelte `sitemap.xml` generator');\n log('');\n log(`svelte-sitemap ${version} (check updates: ${REPO_URL})`);\n log('');\n log('Options:');\n log('');\n log(' -d, --domain Use your domain (eg. https://example.com)');\n log(' -o, --out-dir Custom output dir');\n log(' -i, --ignore Exclude some pages or folders');\n log(' -a, --additional Additional pages outside of SvelteKit (e.g. /, /contact)');\n log(' -t, --trailing-slashes Do you like trailing slashes?');\n log(' -r, --reset-time Set modified time to now');\n log(' -c, --change-freq Set change frequency `weekly` | `daily` | …');\n log(' -v, --version Show version');\n log(' --debug Debug mode');\n log(' ');\n process.exit(args.help ? 0 : 1);\n } else if (config && Object.keys(config).length > 0) {\n // --- CONFIG FILE PATH ---\n const hasCliOptions = process.argv.slice(2).length > 0;\n console.log(cliColors.green, ` ✔ Reading config file...`);\n\n const allowedKeys = Object.keys(defaultConfig);\n const invalidKeys = Object.keys(config).filter((key) => !allowedKeys.includes(key));\n if (invalidKeys.length > 0) {\n console.log(\n cliColors.yellow,\n ` ⚠ Invalid properties in config file, so I ignore them: ${invalidKeys.join(', ')}`\n );\n }\n\n if (hasCliOptions) {\n console.log(\n cliColors.yellow,\n ` ⚠ You have also set CLI options (arguments with '--'), but they are ignored because your config file 'svelte-sitemap.config.ts' is used.`\n );\n }\n\n if (!config.domain) {\n console.log(\n cliColors.yellow,\n ` ⚠ svelte-sitemap: 'domain' property is required in your config file. See instructions: ${REPO_URL}\\n`\n );\n console.error(cliColors.red, errorMsgGeneration);\n process.exit(0);\n }\n\n if (!config.domain.startsWith('https://')) {\n console.log(\n cliColors.yellow,\n ` ⚠ svelte-sitemap: 'domain' property in your config file must start with https:// See instructions: ${REPO_URL}\\n`\n );\n console.error(cliColors.red, errorMsgGeneration);\n process.exit(0);\n }\n\n try {\n await createSitemap(withDefaultConfig(config));\n } catch (err) {\n console.error(cliColors.red, errorMsgGeneration, err);\n process.exit(0);\n }\n } else {\n // --- CLI ARGUMENTS PATH ---\n if (stop) {\n console.error(cliColors.red, errorMsgGeneration);\n process.exit(0);\n }\n\n if (!args.domain) {\n console.log(\n cliColors.red,\n ` ⚠ svelte-sitemap: --domain argument is required. See instructions: ${REPO_URL}\\n Example:\\n svelte-sitemap --domain https://mydomain.com\\n`\n );\n console.error(cliColors.red, errorMsgGeneration);\n process.exit(0);\n }\n\n if (!args.domain.startsWith('https://')) {\n console.log(\n cliColors.red,\n ` ⚠ svelte-sitemap: --domain argument must start with https:// See instructions: ${REPO_URL}\\n Example:\\n\\n svelte-sitemap --domain https://mydomain.com\\n`\n );\n console.error(cliColors.red, errorMsgGeneration);\n process.exit(0);\n }\n\n const domain: string = args.domain;\n const debug: boolean = args.debug === '' || args.debug === true ? true : false;\n const additional = Array.isArray(args['additional'])\n ? args['additional']\n : args.additional\n ? [args.additional]\n : [];\n const resetTime: boolean =\n args['reset-time'] === '' || args['reset-time'] === true ? true : false;\n const trailingSlashes: boolean =\n args['trailing-slashes'] === '' || args['trailing-slashes'] === true ? true : false;\n const changeFreq: ChangeFreq = args['change-freq'];\n const outDir: string = args['out-dir'];\n const ignore: string = args['ignore'];\n const attribution: boolean =\n args['attribution'] === '' || args['attribution'] === false ? false : true;\n\n const optionsCli: OptionsSvelteSitemap = {\n debug,\n resetTime,\n changeFreq,\n outDir,\n domain,\n attribution,\n ignore,\n trailingSlashes,\n additional\n };\n\n console.log(\n cliColors.yellow,\n ` ℹ Hint: Configuration file is now the preferred method to set up svelte-sitemap. See ${REPO_URL}?tab=readme-ov-file#-usage`\n );\n console.log(cliColors.cyanAndBold, ` ✔ Using CLI options. Config file not found.`);\n try {\n await createSitemap(optionsCli);\n } catch (err) {\n console.error(cliColors.red, errorMsgGeneration, err);\n process.exit(0);\n }\n }\n};\n\nmain();\n"],"mappings":"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"}
1
+ {"version":3,"file":"cli.js","names":["pkg.version"],"sources":["../src/cli.ts"],"sourcesContent":["#!/usr/bin/env node\nimport minimist from 'minimist';\nimport pkg from './../package.json' with { type: 'json' };\nimport { APP_NAME, CONFIG_FILES, REPO_URL } from './const.js';\nimport type { ChangeFreq, OptionsSvelteSitemap } from './dto/index.js';\nimport { defaultConfig, loadConfig, withDefaultConfig } from './helpers/config.js';\nimport { cliColors, errorMsgGeneration } from './helpers/vars.helper.js';\nimport { createSitemap } from './index.js';\nconst version = pkg.version;\n\nconst main = async () => {\n console.log(cliColors.cyanAndBold, `> Using ${APP_NAME}`);\n\n let stop = false;\n\n const config = await loadConfig(CONFIG_FILES);\n\n const args = minimist(process.argv.slice(2), {\n string: ['domain', 'out-dir', 'ignore', 'change-freq', 'additional'],\n boolean: ['attribution', 'reset-time', 'trailing-slashes', 'debug', 'version'],\n default: { attribution: true, 'trailing-slashes': false, default: false },\n alias: {\n d: 'domain',\n D: 'domain',\n h: 'help',\n H: 'help',\n v: 'version',\n V: 'version',\n O: 'out-dir',\n o: 'out-dir',\n r: 'reset-time',\n R: 'reset-time',\n c: 'change-freq',\n C: 'change-freq',\n i: 'ignore',\n I: 'ignore',\n t: 'trailing-slashes',\n T: 'trailing-slashes',\n a: 'additional',\n A: 'additional'\n },\n unknown: (err: string) => {\n if (config && Object.keys(config).length > 0) return false;\n console.log(cliColors.yellow, ' ⚠ This argument is not supported:', err);\n // console.log(cliColors.yellow, ' Use: `svelte-sitemap --help` for more options.');\n stop = true;\n return false;\n }\n });\n\n if (args.help || args.version === '' || args.version === true) {\n const log = args.help ? console.log : console.error;\n log('Svelte `sitemap.xml` generator');\n log('');\n log(`svelte-sitemap ${version} (check updates: ${REPO_URL})`);\n log('');\n log('Options:');\n log('');\n log(' -d, --domain Use your domain (eg. https://example.com)');\n log(' -o, --out-dir Custom output dir');\n log(' -i, --ignore Exclude some pages or folders');\n log(' -a, --additional Additional pages outside of SvelteKit (e.g. /, /contact)');\n log(' -t, --trailing-slashes Do you like trailing slashes?');\n log(' -r, --reset-time Set modified time to now');\n log(' -c, --change-freq Set change frequency `weekly` | `daily` | …');\n log(' -v, --version Show version');\n log(' --debug Debug mode');\n log(' ');\n process.exit(args.help ? 0 : 1);\n } else if (config && Object.keys(config).length > 0) {\n // --- CONFIG FILE PATH ---\n const hasCliOptions = process.argv.slice(2).length > 0;\n console.log(cliColors.green, ` ✔ Reading config file...`);\n\n const allowedKeys = Object.keys(defaultConfig);\n const invalidKeys = Object.keys(config).filter((key) => !allowedKeys.includes(key));\n if (invalidKeys.length > 0) {\n console.log(\n cliColors.yellow,\n ` ⚠ Invalid properties in config file, so I ignore them: ${invalidKeys.join(', ')}`\n );\n }\n\n if (hasCliOptions) {\n console.log(\n cliColors.yellow,\n ` ⚠ You have also set CLI options (arguments with '--'), but they are ignored because your config file 'svelte-sitemap.config.ts' is used.`\n );\n }\n\n if (!config.domain) {\n console.log(\n cliColors.yellow,\n ` ⚠ svelte-sitemap: 'domain' property is required in your config file. See instructions: ${REPO_URL}\\n`\n );\n console.error(cliColors.red, errorMsgGeneration);\n process.exit(0);\n }\n\n if (!config.domain.startsWith('https://')) {\n console.log(\n cliColors.yellow,\n ` ⚠ svelte-sitemap: 'domain' property in your config file must start with https:// See instructions: ${REPO_URL}\\n`\n );\n console.error(cliColors.red, errorMsgGeneration);\n process.exit(0);\n }\n\n try {\n await createSitemap(withDefaultConfig(config));\n } catch (err) {\n console.error(cliColors.red, errorMsgGeneration, err);\n process.exit(0);\n }\n } else {\n // --- CLI ARGUMENTS PATH ---\n if (stop) {\n console.error(cliColors.red, errorMsgGeneration);\n process.exit(0);\n }\n\n if (!args.domain) {\n console.log(\n cliColors.red,\n ` ⚠ svelte-sitemap: --domain argument is required. See instructions: ${REPO_URL}\\n Example:\\n svelte-sitemap --domain https://mydomain.com\\n`\n );\n console.error(cliColors.red, errorMsgGeneration);\n process.exit(0);\n }\n\n if (!args.domain.startsWith('https://')) {\n console.log(\n cliColors.red,\n ` ⚠ svelte-sitemap: --domain argument must start with https:// See instructions: ${REPO_URL}\\n Example:\\n\\n svelte-sitemap --domain https://mydomain.com\\n`\n );\n console.error(cliColors.red, errorMsgGeneration);\n process.exit(0);\n }\n\n const domain: string = args.domain;\n const debug: boolean = args.debug === '' || args.debug === true ? true : false;\n const additional = Array.isArray(args['additional'])\n ? args['additional']\n : args.additional\n ? [args.additional]\n : [];\n const resetTime: boolean =\n args['reset-time'] === '' || args['reset-time'] === true ? true : false;\n const trailingSlashes: boolean =\n args['trailing-slashes'] === '' || args['trailing-slashes'] === true ? true : false;\n const changeFreq: ChangeFreq = args['change-freq'];\n const outDir: string = args['out-dir'];\n const ignore: string = args['ignore'];\n const attribution: boolean =\n args['attribution'] === '' || args['attribution'] === false ? false : true;\n\n const optionsCli: OptionsSvelteSitemap = {\n debug,\n resetTime,\n changeFreq,\n outDir,\n domain,\n attribution,\n ignore,\n trailingSlashes,\n additional\n };\n\n console.log(\n cliColors.yellow,\n ` ℹ Hint: Configuration file is now the preferred method to set up svelte-sitemap. See ${REPO_URL}?tab=readme-ov-file#-usage`\n );\n console.log(cliColors.cyanAndBold, ` ✔ Using CLI options. Config file not found.`);\n try {\n await createSitemap(optionsCli);\n } catch (err) {\n console.error(cliColors.red, errorMsgGeneration, err);\n process.exit(0);\n }\n }\n};\n\nmain();\n"],"mappings":"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"}
package/const.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"const.js","names":[],"sources":["../src/const.ts"],"sourcesContent":["export const APP_NAME = 'svelte-sitemap';\n\nexport const REPO_URL = 'https://github.com/bartholomej/svelte-sitemap';\n\nexport const DOMAIN = 'https://example.com';\n\nexport const OUT_DIR = 'build';\n\n// Google recommends to split sitemap into multiple files if there are more than 50k pages\n// https://support.google.com/webmasters/answer/183668?hl=en\nexport const CHUNK = {\n maxSize: 50_000\n};\n\nexport const CONFIG_FILES = [\n 'svelte-sitemap.config.js',\n 'svelte-sitemap.config.mjs',\n 'svelte-sitemap.config.cjs',\n 'svelte-sitemap.config.ts',\n 'svelte-sitemap.config.mts',\n 'svelte-sitemap.config.cts',\n 'svelte-sitemap.config.json'\n];\n\nexport const CHANGE_FREQ = [\n 'always',\n 'hourly',\n 'daily',\n 'weekly',\n 'monthly',\n 'yearly',\n 'never'\n] as const;\n"],"mappings":";AAAA,MAAa,WAAW;AAExB,MAAa,WAAW;AAIxB,MAAa,UAAU;AAIvB,MAAa,QAAQ,EACnB,SAAS,KACV;AAED,MAAa,eAAe;CAC1B;CACA;CACA;CACA;CACA;CACA;CACA;CACD;AAED,MAAa,cAAc;CACzB;CACA;CACA;CACA;CACA;CACA;CACA;CACD"}
1
+ {"version":3,"file":"const.js","names":[],"sources":["../src/const.ts"],"sourcesContent":["export const APP_NAME = 'svelte-sitemap';\n\nexport const REPO_URL = 'https://github.com/bartholomej/svelte-sitemap';\n\nexport const DOMAIN = 'https://example.com';\n\nexport const OUT_DIR = 'build';\n\n// Google recommends to split sitemap into multiple files if there are more than 50k pages\n// https://support.google.com/webmasters/answer/183668?hl=en\nexport const CHUNK = {\n maxSize: 50_000\n};\n\nexport const CONFIG_FILES = [\n 'svelte-sitemap.config.js',\n 'svelte-sitemap.config.mjs',\n 'svelte-sitemap.config.cjs',\n 'svelte-sitemap.config.ts',\n 'svelte-sitemap.config.mts',\n 'svelte-sitemap.config.cts',\n 'svelte-sitemap.config.json'\n];\n\nexport const CHANGE_FREQ = [\n 'always',\n 'hourly',\n 'daily',\n 'weekly',\n 'monthly',\n 'yearly',\n 'never'\n] as const;\n"],"mappings":";AAAA,MAAa,WAAW;AAExB,MAAa,WAAW;AAIxB,MAAa,UAAU;AAIvB,MAAa,QAAQ,EACnB,SAAS,IACX;AAEA,MAAa,eAAe;CAC1B;CACA;CACA;CACA;CACA;CACA;CACA;AACF;AAEA,MAAa,cAAc;CACzB;CACA;CACA;CACA;CACA;CACA;CACA;AACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","names":[],"sources":["../../src/helpers/config.ts"],"sourcesContent":["import { OUT_DIR } from '../const.js';\nimport type { OptionsSvelteSitemap } from '../dto/index.js';\nimport { loadFile } from './file.js';\n\nexport const loadConfig = async (paths: string[]): Promise<OptionsSvelteSitemap | undefined> => {\n for (const path of paths) {\n const config = await loadFile<OptionsSvelteSitemap>(path, false);\n if (config) {\n return config;\n }\n }\n return undefined;\n};\n\nexport const defaultConfig: OptionsSvelteSitemap = {\n debug: false,\n changeFreq: null,\n resetTime: false,\n outDir: OUT_DIR,\n attribution: true,\n ignore: null,\n trailingSlashes: false,\n domain: null\n};\n\nexport const updateConfig = (\n currConfig: OptionsSvelteSitemap,\n newConfig: OptionsSvelteSitemap\n): OptionsSvelteSitemap => {\n return { ...currConfig, ...newConfig };\n};\n\nexport const withDefaultConfig = (config: OptionsSvelteSitemap): OptionsSvelteSitemap => {\n return updateConfig(defaultConfig, config);\n};\n"],"mappings":";;;AAIA,MAAa,aAAa,OAAO,UAA+D;AAC9F,MAAK,MAAM,QAAQ,OAAO;EACxB,MAAM,SAAS,MAAM,SAA+B,MAAM,MAAM;AAChE,MAAI,OACF,QAAO;;;AAMb,MAAa,gBAAsC;CACjD,OAAO;CACP,YAAY;CACZ,WAAW;CACX,QAAQ;CACR,aAAa;CACb,QAAQ;CACR,iBAAiB;CACjB,QAAQ;CACT;AAED,MAAa,gBACX,YACA,cACyB;AACzB,QAAO;EAAE,GAAG;EAAY,GAAG;EAAW;;AAGxC,MAAa,qBAAqB,WAAuD;AACvF,QAAO,aAAa,eAAe,OAAO"}
1
+ {"version":3,"file":"config.js","names":[],"sources":["../../src/helpers/config.ts"],"sourcesContent":["import { OUT_DIR } from '../const.js';\nimport type { OptionsSvelteSitemap } from '../dto/index.js';\nimport { loadFile } from './file.js';\n\nexport const loadConfig = async (paths: string[]): Promise<OptionsSvelteSitemap | undefined> => {\n for (const path of paths) {\n const config = await loadFile<OptionsSvelteSitemap>(path, false);\n if (config) {\n return config;\n }\n }\n return undefined;\n};\n\nexport const defaultConfig: OptionsSvelteSitemap = {\n debug: false,\n changeFreq: null,\n resetTime: false,\n outDir: OUT_DIR,\n attribution: true,\n ignore: null,\n trailingSlashes: false,\n domain: null\n};\n\nexport const updateConfig = (\n currConfig: OptionsSvelteSitemap,\n newConfig: OptionsSvelteSitemap\n): OptionsSvelteSitemap => {\n return { ...currConfig, ...newConfig };\n};\n\nexport const withDefaultConfig = (config: OptionsSvelteSitemap): OptionsSvelteSitemap => {\n return updateConfig(defaultConfig, config);\n};\n"],"mappings":";;;AAIA,MAAa,aAAa,OAAO,UAA+D;CAC9F,KAAK,MAAM,QAAQ,OAAO;EACxB,MAAM,SAAS,MAAM,SAA+B,MAAM,KAAK;EAC/D,IAAI,QACF,OAAO;CAEX;AAEF;AAEA,MAAa,gBAAsC;CACjD,OAAO;CACP,YAAY;CACZ,WAAW;CACX,QAAQ;CACR,aAAa;CACb,QAAQ;CACR,iBAAiB;CACjB,QAAQ;AACV;AAEA,MAAa,gBACX,YACA,cACyB;CACzB,OAAO;EAAE,GAAG;EAAY,GAAG;CAAU;AACvC;AAEA,MAAa,qBAAqB,WAAuD;CACvF,OAAO,aAAa,eAAe,MAAM;AAC3C"}
@@ -1 +1 @@
1
- {"version":3,"file":"file.js","names":[],"sources":["../../src/helpers/file.ts"],"sourcesContent":["import { existsSync } from 'fs';\nimport { createJiti } from 'jiti';\nimport { resolve } from 'path';\nimport { fileURLToPath } from 'url';\n\nconst filename = fileURLToPath(import.meta.url);\nconst jiti = createJiti(filename);\n\nexport const loadFile = async <T>(fileName: string, throwError = true): Promise<T | null> => {\n const filePath = resolve(resolve(process.cwd(), fileName));\n\n if (existsSync(filePath)) {\n try {\n const module = await jiti.import(filePath, { default: true });\n return module as T;\n } catch (err: any) {\n throw err;\n }\n }\n\n if (throwError) {\n throw new Error(`${filePath} does not exist.`);\n }\n return null;\n};\n"],"mappings":";;;;;AAMA,MAAM,OAAO,WADI,cAAc,OAAO,KAAK,IAAI,CACd;AAEjC,MAAa,WAAW,OAAU,UAAkB,aAAa,SAA4B;CAC3F,MAAM,WAAW,QAAQ,QAAQ,QAAQ,KAAK,EAAE,SAAS,CAAC;AAE1D,KAAI,WAAW,SAAS,CACtB,KAAI;AAEF,SADe,MAAM,KAAK,OAAO,UAAU,EAAE,SAAS,MAAM,CAAC;UAEtD,KAAU;AACjB,QAAM;;AAIV,KAAI,WACF,OAAM,IAAI,MAAM,GAAG,SAAS,kBAAkB;AAEhD,QAAO"}
1
+ {"version":3,"file":"file.js","names":[],"sources":["../../src/helpers/file.ts"],"sourcesContent":["import { existsSync } from 'fs';\nimport { createJiti } from 'jiti';\nimport { resolve } from 'path';\nimport { fileURLToPath } from 'url';\n\nconst filename = fileURLToPath(import.meta.url);\nconst jiti = createJiti(filename);\n\nexport const loadFile = async <T>(fileName: string, throwError = true): Promise<T | null> => {\n const filePath = resolve(resolve(process.cwd(), fileName));\n\n if (existsSync(filePath)) {\n try {\n const module = await jiti.import(filePath, { default: true });\n return module as T;\n } catch (err: any) {\n throw err;\n }\n }\n\n if (throwError) {\n throw new Error(`${filePath} does not exist.`);\n }\n return null;\n};\n"],"mappings":";;;;;AAMA,MAAM,OAAO,WADI,cAAc,OAAO,KAAK,GACZ,CAAC;AAEhC,MAAa,WAAW,OAAU,UAAkB,aAAa,SAA4B;CAC3F,MAAM,WAAW,QAAQ,QAAQ,QAAQ,IAAI,GAAG,QAAQ,CAAC;CAEzD,IAAI,WAAW,QAAQ,GACrB,IAAI;EAEF,OAAO,MADc,KAAK,OAAO,UAAU,EAAE,SAAS,KAAK,CAAC;CAE9D,SAAS,KAAU;EACjB,MAAM;CACR;CAGF,IAAI,YACF,MAAM,IAAI,MAAM,GAAG,SAAS,iBAAiB;CAE/C,OAAO;AACT"}
@@ -1 +1 @@
1
- {"version":3,"file":"global.helper.js","names":["pkg.version"],"sources":["../../src/helpers/global.helper.ts"],"sourcesContent":["import fg from 'fast-glob';\nimport fs from 'fs';\nimport { create } from 'xmlbuilder2';\nimport type { XMLBuilder } from 'xmlbuilder2/lib/interfaces.js';\nimport pkg from '../../package.json' with { type: 'json' };\nimport { CHANGE_FREQ, CHUNK, OUT_DIR } from '../const.js';\nimport type { ChangeFreq, Options, OptionsSvelteSitemap, PagesJson } from './../dto/index.js';\nimport {\n cliColors,\n errorMsgFolder,\n errorMsgHtmlFiles,\n errorMsgWrite,\n successMsg\n} from './vars.helper.js';\n\nconst version = pkg.version;\n\nconst getUrl = (url: string, domain: string, options: Options) => {\n let slash: '' | '/' = getSlash(domain);\n\n let trimmed = url\n .split((options?.outDir ?? OUT_DIR) + '/')\n .pop()\n .replace('index.html', '');\n\n trimmed = removeHtml(trimmed);\n\n // Add all traling slashes\n if (options?.trailingSlashes) {\n trimmed = trimmed.length && !trimmed.endsWith('/') ? trimmed + '/' : trimmed;\n } else {\n trimmed = trimmed.endsWith('/') ? trimmed.slice(0, -1) : trimmed;\n slash = trimmed ? slash : '';\n }\n\n // URI-encode each path segment to handle special characters (e.g. spaces → %20).\n // Decode first to avoid double-encoding already percent-encoded segments.\n trimmed = trimmed\n .split('/')\n .map((segment) => {\n try {\n return encodeURIComponent(decodeURIComponent(segment));\n } catch {\n return encodeURIComponent(segment);\n }\n })\n .join('/');\n\n return `${domain}${slash}${trimmed}`;\n};\n\nexport const removeHtml = (fileName: string) => {\n if (fileName?.endsWith('.html')) {\n return fileName.slice(0, -5);\n }\n return fileName;\n};\n\nexport async function prepareData(domain: string, options?: Options): Promise<PagesJson[]> {\n const FOLDER = options?.outDir ?? OUT_DIR;\n\n const ignore = prepareIgnored(options?.ignore, options?.outDir);\n const changeFreq = prepareChangeFreq(options);\n const pages: string[] = await fg(`${FOLDER}/**/*.html`, { ignore });\n\n if (options.additional) pages.push(...options.additional);\n\n const results = pages.map((page) => {\n return {\n page: getUrl(page, domain, options),\n changeFreq: changeFreq,\n lastMod: options?.resetTime ? new Date().toISOString().split('T')[0] : ''\n };\n });\n\n detectErrors({\n folder: !fs.existsSync(FOLDER),\n htmlFiles: !pages.length\n });\n\n return results;\n}\n\nexport const detectErrors = ({ folder, htmlFiles }: { folder: boolean; htmlFiles: boolean }) => {\n if (folder && htmlFiles) {\n console.error(cliColors.red, errorMsgFolder(OUT_DIR));\n } else if (htmlFiles) {\n // If no page exists, then the static adapter is probably not used\n console.error(cliColors.red, errorMsgHtmlFiles(OUT_DIR));\n }\n};\n\nexport const writeSitemap = (items: PagesJson[], options: Options, domain: string): void => {\n const outDir = options?.outDir ?? OUT_DIR;\n\n if (items?.length <= CHUNK.maxSize) {\n createFile(items, options, outDir);\n } else {\n // If the number of pages is greater than the chunk size, then we split the sitemap into multiple files\n // and create an index file that links to all of them\n // https://support.google.com/webmasters/answer/183668?hl=en\n const numberOfChunks = Math.ceil(items.length / CHUNK.maxSize);\n\n console.log(\n cliColors.cyanAndBold,\n `> Oh, your site is huge! Writing sitemap in chunks of ${numberOfChunks} pages and its index sitemap.xml`\n );\n\n for (let i = 0; i < items.length; i += CHUNK.maxSize) {\n const chunk = items.slice(i, i + CHUNK.maxSize);\n createFile(chunk, options, outDir, i / CHUNK.maxSize + 1);\n }\n createIndexFile(numberOfChunks, outDir, options, domain);\n }\n};\n\nconst createFile = (\n items: PagesJson[],\n options: Options,\n outDir: string,\n chunkId?: number\n): void => {\n const sitemap = createXml('urlset');\n addAttribution(sitemap, options);\n\n for (const item of items) {\n const page = sitemap.ele('url');\n page.ele('loc').txt(item.page);\n if (item.changeFreq) {\n page.ele('changefreq').txt(item.changeFreq);\n }\n if (item.lastMod) {\n page.ele('lastmod').txt(item.lastMod);\n }\n }\n\n const xml = finishXml(sitemap);\n\n const fileName = chunkId ? `sitemap-${chunkId}.xml` : 'sitemap.xml';\n\n try {\n fs.writeFileSync(`${outDir}/${fileName}`, xml);\n console.log(cliColors.green, successMsg(outDir, fileName));\n } catch (e) {\n console.error(cliColors.red, errorMsgWrite(outDir, fileName), e);\n }\n};\n\nconst createIndexFile = (\n numberOfChunks: number,\n outDir: string,\n options: Options,\n domain: string\n): void => {\n const FILENAME = 'sitemap.xml';\n const slash = getSlash(domain);\n\n const sitemap = createXml('sitemapindex');\n addAttribution(sitemap, options);\n\n for (let i = 1; i <= numberOfChunks; i++) {\n sitemap.ele('sitemap').ele('loc').txt(`${domain}${slash}sitemap-${i}.xml`);\n }\n\n const xml = finishXml(sitemap);\n\n try {\n fs.writeFileSync(`${outDir}/${FILENAME}`, xml);\n console.log(cliColors.green, successMsg(outDir, FILENAME));\n } catch (e) {\n console.error(cliColors.red, errorMsgWrite(outDir, FILENAME), e);\n }\n};\n\nconst prepareIgnored = (\n ignored: string | string[],\n outDir: string = OUT_DIR\n): string[] | undefined => {\n let ignore: string[] | undefined;\n if (ignored) {\n ignore = Array.isArray(ignored) ? ignored : [ignored];\n ignore = ignore.map((ignoredPage) => `${outDir}/${ignoredPage}`);\n }\n return ignore;\n};\n\nconst prepareChangeFreq = (options: Options): ChangeFreq => {\n let result: ChangeFreq = null;\n\n if (options?.changeFreq) {\n if (CHANGE_FREQ.includes(options.changeFreq)) {\n result = options.changeFreq;\n } else {\n console.log(\n cliColors.red,\n ` × Option \\`--change-freq ${options.changeFreq}\\` is not a valid value. See docs: https://github.com/bartholomej/svelte-sitemap#options`\n );\n }\n }\n return result;\n};\n\nconst getSlash = (domain: string) => (domain.split('/').pop() ? '/' : '');\n\nconst createXml = (elementName: 'urlset' | 'sitemapindex'): XMLBuilder => {\n return create({ version: '1.0', encoding: 'UTF-8' }).ele(elementName, {\n xmlns: 'http://www.sitemaps.org/schemas/sitemap/0.9'\n });\n};\n\nconst finishXml = (sitemap: XMLBuilder): string => {\n return sitemap.end({ prettyPrint: true });\n};\n\nconst addAttribution = (sitemap: XMLBuilder, options: Options): void => {\n if (options?.attribution !== false) {\n sitemap.com(\n ` This file was automatically generated by https://github.com/bartholomej/svelte-sitemap v${version} `\n );\n }\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"global.helper.js","names":["pkg.version"],"sources":["../../src/helpers/global.helper.ts"],"sourcesContent":["import fg from 'fast-glob';\nimport fs from 'fs';\nimport { create } from 'xmlbuilder2';\nimport type { XMLBuilder } from 'xmlbuilder2/lib/interfaces.js';\nimport pkg from '../../package.json' with { type: 'json' };\nimport { CHANGE_FREQ, CHUNK, OUT_DIR } from '../const.js';\nimport type { ChangeFreq, Options, OptionsSvelteSitemap, PagesJson } from './../dto/index.js';\nimport {\n cliColors,\n errorMsgFolder,\n errorMsgHtmlFiles,\n errorMsgWrite,\n successMsg\n} from './vars.helper.js';\n\nconst version = pkg.version;\n\nconst getUrl = (url: string, domain: string, options: Options) => {\n let slash: '' | '/' = getSlash(domain);\n\n let trimmed = url\n .split((options?.outDir ?? OUT_DIR) + '/')\n .pop()\n .replace('index.html', '');\n\n trimmed = removeHtml(trimmed);\n\n // Add all traling slashes\n if (options?.trailingSlashes) {\n trimmed = trimmed.length && !trimmed.endsWith('/') ? trimmed + '/' : trimmed;\n } else {\n trimmed = trimmed.endsWith('/') ? trimmed.slice(0, -1) : trimmed;\n slash = trimmed ? slash : '';\n }\n\n // URI-encode each path segment to handle special characters (e.g. spaces → %20).\n // Decode first to avoid double-encoding already percent-encoded segments.\n trimmed = trimmed\n .split('/')\n .map((segment) => {\n try {\n return encodeURIComponent(decodeURIComponent(segment));\n } catch {\n return encodeURIComponent(segment);\n }\n })\n .join('/');\n\n return `${domain}${slash}${trimmed}`;\n};\n\nexport const removeHtml = (fileName: string) => {\n if (fileName?.endsWith('.html')) {\n return fileName.slice(0, -5);\n }\n return fileName;\n};\n\nexport async function prepareData(domain: string, options?: Options): Promise<PagesJson[]> {\n const FOLDER = options?.outDir ?? OUT_DIR;\n\n const ignore = prepareIgnored(options?.ignore, options?.outDir);\n const changeFreq = prepareChangeFreq(options);\n const pages: string[] = await fg(`${FOLDER}/**/*.html`, { ignore });\n\n if (options.additional) pages.push(...options.additional);\n\n const results = pages.map((page) => {\n return {\n page: getUrl(page, domain, options),\n changeFreq: changeFreq,\n lastMod: options?.resetTime ? new Date().toISOString().split('T')[0] : ''\n };\n });\n\n detectErrors({\n folder: !fs.existsSync(FOLDER),\n htmlFiles: !pages.length\n });\n\n return results;\n}\n\nexport const detectErrors = ({ folder, htmlFiles }: { folder: boolean; htmlFiles: boolean }) => {\n if (folder && htmlFiles) {\n console.error(cliColors.red, errorMsgFolder(OUT_DIR));\n } else if (htmlFiles) {\n // If no page exists, then the static adapter is probably not used\n console.error(cliColors.red, errorMsgHtmlFiles(OUT_DIR));\n }\n};\n\nexport const writeSitemap = (items: PagesJson[], options: Options, domain: string): void => {\n const outDir = options?.outDir ?? OUT_DIR;\n\n if (items?.length <= CHUNK.maxSize) {\n createFile(items, options, outDir);\n } else {\n // If the number of pages is greater than the chunk size, then we split the sitemap into multiple files\n // and create an index file that links to all of them\n // https://support.google.com/webmasters/answer/183668?hl=en\n const numberOfChunks = Math.ceil(items.length / CHUNK.maxSize);\n\n console.log(\n cliColors.cyanAndBold,\n `> Oh, your site is huge! Writing sitemap in chunks of ${numberOfChunks} pages and its index sitemap.xml`\n );\n\n for (let i = 0; i < items.length; i += CHUNK.maxSize) {\n const chunk = items.slice(i, i + CHUNK.maxSize);\n createFile(chunk, options, outDir, i / CHUNK.maxSize + 1);\n }\n createIndexFile(numberOfChunks, outDir, options, domain);\n }\n};\n\nconst createFile = (\n items: PagesJson[],\n options: Options,\n outDir: string,\n chunkId?: number\n): void => {\n const sitemap = createXml('urlset');\n addAttribution(sitemap, options);\n\n for (const item of items) {\n const page = sitemap.ele('url');\n page.ele('loc').txt(item.page);\n if (item.changeFreq) {\n page.ele('changefreq').txt(item.changeFreq);\n }\n if (item.lastMod) {\n page.ele('lastmod').txt(item.lastMod);\n }\n }\n\n const xml = finishXml(sitemap);\n\n const fileName = chunkId ? `sitemap-${chunkId}.xml` : 'sitemap.xml';\n\n try {\n fs.writeFileSync(`${outDir}/${fileName}`, xml);\n console.log(cliColors.green, successMsg(outDir, fileName));\n } catch (e) {\n console.error(cliColors.red, errorMsgWrite(outDir, fileName), e);\n }\n};\n\nconst createIndexFile = (\n numberOfChunks: number,\n outDir: string,\n options: Options,\n domain: string\n): void => {\n const FILENAME = 'sitemap.xml';\n const slash = getSlash(domain);\n\n const sitemap = createXml('sitemapindex');\n addAttribution(sitemap, options);\n\n for (let i = 1; i <= numberOfChunks; i++) {\n sitemap.ele('sitemap').ele('loc').txt(`${domain}${slash}sitemap-${i}.xml`);\n }\n\n const xml = finishXml(sitemap);\n\n try {\n fs.writeFileSync(`${outDir}/${FILENAME}`, xml);\n console.log(cliColors.green, successMsg(outDir, FILENAME));\n } catch (e) {\n console.error(cliColors.red, errorMsgWrite(outDir, FILENAME), e);\n }\n};\n\nconst prepareIgnored = (\n ignored: string | string[],\n outDir: string = OUT_DIR\n): string[] | undefined => {\n let ignore: string[] | undefined;\n if (ignored) {\n ignore = Array.isArray(ignored) ? ignored : [ignored];\n ignore = ignore.map((ignoredPage) => `${outDir}/${ignoredPage}`);\n }\n return ignore;\n};\n\nconst prepareChangeFreq = (options: Options): ChangeFreq => {\n let result: ChangeFreq = null;\n\n if (options?.changeFreq) {\n if (CHANGE_FREQ.includes(options.changeFreq)) {\n result = options.changeFreq;\n } else {\n console.log(\n cliColors.red,\n ` × Option \\`--change-freq ${options.changeFreq}\\` is not a valid value. See docs: https://github.com/bartholomej/svelte-sitemap#options`\n );\n }\n }\n return result;\n};\n\nconst getSlash = (domain: string) => (domain.split('/').pop() ? '/' : '');\n\nconst createXml = (elementName: 'urlset' | 'sitemapindex'): XMLBuilder => {\n return create({ version: '1.0', encoding: 'UTF-8' }).ele(elementName, {\n xmlns: 'http://www.sitemaps.org/schemas/sitemap/0.9'\n });\n};\n\nconst finishXml = (sitemap: XMLBuilder): string => {\n return sitemap.end({ prettyPrint: true });\n};\n\nconst addAttribution = (sitemap: XMLBuilder, options: Options): void => {\n if (options?.attribution !== false) {\n sitemap.com(\n ` This file was automatically generated by https://github.com/bartholomej/svelte-sitemap v${version} `\n );\n }\n};\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"vars.helper.js","names":[],"sources":["../../src/helpers/vars.helper.ts"],"sourcesContent":["export const cliColors = {\n cyanAndBold: '\\x1b[36m\\x1b[1m%s\\x1b[22m\\x1b[0m',\n green: '\\x1b[32m%s\\x1b[0m',\n red: '\\x1b[31m%s\\x1b[0m',\n yellow: '\\x1b[33m%s\\x1b[0m'\n};\n\nexport const successMsg = (outDir: string, filename: string) =>\n ` ✔ Done. Check your new sitemap here: ./${outDir}/${filename}`;\n\nexport const errorMsgWrite = (outDir: string, filename: string) =>\n ` × File '${outDir}/${filename}' could not be created.`;\n\nexport const errorMsgGeneration = ` × Sitemap generation failed.`;\n\nexport const errorMsgFolder = (outDir: string) =>\n ` × Folder '${outDir}/' doesn't exist.\\n Make sure you are using this library as 'postbuild' so '${outDir}/' folder was successfully created before running this script. Or are you using Vercel? See https://github.com/bartholomej/svelte-sitemap#error-missing-folder`;\n\nexport const errorMsgHtmlFiles = (outDir: string) =>\n ` × There is no static html file in your '${outDir}/' folder. Are you sure you are using Svelte adapter-static with prerender option? See https://github.com/bartholomej/svelte-sitemap#error-missing-html-files`;\n"],"mappings":";AAAA,MAAa,YAAY;CACvB,aAAa;CACb,OAAO;CACP,KAAK;CACL,QAAQ;CACT;AAED,MAAa,cAAc,QAAgB,aACzC,4CAA4C,OAAO,GAAG;AAExD,MAAa,iBAAiB,QAAgB,aAC5C,aAAa,OAAO,GAAG,SAAS;AAElC,MAAa,qBAAqB;AAElC,MAAa,kBAAkB,WAC7B,eAAe,OAAO,iFAAiF,OAAO;AAEhH,MAAa,qBAAqB,WAChC,6CAA6C,OAAO"}
1
+ {"version":3,"file":"vars.helper.js","names":[],"sources":["../../src/helpers/vars.helper.ts"],"sourcesContent":["export const cliColors = {\n cyanAndBold: '\\x1b[36m\\x1b[1m%s\\x1b[22m\\x1b[0m',\n green: '\\x1b[32m%s\\x1b[0m',\n red: '\\x1b[31m%s\\x1b[0m',\n yellow: '\\x1b[33m%s\\x1b[0m'\n};\n\nexport const successMsg = (outDir: string, filename: string) =>\n ` ✔ Done. Check your new sitemap here: ./${outDir}/${filename}`;\n\nexport const errorMsgWrite = (outDir: string, filename: string) =>\n ` × File '${outDir}/${filename}' could not be created.`;\n\nexport const errorMsgGeneration = ` × Sitemap generation failed.`;\n\nexport const errorMsgFolder = (outDir: string) =>\n ` × Folder '${outDir}/' doesn't exist.\\n Make sure you are using this library as 'postbuild' so '${outDir}/' folder was successfully created before running this script. Or are you using Vercel? See https://github.com/bartholomej/svelte-sitemap#error-missing-folder`;\n\nexport const errorMsgHtmlFiles = (outDir: string) =>\n ` × There is no static html file in your '${outDir}/' folder. Are you sure you are using Svelte adapter-static with prerender option? See https://github.com/bartholomej/svelte-sitemap#error-missing-html-files`;\n"],"mappings":";AAAA,MAAa,YAAY;CACvB,aAAa;CACb,OAAO;CACP,KAAK;CACL,QAAQ;AACV;AAEA,MAAa,cAAc,QAAgB,aACzC,4CAA4C,OAAO,GAAG;AAExD,MAAa,iBAAiB,QAAgB,aAC5C,aAAa,OAAO,GAAG,SAAS;AAElC,MAAa,qBAAqB;AAElC,MAAa,kBAAkB,WAC7B,eAAe,OAAO,iFAAiF,OAAO;AAEhH,MAAa,qBAAqB,WAChC,6CAA6C,OAAO"}
package/index.d.ts CHANGED
@@ -3,5 +3,5 @@ import { Arguments, ChangeFreq, Options, OptionsSvelteSitemap, PagesJson } from
3
3
  //#region src/index.d.ts
4
4
  declare const createSitemap: (options: OptionsSvelteSitemap) => Promise<void>;
5
5
  //#endregion
6
- export { Arguments, ChangeFreq, Options, OptionsSvelteSitemap, PagesJson, createSitemap };
6
+ export { type Arguments, type ChangeFreq, type Options, type OptionsSvelteSitemap, type PagesJson, createSitemap };
7
7
  //# sourceMappingURL=index.d.ts.map
package/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["import { OUT_DIR } from './const.js';\nimport type { OptionsSvelteSitemap } from './dto/index.js';\nimport { prepareData, writeSitemap } from './helpers/global.helper.js';\nimport { cliColors, errorMsgWrite } from './helpers/vars.helper.js';\n\nexport const createSitemap = async (options: OptionsSvelteSitemap): Promise<void> => {\n if (options?.debug) {\n console.log('OPTIONS', options);\n }\n\n const json = await prepareData(options.domain, options);\n\n if (options?.debug) {\n console.log('RESULT', json);\n }\n\n if (json.length) {\n writeSitemap(json, options, options.domain);\n } else {\n console.error(cliColors.red, errorMsgWrite(options.outDir ?? OUT_DIR, 'sitemap.xml'));\n }\n};\n\nexport type * from './dto/index.js';\n"],"mappings":";;;;AAKA,MAAa,gBAAgB,OAAO,YAAiD;AACnF,KAAI,SAAS,MACX,SAAQ,IAAI,WAAW,QAAQ;CAGjC,MAAM,OAAO,MAAM,YAAY,QAAQ,QAAQ,QAAQ;AAEvD,KAAI,SAAS,MACX,SAAQ,IAAI,UAAU,KAAK;AAG7B,KAAI,KAAK,OACP,cAAa,MAAM,SAAS,QAAQ,OAAO;KAE3C,SAAQ,MAAM,UAAU,KAAK,cAAc,QAAQ,UAAA,SAAmB,cAAc,CAAC"}
1
+ {"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["import { OUT_DIR } from './const.js';\nimport type { OptionsSvelteSitemap } from './dto/index.js';\nimport { prepareData, writeSitemap } from './helpers/global.helper.js';\nimport { cliColors, errorMsgWrite } from './helpers/vars.helper.js';\n\nexport const createSitemap = async (options: OptionsSvelteSitemap): Promise<void> => {\n if (options?.debug) {\n console.log('OPTIONS', options);\n }\n\n const json = await prepareData(options.domain, options);\n\n if (options?.debug) {\n console.log('RESULT', json);\n }\n\n if (json.length) {\n writeSitemap(json, options, options.domain);\n } else {\n console.error(cliColors.red, errorMsgWrite(options.outDir ?? OUT_DIR, 'sitemap.xml'));\n }\n};\n\nexport type * from './dto/index.js';\n"],"mappings":";;;;AAKA,MAAa,gBAAgB,OAAO,YAAiD;CACnF,IAAI,SAAS,OACX,QAAQ,IAAI,WAAW,OAAO;CAGhC,MAAM,OAAO,MAAM,YAAY,QAAQ,QAAQ,OAAO;CAEtD,IAAI,SAAS,OACX,QAAQ,IAAI,UAAU,IAAI;CAG5B,IAAI,KAAK,QACP,aAAa,MAAM,SAAS,QAAQ,MAAM;MAE1C,QAAQ,MAAM,UAAU,KAAK,cAAc,QAAQ,UAAA,SAAmB,aAAa,CAAC;AAExF"}
package/package.js CHANGED
@@ -1,5 +1,5 @@
1
1
  //#region package.json
2
- var version = "3.2.0-next.1";
2
+ var version = "3.2.0";
3
3
  //#endregion
4
4
  export { version };
5
5
 
package/package.json CHANGED
@@ -1,18 +1,10 @@
1
1
  {
2
2
  "name": "svelte-sitemap",
3
- "version": "3.2.0-next.1",
3
+ "version": "3.2.0",
4
4
  "type": "module",
5
5
  "description": "Small helper which scans your Svelte routes folder and generates static sitemap.xml",
6
6
  "author": "BART! <bart@bartweb.cz>",
7
7
  "bin": "cli.js",
8
- "peerDependencies": {
9
- "vite": ">=5.0.0"
10
- },
11
- "peerDependenciesMeta": {
12
- "vite": {
13
- "optional": true
14
- }
15
- },
16
8
  "dependencies": {
17
9
  "fast-glob": "^3.3.3",
18
10
  "jiti": "^2.7.0",
@@ -70,7 +62,6 @@
70
62
  "exports": {
71
63
  ".": "./index.js",
72
64
  "./cli": "./cli.js",
73
- "./vite": "./vite.js",
74
65
  "./package.json": "./package.json"
75
66
  }
76
67
  }
package/vite.d.ts DELETED
@@ -1,8 +0,0 @@
1
- import { OptionsSvelteSitemap } from "./dto/global.interface.js";
2
- import { Plugin } from "vite";
3
-
4
- //#region src/vite.d.ts
5
- declare function svelteSitemap(options: OptionsSvelteSitemap): Plugin;
6
- //#endregion
7
- export { svelteSitemap };
8
- //# sourceMappingURL=vite.d.ts.map
package/vite.js DELETED
@@ -1,15 +0,0 @@
1
- import { createSitemap } from "./index.js";
2
- //#region src/vite.ts
3
- function svelteSitemap(options) {
4
- return {
5
- name: "svelte-sitemap",
6
- apply: "build",
7
- closeBundle: async () => {
8
- await createSitemap(options);
9
- }
10
- };
11
- }
12
- //#endregion
13
- export { svelteSitemap };
14
-
15
- //# sourceMappingURL=vite.js.map
package/vite.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"vite.js","names":[],"sources":["../src/vite.ts"],"sourcesContent":["import type { Plugin } from 'vite';\nimport type { OptionsSvelteSitemap } from './dto/index.js';\nimport { createSitemap } from './index.js';\n\nexport function svelteSitemap(options: OptionsSvelteSitemap): Plugin {\n return {\n name: 'svelte-sitemap',\n apply: 'build',\n closeBundle: async () => {\n await createSitemap(options);\n }\n };\n}\n"],"mappings":";;AAIA,SAAgB,cAAc,SAAuC;AACnE,QAAO;EACL,MAAM;EACN,OAAO;EACP,aAAa,YAAY;AACvB,SAAM,cAAc,QAAQ;;EAE/B"}