Предупреждение. Компонент изменяет неконтролируемый ввод типа флажка для управления.Входные элементы не должны переключаться с неуправляемых на управляемые (или наоборот).Выберите между использованием управляемого или неконтролируемого входного элемента для срока службы компонента.
Мой код:
interface IState {
isSelectedAll: boolean;
selected: any;
confirmDelete: boolean;
confirmSignStatus: boolean;
petitionId: any;
items: any;
verificationCode: any;
}
...
/**
* Default state.
*/
function getDefaultState(): IState {
return {
isSelectedAll: false,
selected: {},
confirmDelete: false,
confirmSignStatus: false,
petitionId: '',
items: [],
verificationCode: null,
};
}
public handleSelect = (id: number) => {
let selectedObj = Object.assign({}, this.state.selected);
selectedObj[id] = !selectedObj[id];
this.setState({ selected: selectedObj });
}
...
public state: IState = getDefaultState();
public componentWillReceiveProps(nextProps: any): void {
if (nextProps.ecourtListBranch.data) {
this.initSelects(nextProps.ecourtListBranch.data);
}
}
private initSelects = (data: any): void => {
let selectedObj: any = {};
data.map((item: IPetitionView) => {
selectedObj[item.petitionId] = false;
this.setState({ selected: selectedObj });
});
}
interface IProps {
ecourt: IPetitionView;
ecourtActions: typeof EcourtActions;
handleSelect: (id: number) => any;
selecteds: any;
handleDeletePetition: (petitionId: number) => any;
handleEditPetition: (petitionId: number) => any;
}
...
<Checkbox
value={this.props.selecteds[petitionId]}
onChange={() => handleSelect(petitionId)}
/>