index.js 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. import React, {Component} from 'react'
  2. import {Checkbox, WhiteSpace, Modal, Toast} from 'antd-mobile'
  3. import classNames from 'classnames'
  4. import {Mutation} from "react-apollo"
  5. import gql from "graphql-tag"
  6. import '../index.css'
  7. import {delete_userCart_by_id} from "../../../../utils/gql"
  8. const alert = Modal.alert
  9. class CartEdit extends Component {
  10. constructor(props) {
  11. super(props)
  12. this.state = {
  13. isSelectAll:false,
  14. selectedCount:0
  15. }
  16. }
  17. //获取数据
  18. componentWillMount(){
  19. this.setState({
  20. cartList:this.props.cartList
  21. },()=>{
  22. this.checkedAll('',false)
  23. })
  24. }
  25. //获取输入框的值
  26. getInputValue=(e,i)=>{
  27. this.setState({
  28. cartList:this.state.cartList.map((item,index)=>{
  29. if(index===i){
  30. item.count=e.target.value
  31. return item
  32. }else {
  33. return item
  34. }
  35. })
  36. })
  37. this.sumCount()
  38. }
  39. // 增加
  40. augment=(e,i)=>{
  41. this.setState({
  42. cartList:this.state.cartList.map((item,index)=>{
  43. if(index===i){
  44. item.count=item.count*1+1
  45. return item
  46. }else {
  47. return item
  48. }
  49. })
  50. })
  51. this.sumCount()
  52. }
  53. // 减少
  54. reduce=(e,i)=> {
  55. this.setState({
  56. cartList:this.state.cartList.map((item,index)=>{
  57. if(index===i){
  58. item.count=item.count*1-1
  59. return item
  60. }else {
  61. return item
  62. }
  63. })
  64. })
  65. this.sumCount()
  66. }
  67. // 删除
  68. delete=(delete_userCart_by_id)=>{
  69. let {cartList} = this.state
  70. alert('', `确定要删除这${this.state.selectedCount}种商品吗?`, [
  71. { text: '取消', onPress: () => console.log('cancel') },
  72. {
  73. text: '确定',
  74. onPress: () => {
  75. let deleteList = cartList.filter((item)=> item.checked === true)
  76. let cartList1 = cartList.filter((item)=> item.checked === false)
  77. let deleteIdList = deleteList.map(item => item.id)
  78. // console.log('delete list',deleteIdList)
  79. delete_userCart_by_id({variables:{id:deleteIdList}}).then((data)=>{
  80. // console.log('delete data',data)
  81. let num = data.data.delete_userCart.replace(/[^0-9]/ig,"")
  82. if(num){
  83. Toast.info('删除成功', 1)
  84. this.setState({
  85. cartList:cartList1,
  86. selectedCount:0
  87. })
  88. }
  89. })
  90. }
  91. }
  92. ])
  93. }
  94. //删除单个备用
  95. del=(e,i)=> {
  96. this.setState({
  97. cartList:this.state.cartList.filter((item,index)=>{
  98. if(index!==i){
  99. return true
  100. }else {
  101. return false
  102. }
  103. })
  104. })
  105. setTimeout(()=>{
  106. this.sumCount()
  107. },1)
  108. }
  109. // 改变选择
  110. changeCheckedStatus=(e,i)=>{
  111. this.setState({
  112. cartList:this.state.cartList.map((item,index)=>{
  113. if(index===i){
  114. item.checked=! item.checked
  115. }
  116. return item
  117. })
  118. })
  119. let flag = this.state.cartList.every((item,index)=>{
  120. if( item.checked===false) {
  121. return false
  122. }else {
  123. return true
  124. }
  125. })
  126. if(flag===true){
  127. this.setState({isSelectAll:true})
  128. }else {
  129. this.setState({isSelectAll:false})
  130. }
  131. this.sumCount()
  132. }
  133. //全选或全不选,判断全选状态
  134. checkedAll=(e,check)=>{
  135. let checked = e.target ? e.target.checked : check
  136. if(checked===true){
  137. this.setState({
  138. cartList:this.state.cartList.map(( item,index)=>{
  139. item.checked=true
  140. return item
  141. }),
  142. isSelectAll:true
  143. })
  144. }else if(checked===false){
  145. this.setState({
  146. cartList:this.state.cartList.map((item,index)=>{
  147. item.checked=false
  148. return item
  149. }),
  150. isSelectAll:false
  151. })
  152. }
  153. this.sumCount()
  154. }
  155. //计算总合计
  156. sumCount=()=>{
  157. let selectedCount=0
  158. this.state.cartList.forEach((item,index)=>{
  159. if(item.checked===true){
  160. selectedCount+=item.count
  161. }
  162. })
  163. this.setState({
  164. selectedCount
  165. })
  166. }
  167. render() {
  168. let {cartList} = this.state
  169. let listLength = cartList.length
  170. return (
  171. <Mutation mutation={gql(delete_userCart_by_id)}
  172. onCompleted={()=>{this.props.refetch()}}
  173. onError={error=>console.log('error',error)}
  174. >
  175. {(delete_userCart_by_id,{ loading, error }) => (
  176. <div className="cart-content-wrap">
  177. <div className='cart-content'>
  178. {
  179. this.state.cartList.map((item,index)=>{
  180. return(
  181. <div key={item.id+'edit'}>
  182. <div className="cart-list">
  183. <div className="cart-list-checkbox">
  184. <Checkbox
  185. style={{marginLeft:15}}
  186. checked={item.checked}
  187. onChange={(e)=>{this.changeCheckedStatus(e,index)}}
  188. />
  189. </div>
  190. <div className="cart-list-image">
  191. <img src={item.product_id.img || "https://gw.alipayobjects.com/zos/rmsportal/nywPmnTAvTmLusPxHPSu.png"} alt=""/>
  192. </div>
  193. <div className="cart-list-intro">
  194. <div>{item.product_id.name}</div>
  195. <div>{item.specificationStock_id.color} {item.specificationStock_id.size}</div>
  196. <div>¥ {item.product_id.price}</div>
  197. </div>
  198. <div className="cart-list-count">
  199. <div className="selected">
  200. <button
  201. className={classNames({
  202. 'selected_button': true,
  203. 'selected_button-disabled': item.count <= 1
  204. })}
  205. disabled={item.count <= 1}
  206. onClick={(e)=>{this.reduce(e,index)}}
  207. >-</button>
  208. <input className="selected_input" type="text" value={item.count} onChange={(e)=>{this.getInputValue(e,index)}}/>
  209. <button className="selected_button" onClick={(e)=>{this.augment(e,index)}}>+</button>
  210. </div>
  211. </div>
  212. </div>
  213. <WhiteSpace size="md" />
  214. </div>
  215. )
  216. })
  217. }
  218. </div>
  219. {
  220. listLength ?
  221. <div className="footer">
  222. <div className="jiesuan">
  223. <div className="jiesuan-checkbox">
  224. <Checkbox
  225. checked={this.state.isSelectAll}
  226. onChange={(e)=>{this.checkedAll(e,'')}}
  227. style={{marginLeft:15}}
  228. />
  229. <span className="jiesuan-checkbox_label">全选</span>
  230. </div>
  231. <div className="jiesuan-total">
  232. </div>
  233. <button className="jiesuan-button" onClick={()=>{this.delete(delete_userCart_by_id)}}>
  234. <span>删除({this.state.selectedCount})</span>
  235. </button>
  236. </div>
  237. </div>:''
  238. }
  239. </div>
  240. )}
  241. </Mutation>
  242. )
  243. }
  244. }
  245. export default CartEdit