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

TypeError: Cannot read property 'Dropdown' of undefined #284

Open
mjaggard opened this issue Jun 20, 2024 · 6 comments
Open

TypeError: Cannot read property 'Dropdown' of undefined #284

mjaggard opened this issue Jun 20, 2024 · 6 comments

Comments

@mjaggard
Copy link

mjaggard commented Jun 20, 2024

I get the error TypeError: Cannot read property 'Dropdown' of undefined when I attempt to use Dropdown for a single selection drop down exactly as described in the docs (I copied and pasted with the exception of adding a type parameter for useState, changing the name of the component and removing AntDesign because I don't use that)

import React, {useState} from 'react';
import {StyleSheet, Text, View} from 'react-native';
import {Dropdown} from 'react-native-element-dropdown';

const data = [
  {label: 'Item 1', value: '1'},
  {label: 'Item 2', value: '2'},
  {label: 'Item 3', value: '3'},
  {label: 'Item 4', value: '4'},
  {label: 'Item 5', value: '5'},
  {label: 'Item 6', value: '6'},
  {label: 'Item 7', value: '7'},
  {label: 'Item 8', value: '8'},
];

const TestDropdown = () => {
  const [value, setValue] = useState<string | null>(null);
  const [isFocus, setIsFocus] = useState(false);

  const renderLabel = () => {
    if (value || isFocus) {
      return <Text style={[styles.label, isFocus && {color: 'blue'}]}>Dropdown label</Text>;
    }
    return null;
  };

  return (
    <View style={styles.container}>
      {renderLabel()}
      <Dropdown
        style={[styles.dropdown, isFocus && {borderColor: 'blue'}]}
        placeholderStyle={styles.placeholderStyle}
        selectedTextStyle={styles.selectedTextStyle}
        inputSearchStyle={styles.inputSearchStyle}
        iconStyle={styles.iconStyle}
        data={data}
        search
        maxHeight={300}
        labelField="label"
        valueField="value"
        placeholder={!isFocus ? 'Select item' : '...'}
        searchPlaceholder="Search..."
        value={value}
        onFocus={() => setIsFocus(true)}
        onBlur={() => setIsFocus(false)}
        onChange={item => {
          setValue(item.value);
          setIsFocus(false);
        }}
        renderLeftIcon={() => <Text>Blah</Text>}
      />
    </View>
  );
};

export default TestDropdown;

const styles = StyleSheet.create({
  container: {
    backgroundColor: 'white',
    padding: 16,
  },
  dropdown: {
    height: 50,
    borderColor: 'gray',
    borderWidth: 0.5,
    borderRadius: 8,
    paddingHorizontal: 8,
  },
  icon: {
    marginRight: 5,
  },
  label: {
    position: 'absolute',
    backgroundColor: 'white',
    left: 22,
    top: 8,
    zIndex: 999,
    paddingHorizontal: 8,
    fontSize: 14,
  },
  placeholderStyle: {
    fontSize: 16,
  },
  selectedTextStyle: {
    fontSize: 16,
  },
  iconStyle: {
    width: 20,
    height: 20,
  },
  inputSearchStyle: {
    height: 40,
    fontSize: 16,
  },
});
@amarnyayapati
Copy link

amarnyayapati commented Jun 28, 2024

We are also facing simlar issue
Dropdown Component not found
Screenshot 2024-06-28 at 11 43 39 AM

And it same with MultiSelectComponent and SelectCountryComponent
Looking for a fix

@LucasHimelfarb
Copy link

same here

@LucasHimelfarb
Copy link

you did find any solution @mjaggard ?

@mjaggard
Copy link
Author

@LucasHimelfarb I gave up on using a dropdown and used a scrollable list instead.

@LucasHimelfarb
Copy link

@kasunchamara
Copy link

I faced the same issue with version 2.12.2 and 2.12.1. After I downgraded to version 2.12.0 the issue seemed to be no longer created. @mjaggard @LucasHimelfarb @amarnyayapati

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

4 participants