mirror of https://github.com/certd/certd
🔱: [client] sync upgrade with 8 commits [trident-sync]
Merge remote-tracking branch 'origin/main' refactor: circle check refactor: circle check refactor: 1.11.8 refactor: upload demo test perf: 优化dict性能 refactor: debugpull/14/head
parent
b9dd4a35db
commit
e7628bdbdd
|
@ -0,0 +1,463 @@
|
||||||
|
/** @type {import('dependency-cruiser').IConfiguration} */
|
||||||
|
module.exports = {
|
||||||
|
forbidden: [
|
||||||
|
/* rules from the 'recommended' preset: */
|
||||||
|
{
|
||||||
|
name: 'no-circular',
|
||||||
|
severity: 'warn',
|
||||||
|
comment:
|
||||||
|
'This dependency is part of a circular relationship. You might want to revise ' +
|
||||||
|
'your solution (i.e. use dependency inversion, make sure the modules have a single responsibility) ',
|
||||||
|
from: {},
|
||||||
|
to: {
|
||||||
|
circular: true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'no-orphans',
|
||||||
|
comment:
|
||||||
|
"This is an orphan module - it's likely not used (anymore?). Either use it or " +
|
||||||
|
"remove it. If it's logical this module is an orphan (i.e. it's a config file), " +
|
||||||
|
"add an exception for it in your dependency-cruiser configuration. By default " +
|
||||||
|
"this rule does not scrutinize dot-files (e.g. .eslintrc.js), TypeScript declaration " +
|
||||||
|
"files (.d.ts), tsconfig.json and some of the babel and webpack configs.",
|
||||||
|
severity: 'warn',
|
||||||
|
from: {
|
||||||
|
orphan: true,
|
||||||
|
pathNot: [
|
||||||
|
'(^|/)\\.[^/]+\\.(js|cjs|mjs|ts|json)$', // dot files
|
||||||
|
'\\.d\\.ts$', // TypeScript declaration files
|
||||||
|
'(^|/)tsconfig\\.json$', // TypeScript config
|
||||||
|
'(^|/)(babel|webpack)\\.config\\.(js|cjs|mjs|ts|json)$' // other configs
|
||||||
|
]
|
||||||
|
},
|
||||||
|
to: {},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'no-deprecated-core',
|
||||||
|
comment:
|
||||||
|
'A module depends on a node core module that has been deprecated. Find an alternative - these are ' +
|
||||||
|
"bound to exist - node doesn't deprecate lightly.",
|
||||||
|
severity: 'warn',
|
||||||
|
from: {},
|
||||||
|
to: {
|
||||||
|
dependencyTypes: [
|
||||||
|
'core'
|
||||||
|
],
|
||||||
|
path: [
|
||||||
|
'^(v8\/tools\/codemap)$',
|
||||||
|
'^(v8\/tools\/consarray)$',
|
||||||
|
'^(v8\/tools\/csvparser)$',
|
||||||
|
'^(v8\/tools\/logreader)$',
|
||||||
|
'^(v8\/tools\/profile_view)$',
|
||||||
|
'^(v8\/tools\/profile)$',
|
||||||
|
'^(v8\/tools\/SourceMap)$',
|
||||||
|
'^(v8\/tools\/splaytree)$',
|
||||||
|
'^(v8\/tools\/tickprocessor-driver)$',
|
||||||
|
'^(v8\/tools\/tickprocessor)$',
|
||||||
|
'^(node-inspect\/lib\/_inspect)$',
|
||||||
|
'^(node-inspect\/lib\/internal\/inspect_client)$',
|
||||||
|
'^(node-inspect\/lib\/internal\/inspect_repl)$',
|
||||||
|
'^(async_hooks)$',
|
||||||
|
'^(punycode)$',
|
||||||
|
'^(domain)$',
|
||||||
|
'^(constants)$',
|
||||||
|
'^(sys)$',
|
||||||
|
'^(_linklist)$',
|
||||||
|
'^(_stream_wrap)$'
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'not-to-deprecated',
|
||||||
|
comment:
|
||||||
|
'This module uses a (version of an) npm module that has been deprecated. Either upgrade to a later ' +
|
||||||
|
'version of that module, or find an alternative. Deprecated modules are a security risk.',
|
||||||
|
severity: 'warn',
|
||||||
|
from: {},
|
||||||
|
to: {
|
||||||
|
dependencyTypes: [
|
||||||
|
'deprecated'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'no-non-package-json',
|
||||||
|
severity: 'error',
|
||||||
|
comment:
|
||||||
|
"This module depends on an npm package that isn't in the 'dependencies' section of your package.json. " +
|
||||||
|
"That's problematic as the package either (1) won't be available on live (2 - worse) will be " +
|
||||||
|
"available on live with an non-guaranteed version. Fix it by adding the package to the dependencies " +
|
||||||
|
"in your package.json.",
|
||||||
|
from: {},
|
||||||
|
to: {
|
||||||
|
dependencyTypes: [
|
||||||
|
'npm-no-pkg',
|
||||||
|
'npm-unknown'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'not-to-unresolvable',
|
||||||
|
comment:
|
||||||
|
"This module depends on a module that cannot be found ('resolved to disk'). If it's an npm " +
|
||||||
|
'module: add it to your package.json. In all other cases you likely already know what to do.',
|
||||||
|
severity: 'error',
|
||||||
|
from: {},
|
||||||
|
to: {
|
||||||
|
couldNotResolve: true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'no-duplicate-dep-types',
|
||||||
|
comment:
|
||||||
|
"Likely this module depends on an external ('npm') package that occurs more than once " +
|
||||||
|
"in your package.json i.e. bot as a devDependencies and in dependencies. This will cause " +
|
||||||
|
"maintenance problems later on.",
|
||||||
|
severity: 'warn',
|
||||||
|
from: {},
|
||||||
|
to: {
|
||||||
|
moreThanOneDependencyType: true,
|
||||||
|
// as it's pretty common to have a type import be a type only import
|
||||||
|
// _and_ (e.g.) a devDependency - don't consider type-only dependency
|
||||||
|
// types for this rule
|
||||||
|
dependencyTypesNot: ["type-only"]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
/* rules you might want to tweak for your specific situation: */
|
||||||
|
{
|
||||||
|
name: 'not-to-test',
|
||||||
|
comment:
|
||||||
|
"This module depends on code within a folder that should only contain tests. As tests don't " +
|
||||||
|
"implement functionality this is odd. Either you're writing a test outside the test folder " +
|
||||||
|
"or there's something in the test folder that isn't a test.",
|
||||||
|
severity: 'error',
|
||||||
|
from: {
|
||||||
|
pathNot: '^(tests)'
|
||||||
|
},
|
||||||
|
to: {
|
||||||
|
path: '^(tests)'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'not-to-spec',
|
||||||
|
comment:
|
||||||
|
'This module depends on a spec (test) file. The sole responsibility of a spec file is to test code. ' +
|
||||||
|
"If there's something in a spec that's of use to other modules, it doesn't have that single " +
|
||||||
|
'responsibility anymore. Factor it out into (e.g.) a separate utility/ helper or a mock.',
|
||||||
|
severity: 'error',
|
||||||
|
from: {},
|
||||||
|
to: {
|
||||||
|
path: '\\.(spec|test)\\.(js|mjs|cjs|ts|ls|coffee|litcoffee|coffee\\.md)$'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'not-to-dev-dep',
|
||||||
|
severity: 'error',
|
||||||
|
comment:
|
||||||
|
"This module depends on an npm package from the 'devDependencies' section of your " +
|
||||||
|
'package.json. It looks like something that ships to production, though. To prevent problems ' +
|
||||||
|
"with npm packages that aren't there on production declare it (only!) in the 'dependencies'" +
|
||||||
|
'section of your package.json. If this module is development only - add it to the ' +
|
||||||
|
'from.pathNot re of the not-to-dev-dep rule in the dependency-cruiser configuration',
|
||||||
|
from: {
|
||||||
|
path: '^(src)',
|
||||||
|
pathNot: '\\.(spec|test)\\.(js|mjs|cjs|ts|ls|coffee|litcoffee|coffee\\.md)$'
|
||||||
|
},
|
||||||
|
to: {
|
||||||
|
dependencyTypes: [
|
||||||
|
'npm-dev'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'optional-deps-used',
|
||||||
|
severity: 'info',
|
||||||
|
comment:
|
||||||
|
"This module depends on an npm package that is declared as an optional dependency " +
|
||||||
|
"in your package.json. As this makes sense in limited situations only, it's flagged here. " +
|
||||||
|
"If you're using an optional dependency here by design - add an exception to your" +
|
||||||
|
"dependency-cruiser configuration.",
|
||||||
|
from: {},
|
||||||
|
to: {
|
||||||
|
dependencyTypes: [
|
||||||
|
'npm-optional'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'peer-deps-used',
|
||||||
|
comment:
|
||||||
|
"This module depends on an npm package that is declared as a peer dependency " +
|
||||||
|
"in your package.json. This makes sense if your package is e.g. a plugin, but in " +
|
||||||
|
"other cases - maybe not so much. If the use of a peer dependency is intentional " +
|
||||||
|
"add an exception to your dependency-cruiser configuration.",
|
||||||
|
severity: 'warn',
|
||||||
|
from: {},
|
||||||
|
to: {
|
||||||
|
dependencyTypes: [
|
||||||
|
'npm-peer'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
options: {
|
||||||
|
|
||||||
|
/* conditions specifying which files not to follow further when encountered:
|
||||||
|
- path: a regular expression to match
|
||||||
|
- dependencyTypes: see https://github.com/sverweij/dependency-cruiser/blob/master/doc/rules-reference.md#dependencytypes-and-dependencytypesnot
|
||||||
|
for a complete list
|
||||||
|
*/
|
||||||
|
doNotFollow: {
|
||||||
|
path: 'node_modules'
|
||||||
|
},
|
||||||
|
|
||||||
|
/* conditions specifying which dependencies to exclude
|
||||||
|
- path: a regular expression to match
|
||||||
|
- dynamic: a boolean indicating whether to ignore dynamic (true) or static (false) dependencies.
|
||||||
|
leave out if you want to exclude neither (recommended!)
|
||||||
|
*/
|
||||||
|
// exclude : {
|
||||||
|
// path: '',
|
||||||
|
// dynamic: true
|
||||||
|
// },
|
||||||
|
|
||||||
|
/* pattern specifying which files to include (regular expression)
|
||||||
|
dependency-cruiser will skip everything not matching this pattern
|
||||||
|
*/
|
||||||
|
// includeOnly : '',
|
||||||
|
|
||||||
|
/* dependency-cruiser will include modules matching against the focus
|
||||||
|
regular expression in its output, as well as their neighbours (direct
|
||||||
|
dependencies and dependents)
|
||||||
|
*/
|
||||||
|
// focus : '',
|
||||||
|
|
||||||
|
/* list of module systems to cruise */
|
||||||
|
// moduleSystems: ['amd', 'cjs', 'es6', 'tsd'],
|
||||||
|
|
||||||
|
/* prefix for links in html and svg output (e.g. 'https://github.com/you/yourrepo/blob/develop/'
|
||||||
|
to open it on your online repo or `vscode://file/${process.cwd()}/` to
|
||||||
|
open it in visual studio code),
|
||||||
|
*/
|
||||||
|
// prefix: '',
|
||||||
|
|
||||||
|
/* false (the default): ignore dependencies that only exist before typescript-to-javascript compilation
|
||||||
|
true: also detect dependencies that only exist before typescript-to-javascript compilation
|
||||||
|
"specify": for each dependency identify whether it only exists before compilation or also after
|
||||||
|
*/
|
||||||
|
tsPreCompilationDeps: true,
|
||||||
|
|
||||||
|
/*
|
||||||
|
list of extensions to scan that aren't javascript or compile-to-javascript.
|
||||||
|
Empty by default. Only put extensions in here that you want to take into
|
||||||
|
account that are _not_ parsable.
|
||||||
|
*/
|
||||||
|
// extraExtensionsToScan: [".json", ".jpg", ".png", ".svg", ".webp"],
|
||||||
|
|
||||||
|
/* if true combines the package.jsons found from the module up to the base
|
||||||
|
folder the cruise is initiated from. Useful for how (some) mono-repos
|
||||||
|
manage dependencies & dependency definitions.
|
||||||
|
*/
|
||||||
|
// combinedDependencies: false,
|
||||||
|
|
||||||
|
/* if true leave symlinks untouched, otherwise use the realpath */
|
||||||
|
// preserveSymlinks: false,
|
||||||
|
|
||||||
|
/* TypeScript project file ('tsconfig.json') to use for
|
||||||
|
(1) compilation and
|
||||||
|
(2) resolution (e.g. with the paths property)
|
||||||
|
|
||||||
|
The (optional) fileName attribute specifies which file to take (relative to
|
||||||
|
dependency-cruiser's current working directory). When not provided
|
||||||
|
defaults to './tsconfig.json'.
|
||||||
|
*/
|
||||||
|
tsConfig: {
|
||||||
|
fileName: 'tsconfig.json'
|
||||||
|
},
|
||||||
|
|
||||||
|
/* Webpack configuration to use to get resolve options from.
|
||||||
|
|
||||||
|
The (optional) fileName attribute specifies which file to take (relative
|
||||||
|
to dependency-cruiser's current working directory. When not provided defaults
|
||||||
|
to './webpack.conf.js'.
|
||||||
|
|
||||||
|
The (optional) `env` and `args` attributes contain the parameters to be passed if
|
||||||
|
your webpack config is a function and takes them (see webpack documentation
|
||||||
|
for details)
|
||||||
|
*/
|
||||||
|
// webpackConfig: {
|
||||||
|
// fileName: './webpack.config.js',
|
||||||
|
// env: {},
|
||||||
|
// args: {},
|
||||||
|
// },
|
||||||
|
|
||||||
|
/* Babel config ('.babelrc', '.babelrc.json', '.babelrc.json5', ...) to use
|
||||||
|
for compilation (and whatever other naughty things babel plugins do to
|
||||||
|
source code). This feature is well tested and usable, but might change
|
||||||
|
behavior a bit over time (e.g. more precise results for used module
|
||||||
|
systems) without dependency-cruiser getting a major version bump.
|
||||||
|
*/
|
||||||
|
// babelConfig: {
|
||||||
|
// fileName: './.babelrc'
|
||||||
|
// },
|
||||||
|
|
||||||
|
/* List of strings you have in use in addition to cjs/ es6 requires
|
||||||
|
& imports to declare module dependencies. Use this e.g. if you've
|
||||||
|
re-declared require, use a require-wrapper or use window.require as
|
||||||
|
a hack.
|
||||||
|
*/
|
||||||
|
// exoticRequireStrings: [],
|
||||||
|
/* options to pass on to enhanced-resolve, the package dependency-cruiser
|
||||||
|
uses to resolve module references to disk. You can set most of these
|
||||||
|
options in a webpack.conf.js - this section is here for those
|
||||||
|
projects that don't have a separate webpack config file.
|
||||||
|
|
||||||
|
Note: settings in webpack.conf.js override the ones specified here.
|
||||||
|
*/
|
||||||
|
enhancedResolveOptions: {
|
||||||
|
/* List of strings to consider as 'exports' fields in package.json. Use
|
||||||
|
['exports'] when you use packages that use such a field and your environment
|
||||||
|
supports it (e.g. node ^12.19 || >=14.7 or recent versions of webpack).
|
||||||
|
|
||||||
|
If you have an `exportsFields` attribute in your webpack config, that one
|
||||||
|
will have precedence over the one specified here.
|
||||||
|
*/
|
||||||
|
exportsFields: ["exports"],
|
||||||
|
/* List of conditions to check for in the exports field. e.g. use ['imports']
|
||||||
|
if you're only interested in exposed es6 modules, ['require'] for commonjs,
|
||||||
|
or all conditions at once `(['import', 'require', 'node', 'default']`)
|
||||||
|
if anything goes for you. Only works when the 'exportsFields' array is
|
||||||
|
non-empty.
|
||||||
|
|
||||||
|
If you have a 'conditionNames' attribute in your webpack config, that one will
|
||||||
|
have precedence over the one specified here.
|
||||||
|
*/
|
||||||
|
conditionNames: ["import", "require", "node", "default"],
|
||||||
|
/*
|
||||||
|
The extensions, by default are the same as the ones dependency-cruiser
|
||||||
|
can access (run `npx depcruise --info` to see which ones that are in
|
||||||
|
_your_ environment. If that list is larger than what you need (e.g.
|
||||||
|
it contains .js, .jsx, .ts, .tsx, .cts, .mts - but you don't use
|
||||||
|
TypeScript you can pass just the extensions you actually use (e.g.
|
||||||
|
[".js", ".jsx"]). This can speed up the most expensive step in
|
||||||
|
dependency cruising (module resolution) quite a bit.
|
||||||
|
*/
|
||||||
|
// extensions: [".js", ".jsx", ".ts", ".tsx", ".d.ts"],
|
||||||
|
/*
|
||||||
|
If your TypeScript project makes use of types specified in 'types'
|
||||||
|
fields in package.jsons of external dependencies, specify "types"
|
||||||
|
in addition to "main" in here, so enhanced-resolve (the resolver
|
||||||
|
dependency-cruiser uses) knows to also look there. You can also do
|
||||||
|
this if you're not sure, but still use TypeScript. In a future version
|
||||||
|
of dependency-cruiser this will likely become the default.
|
||||||
|
*/
|
||||||
|
mainFields: ["main", "types"],
|
||||||
|
},
|
||||||
|
reporterOptions: {
|
||||||
|
dot: {
|
||||||
|
/* pattern of modules that can be consolidated in the detailed
|
||||||
|
graphical dependency graph. The default pattern in this configuration
|
||||||
|
collapses everything in node_modules to one folder deep so you see
|
||||||
|
the external modules, but not the innards your app depends upon.
|
||||||
|
*/
|
||||||
|
collapsePattern: 'node_modules/(@[^/]+/[^/]+|[^/]+)',
|
||||||
|
|
||||||
|
/* Options to tweak the appearance of your graph.See
|
||||||
|
https://github.com/sverweij/dependency-cruiser/blob/master/doc/options-reference.md#reporteroptions
|
||||||
|
for details and some examples. If you don't specify a theme
|
||||||
|
don't worry - dependency-cruiser will fall back to the default one.
|
||||||
|
*/
|
||||||
|
// theme: {
|
||||||
|
// graph: {
|
||||||
|
// /* use splines: "ortho" for straight lines. Be aware though
|
||||||
|
// graphviz might take a long time calculating ortho(gonal)
|
||||||
|
// routings.
|
||||||
|
// */
|
||||||
|
// splines: "true"
|
||||||
|
// },
|
||||||
|
// modules: [
|
||||||
|
// {
|
||||||
|
// criteria: { matchesFocus: true },
|
||||||
|
// attributes: {
|
||||||
|
// fillcolor: "lime",
|
||||||
|
// penwidth: 2,
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// criteria: { matchesFocus: false },
|
||||||
|
// attributes: {
|
||||||
|
// fillcolor: "lightgrey",
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// criteria: { matchesReaches: true },
|
||||||
|
// attributes: {
|
||||||
|
// fillcolor: "lime",
|
||||||
|
// penwidth: 2,
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// criteria: { matchesReaches: false },
|
||||||
|
// attributes: {
|
||||||
|
// fillcolor: "lightgrey",
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// criteria: { source: "^src/model" },
|
||||||
|
// attributes: { fillcolor: "#ccccff" }
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// criteria: { source: "^src/view" },
|
||||||
|
// attributes: { fillcolor: "#ccffcc" }
|
||||||
|
// },
|
||||||
|
// ],
|
||||||
|
// dependencies: [
|
||||||
|
// {
|
||||||
|
// criteria: { "rules[0].severity": "error" },
|
||||||
|
// attributes: { fontcolor: "red", color: "red" }
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// criteria: { "rules[0].severity": "warn" },
|
||||||
|
// attributes: { fontcolor: "orange", color: "orange" }
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// criteria: { "rules[0].severity": "info" },
|
||||||
|
// attributes: { fontcolor: "blue", color: "blue" }
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// criteria: { resolved: "^src/model" },
|
||||||
|
// attributes: { color: "#0000ff77" }
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// criteria: { resolved: "^src/view" },
|
||||||
|
// attributes: { color: "#00770077" }
|
||||||
|
// }
|
||||||
|
// ]
|
||||||
|
// }
|
||||||
|
},
|
||||||
|
archi: {
|
||||||
|
/* pattern of modules that can be consolidated in the high level
|
||||||
|
graphical dependency graph. If you use the high level graphical
|
||||||
|
dependency graph reporter (`archi`) you probably want to tweak
|
||||||
|
this collapsePattern to your situation.
|
||||||
|
*/
|
||||||
|
collapsePattern: '^(packages|src|lib|app|bin|test(s?)|spec(s?))/[^/]+|node_modules/(@[^/]+/[^/]+|[^/]+)',
|
||||||
|
|
||||||
|
/* Options to tweak the appearance of your graph.See
|
||||||
|
https://github.com/sverweij/dependency-cruiser/blob/master/doc/options-reference.md#reporteroptions
|
||||||
|
for details and some examples. If you don't specify a theme
|
||||||
|
for 'archi' dependency-cruiser will use the one specified in the
|
||||||
|
dot section (see above), if any, and otherwise use the default one.
|
||||||
|
*/
|
||||||
|
// theme: {
|
||||||
|
// },
|
||||||
|
},
|
||||||
|
"text": {
|
||||||
|
"highlightFocused": true
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
// generated: dependency-cruiser@12.11.0 on 2023-03-24T14:11:38.647Z
|
|
@ -3,14 +3,20 @@
|
||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.11.8](https://github.com/fast-crud/fast-crud/compare/v1.11.7...v1.11.8) (2023-03-24)
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* 修复当limit=1时,上传文件删光后,再选择文件上传第一次无效的bug ([d0a1ed9](https://github.com/fast-crud/fast-crud/commit/d0a1ed9c8a730d5eea19dc61f0dd6cf4031db1c3))
|
||||||
|
|
||||||
|
### Performance Improvements
|
||||||
|
|
||||||
|
* 优化翻页性能 ([d0a1db7](https://github.com/fast-crud/fast-crud/commit/d0a1db7bda08b49226739bba38e28b38c60c2b65))
|
||||||
|
|
||||||
## [1.11.7](https://github.com/fast-crud/fast-crud/compare/v1.11.6...v1.11.7) (2023-03-22)
|
## [1.11.7](https://github.com/fast-crud/fast-crud/compare/v1.11.6...v1.11.7) (2023-03-22)
|
||||||
|
|
||||||
**Note:** Version bump only for package @fast-crud/fs-admin-antdv
|
**Note:** Version bump only for package @fast-crud/fs-admin-antdv
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## [1.11.6](https://github.com/fast-crud/fast-crud/compare/v1.11.5...v1.11.6) (2023-03-22)
|
## [1.11.6](https://github.com/fast-crud/fast-crud/compare/v1.11.5...v1.11.6) (2023-03-22)
|
||||||
|
|
||||||
**Note:** Version bump only for package @fast-crud/fs-admin-antdv
|
**Note:** Version bump only for package @fast-crud/fs-admin-antdv
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "@fast-crud/fs-admin-antdv",
|
"name": "@fast-crud/fs-admin-antdv",
|
||||||
"version": "1.11.7",
|
"version": "1.11.8",
|
||||||
"private": true,
|
"private": true,
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "vite",
|
"dev": "vite",
|
||||||
|
@ -15,7 +15,8 @@
|
||||||
"pretty-quick": "pretty-quick",
|
"pretty-quick": "pretty-quick",
|
||||||
"lint-fix": "eslint --fix --ext .js --ext .jsx --ext .vue src/",
|
"lint-fix": "eslint --fix --ext .js --ext .jsx --ext .vue src/",
|
||||||
"upgrade": "yarn upgrade-interactive --latest",
|
"upgrade": "yarn upgrade-interactive --latest",
|
||||||
"tsc": "vue-tsc --noEmit --skipLibCheck"
|
"tsc": "vue-tsc --noEmit --skipLibCheck",
|
||||||
|
"circle:check": "pnpm dependency-cruise --validate --output-type err-html -f dependency-report.html src"
|
||||||
},
|
},
|
||||||
"author": "Greper",
|
"author": "Greper",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
@ -24,10 +25,10 @@
|
||||||
"@ant-design/icons-vue": "^6.1.0",
|
"@ant-design/icons-vue": "^6.1.0",
|
||||||
"@aws-sdk/client-s3": "^3.292.0",
|
"@aws-sdk/client-s3": "^3.292.0",
|
||||||
"@aws-sdk/s3-request-presigner": "^3.292.0",
|
"@aws-sdk/s3-request-presigner": "^3.292.0",
|
||||||
"@fast-crud/fast-crud": "^1.11.7",
|
"@fast-crud/fast-crud": "^1.11.8",
|
||||||
"@fast-crud/fast-extends": "^1.11.7",
|
"@fast-crud/fast-extends": "^1.11.8",
|
||||||
"@fast-crud/ui-antdv": "^1.11.7",
|
"@fast-crud/ui-antdv": "^1.11.8",
|
||||||
"@fast-crud/ui-interface": "^1.11.6",
|
"@fast-crud/ui-interface": "^1.11.8",
|
||||||
"@iconify/iconify": "^3.1.0",
|
"@iconify/iconify": "^3.1.0",
|
||||||
"@iconify/json": "^2.2.35",
|
"@iconify/json": "^2.2.35",
|
||||||
"@purge-icons/generated": "^0.9.0",
|
"@purge-icons/generated": "^0.9.0",
|
||||||
|
@ -75,6 +76,8 @@
|
||||||
"autoprefixer": "^10.4.14",
|
"autoprefixer": "^10.4.14",
|
||||||
"caller-path": "^4.0.0",
|
"caller-path": "^4.0.0",
|
||||||
"chai": "^4.3.7",
|
"chai": "^4.3.7",
|
||||||
|
"dependency-cruiser": "^12.11.0",
|
||||||
|
"dot": "^1.1.3",
|
||||||
"eslint": "8.36.0",
|
"eslint": "8.36.0",
|
||||||
"eslint-config-prettier": "^8.7.0",
|
"eslint-config-prettier": "^8.7.0",
|
||||||
"eslint-plugin-import": "^2.27.5",
|
"eslint-plugin-import": "^2.27.5",
|
||||||
|
|
|
@ -27,7 +27,7 @@ let manyStatus = [
|
||||||
{ value: "2", label: "停止", color: "cyan" },
|
{ value: "2", label: "停止", color: "cyan" },
|
||||||
{ value: "0", label: "关闭", color: "red", icon: "ion:radio-button-off" }
|
{ value: "0", label: "关闭", color: "red", icon: "ion:radio-button-off" }
|
||||||
];
|
];
|
||||||
for (let i = 0; i < 8; i++) {
|
for (let i = 0; i < 2; i++) {
|
||||||
manyStatus = manyStatus.concat(_.cloneDeep(manyStatus));
|
manyStatus = manyStatus.concat(_.cloneDeep(manyStatus));
|
||||||
}
|
}
|
||||||
let idIndex = 0;
|
let idIndex = 0;
|
||||||
|
|
|
@ -8,6 +8,15 @@ export const crudResources = [
|
||||||
icon: "ion:apps-sharp"
|
icon: "ion:apps-sharp"
|
||||||
},
|
},
|
||||||
children: [
|
children: [
|
||||||
|
{
|
||||||
|
title: "debug",
|
||||||
|
name: "debug",
|
||||||
|
path: "/crud/debug",
|
||||||
|
component: "/crud/debug/index.vue",
|
||||||
|
meta: {
|
||||||
|
isMenu: false
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
title: "基本特性",
|
title: "基本特性",
|
||||||
name: "basis",
|
name: "basis",
|
||||||
|
|
|
@ -74,12 +74,12 @@ export default function ({ crudExpose }: CreateCrudOptionsProps): CreateCrudOpti
|
||||||
type: "image-uploader",
|
type: "image-uploader",
|
||||||
form: {
|
form: {
|
||||||
component: {
|
component: {
|
||||||
limit: 1,
|
limit: 2,
|
||||||
uploader: {
|
uploader: {
|
||||||
type: "form"
|
type: "form"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
helper: "最大可上传1个文件"
|
helper: "最大可上传2个文件"
|
||||||
},
|
},
|
||||||
column: {
|
column: {
|
||||||
component: {
|
component: {
|
||||||
|
@ -217,12 +217,12 @@ export default function ({ crudExpose }: CreateCrudOptionsProps): CreateCrudOpti
|
||||||
type: "file-uploader",
|
type: "file-uploader",
|
||||||
form: {
|
form: {
|
||||||
component: {
|
component: {
|
||||||
limit: 1,
|
limit: 2,
|
||||||
uploader: {
|
uploader: {
|
||||||
type: "form"
|
type: "form"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
helper: "最大可上传1个文件"
|
helper: "最大可上传2个文件"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
sizeLimit: {
|
sizeLimit: {
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
import * as api from "./api";
|
import * as api from "./api";
|
||||||
import { AddReq, CreateCrudOptionsProps, CreateCrudOptionsRet, DelReq, dict, EditReq, UserPageQuery, UserPageRes } from "@fast-crud/fast-crud";
|
import { AddReq, compute, CreateCrudOptionsProps, CreateCrudOptionsRet, DelReq, dict, EditReq, UserPageQuery, UserPageRes, utils } from "@fast-crud/fast-crud";
|
||||||
|
import dayjs from "dayjs";
|
||||||
|
import { computed, Ref, ref } from "vue";
|
||||||
|
|
||||||
export default function ({ crudExpose }: CreateCrudOptionsProps): CreateCrudOptionsRet {
|
export default function ({ crudExpose }: CreateCrudOptionsProps): CreateCrudOptionsRet {
|
||||||
const pageRequest = async (query: UserPageQuery): Promise<UserPageRes> => {
|
const pageRequest = async (query: UserPageQuery): Promise<UserPageRes> => {
|
||||||
|
@ -17,6 +19,29 @@ export default function ({ crudExpose }: CreateCrudOptionsProps): CreateCrudOpti
|
||||||
return await api.AddObj(form);
|
return await api.AddObj(form);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const options: Ref = ref([]);
|
||||||
|
|
||||||
|
let arr = [
|
||||||
|
{
|
||||||
|
value: "1",
|
||||||
|
label: "test"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: "1",
|
||||||
|
label: "test2"
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
for (let i = 0; i < 10; i++) {
|
||||||
|
arr = arr.concat(arr);
|
||||||
|
}
|
||||||
|
let i = 0;
|
||||||
|
for (const item of arr) {
|
||||||
|
i++;
|
||||||
|
item.value = i + "";
|
||||||
|
}
|
||||||
|
options.value = arr;
|
||||||
|
|
||||||
return {
|
return {
|
||||||
crudOptions: {
|
crudOptions: {
|
||||||
request: {
|
request: {
|
||||||
|
@ -46,18 +71,14 @@ export default function ({ crudExpose }: CreateCrudOptionsProps): CreateCrudOpti
|
||||||
show: false
|
show: false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
statusRemote: {
|
statusRemote: {
|
||||||
title: "单选远程",
|
title: "单选远程",
|
||||||
search: {
|
search: {
|
||||||
show: true,
|
show: false
|
||||||
value: []
|
|
||||||
},
|
},
|
||||||
type: "dict-select",
|
type: "dict-select",
|
||||||
dict: dict({
|
dict: dict({
|
||||||
url: "/mock/dicts/_OpenStatusEnum2?simple",
|
url: "/mock/dicts/ManyOpenStatusEnum?from=dict1"
|
||||||
value: "id",
|
|
||||||
label: "text"
|
|
||||||
}),
|
}),
|
||||||
form: {
|
form: {
|
||||||
component: { mode: "multiple" },
|
component: { mode: "multiple" },
|
||||||
|
@ -66,39 +87,6 @@ export default function ({ crudExpose }: CreateCrudOptionsProps): CreateCrudOpti
|
||||||
column: {
|
column: {
|
||||||
width: 200
|
width: 200
|
||||||
}
|
}
|
||||||
},
|
|
||||||
id2: {
|
|
||||||
title: "ID",
|
|
||||||
key: "id",
|
|
||||||
type: "number",
|
|
||||||
column: {
|
|
||||||
width: 300
|
|
||||||
},
|
|
||||||
form: {
|
|
||||||
show: false
|
|
||||||
}
|
|
||||||
},
|
|
||||||
id3: {
|
|
||||||
title: "ID",
|
|
||||||
key: "id",
|
|
||||||
type: "number",
|
|
||||||
column: {
|
|
||||||
width: 300
|
|
||||||
},
|
|
||||||
form: {
|
|
||||||
show: false
|
|
||||||
}
|
|
||||||
},
|
|
||||||
id4: {
|
|
||||||
title: "ID",
|
|
||||||
key: "id",
|
|
||||||
type: "number",
|
|
||||||
column: {
|
|
||||||
width: 300
|
|
||||||
},
|
|
||||||
form: {
|
|
||||||
show: false
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,9 +1,20 @@
|
||||||
import mockUtil from "/src/mock/base";
|
import mockUtil from "/src/mock/base";
|
||||||
const options: any = {
|
const options: any = {
|
||||||
name: "DebugSelect",
|
name: "DebugSelect",
|
||||||
idGenerator: 0
|
idGenerator: 0,
|
||||||
|
copyTimes: 500
|
||||||
};
|
};
|
||||||
const list: any = [];
|
const list: any = [
|
||||||
|
{
|
||||||
|
statusRemote: "1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
statusRemote: "2"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
statusRemote: "3"
|
||||||
|
}
|
||||||
|
];
|
||||||
options.list = list;
|
options.list = list;
|
||||||
const mock = mockUtil.buildMock(options);
|
const mock = mockUtil.buildMock(options);
|
||||||
export default mock;
|
export default mock;
|
Loading…
Reference in New Issue