Coder Social home page Coder Social logo

Comments (5)

 avatar commented on May 31, 2024 1

@leMaik, I found this bug too πŸ˜•

class DoubleChipApp extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            tags: []
        };
    }

    handleRequestAdd(chip) {
        console.log('added chip', chip)
        const addToEnd = function (array, item) {
            array.push(item);
            return array;
        };
        this.setState((prevState, props) => ({
            tags: addToEnd(prevState.tags, chip)
        }));
        return true;
    }

    handleRequestDelete(chip) {
        this.setState((prevState, props) => ({
            tags: prevState.tags.filter((tag) => tag !== chip)
        }));
        return true;
    }

    render() {
        return (
            <MuiThemeProvider>
                <ChipInput value={this.state.tags}
                           openOnFocus
                           dataSource={['one', 'two']}
                           onRequestAdd={this.handleRequestAdd.bind(this)}
                           onRequestDelete={this.handleRequestDelete.bind(this)}
                />
            </MuiThemeProvider>
        )
    };
}

ReactDOM.render(
    <DoubleChipApp />,
    document.getElementById('app'),
);

from material-ui-chip-input.

leMaik avatar leMaik commented on May 31, 2024

I'm afraid I can't reproduce this bug. Could you please provide code that reproduces the bug?

from material-ui-chip-input.

leMaik avatar leMaik commented on May 31, 2024

I'll fix this later, thanks for the example! πŸ‘

from material-ui-chip-input.

leMaik avatar leMaik commented on May 31, 2024

Fixed it, will release soon. πŸŽ‰

@sever2715 You are mutating the state in handleRequestAdd by using push, which modifies the array. You should better create a new array that has the new chip added, e.g. with [...array, item]. That way, you would work around the bug because calling handleRequestAdd wouldn't have any side-effects. πŸ˜‰

from material-ui-chip-input.

 avatar commented on May 31, 2024

@leMaik thank you for your advice, but I already used another hack(my app is async - therefore it is necessary to consider the previous state).
☺️ πŸ‘Ύ

from material-ui-chip-input.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.