react-native - 在 'preferredDatePickerStyle' 类型的对象上找不到属性 'UIDatePicker'

标签 react-native datetimepicker react-native-ios

我正在使用 react-native 0.62.2 版本和 datetimepicker 3.0.1 版本。当我尝试使用 xcode 构建项目时,显示以下错误:

  1. 使用未声明的标识符“UIDatePickerStyleCompact”
  2. 使用未声明的标识符“UIDatePickerStyleWheels”
  3. 在类型的对象上找不到属性“preferredDatePickerStyle” 'RNDateTimePicker *'
  4. 在类型的对象上找不到属性“preferredDatePickerStyle” 'UIDatePicker*'
  5. “NSInteger”(又名“long”)到“id”的隐式转换是 ARC不允许
  6. 语句需要整数类型的表达式('__strong id' 无效)
  7. “UIDatePickerMode”(又名“枚举”)的隐式转换 ARC 不允许将 UIDatePickerMode') 转换为 'id'
  8. 使用未声明的标识符“UIDatePickerStyleWheels”

以下是RNDateTimePickerManager.h

里面的代码
#import "RNDateTimePickerManager.h"

#import <React/RCTBridge.h>
#import <React/RCTEventDispatcher.h>
#import "RNDateTimePicker.h"
#import <React/UIView+React.h>

@implementation RCTConvert(UIDatePicker)

RCT_ENUM_CONVERTER(UIDatePickerMode, (@{
  @"time": @(UIDatePickerModeTime),
  @"date": @(UIDatePickerModeDate),
  @"datetime": @(UIDatePickerModeDateAndTime),
}), UIDatePickerModeTime, integerValue)

RCT_ENUM_CONVERTER(UIDatePickerStyle, (@{                //Error 5
    @"default": @(UIActionSheetStyleAutomatic),
    @"compact": @(UIDatePickerStyleCompact),             //Error 1
    @"spinner": @(UIDatePickerStyleWheels),              //Error 2
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= 140000
    @"inline": @(UIDatePickerStyleInline),
#endif
}), UIActionSheetStyleAutomatic, integerValue)

@end

@implementation RNDateTimePickerManager

RCT_EXPORT_MODULE()

- (UIView *)view
{
  return [RNDateTimePicker new];
}

+ (NSString*) datepickerStyleToString: (UIDatePickerStyle) style {
    // RCTConvert does not handle this.?
    switch (style) {                                       //Error 6
        case UIDatePickerStyleCompact:
            return @"compact";
        case UIDatePickerStyleWheels:
            return @"spinner";
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= 140000
        case UIDatePickerStyleInline:
            return @"inline";
#endif
        default:
            [NSException raise:@"Unsupported style value" format:@"UIDatePickerStyle of %ld is unsupported", (long)style];
            return @"";
    }
}

RCT_EXPORT_METHOD(getDefaultDisplayValue:(NSDictionary *)options resolver:(RCTPromiseResolveBlock)resolve rejecter:(RCTPromiseRejectBlock)reject)
{
    dispatch_async(dispatch_get_main_queue(), ^{
        UIDatePicker* view = [RNDateTimePicker new];
        
        view.preferredDatePickerStyle = UIActionSheetStyleAutomatic;          //Error 4
        UIDatePickerMode renderedMode = [RCTConvert UIDatePickerMode:options[@"mode"]];
        view.datePickerMode = renderedMode;
        // NOTE afaict we do not need to measure the actual dimensions here, but if we do, just look at the original PR
        
        UIDatePickerMode determinedDisplayValue = view.datePickerMode;    //Error 7

        resolve(@{
                 @"determinedDisplayValue": [RNDateTimePickerManager datepickerStyleToString:determinedDisplayValue],
                });
    });
}

RCT_EXPORT_VIEW_PROPERTY(date, NSDate)
RCT_EXPORT_VIEW_PROPERTY(locale, NSLocale)
RCT_EXPORT_VIEW_PROPERTY(minimumDate, NSDate)
RCT_EXPORT_VIEW_PROPERTY(maximumDate, NSDate)
RCT_EXPORT_VIEW_PROPERTY(minuteInterval, NSInteger)
RCT_EXPORT_VIEW_PROPERTY(onChange, RCTBubblingEventBlock)
RCT_REMAP_VIEW_PROPERTY(mode, datePickerMode, UIDatePickerMode)
RCT_REMAP_VIEW_PROPERTY(timeZoneOffsetInMinutes, timeZone, NSTimeZone)

RCT_CUSTOM_VIEW_PROPERTY(textColor, UIColor, RNDateTimePicker)
{
    if (@available(iOS 14.0, *) && view.datePickerMode != UIDatePickerStyleWheels) {  //Error 8
    // prevents #247
    return;
  }
  if (json) {
    [view setValue:[RCTConvert UIColor:json] forKey:@"textColor"];
    [view setValue:@(NO) forKey:@"highlightsToday"];
  } else {
    UIColor* defaultColor;
    if (@available(iOS 13.0, *)) {
        defaultColor = [UIColor labelColor];
    } else {
        defaultColor = [UIColor blackColor];
    }
    [view setValue:defaultColor forKey:@"textColor"];
    [view setValue:@(YES) forKey:@"highlightsToday"];
  }
}

// TODO vonovak setting preferredDatePickerStyle invalidates minuteinterval
RCT_CUSTOM_VIEW_PROPERTY(displayIOS, UIDatePickerStyle, RNDateTimePicker)
{
    if (@available(iOS 13.4, *)) {
        if (json) {
            UIDatePickerMode propValue = [RCTConvert UIDatePickerStyle:json];
            view.preferredDatePickerStyle = propValue;           //Error 3
        } else {
            view.preferredDatePickerStyle = UIActionSheetStyleAutomatic;
        }
    }
}

@end

react-native datetimepicker 中是否有任何错误?

最佳答案

对于那些仍然坚持这一点的人,特别是使用 this图书馆。

从版本 3.0.3 开始,它要求您的 Xcode 至少是 v11,但他们从未提到 v11.3 将无法工作,很多人已经注意到您至少需要 v11.6。

请注意,降级可能也不会真正帮助您,因为您错过了解决很多错误的更新点,例如 #217 fix

关于react-native - 在 'preferredDatePickerStyle' 类型的对象上找不到属性 'UIDatePicker',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63592410/

相关文章:

react-native - 如何在 React Native 组件上设置accessibilityIdentifier?

javascript - Reactjs 将 key prop 分配给数组渲染组件

javascript - 使用 useState 时如何减少 React 中的重复?

ios - ld:升级到60.5后找不到库,查找-lRCTGeolocation错误

c# - DateTimePicker 在 Windows 窗体应用程序 C# 中单击时更改值

ios - react native : Best approach to run a background task on iOS when the app is closed?

java - 如何在React Native中调用Java字符串并实时显示

C# DateTime解析问题

javascript - 使日期时间选择器与可编辑表一起工作

react-native - react native iOS 构建问题 - glog - 使用未声明的标识符 'SYS_gettid'