@wener/common 2.0.1 → 2.0.3
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/lib/ai/qwen3vl/index.js +2 -0
- package/lib/ai/qwen3vl/index.js.map +1 -0
- package/lib/ai/qwen3vl/utils.js +31 -0
- package/lib/ai/qwen3vl/utils.js.map +1 -0
- package/lib/ai/vision/DocLayoutElementTypeSchema.js +28 -0
- package/lib/ai/vision/DocLayoutElementTypeSchema.js.map +1 -0
- package/lib/ai/vision/ImageAnnotationSchema.js +50 -0
- package/lib/ai/vision/ImageAnnotationSchema.js.map +1 -0
- package/lib/ai/vision/index.js +3 -0
- package/lib/ai/vision/index.js.map +1 -0
- package/lib/ai/vision/resolveImageAnnotation.js +105 -0
- package/lib/ai/vision/resolveImageAnnotation.js.map +1 -0
- package/lib/cn/ChineseResidentIdNo.js +48 -0
- package/lib/cn/ChineseResidentIdNo.js.map +1 -0
- package/lib/cn/ChineseResidentIdNo.mod.js +1 -0
- package/lib/cn/{ResidentIdentityCardNumber.test.js → ChineseResidentIdNo.test.js} +7 -6
- package/lib/cn/DivisionCode.js +217 -301
- package/lib/cn/DivisionCode.js.map +1 -0
- package/lib/cn/DivisionCode.mod.js +1 -0
- package/lib/cn/DivisionCode.test.js +9 -15
- package/lib/cn/Mod11.js +43 -0
- package/lib/cn/Mod11.js.map +1 -0
- package/lib/cn/Mod31.js +49 -0
- package/lib/cn/Mod31.js.map +1 -0
- package/lib/cn/UnifiedSocialCreditCode.js +137 -113
- package/lib/cn/UnifiedSocialCreditCode.js.map +1 -0
- package/lib/cn/UnifiedSocialCreditCode.mod.js +1 -0
- package/lib/cn/UnifiedSocialCreditCode.test.js +1 -1
- package/lib/cn/formatChineseAmount.js +77 -0
- package/lib/cn/formatChineseAmount.js.map +1 -0
- package/lib/cn/index.js +6 -2
- package/lib/cn/index.js.map +1 -0
- package/lib/cn/mod.js +6 -0
- package/lib/cn/parseChineseNumber.js +94 -0
- package/lib/cn/parseChineseNumber.js.map +1 -0
- package/lib/cn/parseChineseNumber.test.js +278 -0
- package/lib/cn/pinyin/cartesianProduct.js +22 -0
- package/lib/cn/pinyin/cartesianProduct.js.map +1 -0
- package/lib/cn/pinyin/cartesianProduct.test.js +179 -0
- package/lib/cn/pinyin/data.json +23573 -0
- package/lib/cn/pinyin/loader.js +14 -0
- package/lib/cn/pinyin/loader.js.map +1 -0
- package/lib/cn/pinyin/preload.js +3 -0
- package/lib/cn/pinyin/preload.js.map +1 -0
- package/lib/cn/pinyin/toPinyin.test.js +167 -0
- package/lib/cn/pinyin/toPinyinPure.js +33 -0
- package/lib/cn/pinyin/toPinyinPure.js.map +1 -0
- package/lib/cn/pinyin/transform.js +14 -0
- package/lib/cn/pinyin/transform.js.map +1 -0
- package/lib/cn/types.d.js +2 -0
- package/lib/cn/types.d.js.map +1 -0
- package/lib/consola/createStandardConsolaReporter.js +6 -6
- package/lib/consola/createStandardConsolaReporter.js.map +1 -0
- package/lib/consola/formatLogObject.js +67 -135
- package/lib/consola/formatLogObject.js.map +1 -0
- package/lib/consola/formatLogObject.test.js +184 -0
- package/lib/consola/index.js +1 -0
- package/lib/consola/index.js.map +1 -0
- package/lib/data/formatSort.js +6 -5
- package/lib/data/formatSort.js.map +1 -0
- package/lib/data/index.js +1 -0
- package/lib/data/index.js.map +1 -0
- package/lib/data/maybeNumber.js +5 -7
- package/lib/data/maybeNumber.js.map +1 -0
- package/lib/data/parseSort.js +22 -28
- package/lib/data/parseSort.js.map +1 -0
- package/lib/data/resolvePagination.js +13 -17
- package/lib/data/resolvePagination.js.map +1 -0
- package/lib/data/types.d.js +2 -0
- package/lib/data/types.d.js.map +1 -0
- package/lib/dayjs/dayjs.js +40 -0
- package/lib/dayjs/dayjs.js.map +1 -0
- package/lib/dayjs/formatDuration.js +59 -0
- package/lib/dayjs/formatDuration.js.map +1 -0
- package/lib/dayjs/formatDuration.test.js +90 -0
- package/lib/dayjs/index.js +5 -0
- package/lib/dayjs/index.js.map +1 -0
- package/lib/dayjs/parseDuration.js +29 -0
- package/lib/dayjs/parseDuration.js.map +1 -0
- package/lib/dayjs/parseRelativeTime.js +90 -0
- package/lib/dayjs/parseRelativeTime.js.map +1 -0
- package/lib/dayjs/parseRelativeTime.test.js +247 -0
- package/lib/dayjs/resolveRelativeTime.js +158 -0
- package/lib/dayjs/resolveRelativeTime.js.map +1 -0
- package/lib/dayjs/resolveRelativeTime.test.js +310 -0
- package/lib/decimal/index.js +2 -0
- package/lib/decimal/index.js.map +1 -0
- package/lib/decimal/parseDecimal.js +15 -0
- package/lib/decimal/parseDecimal.js.map +1 -0
- package/lib/emittery/emitter.js +10 -0
- package/lib/emittery/emitter.js.map +1 -0
- package/lib/emittery/index.js +2 -0
- package/lib/emittery/index.js.map +1 -0
- package/lib/foundation/schema/SexType.js +16 -0
- package/lib/foundation/schema/SexType.js.map +1 -0
- package/lib/foundation/schema/index.js +2 -0
- package/lib/foundation/schema/index.js.map +1 -0
- package/lib/foundation/schema/parseSexType.js +19 -0
- package/lib/foundation/schema/parseSexType.js.map +1 -0
- package/lib/foundation/schema/types.js +7 -0
- package/lib/foundation/schema/types.js.map +1 -0
- package/lib/fs/FileSystemError.js +23 -0
- package/lib/fs/FileSystemError.js.map +1 -0
- package/lib/fs/IFileSystem.d.js +3 -0
- package/lib/fs/IFileSystem.d.js.map +1 -0
- package/lib/fs/MemoryFileSystem.test.js +188 -0
- package/lib/fs/createBrowserFileSystem.js +248 -0
- package/lib/fs/createBrowserFileSystem.js.map +1 -0
- package/lib/fs/createMemoryFileSystem.js +516 -0
- package/lib/fs/createMemoryFileSystem.js.map +1 -0
- package/lib/fs/createSandboxFileSystem.js +108 -0
- package/lib/fs/createSandboxFileSystem.js.map +1 -0
- package/lib/fs/createWebDavFileSystem.js +137 -0
- package/lib/fs/createWebDavFileSystem.js.map +1 -0
- package/lib/fs/findMimeType.js +17 -0
- package/lib/fs/findMimeType.js.map +1 -0
- package/lib/fs/index.js +8 -0
- package/lib/fs/index.js.map +1 -0
- package/lib/fs/orpc/FileSystemContract.js +93 -0
- package/lib/fs/orpc/FileSystemContract.js.map +1 -0
- package/lib/fs/orpc/createContractClientFileSystem.js +93 -0
- package/lib/fs/orpc/createContractClientFileSystem.js.map +1 -0
- package/lib/fs/orpc/index.js +3 -0
- package/lib/fs/orpc/index.js.map +1 -0
- package/lib/fs/orpc/server/createFileSystemContractImpl.js +63 -0
- package/lib/fs/orpc/server/createFileSystemContractImpl.js.map +1 -0
- package/lib/fs/orpc/server/index.js +2 -0
- package/lib/fs/orpc/server/index.js.map +1 -0
- package/lib/fs/s3/createS3MiniFileSystem.js +705 -0
- package/lib/fs/s3/createS3MiniFileSystem.js.map +1 -0
- package/lib/fs/s3/index.js +2 -0
- package/lib/fs/s3/index.js.map +1 -0
- package/lib/fs/s3/s3mini.test.js +584 -0
- package/lib/fs/scandir.js +59 -0
- package/lib/fs/scandir.js.map +1 -0
- package/lib/fs/server/createDatabaseFileSystem.js +750 -0
- package/lib/fs/server/createDatabaseFileSystem.js.map +1 -0
- package/lib/fs/server/createNodeFileSystem.js +401 -0
- package/lib/fs/server/createNodeFileSystem.js.map +1 -0
- package/lib/fs/server/dbfs.test.js +221 -0
- package/lib/fs/server/index.js +2 -0
- package/lib/fs/server/index.js.map +1 -0
- package/lib/fs/server/loadTestDatabase.js +127 -0
- package/lib/fs/server/loadTestDatabase.js.map +1 -0
- package/lib/fs/tests/runFileSystemTest.js +318 -0
- package/lib/fs/tests/runFileSystemTest.js.map +1 -0
- package/lib/fs/types.js +27 -0
- package/lib/fs/types.js.map +1 -0
- package/lib/fs/utils/getFileUrl.js +35 -0
- package/lib/fs/utils/getFileUrl.js.map +1 -0
- package/lib/fs/utils.js +22 -0
- package/lib/fs/utils.js.map +1 -0
- package/lib/index.js +1 -0
- package/lib/index.js.map +1 -0
- package/lib/jsonschema/JsonSchema.js +146 -172
- package/lib/jsonschema/JsonSchema.js.map +1 -0
- package/lib/jsonschema/forEachJsonSchema.js +44 -0
- package/lib/jsonschema/forEachJsonSchema.js.map +1 -0
- package/lib/jsonschema/index.js +2 -0
- package/lib/jsonschema/index.js.map +1 -0
- package/lib/jsonschema/types.d.js +2 -0
- package/lib/jsonschema/types.d.js.map +1 -0
- package/lib/meta/defineFileType.js +20 -103
- package/lib/meta/defineFileType.js.map +1 -0
- package/lib/meta/defineInit.js +31 -250
- package/lib/meta/defineInit.js.map +1 -0
- package/lib/meta/defineMetadata.js +24 -140
- package/lib/meta/defineMetadata.js.map +1 -0
- package/lib/meta/index.js +1 -0
- package/lib/meta/index.js.map +1 -0
- package/lib/orpc/createOpenApiContractClient.js +27 -0
- package/lib/orpc/createOpenApiContractClient.js.map +1 -0
- package/lib/orpc/createRpcContractClient.js +34 -0
- package/lib/orpc/createRpcContractClient.js.map +1 -0
- package/lib/orpc/index.js +3 -0
- package/lib/orpc/index.js.map +1 -0
- package/lib/orpc/resolveLinkPlugins.js +28 -0
- package/lib/orpc/resolveLinkPlugins.js.map +1 -0
- package/lib/password/PHC.js +63 -87
- package/lib/password/PHC.js.map +1 -0
- package/lib/password/PHC.test.js +11 -3
- package/lib/password/Password.js +30 -292
- package/lib/password/Password.js.map +1 -0
- package/lib/password/Password.test.js +35 -22
- package/lib/password/createArgon2PasswordAlgorithm.js +35 -191
- package/lib/password/createArgon2PasswordAlgorithm.js.map +1 -0
- package/lib/password/createBase64PasswordAlgorithm.js +8 -141
- package/lib/password/createBase64PasswordAlgorithm.js.map +1 -0
- package/lib/password/createBcryptPasswordAlgorithm.js +13 -168
- package/lib/password/createBcryptPasswordAlgorithm.js.map +1 -0
- package/lib/password/createPBKDF2PasswordAlgorithm.js +46 -228
- package/lib/password/createPBKDF2PasswordAlgorithm.js.map +1 -0
- package/lib/password/createScryptPasswordAlgorithm.js +55 -211
- package/lib/password/createScryptPasswordAlgorithm.js.map +1 -0
- package/lib/password/index.js +1 -0
- package/lib/password/index.js.map +1 -0
- package/lib/password/server/index.js +1 -0
- package/lib/password/server/index.js.map +1 -0
- package/lib/resource/Identifiable.js +2 -0
- package/lib/resource/Identifiable.js.map +1 -0
- package/lib/resource/ListQuery.js +47 -0
- package/lib/resource/ListQuery.js.map +1 -0
- package/lib/resource/getTitleOfResource.js +3 -5
- package/lib/resource/getTitleOfResource.js.map +1 -0
- package/lib/resource/index.js +2 -0
- package/lib/resource/index.js.map +1 -0
- package/lib/resource/schema/AnyResourceSchema.js +3 -2
- package/lib/resource/schema/AnyResourceSchema.js.map +1 -0
- package/lib/resource/schema/BaseResourceSchema.js +2 -1
- package/lib/resource/schema/BaseResourceSchema.js.map +1 -0
- package/lib/resource/schema/ResourceActionType.js +6 -4
- package/lib/resource/schema/ResourceActionType.js.map +1 -0
- package/lib/resource/schema/ResourceStatus.js +5 -3
- package/lib/resource/schema/ResourceStatus.js.map +1 -0
- package/lib/resource/schema/ResourceType.js +5 -3
- package/lib/resource/schema/ResourceType.js.map +1 -0
- package/lib/resource/schema/index.js +6 -0
- package/lib/resource/schema/index.js.map +1 -0
- package/lib/resource/schema/types.js +16 -20
- package/lib/resource/schema/types.js.map +1 -0
- package/lib/s3/formatS3Url.js +65 -0
- package/lib/s3/formatS3Url.js.map +1 -0
- package/lib/s3/formatS3Url.test.js +262 -0
- package/lib/s3/index.js +3 -0
- package/lib/s3/index.js.map +1 -0
- package/lib/s3/parseS3Url.js +65 -0
- package/lib/s3/parseS3Url.js.map +1 -0
- package/lib/s3/parseS3Url.test.js +270 -0
- package/lib/schema/SchemaRegistry.js +45 -0
- package/lib/schema/SchemaRegistry.js.map +1 -0
- package/lib/schema/SchemaRegistry.mod.js +2 -0
- package/lib/schema/TypeSchema.d.js +2 -0
- package/lib/schema/TypeSchema.d.js.map +1 -0
- package/lib/schema/createSchemaData.js +26 -125
- package/lib/schema/createSchemaData.js.map +1 -0
- package/lib/schema/findJsonSchemaByPath.js +13 -36
- package/lib/schema/findJsonSchemaByPath.js.map +1 -0
- package/lib/schema/formatZodError.js +140 -0
- package/lib/schema/formatZodError.js.map +1 -0
- package/lib/schema/formatZodError.test.js +196 -0
- package/lib/schema/getSchemaCache.js +5 -5
- package/lib/schema/getSchemaCache.js.map +1 -0
- package/lib/schema/getSchemaOptions.js +8 -11
- package/lib/schema/getSchemaOptions.js.map +1 -0
- package/lib/schema/index.js +2 -0
- package/lib/schema/index.js.map +1 -0
- package/lib/schema/toJsonSchema.js +47 -290
- package/lib/schema/toJsonSchema.js.map +1 -0
- package/lib/schema/validate.js +33 -45
- package/lib/schema/validate.js.map +1 -0
- package/lib/tools/generateSchema.js +39 -197
- package/lib/tools/generateSchema.js.map +1 -0
- package/lib/tools/renderJsonSchemaToMarkdownDoc.js +55 -143
- package/lib/tools/renderJsonSchemaToMarkdownDoc.js.map +1 -0
- package/lib/utils/buildBaseUrl.js +13 -0
- package/lib/utils/buildBaseUrl.js.map +1 -0
- package/lib/utils/buildRedactorFormSchema.js +59 -0
- package/lib/utils/buildRedactorFormSchema.js.map +1 -0
- package/lib/utils/getEstimateProcessTime.js +21 -0
- package/lib/utils/getEstimateProcessTime.js.map +1 -0
- package/lib/utils/index.js +4 -0
- package/lib/utils/index.js.map +1 -0
- package/lib/utils/resolveFeatureOptions.js +12 -0
- package/lib/utils/resolveFeatureOptions.js.map +1 -0
- package/package.json +77 -20
- package/src/ai/qwen3vl/index.ts +1 -0
- package/src/ai/qwen3vl/utils.ts +36 -0
- package/src/ai/vision/DocLayoutElementTypeSchema.ts +30 -0
- package/src/ai/vision/ImageAnnotationSchema.ts +60 -0
- package/src/ai/vision/index.ts +2 -0
- package/src/ai/vision/resolveImageAnnotation.ts +135 -0
- package/src/cn/ChineseResidentIdNo.test.ts +18 -0
- package/src/cn/ChineseResidentIdNo.ts +74 -0
- package/src/cn/DivisionCode.test.ts +3 -13
- package/src/cn/DivisionCode.ts +138 -193
- package/src/cn/{Mod11Checksum.ts → Mod11.ts} +3 -1
- package/src/cn/{Mod31Checksum.ts → Mod31.ts} +2 -0
- package/src/cn/UnifiedSocialCreditCode.test.ts +2 -2
- package/src/cn/UnifiedSocialCreditCode.ts +119 -124
- package/src/cn/__snapshots__/ChineseResidentIdNo.test.ts.snap +14 -0
- package/src/cn/__snapshots__/UnifiedSocialCreditCode.test.ts.snap +41 -12
- package/src/cn/formatChineseAmount.ts +61 -0
- package/src/cn/index.ts +6 -2
- package/src/cn/parseChineseNumber.test.ts +159 -0
- package/src/cn/parseChineseNumber.ts +97 -0
- package/src/cn/pinyin/cartesianProduct.test.ts +64 -0
- package/src/cn/pinyin/cartesianProduct.ts +24 -0
- package/src/cn/pinyin/data.json +23573 -0
- package/src/cn/pinyin/loader.ts +12 -0
- package/src/cn/pinyin/preload.ts +3 -0
- package/src/cn/pinyin/toPinyin.test.ts +12 -0
- package/src/cn/pinyin/toPinyinPure.ts +43 -0
- package/src/cn/pinyin/transform.ts +12 -0
- package/src/consola/formatLogObject.test.ts +27 -0
- package/src/consola/formatLogObject.ts +46 -10
- package/src/dayjs/dayjs.ts +40 -0
- package/src/dayjs/formatDuration.test.ts +14 -0
- package/src/dayjs/formatDuration.ts +86 -0
- package/src/dayjs/index.ts +5 -0
- package/src/dayjs/parseDuration.ts +40 -0
- package/src/dayjs/parseRelativeTime.test.ts +185 -0
- package/src/dayjs/parseRelativeTime.ts +115 -0
- package/src/dayjs/resolveRelativeTime.test.ts +357 -0
- package/src/dayjs/resolveRelativeTime.ts +167 -0
- package/src/decimal/index.ts +1 -0
- package/src/decimal/parseDecimal.ts +16 -0
- package/src/emittery/emitter.ts +9 -0
- package/src/emittery/index.ts +1 -0
- package/src/foundation/schema/SexType.ts +21 -0
- package/src/foundation/schema/index.ts +1 -0
- package/src/foundation/schema/parseSexType.ts +19 -0
- package/src/foundation/schema/types.ts +8 -0
- package/src/fs/FileSystemError.ts +26 -0
- package/src/fs/IFileSystem.d.ts +102 -0
- package/src/fs/MemoryFileSystem.test.ts +37 -0
- package/src/fs/createBrowserFileSystem.ts +291 -0
- package/src/fs/createMemoryFileSystem.ts +604 -0
- package/src/fs/createSandboxFileSystem.ts +136 -0
- package/src/fs/createWebDavFileSystem.ts +172 -0
- package/src/fs/findMimeType.ts +23 -0
- package/src/fs/index.ts +8 -0
- package/src/fs/orpc/FileSystemContract.ts +92 -0
- package/src/fs/orpc/createContractClientFileSystem.ts +115 -0
- package/src/fs/orpc/index.ts +2 -0
- package/src/fs/orpc/server/createFileSystemContractImpl.ts +64 -0
- package/src/fs/orpc/server/index.ts +1 -0
- package/src/fs/s3/createS3MiniFileSystem.ts +830 -0
- package/src/fs/s3/index.ts +1 -0
- package/src/fs/s3/s3mini.test.ts +264 -0
- package/src/fs/scandir.ts +75 -0
- package/src/fs/server/createDatabaseFileSystem.ts +668 -0
- package/src/fs/server/createNodeFileSystem.ts +499 -0
- package/src/fs/server/dbfs.test.ts +47 -0
- package/src/fs/server/index.ts +1 -0
- package/src/fs/server/loadTestDatabase.ts +131 -0
- package/src/fs/tests/runFileSystemTest.ts +288 -0
- package/src/fs/types.ts +29 -0
- package/src/fs/utils/getFileUrl.ts +44 -0
- package/src/fs/utils.ts +23 -0
- package/src/jsonschema/JsonSchema.ts +118 -110
- package/src/jsonschema/forEachJsonSchema.ts +50 -0
- package/src/jsonschema/index.ts +1 -0
- package/src/orpc/createOpenApiContractClient.ts +52 -0
- package/src/orpc/createRpcContractClient.ts +50 -0
- package/src/orpc/index.ts +2 -0
- package/src/orpc/resolveLinkPlugins.ts +29 -0
- package/src/password/PHC.ts +3 -3
- package/src/password/Password.test.ts +1 -1
- package/src/password/Password.ts +2 -2
- package/src/password/createPBKDF2PasswordAlgorithm.ts +2 -2
- package/src/resource/ListQuery.ts +53 -0
- package/src/resource/index.ts +1 -0
- package/src/resource/schema/AnyResourceSchema.ts +17 -3
- package/src/resource/schema/index.ts +5 -0
- package/src/s3/formatS3Url.test.ts +254 -0
- package/src/s3/formatS3Url.ts +84 -0
- package/src/s3/index.ts +2 -0
- package/src/s3/parseS3Url.test.ts +258 -0
- package/src/s3/parseS3Url.ts +88 -0
- package/src/schema/SchemaRegistry.ts +48 -0
- package/src/schema/createSchemaData.ts +1 -1
- package/src/schema/formatZodError.test.ts +196 -0
- package/src/schema/formatZodError.ts +151 -0
- package/src/schema/getSchemaOptions.ts +3 -3
- package/src/schema/index.ts +1 -0
- package/src/utils/buildBaseUrl.ts +12 -0
- package/src/utils/buildRedactorFormSchema.ts +85 -0
- package/src/utils/getEstimateProcessTime.ts +36 -0
- package/src/utils/index.ts +5 -0
- package/src/utils/resolveFeatureOptions.ts +14 -0
- package/lib/cn/Mod11Checksum.js +0 -85
- package/lib/cn/Mod31Checksum.js +0 -97
- package/lib/cn/ResidentIdentityCardNumber.js +0 -50
- package/lib/cn/formatDate.js +0 -13
- package/lib/cn/parseSex.js +0 -20
- package/lib/resource/schema/SchemaRegistry.js +0 -38
- package/lib/resource/schema/SexType.js +0 -10
- package/lib/search/AdvanceSearch.js +0 -9
- package/lib/search/AdvanceSearch.test.js +0 -435
- package/lib/search/formatAdvanceSearch.js +0 -78
- package/lib/search/index.js +0 -1
- package/lib/search/optimizeAdvanceSearch.js +0 -143
- package/lib/search/parseAdvanceSearch.js +0 -20
- package/lib/search/parser.d.js +0 -1
- package/lib/search/parser.js +0 -3088
- package/lib/search/types.d.js +0 -1
- package/src/cn/ResidentIdentityCardNumber.test.ts +0 -17
- package/src/cn/ResidentIdentityCardNumber.ts +0 -96
- package/src/cn/__snapshots__/ResidentIdentityCardNumber.test.ts.snap +0 -15
- package/src/cn/formatDate.ts +0 -12
- package/src/cn/parseSex.ts +0 -13
- package/src/resource/schema/SchemaRegistry.ts +0 -42
- package/src/resource/schema/SexType.ts +0 -13
- package/src/search/AdvanceSearch.test.ts +0 -149
- package/src/search/AdvanceSearch.ts +0 -14
- package/src/search/Makefile +0 -2
- package/src/search/__snapshots__/AdvanceSearch.test.ts.snap +0 -675
- package/src/search/formatAdvanceSearch.ts +0 -52
- package/src/search/index.ts +0 -1
- package/src/search/optimizeAdvanceSearch.ts +0 -77
- package/src/search/parseAdvanceSearch.ts +0 -23
- package/src/search/parser.d.ts +0 -8
- package/src/search/parser.js +0 -2794
- package/src/search/parser.peggy +0 -237
- package/src/search/types.d.ts +0 -45
package/lib/search/types.d.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { };
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from 'vitest';
|
|
2
|
-
import { ResidentIdentityCardNumber } from './ResidentIdentityCardNumber';
|
|
3
|
-
|
|
4
|
-
describe('ResidentIdentityCardNumber', () => {
|
|
5
|
-
it('should parse', () => {
|
|
6
|
-
for (const a of ['11010519491231002X']) {
|
|
7
|
-
let out = ResidentIdentityCardNumber.parse(a);
|
|
8
|
-
expect(ResidentIdentityCardNumber.format(out)).toBe(a);
|
|
9
|
-
expect(out).toMatchSnapshot();
|
|
10
|
-
}
|
|
11
|
-
});
|
|
12
|
-
it('should format with partial', () => {
|
|
13
|
-
expect(
|
|
14
|
-
ResidentIdentityCardNumber.format({ division: '110105', birthDate: new Date('1949-12-31'), sequence: 2 }),
|
|
15
|
-
).toBe('11010519491231002X');
|
|
16
|
-
});
|
|
17
|
-
});
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
import { formatDate } from './formatDate';
|
|
2
|
-
import { Mod11Checksum } from './Mod11Checksum';
|
|
3
|
-
|
|
4
|
-
export namespace ResidentIdentityCardNumber {
|
|
5
|
-
export const Checksum = new Mod11Checksum();
|
|
6
|
-
|
|
7
|
-
/*
|
|
8
|
-
export const length = 18;
|
|
9
|
-
export const pattern = /^\d{6}(18|19|20)\d{2}(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])\d{3}[0-9Xx]$/;
|
|
10
|
-
*/
|
|
11
|
-
|
|
12
|
-
export function parse(s: string): ParsedResidentIdentityCardNumber {
|
|
13
|
-
const division = s.slice(0, 6);
|
|
14
|
-
const birthDate = s.slice(6, 14);
|
|
15
|
-
const sequence = parseInt(s.slice(14, 17), 10);
|
|
16
|
-
const checksum = s.slice(17, 18);
|
|
17
|
-
const valid = Checksum.validate(s);
|
|
18
|
-
const sex = sequence % 2 === 1 ? 'Male' : 'Female';
|
|
19
|
-
return {
|
|
20
|
-
division,
|
|
21
|
-
birthDate,
|
|
22
|
-
sequence,
|
|
23
|
-
checksum,
|
|
24
|
-
valid,
|
|
25
|
-
sex,
|
|
26
|
-
male: sex === 'Male',
|
|
27
|
-
female: sex === 'Female',
|
|
28
|
-
age: new Date().getFullYear() - parseInt(birthDate.slice(0, 4), 10),
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export function format({
|
|
33
|
-
division,
|
|
34
|
-
birthDate,
|
|
35
|
-
sequence,
|
|
36
|
-
checksum,
|
|
37
|
-
}: {
|
|
38
|
-
division: string;
|
|
39
|
-
birthDate: string | Date;
|
|
40
|
-
sequence: number | string;
|
|
41
|
-
checksum?: string;
|
|
42
|
-
}) {
|
|
43
|
-
if (typeof birthDate !== 'string') {
|
|
44
|
-
birthDate = formatDate(birthDate, 'yyyyMMDD');
|
|
45
|
-
}
|
|
46
|
-
if (birthDate.includes('-')) {
|
|
47
|
-
birthDate = birthDate.replace(/-/g, '');
|
|
48
|
-
}
|
|
49
|
-
typeof sequence === 'number' && (sequence = sequence.toString());
|
|
50
|
-
sequence = sequence.padStart(3, '0');
|
|
51
|
-
const base = [division, birthDate, sequence].join('');
|
|
52
|
-
if (base.length !== 17) throw new Error('Invalid params');
|
|
53
|
-
checksum ||= Checksum.compute(base);
|
|
54
|
-
return base + checksum;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
export interface ParsedResidentIdentityCardNumber {
|
|
58
|
-
/**
|
|
59
|
-
* @title 行政区划代码
|
|
60
|
-
*/
|
|
61
|
-
division: string;
|
|
62
|
-
/**
|
|
63
|
-
* @title 出生日期
|
|
64
|
-
* 格式 yyyyMMDD
|
|
65
|
-
*/
|
|
66
|
-
birthDate: string;
|
|
67
|
-
/**
|
|
68
|
-
* @title 顺序码
|
|
69
|
-
*/
|
|
70
|
-
sequence: number;
|
|
71
|
-
/**
|
|
72
|
-
* @title 校验位
|
|
73
|
-
*/
|
|
74
|
-
checksum: string;
|
|
75
|
-
|
|
76
|
-
/**
|
|
77
|
-
* @title 是否有效
|
|
78
|
-
*/
|
|
79
|
-
valid: boolean;
|
|
80
|
-
/**
|
|
81
|
-
* @title 是否男性
|
|
82
|
-
*/
|
|
83
|
-
male: boolean;
|
|
84
|
-
/**
|
|
85
|
-
* @title 是否女性
|
|
86
|
-
*/
|
|
87
|
-
female: boolean;
|
|
88
|
-
/**
|
|
89
|
-
* @title 性别
|
|
90
|
-
*/
|
|
91
|
-
sex: 'Male' | 'Female';
|
|
92
|
-
/**
|
|
93
|
-
* @title 年龄
|
|
94
|
-
*/
|
|
95
|
-
age: number;
|
|
96
|
-
}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
|
2
|
-
|
|
3
|
-
exports[`ResidentIdentityCardNumber > should parse 1`] = `
|
|
4
|
-
{
|
|
5
|
-
"age": 76,
|
|
6
|
-
"birthDate": "19491231",
|
|
7
|
-
"checksum": "X",
|
|
8
|
-
"division": "110105",
|
|
9
|
-
"female": true,
|
|
10
|
-
"male": false,
|
|
11
|
-
"sequence": 2,
|
|
12
|
-
"sex": "Female",
|
|
13
|
-
"valid": true,
|
|
14
|
-
}
|
|
15
|
-
`;
|
package/src/cn/formatDate.ts
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
export function formatDate(date: Date, format: 'yyyyMMDD') {
|
|
2
|
-
switch (format) {
|
|
3
|
-
case 'yyyyMMDD': {
|
|
4
|
-
const year = date.getFullYear();
|
|
5
|
-
const month = (date.getMonth() + 1).toString().padStart(2, '0');
|
|
6
|
-
const day = date.getDate().toString().padStart(2, '0');
|
|
7
|
-
return `${year}${month}${day}`;
|
|
8
|
-
}
|
|
9
|
-
default:
|
|
10
|
-
throw new Error(`Invalid format`);
|
|
11
|
-
}
|
|
12
|
-
}
|
package/src/cn/parseSex.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export function parseSex(s: string): undefined | { sex: 'Male' | 'Female'; male: boolean; female: boolean } {
|
|
2
|
-
if (!s) return undefined;
|
|
3
|
-
|
|
4
|
-
switch (s.toLowerCase()) {
|
|
5
|
-
case '男':
|
|
6
|
-
case 'male':
|
|
7
|
-
return { sex: 'Male', male: true, female: false };
|
|
8
|
-
case '女':
|
|
9
|
-
case 'female':
|
|
10
|
-
return { sex: 'Female', male: false, female: true };
|
|
11
|
-
}
|
|
12
|
-
return undefined;
|
|
13
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { getGlobalStates } from '@wener/utils';
|
|
2
|
-
import type { JsonSchemaDef } from '../../jsonschema';
|
|
3
|
-
import { toJsonSchema, type SchemaOutput, type TypeSchema } from '../../schema';
|
|
4
|
-
|
|
5
|
-
const types = getGlobalStates('@wener/common/resource/schema/SchemaRegistry', () => new Map<string, JsonSchemaDef>());
|
|
6
|
-
|
|
7
|
-
export function get(name: string): JsonSchemaDef;
|
|
8
|
-
export function get<S extends TypeSchema>(schema: S): JsonSchemaDef<SchemaOutput<S>>;
|
|
9
|
-
export function get(needle: TypeSchema | string) {
|
|
10
|
-
let key = getKey(needle);
|
|
11
|
-
let found = types.get(key);
|
|
12
|
-
if (found) {
|
|
13
|
-
return found;
|
|
14
|
-
} else {
|
|
15
|
-
if (typeof needle !== 'string') {
|
|
16
|
-
return toJsonSchema(needle);
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
throw new Error(`Schema not found: ${key}`);
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
function getKey(s: TypeSchema | string) {
|
|
23
|
-
let key;
|
|
24
|
-
if (typeof s === 'string') {
|
|
25
|
-
key = s;
|
|
26
|
-
} else {
|
|
27
|
-
let js = toJsonSchema(s);
|
|
28
|
-
key = js.$id || js.title;
|
|
29
|
-
}
|
|
30
|
-
if (!key) {
|
|
31
|
-
throw new Error(`Schema must have $id or title`);
|
|
32
|
-
}
|
|
33
|
-
return key;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
export function add(def: TypeSchema) {
|
|
37
|
-
types.set(getKey(def), toJsonSchema(def));
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
export function set(key: TypeSchema | string, def: TypeSchema) {
|
|
41
|
-
types.set(getKey(key), toJsonSchema(def));
|
|
42
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { z } from 'zod/v4';
|
|
2
|
-
import type { EnumValues } from './types';
|
|
3
|
-
|
|
4
|
-
export const SexType = Object.freeze({
|
|
5
|
-
__proto__: null,
|
|
6
|
-
Male: 'Male',
|
|
7
|
-
Female: 'Female',
|
|
8
|
-
// Intersex
|
|
9
|
-
} as const);
|
|
10
|
-
export type SexType = EnumValues<typeof SexType>;
|
|
11
|
-
export const SexTypeSchema = z
|
|
12
|
-
.union([z.literal(SexType.Male).describe('男'), z.literal(SexType.Female).describe('女')])
|
|
13
|
-
.describe('性别');
|
|
@@ -1,149 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from 'vitest';
|
|
2
|
-
import { AdvanceSearch } from './AdvanceSearch';
|
|
3
|
-
|
|
4
|
-
describe('AdvanceSearch', () => {
|
|
5
|
-
it('should parse', () => {
|
|
6
|
-
for (const input of [
|
|
7
|
-
//
|
|
8
|
-
'-a',
|
|
9
|
-
'a',
|
|
10
|
-
'a b',
|
|
11
|
-
'a -b',
|
|
12
|
-
'a-b',
|
|
13
|
-
'a"b',
|
|
14
|
-
'a&b',
|
|
15
|
-
'NOT a',
|
|
16
|
-
'NOT -a',
|
|
17
|
-
'HELLO -WORLD',
|
|
18
|
-
'(a)',
|
|
19
|
-
'( a OR B )',
|
|
20
|
-
'A OR B',
|
|
21
|
-
'a:[1,2]',
|
|
22
|
-
'a:*..1',
|
|
23
|
-
'a:ok a:=1 a:>1 a:<1 a:>=1 a:<=1 a:!=1 a:1..2 a:*..1 a:1..* a:[1,2] a:(1,2) a:[1,2) a:(1,2]',
|
|
24
|
-
'NOT (A B) AND (a:ok AND size:>1)',
|
|
25
|
-
'NOT -a',
|
|
26
|
-
'NOT (NOT -a)',
|
|
27
|
-
'owner:@me owner:=@me owner:!=@me',
|
|
28
|
-
'@AI:"Where is my car"',
|
|
29
|
-
'/**/ a',
|
|
30
|
-
'/* Hint */ a',
|
|
31
|
-
'/* a */ a /* b */',
|
|
32
|
-
]) {
|
|
33
|
-
let out = AdvanceSearch.parse(input);
|
|
34
|
-
let formated = AdvanceSearch.format(out);
|
|
35
|
-
expect(formated, `reformat`).toMatchSnapshot();
|
|
36
|
-
let optimized = AdvanceSearch.format(AdvanceSearch.optimize(out));
|
|
37
|
-
expect(optimized, `optimized`).toMatchSnapshot();
|
|
38
|
-
expect(out, `parsed`).toMatchSnapshot();
|
|
39
|
-
expect(AdvanceSearch.parse(formated), `reformat match original`).toMatchObject(out);
|
|
40
|
-
}
|
|
41
|
-
});
|
|
42
|
-
it('should parse as expected', () => {
|
|
43
|
-
type Case = [string | null | undefined, AdvanceSearch.Expr[]];
|
|
44
|
-
|
|
45
|
-
const cases: Case[] = [
|
|
46
|
-
[null, []],
|
|
47
|
-
[undefined, []],
|
|
48
|
-
['', []],
|
|
49
|
-
// fast path
|
|
50
|
-
['a', [{ type: 'keyword', value: 'a' }]],
|
|
51
|
-
['a-b', [{ type: 'keyword', value: 'a-b' }]],
|
|
52
|
-
['a"b', [{ type: 'keyword', value: 'a"b' }]],
|
|
53
|
-
[
|
|
54
|
-
'hello world',
|
|
55
|
-
[
|
|
56
|
-
{ type: 'keyword', value: 'hello' },
|
|
57
|
-
{ type: 'keyword', value: 'world' },
|
|
58
|
-
],
|
|
59
|
-
],
|
|
60
|
-
// advance
|
|
61
|
-
['-a', [{ type: 'keyword', value: 'a', negative: true }]],
|
|
62
|
-
[
|
|
63
|
-
'/*Hi*/ hello -world',
|
|
64
|
-
[
|
|
65
|
-
{ type: 'comment', value: 'Hi' },
|
|
66
|
-
{ type: 'keyword', value: 'hello', negative: false },
|
|
67
|
-
{ type: 'keyword', value: 'world', negative: true },
|
|
68
|
-
],
|
|
69
|
-
],
|
|
70
|
-
['"Hello"', [{ type: 'keyword', value: 'Hello', exact: true }]],
|
|
71
|
-
['-"Hello"', [{ type: 'keyword', value: 'Hello', exact: true, negative: true }]],
|
|
72
|
-
['is:ok', [{ type: 'compare', field: 'is', operator: 'match', value: { value: 'ok' } }]],
|
|
73
|
-
['-is:ok', [{ type: 'compare', field: 'is', negative: true, operator: 'match', value: { value: 'ok' } }]],
|
|
74
|
-
];
|
|
75
|
-
|
|
76
|
-
for (const [input, expected] of cases) {
|
|
77
|
-
let out = AdvanceSearch.parse(input);
|
|
78
|
-
expect(out).toMatchObject(expected);
|
|
79
|
-
expect(AdvanceSearch.parse(AdvanceSearch.format(out)), 'reformat should match').toMatchObject(expected);
|
|
80
|
-
}
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
it('should optimize simple', () => {
|
|
84
|
-
type Case = { input: AdvanceSearch.Expr[]; expected: AdvanceSearch.Expr[] };
|
|
85
|
-
const cases: Case[] = [
|
|
86
|
-
// rm empty comment
|
|
87
|
-
{
|
|
88
|
-
input: [
|
|
89
|
-
{ type: 'comment', value: '' },
|
|
90
|
-
{ type: 'keyword', value: 'a' },
|
|
91
|
-
],
|
|
92
|
-
expected: [{ type: 'keyword', value: 'a' }],
|
|
93
|
-
},
|
|
94
|
-
// unwrap parentheses
|
|
95
|
-
{
|
|
96
|
-
input: [
|
|
97
|
-
{ type: 'parentheses', value: [{ type: 'keyword', value: 'a' }] },
|
|
98
|
-
{ type: 'keyword', value: 'b' },
|
|
99
|
-
],
|
|
100
|
-
expected: [
|
|
101
|
-
{ type: 'keyword', value: 'a' },
|
|
102
|
-
{ type: 'keyword', value: 'b' },
|
|
103
|
-
],
|
|
104
|
-
},
|
|
105
|
-
// not not
|
|
106
|
-
{
|
|
107
|
-
input: [{ type: 'not', value: { type: 'not', value: { type: 'keyword', value: 'a' } } }],
|
|
108
|
-
expected: [{ type: 'keyword', value: 'a', negative: false }],
|
|
109
|
-
},
|
|
110
|
-
// not to negative
|
|
111
|
-
{
|
|
112
|
-
input: [{ type: 'not', value: { type: 'keyword', value: 'a' } }],
|
|
113
|
-
expected: [{ type: 'keyword', value: 'a', negative: true }],
|
|
114
|
-
},
|
|
115
|
-
];
|
|
116
|
-
|
|
117
|
-
for (let i = 0; i < cases.length; i++) {
|
|
118
|
-
const { input, expected } = cases[i];
|
|
119
|
-
let out = AdvanceSearch.optimize(input);
|
|
120
|
-
expect(out, `case #${i}`).toEqual(expected);
|
|
121
|
-
}
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
it('should optimize by formated', () => {
|
|
125
|
-
type Case = [string, string];
|
|
126
|
-
|
|
127
|
-
const cases: Case[] = [
|
|
128
|
-
['( a )', 'a'],
|
|
129
|
-
['NOT a', '-a'],
|
|
130
|
-
['NOT -a', 'a'],
|
|
131
|
-
['NOT is:ok', '-is:ok'],
|
|
132
|
-
['NOT -is:ok', 'is:ok'],
|
|
133
|
-
['NOT -is:=ok', 'is:=ok'],
|
|
134
|
-
['NOT is:=ok', 'is:!=ok'],
|
|
135
|
-
['NOT (NOT -a)', '-a'],
|
|
136
|
-
];
|
|
137
|
-
|
|
138
|
-
for (const [input, expected] of cases) {
|
|
139
|
-
let out = AdvanceSearch.optimize(AdvanceSearch.parse(input));
|
|
140
|
-
expect(AdvanceSearch.format(out), `${input} -> ${expected}: ${JSON.stringify(out)}`).toEqual(expected);
|
|
141
|
-
}
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
it.fails('should parse parentheses', () => {
|
|
145
|
-
let out = AdvanceSearch.parse('(a)');
|
|
146
|
-
console.log(out);
|
|
147
|
-
expect(out).toEqual([{ type: 'parentheses', value: [{ type: 'keyword', value: 'a' }] }]);
|
|
148
|
-
});
|
|
149
|
-
});
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { formatAdvanceSearch } from './formatAdvanceSearch';
|
|
2
|
-
import { optimizeAdvanceSearch } from './optimizeAdvanceSearch';
|
|
3
|
-
import { parseAdvanceSearch } from './parseAdvanceSearch';
|
|
4
|
-
import type * as types from './types';
|
|
5
|
-
|
|
6
|
-
export namespace AdvanceSearch {
|
|
7
|
-
export type Exprs = types.Exprs;
|
|
8
|
-
export type Expr = types.Expr;
|
|
9
|
-
export type Value = types.Value;
|
|
10
|
-
|
|
11
|
-
export const parse = parseAdvanceSearch;
|
|
12
|
-
export const format = formatAdvanceSearch;
|
|
13
|
-
export const optimize = optimizeAdvanceSearch;
|
|
14
|
-
}
|
package/src/search/Makefile
DELETED