UNPKG

react-on-rails

Version:

react-on-rails JavaScript for react_on_rails Ruby gem

27 lines 1.49 kB
import { createBaseClientObject } from "./client.js"; export function createBaseFullObject(registries, currentObject = null) { // Get or create client object (with caching logic) const clientObject = createBaseClientObject(registries, currentObject); // Define SSR-specific functions with proper types // This object acts as a type-safe specification of what we're adding to the base object const reactOnRailsFullSpecificFunctions = { handleError() { throw new Error('"handleError" function is not supported in RSC bundle'); }, serverRenderReactComponent() { throw new Error('"serverRenderReactComponent" function is not supported in RSC bundle'); }, }; // Type assertion is safe here because: // 1. We start with BaseClientObjectType (from createBaseClientObject) // 2. We add exactly the methods defined in ReactOnRailsFullSpecificFunctions // 3. BaseFullObjectType = BaseClientObjectType + ReactOnRailsFullSpecificFunctions // TypeScript can't track the mutation, but we ensure type safety by explicitly typing // the functions object above const fullObject = clientObject; // Assign SSR-specific functions to the full object using Object.assign // This pattern ensures we add exactly what's defined in the type, nothing more, nothing less Object.assign(fullObject, reactOnRailsFullSpecificFunctions); return fullObject; } //# sourceMappingURL=full.rsc.js.map