template-syncer 1.0.3 → 1.1.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.
Files changed (54) hide show
  1. package/README.md +127 -57
  2. package/bin/syn.js +37 -83
  3. package/lib/index.d.ts +4 -116
  4. package/lib/index.d.ts.map +1 -1
  5. package/lib/index.js +14 -1045
  6. package/lib/index.js.map +1 -1
  7. package/lib/package.json +15 -12
  8. package/lib/syncer.d.ts +65 -0
  9. package/lib/syncer.d.ts.map +1 -0
  10. package/lib/syncer.js +413 -0
  11. package/lib/syncer.js.map +1 -0
  12. package/lib/types.d.ts +95 -32
  13. package/lib/types.d.ts.map +1 -1
  14. package/lib/ui/index.d.ts +4 -0
  15. package/lib/ui/index.d.ts.map +1 -0
  16. package/lib/ui/index.js +11 -0
  17. package/lib/ui/index.js.map +1 -0
  18. package/lib/ui/logger.d.ts +26 -0
  19. package/lib/ui/logger.d.ts.map +1 -0
  20. package/lib/ui/logger.js +60 -0
  21. package/lib/ui/logger.js.map +1 -0
  22. package/lib/ui/prompts.d.ts +48 -0
  23. package/lib/ui/prompts.d.ts.map +1 -0
  24. package/lib/ui/prompts.js +202 -0
  25. package/lib/ui/prompts.js.map +1 -0
  26. package/lib/ui/tree.d.ts +10 -0
  27. package/lib/ui/tree.d.ts.map +1 -0
  28. package/lib/ui/tree.js +130 -0
  29. package/lib/ui/tree.js.map +1 -0
  30. package/lib/utils/categorizer.d.ts +24 -0
  31. package/lib/utils/categorizer.d.ts.map +1 -0
  32. package/lib/utils/categorizer.js +201 -0
  33. package/lib/utils/categorizer.js.map +1 -0
  34. package/lib/utils/git.d.ts +36 -0
  35. package/lib/utils/git.d.ts.map +1 -0
  36. package/lib/utils/git.js +96 -0
  37. package/lib/utils/git.js.map +1 -0
  38. package/lib/utils/index.d.ts +6 -0
  39. package/lib/utils/index.d.ts.map +1 -0
  40. package/lib/utils/index.js +14 -0
  41. package/lib/utils/index.js.map +1 -0
  42. package/lib/utils/merger.d.ts +40 -0
  43. package/lib/utils/merger.d.ts.map +1 -0
  44. package/lib/utils/merger.js +223 -0
  45. package/lib/utils/merger.js.map +1 -0
  46. package/lib/utils/platform.d.ts +44 -0
  47. package/lib/utils/platform.d.ts.map +1 -0
  48. package/lib/utils/platform.js +169 -0
  49. package/lib/utils/platform.js.map +1 -0
  50. package/lib/utils/scanner.d.ts +40 -0
  51. package/lib/utils/scanner.d.ts.map +1 -0
  52. package/lib/utils/scanner.js +221 -0
  53. package/lib/utils/scanner.js.map +1 -0
  54. package/package.json +15 -12
package/README.md CHANGED
@@ -4,31 +4,29 @@
4
4
 
5
5
  <a href="https://github.com/iceywu/template-syncer">
6
6
  <img alt="GitHub Repo stars" src="https://img.shields.io/github/stars/iceywu/template-syncer?logo=github&color=%234d80f0&link=https%3A%2F%2Fgithub.com%2iceywu%2Ftemplate-syncer">
7
- </a>
7
+ </a>
8
8
  <a href="https://www.npmjs.com/package/template-syncer">
9
9
  <img alt="npm" src="https://img.shields.io/npm/v/template-syncer?logo=npm&color=%234d80f0&link=https%3A%2F%2Fwww.npmjs.com%2Fpackage%2Ftemplate-syncer">
10
10
  </a>
11
11
  <a href="https://www.npmjs.com/package/template-syncer">
12
12
  <img alt="npm" src="https://img.shields.io/npm/dw/template-syncer?logo=npm&link=https%3A%2F%2Fwww.npmjs.com%2Fpackage%2Ftemplate-syncer">
13
13
  </a>
14
- <a href="https://www.npmjs.com/package/template-syncer">
15
- <img src="https://img.shields.io/npm/dt/template-syncer?style=flat-square" alt="downloads">
16
- </a>
17
14
 
18
15
  ## ✨ 特性
19
16
 
20
17
  - 🚀 **智能同步** - 自动检测并同步模板更新
21
- - 🎇 **自动扫描** - 智能扫描当前目录的所有可同步文件
22
- - **批量选择** - 支持全选/反选,批量处理文件
23
- - 🔍 **智能对比** - 先对比差异,再选择性更新
24
- - 📦 **智能合并** - 特别针对 `package.json` 的智能合并策略
25
- - 🔄 **差异对比** - 使用 Git diff 显示文件变更
18
+ - 🌍 **跨平台** - 完美支持 Windows/macOS/Linux
19
+ - 📦 **智能合并** - package.json 等配置文件智能合并
20
+ - 🎯 **自动分类** - 基于 glob 模式的智能文件分类
21
+ - 🔌 **可扩展** - 支持自定义分类规则和合并策略
26
22
  - 💾 **安全备份** - 操作前自动创建 Git 备份
27
- - 🎯 **两阶段确认** - 先选择文件,再选择更新项
23
+ - 🌿 **多分支** - 支持从任意分支同步
28
24
 
29
25
  ## 📦 安装
30
26
 
31
27
  ```bash
28
+ pnpm add -g template-syncer
29
+ # 或
32
30
  npm install -g template-syncer
33
31
  ```
34
32
 
@@ -37,74 +35,146 @@ npm install -g template-syncer
37
35
  ### 基本用法
38
36
 
39
37
  ```bash
40
- # 交互式同步(会询问模板仓库)
38
+ # 交互式同步
41
39
  syn
42
40
 
43
41
  # 指定模板仓库
44
- syn --repo https://github.com/IceyWu/cloud-template.git
45
-
46
- # 指定模板仓库和分支
47
- syn --repo https://github.com/IceyWu/cloud-template.git --branch dev
42
+ syn -r https://github.com/user/template.git
48
43
 
49
- # 详细模式
50
- syn --verbose
44
+ # 指定分支
45
+ syn -r https://github.com/user/template.git -b dev
51
46
 
52
- # 只指定分支(会使用配置文件中的仓库)
53
- syn --branch main
47
+ # 详细输出
48
+ syn -v
54
49
  ```
55
50
 
56
- ### 同步流程
57
-
58
- 1. **文件扫描** - 自动扫描当前目录下的所有支持文件
59
- 2. **仓库克隆** - 克隆指定的模板仓库
60
- 3. **分支选择** - 如果未指定分支,会列出所有分支供选择
61
- 4. **文件选择** - 默认全选,可以自定义选择要检查的文件
62
- 5. **差异对比** - 与模板进行对比,找出有变化的文件
63
- 6. **变更选择** - 选择要更新的文件,可以预览差异
64
- 7. **批量更新** - 一次性更新所有选中的文件
65
-
66
- ### 支持的文件类型
67
-
68
- - **配置文件**: `.json`, `.yml`, `.yaml`, `.xml`
69
- - **代码文件**: `.js`, `.ts`, `.jsx`, `.tsx`
70
- - **样式文件**: `.css`, `.scss`, `.less`
71
- - **文档文件**: `.md`, `.txt`
72
- - **配置文件**: `.gitignore`, `.npmrc`, `.eslintrc`, `.prettierrc` 等
73
- - **容器文件**: `Dockerfile`, `.dockerignore`
74
- - **构建文件**: `Makefile`, 各种配置文件
75
-
76
- ### 初始化配置
51
+ ### 运行模式
77
52
 
78
53
  ```bash
79
- syn --init
54
+ syn # 交互式同步 (默认)
55
+ syn --init # 初始化配置
56
+ syn --batch # 批量处理模式
57
+ syn --preview # 预览差异
58
+ syn --smart # 智能推荐模式
80
59
  ```
81
60
 
82
- ### 分支支持
61
+ ### 配置文件
62
+
63
+ 运行 `syn --init` 创建配置文件 `.template-sync.json`:
64
+
65
+ ```json
66
+ {
67
+ "repo": "https://github.com/user/template.git",
68
+ "branch": "main",
69
+ "ignore": [".env.local"],
70
+ "rules": {
71
+ "deleteOrphans": false,
72
+ "deletePatterns": ["src/deprecated/**"],
73
+ "protectPatterns": ["src/local/**", "*.local.*"],
74
+ "autoBackup": true,
75
+ "defaultMergeStrategy": "overwrite"
76
+ },
77
+ "lastSync": "2024-01-01T00:00:00.000Z"
78
+ }
79
+ ```
83
80
 
84
- Tool 支持从任意分支同步模板:
81
+ ### 同步规则 (rules)
82
+
83
+ | 选项 | 类型 | 默认值 | 说明 |
84
+ |------|------|--------|------|
85
+ | `deleteOrphans` | boolean | `false` | 是否删除本地独有文件 |
86
+ | `deletePatterns` | string[] | `[]` | 要删除的文件模式 (glob) |
87
+ | `protectPatterns` | string[] | `[]` | 保护不被删除的文件模式 |
88
+ | `autoBackup` | boolean | `true` | 同步前自动备份 |
89
+ | `defaultMergeStrategy` | string | `"overwrite"` | 默认合并策略 |
90
+
91
+ **示例:删除本地独有的 Swift 文件**
92
+
93
+ ```json
94
+ {
95
+ "rules": {
96
+ "deleteOrphans": true,
97
+ "deletePatterns": ["**/*.swift"],
98
+ "protectPatterns": ["src/local/**"]
99
+ }
100
+ }
101
+ ```
102
+ ```
85
103
 
86
- - **指定分支**: 使用 `--branch` 参数指定要同步的分支
87
- - **交互选择**: 如果不指定分支,工具会列出所有可用分支供你选择
88
- - **配置保存**: 可以在初始化配置时设置默认分支
104
+ ## 🔧 高级用法
105
+
106
+ ### 编程式使用
107
+
108
+ ```typescript
109
+ import { TemplateSyncer } from 'template-syncer';
110
+
111
+ const syncer = new TemplateSyncer({
112
+ repo: 'https://github.com/user/template.git',
113
+ branch: 'main',
114
+ verbose: true,
115
+ // 自定义忽略模式
116
+ ignore: ['*.local', 'secrets/**'],
117
+ // 自定义分类规则
118
+ categories: [
119
+ { match: '**/custom/*.ts', category: '自定义模块', icon: '🎯', priority: 100 }
120
+ ],
121
+ // 自定义合并策略
122
+ mergers: {
123
+ 'config.json': 'smart',
124
+ 'README.md': 'skip'
125
+ },
126
+ // 同步规则
127
+ rules: {
128
+ deleteOrphans: true,
129
+ deletePatterns: ['src/deprecated/**'],
130
+ protectPatterns: ['src/local/**'],
131
+ autoBackup: true
132
+ }
133
+ });
134
+
135
+ await syncer.sync();
136
+ ```
89
137
 
90
- ```bash
91
- # 从 dev 分支同步
92
- syn --repo https://github.com/owner/repo.git --branch dev
138
+ ### 合并策略
139
+
140
+ | 策略 | 说明 |
141
+ |------|------|
142
+ | `overwrite` | 直接覆盖 (默认) |
143
+ | `skip` | 跳过不处理 |
144
+ | `smart` | 智能合并 (JSON 文件) |
145
+ | `ask` | 询问用户 |
146
+
147
+ ### 自定义分类规则
148
+
149
+ ```typescript
150
+ const syncer = new TemplateSyncer({
151
+ categories: [
152
+ // 高优先级规则
153
+ { match: '**/api/*.ts', category: 'API 模块', icon: '🔌', priority: 100 },
154
+ // 低优先级规则
155
+ { match: '**/*.ts', category: 'TypeScript', icon: '🔷', priority: 10 }
156
+ ]
157
+ });
158
+ ```
93
159
 
94
- # feature/new-ui 分支同步
95
- syn --repo https://github.com/owner/repo.git --branch feature/new-ui
160
+ ## 📁 支持的文件类型
96
161
 
97
- # 不指定分支,工具会列出所有分支让你选择
98
- syn --repo https://github.com/owner/repo.git
99
- ```
162
+ 工具会自动识别并分类各种文件:
100
163
 
164
+ - **项目配置**: package.json, Cargo.toml, go.mod 等
165
+ - **构建工具**: vite.config.*, webpack.config.* 等
166
+ - **代码质量**: .eslintrc*, .prettierrc* 等
167
+ - **框架配置**: nuxt.config.*, next.config.* 等
168
+ - **容器化**: Dockerfile, docker-compose.yml 等
169
+ - **CI/CD**: .github/workflows/*, .gitlab-ci.yml 等
170
+ - **各种编程语言**: .ts, .js, .py, .go, .rs, .java 等
101
171
 
102
172
  ## 🛡️ 安全性
103
173
 
104
174
  - **Git 备份**: 操作前自动创建 stash 备份
105
- - **交互确认**: 每个文件更改都需要用户确认
106
- - **差异显示**: 清楚展示即将进行的更改
175
+ - **交互确认**: 每次操作都需要用户确认
176
+ - **差异预览**: 可以先预览再决定是否应用
107
177
 
108
178
  ## 📄 许可证
109
179
 
110
- [MIT License](./LICENSE)
180
+ [MIT License](./LICENSE)
package/bin/syn.js CHANGED
@@ -1,7 +1,7 @@
1
- #!/usr/bin/env node
1
+ #!/usr/bin/env node
2
2
 
3
3
  const { Command } = require('commander');
4
- const { TemplateSyncer } = require('../lib/index');
4
+ const { TemplateSyncer } = require('../lib/syncer');
5
5
  const pkg = require('../package.json');
6
6
 
7
7
  const program = new Command();
@@ -10,109 +10,65 @@ program
10
10
  .name('syn')
11
11
  .description('智能模板同步工具 - 让你的项目与模板仓库保持同步')
12
12
  .version(pkg.version)
13
- .option('-r, --repo <url>', '指定模板仓库 URL')
14
- .option('-b, --branch <name>', '指定分支名称')
15
- .option('-v, --verbose', '显示详细输出信息')
16
- .option('-i, --init', '初始化配置向导')
17
- .option('--batch', '高级批量操作模式')
18
- .option('-p, --preview', '预览所有差异(不执行更新)')
19
- .option('-s, --smart', '智能同步模式(自动推荐)')
20
- .helpOption('-h, --help', '显示帮助信息');
13
+ .option('-r, --repo <url>', '模板仓库 URL')
14
+ .option('-b, --branch <name>', '分支名称')
15
+ .option('-v, --verbose', '详细输出')
16
+ .option('-i, --init', '初始化配置')
17
+ .option('--batch', '批量处理模式')
18
+ .option('-p, --preview', '预览差异')
19
+ .option('-s, --smart', '智能同步模式')
20
+ .helpOption('-h, --help', '显示帮助');
21
21
 
22
22
  program.addHelpText('after', `
23
23
 
24
24
  示例:
25
25
  $ syn # 交互式同步
26
26
  $ syn --init # 初始化配置
27
- $ syn --batch # 高级批量操作
28
- $ syn --preview # 预览所有差异
27
+ $ syn --batch # 批量处理模式
28
+ $ syn --preview # 预览差异
29
29
  $ syn --smart # 智能推荐模式
30
- $ syn --repo https://github.com/IceyWu/cloud-template.git
31
- $ syn --repo https://github.com/IceyWu/cloud-template.git --branch dev
32
- $ syn --repo git@github.com:your/template.git --verbose
30
+ $ syn -r https://github.com/user/template.git
31
+ $ syn -r https://github.com/user/template.git -b dev
33
32
 
34
33
  支持的仓库格式:
35
- GitHub: https://github.com/owner/repo.git
36
- • GitLab: https://gitlab.com/owner/repo.git
37
- • Bitbucket: https://bitbucket.org/owner/repo.git
34
+ HTTPS: https://github.com/owner/repo.git
38
35
  • SSH: git@github.com:owner/repo.git
39
36
 
40
- 分支支持:
41
- • 指定分支: --branch dev
42
- • 不指定分支时会列出所有分支供选择
43
- • 支持任意分支名称
44
-
45
37
  功能特性:
46
38
  ✅ 智能合并 package.json
47
- 支持 Vue/React/Angular 项目
48
- 文件差异对比
49
- ✅ 交互式确认更新
50
- ✅ Git 备份保护
51
- ✅ 配置文件保存
39
+ 跨平台支持 (Windows/macOS/Linux)
40
+ 自动文件分类
52
41
  ✅ 多分支支持
42
+ ✅ Git 备份保护
43
+ ✅ 可扩展的分类规则
53
44
 
54
45
  更多信息: https://github.com/IceyWu/template-syncer
55
46
  `);
56
47
 
57
- // 主要执行逻辑
58
48
  async function main() {
59
49
  try {
60
50
  program.parse();
61
- const options = program.opts(); // 显示启动信息
62
- if (options.verbose) {
63
- console.log('🔧 启动配置:');
64
- if (options.repo) {
65
- console.log(` 模板仓库: ${options.repo}`);
66
- }
67
- if (options.branch) {
68
- console.log(` 指定分支: ${options.branch}`);
69
- }
70
- console.log(` 详细模式: 已启用`);
71
- console.log('');
72
- } // 创建同步器实例
73
- const syncerOptions = {
74
- ...options,
75
- templateRepo: options.repo,
76
- branch: options.branch
77
- };
78
- const syncer = new TemplateSyncer(syncerOptions);
79
-
80
- if (options.init) {
81
- await syncer.initConfig(); } else if (options.batch) {
82
- // 高级批量操作模式
83
- try {
84
- await syncer.batchProcess();
85
- } finally {
86
- // 清理临时文件
87
- syncer.cleanup();
88
- }
89
- } else if (options.preview) {
90
- // 预览模式
91
- try {
92
- await syncer.getTemplateRepo();
93
- await syncer.cloneTemplate();
94
- const templateFiles = await syncer.scanTemplateFiles();
95
- const currentFiles = await syncer.scanCurrentFiles();
96
- const changedFiles = await syncer.compareFiles(templateFiles, currentFiles);
97
- await syncer.previewAllDifferences(changedFiles);
98
- } finally {
99
- // 清理临时文件
100
- syncer.cleanup();
101
- }
102
- } else if (options.smart) {
103
- // 智能同步模式
104
- try {
105
- await syncer.intelligentSync();
106
- } finally {
107
- // 清理临时文件
108
- syncer.cleanup();
109
- }
51
+ const opts = program.opts();
52
+
53
+ const syncer = new TemplateSyncer({
54
+ repo: opts.repo,
55
+ branch: opts.branch,
56
+ verbose: opts.verbose
57
+ });
58
+
59
+ if (opts.init) {
60
+ await syncer.init();
61
+ } else if (opts.batch) {
62
+ await syncer.batch();
63
+ } else if (opts.preview) {
64
+ await syncer.preview();
65
+ } else if (opts.smart) {
66
+ await syncer.smart();
110
67
  } else {
111
- // 默认交互式同步
112
68
  await syncer.sync();
113
69
  }
114
70
  } catch (error) {
115
- console.error('❌ 程序执行失败:', error.message);
71
+ console.error('❌ 执行失败:', error.message);
116
72
  if (program.opts().verbose) {
117
73
  console.error(error.stack);
118
74
  }
@@ -120,16 +76,14 @@ async function main() {
120
76
  }
121
77
  }
122
78
 
123
- // 处理未捕获的异常
124
79
  process.on('uncaughtException', (error) => {
125
80
  console.error('💥 未捕获的异常:', error.message);
126
81
  process.exit(1);
127
82
  });
128
83
 
129
- process.on('unhandledRejection', (reason, promise) => {
84
+ process.on('unhandledRejection', (reason) => {
130
85
  console.error('💥 未处理的 Promise 拒绝:', reason);
131
86
  process.exit(1);
132
87
  });
133
88
 
134
- // 启动程序
135
89
  main();
package/lib/index.d.ts CHANGED
@@ -1,117 +1,5 @@
1
- import { FileConfig, TemplateSyncerOptions, BatchResults } from './types';
2
- /**
3
- * 智能模板同步工具
4
- * 用于将项目与模板仓库保持同步
5
- */
6
- export declare class TemplateSyncer {
7
- private tempDir;
8
- private templateRepo;
9
- private branch;
10
- private configFile;
11
- private changes;
12
- private verbose;
13
- private ignorePatterns;
14
- private fileTypeConfig;
15
- private specialFiles;
16
- constructor(options?: TemplateSyncerOptions);
17
- /**
18
- * 创建 Git 备份
19
- */
20
- createBackup(): void;
21
- /**
22
- * 克隆模板仓库
23
- */
24
- cloneTemplate(): Promise<void>; /**
25
- * 获取或设置模板仓库
26
- */
27
- getTemplateRepo(): Promise<string>;
28
- /**
29
- * 测试仓库连接
30
- */
31
- testRepository(repo: string): Promise<boolean>;
32
- /**
33
- * 扫描模板文件
34
- */
35
- scanTemplateFiles(): Promise<FileConfig[]>;
36
- /**
37
- * 扫描当前项目文件
38
- */
39
- scanCurrentFiles(): Promise<FileConfig[]>;
40
- /**
41
- * 分析文件类型和特征
42
- */
43
- private analyzeFile;
44
- /**
45
- * 对比文件并生成变更列表
46
- */
47
- compareFiles(templateFiles: FileConfig[], currentFiles: FileConfig[]): Promise<FileConfig[]>;
48
- /**
49
- * 交互式选择要应用的变更
50
- */
51
- selectChangesToApply(changes: FileConfig[]): Promise<FileConfig[]>;
52
- /**
53
- * 按分类选择文件
54
- */
55
- private selectByCategory;
56
- /**
57
- * 逐一选择文件
58
- */
59
- private selectIndividually;
60
- /**
61
- * 批量更新文件
62
- */
63
- batchUpdateFiles(files: FileConfig[]): Promise<BatchResults>;
64
- /**
65
- * 更新单个文件
66
- */
67
- private updateSingleFile;
68
- /**
69
- * 智能合并 package.json
70
- */
71
- private mergePackageJson;
72
- /**
73
- * 显示操作摘要
74
- */
75
- showSummary(results: BatchResults): void;
76
- /**
77
- * 清理临时文件
78
- */
79
- cleanup(): void;
80
- /**
81
- * 加载配置文件
82
- */
83
- private loadConfig;
84
- /**
85
- * 保存配置文件
86
- */
87
- private saveConfig;
88
- /**
89
- * 主同步流程
90
- */
91
- sync(options?: TemplateSyncerOptions): Promise<void>;
92
- /**
93
- * 初始化配置向导
94
- */
95
- initConfig(): Promise<void>;
96
- /**
97
- * 批量处理模式
98
- */
99
- batchProcess(): Promise<void>;
100
- /**
101
- * 生成智能推荐
102
- */
103
- private generateRecommendations;
104
- /**
105
- * 预览所有差异
106
- */
107
- previewAllDifferences(files: FileConfig[]): Promise<void>;
108
- /**
109
- * 智能同步模式
110
- */
111
- intelligentSync(): Promise<void>;
112
- /**
113
- * 选择分支
114
- */
115
- private selectBranch;
116
- }
1
+ export { TemplateSyncer } from './syncer';
2
+ export type { FileInfo, FileChange, SyncerOptions, SyncConfig, SyncRules, CategoryRule, MergeStrategy, BatchResult, Recommendation } from './types';
3
+ export { platform, Categorizer, Merger, Git, Scanner } from './utils';
4
+ export { prompts, logger } from './ui';
117
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAMA,OAAO,EACL,UAAU,EAEV,qBAAqB,EAGrB,YAAY,EAGb,MAAM,SAAS,CAAC;AAEjB;;;GAGG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,YAAY,CAAqB;IACzC,OAAO,CAAC,MAAM,CAAqB;IACnC,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,OAAO,CAAW;IAC1B,OAAO,CAAC,OAAO,CAAU;IACzB,OAAO,CAAC,cAAc,CAAW;IACjC,OAAO,CAAC,cAAc,CAAiC;IACvD,OAAO,CAAC,YAAY,CAAiC;gBACzC,OAAO,GAAE,qBAA0B;IAyK/C;;OAEG;IACH,YAAY,IAAI,IAAI;IAWpB;;OAEG;IACG,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,EA0CjC;;OAEA;IACG,eAAe,IAAI,OAAO,CAAC,MAAM,CAAC;IAqCxC;;OAEG;IACG,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAYpD;;OAEG;IACG,iBAAiB,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;IAgChD;;OAEG;IACG,gBAAgB,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;IA8B/C;;OAEG;IACH,OAAO,CAAC,WAAW;IAyCnB;;OAEG;IACG,YAAY,CAAC,aAAa,EAAE,UAAU,EAAE,EAAE,YAAY,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAsClG;;OAEG;IACG,oBAAoB,CAAC,OAAO,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAuDxE;;OAEG;YACW,gBAAgB;IAqB9B;;OAEG;YACW,kBAAkB;IAoBhC;;OAEG;IACG,gBAAgB,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,YAAY,CAAC;IAgClE;;OAEG;YACW,gBAAgB;IAyB9B;;OAEG;YACW,gBAAgB;IAuC9B;;OAEG;IACH,WAAW,CAAC,OAAO,EAAE,YAAY,GAAG,IAAI;IAuBxC;;OAEG;IACH,OAAO,IAAI,IAAI;IAWf;;OAEG;IACH,OAAO,CAAC,UAAU;IAWlB;;OAEG;IACH,OAAO,CAAC,UAAU;IAQlB;;OAEG;IACG,IAAI,CAAC,OAAO,GAAE,qBAA0B,GAAG,OAAO,CAAC,IAAI,CAAC;IAqE9D;;OAEG;IACG,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IA2DjC;;OAEG;IACG,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAgEnC;;OAEG;YACW,uBAAuB;IA6DrC;;OAEG;IACG,qBAAqB,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAkC/D;;OAEG;IACG,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IA0DtC;;OAEG;YACW,YAAY;CAyD3B"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAG1C,YAAY,EACV,QAAQ,EACR,UAAU,EACV,aAAa,EACb,UAAU,EACV,SAAS,EACT,YAAY,EACZ,aAAa,EACb,WAAW,EACX,cAAc,EACf,MAAM,SAAS,CAAC;AAGjB,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AACtE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC"}