Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
B
basic-vue-admin
概览
概览
详情
活动
周期分析
版本库
存储库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
Basic
basic-vue-admin
Commits
a98835e1
提交
a98835e1
authored
3月 26, 2021
作者:
Vben
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
chore: types
上级
5b4a41ce
显示空白字符变更
内嵌
并排
正在显示
15 个修改的文件
包含
103 行增加
和
236 行删除
+103
-236
ApiSelect copy.vue
src/components/Form/src/components/ApiSelect copy.vue
+0
-127
bar.ts
src/components/Scrollbar/src/bar.ts
+1
-1
index.ts
src/components/Table/src/components/editable/index.ts
+1
-1
table.ts
src/components/Table/src/types/table.ts
+1
-1
index.ts
src/directives/ripple/index.ts
+1
-1
useFormItem.ts
src/hooks/component/useFormItem.ts
+1
-1
transition.ts
src/layouts/page/transition.ts
+1
-1
permissionGuard.ts
src/router/guard/permissionGuard.ts
+1
-1
types.ts
src/utils/http/axios/types.ts
+1
-1
global.d.ts
types/global.d.ts
+63
-69
index.d.ts
types/index.d.ts
+26
-0
module.d.ts
types/module.d.ts
+6
-0
tsx.d.ts
types/tsx.d.ts
+0
-19
vue-app-env.d.ts
types/vue-app-env.d.ts
+0
-5
window.d.ts
types/window.d.ts
+0
-8
没有找到文件。
src/components/Form/src/components/ApiSelect copy.vue
deleted
100644 → 0
浏览文件 @
5b4a41ce
<
template
>
<Select
v-bind=
"attrs"
:options=
"getOptions"
v-model:value=
"state"
@
focus=
"handleFetch"
>
<template
#[
item
]="
data
"
v-for=
"item in Object.keys($slots)"
>
<slot
:name=
"item"
v-bind=
"data"
></slot>
</
template
>
<
template
#
suffixIcon
v-if=
"loading"
>
<LoadingOutlined
spin
/>
</
template
>
<
template
#
notFoundContent
v-if=
"loading"
>
<span>
<LoadingOutlined
spin
class=
"mr-1"
/>
{{
t
(
'component.form.apiSelectNotFound'
)
}}
</span>
</
template
>
</Select>
</template>
<
script
lang=
"ts"
>
import
{
defineComponent
,
PropType
,
ref
,
watchEffect
,
computed
,
unref
}
from
'vue'
;
import
{
Select
}
from
'ant-design-vue'
;
import
{
isFunction
}
from
'/@/utils/is'
;
import
{
useRuleFormItem
}
from
'/@/hooks/component/useFormItem'
;
import
{
useAttrs
}
from
'/@/hooks/core/useAttrs'
;
import
{
get
}
from
'lodash-es'
;
import
{
LoadingOutlined
}
from
'@ant-design/icons-vue'
;
import
{
useI18n
}
from
'/@/hooks/web/useI18n'
;
import
{
propTypes
}
from
'/@/utils/propTypes'
;
type
OptionsItem
=
{
label
:
string
;
value
:
string
;
disabled
?:
boolean
};
export
default
defineComponent
({
name
:
'ApiSelect'
,
components
:
{
Select
,
LoadingOutlined
,
},
inheritAttrs
:
false
,
props
:
{
value
:
propTypes
.
string
,
numberToString
:
propTypes
.
bool
,
api
:
{
type
:
Function
as
PropType
<
(
arg
?:
Recordable
)
=>
Promise
<
OptionsItem
[]
>>
,
default
:
null
,
},
// api params
params
:
{
type
:
Object
as
PropType
<
Recordable
>
,
default
:
()
=>
{},
},
// support xxx.xxx.xx
resultField
:
propTypes
.
string
.
def
(
''
),
labelField
:
propTypes
.
string
.
def
(
'label'
),
valueField
:
propTypes
.
string
.
def
(
'value'
),
immediate
:
propTypes
.
bool
.
def
(
true
),
},
emits
:
[
'options-change'
,
'change'
],
setup
(
props
,
{
emit
})
{
const
options
=
ref
<
OptionsItem
[]
>
([]);
const
loading
=
ref
(
false
);
const
isFirstLoad
=
ref
(
true
);
const
attrs
=
useAttrs
();
const
{
t
}
=
useI18n
();
// Embedded in the form, just use the hook binding to perform form verification
const
[
state
]
=
useRuleFormItem
(
props
);
const
getOptions
=
computed
(()
=>
{
const
{
labelField
,
valueField
,
numberToString
}
=
props
;
return
unref
(
options
).
reduce
((
prev
,
next
:
Recordable
)
=>
{
if
(
next
)
{
const
value
=
next
[
valueField
];
prev
.
push
({
label
:
next
[
labelField
],
value
:
numberToString
?
`
${
value
}
`
:
value
,
});
}
return
prev
;
},
[]
as
OptionsItem
[]);
});
watchEffect
(()
=>
{
if
(
isFirstLoad
.
value
)
{
props
.
immediate
&&
fetch
();
}
else
{
fetch
();
}
});
async
function
fetch
()
{
const
api
=
props
.
api
;
if
(
!
api
||
!
isFunction
(
api
))
return
;
try
{
loading
.
value
=
true
;
const
res
=
await
api
(
props
.
params
);
if
(
Array
.
isArray
(
res
))
{
options
.
value
=
res
;
emitChange
();
return
;
}
if
(
props
.
resultField
)
{
options
.
value
=
get
(
res
,
props
.
resultField
)
||
[];
}
emitChange
();
}
catch
(
error
)
{
console
.
warn
(
error
);
}
finally
{
loading
.
value
=
false
;
}
}
async
function
handleFetch
()
{
if
(
!
props
.
immediate
)
{
await
fetch
();
}
isFirstLoad
.
value
=
false
;
}
function
emitChange
()
{
emit
(
'options-change'
,
unref
(
options
));
}
return
{
state
,
attrs
,
getOptions
,
loading
,
t
,
handleFetch
};
},
});
</
script
>
src/components/Scrollbar/src/bar.ts
浏览文件 @
a98835e1
...
@@ -28,7 +28,7 @@ export default defineComponent({
...
@@ -28,7 +28,7 @@ export default defineComponent({
const
bar
=
computed
(()
=>
{
const
bar
=
computed
(()
=>
{
return
BAR_MAP
[
props
.
vertical
?
'vertical'
:
'horizontal'
];
return
BAR_MAP
[
props
.
vertical
?
'vertical'
:
'horizontal'
];
});
});
const
barStore
=
ref
<
Index
able
>
({});
const
barStore
=
ref
<
Record
able
>
({});
const
cursorDown
=
ref
<
any
>
(
null
);
const
cursorDown
=
ref
<
any
>
(
null
);
const
clickThumbHandler
=
(
e
:
any
)
=>
{
const
clickThumbHandler
=
(
e
:
any
)
=>
{
// prevent click event of right button
// prevent click event of right button
...
...
src/components/Table/src/components/editable/index.ts
浏览文件 @
a98835e1
...
@@ -41,7 +41,7 @@ export function renderEditCell(column: BasicColumn) {
...
@@ -41,7 +41,7 @@ export function renderEditCell(column: BasicColumn) {
};
};
}
}
export
type
EditRecordRow
<
T
=
Hash
<
any
>
>
=
Partial
<
export
type
EditRecordRow
<
T
=
Recordable
>
=
Partial
<
{
{
onEdit
:
(
editable
:
boolean
,
submit
?:
boolean
)
=>
Promise
<
boolean
>
;
onEdit
:
(
editable
:
boolean
,
submit
?:
boolean
)
=>
Promise
<
boolean
>
;
editable
:
boolean
;
editable
:
boolean
;
...
...
src/components/Table/src/types/table.ts
浏览文件 @
a98835e1
...
@@ -402,7 +402,7 @@ export interface BasicColumn extends ColumnProps {
...
@@ -402,7 +402,7 @@ export interface BasicColumn extends ColumnProps {
flag
?:
'INDEX'
|
'DEFAULT'
|
'CHECKBOX'
|
'RADIO'
|
'ACTION'
;
flag
?:
'INDEX'
|
'DEFAULT'
|
'CHECKBOX'
|
'RADIO'
|
'ACTION'
;
customTitle
?:
VueNode
;
customTitle
?:
VueNode
;
slots
?:
Index
able
;
slots
?:
Record
able
;
// Whether to hide the column by default, it can be displayed in the column configuration
// Whether to hide the column by default, it can be displayed in the column configuration
defaultHidden
?:
boolean
;
defaultHidden
?:
boolean
;
...
...
src/directives/ripple/index.ts
浏览文件 @
a98835e1
...
@@ -181,7 +181,7 @@ function rippler({
...
@@ -181,7 +181,7 @@ function rippler({
};
};
}
}
function
setProps
(
modifiers
:
Hash
<
any
>
,
props
:
Recordable
)
{
function
setProps
(
modifiers
:
Recordable
,
props
:
Recordable
)
{
modifiers
.
forEach
((
item
:
Recordable
)
=>
{
modifiers
.
forEach
((
item
:
Recordable
)
=>
{
if
(
isNaN
(
Number
(
item
)))
props
.
event
=
item
;
if
(
isNaN
(
Number
(
item
)))
props
.
event
=
item
;
else
props
.
transition
=
item
;
else
props
.
transition
=
item
;
...
...
src/hooks/component/useFormItem.ts
浏览文件 @
a98835e1
...
@@ -3,7 +3,7 @@ import { reactive, readonly, computed, getCurrentInstance, watchEffect } from 'v
...
@@ -3,7 +3,7 @@ import { reactive, readonly, computed, getCurrentInstance, watchEffect } from 'v
import
{
isEqual
}
from
'lodash-es'
;
import
{
isEqual
}
from
'lodash-es'
;
export
function
useRuleFormItem
<
T
extends
Index
able
>
(
export
function
useRuleFormItem
<
T
extends
Record
able
>
(
props
:
T
,
props
:
T
,
key
:
keyof
T
=
'value'
,
key
:
keyof
T
=
'value'
,
changeEvent
=
'change'
changeEvent
=
'change'
...
...
src/layouts/page/transition.ts
浏览文件 @
a98835e1
...
@@ -2,7 +2,7 @@ import type { FunctionalComponent } from 'vue';
...
@@ -2,7 +2,7 @@ import type { FunctionalComponent } from 'vue';
import
type
{
RouteLocation
}
from
'vue-router'
;
import
type
{
RouteLocation
}
from
'vue-router'
;
export
interface
DefaultContext
{
export
interface
DefaultContext
{
Component
:
FunctionalComponent
&
{
type
:
Index
able
};
Component
:
FunctionalComponent
&
{
type
:
Record
able
};
route
:
RouteLocation
;
route
:
RouteLocation
;
}
}
...
...
src/router/guard/permissionGuard.ts
浏览文件 @
a98835e1
...
@@ -38,7 +38,7 @@ export function createPermissionGuard(router: Router) {
...
@@ -38,7 +38,7 @@ export function createPermissionGuard(router: Router) {
return
;
return
;
}
}
// redirect login page
// redirect login page
const
redirectData
:
{
path
:
string
;
replace
:
boolean
;
query
?:
Index
able
<
string
>
}
=
{
const
redirectData
:
{
path
:
string
;
replace
:
boolean
;
query
?:
Record
able
<
string
>
}
=
{
path
:
LOGIN_PATH
,
path
:
LOGIN_PATH
,
replace
:
true
,
replace
:
true
,
};
};
...
...
src/utils/http/axios/types.ts
浏览文件 @
a98835e1
...
@@ -28,7 +28,7 @@ export interface Result<T = any> {
...
@@ -28,7 +28,7 @@ export interface Result<T = any> {
// multipart/form-data: upload file
// multipart/form-data: upload file
export
interface
UploadFileParams
{
export
interface
UploadFileParams
{
// Other parameters
// Other parameters
data
?:
Index
able
;
data
?:
Record
able
;
// File parameter interface field name
// File parameter interface field name
name
?:
string
;
name
?:
string
;
// file name
// file name
...
...
types/global.d.ts
浏览文件 @
a98835e1
declare
interface
Fn
<
T
=
any
,
R
=
T
>
{
import
type
{
(...
arg
:
T
[]):
R
;
App
,
}
ComponentRenderProxy
,
VNode
,
declare
interface
PromiseFn
<
T
=
any
,
R
=
T
>
{
ComponentPublicInstance
,
(...
arg
:
T
[]):
Promise
<
R
>
;
FunctionalComponent
,
}
}
from
'vue'
;
declare
global
{
declare
interface
IObj
<
T
=
any
>
{
declare
interface
Window
{
[
key
:
string
]:
T
;
// Global vue app instance
[
key
:
number
]:
T
;
__APP__
:
App
<
Element
>
;
}
}
declare
function
parseInt
(
s
:
string
|
number
,
radix
?:
number
):
number
;
export
type
Writable
<
T
>
=
{
-
readonly
[
P
in
keyof
T
]:
T
[
P
];
declare
function
parseFloat
(
string
:
string
|
number
):
number
;
};
declare
type
Nullable
<
T
>
=
T
|
null
;
declare
type
Nullable
<
T
>
=
T
|
null
;
declare
type
NonNullable
<
T
>
=
T
extends
null
|
undefined
?
never
:
T
;
declare
type
NonNullable
<
T
>
=
T
extends
null
|
undefined
?
never
:
T
;
declare
type
Recordable
<
T
=
any
>
=
Record
<
string
,
T
>
;
declare
type
ReadonlyRecordable
<
T
=
any
>
=
{
declare
type
RefType
<
T
>
=
T
|
null
;
declare
type
CustomizedHTMLElement
<
T
>
=
HTMLElement
&
T
;
declare
type
Indexable
<
T
extends
any
=
any
>
=
{
[
key
:
string
]:
T
;
};
declare
type
Recordable
<
T
extends
any
=
any
>
=
Record
<
string
,
T
>
;
declare
type
ReadonlyRecordable
<
T
extends
any
=
any
>
=
{
readonly
[
key
:
string
]:
T
;
readonly
[
key
:
string
]:
T
;
};
};
declare
type
Indexable
<
T
=
any
>
=
{
declare
type
Hash
<
T
>
=
Indexable
<
T
>
;
[
key
:
string
]:
T
;
};
declare
type
DeepPartial
<
T
>
=
{
declare
type
DeepPartial
<
T
>
=
{
[
P
in
keyof
T
]?:
DeepPartial
<
T
[
P
]
>
;
[
P
in
keyof
T
]?:
DeepPartial
<
T
[
P
]
>
;
};
};
declare
type
TimeoutHandle
=
ReturnType
<
typeof
setTimeout
>
;
declare
type
LabelValueOptions
=
{
declare
type
IntervalHandle
=
ReturnType
<
typeof
setInterval
>
;
label
:
string
;
value
:
any
;
}[];
declare
type
EmitType
=
(
event
:
string
,
...
args
:
any
[])
=>
void
;
declare
type
TargetContext
=
'_self'
|
'_blank'
;
declare
type
TimeoutHandle
=
ReturnType
<
typeof
setTimeout
>
;
declare
type
IntervalHandle
=
ReturnType
<
typeof
setInterval
>
;
declare
interface
ComponentElRef
<
T
extends
HTMLElement
=
HTMLDivElement
>
{
$el
:
T
;
}
declare
type
ComponentRef
<
T
extends
HTMLElement
=
HTMLDivElement
>
=
ComponentElRef
<
T
>
|
null
;
declare
type
ElRef
<
T
extends
HTMLElement
=
HTMLDivElement
>
=
Nullable
<
T
>
;
declare
interface
ChangeEvent
extends
Event
{
type
IsSame
<
A
,
B
>
=
A
|
B
extends
A
&
B
?
true
:
false
;
declare
interface
ChangeEvent
extends
Event
{
target
:
HTMLInputElement
;
target
:
HTMLInputElement
;
}
}
declare
interface
WheelEvent
{
declare
interface
WheelEvent
{
path
?:
EventTarget
[];
path
?:
EventTarget
[];
}
}
interface
ImportMetaEnv
extends
ViteEnv
{
interface
ImportMetaEnv
extends
ViteEnv
{
__
:
unknown
;
__
:
unknown
;
}
}
declare
interface
ViteEnv
{
declare
interface
ViteEnv
{
VITE_PORT
:
number
;
VITE_PORT
:
number
;
VITE_USE_MOCK
:
boolean
;
VITE_USE_MOCK
:
boolean
;
VITE_USE_PWA
:
boolean
;
VITE_USE_PWA
:
boolean
;
...
@@ -88,4 +55,31 @@ declare interface ViteEnv {
...
@@ -88,4 +55,31 @@ declare interface ViteEnv {
VITE_LEGACY
:
boolean
;
VITE_LEGACY
:
boolean
;
VITE_USE_IMAGEMIN
:
boolean
;
VITE_USE_IMAGEMIN
:
boolean
;
VITE_GENERATE_UI
:
string
;
VITE_GENERATE_UI
:
string
;
}
declare
function
parseInt
(
s
:
string
|
number
,
radix
?:
number
):
number
;
declare
function
parseFloat
(
string
:
string
|
number
):
number
;
namespace
JSX
{
// tslint:disable no-empty-interface
type
Element
=
VNode
;
// tslint:disable no-empty-interface
type
ElementClass
=
ComponentRenderProxy
;
interface
ElementAttributesProperty
{
$props
:
any
;
}
interface
IntrinsicElements
{
[
elem
:
string
]:
any
;
}
interface
IntrinsicAttributes
{
[
elem
:
string
]:
any
;
}
}
}
declare
module
'vue'
{
export
type
JSXComponent
<
Props
=
any
>
=
|
{
new
():
ComponentPublicInstance
<
Props
>
}
|
FunctionalComponent
<
Props
>
;
}
}
types/index.d.ts
0 → 100644
浏览文件 @
a98835e1
declare
interface
Fn
<
T
=
any
,
R
=
T
>
{
(...
arg
:
T
[]):
R
;
}
declare
interface
PromiseFn
<
T
=
any
,
R
=
T
>
{
(...
arg
:
T
[]):
Promise
<
R
>
;
}
declare
type
RefType
<
T
>
=
T
|
null
;
declare
type
LabelValueOptions
=
{
label
:
string
;
value
:
any
;
}[];
declare
type
EmitType
=
(
event
:
string
,
...
args
:
any
[])
=>
void
;
declare
type
TargetContext
=
'_self'
|
'_blank'
;
declare
interface
ComponentElRef
<
T
extends
HTMLElement
=
HTMLDivElement
>
{
$el
:
T
;
}
declare
type
ComponentRef
<
T
extends
HTMLElement
=
HTMLDivElement
>
=
ComponentElRef
<
T
>
|
null
;
declare
type
ElRef
<
T
extends
HTMLElement
=
HTMLDivElement
>
=
Nullable
<
T
>
;
types/module.d.ts
浏览文件 @
a98835e1
declare
module
'*.vue'
{
import
{
defineComponent
}
from
'vue'
;
const
Component
:
ReturnType
<
typeof
defineComponent
>
;
export
default
Component
;
}
declare
module
'ant-design-vue/es/locale/*'
{
declare
module
'ant-design-vue/es/locale/*'
{
import
{
Locale
}
from
'ant-design-vue/types/locale-provider'
;
import
{
Locale
}
from
'ant-design-vue/types/locale-provider'
;
const
locale
:
Locale
&
ReadonlyRecordable
;
const
locale
:
Locale
&
ReadonlyRecordable
;
...
...
types/tsx.d.ts
deleted
100644 → 0
浏览文件 @
5b4a41ce
import
type
{
ComponentRenderProxy
,
VNode
}
from
'vue'
;
declare
global
{
namespace
JSX
{
// tslint:disable no-empty-interface
type
Element
=
VNode
;
// tslint:disable no-empty-interface
type
ElementClass
=
ComponentRenderProxy
;
interface
ElementAttributesProperty
{
$props
:
any
;
}
interface
IntrinsicElements
{
[
elem
:
string
]:
any
;
}
interface
IntrinsicAttributes
{
[
elem
:
string
]:
any
;
}
}
}
types/vue-app-env.d.ts
deleted
100644 → 0
浏览文件 @
5b4a41ce
declare
module
'*.vue'
{
import
{
defineComponent
}
from
'vue'
;
const
Component
:
ReturnType
<
typeof
defineComponent
>
;
export
default
Component
;
}
types/window.d.ts
deleted
100644 → 0
浏览文件 @
5b4a41ce
import
type
{
App
}
from
'vue'
;
declare
global
{
declare
interface
Window
{
// Global vue app instance
__APP__
:
App
<
Element
>
;
}
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论