zioinfo-mail/app/node_modules/expo-modules-core/src/NativeViewManagerAdapter.native.tsx
DESKTOP-TKLFCPR\ython 11c670f2a0 refactor: 101.79.17.164 → zioinfo.co.kr 전체 도메인 변환 + Manager UI 배포
- 37개 파일 IP → zioinfo.co.kr 치환 (소스/매뉴얼/설정/하네스)
- Manager DrConsole/NetworkConsole/CsapConsole 빌드 + /var/www/manager/ 배포
- 테스트: Manager HTTP 200, ITSM 신규 API 7개 전체 200

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 10:09:17 +09:00

113 lines
4.4 KiB
TypeScript

// Copyright © 2024 650 Industries.
'use client';
import React from 'react';
import { findNodeHandle, NativeModules, HostComponent } from 'react-native';
import * as NativeComponentRegistry from 'react-native/Libraries/NativeComponent/NativeComponentRegistry';
import { requireNativeModule } from './requireNativeModule';
// To make the transition from React Native's `requireNativeComponent` to Expo's
// `requireNativeViewManager` as easy as possible, `requireNativeViewManager` is a drop-in
// replacement for `requireNativeComponent`.
//
// For each view manager, we create a wrapper component that accepts all of the props available to
// the author of the universal module. This wrapper component splits the props into two sets: props
// passed to React Native's View (ex: style, testID) and custom view props, which are passed to the
// adapter view component in a prop called `proxiedProperties`.
/**
* A map that caches registered native components.
*/
const nativeComponentsCache = new Map<string, HostComponent<any>>();
/**
* Requires a React Native component using the static view config from an Expo module.
*/
function requireNativeComponent<Props>(viewName: string): HostComponent<Props> {
return NativeComponentRegistry.get<Props>(viewName, () => {
const viewModuleName = viewName.replace('ViewManagerAdapter_', '');
const expoViewConfig = globalThis.expo?.getViewConfig(viewModuleName);
if (!expoViewConfig) {
console.warn('Unable to get the view config for %s', viewModuleName);
}
return {
uiViewClassName: viewName,
...expoViewConfig,
};
});
}
/**
* Requires a React Native component from cache if possible. This prevents
* "Tried to register two views with the same name" errors on fast refresh, but
* also when there are multiple versions of the same package with native component.
*/
function requireCachedNativeComponent<Props>(viewName: string): HostComponent<Props> {
const cachedNativeComponent = nativeComponentsCache.get(viewName);
if (!cachedNativeComponent) {
const nativeComponent = requireNativeComponent<Props>(viewName);
nativeComponentsCache.set(viewName, nativeComponent);
return nativeComponent;
}
return cachedNativeComponent;
}
/**
* A drop-in replacement for `requireNativeComponent`.
*/
export function requireNativeViewManager<P>(viewName: string): React.ComponentType<P> {
const { viewManagersMetadata } = NativeModules.NativeUnimoduleProxy;
const viewManagerConfig = viewManagersMetadata?.[viewName];
if (__DEV__ && !viewManagerConfig) {
const exportedViewManagerNames = Object.keys(viewManagersMetadata).join(', ');
console.warn(
`The native view manager required by name (${viewName}) from NativeViewManagerAdapter isn't exported by expo-modules-core. Views of this type may not render correctly. Exported view managers: [${exportedViewManagerNames}].`
);
}
// Set up the React Native native component, which is an adapter to the universal module's view
// manager
const reactNativeViewName = `ViewManagerAdapter_${viewName}`;
const ReactNativeComponent = requireCachedNativeComponent(reactNativeViewName);
class NativeComponent extends React.PureComponent<P> {
static displayName = viewName;
// This will be accessed from native when the prototype functions are called,
// in order to find the associated native view.
nativeTag: number | null = null;
componentDidMount(): void {
this.nativeTag = findNodeHandle(this);
}
render(): React.ReactNode {
return <ReactNativeComponent {...this.props} />;
}
}
try {
const nativeModule = requireNativeModule(viewName);
const nativeViewPrototype = nativeModule.ViewPrototype;
if (nativeViewPrototype) {
// Assign native view functions to the component prototype so they can be accessed from the ref.
Object.assign(NativeComponent.prototype, nativeViewPrototype);
}
} catch {
// `requireNativeModule` may throw an error when the native module cannot be found.
// In some tests we don't mock the entire modules, but we do want to mock native views. For now,
// until we still have to support the legacy modules proxy and don't have better ways to mock,
// let's just gracefully skip assigning the prototype functions.
// See: https://github.com/expo/expo/blob/main/packages/expo-modules-core/src/__tests__/NativeViewManagerAdapter-test.native.tsx
}
return NativeComponent;
}