bkui-vue 1.0.2 → 1.0.3-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/preset.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { App } from 'vue';
2
2
  declare const _default: {
3
- createInstall: (prefix?: string) => (app: App<any>, options: Partial<import("vue").ExtractPropTypes<{
3
+ createInstall: (prefix?: string) => (app: App<any>, options?: Partial<import("vue").ExtractPropTypes<{
4
4
  locale: {
5
5
  type: import("vue").PropType<{
6
6
  lang: string;
@@ -143,7 +143,7 @@ declare const _default: {
143
143
  default: string;
144
144
  };
145
145
  }>>) => void;
146
- install: (app: App<any>, options: Partial<import("vue").ExtractPropTypes<{
146
+ install: (app: App<any>, options?: Partial<import("vue").ExtractPropTypes<{
147
147
  locale: {
148
148
  type: import("vue").PropType<{
149
149
  lang: string;
@@ -1663,10 +1663,11 @@ var resolvePaginationOption = function resolvePaginationOption(propPagination, d
1663
1663
  * pagination 为Prop传入配置
1664
1664
  * 方便兼容内置分页功能,此处需要单独处理count
1665
1665
  */
1666
- var localPagination = (0,external_vue_namespaceObject.ref)(null);
1667
- var indexData = (0,external_vue_namespaceObject.computed)(function () {
1666
+ var propsData = (0,external_vue_namespaceObject.computed)(function () {
1668
1667
  return props.data;
1669
1668
  });
1669
+ var localPagination = (0,external_vue_namespaceObject.ref)(null);
1670
+ var indexData = (0,external_vue_namespaceObject.reactive)([]);
1670
1671
  // 当前分页缓存,用于支持内置前端分页,用户无需接收change事件来自行处理数据分割
1671
1672
  var pagination = (0,external_vue_namespaceObject.reactive)({
1672
1673
  count: 0,
@@ -1680,7 +1681,7 @@ var resolvePaginationOption = function resolvePaginationOption(propPagination, d
1680
1681
  return;
1681
1682
  }
1682
1683
  localPagination.value = props.remotePagination ? pagination : use_pagination_objectSpread(use_pagination_objectSpread({}, pagination), {}, {
1683
- count: indexData.value.length
1684
+ count: indexData.length
1684
1685
  });
1685
1686
  };
1686
1687
  /**
@@ -1691,7 +1692,7 @@ var resolvePaginationOption = function resolvePaginationOption(propPagination, d
1691
1692
  var resetStartEndIndex = function resetStartEndIndex() {
1692
1693
  if (!props.pagination || props.remotePagination) {
1693
1694
  startIndex.value = 0;
1694
- endIndex.value = indexData.value.length;
1695
+ endIndex.value = indexData.length;
1695
1696
  return;
1696
1697
  }
1697
1698
  // 如果是前端分页
@@ -1722,15 +1723,25 @@ var resolvePaginationOption = function resolvePaginationOption(propPagination, d
1722
1723
  var filter = function filter(sourceData, filterFn) {
1723
1724
  if (typeof filterFn === 'function') {
1724
1725
  var filterVals = sourceData.filter(function (row, index) {
1725
- return filterFn(row, index, indexData.value);
1726
+ return filterFn(row, index, indexData);
1726
1727
  });
1727
1728
  sourceData.length = 0;
1728
1729
  sourceData.push.apply(sourceData, _toConsumableArray(filterVals));
1729
1730
  }
1730
1731
  return sourceData;
1731
1732
  };
1733
+ var resolveIndexData = function resolveIndexData() {
1734
+ return new Promise(function (resolve) {
1735
+ (0,external_vue_namespaceObject.nextTick)(function () {
1736
+ var target = propsData.value.slice();
1737
+ indexData.length = 0;
1738
+ indexData.push.apply(indexData, _toConsumableArray(target));
1739
+ resolve();
1740
+ });
1741
+ });
1742
+ };
1732
1743
  var resolvePageData = function resolvePageData(filterFn, sortFn, column, type, sortScope, multiCol) {
1733
- var sourceData = indexData.value.slice();
1744
+ var sourceData = indexData.slice();
1734
1745
  if (multiCol !== null && multiCol !== void 0 && multiCol.length) {
1735
1746
  multiSort(sourceData, multiCol);
1736
1747
  }
@@ -1744,7 +1755,7 @@ var resolvePaginationOption = function resolvePaginationOption(propPagination, d
1744
1755
  resolvePageData(null, null, null, null, null, multiCol);
1745
1756
  };
1746
1757
  var multiFilter = function multiFilter(filterFnList) {
1747
- var sourceData = indexData.value.slice();
1758
+ var sourceData = indexData.slice();
1748
1759
  var target = filterFnList.reduce(function (result, fn) {
1749
1760
  return filter(result, fn);
1750
1761
  }, sourceData);
@@ -1770,6 +1781,7 @@ var resolvePaginationOption = function resolvePaginationOption(propPagination, d
1770
1781
  indexData: indexData,
1771
1782
  localPagination: localPagination,
1772
1783
  resolvePageData: resolvePageData,
1784
+ resolveIndexData: resolveIndexData,
1773
1785
  resolvePageDataBySortList: resolvePageDataBySortList,
1774
1786
  resetStartEndIndex: resetStartEndIndex,
1775
1787
  multiFilter: multiFilter,
@@ -3250,12 +3262,14 @@ function use_attributes_objectSpread(e) { for (var r = 1; r < arguments.length;
3250
3262
  });
3251
3263
  var _usePagination = use_pagination(props),
3252
3264
  pageData = _usePagination.pageData,
3265
+ indexData = _usePagination.indexData,
3253
3266
  localPagination = _usePagination.localPagination,
3254
3267
  resolvePageData = _usePagination.resolvePageData,
3255
3268
  resolvePageDataBySortList = _usePagination.resolvePageDataBySortList,
3256
3269
  multiFilter = _usePagination.multiFilter,
3257
3270
  sort = _usePagination.sort,
3258
- resetStartEndIndex = _usePagination.resetStartEndIndex;
3271
+ resetStartEndIndex = _usePagination.resetStartEndIndex,
3272
+ resolveIndexData = _usePagination.resolveIndexData;
3259
3273
  var updateSettings = function updateSettings(settings, rowHeight) {
3260
3274
  if (settings) {
3261
3275
  var _ref2, _ref3;
@@ -3391,6 +3405,13 @@ function use_attributes_objectSpread(e) { for (var r = 1; r < arguments.length;
3391
3405
  var type = getColumnAttribute(column, COLUMN_ATTRIBUTE.COL_SORT_TYPE);
3392
3406
  var scope = getColumnAttribute(column, COLUMN_ATTRIBUTE.COL_SORT_SCOPE);
3393
3407
  if (type === SORT_OPTION.NULL) {
3408
+ resolveIndexData().then(function () {
3409
+ resolvePageData();
3410
+ });
3411
+ return;
3412
+ }
3413
+ if (scope === 'all') {
3414
+ sort(indexData, fn, column, type, scope);
3394
3415
  resolvePageData();
3395
3416
  return;
3396
3417
  }
@@ -3828,6 +3849,9 @@ function use_attributes_objectSpread(e) { for (var r = 1; r < arguments.length;
3828
3849
  var resolvedIndex = sourceIndex < targetIndex ? sourceIndex : sourceIndex + 1;
3829
3850
  pageData.splice(resolvedIndex, 1);
3830
3851
  };
3852
+ var setIndexData = function setIndexData() {
3853
+ return resolveIndexData();
3854
+ };
3831
3855
  return {
3832
3856
  formatColumns: formatColumns,
3833
3857
  formatDataSchema: formatDataSchema,
@@ -3864,7 +3888,8 @@ function use_attributes_objectSpread(e) { for (var r = 1; r < arguments.length;
3864
3888
  changePageRowIndex: changePageRowIndex,
3865
3889
  pageData: pageData,
3866
3890
  localPagination: localPagination,
3867
- formatData: formatData
3891
+ formatData: formatData,
3892
+ setIndexData: setIndexData
3868
3893
  };
3869
3894
  });
3870
3895
  ;// CONCATENATED MODULE: ../../packages/table/src/use-column.ts
@@ -6513,27 +6538,30 @@ function table_objectSpread(e) { for (var r = 1; r < arguments.length; r++) { va
6513
6538
  }
6514
6539
  };
6515
6540
  var isFirstLoad = (0,external_vue_namespaceObject.ref)(true);
6541
+ // const tableWidth = ref(null);
6516
6542
  (0,external_vue_namespaceObject.watch)(function () {
6517
6543
  return [props.data, columns];
6518
6544
  }, function () {
6519
- tableSchema.formatColumns(columns);
6520
- tableSchema.formatDataSchema(props.data);
6521
- tableSchema.resetStartEndIndex();
6522
- if (isFirstLoad.value) {
6523
- tableSchema.resolveByDefColumns();
6524
- isFirstLoad.value = false;
6525
- } else {
6526
- tableSchema.resolvePageData();
6527
- }
6528
- registerResizeEvent();
6529
- (0,external_vue_namespaceObject.nextTick)(function () {
6530
- updateOffsetRight();
6531
- resolveFixedColumns(tableOffsetRight.value);
6532
- /**
6533
- * 确保在所有数据渲染完毕再执行fix column计算
6534
- */
6545
+ tableSchema.setIndexData().then(function () {
6546
+ tableSchema.formatColumns(columns);
6547
+ tableSchema.formatDataSchema(props.data);
6548
+ tableSchema.resetStartEndIndex();
6549
+ if (isFirstLoad.value) {
6550
+ tableSchema.resolveByDefColumns();
6551
+ isFirstLoad.value = false;
6552
+ } else {
6553
+ tableSchema.resolvePageData();
6554
+ }
6555
+ registerResizeEvent();
6535
6556
  (0,external_vue_namespaceObject.nextTick)(function () {
6536
- resetTableHeight(root.value);
6557
+ updateOffsetRight();
6558
+ resolveFixedColumns(tableOffsetRight.value);
6559
+ /**
6560
+ * 确保在所有数据渲染完毕再执行fix column计算
6561
+ */
6562
+ (0,external_vue_namespaceObject.nextTick)(function () {
6563
+ resetTableHeight(root.value);
6564
+ });
6537
6565
  });
6538
6566
  });
6539
6567
  }, {
@@ -9,9 +9,10 @@ import { Column, SortScope, TablePropTypes } from '../props';
9
9
  export declare const resolvePaginationOption: (propPagination: any, defVal: any) => any;
10
10
  declare const _default: (props: TablePropTypes) => {
11
11
  pageData: any[];
12
- indexData: import("vue").ComputedRef<any[]>;
12
+ indexData: any[];
13
13
  localPagination: import("vue").Ref<any>;
14
14
  resolvePageData: (filterFn?: any, sortFn?: any, column?: Column, type?: string, sortScope?: any, multiCol?: any) => void;
15
+ resolveIndexData: () => Promise<void>;
15
16
  resolvePageDataBySortList: (multiCol?: any) => void;
16
17
  resetStartEndIndex: () => void;
17
18
  multiFilter: (filterFnList: ((row: any, index: any, data: any) => void)[]) => void;
@@ -997,6 +997,7 @@
997
997
  position: relative;
998
998
  height: auto;
999
999
  overflow: hidden;
1000
+ width: 100%;
1000
1001
  }
1001
1002
  .bk-table-flex {
1002
1003
  display: flex;
@@ -14,6 +14,7 @@
14
14
  position: relative;
15
15
  height: auto;
16
16
  overflow: hidden;
17
+ width: 100%;
17
18
 
18
19
  &-flex {
19
20
  display: flex;
@@ -1123,6 +1123,7 @@
1123
1123
  position: relative;
1124
1124
  height: auto;
1125
1125
  overflow: hidden;
1126
+ width: 100%;
1126
1127
  }
1127
1128
  .bk-table-flex {
1128
1129
  display: flex;
@@ -19,6 +19,7 @@ export type ITableFormatData = {
19
19
  };
20
20
  };
21
21
  export type ITableResponse = {
22
+ setIndexData: () => Promise<void>;
22
23
  formatColumns: (columns: Column[]) => void;
23
24
  formatDataSchema: (data: any[]) => void;
24
25
  setRowSelection: (row: any, isSelected: boolean) => void;
@@ -56,5 +57,43 @@ export type ITableResponse = {
56
57
  localPagination: any;
57
58
  formatData: ITableFormatData;
58
59
  };
59
- declare const _default: (props: TablePropTypes) => ITableResponse;
60
+ declare const _default: (props: TablePropTypes) => {
61
+ formatColumns: (columns: Column[]) => void;
62
+ formatDataSchema: (data: any[]) => void;
63
+ setRowSelection: (row: any, isSelected: boolean) => void;
64
+ setRowExpand: (row: any, isExpand: boolean) => void;
65
+ setRowIndex: (row: any, index: number) => void;
66
+ setColumnAttribute: (col: Column, attrName: string, attrValue: string | number | boolean | ((...args: any[]) => boolean | number | void | string)) => void;
67
+ setColumnAttributeBySettings: (settings: Settings, checkedVal?: string[]) => void;
68
+ setColumnSortActive: (column: Column, active: boolean) => void;
69
+ setRowSelectionAll: (val: boolean) => void;
70
+ setRowIndeterminate: () => void;
71
+ setAllColumnAttribute: (attributeName: string | string[], value: string | number | boolean | ((...args: any[]) => boolean | number | void | string)) => void;
72
+ getColumnAttribute: (col: Column | IEmptyObject, attributeName: string) => any;
73
+ getColumnId: (col: Column) => any;
74
+ getColumnOrderWidth: (col: Column, orders?: string[]) => number;
75
+ getRowSelection: () => any[];
76
+ resolveColumnWidth: (root: HTMLElement, autoWidth?: number, offsetWidth?: number) => void;
77
+ isActiveColumn: (col: Column) => any;
78
+ isHiddenColumn: (col: Column) => any;
79
+ resolvePageData: (filterFn?: any, sortFn?: any, column?: Column, type?: string, sortScope?: any, multiCol?: any) => void;
80
+ resolveByDefColumns: () => void;
81
+ resetStartEndIndex: () => void;
82
+ toggleAllSelection: (value?: boolean) => void;
83
+ setAllRowExpand: (value?: boolean) => void;
84
+ clearSelection: () => void;
85
+ clearColumnSort: (reset?: boolean) => void;
86
+ toggleRowSelection: (row: any) => void;
87
+ getRowAttribute: (row: any | IEmptyObject, attrName: string) => any;
88
+ filter: () => void;
89
+ sortData: (column: Column) => void;
90
+ isCheckedAll: () => boolean;
91
+ hasCheckedRow: () => boolean;
92
+ updateSettings: (settings?: Settings, rowHeight?: number) => void;
93
+ changePageRowIndex: (sourceIndex: any, targetIndex: any) => void;
94
+ pageData: any[];
95
+ localPagination: import("vue").Ref<any>;
96
+ formatData: ITableFormatData;
97
+ setIndexData: () => Promise<void>;
98
+ };
60
99
  export default _default;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bkui-vue",
3
- "version": "1.0.2",
3
+ "version": "1.0.3-beta.2",
4
4
  "workspaces": {
5
5
  "packages": [
6
6
  "packages/!(**.bak)*",
@@ -30,7 +30,7 @@
30
30
  "postpublish": "node scripts/post-publish.js",
31
31
  "prepare": "husky install",
32
32
  "dev": "lerna run --stream --scope site dev",
33
- "debug": "TS_NODE_PROJECT=./scripts/cli/tsconfig.declaration.json node --inspect-brk -r ts-node/register ./scripts/cli/index.ts lib",
33
+ "debug": "TS_NODE_CWD=./scripts/cli node --inspect-brk -r ts-node/register ./scripts/cli/index.ts lib",
34
34
  "build": "run-s build:dist build:lib",
35
35
  "build:site": "lerna run --stream --scope site build && cp -r ./site/views/ ./site/dist/views",
36
36
  "build:dist": "rimraf dist && lerna run --stream --scope cli dist",