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
JavaScript
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"]}