bm-admin-ui 1.0.40-alpha → 1.0.41-alpha
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/es/components/breadcrumb/index.d.ts +162 -0
- package/es/components/breadcrumb/index.js +158 -0
- package/es/components/breadcrumb/src/breadcrumb.vue.d.ts +161 -0
- package/es/components/button/index.d.ts +303 -1
- package/es/components/editor/index.d.ts +305 -0
- package/es/components/editor/index.js +12543 -0
- package/es/components/editor/src/editor.vue.d.ts +304 -0
- package/es/components/editor/src/props.d.ts +31 -0
- package/es/components/feedback/index.d.ts +1028 -2
- package/es/components/float-table/index.d.ts +68 -1
- package/es/components/flow-designer/index.d.ts +5 -1
- package/es/components/form-create/index.js +77 -156
- package/es/components/form-designer/index.js +33 -131
- package/es/components/index.d.ts +2 -0
- package/es/components/index.js +2 -0
- package/es/components/input-tags-display/index.d.ts +138 -1
- package/es/components/input-tags-display/src/input-tags-display.vue.d.ts +1 -1
- package/es/components/over-tooltips/index.d.ts +33 -1
- package/es/components/search-filter/index.d.ts +233 -1
- package/es/components/search-filter/src/search-filter.vue.d.ts +3 -3
- package/es/components/select-all/index.d.ts +752 -1
- package/es/components/select-all/src/selectAll.vue.d.ts +5 -5
- package/es/components/shops-filter/index.d.ts +97 -1
- package/es/components/shops-filter/src/shops-filter.vue.d.ts +1 -1
- package/es/components/staffs-selector/index.d.ts +1095 -1
- package/es/components/staffs-selector/index.js +535 -505
- package/es/components/staffs-selector/src/action.d.ts +66 -0
- package/es/components/staffs-selector/src/multipleCmp.vue.d.ts +11 -49
- package/es/components/staffs-selector/src/staffs-selector.vue.d.ts +998 -10
- package/es/components/staffs-selector/src/variedCmp.vue.d.ts +18 -11
- package/es/components/timeline/index.d.ts +111 -2
- package/es/components/upload/index.d.ts +139 -2
- package/es/components/upload/index.js +207 -170
- package/es/components/upload/src/props.d.ts +50 -0
- package/es/components/upload/src/upload.vue.d.ts +44 -11
- package/es/utils/bm-admin-ui-resolver.d.ts +1 -3
- package/es/utils/bm-admin-ui-resolver.js +1 -1
- package/es/utils/with-install.d.ts +7 -1
- package/es/utils/with-install.js +1 -0
- package/index.esm.js +81188 -71499
- package/index.js +81186 -71495
- package/lib/components/breadcrumb/index.d.ts +162 -0
- package/lib/components/breadcrumb/index.js +168 -0
- package/lib/components/breadcrumb/src/breadcrumb.vue.d.ts +161 -0
- package/lib/components/button/index.d.ts +303 -1
- package/lib/components/editor/index.d.ts +305 -0
- package/lib/components/editor/index.js +12548 -0
- package/lib/components/editor/src/editor.vue.d.ts +304 -0
- package/lib/components/editor/src/props.d.ts +31 -0
- package/lib/components/feedback/index.d.ts +1028 -2
- package/lib/components/float-table/index.d.ts +68 -1
- package/lib/components/flow-designer/index.d.ts +5 -1
- package/lib/components/form-create/index.js +76 -155
- package/lib/components/form-designer/index.js +32 -130
- package/lib/components/index.d.ts +2 -0
- package/lib/components/index.js +14 -0
- package/lib/components/input-tags-display/index.d.ts +138 -1
- package/lib/components/input-tags-display/src/input-tags-display.vue.d.ts +1 -1
- package/lib/components/over-tooltips/index.d.ts +33 -1
- package/lib/components/search-filter/index.d.ts +233 -1
- package/lib/components/search-filter/src/search-filter.vue.d.ts +3 -3
- package/lib/components/select-all/index.d.ts +752 -1
- package/lib/components/select-all/src/selectAll.vue.d.ts +5 -5
- package/lib/components/shops-filter/index.d.ts +97 -1
- package/lib/components/shops-filter/src/shops-filter.vue.d.ts +1 -1
- package/lib/components/staffs-selector/index.d.ts +1095 -1
- package/lib/components/staffs-selector/index.js +536 -506
- package/lib/components/staffs-selector/src/action.d.ts +66 -0
- package/lib/components/staffs-selector/src/multipleCmp.vue.d.ts +11 -49
- package/lib/components/staffs-selector/src/staffs-selector.vue.d.ts +998 -10
- package/lib/components/staffs-selector/src/variedCmp.vue.d.ts +18 -11
- package/lib/components/timeline/index.d.ts +111 -2
- package/lib/components/upload/index.d.ts +139 -2
- package/lib/components/upload/index.js +205 -168
- package/lib/components/upload/src/props.d.ts +50 -0
- package/lib/components/upload/src/upload.vue.d.ts +44 -11
- package/lib/utils/bm-admin-ui-resolver.d.ts +1 -3
- package/lib/utils/bm-admin-ui-resolver.js +1 -1
- package/lib/utils/with-install.d.ts +7 -1
- package/lib/utils/with-install.js +1 -0
- package/package.json +2 -2
- package/theme-chalk/breadcrumb.css +1 -0
- package/theme-chalk/editor.css +16 -0
- package/theme-chalk/form-create.css +1 -1
- package/theme-chalk/index.css +16 -1
- package/theme-chalk/staffs-selector.css +1 -1
- package/theme-chalk/upload.css +1 -1
- package/types/components/breadcrumb/index.d.ts +162 -0
- package/types/components/breadcrumb/src/breadcrumb.vue.d.ts +161 -0
- package/types/components/button/index.d.ts +303 -1
- package/types/components/editor/index.d.ts +305 -0
- package/types/components/editor/src/editor.vue.d.ts +304 -0
- package/types/components/editor/src/props.d.ts +31 -0
- package/types/components/feedback/index.d.ts +1028 -2
- package/types/components/float-table/index.d.ts +68 -1
- package/types/components/flow-designer/index.d.ts +5 -1
- package/types/components/index.d.ts +2 -0
- package/types/components/input-tags-display/index.d.ts +138 -1
- package/types/components/input-tags-display/src/input-tags-display.vue.d.ts +1 -1
- package/types/components/over-tooltips/index.d.ts +33 -1
- package/types/components/search-filter/index.d.ts +233 -1
- package/types/components/search-filter/src/search-filter.vue.d.ts +3 -3
- package/types/components/select-all/index.d.ts +752 -1
- package/types/components/select-all/src/selectAll.vue.d.ts +5 -5
- package/types/components/shops-filter/index.d.ts +97 -1
- package/types/components/shops-filter/src/shops-filter.vue.d.ts +1 -1
- package/types/components/staffs-selector/index.d.ts +1095 -1
- package/types/components/staffs-selector/src/action.d.ts +66 -0
- package/types/components/staffs-selector/src/multipleCmp.vue.d.ts +11 -49
- package/types/components/staffs-selector/src/staffs-selector.vue.d.ts +998 -10
- package/types/components/staffs-selector/src/variedCmp.vue.d.ts +18 -11
- package/types/components/timeline/index.d.ts +111 -2
- package/types/components/upload/index.d.ts +139 -2
- package/types/components/upload/src/props.d.ts +50 -0
- package/types/components/upload/src/upload.vue.d.ts +44 -11
- package/types/utils/bm-admin-ui-resolver.d.ts +1 -3
- package/types/utils/with-install.d.ts +7 -1
|
@@ -16,23 +16,30 @@ declare const _default: import("vue").DefineComponent<{
|
|
|
16
16
|
default: () => Set<unknown>;
|
|
17
17
|
};
|
|
18
18
|
}, {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
19
|
+
multipleChecked: import("vue").Ref<any>;
|
|
20
|
+
departmentChecked: import("vue").Ref<string[]>;
|
|
21
|
+
multipDepartment: import("vue").Ref<string[]>;
|
|
22
|
+
staffsChecked: import("vue").Ref<any>;
|
|
23
|
+
shopChecked: import("vue").Ref<any>;
|
|
24
|
+
groupChecked: import("vue").Ref<any>;
|
|
25
|
+
dataMap: import("vue").Ref<Map<string, any>>;
|
|
26
|
+
curlistKeys: import("vue").Ref<Set<string>>;
|
|
27
|
+
activeKey: import("vue").Ref<number>;
|
|
28
|
+
indicator: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
|
|
29
|
+
[key: string]: any;
|
|
30
|
+
}>;
|
|
31
|
+
loading: import("vue").Ref<boolean>;
|
|
23
32
|
emptyPic: import("ant-design-vue/lib/_util/type").VueNode;
|
|
24
|
-
activeKey: any;
|
|
25
|
-
searchVal: import("vue").Ref<string>;
|
|
26
|
-
staffsChecked: import("vue").Ref<{}>;
|
|
27
|
-
groupChecked: import("vue").Ref<{}>;
|
|
28
|
-
departmentChecked: any;
|
|
29
|
-
shopChecked: import("vue").Ref<{}>;
|
|
30
|
-
inputPlaceHolder: import("vue").ComputedRef<"请输入部门搜索" | "请输入工作组搜索" | "请输入店铺搜索" | "请输入人名搜索">;
|
|
31
33
|
areas: readonly {
|
|
32
34
|
readonly title: string;
|
|
33
35
|
readonly key: number;
|
|
34
36
|
readonly paramStr: string;
|
|
35
37
|
}[];
|
|
38
|
+
searchVal: import("vue").Ref<string>;
|
|
39
|
+
search: () => void;
|
|
40
|
+
changeArea: (item: any) => void;
|
|
41
|
+
inputPlaceHolder: import("vue").ComputedRef<"请输入部门搜索" | "请输入工作组搜索" | "请输入店铺搜索" | "请输入人名搜索">;
|
|
42
|
+
changeTreeCheck: (checkedKeys: any) => void;
|
|
36
43
|
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("update:selected" | "fetchList")[], "update:selected" | "fetchList", import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
37
44
|
list: {
|
|
38
45
|
type: ArrayConstructor;
|
|
@@ -1,5 +1,114 @@
|
|
|
1
1
|
export type { TimelineProps, TimelineItemProps } from './src/props';
|
|
2
|
-
declare const BmTimeline:
|
|
3
|
-
|
|
2
|
+
declare const BmTimeline: import("bm-admin-ui/es/utils/with-install").SFCWithInstall<import("vue").DefineComponent<{
|
|
3
|
+
mode: import("vue-types").VueTypeDef<string> & {
|
|
4
|
+
default: string;
|
|
5
|
+
};
|
|
6
|
+
size: import("vue-types").VueTypeDef<string> & {
|
|
7
|
+
default: string;
|
|
8
|
+
};
|
|
9
|
+
labelWidth: import("vue-types").VueTypeValidableDef<string> & {
|
|
10
|
+
default: string;
|
|
11
|
+
} & {
|
|
12
|
+
default: string;
|
|
13
|
+
};
|
|
14
|
+
}, {
|
|
15
|
+
props: Readonly<import("@vue/shared").LooseRequired<Readonly<import("vue").ExtractPropTypes<{
|
|
16
|
+
mode: import("vue-types").VueTypeDef<string> & {
|
|
17
|
+
default: string;
|
|
18
|
+
};
|
|
19
|
+
size: import("vue-types").VueTypeDef<string> & {
|
|
20
|
+
default: string;
|
|
21
|
+
};
|
|
22
|
+
labelWidth: import("vue-types").VueTypeValidableDef<string> & {
|
|
23
|
+
default: string;
|
|
24
|
+
} & {
|
|
25
|
+
default: string;
|
|
26
|
+
};
|
|
27
|
+
}>> & {}>>;
|
|
28
|
+
labelWidth: import("vue").Ref<string>;
|
|
29
|
+
mode: import("vue").Ref<string>;
|
|
30
|
+
className: import("vue").ComputedRef<{
|
|
31
|
+
[x: string]: boolean;
|
|
32
|
+
'bm-timeline': boolean;
|
|
33
|
+
}>;
|
|
34
|
+
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
35
|
+
mode: import("vue-types").VueTypeDef<string> & {
|
|
36
|
+
default: string;
|
|
37
|
+
};
|
|
38
|
+
size: import("vue-types").VueTypeDef<string> & {
|
|
39
|
+
default: string;
|
|
40
|
+
};
|
|
41
|
+
labelWidth: import("vue-types").VueTypeValidableDef<string> & {
|
|
42
|
+
default: string;
|
|
43
|
+
} & {
|
|
44
|
+
default: string;
|
|
45
|
+
};
|
|
46
|
+
}>>, {
|
|
47
|
+
size: string;
|
|
48
|
+
mode: string;
|
|
49
|
+
labelWidth: string;
|
|
50
|
+
}>>;
|
|
51
|
+
declare const BmTimelineItem: import("bm-admin-ui/es/utils/with-install").SFCWithInstall<import("vue").DefineComponent<{
|
|
52
|
+
color: import("vue-types").VueTypeDef<string> & {
|
|
53
|
+
default: string;
|
|
54
|
+
};
|
|
55
|
+
dot: import("vue-types").VueTypeValidableDef<any> & {
|
|
56
|
+
default: any;
|
|
57
|
+
};
|
|
58
|
+
label: import("vue-types").VueTypeValidableDef<any> & {
|
|
59
|
+
default: any;
|
|
60
|
+
};
|
|
61
|
+
}, {
|
|
62
|
+
slots: Readonly<{
|
|
63
|
+
[name: string]: import("vue").Slot | undefined;
|
|
64
|
+
}>;
|
|
65
|
+
props: Readonly<import("@vue/shared").LooseRequired<Readonly<import("vue").ExtractPropTypes<{
|
|
66
|
+
color: import("vue-types").VueTypeDef<string> & {
|
|
67
|
+
default: string;
|
|
68
|
+
};
|
|
69
|
+
dot: import("vue-types").VueTypeValidableDef<any> & {
|
|
70
|
+
default: any;
|
|
71
|
+
};
|
|
72
|
+
label: import("vue-types").VueTypeValidableDef<any> & {
|
|
73
|
+
default: any;
|
|
74
|
+
};
|
|
75
|
+
}>> & {}>>;
|
|
76
|
+
labelWidth: import("vue").Ref<any>;
|
|
77
|
+
mode: import("vue").Ref<any>;
|
|
78
|
+
offsetStyle: import("vue").ComputedRef<{
|
|
79
|
+
left: string;
|
|
80
|
+
right?: undefined;
|
|
81
|
+
} | {
|
|
82
|
+
right: string;
|
|
83
|
+
left?: undefined;
|
|
84
|
+
} | {
|
|
85
|
+
left?: undefined;
|
|
86
|
+
right?: undefined;
|
|
87
|
+
}>;
|
|
88
|
+
itemClassName: import("vue").ComputedRef<{
|
|
89
|
+
'bm-timeline-item': boolean;
|
|
90
|
+
'bm-timeline-item-has-label': any;
|
|
91
|
+
}>;
|
|
92
|
+
dotClassName: import("vue").ComputedRef<{
|
|
93
|
+
[x: string]: any;
|
|
94
|
+
'bm-timeline-item-head': boolean;
|
|
95
|
+
'bm-timeline-item-head-custom': any;
|
|
96
|
+
}>;
|
|
97
|
+
customColor: import("vue").ComputedRef<string | undefined>;
|
|
98
|
+
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
99
|
+
color: import("vue-types").VueTypeDef<string> & {
|
|
100
|
+
default: string;
|
|
101
|
+
};
|
|
102
|
+
dot: import("vue-types").VueTypeValidableDef<any> & {
|
|
103
|
+
default: any;
|
|
104
|
+
};
|
|
105
|
+
label: import("vue-types").VueTypeValidableDef<any> & {
|
|
106
|
+
default: any;
|
|
107
|
+
};
|
|
108
|
+
}>>, {
|
|
109
|
+
color: string;
|
|
110
|
+
label: any;
|
|
111
|
+
dot: any;
|
|
112
|
+
}>>;
|
|
4
113
|
export { BmTimeline, BmTimelineItem };
|
|
5
114
|
export default BmTimeline;
|
|
@@ -1,3 +1,140 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import type { UploadProps, UploadPropsInner, ExtraProps, DefaultList, UploadRequest, CustomErrors } from './src/props';
|
|
2
|
+
declare const BmUpload: import("bm-admin-ui/es/utils/with-install").SFCWithInstall<{
|
|
3
|
+
name: string;
|
|
4
|
+
components: {
|
|
5
|
+
PlusOutlined: import("@ant-design/icons-vue/lib/icons/PlusOutlined").PlusOutlinedIconType;
|
|
6
|
+
OverTooltips: import("bm-admin-ui/es/utils/with-install").SFCWithInstall<{
|
|
7
|
+
name: string;
|
|
8
|
+
props: {
|
|
9
|
+
title: {
|
|
10
|
+
type: StringConstructor;
|
|
11
|
+
default: undefined;
|
|
12
|
+
};
|
|
13
|
+
labelTitle: {
|
|
14
|
+
type: StringConstructor;
|
|
15
|
+
default: undefined;
|
|
16
|
+
};
|
|
17
|
+
line: {
|
|
18
|
+
type: NumberConstructor;
|
|
19
|
+
default: number;
|
|
20
|
+
};
|
|
21
|
+
width: {
|
|
22
|
+
type: (NumberConstructor | StringConstructor)[];
|
|
23
|
+
default: number;
|
|
24
|
+
};
|
|
25
|
+
showAlways: {
|
|
26
|
+
type: BooleanConstructor;
|
|
27
|
+
default: boolean;
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
setup(props: any, context: any): {
|
|
31
|
+
mySelf: import("vue").Ref<any>;
|
|
32
|
+
handleVisibleChange: (val: any) => void;
|
|
33
|
+
getPopupContainer: () => HTMLElement;
|
|
34
|
+
mSlots: import("vue").Ref<{}>;
|
|
35
|
+
isShow: import("vue").Ref<boolean>;
|
|
36
|
+
openShow: import("vue").Ref<boolean>;
|
|
37
|
+
};
|
|
38
|
+
}>;
|
|
39
|
+
UploadOutlined: import("@ant-design/icons-vue/lib/icons/UploadOutlined").UploadOutlinedIconType;
|
|
40
|
+
LoadingOutlined: import("@ant-design/icons-vue/lib/icons/LoadingOutlined").LoadingOutlinedIconType;
|
|
41
|
+
InboxOutlined: import("@ant-design/icons-vue/lib/icons/InboxOutlined").InboxOutlinedIconType;
|
|
42
|
+
};
|
|
43
|
+
props: {
|
|
44
|
+
uploadProps: {
|
|
45
|
+
type: import("vue").PropType<UploadPropsInner>;
|
|
46
|
+
default: () => {};
|
|
47
|
+
};
|
|
48
|
+
extraProps: {
|
|
49
|
+
type: import("vue").PropType<ExtraProps>;
|
|
50
|
+
default: () => {};
|
|
51
|
+
};
|
|
52
|
+
defaultList: {
|
|
53
|
+
type: import("vue").PropType<DefaultList>;
|
|
54
|
+
default: () => never[];
|
|
55
|
+
};
|
|
56
|
+
uploadRequest: {
|
|
57
|
+
type: import("vue").PropType<UploadRequest>;
|
|
58
|
+
default(): () => void;
|
|
59
|
+
};
|
|
60
|
+
cloudReadUrl: {
|
|
61
|
+
type: import("vue").PropType<string>;
|
|
62
|
+
default: string;
|
|
63
|
+
};
|
|
64
|
+
holdProgress: {
|
|
65
|
+
type: import("vue").PropType<number>;
|
|
66
|
+
default: number;
|
|
67
|
+
};
|
|
68
|
+
customErrors: {
|
|
69
|
+
type: import("vue").PropType<CustomErrors>;
|
|
70
|
+
default(): undefined;
|
|
71
|
+
};
|
|
72
|
+
};
|
|
73
|
+
emits: string[];
|
|
74
|
+
setup(props: any, { emit }: {
|
|
75
|
+
emit: any;
|
|
76
|
+
}): {
|
|
77
|
+
uploadDisabled: import("vue").ComputedRef<boolean>;
|
|
78
|
+
updateUploadProgress(file: any, progress: any): void;
|
|
79
|
+
customUploadRequest(file: any): void;
|
|
80
|
+
fileIsDelete(file: any): boolean;
|
|
81
|
+
uploadSuccess(data: any, file: any): void;
|
|
82
|
+
uploadError(error: any, file?: any): void;
|
|
83
|
+
deleteFile(uid: any): Promise<void>;
|
|
84
|
+
pictureHoverEnter(uid: string): void;
|
|
85
|
+
pictureHoverLeave(uid: string): void;
|
|
86
|
+
viewOnePicture(item: any): void;
|
|
87
|
+
handleClosePictureView(): void;
|
|
88
|
+
reUpload(e: any, uid: any): void;
|
|
89
|
+
paste(event: ClipboardEvent): void;
|
|
90
|
+
handleReject(e: any): void;
|
|
91
|
+
icons: {
|
|
92
|
+
pdf: string;
|
|
93
|
+
ppt: string;
|
|
94
|
+
excel: string;
|
|
95
|
+
doc: string;
|
|
96
|
+
others: string;
|
|
97
|
+
};
|
|
98
|
+
uploadBarColor: import("vue").Ref<string>;
|
|
99
|
+
uploadedList: import("vue").Ref<any[]>;
|
|
100
|
+
fileList: import("vue").Ref<{}>;
|
|
101
|
+
onepViewImageHover: import("vue").Ref<{}>;
|
|
102
|
+
previewVisible: import("vue").Ref<boolean>;
|
|
103
|
+
onepViewImage: import("vue").Ref<{}>;
|
|
104
|
+
extraConfigs: import("vue").Ref<{
|
|
105
|
+
maxSize: number;
|
|
106
|
+
maxCount: number;
|
|
107
|
+
isAllowDownloadFieldProps: boolean;
|
|
108
|
+
hideDisabledBtn: boolean;
|
|
109
|
+
tips: string;
|
|
110
|
+
showTips: boolean;
|
|
111
|
+
btnClass: string;
|
|
112
|
+
picClass: string;
|
|
113
|
+
alignCenter: boolean;
|
|
114
|
+
canNotViewAccept: string;
|
|
115
|
+
myBtn: boolean;
|
|
116
|
+
showFileName: boolean;
|
|
117
|
+
drag: boolean;
|
|
118
|
+
}>;
|
|
119
|
+
uploadConfigs: import("vue").Ref<{
|
|
120
|
+
multiple: boolean;
|
|
121
|
+
showUploadList: boolean;
|
|
122
|
+
showSlotList: boolean;
|
|
123
|
+
listType: string;
|
|
124
|
+
text: string;
|
|
125
|
+
accept: string;
|
|
126
|
+
data: {};
|
|
127
|
+
name: string;
|
|
128
|
+
disabled: boolean;
|
|
129
|
+
customRequest: ({ file, fileField, data }: {
|
|
130
|
+
file: any;
|
|
131
|
+
fileField: any;
|
|
132
|
+
data: any;
|
|
133
|
+
}) => Promise<void>;
|
|
134
|
+
}>;
|
|
135
|
+
pictureFileTypes: import("vue").Ref<string[]>;
|
|
136
|
+
};
|
|
137
|
+
}>;
|
|
138
|
+
export { BmUpload, UploadPropsInner, ExtraProps, DefaultList, UploadRequest, CustomErrors, };
|
|
139
|
+
export type { UploadProps };
|
|
3
140
|
export default BmUpload;
|