bhd-components 0.4.5 → 0.4.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (37) hide show
  1. package/es2017/bhdAppLayout/components/BhdTableSimple/index.js +96 -0
  2. package/es2017/bhdAppLayout/components/BhdTableSimple/index.less +52 -0
  3. package/es2017/bhdAppLayout/index.d.ts +28 -0
  4. package/es2017/bhdAppLayout/index.js +128 -0
  5. package/es2017/bhdAppLayout/index.module.less +95 -0
  6. package/es2017/i18n/en_US.d.ts +8 -0
  7. package/es2017/i18n/en_US.js +8 -0
  8. package/es2017/i18n/index.d.ts +2 -0
  9. package/es2017/i18n/index.js +15 -0
  10. package/es2017/i18n/zh_CN.d.ts +8 -0
  11. package/es2017/i18n/zh_CN.js +8 -0
  12. package/es2017/images/index.d.ts +2 -0
  13. package/es2017/images/index.js +2 -0
  14. package/es2017/images/notData.js +2 -0
  15. package/es2017/images/serverError.js +2 -0
  16. package/es2017/index.d.ts +1 -0
  17. package/es2017/index.js +1 -0
  18. package/es2017/titleBar/index.d.ts +1 -1
  19. package/esm/bhdAppLayout/components/BhdTableSimple/index.js +96 -0
  20. package/esm/bhdAppLayout/components/BhdTableSimple/index.less +52 -0
  21. package/esm/bhdAppLayout/index.d.ts +28 -0
  22. package/esm/bhdAppLayout/index.js +130 -0
  23. package/esm/bhdAppLayout/index.module.less +95 -0
  24. package/esm/i18n/en_US.d.ts +8 -0
  25. package/esm/i18n/en_US.js +8 -0
  26. package/esm/i18n/index.d.ts +2 -0
  27. package/esm/i18n/index.js +15 -0
  28. package/esm/i18n/zh_CN.d.ts +8 -0
  29. package/esm/i18n/zh_CN.js +8 -0
  30. package/esm/images/index.d.ts +2 -0
  31. package/esm/images/index.js +2 -0
  32. package/esm/images/notData.js +2 -0
  33. package/esm/images/serverError.js +2 -0
  34. package/esm/index.d.ts +1 -0
  35. package/esm/index.js +1 -0
  36. package/esm/titleBar/index.d.ts +1 -1
  37. package/package.json +1 -1
@@ -0,0 +1,96 @@
1
+ import { _ as _object_spread } from "@swc/helpers/_/_object_spread";
2
+ import { _ as _object_spread_props } from "@swc/helpers/_/_object_spread_props";
3
+ import { jsx as _jsx, jsxs as _jsxs } from "@ice/jsx-runtime/jsx-runtime";
4
+ import * as React from "react";
5
+ import "./index.less";
6
+ import Table from "../../../table";
7
+ import { Loading, NotData, ServerError } from "../../../images";
8
+ import i18Conversion from "../../../i18n";
9
+ /*
10
+ 参数与Table一致
11
+
12
+ ajaxErr:接口是否报错
13
+ notDataText:无数据时,显示的文案
14
+ borderBottom: 是否显示下边框线
15
+ loading:是否加载中
16
+ className
17
+ 超长内容 出现滚动条 需在管理列定义好width 没有定义的max-width:300
18
+ */ const BhdTableSimple = (props)=>{
19
+ let { className , locale , borderBottom =false , rowSelection , ajaxErr , dataSource , kind ="simple" , loading , notDataText =i18Conversion("noData") } = props;
20
+ const renderTableText = ()=>{
21
+ if (ajaxErr) {
22
+ return /*#__PURE__*/ _jsxs("div", {
23
+ className: "app_BhdTableSimple_errorTable",
24
+ children: [
25
+ /*#__PURE__*/ _jsx("img", {
26
+ src: ServerError,
27
+ alt: "",
28
+ srcset: ""
29
+ }),
30
+ /*#__PURE__*/ _jsx("p", {
31
+ children: i18Conversion("系统繁忙,稍后重试!")
32
+ })
33
+ ]
34
+ });
35
+ }
36
+ if (loading) {
37
+ return /*#__PURE__*/ _jsx("div", {
38
+ className: "app_BhdTableSimple_noTable",
39
+ style: {
40
+ minHeight: "150px"
41
+ }
42
+ });
43
+ } else {
44
+ return /*#__PURE__*/ _jsxs("div", {
45
+ className: "app_BhdTableSimple_noTable",
46
+ style: {
47
+ width: "100%"
48
+ },
49
+ children: [
50
+ /*#__PURE__*/ _jsx("img", {
51
+ src: NotData,
52
+ alt: ""
53
+ }),
54
+ /*#__PURE__*/ _jsx("div", {
55
+ children: notDataText
56
+ })
57
+ ]
58
+ });
59
+ }
60
+ };
61
+ if (kind === "simple") {
62
+ /* simple 模式下 高度为48px */ className += " app_BhdTableSimple_simple";
63
+ }
64
+ if (loading) {
65
+ return /*#__PURE__*/ _jsxs("div", {
66
+ className: "app_BhdTableSimple_noTable app_BhdTableSimple_noTable_loadingTable",
67
+ children: [
68
+ /*#__PURE__*/ _jsx("img", {
69
+ src: Loading,
70
+ alt: "",
71
+ style: {
72
+ width: "48px",
73
+ height: "48px"
74
+ }
75
+ }),
76
+ /*#__PURE__*/ _jsx("p", {
77
+ children: i18Conversion("Load")
78
+ })
79
+ ]
80
+ });
81
+ }
82
+ return /*#__PURE__*/ _jsx(Table, _object_spread_props(_object_spread({
83
+ style: {
84
+ width: "100%"
85
+ }
86
+ }, props), {
87
+ loading: false,
88
+ dataSource: ajaxErr ? [] : dataSource,
89
+ className: `app_BhdTableSimple ${className || " "} ${rowSelection ? "app_BhdTableSimple_rowSelection" : ""}`,
90
+ locale: locale || {
91
+ emptyText: renderTableText()
92
+ },
93
+ scroll: props.scroll
94
+ }));
95
+ };
96
+ export default BhdTableSimple;
@@ -0,0 +1,52 @@
1
+ @import "../../../theme/variable.less";
2
+ .app_BhdTableSimple {
3
+ /* 无数据样式 */
4
+ .app_BhdTableSimple_noTable {
5
+ padding: 24px 0;
6
+ img {
7
+ width: 200px;
8
+ height: 200px;
9
+ margin-bottom: 24px;
10
+ }
11
+ div {
12
+ color: @color-text-tertiary-Tr;
13
+ font-size: 14px;
14
+ }
15
+ }
16
+
17
+ /* 错误样式 */
18
+ .app_BhdTableSimple_errorTable {
19
+ padding: 24px 0;
20
+ img {
21
+ width: 200px;
22
+ height: 200px;
23
+ margin-bottom: 24px;
24
+ }
25
+ p {
26
+ color: @color-text-tertiary-Tr;
27
+ font-size: 14px;
28
+ span {
29
+ color: rgba(240, 93, 59, 1);
30
+ cursor: pointer;
31
+ }
32
+ }
33
+ }
34
+
35
+
36
+
37
+ }
38
+
39
+ /* 加载样式 */
40
+ .app_BhdTableSimple_noTable_loadingTable {
41
+ display: flex;
42
+ align-items: center;
43
+ justify-content: center;
44
+ flex-direction: column;
45
+ position: absolute;
46
+ top: 50%;
47
+ left: 50%;
48
+ transform: translate(-50%, -50%);
49
+ img {
50
+ margin-bottom: 24px;
51
+ }
52
+ }
@@ -0,0 +1,28 @@
1
+ import * as React from "react";
2
+ import { TitleBarProps } from "../titleBar";
3
+ import { PaginationProps } from "antd";
4
+ interface footerConfigProps extends PaginationProps {
5
+ leftDom: React.ReactElement;
6
+ }
7
+ interface BhdAppLayoutProps {
8
+ className?: string;
9
+ headerClassName?: string;
10
+ tableBoxClassName?: string;
11
+ headConfig?: TitleBarProps;
12
+ filterConfig?: {
13
+ filterArr: {
14
+ id: string | number;
15
+ title: string | number;
16
+ value: string | number;
17
+ }[];
18
+ onClearSingle: () => void;
19
+ onClearAll: () => void;
20
+ };
21
+ headContent?: any;
22
+ otherContent?: any;
23
+ tableConfig?: any;
24
+ footerConfig?: footerConfigProps;
25
+ scrollConfig?: any;
26
+ }
27
+ declare function BhdAppLayout(props: BhdAppLayoutProps): React.JSX.Element;
28
+ export default BhdAppLayout;
@@ -0,0 +1,128 @@
1
+ import { _ as _object_spread } from "@swc/helpers/_/_object_spread";
2
+ import { _ as _object_spread_props } from "@swc/helpers/_/_object_spread_props";
3
+ import { jsx as _jsx, jsxs as _jsxs } from "@ice/jsx-runtime/jsx-runtime";
4
+ import * as React from "react";
5
+ import { useState, useLayoutEffect, useRef } from "react";
6
+ import styles from "./index.module.less";
7
+ import TitleBar from "../titleBar";
8
+ import { Pagination } from "antd";
9
+ import i18Conversion from "../i18n";
10
+ import BhdTableSimple from "./components/BhdTableSimple/index";
11
+ function BhdAppLayout(props) {
12
+ var _filterRef_current, _headRef_current, _otherHeadRef_current, _otherContentRef_current;
13
+ const { className , headerClassName , tableBoxClassName , headConfig , filterConfig , headContent , otherContent , tableConfig , footerConfig } = props;
14
+ const [scrollY, setScrollY] = useState("");
15
+ const [scrollConfig, setScrollConfig] = useState(props.scrollConfig);
16
+ const windowChange = ()=>{
17
+ var _headRef_current, _headRef_current1, _filterRef_current, _filterRef_current1, _otherHeadRef_current, _otherHeadRef_current1, _otherContentRef_current, _otherContentRef_current1;
18
+ let headRefHeight = isNaN(headRef === null || headRef === void 0 ? void 0 : (_headRef_current = headRef.current) === null || _headRef_current === void 0 ? void 0 : _headRef_current.offsetHeight) ? 0 : headRef === null || headRef === void 0 ? void 0 : (_headRef_current1 = headRef.current) === null || _headRef_current1 === void 0 ? void 0 : _headRef_current1.offsetHeight;
19
+ let filterRefHeight = isNaN(filterRef === null || filterRef === void 0 ? void 0 : (_filterRef_current = filterRef.current) === null || _filterRef_current === void 0 ? void 0 : _filterRef_current.offsetHeight) ? 0 : filterRef === null || filterRef === void 0 ? void 0 : (_filterRef_current1 = filterRef.current) === null || _filterRef_current1 === void 0 ? void 0 : _filterRef_current1.offsetHeight;
20
+ let otherHeadRefHeight = isNaN(otherHeadRef === null || otherHeadRef === void 0 ? void 0 : (_otherHeadRef_current = otherHeadRef.current) === null || _otherHeadRef_current === void 0 ? void 0 : _otherHeadRef_current.offsetHeight) ? 0 : otherHeadRef === null || otherHeadRef === void 0 ? void 0 : (_otherHeadRef_current1 = otherHeadRef.current) === null || _otherHeadRef_current1 === void 0 ? void 0 : _otherHeadRef_current1.offsetHeight;
21
+ let otherContentRefHeight = isNaN(otherContentRef === null || otherContentRef === void 0 ? void 0 : (_otherContentRef_current = otherContentRef.current) === null || _otherContentRef_current === void 0 ? void 0 : _otherContentRef_current.offsetHeight) ? 0 : otherContentRef === null || otherContentRef === void 0 ? void 0 : (_otherContentRef_current1 = otherContentRef.current) === null || _otherContentRef_current1 === void 0 ? void 0 : _otherContentRef_current1.offsetHeight;
22
+ const height = headRefHeight + filterRefHeight + otherHeadRefHeight + otherContentRefHeight + 56 + 16 + 60 + 50;
23
+ const offsetHeight = `calc(100vh - ${height}px)`;
24
+ setScrollY(offsetHeight);
25
+ setScrollConfig(_object_spread_props(_object_spread({}, props.scrollConfig), {
26
+ y: offsetHeight
27
+ }));
28
+ };
29
+ const headRef = useRef(null);
30
+ const otherHeadRef = useRef(null);
31
+ const otherContentRef = useRef(null);
32
+ const filterRef = useRef(null);
33
+ useLayoutEffect(()=>{
34
+ windowChange();
35
+ }, []);
36
+ useLayoutEffect(()=>{
37
+ windowChange();
38
+ }, [
39
+ filterRef === null || filterRef === void 0 ? void 0 : (_filterRef_current = filterRef.current) === null || _filterRef_current === void 0 ? void 0 : _filterRef_current.offsetHeight,
40
+ headRef === null || headRef === void 0 ? void 0 : (_headRef_current = headRef.current) === null || _headRef_current === void 0 ? void 0 : _headRef_current.offsetHeight,
41
+ otherHeadRef === null || otherHeadRef === void 0 ? void 0 : (_otherHeadRef_current = otherHeadRef.current) === null || _otherHeadRef_current === void 0 ? void 0 : _otherHeadRef_current.offsetHeight,
42
+ otherContentRef === null || otherContentRef === void 0 ? void 0 : (_otherContentRef_current = otherContentRef.current) === null || _otherContentRef_current === void 0 ? void 0 : _otherContentRef_current.offsetHeight
43
+ ]);
44
+ return /*#__PURE__*/ _jsxs("div", {
45
+ className: `${styles.bhd_app_layout} ${styles.className} ${className || ""}`,
46
+ children: [
47
+ /*#__PURE__*/ _jsx("header", {
48
+ ref: headRef,
49
+ className: `${styles.bhd_app_layout_header} ${headerClassName || ""}`,
50
+ children: headConfig && /*#__PURE__*/ _jsx(TitleBar, _object_spread({}, headConfig))
51
+ }),
52
+ headContent && /*#__PURE__*/ _jsx("div", {
53
+ ref: otherHeadRef,
54
+ children: headContent
55
+ }),
56
+ /*#__PURE__*/ _jsxs("main", {
57
+ className: styles.bhd_app_layout_main,
58
+ children: [
59
+ (filterConfig === null || filterConfig === void 0 ? void 0 : filterConfig.filterArr) && filterConfig.filterArr.length ? /*#__PURE__*/ _jsxs("div", {
60
+ ref: filterRef,
61
+ className: styles.bhd_app_layout_main_filter,
62
+ children: [
63
+ /*#__PURE__*/ _jsxs("div", {
64
+ className: styles.bhd_app_layout_main_filter_title,
65
+ children: [
66
+ i18Conversion("已筛选"),
67
+ ":"
68
+ ]
69
+ }),
70
+ /*#__PURE__*/ _jsx("ul", {
71
+ className: styles.bhd_app_layout_main_filter_ul,
72
+ children: filterConfig.filterArr.map((ele, index)=>{
73
+ var _filterConfig_onClearSingle;
74
+ return /*#__PURE__*/ _jsxs("li", {
75
+ children: [
76
+ /*#__PURE__*/ _jsx("span", {
77
+ className: styles.bhd_app_layout_main_filter_show_title,
78
+ children: ele.title
79
+ }),
80
+ /*#__PURE__*/ _jsxs("span", {
81
+ className: styles.bhd_app_layout_main_filter_show_value,
82
+ children: [
83
+ "“",
84
+ ele.value,
85
+ "”"
86
+ ]
87
+ }),
88
+ /*#__PURE__*/ _jsx("i", {
89
+ onClick: filterConfig === null || filterConfig === void 0 ? void 0 : (_filterConfig_onClearSingle = filterConfig.onClearSingle) === null || _filterConfig_onClearSingle === void 0 ? void 0 : _filterConfig_onClearSingle.bind(this, ele.id),
90
+ className: "iconfont iconicon_guanbi_Close"
91
+ })
92
+ ]
93
+ }, ele.id);
94
+ })
95
+ }),
96
+ /*#__PURE__*/ _jsx("div", {
97
+ onClick: filterConfig === null || filterConfig === void 0 ? void 0 : filterConfig.onClearAll,
98
+ className: styles.bhd_app_layout_main_filter_clear,
99
+ children: i18Conversion("清空条件")
100
+ })
101
+ ]
102
+ }) : null,
103
+ otherContent && /*#__PURE__*/ _jsx("div", {
104
+ ref: otherContentRef,
105
+ children: otherContent
106
+ }),
107
+ /*#__PURE__*/ _jsx("div", {
108
+ className: `${styles.bhd_app_layout_main_table} ${tableBoxClassName || ""}`,
109
+ children: scrollConfig ? tableConfig && /*#__PURE__*/ _jsx(BhdTableSimple, _object_spread_props(_object_spread({}, tableConfig), {
110
+ pagination: false,
111
+ scroll: _object_spread({}, scrollConfig)
112
+ })) : null
113
+ })
114
+ ]
115
+ }),
116
+ footerConfig ? /*#__PURE__*/ _jsxs("footer", {
117
+ className: styles.bhd_app_layout_footer,
118
+ children: [
119
+ /*#__PURE__*/ _jsx("div", {
120
+ children: (footerConfig === null || footerConfig === void 0 ? void 0 : footerConfig.leftDom) && footerConfig.leftDom
121
+ }),
122
+ /*#__PURE__*/ _jsx(Pagination, _object_spread({}, footerConfig))
123
+ ]
124
+ }) : null
125
+ ]
126
+ });
127
+ }
128
+ export default BhdAppLayout;
@@ -0,0 +1,95 @@
1
+ @import "../theme/variable.less";
2
+ .bhd_app_layout {
3
+ display: flex;
4
+ flex-direction: column;
5
+ height: calc(100vh - 60px);
6
+ background-color: #fff;
7
+ :global {
8
+ }
9
+ .bhd_app_layout_header {
10
+ background: #FFFFFF;
11
+ padding: 12px 48px;
12
+ border-bottom: 1px solid rgba(0, 0, 0, 0.06);
13
+ }
14
+ .bhd_app_layout_main {
15
+ flex: 1;
16
+ margin-bottom: 56px;
17
+ .bhd_app_layout_main_filter {
18
+ min-height: 40px;
19
+ background: rgba(0,0,0,0.02);
20
+ border-bottom: 1px solid rgba(0,0,0,0.06);
21
+ padding: 0 48px;
22
+ display: flex;
23
+ align-items: center;
24
+ .bhd_app_layout_main_filter_title {
25
+ color: rgba(0, 0, 0, 0.65);
26
+ font-size: 12px;
27
+ }
28
+ .bhd_app_layout_main_filter_ul {
29
+ display: flex;
30
+ align-items: center;
31
+ li:nth-of-type(1) {
32
+ margin-left: 0;
33
+ }
34
+ li {
35
+ margin-left: 8px;
36
+ border: 1px solid rgba(0, 0, 0, 0.15);
37
+ border-radius: 2px;
38
+ height: 24px;
39
+ color: rgba(0, 0, 0, 0.65);
40
+ font-size: 12px;
41
+ display: flex;
42
+ align-items: center;
43
+ padding: 0 8px;
44
+ * {
45
+ line-height: 1;
46
+ }
47
+ .bhd_app_layout_main_filter_show_title {
48
+
49
+ }
50
+ .bhd_app_layout_main_filter_show_value {
51
+ margin-left: 4px;
52
+ margin-right: 8px;
53
+ }
54
+ :global {
55
+ .iconicon_guanbi_Close {
56
+ font-size: 12px;
57
+ }
58
+ .iconicon_guanbi_Close:hover {
59
+ cursor: pointer;
60
+ }
61
+ }
62
+ }
63
+ }
64
+ .bhd_app_layout_main_filter_clear {
65
+ color: #F4523B;
66
+ font-size: 12px;
67
+ margin-left: 8px;
68
+ cursor: pointer;
69
+ }
70
+ }
71
+ .bhd_app_layout_main_table {
72
+ padding: 0 48px;
73
+ margin-top: 16px;
74
+ :global{
75
+ /* table 无数据,异常时 */
76
+ .app_BhdTableSimple_errorTable,.app_BhdTableSimple_noTable{
77
+ padding-top: 120px;
78
+ }
79
+ }
80
+ }
81
+ }
82
+ .bhd_app_layout_footer {
83
+ width: calc(100% - 60px);
84
+ height: 56px;
85
+ position: fixed;
86
+ z-index: 10;
87
+ bottom: 0;
88
+ display: flex;
89
+ background-color: #fff;
90
+ align-items: center;
91
+ padding: 0 48px;
92
+ justify-content: space-between;
93
+ border-top: 1px solid rgba(0,0,0,0.15);
94
+ }
95
+ }
@@ -0,0 +1,8 @@
1
+ declare const en_US: {
2
+ 已筛选: string;
3
+ 清空条件: string;
4
+ noData: string;
5
+ "\u7CFB\u7EDF\u7E41\u5FD9,\u7A0D\u540E\u91CD\u8BD5!": string;
6
+ Load: string;
7
+ };
8
+ export default en_US;
@@ -0,0 +1,8 @@
1
+ const en_US = {
2
+ 已筛选: "screened",
3
+ 清空条件: "Emptying condition",
4
+ noData: "No Data",
5
+ "系统繁忙,稍后重试!": "",
6
+ Load: "Loading..."
7
+ };
8
+ export default en_US;
@@ -0,0 +1,2 @@
1
+ declare const i18Conversion: (str: string, lang?: "zh_CN" | "en_US") => any;
2
+ export default i18Conversion;
@@ -0,0 +1,15 @@
1
+ import zh_CN from "./zh_CN";
2
+ import en_US from "./en_US";
3
+ import { useLocale } from "antd/es/locale";
4
+ const i18Conversion = (str, lang)=>{
5
+ if (!lang) {
6
+ lang = useLocale("Pagination")[1] === "zh-cn" ? "zh_CN" : "en_US";
7
+ }
8
+ if (lang === "zh_CN") {
9
+ return zh_CN[str];
10
+ } else if (lang === "en_US") {
11
+ return en_US[str];
12
+ }
13
+ return str;
14
+ };
15
+ export default i18Conversion;
@@ -0,0 +1,8 @@
1
+ declare const zh_CN: {
2
+ 已筛选: string;
3
+ 清空条件: string;
4
+ noData: string;
5
+ "\u7CFB\u7EDF\u7E41\u5FD9,\u7A0D\u540E\u91CD\u8BD5!": string;
6
+ Load: string;
7
+ };
8
+ export default zh_CN;
@@ -0,0 +1,8 @@
1
+ const zh_CN = {
2
+ 已筛选: "已筛选",
3
+ 清空条件: "清空条件",
4
+ noData: "No Data",
5
+ "系统繁忙,稍后重试!": "系统繁忙,稍后重试!",
6
+ Load: "正在加载..."
7
+ };
8
+ export default zh_CN;
@@ -1,4 +1,6 @@
1
1
  export { default as Loading } from "./loading";
2
+ export { default as NotData } from "./notData";
3
+ export { default as ServerError } from "./serverError";
2
4
  export { default as Confirm } from "./confirm";
3
5
  export { default as Success } from "./success";
4
6
  export { default as Info } from "./info";
@@ -1,4 +1,6 @@
1
1
  export { default as Loading } from "./loading";
2
+ export { default as NotData } from "./notData";
3
+ export { default as ServerError } from "./serverError";
2
4
  export { default as Confirm } from "./confirm";
3
5
  export { default as Success } from "./success";
4
6
  export { default as Info } from "./info";
@@ -0,0 +1,2 @@
1
+ const NotData = "";
2
+ export default NotData;
@@ -0,0 +1,2 @@
1
+ const ServerError = "";
2
+ export default ServerError;
package/es2017/index.d.ts CHANGED
@@ -76,3 +76,4 @@ export { default as TitleBar } from "./titleBar";
76
76
  export { default as ViewImage } from "./viewImage";
77
77
  export { default as BhdTipModal } from "./bhdTipModal";
78
78
  export { default as BhdSelect } from './bhdSelect';
79
+ export { default as BhdAppLayout } from './bhdAppLayout';
package/es2017/index.js CHANGED
@@ -81,3 +81,4 @@ export { default as TitleBar } from "./titleBar/index"; //标题栏
81
81
  export { default as ViewImage } from "./viewImage/index"; //查看大图
82
82
  export { default as BhdTipModal } from "./bhdTipModal/index"; //提示框
83
83
  export { default as BhdSelect } from "./bhdSelect/index"; //封装 bhdSelect
84
+ export { default as BhdAppLayout } from "./bhdAppLayout/index"; //封装 BhdAppLayout
@@ -1,5 +1,5 @@
1
1
  import * as React from "react";
2
- interface TitleBarProps {
2
+ export interface TitleBarProps {
3
3
  title?: React.ReactElement;
4
4
  leftIcon?: React.ReactElement;
5
5
  subTitle?: React.ReactElement;
@@ -0,0 +1,96 @@
1
+ import { _ as _object_spread } from "@swc/helpers/_/_object_spread";
2
+ import { _ as _object_spread_props } from "@swc/helpers/_/_object_spread_props";
3
+ import { jsx as _jsx, jsxs as _jsxs } from "@ice/jsx-runtime/jsx-runtime";
4
+ import * as React from "react";
5
+ import "./index.less";
6
+ import Table from "../../../table";
7
+ import { Loading, NotData, ServerError } from "../../../images";
8
+ import i18Conversion from "../../../i18n";
9
+ /*
10
+ 参数与Table一致
11
+
12
+ ajaxErr:接口是否报错
13
+ notDataText:无数据时,显示的文案
14
+ borderBottom: 是否显示下边框线
15
+ loading:是否加载中
16
+ className
17
+ 超长内容 出现滚动条 需在管理列定义好width 没有定义的max-width:300
18
+ */ var BhdTableSimple = function(props) {
19
+ var className = props.className, locale = props.locale, _props_borderBottom = props.borderBottom, borderBottom = _props_borderBottom === void 0 ? false : _props_borderBottom, rowSelection = props.rowSelection, ajaxErr = props.ajaxErr, dataSource = props.dataSource, _props_kind = props.kind, kind = _props_kind === void 0 ? "simple" : _props_kind, loading = props.loading, _props_notDataText = props.notDataText, notDataText = _props_notDataText === void 0 ? i18Conversion("noData") : _props_notDataText;
20
+ var renderTableText = function() {
21
+ if (ajaxErr) {
22
+ return /*#__PURE__*/ _jsxs("div", {
23
+ className: "app_BhdTableSimple_errorTable",
24
+ children: [
25
+ /*#__PURE__*/ _jsx("img", {
26
+ src: ServerError,
27
+ alt: "",
28
+ srcset: ""
29
+ }),
30
+ /*#__PURE__*/ _jsx("p", {
31
+ children: i18Conversion("系统繁忙,稍后重试!")
32
+ })
33
+ ]
34
+ });
35
+ }
36
+ if (loading) {
37
+ return /*#__PURE__*/ _jsx("div", {
38
+ className: "app_BhdTableSimple_noTable",
39
+ style: {
40
+ minHeight: "150px"
41
+ }
42
+ });
43
+ } else {
44
+ return /*#__PURE__*/ _jsxs("div", {
45
+ className: "app_BhdTableSimple_noTable",
46
+ style: {
47
+ width: "100%"
48
+ },
49
+ children: [
50
+ /*#__PURE__*/ _jsx("img", {
51
+ src: NotData,
52
+ alt: ""
53
+ }),
54
+ /*#__PURE__*/ _jsx("div", {
55
+ children: notDataText
56
+ })
57
+ ]
58
+ });
59
+ }
60
+ };
61
+ if (kind === "simple") {
62
+ /* simple 模式下 高度为48px */ className += " app_BhdTableSimple_simple";
63
+ }
64
+ if (loading) {
65
+ return /*#__PURE__*/ _jsxs("div", {
66
+ className: "app_BhdTableSimple_noTable app_BhdTableSimple_noTable_loadingTable",
67
+ children: [
68
+ /*#__PURE__*/ _jsx("img", {
69
+ src: Loading,
70
+ alt: "",
71
+ style: {
72
+ width: "48px",
73
+ height: "48px"
74
+ }
75
+ }),
76
+ /*#__PURE__*/ _jsx("p", {
77
+ children: i18Conversion("Load")
78
+ })
79
+ ]
80
+ });
81
+ }
82
+ return /*#__PURE__*/ _jsx(Table, _object_spread_props(_object_spread({
83
+ style: {
84
+ width: "100%"
85
+ }
86
+ }, props), {
87
+ loading: false,
88
+ dataSource: ajaxErr ? [] : dataSource,
89
+ className: "app_BhdTableSimple ".concat(className || " ", " ").concat(rowSelection ? "app_BhdTableSimple_rowSelection" : ""),
90
+ locale: locale || {
91
+ emptyText: renderTableText()
92
+ },
93
+ scroll: props.scroll
94
+ }));
95
+ };
96
+ export default BhdTableSimple;
@@ -0,0 +1,52 @@
1
+ @import "../../../theme/variable.less";
2
+ .app_BhdTableSimple {
3
+ /* 无数据样式 */
4
+ .app_BhdTableSimple_noTable {
5
+ padding: 24px 0;
6
+ img {
7
+ width: 200px;
8
+ height: 200px;
9
+ margin-bottom: 24px;
10
+ }
11
+ div {
12
+ color: @color-text-tertiary-Tr;
13
+ font-size: 14px;
14
+ }
15
+ }
16
+
17
+ /* 错误样式 */
18
+ .app_BhdTableSimple_errorTable {
19
+ padding: 24px 0;
20
+ img {
21
+ width: 200px;
22
+ height: 200px;
23
+ margin-bottom: 24px;
24
+ }
25
+ p {
26
+ color: @color-text-tertiary-Tr;
27
+ font-size: 14px;
28
+ span {
29
+ color: rgba(240, 93, 59, 1);
30
+ cursor: pointer;
31
+ }
32
+ }
33
+ }
34
+
35
+
36
+
37
+ }
38
+
39
+ /* 加载样式 */
40
+ .app_BhdTableSimple_noTable_loadingTable {
41
+ display: flex;
42
+ align-items: center;
43
+ justify-content: center;
44
+ flex-direction: column;
45
+ position: absolute;
46
+ top: 50%;
47
+ left: 50%;
48
+ transform: translate(-50%, -50%);
49
+ img {
50
+ margin-bottom: 24px;
51
+ }
52
+ }
@@ -0,0 +1,28 @@
1
+ import * as React from "react";
2
+ import { TitleBarProps } from "../titleBar";
3
+ import { PaginationProps } from "antd";
4
+ interface footerConfigProps extends PaginationProps {
5
+ leftDom: React.ReactElement;
6
+ }
7
+ interface BhdAppLayoutProps {
8
+ className?: string;
9
+ headerClassName?: string;
10
+ tableBoxClassName?: string;
11
+ headConfig?: TitleBarProps;
12
+ filterConfig?: {
13
+ filterArr: {
14
+ id: string | number;
15
+ title: string | number;
16
+ value: string | number;
17
+ }[];
18
+ onClearSingle: () => void;
19
+ onClearAll: () => void;
20
+ };
21
+ headContent?: any;
22
+ otherContent?: any;
23
+ tableConfig?: any;
24
+ footerConfig?: footerConfigProps;
25
+ scrollConfig?: any;
26
+ }
27
+ declare function BhdAppLayout(props: BhdAppLayoutProps): React.JSX.Element;
28
+ export default BhdAppLayout;
@@ -0,0 +1,130 @@
1
+ import { _ as _object_spread } from "@swc/helpers/_/_object_spread";
2
+ import { _ as _object_spread_props } from "@swc/helpers/_/_object_spread_props";
3
+ import { _ as _sliced_to_array } from "@swc/helpers/_/_sliced_to_array";
4
+ import { jsx as _jsx, jsxs as _jsxs } from "@ice/jsx-runtime/jsx-runtime";
5
+ import * as React from "react";
6
+ import { useState, useLayoutEffect, useRef } from "react";
7
+ import styles from "./index.module.less";
8
+ import TitleBar from "../titleBar";
9
+ import { Pagination } from "antd";
10
+ import i18Conversion from "../i18n";
11
+ import BhdTableSimple from "./components/BhdTableSimple/index";
12
+ function BhdAppLayout(props) {
13
+ var _this = this;
14
+ var _filterRef_current, _headRef_current, _otherHeadRef_current, _otherContentRef_current;
15
+ var className = props.className, headerClassName = props.headerClassName, tableBoxClassName = props.tableBoxClassName, headConfig = props.headConfig, filterConfig = props.filterConfig, headContent = props.headContent, otherContent = props.otherContent, tableConfig = props.tableConfig, footerConfig = props.footerConfig;
16
+ var _useState = _sliced_to_array(useState(""), 2), scrollY = _useState[0], setScrollY = _useState[1];
17
+ var _useState1 = _sliced_to_array(useState(props.scrollConfig), 2), scrollConfig = _useState1[0], setScrollConfig = _useState1[1];
18
+ var windowChange = function() {
19
+ var _headRef_current, _headRef_current1, _filterRef_current, _filterRef_current1, _otherHeadRef_current, _otherHeadRef_current1, _otherContentRef_current, _otherContentRef_current1;
20
+ var headRefHeight = isNaN(headRef === null || headRef === void 0 ? void 0 : (_headRef_current = headRef.current) === null || _headRef_current === void 0 ? void 0 : _headRef_current.offsetHeight) ? 0 : headRef === null || headRef === void 0 ? void 0 : (_headRef_current1 = headRef.current) === null || _headRef_current1 === void 0 ? void 0 : _headRef_current1.offsetHeight;
21
+ var filterRefHeight = isNaN(filterRef === null || filterRef === void 0 ? void 0 : (_filterRef_current = filterRef.current) === null || _filterRef_current === void 0 ? void 0 : _filterRef_current.offsetHeight) ? 0 : filterRef === null || filterRef === void 0 ? void 0 : (_filterRef_current1 = filterRef.current) === null || _filterRef_current1 === void 0 ? void 0 : _filterRef_current1.offsetHeight;
22
+ var otherHeadRefHeight = isNaN(otherHeadRef === null || otherHeadRef === void 0 ? void 0 : (_otherHeadRef_current = otherHeadRef.current) === null || _otherHeadRef_current === void 0 ? void 0 : _otherHeadRef_current.offsetHeight) ? 0 : otherHeadRef === null || otherHeadRef === void 0 ? void 0 : (_otherHeadRef_current1 = otherHeadRef.current) === null || _otherHeadRef_current1 === void 0 ? void 0 : _otherHeadRef_current1.offsetHeight;
23
+ var otherContentRefHeight = isNaN(otherContentRef === null || otherContentRef === void 0 ? void 0 : (_otherContentRef_current = otherContentRef.current) === null || _otherContentRef_current === void 0 ? void 0 : _otherContentRef_current.offsetHeight) ? 0 : otherContentRef === null || otherContentRef === void 0 ? void 0 : (_otherContentRef_current1 = otherContentRef.current) === null || _otherContentRef_current1 === void 0 ? void 0 : _otherContentRef_current1.offsetHeight;
24
+ var height = headRefHeight + filterRefHeight + otherHeadRefHeight + otherContentRefHeight + 56 + 16 + 60 + 50;
25
+ var offsetHeight = "calc(100vh - ".concat(height, "px)");
26
+ setScrollY(offsetHeight);
27
+ setScrollConfig(_object_spread_props(_object_spread({}, props.scrollConfig), {
28
+ y: offsetHeight
29
+ }));
30
+ };
31
+ var headRef = useRef(null);
32
+ var otherHeadRef = useRef(null);
33
+ var otherContentRef = useRef(null);
34
+ var filterRef = useRef(null);
35
+ useLayoutEffect(function() {
36
+ windowChange();
37
+ }, []);
38
+ useLayoutEffect(function() {
39
+ windowChange();
40
+ }, [
41
+ filterRef === null || filterRef === void 0 ? void 0 : (_filterRef_current = filterRef.current) === null || _filterRef_current === void 0 ? void 0 : _filterRef_current.offsetHeight,
42
+ headRef === null || headRef === void 0 ? void 0 : (_headRef_current = headRef.current) === null || _headRef_current === void 0 ? void 0 : _headRef_current.offsetHeight,
43
+ otherHeadRef === null || otherHeadRef === void 0 ? void 0 : (_otherHeadRef_current = otherHeadRef.current) === null || _otherHeadRef_current === void 0 ? void 0 : _otherHeadRef_current.offsetHeight,
44
+ otherContentRef === null || otherContentRef === void 0 ? void 0 : (_otherContentRef_current = otherContentRef.current) === null || _otherContentRef_current === void 0 ? void 0 : _otherContentRef_current.offsetHeight
45
+ ]);
46
+ return /*#__PURE__*/ _jsxs("div", {
47
+ className: "".concat(styles.bhd_app_layout, " ").concat(styles.className, " ").concat(className || ""),
48
+ children: [
49
+ /*#__PURE__*/ _jsx("header", {
50
+ ref: headRef,
51
+ className: "".concat(styles.bhd_app_layout_header, " ").concat(headerClassName || ""),
52
+ children: headConfig && /*#__PURE__*/ _jsx(TitleBar, _object_spread({}, headConfig))
53
+ }),
54
+ headContent && /*#__PURE__*/ _jsx("div", {
55
+ ref: otherHeadRef,
56
+ children: headContent
57
+ }),
58
+ /*#__PURE__*/ _jsxs("main", {
59
+ className: styles.bhd_app_layout_main,
60
+ children: [
61
+ (filterConfig === null || filterConfig === void 0 ? void 0 : filterConfig.filterArr) && filterConfig.filterArr.length ? /*#__PURE__*/ _jsxs("div", {
62
+ ref: filterRef,
63
+ className: styles.bhd_app_layout_main_filter,
64
+ children: [
65
+ /*#__PURE__*/ _jsxs("div", {
66
+ className: styles.bhd_app_layout_main_filter_title,
67
+ children: [
68
+ i18Conversion("已筛选"),
69
+ ":"
70
+ ]
71
+ }),
72
+ /*#__PURE__*/ _jsx("ul", {
73
+ className: styles.bhd_app_layout_main_filter_ul,
74
+ children: filterConfig.filterArr.map(function(ele, index) {
75
+ var _filterConfig_onClearSingle;
76
+ return /*#__PURE__*/ _jsxs("li", {
77
+ children: [
78
+ /*#__PURE__*/ _jsx("span", {
79
+ className: styles.bhd_app_layout_main_filter_show_title,
80
+ children: ele.title
81
+ }),
82
+ /*#__PURE__*/ _jsxs("span", {
83
+ className: styles.bhd_app_layout_main_filter_show_value,
84
+ children: [
85
+ "“",
86
+ ele.value,
87
+ "”"
88
+ ]
89
+ }),
90
+ /*#__PURE__*/ _jsx("i", {
91
+ onClick: filterConfig === null || filterConfig === void 0 ? void 0 : (_filterConfig_onClearSingle = filterConfig.onClearSingle) === null || _filterConfig_onClearSingle === void 0 ? void 0 : _filterConfig_onClearSingle.bind(_this, ele.id),
92
+ className: "iconfont iconicon_guanbi_Close"
93
+ })
94
+ ]
95
+ }, ele.id);
96
+ })
97
+ }),
98
+ /*#__PURE__*/ _jsx("div", {
99
+ onClick: filterConfig === null || filterConfig === void 0 ? void 0 : filterConfig.onClearAll,
100
+ className: styles.bhd_app_layout_main_filter_clear,
101
+ children: i18Conversion("清空条件")
102
+ })
103
+ ]
104
+ }) : null,
105
+ otherContent && /*#__PURE__*/ _jsx("div", {
106
+ ref: otherContentRef,
107
+ children: otherContent
108
+ }),
109
+ /*#__PURE__*/ _jsx("div", {
110
+ className: "".concat(styles.bhd_app_layout_main_table, " ").concat(tableBoxClassName || ""),
111
+ children: scrollConfig ? tableConfig && /*#__PURE__*/ _jsx(BhdTableSimple, _object_spread_props(_object_spread({}, tableConfig), {
112
+ pagination: false,
113
+ scroll: _object_spread({}, scrollConfig)
114
+ })) : null
115
+ })
116
+ ]
117
+ }),
118
+ footerConfig ? /*#__PURE__*/ _jsxs("footer", {
119
+ className: styles.bhd_app_layout_footer,
120
+ children: [
121
+ /*#__PURE__*/ _jsx("div", {
122
+ children: (footerConfig === null || footerConfig === void 0 ? void 0 : footerConfig.leftDom) && footerConfig.leftDom
123
+ }),
124
+ /*#__PURE__*/ _jsx(Pagination, _object_spread({}, footerConfig))
125
+ ]
126
+ }) : null
127
+ ]
128
+ });
129
+ }
130
+ export default BhdAppLayout;
@@ -0,0 +1,95 @@
1
+ @import "../theme/variable.less";
2
+ .bhd_app_layout {
3
+ display: flex;
4
+ flex-direction: column;
5
+ height: calc(100vh - 60px);
6
+ background-color: #fff;
7
+ :global {
8
+ }
9
+ .bhd_app_layout_header {
10
+ background: #FFFFFF;
11
+ padding: 12px 48px;
12
+ border-bottom: 1px solid rgba(0, 0, 0, 0.06);
13
+ }
14
+ .bhd_app_layout_main {
15
+ flex: 1;
16
+ margin-bottom: 56px;
17
+ .bhd_app_layout_main_filter {
18
+ min-height: 40px;
19
+ background: rgba(0,0,0,0.02);
20
+ border-bottom: 1px solid rgba(0,0,0,0.06);
21
+ padding: 0 48px;
22
+ display: flex;
23
+ align-items: center;
24
+ .bhd_app_layout_main_filter_title {
25
+ color: rgba(0, 0, 0, 0.65);
26
+ font-size: 12px;
27
+ }
28
+ .bhd_app_layout_main_filter_ul {
29
+ display: flex;
30
+ align-items: center;
31
+ li:nth-of-type(1) {
32
+ margin-left: 0;
33
+ }
34
+ li {
35
+ margin-left: 8px;
36
+ border: 1px solid rgba(0, 0, 0, 0.15);
37
+ border-radius: 2px;
38
+ height: 24px;
39
+ color: rgba(0, 0, 0, 0.65);
40
+ font-size: 12px;
41
+ display: flex;
42
+ align-items: center;
43
+ padding: 0 8px;
44
+ * {
45
+ line-height: 1;
46
+ }
47
+ .bhd_app_layout_main_filter_show_title {
48
+
49
+ }
50
+ .bhd_app_layout_main_filter_show_value {
51
+ margin-left: 4px;
52
+ margin-right: 8px;
53
+ }
54
+ :global {
55
+ .iconicon_guanbi_Close {
56
+ font-size: 12px;
57
+ }
58
+ .iconicon_guanbi_Close:hover {
59
+ cursor: pointer;
60
+ }
61
+ }
62
+ }
63
+ }
64
+ .bhd_app_layout_main_filter_clear {
65
+ color: #F4523B;
66
+ font-size: 12px;
67
+ margin-left: 8px;
68
+ cursor: pointer;
69
+ }
70
+ }
71
+ .bhd_app_layout_main_table {
72
+ padding: 0 48px;
73
+ margin-top: 16px;
74
+ :global{
75
+ /* table 无数据,异常时 */
76
+ .app_BhdTableSimple_errorTable,.app_BhdTableSimple_noTable{
77
+ padding-top: 120px;
78
+ }
79
+ }
80
+ }
81
+ }
82
+ .bhd_app_layout_footer {
83
+ width: calc(100% - 60px);
84
+ height: 56px;
85
+ position: fixed;
86
+ z-index: 10;
87
+ bottom: 0;
88
+ display: flex;
89
+ background-color: #fff;
90
+ align-items: center;
91
+ padding: 0 48px;
92
+ justify-content: space-between;
93
+ border-top: 1px solid rgba(0,0,0,0.15);
94
+ }
95
+ }
@@ -0,0 +1,8 @@
1
+ declare const en_US: {
2
+ 已筛选: string;
3
+ 清空条件: string;
4
+ noData: string;
5
+ "\u7CFB\u7EDF\u7E41\u5FD9,\u7A0D\u540E\u91CD\u8BD5!": string;
6
+ Load: string;
7
+ };
8
+ export default en_US;
@@ -0,0 +1,8 @@
1
+ var en_US = {
2
+ 已筛选: "screened",
3
+ 清空条件: "Emptying condition",
4
+ noData: "No Data",
5
+ "系统繁忙,稍后重试!": "",
6
+ Load: "Loading..."
7
+ };
8
+ export default en_US;
@@ -0,0 +1,2 @@
1
+ declare const i18Conversion: (str: string, lang?: "zh_CN" | "en_US") => any;
2
+ export default i18Conversion;
@@ -0,0 +1,15 @@
1
+ import zh_CN from "./zh_CN";
2
+ import en_US from "./en_US";
3
+ import { useLocale } from "antd/es/locale";
4
+ var i18Conversion = function(str, lang) {
5
+ if (!lang) {
6
+ lang = useLocale("Pagination")[1] === "zh-cn" ? "zh_CN" : "en_US";
7
+ }
8
+ if (lang === "zh_CN") {
9
+ return zh_CN[str];
10
+ } else if (lang === "en_US") {
11
+ return en_US[str];
12
+ }
13
+ return str;
14
+ };
15
+ export default i18Conversion;
@@ -0,0 +1,8 @@
1
+ declare const zh_CN: {
2
+ 已筛选: string;
3
+ 清空条件: string;
4
+ noData: string;
5
+ "\u7CFB\u7EDF\u7E41\u5FD9,\u7A0D\u540E\u91CD\u8BD5!": string;
6
+ Load: string;
7
+ };
8
+ export default zh_CN;
@@ -0,0 +1,8 @@
1
+ var zh_CN = {
2
+ 已筛选: "已筛选",
3
+ 清空条件: "清空条件",
4
+ noData: "No Data",
5
+ "系统繁忙,稍后重试!": "系统繁忙,稍后重试!",
6
+ Load: "正在加载..."
7
+ };
8
+ export default zh_CN;
@@ -1,4 +1,6 @@
1
1
  export { default as Loading } from "./loading";
2
+ export { default as NotData } from "./notData";
3
+ export { default as ServerError } from "./serverError";
2
4
  export { default as Confirm } from "./confirm";
3
5
  export { default as Success } from "./success";
4
6
  export { default as Info } from "./info";
@@ -1,4 +1,6 @@
1
1
  export { default as Loading } from "./loading";
2
+ export { default as NotData } from "./notData";
3
+ export { default as ServerError } from "./serverError";
2
4
  export { default as Confirm } from "./confirm";
3
5
  export { default as Success } from "./success";
4
6
  export { default as Info } from "./info";
@@ -0,0 +1,2 @@
1
+ var NotData = "";
2
+ export default NotData;
@@ -0,0 +1,2 @@
1
+ var ServerError = "";
2
+ export default ServerError;
package/esm/index.d.ts CHANGED
@@ -76,3 +76,4 @@ export { default as TitleBar } from "./titleBar";
76
76
  export { default as ViewImage } from "./viewImage";
77
77
  export { default as BhdTipModal } from "./bhdTipModal";
78
78
  export { default as BhdSelect } from './bhdSelect';
79
+ export { default as BhdAppLayout } from './bhdAppLayout';
package/esm/index.js CHANGED
@@ -81,3 +81,4 @@ export { default as TitleBar } from "./titleBar/index"; //标题栏
81
81
  export { default as ViewImage } from "./viewImage/index"; //查看大图
82
82
  export { default as BhdTipModal } from "./bhdTipModal/index"; //提示框
83
83
  export { default as BhdSelect } from "./bhdSelect/index"; //封装 bhdSelect
84
+ export { default as BhdAppLayout } from "./bhdAppLayout/index"; //封装 BhdAppLayout
@@ -1,5 +1,5 @@
1
1
  import * as React from "react";
2
- interface TitleBarProps {
2
+ export interface TitleBarProps {
3
3
  title?: React.ReactElement;
4
4
  leftIcon?: React.ReactElement;
5
5
  subTitle?: React.ReactElement;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bhd-components",
3
- "version": "0.4.5",
3
+ "version": "0.4.6",
4
4
  "description": "组件功能描述",
5
5
  "files": [
6
6
  "esm",