import React, { Component } from 'react'; import { View, Button, TextInput } from 'react-native'; import { connect } from 'react-redux' import { Log } from 'lib/log.js' import { Folder } from 'lib/models/folder.js' import { BaseModel } from 'lib/base-model.js' import { ScreenHeader } from 'lib/components/screen-header.js'; class FolderScreenComponent extends React.Component { static navigationOptions(options) { return { header: null }; } constructor() { super(); this.state = { folder: Folder.new() }; this.originalFolder = null; } componentWillMount() { if (!this.props.folderId) { this.setState({ folder: Folder.new() }); } else { Folder.load(this.props.folderId).then((folder) => { this.originalFolder = Object.assign({}, folder); this.setState({ folder: folder }); }); } } folderComponent_change(propName, propValue) { this.setState((prevState, props) => { let folder = Object.assign({}, prevState.folder); folder[propName] = propValue; return { folder: folder } }); } title_changeText(text) { this.folderComponent_change('title', text); } async saveFolderButton_press() { let toSave = { title: this.state.folder.title, }; if (this.originalFolder) toSave.id = this.originalFolder.id; this.originalFolder = await Folder.save(toSave); this.setState({ folder: this.originalFolder }); } render() { return ( this.title_changeText(text)} />