54 lines
2.2 KiB
JavaScript
54 lines
2.2 KiB
JavaScript
import * as React from 'react';
|
|
/**
|
|
* Similar to `getSlots`, main difference is that it's compatible with new custom jsx pragma
|
|
*
|
|
* @internal
|
|
* This is an internal temporary method, this method will cease to exist eventually!
|
|
*
|
|
* * ❗️❗️ **DO NOT USE IT EXTERNALLY** ❗️❗️
|
|
*
|
|
* @deprecated use slot.always or slot.optional combined with assertSlots instead
|
|
*/ export function getSlotsNext(state) {
|
|
const typedState = state;
|
|
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
const slots = {};
|
|
const slotProps = {};
|
|
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
const slotNames = Object.keys(typedState.components);
|
|
for (const slotName of slotNames){
|
|
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
const [slot, props] = getSlotNext(typedState, slotName);
|
|
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
slots[slotName] = slot;
|
|
slotProps[slotName] = props;
|
|
}
|
|
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
return {
|
|
slots,
|
|
slotProps: slotProps
|
|
};
|
|
}
|
|
/**
|
|
* @deprecated use slot.always or slot.optional combined with assertSlots instead
|
|
*/ function getSlotNext(state, slotName) {
|
|
var _state_components, _state_components1;
|
|
const props = state[slotName];
|
|
if (props === undefined) {
|
|
return [
|
|
null,
|
|
undefined
|
|
];
|
|
}
|
|
// TS Error: Property 'as' does not exist on type 'UnknownSlotProps | undefined'.ts(2339)
|
|
const { as: asProp, ...propsWithoutAs } = props;
|
|
const slot = ((_state_components = state.components) === null || _state_components === void 0 ? void 0 : _state_components[slotName]) === undefined || // eslint-disable-line @typescript-eslint/no-deprecated
|
|
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
typeof state.components[slotName] === 'string' ? asProp || ((_state_components1 = state.components) === null || _state_components1 === void 0 ? void 0 : _state_components1[slotName]) || 'div' : state.components[slotName];
|
|
const shouldOmitAsProp = typeof slot === 'string' && asProp;
|
|
const slotProps = shouldOmitAsProp ? propsWithoutAs : props;
|
|
return [
|
|
slot,
|
|
slotProps
|
|
];
|
|
}
|