Компонент семантического интерфейса реагирования реагирования всегда остается открытым - PullRequest
0 голосов
/ 02 мая 2018

Я пытаюсь использовать выпадающий компонент семантического интерфейса пользователя внутри компонента меню (приложение Meteor). Компонент всегда остается открытым и, что наиболее важно, отображается полностью внутри компонента меню.

вот простое изображение:

и вот код:

  render() {
const {
  documents, columns, loading, className,
} = this.props;
const options = [
  {
    key: 'default',
    value: 'default',
    text: 'Default grid',
  },
  {
    key: 'edit',
    value: 'edit',
    text: 'Edit grid',
  },
];
return (
  !loading ? (
    <div className="eb-list" >
      <div className="eb-list-toolbar" >
        <Menu borderless icon="labeled" >
          <Menu.Item name="add" onClick={this.addDocument}><Icon name="add" />Nuovo</Menu.Item>
          <Menu.Item name="edit" onClick={this.editDocument}><Icon name="edit" />Modifica</Menu.Item>
          <Menu.Item name="copy"><Icon name="copy" />Duplica</Menu.Item>
          <Menu.Item name="mass"><Icon name="tasks" />Modifica di massa</Menu.Item>
          <Menu.Item name="delete" onClick={this.removeDocuments}><Icon name="delete" />Elimina</Menu.Item>
          <Menu.Item position="right" header name="className" >{className}</Menu.Item>
          <Dropdown item icon="" open={false} trigger={<Icon name="grid layout" />} options={options} />
        </Menu>
      </div>
      <div className="eb-list-content" >
        <AutoSizer defaultHeight={200} defaultWidth={500} >
          {({ height, width }) => (
            <Table
              data={documents}
              columns={columns}
              ref={(t) => { this.handleTable = t; }}
              onDoubleClickHandler={this.handleDoubleClick}
              height={height}
              width={width}
            />
        )}
        </AutoSizer>
      </div>
    </div>) : <Loading />

CSS:

.eb-list {
    position: absolute;
    top: 0px;
    right: 0px;
    bottom: 0px;
    left: 0px;
    display: flex;
    flex-direction: column;
}

.eb-list > .eb-list-content {
    flex: 1 1 auto;
}

.eb-list > .eb-list-toolbar {
    padding-bottom: 5px;
}

Я не могу понять, что я делаю неправильно. Я наблюдаю такое же поведение с субкомпонентным API.

Может кто-нибудь помочь мне, пожалуйста?

1 Ответ

0 голосов
/ 03 мая 2018

Решено!

Я забыл включить определение для раскрывающегося списка в custom.semantic.json

{
    "definitions" : {
      "site": true,
      "menu": true,
      "icon": true,
      "dropdown": true,
      "modal": true,
      "list": true
    },
    "themes": {
      "amazon"     : false,
      "basic"      : true,
      "bookish"    : false,
      "bootstrap3" : false,
      "chubby"     : false,
      "classic"    : false,
      "default"    : true
    }
}

Теперь все работает как положено!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...