company.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. import React, { PureComponent, Fragment } from 'react';
  2. import { connect } from 'react-redux';
  3. import { Input, Cascader, message } from 'antd';
  4. import { actionCreators } from './store';
  5. import options from '../popups/districtOptions.json';
  6. class company extends PureComponent {
  7. render() {
  8. const { companyDetail, natureOptions, handleModifyCompany } = this.props;
  9. let companyDetail2 = companyDetail.toJS();
  10. let natureOptions2 = natureOptions.toJS();
  11. console.log('ddd');
  12. return (
  13. <Fragment>
  14. {/* <div className="save-tips">
  15. <div className="alert bg-warning-700 text-white p-2 m-1" role="alert">
  16. <div className="d-flex align-items-center">
  17. <div className="alert-icon">
  18. <i className="fal fa-info-circle"></i>
  19. </div>
  20. <div className="flex-1">
  21. <span className="h5">内容已经修改</span>
  22. </div>
  23. <a href="#" className="btn btn-sm text-white width-8">取消</a>
  24. <a href="#" className="btn btn-light btn-sm width-8">保存</a>
  25. </div>
  26. </div>
  27. </div> */}
  28. <div className="sheet-panel-header d-flex justify-content-between mx-4">
  29. <div>
  30. <a href="#" data-toggle="tooltip" data-placement="top" title="" data-original-title="新页面打开"><i className="fal fa-external-link"></i></a>
  31. </div>
  32. <div>
  33. </div>
  34. </div>
  35. <div className="sheet-panel-content">
  36. <div className="sheet-panel-form slimScroll1 mx-4">
  37. <div className="form-header mt-3">
  38. <div className="d-flex justify-content-between">
  39. <span className="text-muted">公司</span>
  40. <span className="text-muted">{companyDetail2.staffDetial.username} 创建于 {companyDetail2.create_time}</span>
  41. </div>
  42. <legend>{companyDetail2.companyname}</legend>
  43. </div>
  44. <div className="cldform clearfix">
  45. <div className="cldform-line"></div>
  46. <div className="cldform-item">
  47. <div className="cldform-label">公司全称</div>
  48. <div className="cldform-control">
  49. {/* {false ?(<Input id="2"
  50. value={companyDetail2.companyname}
  51. onClick={() => console.log('false')}
  52. onChange={() => console.log('sdf')}
  53. />):(<div onClick={() => console.log('false')} className="cldform-contarl-box cldform-contarl-textareabox"><span>张三</span></div>)} */}
  54. <Input id="2"
  55. value={companyDetail2.companyname}
  56. onChange={(e) => handleModifyCompany({
  57. 'field': 'companyname', 'value': e.target.value
  58. , 'key': companyDetail2.key, 'title': '公司全称'
  59. })}
  60. />
  61. </div>
  62. </div>
  63. <div className="cldform-line"></div>
  64. <div className="cldform-item cldform-item-wauto">
  65. <div className="cldform-label">公司地区</div>
  66. <div className="cldform-control">
  67. {/* {["19","292","3066"]} */}
  68. <Cascader options={options} value={companyDetail2.district} style={{ width: '100%' }} placeholder="公司地区"
  69. onChange={(e, selectedOptions) => handleModifyCompany({
  70. 'field': 'district', 'value': e
  71. , 'key': companyDetail2.key, 'title': '公司地区', 'lable': selectedOptions
  72. })}
  73. />
  74. </div>
  75. </div>
  76. <div className="cldform-line"></div>
  77. <div className="cldform-item cldform-item-wauto">
  78. <div className="cldform-label">公司性质</div>
  79. <div className="cldform-control">
  80. <Cascader options={natureOptions2} value={[companyDetail2.nature]} placeholder="公司性质" style={{ width: '100%' }}
  81. onChange={(e, selectedOptions) => handleModifyCompany({
  82. 'field': 'nature', 'value': e
  83. , 'key': companyDetail2.key, 'title': '公司性质', 'lable': selectedOptions
  84. })}
  85. />
  86. </div>
  87. </div>
  88. <div className="cldform-line"></div>
  89. <div className="cldform-item">
  90. <div className="cldform-label">公司地址</div>
  91. <div className="cldform-control">
  92. <Input id="2" value={companyDetail2.address}
  93. onChange={(e) => handleModifyCompany({ 'field': 'address', 'value': e.target.value
  94. , 'key': companyDetail2.key, 'title': '公司地址' })}
  95. />
  96. </div>
  97. </div>
  98. <div className="cldform-line"></div>
  99. <div className="cldform-item cldform-item-half pr-3">
  100. <div className="cldform-label">公司传真</div>
  101. <div className="cldform-control">
  102. <Input id="2"
  103. value={companyDetail2.fax}
  104. onChange={(e) => handleModifyCompany({ 'field': 'fax', 'value': e.target.value
  105. , 'key': companyDetail2.key, 'title': '公司传真' })}
  106. />
  107. </div>
  108. </div>
  109. <div className="cldform-item cldform-item-half pl-3">
  110. <div className="cldform-label">网址</div>
  111. <div className="cldform-control">
  112. <Input id="2"
  113. value={companyDetail2.webservice}
  114. onChange={(e) => handleModifyCompany({ 'field': 'webservice', 'value': e.target.value
  115. , 'key': companyDetail2.key, 'title': '网址' })}
  116. />
  117. </div>
  118. </div>
  119. <div className="cldform-line"></div>
  120. <div className="cldform-item">
  121. <div className="cldform-label">乘车路线</div>
  122. <div className="cldform-control">
  123. <Input id="2"
  124. value={companyDetail2.ride}
  125. onChange={(e) => handleModifyCompany({ 'field': 'ride', 'value': e.target.value
  126. , 'key': companyDetail2.key, 'title': '乘车路线' })}
  127. />
  128. </div>
  129. </div>
  130. <div className="cldform-line"></div>
  131. <div className="cldform-item">
  132. <div className="cldform-label">地标建筑</div>
  133. <div className="cldform-control">
  134. <Input id="2"
  135. value={companyDetail2.landmarks}
  136. onChange={(e) => handleModifyCompany({ 'field': 'landmarks', 'value': e.target.value
  137. , 'key': companyDetail2.key, 'title': '地标建筑' })}
  138. />
  139. </div>
  140. </div>
  141. <div className="cldform-line"></div>
  142. <div className="cldform-item">
  143. <div className="cldform-label">参考住宿</div>
  144. <div className="cldform-control">
  145. <Input id="2"
  146. value={companyDetail2.stay}
  147. onChange={(e) => handleModifyCompany({ 'field': 'stay', 'value': e.target.value
  148. , 'key': companyDetail2.key, 'title': '参考住宿' })}
  149. />
  150. </div>
  151. </div>
  152. <div className="cldform-line"></div>
  153. <div className="cldform-item">
  154. <div className="cldform-label">备注</div>
  155. <div className="cldform-control">
  156. <Input id="2"
  157. value={companyDetail2.remarks}
  158. onChange={(e) => handleModifyCompany({ 'field': 'remarks', 'value': e.target.value
  159. , 'key': companyDetail2.key, 'title': '备注' })}
  160. />
  161. </div>
  162. </div>
  163. </div>
  164. </div>
  165. </div>
  166. </Fragment>
  167. );
  168. }
  169. }
  170. let delaySwitch = null;//延迟检索开关
  171. const mapStateToProps = (state) => {
  172. return {
  173. companyDetail: state.getIn(['companyPopups', 'companyDetail']),
  174. natureOptions: state.getIn(['companyPopups', 'natureOptions']),
  175. }
  176. }
  177. const mapDispathToProps = (dispatch) => {
  178. return {
  179. handleModifyCompany(parameter) {
  180. dispatch(actionCreators.changeInputValue(parameter));
  181. if (delaySwitch != null) {
  182. clearTimeout(delaySwitch);
  183. }
  184. delaySwitch = setTimeout(() => {
  185. dispatch(actionCreators.modifyCompany(parameter));
  186. }, 800);
  187. },
  188. }
  189. }
  190. export default connect(mapStateToProps, mapDispathToProps)(company);