@porsche-design-system/components-react 3.1.0 → 3.2.0-rc.0
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/CHANGELOG.md +40 -9
- package/esm/lib/components/carousel.wrapper.js +3 -3
- package/esm/lib/components/pagination.wrapper.js +3 -3
- package/lib/components/carousel.wrapper.d.ts +8 -0
- package/lib/components/carousel.wrapper.js +3 -3
- package/lib/components/pagination.wrapper.d.ts +10 -2
- package/lib/components/pagination.wrapper.js +3 -3
- package/lib/types.d.ts +199 -199
- package/package.json +2 -2
- package/ssr/components/dist/styles/esm/styles-entry.js +79 -37
- package/ssr/components/dist/utils/esm/utils-entry.js +55 -89
- package/ssr/components-react/projects/react-ssr-wrapper/src/lib/components/carousel.wrapper.js +4 -4
- package/ssr/components-react/projects/react-ssr-wrapper/src/lib/components/pagination.wrapper.js +4 -4
- package/ssr/components-react/projects/react-ssr-wrapper/src/lib/dsr-components/carousel.js +5 -4
- package/ssr/components-react/projects/react-ssr-wrapper/src/lib/dsr-components/pagination.js +7 -6
- package/ssr/esm/components/dist/styles/esm/styles-entry.js +79 -37
- package/ssr/esm/components/dist/utils/esm/utils-entry.js +55 -89
- package/ssr/esm/components-react/projects/react-ssr-wrapper/src/lib/components/carousel.wrapper.js +4 -4
- package/ssr/esm/components-react/projects/react-ssr-wrapper/src/lib/components/pagination.wrapper.js +4 -4
- package/ssr/esm/components-react/projects/react-ssr-wrapper/src/lib/dsr-components/carousel.js +5 -4
- package/ssr/esm/components-react/projects/react-ssr-wrapper/src/lib/dsr-components/pagination.js +8 -7
- package/ssr/lib/components/carousel.wrapper.d.ts +8 -0
- package/ssr/lib/components/pagination.wrapper.d.ts +10 -2
- package/ssr/lib/dsr-components/pagination.d.ts +0 -1
- package/ssr/lib/types.d.ts +199 -199
|
@@ -158,14 +158,17 @@ const hasVisibleIcon = (iconName, iconSource) => {
|
|
|
158
158
|
};
|
|
159
159
|
|
|
160
160
|
const childrenMutationMap = new Map();
|
|
161
|
-
const getObservedNode = (mutatedNode) => childrenMutationMap.has(mutatedNode) ? mutatedNode : getObservedNode(mutatedNode.parentNode);
|
|
162
161
|
hasWindow &&
|
|
163
162
|
new MutationObserver((mutations) => {
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
163
|
+
// there may be race conditions in jsdom-polyfill tests where the map is already empty when a mutation happens
|
|
164
|
+
if (childrenMutationMap.size) {
|
|
165
|
+
const mapKeys = Array.from(childrenMutationMap.keys());
|
|
166
|
+
mutations
|
|
167
|
+
// remove duplicates so we execute callback only once per node
|
|
168
|
+
.filter((mutation, idx, arr) => arr.findIndex((m) => m.target === mutation.target) === idx)
|
|
169
|
+
// find node in map that contains the mutated element to find and invoke its callback
|
|
170
|
+
.forEach((mutation) => { var _a; return (_a = childrenMutationMap.get(mapKeys.find((node) => node.contains(mutation.target)))) === null || _a === void 0 ? void 0 : _a(); });
|
|
171
|
+
}
|
|
169
172
|
});
|
|
170
173
|
|
|
171
174
|
const isTouchDevice = () => {
|
|
@@ -2759,7 +2762,7 @@ function convertCase(style) {
|
|
|
2759
2762
|
*/
|
|
2760
2763
|
|
|
2761
2764
|
|
|
2762
|
-
function camelCase
|
|
2765
|
+
function camelCase() {
|
|
2763
2766
|
function onProcessStyle(style) {
|
|
2764
2767
|
if (Array.isArray(style)) {
|
|
2765
2768
|
// Handle rules like @font-face, which can have multiple styles in an array
|
|
@@ -3629,7 +3632,7 @@ createJss({
|
|
|
3629
3632
|
plugins: [
|
|
3630
3633
|
jssGlobal(),
|
|
3631
3634
|
jssNested(),
|
|
3632
|
-
camelCase
|
|
3635
|
+
camelCase(),
|
|
3633
3636
|
jssPluginSortMediaQueries({ combineMediaQueries: true }),
|
|
3634
3637
|
],
|
|
3635
3638
|
});
|
|
@@ -3683,7 +3686,11 @@ const getButtonAriaAttributes = (isDisabled, isLoading, aria) => {
|
|
|
3683
3686
|
};
|
|
3684
3687
|
getMediaQueryMin('s');
|
|
3685
3688
|
getMediaQueryMin('xxl');
|
|
3686
|
-
|
|
3689
|
+
// Infinite bullets will be shown if the total number of bullets is greater than this value
|
|
3690
|
+
const INFINITE_BULLET_THRESHOLD = 5;
|
|
3691
|
+
const isInfinitePagination = (amountOfPages) => {
|
|
3692
|
+
return amountOfPages > INFINITE_BULLET_THRESHOLD;
|
|
3693
|
+
};
|
|
3687
3694
|
|
|
3688
3695
|
const CDN_BASE_URL$3 = (typeof window !== 'undefined' && window.PORSCHE_DESIGN_SYSTEM_CDN === 'cn' ? 'https://cdn.ui.porsche.cn' : 'https://cdn.ui.porsche.com') + '/porsche-design-system/crest';
|
|
3689
3696
|
const CRESTS_MANIFEST = { "porscheCrest": { "1x": { "png": "porsche-crest.min.d76137cf8cf94822b7aedb534ba88418@1x.png", "webp": "porsche-crest.min.0d0cc89ae5ee57c4c15bd0dbbcbfe5d0@1x.webp" }, "2x": { "png": "porsche-crest.min.8a292fbd35a5155789ddd011585e05c4@2x.png", "webp": "porsche-crest.min.2245c45e99be5a46b4b56e73c43d5c63@2x.webp" }, "3x": { "png": "porsche-crest.min.18d6f02003b0829bac939fade88fd4e6@3x.png", "webp": "porsche-crest.min.19b429278b158b5cb5aa6ce80751e3fe@3x.webp" } } };
|
|
@@ -3812,38 +3819,21 @@ const getSvgUrl = (model) => {
|
|
|
3812
3819
|
return `${cdnBaseUrl}/${MODEL_SIGNATURES_MANIFEST[model]}`;
|
|
3813
3820
|
};
|
|
3814
3821
|
const modelSignatureHeight = 36;
|
|
3815
|
-
|
|
3816
|
-
|
|
3817
|
-
PAGE
|
|
3818
|
-
ELLIPSIS
|
|
3819
|
-
|
|
3820
|
-
|
|
3821
|
-
};
|
|
3822
|
-
|
|
3823
|
-
|
|
3824
|
-
FIRST_ELLIPSIS: -1,
|
|
3825
|
-
SECOND_ELLIPSIS: -2,
|
|
3826
|
-
PREVIOUS_PAGE_LINK: -4,
|
|
3827
|
-
NEXT_PAGE_LINK: -5,
|
|
3828
|
-
};
|
|
3829
|
-
// TODO: merge factories
|
|
3830
|
-
const createFirstEllipsis = (pageNumber) => ({
|
|
3831
|
-
type: itemTypes.ELLIPSIS,
|
|
3832
|
-
key: itemKeys.FIRST_ELLIPSIS,
|
|
3833
|
-
value: pageNumber,
|
|
3834
|
-
isActive: false,
|
|
3835
|
-
});
|
|
3836
|
-
const createSecondEllipsis = (pageNumber) => ({
|
|
3837
|
-
type: itemTypes.ELLIPSIS,
|
|
3838
|
-
key: itemKeys.SECOND_ELLIPSIS,
|
|
3839
|
-
value: pageNumber,
|
|
3822
|
+
exports.ItemType = void 0;
|
|
3823
|
+
(function (ItemType) {
|
|
3824
|
+
ItemType[ItemType["PAGE"] = 0] = "PAGE";
|
|
3825
|
+
ItemType[ItemType["ELLIPSIS"] = 1] = "ELLIPSIS";
|
|
3826
|
+
ItemType[ItemType["PREVIOUS"] = 2] = "PREVIOUS";
|
|
3827
|
+
ItemType[ItemType["NEXT"] = 3] = "NEXT";
|
|
3828
|
+
})(exports.ItemType || (exports.ItemType = {}));
|
|
3829
|
+
const ellipsisItem = {
|
|
3830
|
+
type: exports.ItemType.ELLIPSIS,
|
|
3840
3831
|
isActive: false,
|
|
3841
|
-
}
|
|
3832
|
+
};
|
|
3842
3833
|
const createPreviousPageLink = (options) => {
|
|
3843
3834
|
const { activePage } = options;
|
|
3844
3835
|
return {
|
|
3845
|
-
type:
|
|
3846
|
-
key: itemKeys.PREVIOUS_PAGE_LINK,
|
|
3836
|
+
type: exports.ItemType.PREVIOUS,
|
|
3847
3837
|
value: Math.max(1, activePage - 1),
|
|
3848
3838
|
isActive: activePage > 1,
|
|
3849
3839
|
};
|
|
@@ -3851,78 +3841,58 @@ const createPreviousPageLink = (options) => {
|
|
|
3851
3841
|
const createNextPageLink = (options) => {
|
|
3852
3842
|
const { activePage, pageTotal } = options;
|
|
3853
3843
|
return {
|
|
3854
|
-
type:
|
|
3855
|
-
key: itemKeys.NEXT_PAGE_LINK,
|
|
3844
|
+
type: exports.ItemType.NEXT,
|
|
3856
3845
|
value: Math.min(pageTotal, activePage + 1),
|
|
3857
3846
|
isActive: activePage < pageTotal,
|
|
3858
3847
|
};
|
|
3859
3848
|
};
|
|
3860
3849
|
const createPageFunctionFactory = (options) => {
|
|
3861
|
-
const { activePage } = options;
|
|
3862
3850
|
return (pageNumber) => ({
|
|
3863
|
-
type:
|
|
3864
|
-
key: pageNumber,
|
|
3851
|
+
type: exports.ItemType.PAGE,
|
|
3865
3852
|
value: pageNumber,
|
|
3866
|
-
isActive: pageNumber === activePage,
|
|
3853
|
+
isActive: pageNumber === options.activePage,
|
|
3867
3854
|
});
|
|
3868
3855
|
};
|
|
3869
3856
|
const createRange = (start, end) => Array.from(Array(end - start + 1)).map((_, i) => i + start);
|
|
3870
3857
|
const createPaginationModel = (options) => {
|
|
3871
|
-
|
|
3872
|
-
if (options == null) {
|
|
3873
|
-
throw new Error('createPaginationModel(): options object should be a passed');
|
|
3874
|
-
}
|
|
3875
|
-
const { pageTotal, activePage, pageRange } = options;
|
|
3858
|
+
const { pageTotal, activePage, pageRange, showLastPage } = options;
|
|
3876
3859
|
const boundaryPagesRange = 1;
|
|
3877
3860
|
const ellipsisSize = 1;
|
|
3878
|
-
const paginationModel = [];
|
|
3861
|
+
const paginationModel = [createPreviousPageLink(options)];
|
|
3879
3862
|
const createPage = createPageFunctionFactory(options);
|
|
3880
|
-
paginationModel.push(createPreviousPageLink(options));
|
|
3881
3863
|
// Simplify generation of pages if number of available items is equal or greater than total pages to show
|
|
3882
3864
|
if (1 + 2 * ellipsisSize + 2 * pageRange + 2 * boundaryPagesRange >= pageTotal) {
|
|
3883
3865
|
const allPages = createRange(1, pageTotal).map(createPage);
|
|
3884
3866
|
paginationModel.push(...allPages);
|
|
3885
3867
|
}
|
|
3886
3868
|
else {
|
|
3887
|
-
//
|
|
3888
|
-
|
|
3889
|
-
|
|
3890
|
-
const
|
|
3891
|
-
|
|
3892
|
-
const
|
|
3893
|
-
|
|
3894
|
-
const
|
|
3895
|
-
|
|
3896
|
-
const
|
|
3897
|
-
|
|
3898
|
-
|
|
3899
|
-
|
|
3900
|
-
|
|
3901
|
-
|
|
3902
|
-
const
|
|
3903
|
-
const
|
|
3904
|
-
|
|
3905
|
-
|
|
3906
|
-
|
|
3907
|
-
|
|
3908
|
-
|
|
3909
|
-
// Calculate and add ellipsis after group of main pages
|
|
3910
|
-
const secondEllipsisPageNumber = mainPagesEnd + 1;
|
|
3911
|
-
const showPageInsteadOfSecondEllipsis = secondEllipsisPageNumber === lastPagesStart - 1;
|
|
3912
|
-
const createSecondEllipsisOrPage = showPageInsteadOfSecondEllipsis ? createPage : createSecondEllipsis;
|
|
3913
|
-
const secondEllipsis = createSecondEllipsisOrPage(secondEllipsisPageNumber);
|
|
3914
|
-
paginationModel.push(secondEllipsis);
|
|
3915
|
-
// Add group of last pages
|
|
3916
|
-
paginationModel.push(...lastPages);
|
|
3869
|
+
// Add first page
|
|
3870
|
+
paginationModel.push(createPage(1));
|
|
3871
|
+
// Calculate group of middle pages
|
|
3872
|
+
const middlePagesStart = Math.min(Math.max(activePage - pageRange, 2 + ellipsisSize), pageTotal - ellipsisSize - 2 * pageRange - (showLastPage ? 1 : 0));
|
|
3873
|
+
const middlePagesEnd = middlePagesStart + 2 * pageRange;
|
|
3874
|
+
const middlePages = createRange(middlePagesStart, middlePagesEnd).map(createPage);
|
|
3875
|
+
// Calculate and add ellipsis before group of middle pages
|
|
3876
|
+
const firstEllipsisPageNumber = middlePagesStart - 1;
|
|
3877
|
+
const showPageInsteadOfFirstEllipsis = firstEllipsisPageNumber === 2;
|
|
3878
|
+
const firstEllipsisOrPage = showPageInsteadOfFirstEllipsis ? createPage(firstEllipsisPageNumber) : ellipsisItem;
|
|
3879
|
+
paginationModel.push(firstEllipsisOrPage);
|
|
3880
|
+
// Add group of middle pages
|
|
3881
|
+
paginationModel.push(...middlePages);
|
|
3882
|
+
// Calculate and add ellipsis after group of middle pages
|
|
3883
|
+
const lastEllipsisPageNumber = middlePagesEnd + 1;
|
|
3884
|
+
const showPageInsteadOfLastEllipsis = lastEllipsisPageNumber === pageTotal - (showLastPage ? 1 : 0);
|
|
3885
|
+
const lastEllipsisOrPage = showPageInsteadOfLastEllipsis ? createPage(lastEllipsisPageNumber) : ellipsisItem;
|
|
3886
|
+
paginationModel.push(lastEllipsisOrPage);
|
|
3887
|
+
// Add last page
|
|
3888
|
+
if (showLastPage) {
|
|
3889
|
+
paginationModel.push(createPage(pageTotal));
|
|
3890
|
+
}
|
|
3917
3891
|
}
|
|
3918
3892
|
paginationModel.push(createNextPageLink(options));
|
|
3919
3893
|
return paginationModel;
|
|
3920
3894
|
};
|
|
3921
3895
|
const getCurrentActivePage = (activePage, totalPages) => {
|
|
3922
|
-
// exception tests
|
|
3923
|
-
if (activePage === undefined || totalPages === undefined) {
|
|
3924
|
-
throw new Error('getCurrentActivePage(): activePage and totalPages props must be provided');
|
|
3925
|
-
}
|
|
3926
3896
|
// Obviously we can't be on a negative or 0 page.
|
|
3927
3897
|
if (activePage < 1) {
|
|
3928
3898
|
activePage = 1;
|
|
@@ -3934,10 +3904,6 @@ const getCurrentActivePage = (activePage, totalPages) => {
|
|
|
3934
3904
|
return activePage;
|
|
3935
3905
|
};
|
|
3936
3906
|
const getTotalPages = (totalItemsCount, itemsPerPage) => {
|
|
3937
|
-
// exception test
|
|
3938
|
-
if (totalItemsCount === undefined || itemsPerPage === undefined) {
|
|
3939
|
-
throw new Error('getTotalPages(): totalItemsCount and itemsPerPage props must be provided');
|
|
3940
|
-
}
|
|
3941
3907
|
if (totalItemsCount < 1) {
|
|
3942
3908
|
totalItemsCount = 1;
|
|
3943
3909
|
}
|
|
@@ -4140,6 +4106,7 @@ exports.hasWindow = hasWindow;
|
|
|
4140
4106
|
exports.isCustomDropdown = isCustomDropdown;
|
|
4141
4107
|
exports.isDisabledOrLoading = isDisabledOrLoading;
|
|
4142
4108
|
exports.isHighContrastMode = isHighContrastMode;
|
|
4109
|
+
exports.isInfinitePagination = isInfinitePagination;
|
|
4143
4110
|
exports.isListTypeOrdered = isListTypeOrdered;
|
|
4144
4111
|
exports.isScrollable = isScrollable;
|
|
4145
4112
|
exports.isSortable = isSortable;
|
|
@@ -4149,7 +4116,6 @@ exports.isTouchDevice = isTouchDevice;
|
|
|
4149
4116
|
exports.isType = isType;
|
|
4150
4117
|
exports.isUrl = isUrl;
|
|
4151
4118
|
exports.isWithinForm = isWithinForm;
|
|
4152
|
-
exports.itemTypes = itemTypes;
|
|
4153
4119
|
exports.modelSignatureHeight = modelSignatureHeight;
|
|
4154
4120
|
exports.parseAndGetAriaAttributes = parseAndGetAriaAttributes;
|
|
4155
4121
|
exports.parseJSONAttribute = parseJSONAttribute;
|
package/ssr/components-react/projects/react-ssr-wrapper/src/lib/components/carousel.wrapper.js
CHANGED
|
@@ -6,15 +6,15 @@ var hooks = require('../../hooks.js');
|
|
|
6
6
|
var utils = require('../../utils.js');
|
|
7
7
|
var carousel = require('../dsr-components/carousel.js');
|
|
8
8
|
|
|
9
|
-
const PCarousel = react.forwardRef(({ activeSlideIndex = 0, alignHeader = 'left', description, disablePagination, heading, intl, onCarouselChange, onUpdate, pagination = true, rewind = true, slidesPerPage = 1, theme = 'light', width = 'basic', wrapContent, className, children, ...rest }, ref) => {
|
|
9
|
+
const PCarousel = react.forwardRef(({ activeSlideIndex = 0, alignHeader = 'left', description, disablePagination, heading, intl, onCarouselChange, onUpdate, pagination = true, rewind = true, skipLinkTarget, slidesPerPage = 1, theme = 'light', width = 'basic', wrapContent, className, children, ...rest }, ref) => {
|
|
10
10
|
const elementRef = react.useRef();
|
|
11
11
|
hooks.useEventCallback(elementRef, 'carouselChange', onCarouselChange);
|
|
12
12
|
hooks.useEventCallback(elementRef, 'update', onUpdate);
|
|
13
13
|
const WebComponentTag = hooks.usePrefix('p-carousel');
|
|
14
|
-
const propsToSync = [activeSlideIndex, alignHeader, description, disablePagination, heading, intl, pagination, rewind, slidesPerPage, theme, width, wrapContent];
|
|
14
|
+
const propsToSync = [activeSlideIndex, alignHeader, description, disablePagination, heading, intl, pagination, rewind, skipLinkTarget, slidesPerPage, theme, width, wrapContent];
|
|
15
15
|
hooks.useBrowserLayoutEffect(() => {
|
|
16
16
|
const { current } = elementRef;
|
|
17
|
-
['activeSlideIndex', 'alignHeader', 'description', 'disablePagination', 'heading', 'intl', 'pagination', 'rewind', 'slidesPerPage', 'theme', 'width', 'wrapContent'].forEach((propName, i) => (current[propName] = propsToSync[i]));
|
|
17
|
+
['activeSlideIndex', 'alignHeader', 'description', 'disablePagination', 'heading', 'intl', 'pagination', 'rewind', 'skipLinkTarget', 'slidesPerPage', 'theme', 'width', 'wrapContent'].forEach((propName, i) => (current[propName] = propsToSync[i]));
|
|
18
18
|
}, propsToSync);
|
|
19
19
|
// @ts-ignore
|
|
20
20
|
if (!process.browser) {
|
|
@@ -25,7 +25,7 @@ const PCarousel = react.forwardRef(({ activeSlideIndex = 0, alignHeader = 'left'
|
|
|
25
25
|
// @ts-ignore
|
|
26
26
|
...(!process.browser
|
|
27
27
|
? {
|
|
28
|
-
children: (jsxRuntime.jsx(carousel.DSRCarousel, { ...{ activeSlideIndex, alignHeader, description, disablePagination, heading, intl, pagination, rewind, slidesPerPage, theme, width, wrapContent, children } })),
|
|
28
|
+
children: (jsxRuntime.jsx(carousel.DSRCarousel, { ...{ activeSlideIndex, alignHeader, description, disablePagination, heading, intl, pagination, rewind, skipLinkTarget, slidesPerPage, theme, width, wrapContent, children } })),
|
|
29
29
|
}
|
|
30
30
|
: {
|
|
31
31
|
children,
|
package/ssr/components-react/projects/react-ssr-wrapper/src/lib/components/pagination.wrapper.js
CHANGED
|
@@ -6,15 +6,15 @@ var hooks = require('../../hooks.js');
|
|
|
6
6
|
var utils = require('../../utils.js');
|
|
7
7
|
var pagination = require('../dsr-components/pagination.js');
|
|
8
8
|
|
|
9
|
-
const PPagination = react.forwardRef(({ activePage = 1, allyLabel, allyLabelNext, allyLabelPage, allyLabelPrev, intl = { root: 'Pagination', prev: 'Previous page', next: 'Next page', page: 'Page', }, itemsPerPage = 1, maxNumberOfPageLinks = { base: 5, xs: 7, }, onPageChange, onUpdate, theme = 'light', totalItemsCount = 1, className, ...rest }, ref) => {
|
|
9
|
+
const PPagination = react.forwardRef(({ activePage = 1, allyLabel, allyLabelNext, allyLabelPage, allyLabelPrev, intl = { root: 'Pagination', prev: 'Previous page', next: 'Next page', page: 'Page', }, itemsPerPage = 1, maxNumberOfPageLinks = { base: 5, xs: 7, }, onPageChange, onUpdate, showLastPage = true, theme = 'light', totalItemsCount = 1, className, ...rest }, ref) => {
|
|
10
10
|
const elementRef = react.useRef();
|
|
11
11
|
hooks.useEventCallback(elementRef, 'pageChange', onPageChange);
|
|
12
12
|
hooks.useEventCallback(elementRef, 'update', onUpdate);
|
|
13
13
|
const WebComponentTag = hooks.usePrefix('p-pagination');
|
|
14
|
-
const propsToSync = [activePage, allyLabel, allyLabelNext, allyLabelPage, allyLabelPrev, intl, itemsPerPage, maxNumberOfPageLinks, theme, totalItemsCount];
|
|
14
|
+
const propsToSync = [activePage, allyLabel, allyLabelNext, allyLabelPage, allyLabelPrev, intl, itemsPerPage, maxNumberOfPageLinks, showLastPage, theme, totalItemsCount];
|
|
15
15
|
hooks.useBrowserLayoutEffect(() => {
|
|
16
16
|
const { current } = elementRef;
|
|
17
|
-
['activePage', 'allyLabel', 'allyLabelNext', 'allyLabelPage', 'allyLabelPrev', 'intl', 'itemsPerPage', 'maxNumberOfPageLinks', 'theme', 'totalItemsCount'].forEach((propName, i) => (current[propName] = propsToSync[i]));
|
|
17
|
+
['activePage', 'allyLabel', 'allyLabelNext', 'allyLabelPage', 'allyLabelPrev', 'intl', 'itemsPerPage', 'maxNumberOfPageLinks', 'showLastPage', 'theme', 'totalItemsCount'].forEach((propName, i) => (current[propName] = propsToSync[i]));
|
|
18
18
|
}, propsToSync);
|
|
19
19
|
// @ts-ignore
|
|
20
20
|
if (!process.browser) {
|
|
@@ -25,7 +25,7 @@ const PPagination = react.forwardRef(({ activePage = 1, allyLabel, allyLabelNext
|
|
|
25
25
|
// @ts-ignore
|
|
26
26
|
...(!process.browser
|
|
27
27
|
? {
|
|
28
|
-
children: (jsxRuntime.jsx(pagination.DSRPagination, { ...{ activePage, allyLabel, allyLabelNext, allyLabelPage, allyLabelPrev, intl, itemsPerPage, maxNumberOfPageLinks, theme, totalItemsCount } })),
|
|
28
|
+
children: (jsxRuntime.jsx(pagination.DSRPagination, { ...{ activePage, allyLabel, allyLabelNext, allyLabelPage, allyLabelPrev, intl, itemsPerPage, maxNumberOfPageLinks, showLastPage, theme, totalItemsCount } })),
|
|
29
29
|
}
|
|
30
30
|
: {
|
|
31
31
|
suppressHydrationWarning: true,
|
|
@@ -25,7 +25,7 @@ require('../components/headline.wrapper.js');
|
|
|
25
25
|
require('../components/icon.wrapper.js');
|
|
26
26
|
require('../components/inline-notification.wrapper.js');
|
|
27
27
|
require('../components/link.wrapper.js');
|
|
28
|
-
require('../components/link-pure.wrapper.js');
|
|
28
|
+
var linkPure_wrapper = require('../components/link-pure.wrapper.js');
|
|
29
29
|
require('../components/link-social.wrapper.js');
|
|
30
30
|
require('../components/link-tile.wrapper.js');
|
|
31
31
|
require('../components/link-tile-model-signature.wrapper.js');
|
|
@@ -67,6 +67,7 @@ var react = require('react');
|
|
|
67
67
|
var minifyCss = require('../../minifyCss.js');
|
|
68
68
|
var stripFocusAndHoverStyles = require('../../stripFocusAndHoverStyles.js');
|
|
69
69
|
var stylesEntry = require('../../../../../../components/dist/styles/esm/styles-entry.js');
|
|
70
|
+
var utilsEntry = require('../../../../../../components/dist/utils/esm/utils-entry.js');
|
|
70
71
|
|
|
71
72
|
class DSRCarousel extends react.Component {
|
|
72
73
|
constructor() {
|
|
@@ -89,9 +90,9 @@ class DSRCarousel extends react.Component {
|
|
|
89
90
|
? typeof this.props.disablePagination === 'object'
|
|
90
91
|
? Object.fromEntries(Object.entries(this.props.disablePagination).map(([key, value]) => [key, !value]))
|
|
91
92
|
: !this.props.disablePagination
|
|
92
|
-
: this.props.pagination, this.props.alignHeader, this.props.theme)));
|
|
93
|
-
return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsxs("template", { shadowroot: "open", shadowrootmode: "open", children: [jsxRuntime.jsx("style", { dangerouslySetInnerHTML: { __html: style } }), jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsxs("div", { className: "header", children: [this.props.heading ? jsxRuntime.jsx("h2", { children: this.props.heading }) : jsxRuntime.jsx("slot", { name: "heading" }), (this.props.description || namedSlotChildren.filter(({ props: { slot } }) => slot === 'description').length > 0) &&
|
|
94
|
-
((this.props.description && jsxRuntime.jsx("p", { children: this.props.description })) || jsxRuntime.jsx("slot", { name: "description" })), jsxRuntime.jsxs("div", { className: "nav", children: [jsxRuntime.jsx(buttonPure_wrapper.PButtonPure, { ...btnProps, icon: "arrow-left" }), jsxRuntime.jsx(buttonPure_wrapper.PButtonPure, { ...btnProps, icon: "arrow-right" })] })] }), jsxRuntime.jsx("div", { id: "splide", className: "splide", "aria-label": this.props.heading || ((_a = namedSlotChildren.find(({ props: { slot } }) => slot === 'heading')) === null || _a === void 0 ? void 0 : _a.props.children), children: jsxRuntime.jsx("div", { className: "splide__track", children: jsxRuntime.jsx("div", { className: "splide__list", children: otherChildren.map((_, i) => (jsxRuntime.jsx("div", { className: "splide__slide", children: jsxRuntime.jsx("slot", { name: `slide-${i}` }) }, i))) }) }) }), (this.props.disablePagination ? this.props.disablePagination !== true : this.props.pagination) && (jsxRuntime.jsx("div", { className: "pagination" }))] })] }), this.props.children] }));
|
|
93
|
+
: this.props.pagination, utilsEntry.isInfinitePagination(this.props.amountOfPages), this.props.alignHeader, this.props.theme)));
|
|
94
|
+
return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsxs("template", { shadowroot: "open", shadowrootmode: "open", children: [jsxRuntime.jsx("style", { dangerouslySetInnerHTML: { __html: style } }), jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsxs("div", { className: "header", children: [this.props.heading ? jsxRuntime.jsx("h2", { id: "heading", children: this.props.heading }) : jsxRuntime.jsx("slot", { name: "heading" }), (this.props.description || namedSlotChildren.filter(({ props: { slot } }) => slot === 'description').length > 0) &&
|
|
95
|
+
((this.props.description && jsxRuntime.jsx("p", { children: this.props.description })) || jsxRuntime.jsx("slot", { name: "description" })), jsxRuntime.jsxs("div", { className: "nav", children: [this.props.skipLinkTarget && (jsxRuntime.jsx(linkPure_wrapper.PLinkPure, { href: this.props.skipLinkTarget, theme: this.props.theme, icon: "arrow-last", className: "btn skip-link", alignLabel: "left", hideLabel: true, "aria-describedby": this.props.heading ? 'heading' : null, children: "Skip carousel entries" })), jsxRuntime.jsx(buttonPure_wrapper.PButtonPure, { ...btnProps, icon: "arrow-left" }), jsxRuntime.jsx(buttonPure_wrapper.PButtonPure, { ...btnProps, icon: "arrow-right" })] })] }), jsxRuntime.jsx("div", { id: "splide", className: "splide", "aria-label": this.props.heading || ((_a = namedSlotChildren.find(({ props: { slot } }) => slot === 'heading')) === null || _a === void 0 ? void 0 : _a.props.children), children: jsxRuntime.jsx("div", { className: "splide__track", children: jsxRuntime.jsx("div", { className: "splide__list", children: otherChildren.map((_, i) => (jsxRuntime.jsx("div", { className: "splide__slide", tabIndex: 0, children: jsxRuntime.jsx("slot", { name: `slide-${i}` }) }, i))) }) }) }), (this.props.disablePagination ? this.props.disablePagination !== true : this.props.pagination) && (jsxRuntime.jsx("div", { className: "pagination-container", children: jsxRuntime.jsx("div", { className: "pagination" }) }))] })] }), this.props.children] }));
|
|
95
96
|
}
|
|
96
97
|
}
|
|
97
98
|
|
package/ssr/components-react/projects/react-ssr-wrapper/src/lib/dsr-components/pagination.js
CHANGED
|
@@ -79,6 +79,7 @@ class DSRPagination extends react.Component {
|
|
|
79
79
|
activePage: utilsEntry.getCurrentActivePage(this.props.activePage, pageTotal),
|
|
80
80
|
pageTotal,
|
|
81
81
|
pageRange: this.props.breakpointMaxNumberOfPageLinks === 7 ? 1 : 0,
|
|
82
|
+
showLastPage: this.props.showLastPage,
|
|
82
83
|
});
|
|
83
84
|
const style = minifyCss.minifyCss(stripFocusAndHoverStyles.stripFocusAndHoverStyles(stylesEntry.getPaginationCss(this.props.maxNumberOfPageLinks, this.props.theme)));
|
|
84
85
|
return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsxs("template", { shadowroot: "open", shadowrootmode: "open", shadowrootdelegatesfocus: "true", children: [jsxRuntime.jsx("style", { dangerouslySetInnerHTML: { __html: style } }), jsxRuntime.jsx("nav", { role: "navigation", "aria-label": this.props.allyLabel || this.props.intl.root, children: jsxRuntime.jsx("ul", { children: paginationModel.map((pageModel) => {
|
|
@@ -93,14 +94,14 @@ class DSRPagination extends react.Component {
|
|
|
93
94
|
'aria-hidden': 'true',
|
|
94
95
|
};
|
|
95
96
|
switch (type) {
|
|
96
|
-
case utilsEntry.
|
|
97
|
-
return (jsxRuntime.jsx("li", { children: jsxRuntime.jsx("span", { ...spanProps, "aria-
|
|
98
|
-
case utilsEntry.
|
|
97
|
+
case utilsEntry.ItemType.PREVIOUS:
|
|
98
|
+
return (jsxRuntime.jsx("li", { children: jsxRuntime.jsx("span", { ...spanProps, "aria-label": this.props.allyLabelPrev || this.props.intl.prev, "aria-disabled": isActive ? null : 'true', children: jsxRuntime.jsx(icon_wrapper.PIcon, { name: "arrow-left", ...iconProps }) }) }, "prev"));
|
|
99
|
+
case utilsEntry.ItemType.ELLIPSIS:
|
|
99
100
|
return (jsxRuntime.jsx("li", { children: jsxRuntime.jsx("span", { className: "ellipsis" }) }, "ellipsis"));
|
|
100
|
-
case utilsEntry.
|
|
101
|
+
case utilsEntry.ItemType.PAGE:
|
|
101
102
|
return (jsxRuntime.jsx("li", { children: jsxRuntime.jsx("span", { ...spanProps, tabIndex: 0, "aria-label": `${this.props.allyLabelPage || this.props.intl.page} ${value}`, "aria-current": isActive ? 'page' : null, children: value }) }, value));
|
|
102
|
-
case utilsEntry.
|
|
103
|
-
return (jsxRuntime.jsx("li", { children: jsxRuntime.jsx("span", { ...spanProps, "aria-
|
|
103
|
+
case utilsEntry.ItemType.NEXT:
|
|
104
|
+
return (jsxRuntime.jsx("li", { children: jsxRuntime.jsx("span", { ...spanProps, "aria-label": this.props.allyLabelNext || this.props.intl.next, "aria-disabled": isActive ? null : 'true', children: jsxRuntime.jsx(icon_wrapper.PIcon, { name: "arrow-right", ...iconProps }) }) }, "next"));
|
|
104
105
|
}
|
|
105
106
|
}) }) })] }) }));
|
|
106
107
|
}
|
|
@@ -313,14 +313,17 @@ const hasVisibleIcon = (iconName, iconSource) => {
|
|
|
313
313
|
};
|
|
314
314
|
|
|
315
315
|
const childrenMutationMap = new Map();
|
|
316
|
-
const getObservedNode = (mutatedNode) => childrenMutationMap.has(mutatedNode) ? mutatedNode : getObservedNode(mutatedNode.parentNode);
|
|
317
316
|
hasWindow &&
|
|
318
317
|
new MutationObserver((mutations) => {
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
318
|
+
// there may be race conditions in jsdom-polyfill tests where the map is already empty when a mutation happens
|
|
319
|
+
if (childrenMutationMap.size) {
|
|
320
|
+
const mapKeys = Array.from(childrenMutationMap.keys());
|
|
321
|
+
mutations
|
|
322
|
+
// remove duplicates so we execute callback only once per node
|
|
323
|
+
.filter((mutation, idx, arr) => arr.findIndex((m) => m.target === mutation.target) === idx)
|
|
324
|
+
// find node in map that contains the mutated element to find and invoke its callback
|
|
325
|
+
.forEach((mutation) => { var _a; return (_a = childrenMutationMap.get(mapKeys.find((node) => node.contains(mutation.target)))) === null || _a === void 0 ? void 0 : _a(); });
|
|
326
|
+
}
|
|
324
327
|
});
|
|
325
328
|
|
|
326
329
|
/* eslint-disable no-undefined,no-param-reassign,no-shadow */
|
|
@@ -4350,6 +4353,11 @@ const getComponentCss$U = (icon, iconSource, variant, hideLabel, disabled, loadi
|
|
|
4350
4353
|
|
|
4351
4354
|
const carouselTransitionDuration = 400;
|
|
4352
4355
|
const bulletActiveClass = 'bullet--active';
|
|
4356
|
+
const paginationInfiniteStartCaseClass = 'pagination--infinite';
|
|
4357
|
+
const bulletInfiniteClass = 'bullet--infinite';
|
|
4358
|
+
const paginationBulletSize = '8px';
|
|
4359
|
+
const paginationInfiniteBulletSize = '4px';
|
|
4360
|
+
const paginationActiveBulletSize = '20px';
|
|
4353
4361
|
const selectorHeading = 'h2,::slotted([slot=heading])';
|
|
4354
4362
|
const selectorDescription = 'p,::slotted([slot=description])';
|
|
4355
4363
|
const mediaQueryS = getMediaQueryMin('s');
|
|
@@ -4357,13 +4365,13 @@ const mediaQueryXXL = getMediaQueryMin('xxl');
|
|
|
4357
4365
|
// we need an explicit grid template, therefor we need to calculate the button group width
|
|
4358
4366
|
const buttonSize$1 = `calc(${spacingStaticSmall} * 2 + ${fontLineHeight})`;
|
|
4359
4367
|
// + 2px, compensates hover offset of button-pure
|
|
4360
|
-
const buttonGroupWidth = `calc(${buttonSize$1} *
|
|
4368
|
+
const buttonGroupWidth = `calc(${buttonSize$1} * 3 + ${spacingStaticXSmall} + 2px)`;
|
|
4361
4369
|
const spacingMap = {
|
|
4362
4370
|
basic: gridBasicOffset,
|
|
4363
4371
|
extended: gridExtendedOffset,
|
|
4364
4372
|
};
|
|
4365
|
-
const getComponentCss$T = (width, hasPagination, alignHeader, theme) => {
|
|
4366
|
-
const { primaryColor, contrastMediumColor } = getThemedColors(theme);
|
|
4373
|
+
const getComponentCss$T = (width, hasPagination, isInfinitePagination, alignHeader, theme) => {
|
|
4374
|
+
const { primaryColor, contrastMediumColor, focusColor } = getThemedColors(theme);
|
|
4367
4375
|
const { canvasTextColor } = getHighContrastColors();
|
|
4368
4376
|
const isHeaderAlignCenter = alignHeader === 'center';
|
|
4369
4377
|
return getCss(Object.assign({ '@global': {
|
|
@@ -4393,12 +4401,23 @@ const getComponentCss$T = (width, hasPagination, alignHeader, theme) => {
|
|
|
4393
4401
|
gap: spacingStaticXSmall,
|
|
4394
4402
|
gridArea: '1 / 3 / 3 / auto',
|
|
4395
4403
|
alignItems: 'end',
|
|
4404
|
+
justifyContent: 'end',
|
|
4405
|
+
justifySelf: 'end',
|
|
4396
4406
|
},
|
|
4397
4407
|
}, btn: {
|
|
4398
4408
|
padding: spacingStaticSmall,
|
|
4409
|
+
}, 'skip-link': {
|
|
4410
|
+
opacity: 0,
|
|
4411
|
+
pointerEvents: 'none',
|
|
4412
|
+
'&:focus': {
|
|
4413
|
+
opacity: 1,
|
|
4414
|
+
pointerEvents: 'all',
|
|
4415
|
+
},
|
|
4399
4416
|
}, splide: {
|
|
4400
4417
|
overflow: 'hidden',
|
|
4401
4418
|
// visibility: 'hidden',
|
|
4419
|
+
padding: '4px 0',
|
|
4420
|
+
margin: '-4px 0',
|
|
4402
4421
|
'&__track': Object.assign(Object.assign({ cursor: 'grab' }, addImportantToEachRule({
|
|
4403
4422
|
padding: `0 ${spacingMap[width].base}`,
|
|
4404
4423
|
[getMediaQueryMax('xs')]: {
|
|
@@ -4415,26 +4434,57 @@ const getComponentCss$T = (width, hasPagination, alignHeader, theme) => {
|
|
|
4415
4434
|
WebkitUserSelect: 'none',
|
|
4416
4435
|
WebkitTouchCallout: 'none',
|
|
4417
4436
|
} }),
|
|
4418
|
-
'&__list': Object.assign({ display: 'flex'
|
|
4419
|
-
'&__slide': Object.assign(Object.assign({ position: 'relative', flexShrink: 0 }, getBackfaceVisibilityJssStyle()), { transform: 'translateZ(0)'
|
|
4437
|
+
'&__list': Object.assign({ display: 'flex' }, getBackfaceVisibilityJssStyle()),
|
|
4438
|
+
'&__slide': Object.assign(Object.assign({ position: 'relative', flexShrink: 0 }, getBackfaceVisibilityJssStyle()), { transform: 'translateZ(0)', borderRadius: borderRadiusLarge, overflow: 'hidden', '&:focus-visible': {
|
|
4439
|
+
outline: `${borderWidthBase} solid ${focusColor}`,
|
|
4440
|
+
outlineOffset: '2px',
|
|
4441
|
+
} }),
|
|
4420
4442
|
'&__sr': getHiddenTextJssStyle(), // appears in the DOM when sliding
|
|
4421
|
-
} }, (hasPagination && {
|
|
4422
|
-
pagination: Object.assign(Object.assign({}, buildResponsiveStyles(hasPagination, (hasPaginationValue) => ({
|
|
4443
|
+
} }, (hasPagination && Object.assign(Object.assign({ ['pagination-container']: Object.assign(Object.assign({}, buildResponsiveStyles(hasPagination, (hasPaginationValue) => ({
|
|
4423
4444
|
display: hasPaginationValue ? 'flex' : 'none',
|
|
4424
|
-
}))), { justifyContent: 'center',
|
|
4425
|
-
|
|
4426
|
-
|
|
4427
|
-
|
|
4428
|
-
|
|
4429
|
-
transition: `
|
|
4430
|
-
|
|
4431
|
-
|
|
4432
|
-
|
|
4433
|
-
|
|
4434
|
-
|
|
4435
|
-
|
|
4445
|
+
}))), { position: 'relative', justifyContent: isInfinitePagination ? 'flex-start' : 'center', width: `calc(${paginationActiveBulletSize} + ${paginationBulletSize} * 4 + ${spacingStaticSmall} * 4)`, left: 'calc(50% - 42px)', overflowX: 'hidden' }), pagination: {
|
|
4446
|
+
display: 'flex',
|
|
4447
|
+
alignItems: 'center',
|
|
4448
|
+
width: 'fit-content',
|
|
4449
|
+
gap: spacingStaticSmall,
|
|
4450
|
+
transition: `transform ${carouselTransitionDuration}ms`,
|
|
4451
|
+
}, bullet: Object.assign({ borderRadius: borderRadiusSmall, background: isHighContrastMode ? canvasTextColor : contrastMediumColor }, (isInfinitePagination
|
|
4452
|
+
? {
|
|
4453
|
+
width: '0px',
|
|
4454
|
+
height: '0px',
|
|
4455
|
+
transition: `background-color ${carouselTransitionDuration}ms, width ${carouselTransitionDuration}ms, height ${carouselTransitionDuration}ms`,
|
|
4456
|
+
}
|
|
4457
|
+
: {
|
|
4458
|
+
width: paginationBulletSize,
|
|
4459
|
+
height: paginationBulletSize,
|
|
4460
|
+
transition: `background-color ${carouselTransitionDuration}ms, width ${carouselTransitionDuration}ms`,
|
|
4461
|
+
})) }, (isInfinitePagination && {
|
|
4462
|
+
[`${paginationInfiniteStartCaseClass}`]: {
|
|
4463
|
+
['& > .bullet:nth-child(-n+4)']: {
|
|
4464
|
+
width: paginationBulletSize,
|
|
4465
|
+
height: paginationBulletSize,
|
|
4466
|
+
},
|
|
4436
4467
|
},
|
|
4437
|
-
|
|
4468
|
+
[`${bulletInfiniteClass}`]: Object.assign(Object.assign({}, addImportantToEachRule({
|
|
4469
|
+
width: paginationInfiniteBulletSize,
|
|
4470
|
+
height: paginationInfiniteBulletSize,
|
|
4471
|
+
})), { '& ~ span': {
|
|
4472
|
+
width: paginationBulletSize,
|
|
4473
|
+
height: paginationBulletSize,
|
|
4474
|
+
}, [`& ~ .${bulletInfiniteClass} ~ span`]: {
|
|
4475
|
+
width: '0px',
|
|
4476
|
+
height: '0px',
|
|
4477
|
+
} }),
|
|
4478
|
+
})), { [`${bulletActiveClass}`]: Object.assign({ background: isHighContrastMode ? canvasTextColor : primaryColor, height: paginationBulletSize, width: addImportantToRule(paginationActiveBulletSize) }, (isInfinitePagination && {
|
|
4479
|
+
'& ~ span': {
|
|
4480
|
+
width: paginationBulletSize,
|
|
4481
|
+
height: paginationBulletSize,
|
|
4482
|
+
},
|
|
4483
|
+
[`& ~ .${bulletInfiniteClass} ~ span`]: {
|
|
4484
|
+
width: '0px',
|
|
4485
|
+
height: '0px',
|
|
4486
|
+
},
|
|
4487
|
+
})) }))));
|
|
4438
4488
|
};
|
|
4439
4489
|
|
|
4440
4490
|
const getThemedFormStateColors = (theme, state) => {
|
|
@@ -5328,7 +5378,7 @@ const getComponentCss$v = (maxNumberOfPageLinks, theme) => {
|
|
|
5328
5378
|
return getCss({
|
|
5329
5379
|
'@global': {
|
|
5330
5380
|
':host': Object.assign({ display: 'block' }, addImportantToEachRule(hostHiddenStyles)),
|
|
5331
|
-
nav: Object.assign({ display: 'flex', justifyContent: 'center' }, buildResponsiveStyles(maxNumberOfPageLinks, (n) => ({
|
|
5381
|
+
nav: Object.assign({ display: 'flex', justifyContent: 'center', userSelect: 'none' }, buildResponsiveStyles(maxNumberOfPageLinks, (n) => ({
|
|
5332
5382
|
counterReset: `size ${n}`,
|
|
5333
5383
|
}))),
|
|
5334
5384
|
ul: {
|
|
@@ -5352,16 +5402,8 @@ const getComponentCss$v = (maxNumberOfPageLinks, theme) => {
|
|
|
5352
5402
|
},
|
|
5353
5403
|
},
|
|
5354
5404
|
span: Object.assign(Object.assign(Object.assign(Object.assign({ display: 'flex', justifyContent: 'center', alignItems: 'center', transition: ['color', 'border-color', 'background-color'].map(getTransition).join(), position: 'relative', width: buttonSize, height: buttonSize, boxSizing: 'border-box' }, textSmallStyle), { whiteSpace: 'nowrap', cursor: 'pointer', color: primaryColor, outline: 0, borderRadius: borderRadiusSmall, borderColor: 'transparent' }), hoverMediaQuery({
|
|
5355
|
-
'&:not([aria-disabled]):not(.ellipsis):hover': Object.assign(Object.assign({}, frostedGlassStyle), {
|
|
5356
|
-
})), { '&:not(.ellipsis):focus::before': Object.assign(Object.assign({ content: '""', position: 'absolute' }, getInsetJssStyle(-4)), { border: `${borderWidthBase} solid ${focusColor}`, borderRadius: borderRadiusMedium }), '&:
|
|
5357
|
-
borderColor: 'transparent',
|
|
5358
|
-
}, '&[aria-current]': {
|
|
5359
|
-
disabledCursorStyle,
|
|
5360
|
-
color: primaryColor,
|
|
5361
|
-
border: `${borderWidthBase} solid ${primaryColor}`,
|
|
5362
|
-
borderRadius: borderRadiusSmall,
|
|
5363
|
-
'&:not(.ellipsis):focus::before': Object.assign({}, getInsetJssStyle(-6)),
|
|
5364
|
-
}, '&[aria-disabled]': Object.assign(Object.assign({}, disabledCursorStyle), { color: disabledColor }) }),
|
|
5405
|
+
'&:not([aria-disabled]):not(.ellipsis):hover': Object.assign(Object.assign({}, frostedGlassStyle), { background: hoverColor }),
|
|
5406
|
+
})), { '&:not(.ellipsis):focus:focus-visible::before': Object.assign(Object.assign({ content: '""', position: 'absolute' }, getInsetJssStyle(-4)), { border: `${borderWidthBase} solid ${focusColor}`, borderRadius: borderRadiusMedium }), '&[aria-current]': Object.assign(Object.assign({}, disabledCursorStyle), { color: primaryColor, border: `${borderWidthBase} solid ${primaryColor}`, '&:not(.ellipsis):focus::before': getInsetJssStyle(-6) }), '&[aria-disabled]': Object.assign(Object.assign({}, disabledCursorStyle), { color: disabledColor }) }),
|
|
5365
5407
|
},
|
|
5366
5408
|
ellipsis: Object.assign(Object.assign({}, disabledCursorStyle), { '&::after': {
|
|
5367
5409
|
content: '"…"',
|