lightning-base-components 1.21.2-alpha → 1.21.3-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/metadata/raptor.json +28 -1
- package/package.json +28 -2
- package/scopedImports/@salesforce-label-LightningRichTextEditor.colorPicker.js +1 -0
- package/src/lightning/accordion/accordion-section.slds.css +3 -3
- package/src/lightning/accordion/accordion.slds.css +1 -2
- package/src/lightning/accordionSection/accordion-section.slds.css +3 -3
- package/src/lightning/accordionSection/accordionSection.js +3 -1
- package/src/lightning/accordionSection/button.slds.css +1 -1
- package/src/lightning/badge/badge.js +1 -0
- package/src/lightning/badge/badge.js-meta.xml +3 -0
- package/src/lightning/baseCombobox/base-combobox.slds.css +11 -6
- package/src/lightning/baseCombobox/baseCombobox.html +1 -1
- package/src/lightning/baseCombobox/baseCombobox.js +2 -2
- package/src/lightning/baseCombobox/baseCombobox.js-meta.xml +6 -0
- package/src/lightning/baseCombobox/input-text.slds.css +41 -68
- package/src/lightning/baseCombobox/keyboard.js +12 -4
- package/src/lightning/baseCombobox/listbox.slds.css +51 -99
- package/src/lightning/baseCombobox/spinner.slds.css +62 -62
- package/src/lightning/baseComboboxFormattedText/baseComboboxFormattedText.js-meta.xml +6 -0
- package/src/lightning/baseComboboxItem/baseComboboxItem.js +10 -6
- package/src/lightning/baseComboboxItem/baseComboboxItem.js-meta.xml +6 -0
- package/src/lightning/baseComboboxItem/listbox.slds.css +51 -99
- package/src/lightning/baseFormattedText/baseFormattedText.js +2 -2
- package/src/lightning/button/button.js +2 -1
- package/src/lightning/button/button.slds.css +1 -1
- package/src/lightning/buttonIcon/button-icon.slds.css +1 -1
- package/src/lightning/buttonIconStateful/button-icon-stateful.slds.css +4 -2
- package/src/lightning/buttonIconStateful/button-icon.slds.css +1 -1
- package/src/lightning/buttonIconStateful/button.slds.css +1 -1
- package/src/lightning/buttonMenu/button-icon.slds.css +1 -1
- package/src/lightning/buttonMenu/button-menu.slds.css +8 -2
- package/src/lightning/buttonMenu/button.slds.css +1 -1
- package/src/lightning/buttonStateful/button-stateful.slds.css +6 -2
- package/src/lightning/buttonStateful/button.slds.css +1 -1
- package/src/lightning/buttonStateful/buttonStateful.js +4 -1
- package/src/lightning/calendar/calendar.js-meta.xml +6 -0
- package/src/lightning/calendar/calendar.slds.css +9 -2
- package/src/lightning/colorPickerCustom/color-picker-custom.slds.css +22 -23
- package/src/lightning/colorPickerCustom/input-text.slds.css +41 -68
- package/src/lightning/colorPickerPanel/color-picker-panel.slds.css +9 -10
- package/src/lightning/colorPickerPanel/popover.slds.css +0 -2
- package/src/lightning/combobox/combobox.slds.css +1 -2
- package/src/lightning/combobox/form-element.slds.css +54 -54
- package/src/lightning/datatable/__examples__/customDatatableWrapper/customDatatableWrapper.js +0 -69
- package/src/lightning/datatable/__examples__/customDatatypeDeleteRowBtn/customDatatypeDeleteRowBtn.html +1 -1
- package/src/lightning/datatable/__examples__/customDatatypeDeleteRowBtn/customDatatypeDeleteRowBtn.js +1 -16
- package/src/lightning/datatable/__examples__/customDatatypeLink/customDatatypeLink.html +3 -3
- package/src/lightning/datatable/__examples__/customDatatypeRowOrderingBtn/customDatatypeRowOrderingBtn.html +1 -8
- package/src/lightning/datatable/__examples__/customDatatypeRowOrderingBtn/customDatatypeRowOrderingBtn.js +2 -39
- package/src/lightning/datatable/__examples__/customDatatypeTable/customNumber.html +1 -1
- package/src/lightning/datatable/__examples__/customDatatypeTable/customNumberEdit.html +2 -0
- package/src/lightning/datatable/__examples__/customDatatypeTable/deleteRow.html +3 -2
- package/src/lightning/datatable/__examples__/customDatatypeTable/iconPill.html +1 -1
- package/src/lightning/datatable/__examples__/customNestedComponent/customNestedComponent.html +10 -0
- package/src/lightning/datatable/__examples__/customNestedComponent/customNestedComponent.js +12 -0
- package/src/lightning/datatable/autoWidthStrategy.js +147 -191
- package/src/lightning/datatable/columnResizer.js +35 -35
- package/src/lightning/datatable/columnWidthManager.js +118 -177
- package/src/lightning/datatable/columns.js +90 -59
- package/src/lightning/datatable/datagrid.slds.css +187 -0
- package/src/lightning/datatable/datatable.js +248 -229
- package/src/lightning/datatable/errors.js +3 -0
- package/src/lightning/datatable/fixedWidthStrategy.js +22 -29
- package/src/lightning/datatable/headerActions.js +7 -9
- package/src/lightning/datatable/infiniteLoading.js +15 -15
- package/src/lightning/datatable/inlineEdit.js +255 -235
- package/src/lightning/datatable/keyboard.js +318 -282
- package/src/lightning/datatable/renderManager.js +10 -7
- package/src/lightning/datatable/resizeObserver.js +11 -59
- package/src/lightning/datatable/rowLevelActions.js +6 -5
- package/src/lightning/datatable/rowNumber.js +23 -23
- package/src/lightning/datatable/rowSelection.js +173 -145
- package/src/lightning/datatable/rowSelectionShared.js +13 -6
- package/src/lightning/datatable/rows.js +231 -196
- package/src/lightning/datatable/sort.js +26 -22
- package/src/lightning/datatable/templates/div/div.css +2 -57
- package/src/lightning/datatable/templates/div/div.html +13 -6
- package/src/lightning/datatable/templates/div/div.lbc.native.css +3 -0
- package/src/lightning/datatable/templates/div/div.lbc.synthetic.css +86 -0
- package/src/lightning/datatable/templates/table/table.html +1 -0
- package/src/lightning/datatable/utils.js +5 -5
- package/src/lightning/datatable/widthManagerShared.js +24 -21
- package/src/lightning/datatable/wrapText.js +25 -26
- package/src/lightning/datepicker/datepicker.js +32 -9
- package/src/lightning/datepicker/datepicker.js-meta.xml +6 -0
- package/src/lightning/datepicker/form-element.slds.css +54 -54
- package/src/lightning/datepicker/input-text.slds.css +41 -68
- package/src/lightning/datetimepicker/datetimepicker.js-meta.xml +6 -0
- package/src/lightning/datetimepicker/form-element.slds.css +54 -54
- package/src/lightning/datetimepicker/input-text.slds.css +41 -68
- package/src/lightning/dualListbox/dual-listbox.slds.css +7 -2
- package/src/lightning/dualListbox/form-element.slds.css +54 -54
- package/src/lightning/dualListbox/listbox.slds.css +51 -99
- package/src/lightning/dynamicIcon/dynamic-icon-strength.slds.css +1 -2
- package/src/lightning/dynamicIcon/dynamic-icon-trend.slds.css +1 -2
- package/src/lightning/formattedDateTime/formattedDateTime.js +7 -62
- package/src/lightning/formattedDateTime/formattedDateTime.js-meta.xml +3 -0
- package/src/lightning/formattedLocation/formattedLocation.html +1 -3
- package/src/lightning/formattedLocation/formattedLocation.js +3 -25
- package/src/lightning/formattedLookup/events.js +2 -4
- package/src/lightning/formattedNumber/formattedNumber.js +2 -49
- package/src/lightning/formattedRichText/formattedRichText.js +5 -5
- package/src/lightning/formattedRichText/linkTextNodes.js +58 -0
- package/src/lightning/groupedCombobox/form-element.slds.css +54 -54
- package/src/lightning/groupedCombobox/grouped-combobox.slds.css +0 -2
- package/src/lightning/groupedCombobox/groupedCombobox.js-meta.xml +1 -1
- package/src/lightning/groupedCombobox/input-text.slds.css +41 -68
- package/src/lightning/helptext/button-icon.slds.css +1 -1
- package/src/lightning/helptext/form-element.slds.css +54 -54
- package/src/lightning/icon/icon.slds.css +12 -25
- package/src/lightning/input/form-element.slds.css +54 -54
- package/src/lightning/inputAddress/form-element.slds.css +54 -54
- package/src/lightning/inputAddress/input-address.slds.css +1 -2
- package/src/lightning/inputAddress/input-text.slds.css +41 -68
- package/src/lightning/inputAddress/inputAddress.js +1 -0
- package/src/lightning/inputAddress/inputAddress.js-meta.xml +3 -0
- package/src/lightning/inputLocation/form-element.slds.css +54 -54
- package/src/lightning/inputLocation/input-location.slds.css +1 -2
- package/src/lightning/inputLocation/input-text.slds.css +41 -68
- package/src/lightning/inputName/form-element.slds.css +54 -54
- package/src/lightning/inputName/input-text.slds.css +41 -68
- package/src/lightning/interactiveDialogBase/interactive-dialog-base.slds.css +0 -3
- package/src/lightning/interactiveDialogBase/interactiveDialogBase.js-meta.xml +6 -0
- package/src/lightning/lookupAddress/form-element.slds.css +54 -54
- package/src/lightning/lookupAddress/listbox.slds.css +51 -99
- package/src/lightning/lookupAddress/location.js +2 -0
- package/src/lightning/lookupAddress/lookup-address.slds.css +0 -2
- package/src/lightning/lookupAddress/lookupAddress.js +15 -10
- package/src/lightning/menuDivider/menu-divider.slds.css +0 -2
- package/src/lightning/menuItem/menu-item.slds.css +8 -2
- package/src/lightning/menuSubheader/menu-subheader.slds.css +1 -2
- package/src/lightning/modalBase/modal-base.slds.css +3 -3
- package/src/lightning/modalBase/modalBase.js +0 -8
- package/src/lightning/modalBase/modalBase.js-meta.xml +6 -0
- package/src/lightning/modalBody/modal-body.slds.css +1 -2
- package/src/lightning/modalFooter/modal-footer.slds.css +2 -2
- package/src/lightning/modalFooter/modalFooter.js +0 -21
- package/src/lightning/modalHeader/modal-header.slds.css +1 -2
- package/src/lightning/modalHeader/modalHeader.js +0 -22
- package/src/lightning/overlay/overlay.js-meta.xml +6 -0
- package/src/lightning/pill/pill.slds.css +32 -58
- package/src/lightning/pillContainer/button.slds.css +1 -1
- package/src/lightning/pillContainer/listbox.slds.css +51 -99
- package/src/lightning/pillContainer/pill-container.slds.css +6 -10
- package/src/lightning/pillContainer/pill.slds.css +32 -58
- package/src/lightning/popup/popover.slds.css +0 -2
- package/src/lightning/primitiveBubble/primitiveBubble.js-meta.xml +6 -0
- package/src/lightning/primitiveButton/primitiveButoon.js-meta.xml +6 -0
- package/src/lightning/primitiveCellCheckbox/checkbox.css +2 -0
- package/src/lightning/primitiveColorpickerButton/color-picker-button.slds.css +16 -38
- package/src/lightning/primitiveCustomCell/primitiveCustomCell.js +26 -1
- package/src/lightning/primitiveHeaderFactory/nonsortableHeader.css +1 -0
- package/src/lightning/primitiveHeaderFactory/selectableHeader.css +2 -0
- package/src/lightning/primitiveIcon/icon.slds.css +12 -25
- package/src/lightning/primitiveIcon/primitiveIcon.js-meta.xml +6 -0
- package/src/lightning/primitiveIframe/primitiveIframe.js +3 -1
- package/src/lightning/primitiveInputCheckbox/form-element.slds.css +54 -54
- package/src/lightning/primitiveInputCheckbox/primitiveInputCheckbox.js +5 -2
- package/src/lightning/primitiveInputCheckbox/primitiveInputCheckbox.js-meta.xml +6 -0
- package/src/lightning/primitiveInputCheckboxButton/form-element.slds.css +54 -54
- package/src/lightning/primitiveInputCheckboxButton/input-checkbox-button.slds.css +6 -4
- package/src/lightning/primitiveInputCheckboxButton/primitiveInputCheckboxButton.js +5 -2
- package/src/lightning/primitiveInputCheckboxButton/primitiveInputCheckboxButton.js-meta.xml +6 -0
- package/src/lightning/primitiveInputColor/form-element.slds.css +54 -54
- package/src/lightning/primitiveInputColor/input-color.slds.css +2 -3
- package/src/lightning/primitiveInputColor/input-text.slds.css +41 -68
- package/src/lightning/primitiveInputColor/primitiveInputColor.js +5 -2
- package/src/lightning/primitiveInputColor/primitiveInputColor.js-meta.xml +6 -0
- package/src/lightning/primitiveInputFile/button.slds.css +1 -1
- package/src/lightning/primitiveInputFile/form-element.slds.css +54 -54
- package/src/lightning/primitiveInputFile/input-file.slds.css +1 -4
- package/src/lightning/primitiveInputFile/primitiveInputFile.js +4 -2
- package/src/lightning/primitiveInputFile/primitiveInputFile.js-meta.xml +6 -0
- package/src/lightning/primitiveInputRadio/primitiveInputRadio.js +4 -2
- package/src/lightning/primitiveInputSimple/form-element.slds.css +54 -54
- package/src/lightning/primitiveInputSimple/input-text.slds.css +41 -68
- package/src/lightning/primitiveInputSimple/primitiveInputSimple.js-meta.xml +6 -0
- package/src/lightning/primitiveInputToggle/form-element.slds.css +54 -54
- package/src/lightning/primitiveInputToggle/input-toggle.slds.css +50 -27
- package/src/lightning/primitiveInputToggle/primitiveInputToggle.js +5 -2
- package/src/lightning/primitiveInputToggle/primitiveInputToggle.js-meta.xml +6 -0
- package/src/lightning/progressBar/progress-bar.slds.css +8 -10
- package/src/lightning/progressRing/progress-ring.slds.css +0 -23
- package/src/lightning/progressStep/progressStep.js +1 -14
- package/src/lightning/radioGroup/form-element.slds.css +54 -54
- package/src/lightning/radioGroup/radioGroup.html +1 -2
- package/src/lightning/radioGroup/radioGroup.js +1 -0
- package/src/lightning/routingService/routingService.js +31 -5
- package/src/lightning/select/form-element.slds.css +54 -54
- package/src/lightning/select/select.slds.css +4 -2
- package/src/lightning/sldsUtilsVisibility/sldsUtilsVisibility.css +4 -0
- package/src/lightning/spinner/spinner.slds.css +62 -62
- package/src/lightning/tab/tab.js +4 -2
- package/src/lightning/tab/tab.slds.css +14 -7
- package/src/lightning/tabBar/tab-bar.slds.css +16 -6
- package/src/lightning/tabset/__docs__/tabset.md +24 -1
- package/src/lightning/tabset/tabset.js +25 -38
- package/src/lightning/tabset/tabset.slds.css +0 -2
- package/src/lightning/textarea/form-element.slds.css +54 -54
- package/src/lightning/textarea/textarea.js +5 -1
- package/src/lightning/textarea/textarea.slds.css +22 -9
- package/src/lightning/timepicker/form-element.slds.css +54 -54
- package/src/lightning/timepicker/timepicker.js-meta.xml +6 -0
- package/src/lightning/timepicker/timepicker.slds.css +2 -2
- package/src/lightning/toast/__docs__/toast.md +20 -22
- package/src/lightning/toast/button-icon.slds.css +1 -1
- package/src/lightning/toast/icon.slds.css +12 -25
- package/src/lightning/toast/toast.js +15 -12
- package/src/lightning/toast/toast.slds.css +6 -18
- package/src/lightning/toastContainer/toast.slds.css +6 -18
- package/src/lightning/toastContainer/toastContainer.js +25 -17
- package/src/lightning/tooltipLibrary/tooltipLibrary.js +12 -9
- package/src/lightning/tree/tree.js +2 -0
- package/src/lightning/utils/classSet.js +9 -3
- package/src/lightning/utilsPrivate/formatUtils.js +158 -0
- package/src/lightning/utilsPrivate/textUtils.js +16 -0
- package/src/lightning/utilsPrivate/utilsPrivate.js +56 -15
- package/src/lightning/utilsPrivate/validationUtils.js +59 -0
- package/src/lightning/verticalNavigationSection/vertical-navigation-section.slds.css +0 -2
- package/src/lightning/datatable/resizeSensor.js +0 -244
- package/src/lightning/formattedRichText/linkify.js +0 -43
- package/src/lightning/utilsPrivate/smartSetAttribute.js +0 -19
|
@@ -15,6 +15,9 @@ export function getErrors(state) {
|
|
|
15
15
|
/**
|
|
16
16
|
* Sets the row-level errors and table-level errors in datatable's state object
|
|
17
17
|
* Errors being set here overwrite the previous error object in the state
|
|
18
|
+
*
|
|
19
|
+
*
|
|
20
|
+
* @param {Object} state - The untracked datatable state
|
|
18
21
|
*/
|
|
19
22
|
export function setErrors(state, errors) {
|
|
20
23
|
return (state.errors = Object.assign({}, DEFAULT_ERROR_STATE, errors));
|
|
@@ -1,18 +1,15 @@
|
|
|
1
|
-
import {
|
|
2
|
-
getTotalWidthsMetadata,
|
|
3
|
-
getColumnWidthFromDef,
|
|
4
|
-
} from './widthManagerShared';
|
|
1
|
+
import { getColumnWidth, getTotalWidthsData } from './widthManagerShared';
|
|
5
2
|
|
|
6
3
|
/**
|
|
7
4
|
* Determines the expected table width
|
|
8
5
|
*
|
|
9
6
|
* @param {Number} availableWidth The available width for the entire table
|
|
10
|
-
* @param {Object}
|
|
7
|
+
* @param {Object} widthsData The widths metadata object
|
|
11
8
|
* @returns {Number} The expected width of the table
|
|
12
9
|
*/
|
|
13
|
-
function getExpectedTableWidth(availableWidth,
|
|
14
|
-
const minExpectedTableWidth = getMinExpectedTableWidth(
|
|
15
|
-
return
|
|
10
|
+
function getExpectedTableWidth(availableWidth, widthsData) {
|
|
11
|
+
const minExpectedTableWidth = getMinExpectedTableWidth(widthsData);
|
|
12
|
+
return widthsData.totalFlexibleColumns === 0
|
|
16
13
|
? minExpectedTableWidth
|
|
17
14
|
: Math.max(minExpectedTableWidth, availableWidth);
|
|
18
15
|
}
|
|
@@ -38,13 +35,12 @@ function getMinExpectedTableWidth(widthsMetadata) {
|
|
|
38
35
|
* Strategy for columns with defined fixed widths.
|
|
39
36
|
*/
|
|
40
37
|
export class FixedWidthStrategy {
|
|
41
|
-
|
|
42
|
-
_columnWidthMetaData = {};
|
|
38
|
+
widthsData = {};
|
|
43
39
|
|
|
44
40
|
/************************** LIFECYCLE HOOKS **************************/
|
|
45
41
|
|
|
46
42
|
constructor(minColumnWidth, maxColumnWidth) {
|
|
47
|
-
this.
|
|
43
|
+
this.widthsData = { minColumnWidth, maxColumnWidth };
|
|
48
44
|
}
|
|
49
45
|
|
|
50
46
|
/************************** PRIVATE SETTERS **************************/
|
|
@@ -55,7 +51,7 @@ export class FixedWidthStrategy {
|
|
|
55
51
|
* @param {Number} value The minimum width
|
|
56
52
|
*/
|
|
57
53
|
set minColumnWidth(value) {
|
|
58
|
-
this.
|
|
54
|
+
this.widthsData.minColumnWidth = value;
|
|
59
55
|
}
|
|
60
56
|
|
|
61
57
|
/**
|
|
@@ -64,7 +60,7 @@ export class FixedWidthStrategy {
|
|
|
64
60
|
* @param {Number} value The maximum width
|
|
65
61
|
*/
|
|
66
62
|
set maxColumnWidth(value) {
|
|
67
|
-
this.
|
|
63
|
+
this.widthsData.maxColumnWidth = value;
|
|
68
64
|
}
|
|
69
65
|
|
|
70
66
|
/**
|
|
@@ -72,31 +68,28 @@ export class FixedWidthStrategy {
|
|
|
72
68
|
* equally amongst the possible columns
|
|
73
69
|
*
|
|
74
70
|
* @param {Object} datatableInterface Interface to datatable with callbacks giving width information
|
|
75
|
-
* @param {Array}
|
|
71
|
+
* @param {Array} _columns The untracked column definitions
|
|
76
72
|
* @returns {Object} columnWidths: [], expectedTableWidth: (number)
|
|
77
73
|
*/
|
|
78
|
-
getAdjustedColumnWidths(datatableInterface,
|
|
79
|
-
const
|
|
80
|
-
this._columnWidthMetaData,
|
|
81
|
-
columnDefs
|
|
82
|
-
);
|
|
74
|
+
getAdjustedColumnWidths(datatableInterface, _columns) {
|
|
75
|
+
const totalWidthsData = getTotalWidthsData(this.widthsData, _columns);
|
|
83
76
|
const availableWidth = datatableInterface.getAvailableWidthFromDom();
|
|
84
77
|
const expectedTableWidth = getExpectedTableWidth(
|
|
85
78
|
availableWidth,
|
|
86
|
-
|
|
79
|
+
totalWidthsData
|
|
87
80
|
);
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
widthsMetadata,
|
|
81
|
+
const expectedFlexibleColumnWidth = this.getFlexibleColumnWidth(
|
|
82
|
+
totalWidthsData,
|
|
91
83
|
expectedTableWidth
|
|
92
84
|
);
|
|
93
85
|
|
|
94
86
|
const columnWidths = [];
|
|
95
|
-
|
|
87
|
+
for (let colIndex = 0; colIndex < _columns.length; colIndex += 1) {
|
|
96
88
|
const width =
|
|
97
|
-
|
|
89
|
+
getColumnWidth(_columns[colIndex]) ||
|
|
90
|
+
expectedFlexibleColumnWidth;
|
|
98
91
|
columnWidths[colIndex] = width;
|
|
99
|
-
}
|
|
92
|
+
}
|
|
100
93
|
|
|
101
94
|
return { columnWidths, expectedTableWidth };
|
|
102
95
|
}
|
|
@@ -104,18 +97,18 @@ export class FixedWidthStrategy {
|
|
|
104
97
|
/**
|
|
105
98
|
* Determines the expected flexible column width
|
|
106
99
|
*
|
|
107
|
-
* @param {Object}
|
|
100
|
+
* @param {Object} widthsData The widths metadata object
|
|
108
101
|
* @param {Number} totalTableWidth The total available width for the table
|
|
109
102
|
* @returns {Number} The column width
|
|
110
103
|
*/
|
|
111
|
-
|
|
104
|
+
getFlexibleColumnWidth(widthsData, totalTableWidth) {
|
|
112
105
|
const {
|
|
113
106
|
totalFixedWidth,
|
|
114
107
|
totalResizedWidth,
|
|
115
108
|
totalFlexibleColumns,
|
|
116
109
|
minColumnWidth,
|
|
117
110
|
maxColumnWidth,
|
|
118
|
-
} =
|
|
111
|
+
} = widthsData;
|
|
119
112
|
const totalFlexibleWidth =
|
|
120
113
|
totalTableWidth - totalFixedWidth - totalResizedWidth;
|
|
121
114
|
const avgFlexibleColumnWidth = Math.floor(
|
|
@@ -29,16 +29,14 @@ export function getInternalActions(state, columnDefinition) {
|
|
|
29
29
|
*/
|
|
30
30
|
export function updateHeaderActions(state) {
|
|
31
31
|
const columns = getColumns(state);
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
menuAlignment: getMenuAlignment(columns,
|
|
36
|
-
customerActions: Array.isArray(
|
|
37
|
-
|
|
38
|
-
: [],
|
|
39
|
-
internalActions: getInternalActions(state, column),
|
|
32
|
+
for (let colIndex = 0; colIndex < columns.length; colIndex += 1) {
|
|
33
|
+
const col = columns[colIndex];
|
|
34
|
+
col.actions = {
|
|
35
|
+
menuAlignment: getMenuAlignment(columns, colIndex),
|
|
36
|
+
customerActions: Array.isArray(col.actions) ? col.actions : [],
|
|
37
|
+
internalActions: getInternalActions(state, col),
|
|
40
38
|
};
|
|
41
|
-
}
|
|
39
|
+
}
|
|
42
40
|
}
|
|
43
41
|
|
|
44
42
|
/**
|
|
@@ -42,7 +42,7 @@ export function isInfiniteLoadingEnabled(state) {
|
|
|
42
42
|
* @param {Object} state The datatable state object
|
|
43
43
|
* @param {Boolean} value The infinite loading state to set
|
|
44
44
|
*/
|
|
45
|
-
export function
|
|
45
|
+
export function setEnableInfiniteLoading(state, value) {
|
|
46
46
|
state.enableInfiniteLoading = normalizeBoolean(value);
|
|
47
47
|
}
|
|
48
48
|
|
|
@@ -117,13 +117,13 @@ export function handlePrefetch(root, state) {
|
|
|
117
117
|
!this._renderManager.hasWrapperHeight()) ||
|
|
118
118
|
!hasData(root)
|
|
119
119
|
) {
|
|
120
|
-
//
|
|
120
|
+
// Don't prefetch if already loading or data is not set yet
|
|
121
121
|
return;
|
|
122
122
|
}
|
|
123
123
|
|
|
124
|
-
const
|
|
124
|
+
const scrollerY = root.querySelector('.slds-scrollable_y');
|
|
125
125
|
|
|
126
|
-
if (
|
|
126
|
+
if (scrollerY && isScrollerVisible(scrollerY) && !isScrollable(scrollerY)) {
|
|
127
127
|
this.dispatchEvent(new CustomEvent('loadmore'));
|
|
128
128
|
}
|
|
129
129
|
}
|
|
@@ -131,27 +131,27 @@ export function handlePrefetch(root, state) {
|
|
|
131
131
|
/************************** PRIVATE METHODS ***************************/
|
|
132
132
|
|
|
133
133
|
/**
|
|
134
|
-
* Determines if a
|
|
134
|
+
* Determines if a scroller element is scrollable.
|
|
135
135
|
*
|
|
136
|
-
* @param {Element}
|
|
136
|
+
* @param {Element} scroller The scroller element to check
|
|
137
137
|
* @returns {Boolean} Whether or not the element is scrollable
|
|
138
138
|
*/
|
|
139
|
-
function isScrollable(
|
|
139
|
+
function isScrollable(scroller) {
|
|
140
140
|
// scrollHeight should be greater than clientHeight by some allowance
|
|
141
|
-
return
|
|
141
|
+
return scroller.scrollHeight > scroller.clientHeight + SCROLL_ALLOWANCE;
|
|
142
142
|
}
|
|
143
143
|
|
|
144
144
|
/**
|
|
145
|
-
* Determines if a
|
|
145
|
+
* Determines if a scroller element's scroll bars are visible.
|
|
146
146
|
*
|
|
147
|
-
* @param {Element}
|
|
148
|
-
* @returns {Boolean} Whether or not the element's scroll bars are visible
|
|
147
|
+
* @param {Element} scroller The DOM element to check
|
|
148
|
+
* @returns {Boolean} Whether or not the scroller element's scroll bars are visible
|
|
149
149
|
*/
|
|
150
|
-
function isScrollerVisible(
|
|
150
|
+
function isScrollerVisible(scroller) {
|
|
151
151
|
return !!(
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
152
|
+
scroller.offsetParent ||
|
|
153
|
+
scroller.offsetHeight ||
|
|
154
|
+
scroller.offsetWidth
|
|
155
155
|
);
|
|
156
156
|
}
|
|
157
157
|
|