如何在事件点击时填充模态?

时间:2019-05-23 10:01:16

标签: javascript reactjs fullcalendar fullcalendar-4

当前使用ReactJS设置FullCalendar。我可以填充日历和事件,但是在eventClick={}上遇到了麻烦。如何使用eventClick={}填充模式并检索事件信息?

我设法使该模式在单击事件时出现,但是我似乎无法通过任何数据传递<这是我得到的最接近的数据。 我想到了可能会激发模态触发的功能,但我无法弄清楚如何使其显示出来。

当前代码

constructor() {
        super();
        this.state = {
            modal: false
        };

        this.toggle = this.toggle.bind(this);
    };

    toggle() {
        this.setState(prevState => ({
            modal: !prevState.modal
        }));
    }

----
  //I then render the calendar and modal inside the div.

<div id="calendar" class="container" ref="calendar">
                <FullCalendar
                    header={{
                        left: 'prev,next today',
                        center: 'title',
                        right: 'dayGridMonth, listWeek'
                    }}
                    selectable={true}
                    height={650}
                    aspectRatio={2}
                    plugins={[interaction, dayListPlugin, dayGridPlugin, bootstrapPlugin]}
                    themeSystem="bootstrap"
                    weekends={false}
                    displayEventTime={true}
                    timeZone="UTC"
                    events={jsonFeed}
                    eventRender={this.handleEventRender}
                    eventClick={this.toggle}
                />
            <Modal isOpen={this.state.modal} toggle={this.toggle} className={this.props.className}>
            <ModalHeader toggle={this.toggle}>testTitle</ModalHeader>
            <ModalBody>test body</ModalBody>
            <ModalFooter>
                <Button color="primary" onClick={this.toggle}>Do Something</Button>{' '}
                <Button color="secondary" onClick={this.toggle}>Cancel</Button>
            </ModalFooter>
        </Modal>
            </div>

所以在这里,当我单击事件/关闭按钮时,模态会出现和消失,但是我无法通过单击事件传递数据。我希望有人能提供帮助。我似乎无法做到这一点。

2 个答案:

答案 0 :(得分:0)

您的问题指出“因此,当我单击事件/关闭按钮时,我会看到模态的出现和消失...”,但是在注释中您指出“但我只是不知道该写些什么来呈现它”

我将假定正在渲染Modal,而问题是您不确定如何使用eventClick回调。

ADyson就您遇到的问题进行了现场采访。您已经设置了回调,FullCalendar认为您的切换函数是触发event click时要调用的函数。调用您的切换函数时,将传递一个eventClickInfo对象,该对象使您可以访问事件,HTML元素,jsEvent和视图。

因此,将切换切换到该位置将使您可以访问事件:

toggle(eventClickInfo) {
  console.log(eventClickInfo);

  this.setState(prevState => ({
    modal: !prevState.modal
  }));
}

*我将名称更改为handleEventClick或eventClick。

更新1: 根据以上评论,我已接受了您的code sandbox并进行了更新。我更改了以下内容:

  1. 将模态移动到render函数中,以便对其进行渲染,然后从状态进行更新。
  2. 已将事件添加到状态对象,因此单击事件时将对其进行更新。这就是对话框中呈现的内容。
  3. 在具有id日历的div上将类更改为className,因为这是React的标准功能,因为class是JS中的关键字。

    class Calendar extends React.Component {
      state = {
        modal: false,
        event: {
          title: "",
          start: new Date()
        }
      };
    
      toggle = () => {
        this.setState({ modal: !this.state.modal });
      };
    
      handleEventClick = ({ event, el }) => {
        this.toggle();
        this.setState({ event });
      };
    
      render() {
        return (
          <div id="calendar" className="container" ref="calendar">
            <FullCalendar
              header={{
                left: "prev,next today",
                center: "title",
                right: "dayGridMonth, listWeek"
              }}
              selectable={true}
              plugins={[interaction, dayListPlugin, dayGridPlugin, bootstrapPlugin]}
              themeSystem="bootstrap"
              weekends={false}
              displayEventTime={true}
              timeZone="UTC"
              events={[
                { title: "event 1", date: "2019-05-01" },
                { title: "event 2", date: "2019-05-02" }
              ]}
              eventRender={this.handleEventRender}
              eventClick={this.handleEventClick}
            />
            <Modal
              isOpen={this.state.modal}
              toggle={this.toggle}
              className={this.props.className}
            >
              <ModalHeader toggle={this.toggle}>
                {this.state.event.title}
              </ModalHeader>
              <ModalBody>
                <div>
                  <p>{this.state.event.start.toISOString()}</p>
                </div>
              </ModalBody>
              <ModalFooter>
                <Button color="primary">Do Something</Button>{" "}
                <Button color="secondary" onClick={this.toggle}>
                  Cancel
                </Button>
              </ModalFooter>
            </Modal>
          </div>
        );
      }
    }
    

答案 1 :(得分:0)

在您的按钮(样式化组件)上,

<Button type="button" color="primary" onClick={e => toggle(e)}>Toggle Button</Button>

也在您的handleToggle()

toggle = event => {
 // event.preventDefault() or manipulate something with the @param
 this.setState(prevState => ({ modal: !prevState.modal }))
}
相关问题