Alexey Safronov
f3afd79a3f
# Conflicts: # packages/asc-web-common/components/AdvancedSelector/AdvancedSelector.js # packages/asc-web-common/components/AdvancedSelector/sub-components/Selector.js # packages/asc-web-common/components/FilterInput/sub-components/SortComboBox.js # packages/asc-web-common/components/PageLayout/index.js # packages/asc-web-common/store/SettingsStore.js # packages/asc-web-components/avatar-editor/sub-components/avatar-editor-body.js # packages/asc-web-components/combobox/index.js # packages/asc-web-components/context-menu/styled-context-menu.js # packages/asc-web-components/drop-down/index.js # packages/asc-web-components/link-with-dropdown/index.js # packages/asc-web-components/row/index.js # packages/asc-web-components/table-container/StyledTableContainer.js # packages/asc-web-components/table-container/TableHeaderCell.js # packages/asc-web-components/themes/dark.js # products/ASC.Files/Client/public/images/files.menu.svg # products/ASC.Files/Client/src/components/Article/Body/TreeFolders.js # products/ASC.Files/Client/src/components/Badges.js # products/ASC.Files/Client/src/components/QuickButtons.js # products/ASC.Files/Client/src/components/panels/NewFilesPanel/index.js # products/ASC.Files/Client/src/components/panels/OperationsPanel/index.js # products/ASC.Files/Client/src/components/panels/SelectFileDialog/AsideView.js # products/ASC.Files/Client/src/components/panels/SelectFileDialog/ModalView.js # products/ASC.Files/Client/src/components/panels/SharingPanel/index.js # products/ASC.Files/Client/src/components/panels/StyledPanels.js # products/ASC.Files/Client/src/components/panels/UploadPanel/FileRow.js # products/ASC.Files/Client/src/components/panels/UploadPanel/index.js # products/ASC.Files/Client/src/pages/Home/Section/Body/RowsView/FilesRowContent.js # products/ASC.Files/Client/src/pages/Home/Section/Body/RowsView/SimpleFilesRow.js # products/ASC.Files/Client/src/pages/Home/Section/Body/TableView/TableContainer.js # products/ASC.Files/Client/src/pages/Home/Section/Body/TableView/TableRow.js # products/ASC.Files/Client/src/pages/Home/Section/Body/TableView/sub-components/FileNameCell.js # products/ASC.Files/Client/src/pages/Home/Section/Filter/index.js # products/ASC.Files/Client/src/pages/Home/Section/Header/index.js # products/ASC.Files/Client/src/pages/Home/index.js # products/ASC.Files/Client/src/pages/VersionHistory/Section/Body/VersionRow.js # products/ASC.Files/Client/src/store/UploadDataStore.js # products/ASC.People/Client/public/images/people.menu.svg # products/ASC.People/Client/src/components/GroupSelector/index.js # products/ASC.People/Client/src/components/PeopleSelector/index.js # products/ASC.People/Client/src/pages/Home/Section/Body/RowView/userContent.js # products/ASC.People/Client/src/pages/Home/index.js # products/ASC.People/Client/src/pages/Profile/Section/Body/index.js # web/ASC.Web.Client/src/components/NavMenu/sub-components/header-nav.js # web/ASC.Web.Client/src/components/NavMenu/sub-components/header.js # web/ASC.Web.Client/src/components/NavMenu/sub-components/nav-item.js # web/ASC.Web.Client/src/components/NavMenu/sub-components/profile-menu.js # web/ASC.Web.Client/src/components/pages/Home/index.js
106 lines
2.5 KiB
JavaScript
106 lines
2.5 KiB
JavaScript
import React from "react";
|
|
import PropTypes from "prop-types";
|
|
|
|
import Selector from "./sub-components/Selector";
|
|
import Backdrop from "@appserver/components/backdrop";
|
|
import Aside from "@appserver/components/aside";
|
|
|
|
const sizes = ["compact", "full"];
|
|
|
|
class AdvancedSelector extends React.Component {
|
|
constructor(props) {
|
|
super(props);
|
|
|
|
this.ref = React.createRef();
|
|
}
|
|
|
|
onClose = (e) => {
|
|
//console.log("onClose");
|
|
//this.setState({ isOpen: false });
|
|
this.props.onCancel && this.props.onCancel(e);
|
|
};
|
|
|
|
render() {
|
|
const {
|
|
isOpen,
|
|
id,
|
|
className,
|
|
style,
|
|
withoutAside,
|
|
isDefaultDisplayDropDown,
|
|
smallSectionWidth,
|
|
} = this.props;
|
|
|
|
return (
|
|
<div id={id} className={className} style={style}>
|
|
{withoutAside ? (
|
|
<Selector {...this.props} />
|
|
) : (
|
|
<>
|
|
<Backdrop
|
|
onClick={this.onClose}
|
|
visible={isOpen}
|
|
zIndex={310}
|
|
isAside={true}
|
|
/>
|
|
<Aside visible={isOpen} scale={false} className="aside-container">
|
|
<Selector {...this.props} />
|
|
</Aside>
|
|
</>
|
|
)}
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
AdvancedSelector.propTypes = {
|
|
id: PropTypes.string,
|
|
className: PropTypes.oneOfType([PropTypes.string, PropTypes.array]),
|
|
style: PropTypes.object,
|
|
options: PropTypes.array,
|
|
selectedOptions: PropTypes.array,
|
|
groups: PropTypes.array,
|
|
selectedGroups: PropTypes.array,
|
|
|
|
value: PropTypes.string,
|
|
placeholder: PropTypes.string,
|
|
selectAllLabel: PropTypes.string,
|
|
buttonLabel: PropTypes.string,
|
|
|
|
size: PropTypes.oneOf(sizes),
|
|
|
|
maxHeight: PropTypes.number,
|
|
|
|
isMultiSelect: PropTypes.bool,
|
|
isDisabled: PropTypes.bool,
|
|
selectedAll: PropTypes.bool,
|
|
isOpen: PropTypes.bool,
|
|
allowGroupSelection: PropTypes.bool,
|
|
allowCreation: PropTypes.bool,
|
|
allowAnyClickClose: PropTypes.bool,
|
|
hasNextPage: PropTypes.bool,
|
|
isNextPageLoading: PropTypes.bool,
|
|
withoutAside: PropTypes.bool,
|
|
|
|
onSearchChanged: PropTypes.func,
|
|
onSelect: PropTypes.func,
|
|
onGroupChange: PropTypes.func,
|
|
onCancel: PropTypes.func,
|
|
onAddNewClick: PropTypes.func,
|
|
loadNextPage: PropTypes.func,
|
|
isDefaultDisplayDropDown: PropTypes.bool,
|
|
};
|
|
|
|
AdvancedSelector.defaultProps = {
|
|
isMultiSelect: false,
|
|
size: "full",
|
|
buttonLabel: "Add members",
|
|
selectAllLabel: "Select all",
|
|
allowGroupSelection: false,
|
|
allowAnyClickClose: true,
|
|
options: [],
|
|
isDefaultDisplayDropDown: true,
|
|
};
|
|
|
|
export default AdvancedSelector;
|