|
| 1 | +import React, { Component } from 'react'; |
| 2 | +import Modal from '../../src/index'; |
| 3 | +import ModalA from './modal_a'; |
| 4 | + |
| 5 | +function List(props) { |
| 6 | + return ( |
| 7 | + <div> |
| 8 | + {props.items.map( |
| 9 | + (x, i) => <div key={i} onClick={props.onItemClick(i)}><a href="javascript:void(0)">{x}</a></div> |
| 10 | + )} |
| 11 | + </div> |
| 12 | + ); |
| 13 | +} |
| 14 | + |
| 15 | +export default class ViewB extends Component { |
| 16 | + constructor(props) { |
| 17 | + super(props); |
| 18 | + this.state = { |
| 19 | + listItemsIsOpen: false, |
| 20 | + currentItem: -1, |
| 21 | + loading: false, |
| 22 | + items: [] |
| 23 | + }; |
| 24 | + } |
| 25 | + |
| 26 | + toggleModal = event => { |
| 27 | + event.preventDefault(); |
| 28 | + if (this.state.listItemsIsOpen) { |
| 29 | + this.handleModalCloseRequest(); |
| 30 | + return; |
| 31 | + } |
| 32 | + this.setState({ |
| 33 | + ...this.state, |
| 34 | + items: [], |
| 35 | + listItemsIsOpen: true, |
| 36 | + loading: true |
| 37 | + }); |
| 38 | + } |
| 39 | + |
| 40 | + handleModalCloseRequest = () => { |
| 41 | + // opportunity to validate something and keep the modal open even if it |
| 42 | + // requested to be closed |
| 43 | + this.setState({ |
| 44 | + ...this.state, |
| 45 | + listItemsIsOpen: false, |
| 46 | + loading: false |
| 47 | + }); |
| 48 | + } |
| 49 | + |
| 50 | + handleOnAfterOpenModal = () => { |
| 51 | + // when ready, we can access the available refs. |
| 52 | + (new Promise((resolve, reject) => { |
| 53 | + setTimeout(() => resolve(true), 1000); |
| 54 | + })).then(res => { |
| 55 | + this.setState({ |
| 56 | + ...this.state, |
| 57 | + items: [1, 2, 3, 4, 5].map(x => `Item ${x}`), |
| 58 | + loading: false |
| 59 | + }); |
| 60 | + }); |
| 61 | + } |
| 62 | + |
| 63 | + onItemClick = index => event => { |
| 64 | + this.setState({ ...this.state, currentItem: index }); |
| 65 | + } |
| 66 | + |
| 67 | + cleanCurrentItem = () => { |
| 68 | + this.setState({ ...this.state, currentItem: -1 }); |
| 69 | + } |
| 70 | + |
| 71 | + render() { |
| 72 | + const { listItemsIsOpen } = this.state; |
| 73 | + return ( |
| 74 | + <div> |
| 75 | + <button onClick={this.toggleModal}>Open Modal A</button> |
| 76 | + <Modal |
| 77 | + id="test" |
| 78 | + closeTimeoutMS={150} |
| 79 | + contentLabel="modalA" |
| 80 | + isOpen={listItemsIsOpen} |
| 81 | + onAfterOpen={this.handleOnAfterOpenModal} |
| 82 | + onRequestClose={this.toggleModal}> |
| 83 | + <h1>List of items</h1> |
| 84 | + {this.state.loading ? ( |
| 85 | + <p>Loading...</p> |
| 86 | + ) : ( |
| 87 | + <List onItemClick={this.onItemClick} items={this.state.items} /> |
| 88 | + )} |
| 89 | + </Modal> |
| 90 | + <Modal |
| 91 | + id="test2" |
| 92 | + closeTimeoutMS={150} |
| 93 | + contentLabel="modalB" |
| 94 | + isOpen={this.state.currentItem > -1} |
| 95 | + onRequestClose={this.cleanCurrentItem} |
| 96 | + aria={{ |
| 97 | + labelledby: "item_title", |
| 98 | + describedby: "item_info" |
| 99 | + }}> |
| 100 | + <h1 id="item_title">Item: {this.state.items[this.state.currentItem]}</h1> |
| 101 | + <div id="item_info"> |
| 102 | + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Curabitur pulvinar varius auctor. Aliquam maximus et justo ut faucibus. Nullam sit amet urna molestie turpis bibendum accumsan a id sem. Proin ullamcorper nisl sapien, gravida dictum nibh congue vel. Vivamus convallis dolor vitae ipsum ultricies, vitae pulvinar justo tincidunt. Maecenas a nunc elit. Phasellus fermentum, tellus ut consectetur scelerisque, eros nunc lacinia eros, aliquet efficitur tellus arcu a nibh. Praesent quis consequat nulla. Etiam dapibus ac sem vel efficitur. Nunc faucibus efficitur leo vitae vulputate. Nunc at quam vitae felis pretium vehicula vel eu quam. Quisque sapien mauris, condimentum eget dictum ut, congue id dolor. Donec vitae varius orci, eu faucibus turpis. Morbi eleifend orci non urna bibendum, ac scelerisque augue efficitur.</p> |
| 103 | + |
| 104 | + <p>Maecenas justo justo, laoreet vitae odio quis, lacinia porttitor arcu. Nunc nisl est, ultricies sed laoreet eu, semper in nisi. Phasellus lacinia porta purus, eu luctus neque. Nullam quis mi malesuada, vestibulum sem id, rhoncus purus. Aliquam erat volutpat. Duis nec turpis mi. Pellentesque eleifend nisl sed risus aliquet, eu feugiat elit auctor. Suspendisse ac neque vitae ligula consequat aliquam. Vivamus sit amet eros et ante mollis porta.</p> |
| 105 | + </div> |
| 106 | + </Modal> |
| 107 | + </div> |
| 108 | + ); |
| 109 | + } |
| 110 | +} |
0 commit comments