Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

IOS (Spinner ui) - minimum date stops working if we don't pass maximum date. #962

Open
pranshulantz01 opened this issue Feb 24, 2025 · 4 comments

Comments

@pranshulantz01
Copy link

pranshulantz01 commented Feb 24, 2025

Bug report

Summary

If i have 2 instances of DateTimePicker , In first picker i am passing min date and in second both min and max date ,now if i open/close the picker, minimum date stops working for first ( in which i am not passing max date).If i pass some future date in maximum instead of undefined then it works.

Reproducible sample code

import {StyleSheet, Text, View} from 'react-native';
import React, {useState} from 'react';
import RNDateTimePicker from '@react-native-community/datetimepicker';

const App = () => {
  const [firstModal, setFirstModal] = useState(false);
  const [secondModal, setSecondModal] = useState(false);
  return (
    <View style={{flex: 1, justifyContent: 'center', alignItems: 'center'}}>
      <Text
        onPress={() => {
          setSecondModal(false);
          setFirstModal(true);
        }}>
        Open First Modal{' '}
      </Text>
      <Text
        onPress={() => {
          setFirstModal(false);
          setSecondModal(true);
        }}>
         Open Second Modal{' '}
      </Text>
      {firstModal && (
        <RNDateTimePicker
          display="spinner"
          onCancel={() => setFirstModal(false)}
          onConfirm={() => {
            setFirstModal(false);
            setSecondModal(true);
          }}
          onHide={() => setSecondModal(true)}
          value={new Date()}
          minimumDate={new Date()}
          maximumDate={undefined}
        />
      )}
      {secondModal && (
        <RNDateTimePicker
          display="spinner"
          onCancel={() => setSecondModal(false)}
          onConfirm={() => setSecondModal(false)}
          style={{backgroundColor: 'red'}}
          value={new Date()}
          minimumDate={new Date()}
          maximumDate={new Date()}
        />
      )}
    </View>
  );
};

export default App;

const styles = StyleSheet.create({});

Steps to reproduce

1.Click on Open First Modal then check if min date is working or not by scrolling..
2.Click on Open Second Modal check min and max date is working..
3. Click on Open First Modal.. minimum date is not working

Describe what you expected to happen:

1.minimum date should be working

Environment info

npx react-native info output:

# paste it here
System:
  OS: macOS 15.3.1
  CPU: (8) arm64 Apple M2
  Memory: 364.28 MB / 16.00 GB
  Shell:
    version: "5.9"
    path: /bin/zsh
Binaries:
  Node:
    version: 20.13.1
    path: /usr/local/bin/node
  Yarn:
    version: 4.6.0
    path: /opt/homebrew/bin/yarn
  npm:
    version: 9.5.1
    path: /usr/local/bin/npm
  Watchman:
    version: 2024.05.06.00
    path: /opt/homebrew/bin/watchman
Managers:
  CocoaPods:
    version: 1.16.1
    path: /Users/evdt/.gem/bin/pod
SDKs:
  iOS SDK:
    Platforms:
      - DriverKit 24.2
      - iOS 18.2
      - macOS 15.2
      - tvOS 18.2
      - visionOS 2.2
      - watchOS 11.2
  Android SDK:
    API Levels:
      - "28"
      - "29"
      - "31"
      - "32"
      - "33"
      - "34"
      - "35"
    Build Tools:
      - 30.0.2
      - 30.0.3
      - 33.0.0
      - 33.0.1
      - 34.0.0
      - 35.0.0
    System Images:
      - android-33 | Google APIs ARM 64 v8a
      - android-33 | Google Play ARM 64 v8a
      - android-34 | Google APIs ARM 64 v8a
      - android-34 | Google Play ARM 64 v8a
      - android-35 | Google Play ARM 64 v8a
    Android NDK: Not Found
IDEs:
  Android Studio: 2024.2 AI-242.23339.11.2421.12700392
  Xcode:
    version: 16.2/16C5032a
    path: /usr/bin/xcodebuild
Languages:
  Java:
    version: 17.0.10
    path: /Library/Java/JavaVirtualMachines/zulu-17.jdk/Contents/Home/bin/javac
  Ruby:
    version: 2.7.5
    path: /Users/evdt/.rbenv/shims/ruby
npmPackages:
  "@react-native-community/cli":
    installed: 15.1.3
    wanted: latest
  react:
    installed: 18.3.1
    wanted: 18.3.1
  react-native:
    installed: 0.76.7
    wanted: 0.76.7
  react-native-macos: Not Found
npmGlobalPackages:
  "*react-native*": Not Found
Android:
  hermesEnabled: Not found
  newArchEnabled: Not found
iOS:
  hermesEnabled: Not found
  newArchEnabled: Not found

Time zone name (If the problem you have is related to unexpected time / date. See list in https://en.wikipedia.org/wiki/List_of_tz_database_time_zones).

datetimepicker version: 8.3.0
"expo": "~52.0.37",
"react": "18.3.1",
"react-dom": "18.3.1",
"react-native": "0.76.7",

iOS / Android version: 18.2(ios)

@marijang
Copy link

marijang commented Mar 5, 2025

same problem....
not working and not showing if you try to display inline it is the same

@pranshulantz01
Copy link
Author

yeah, also when using time mode, time is stuck at 5:30. Wonder if you are facing the same

@marijang
Copy link

marijang commented Mar 6, 2025

Yes. It is stuck or empty

@marijang
Copy link

not working on react 0.77.1

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants