UNPKG

react-planner-viewer

Version:

react-planner-viewer is a React Component for view plans builded with react-planner in 2D mode

278 lines (236 loc) 29.4 kB
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } import React, { Component } from 'react'; import PropTypes from 'prop-types'; import CatalogItem from './catalog-item'; import CatalogBreadcrumb from './catalog-breadcrumb'; import CatalogPageItem from './catalog-page-item'; import CatalogTurnBackPageItem from './catalog-turn-back-page-item'; import ContentContainer from '../style/content-container'; import ContentTitle from '../style/content-title'; import * as SharedStyle from '../../shared-style'; var containerStyle = { position: 'fixed', width: 'calc( 100% - 51px)', height: 'calc( 100% - 20px)', backgroundColor: '#FFF', padding: '1em', left: 50, overflowY: 'auto', overflowX: 'hidden', zIndex: 10 }; var itemsStyle = { display: 'grid', gridTemplateColumns: 'repeat(auto-fit, minmax(14em, 1fr))', gridGap: '10px', marginTop: '1em' }; var searchContainer = { width: '100%', height: '3em', padding: '0.625em', background: '#f7f7f9', border: '1px solid #e1e1e8', cursor: 'pointer', position: 'relative', boxShadow: '0 1px 6px 0 rgba(0, 0, 0, 0.11), 0 1px 4px 0 rgba(0, 0, 0, 0.11)', borderRadius: '2px', transition: 'all .2s ease-in-out', WebkitTransition: 'all .2s ease-in-out', marginBottom: '1em' }; var searchText = { width: '8em', display: 'inline-block' }; var searchInput = { width: 'calc( 100% - 10em )', height: '2em', margin: '0', padding: '0 1em', border: '1px solid #EEE' }; var historyContainer = _extends({}, searchContainer, { padding: '0.2em 0.625em' }); var historyElementStyle = { width: 'auto', height: '2em', lineHeight: '2em', textAlign: 'center', borderRadius: '1em', display: 'inline-block', cursor: 'pointer', backgroundColor: SharedStyle.PRIMARY_COLOR.alt, color: SharedStyle.PRIMARY_COLOR.text_main, textTransform: 'capitalize', margin: '0.25em', padding: '0 1em' }; var CatalogList = function (_Component) { _inherits(CatalogList, _Component); function CatalogList(props, context) { _classCallCheck(this, CatalogList); var _this = _possibleConstructorReturn(this, (CatalogList.__proto__ || Object.getPrototypeOf(CatalogList)).call(this, props)); var page = props.state.catalog.page; var currentCategory = context.catalog.getCategory(page); var categoriesToDisplay = currentCategory.categories; var elementsToDisplay = currentCategory.elements.filter(function (element) { return element.info.visibility ? element.info.visibility.catalog : true; }); _this.state = { categories: currentCategory.categories, elements: elementsToDisplay, matchString: '', matchedElements: [] }; return _this; } _createClass(CatalogList, [{ key: 'flattenCategories', value: function flattenCategories(categories) { var toRet = []; for (var x = 0; x < categories.length; x++) { var curr = categories[x]; toRet = toRet.concat(curr.elements); if (curr.categories.length) toRet = toRet.concat(this.flattenCategories(curr.categories)); } return toRet; } }, { key: 'matcharray', value: function matcharray(text) { var array = this.state.elements.concat(this.flattenCategories(this.state.categories)); var filtered = []; if (text != '') { var regexp = new RegExp(text, 'i'); for (var i = 0; i < array.length; i++) { if (regexp.test(array[i].info.title)) { filtered.push(array[i]); } } } this.setState({ matchString: text, matchedElements: filtered }); } }, { key: 'select', value: function select(element) { switch (element.prototype) { case 'lines': this.context.linesActions.selectToolDrawingLine(element.name); break; case 'items': this.context.itemsActions.selectToolDrawingItem(element.name); break; case 'holes': this.context.holesActions.selectToolDrawingHole(element.name); break; } this.context.projectActions.pushLastSelectedCatalogElementToHistory(element); } }, { key: 'render', value: function render() { var _this2 = this; var page = this.props.state.catalog.page; var currentCategory = this.context.catalog.getCategory(page); var categoriesToDisplay = currentCategory.categories; var elementsToDisplay = currentCategory.elements.filter(function (element) { return element.info.visibility ? element.info.visibility.catalog : true; }); var breadcrumbComponent = null; if (page !== 'root') { var breadcrumbsNames = []; this.props.state.catalog.path.forEach(function (pathName) { breadcrumbsNames.push({ name: _this2.context.catalog.getCategory(pathName).label, action: function action() { return projectActions.goBackToCatalogPage(pathName); } }); }); breadcrumbsNames.push({ name: currentCategory.label, action: '' }); breadcrumbComponent = React.createElement(CatalogBreadcrumb, { names: breadcrumbsNames }); } var pathSize = this.props.state.catalog.path.size; var turnBackButton = pathSize > 0 ? React.createElement(CatalogTurnBackPageItem, { key: pathSize, page: this.context.catalog.categories[this.props.state.catalog.path.get(pathSize - 1)] }) : null; var selectedHistory = this.props.state.get('selectedElementsHistory'); var selectedHistoryElements = selectedHistory.map(function (el, ind) { return React.createElement( 'div', { key: ind, style: historyElementStyle, title: el.name, onClick: function onClick() { return _this2.select(el); } }, el.name ); }); return React.createElement( ContentContainer, { width: this.props.width, height: this.props.height, style: _extends({}, containerStyle, this.props.style) }, React.createElement( ContentTitle, null, this.context.translator.t('Catalog') ), breadcrumbComponent, React.createElement( 'div', { style: searchContainer }, React.createElement( 'span', { style: searchText }, this.context.translator.t('Search Element') ), React.createElement('input', { type: 'text', style: searchInput, onChange: function onChange(e) { _this2.matcharray(e.target.value); } }) ), selectedHistory.size ? React.createElement( 'div', { style: historyContainer }, React.createElement( 'span', null, this.context.translator.t('Last Selected') ), selectedHistoryElements ) : null, React.createElement( 'div', { style: itemsStyle }, this.state.matchString === '' ? [turnBackButton, categoriesToDisplay.map(function (cat) { return React.createElement(CatalogPageItem, { key: cat.name, page: cat, oldPage: currentCategory }); }), elementsToDisplay.map(function (elem) { return React.createElement(CatalogItem, { key: elem.name, element: elem }); })] : this.state.matchedElements.map(function (elem) { return React.createElement(CatalogItem, { key: elem.name, element: elem }); }) ) ); } }]); return CatalogList; }(Component); export default CatalogList; CatalogList.propTypes = { state: PropTypes.object.isRequired, width: PropTypes.number.isRequired, height: PropTypes.number.isRequired, style: PropTypes.object }; CatalogList.contextTypes = { catalog: PropTypes.object.isRequired, translator: PropTypes.object.isRequired, itemsActions: PropTypes.object.isRequired, linesActions: PropTypes.object.isRequired, holesActions: PropTypes.object.isRequired, projectActions: PropTypes.object.isRequired }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/catalog-view/catalog-list.jsx"],"names":["React","Component","PropTypes","CatalogItem","CatalogBreadcrumb","CatalogPageItem","CatalogTurnBackPageItem","ContentContainer","ContentTitle","SharedStyle","containerStyle","position","width","height","backgroundColor","padding","left","overflowY","overflowX","zIndex","itemsStyle","display","gridTemplateColumns","gridGap","marginTop","searchContainer","background","border","cursor","boxShadow","borderRadius","transition","WebkitTransition","marginBottom","searchText","searchInput","margin","historyContainer","historyElementStyle","lineHeight","textAlign","PRIMARY_COLOR","alt","color","text_main","textTransform","CatalogList","props","context","page","state","catalog","currentCategory","getCategory","categoriesToDisplay","categories","elementsToDisplay","elements","filter","element","info","visibility","matchString","matchedElements","toRet","x","length","curr","concat","flattenCategories","text","array","filtered","regexp","RegExp","i","test","title","push","setState","prototype","linesActions","selectToolDrawingLine","name","itemsActions","selectToolDrawingItem","holesActions","selectToolDrawingHole","projectActions","pushLastSelectedCatalogElementToHistory","breadcrumbComponent","breadcrumbsNames","path","forEach","pathName","label","action","goBackToCatalogPage","pathSize","size","turnBackButton","get","selectedHistory","selectedHistoryElements","map","el","ind","select","style","translator","t","e","matcharray","target","value","cat","elem","propTypes","object","isRequired","number","contextTypes"],"mappings":"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","file":"catalog-list.js","sourcesContent":["import React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport CatalogItem from './catalog-item';\nimport CatalogBreadcrumb from './catalog-breadcrumb';\nimport CatalogPageItem from './catalog-page-item';\nimport CatalogTurnBackPageItem from './catalog-turn-back-page-item';\nimport ContentContainer from '../style/content-container';\nimport ContentTitle from '../style/content-title';\nimport * as SharedStyle from '../../shared-style';\n\nconst containerStyle = {\n  position: 'fixed',\n  width:'calc( 100% - 51px)',\n  height:'calc( 100% - 20px)',\n  backgroundColor:'#FFF',\n  padding:'1em',\n  left:50,\n  overflowY:'auto',\n  overflowX:'hidden',\n  zIndex:10\n};\n\nconst itemsStyle = {\n  display: 'grid',\n  gridTemplateColumns: 'repeat(auto-fit, minmax(14em, 1fr))',\n  gridGap: '10px',\n  marginTop: '1em'\n};\n\nconst searchContainer = {\n  width: '100%',\n  height: '3em',\n  padding: '0.625em',\n  background: '#f7f7f9',\n  border: '1px solid #e1e1e8',\n  cursor: 'pointer',\n  position: 'relative',\n  boxShadow: '0 1px 6px 0 rgba(0, 0, 0, 0.11), 0 1px 4px 0 rgba(0, 0, 0, 0.11)',\n  borderRadius: '2px',\n  transition: 'all .2s ease-in-out',\n  WebkitTransition: 'all .2s ease-in-out',\n  marginBottom: '1em'\n};\n\nconst searchText = {\n  width: '8em',\n  display: 'inline-block'\n};\n\nconst searchInput = {\n  width: 'calc( 100% - 10em )',\n  height: '2em',\n  margin: '0',\n  padding: '0 1em',\n  border: '1px solid #EEE'\n};\n\nconst historyContainer = {\n  ...searchContainer,\n  padding: '0.2em 0.625em'\n};\n\nconst historyElementStyle = {\n  width: 'auto',\n  height: '2em',\n  lineHeight: '2em',\n  textAlign:'center',\n  borderRadius: '1em',\n  display: 'inline-block',\n  cursor: 'pointer',\n  backgroundColor: SharedStyle.PRIMARY_COLOR.alt,\n  color: SharedStyle.PRIMARY_COLOR.text_main,\n  textTransform: 'capitalize',\n  margin: '0.25em',\n  padding: '0 1em'\n};\n\nexport default class CatalogList extends Component {\n\n  constructor(props, context) {\n    super(props);\n\n    let page = props.state.catalog.page;\n    let currentCategory = context.catalog.getCategory(page);\n    let categoriesToDisplay = currentCategory.categories;\n    let elementsToDisplay = currentCategory.elements.filter(element => element.info.visibility ? element.info.visibility.catalog : true );\n\n    this.state = {\n      categories: currentCategory.categories,\n      elements: elementsToDisplay,\n      matchString: '',\n      matchedElements: []\n    };\n  }\n\n  flattenCategories( categories ) {\n    let toRet = [];\n\n    for( let x = 0; x < categories.length; x++ )\n    {\n      let curr = categories[x];\n      toRet = toRet.concat( curr.elements );\n      if( curr.categories.length ) toRet = toRet.concat( this.flattenCategories ( curr.categories ) );\n    }\n\n    return toRet;\n  }\n\n  matcharray( text ) {\n\n    let array = this.state.elements.concat( this.flattenCategories( this.state.categories ) );\n\n    let filtered = [];\n\n    if( text != '' ) {\n      let regexp = new RegExp( text, 'i');\n      for (let i = 0; i < array.length; i++) {\n        if (regexp.test(array[i].info.title)) {\n          filtered.push(array[i]);\n        }\n      }\n    }\n\n    this.setState({\n      matchString: text,\n      matchedElements: filtered\n    });\n  };\n\n  select( element ) {\n\n    switch (element.prototype) {\n      case 'lines':\n        this.context.linesActions.selectToolDrawingLine(element.name);\n        break;\n      case 'items':\n        this.context.itemsActions.selectToolDrawingItem(element.name);\n        break;\n      case 'holes':\n        this.context.holesActions.selectToolDrawingHole(element.name);\n        break;\n    }\n\n    this.context.projectActions.pushLastSelectedCatalogElementToHistory(element);\n  }\n\n  render() {\n\n    let page = this.props.state.catalog.page;\n    let currentCategory = this.context.catalog.getCategory(page);\n    let categoriesToDisplay = currentCategory.categories;\n    let elementsToDisplay = currentCategory.elements.filter(element => element.info.visibility ? element.info.visibility.catalog : true );\n\n    let breadcrumbComponent = null;\n\n    if (page !== 'root') {\n\n      let breadcrumbsNames = [];\n\n      this.props.state.catalog.path.forEach(pathName => {\n        breadcrumbsNames.push({\n          name: this.context.catalog.getCategory(pathName).label,\n          action: () => projectActions.goBackToCatalogPage(pathName)\n        });\n      });\n\n      breadcrumbsNames.push({name: currentCategory.label, action: ''});\n\n      breadcrumbComponent = (<CatalogBreadcrumb names={breadcrumbsNames}/>);\n    }\n\n    let pathSize = this.props.state.catalog.path.size;\n\n    let turnBackButton = pathSize > 0 ? (\n      <CatalogTurnBackPageItem key={pathSize} page={this.context.catalog.categories[this.props.state.catalog.path.get(pathSize - 1)]}/>) : null;\n\n\n    let selectedHistory = this.props.state.get('selectedElementsHistory');\n    let selectedHistoryElements = selectedHistory.map( ( el, ind ) =>\n      <div key={ind} style={historyElementStyle} title={el.name} onClick={() => this.select(el) }>{el.name}</div>\n    );\n\n    return (\n      <ContentContainer width={this.props.width} height={this.props.height} style={{...containerStyle, ...this.props.style}}>\n        <ContentTitle>{this.context.translator.t('Catalog')}</ContentTitle>\n        {breadcrumbComponent}\n        <div style={searchContainer}>\n          <span style={searchText}>{this.context.translator.t('Search Element')}</span>\n          <input type=\"text\" style={searchInput} onChange={( e ) => { this.matcharray( e.target.value ); } }/>\n        </div>\n        { selectedHistory.size ?\n          <div style={historyContainer}>\n            <span>{this.context.translator.t('Last Selected')}</span>\n            {selectedHistoryElements}\n          </div> :\n          null\n        }\n        <div style={itemsStyle}>\n          {\n            this.state.matchString === '' ? [\n              turnBackButton,\n              categoriesToDisplay.map(cat => <CatalogPageItem key={cat.name} page={cat} oldPage={currentCategory}/>),\n              elementsToDisplay.map(elem => <CatalogItem key={elem.name} element={elem}/>)\n            ] :\n            this.state.matchedElements.map(elem => <CatalogItem key={elem.name} element={elem}/>)\n          }\n        </div>\n      </ContentContainer>\n    )\n  }\n}\n\nCatalogList.propTypes = {\n  state: PropTypes.object.isRequired,\n  width: PropTypes.number.isRequired,\n  height: PropTypes.number.isRequired,\n  style: PropTypes.object\n};\n\nCatalogList.contextTypes = {\n  catalog: PropTypes.object.isRequired,\n  translator: PropTypes.object.isRequired,\n  itemsActions: PropTypes.object.isRequired,\n  linesActions: PropTypes.object.isRequired,\n  holesActions: PropTypes.object.isRequired,\n  projectActions: PropTypes.object.isRequired\n};\n"]}