add json viewer of document query result
This commit is contained in:
		
							parent
							
								
									e43ef558ce
								
							
						
					
					
						commit
						853bc5cdde
					
				|  | @ -9,7 +9,6 @@ class InputSelect extends React.Component{ | ||||||
|     super(props); |     super(props); | ||||||
|     this.state = { |     this.state = { | ||||||
|       value: props.defaultValue || props.value, |       value: props.defaultValue || props.value, | ||||||
|       originData: props.data || [], |  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  | @ -27,7 +26,7 @@ class InputSelect extends React.Component{ | ||||||
|   } |   } | ||||||
|   handleChange = (ev) => { |   handleChange = (ev) => { | ||||||
|     let val = ev.target.value; |     let val = ev.target.value; | ||||||
|     let filterData = this.state.originData.slice(); |     let filterData = this.props.data.slice(); | ||||||
|     if(val != ""){ |     if(val != ""){ | ||||||
|       filterData = filterData.filter(v=>v.value.includes(val)) |       filterData = filterData.filter(v=>v.value.includes(val)) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -2,13 +2,16 @@ import React from 'react'; | ||||||
| import { formatMessage, FormattedMessage } from 'umi/locale'; | import { formatMessage, FormattedMessage } from 'umi/locale'; | ||||||
| import router from 'umi/router'; | import router from 'umi/router'; | ||||||
| import { connect } from 'dva'; | import { connect } from 'dva'; | ||||||
| import { Col, Form, Row,Select, Input, Card,Icon, Table, InputNumber, Popconfirm, | import { | ||||||
|    Divider,Button,Tooltip, Modal, DatePicker, message,Cascader } from 'antd'; |   Col, Form, Row, Select, Input, Card, Icon, Table, InputNumber, Popconfirm, | ||||||
|  |   Divider, Button, Tooltip, Modal, DatePicker, message, Cascader, List,Radio | ||||||
|  | } from 'antd'; | ||||||
| import Editor, {monaco} from '@monaco-editor/react'; | import Editor, {monaco} from '@monaco-editor/react'; | ||||||
| import moment from 'moment'; | import moment from 'moment'; | ||||||
| import {createDependencyProposals} from './autocomplete'; | import {createDependencyProposals} from './autocomplete'; | ||||||
| import InputSelect from '@/components/infini/InputSelect'; | import InputSelect from '@/components/infini/InputSelect'; | ||||||
| import {getFields,getESAPI} from '@/lib/elasticsearch/util'; | import {getFields,getESAPI} from '@/lib/elasticsearch/util'; | ||||||
|  | import {Link} from "_umi@2.13.16@umi"; | ||||||
| 
 | 
 | ||||||
| function findParentIdentifier(textUntilPosition){ | function findParentIdentifier(textUntilPosition){ | ||||||
|   let chars = textUntilPosition; |   let chars = textUntilPosition; | ||||||
|  | @ -99,7 +102,184 @@ function initEditor() { | ||||||
|     }) |     }) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const {Option} = Select; | class EditModal extends React.Component{ | ||||||
|  |    okHandle = () => { | ||||||
|  |      const {handleUpdate, values} = this.props; | ||||||
|  |      handleUpdate({ | ||||||
|  |        _type: values._type, | ||||||
|  |        _index: values._index, | ||||||
|  |        _id: values.id, | ||||||
|  |        data: JSON.parse(this.valueGetter()), | ||||||
|  |      }); | ||||||
|  |   } | ||||||
|  |   handleEditorDidMount = (valueGetter)=>{ | ||||||
|  |      this.valueGetter = valueGetter; | ||||||
|  |   } | ||||||
|  |   render(){ | ||||||
|  |     const { handleModalVisible, values, cleanRecord } = this.props; | ||||||
|  |     let newR = cleanRecord(values); | ||||||
|  |     return ( | ||||||
|  |       <Modal | ||||||
|  |         destroyOnClose | ||||||
|  |         title="update document" | ||||||
|  |         width={640} | ||||||
|  |         visible={values!==null} | ||||||
|  |         onOk={this.okHandle} | ||||||
|  |         onCancel={() => handleModalVisible()} | ||||||
|  |       > | ||||||
|  |         <div> | ||||||
|  |           <Editor | ||||||
|  |             height="300px" | ||||||
|  |             language="json" | ||||||
|  |             theme="light" | ||||||
|  |             value={JSON.stringify(newR,null,2)} | ||||||
|  |             options={{ | ||||||
|  |               minimap: { | ||||||
|  |                 enabled: false, | ||||||
|  |               }, | ||||||
|  |               tabSize: 2, | ||||||
|  |               wordBasedSuggestions: true, | ||||||
|  |             }} | ||||||
|  |             editorDidMount={this.handleEditorDidMount} | ||||||
|  |           /> | ||||||
|  |         </div> | ||||||
|  |       </Modal> | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | class JSONTable extends React.Component{ | ||||||
|  |   handleTableChange = (page, size) =>{ | ||||||
|  |     //console.log(pagination, filters, sorter);
 | ||||||
|  | 
 | ||||||
|  |     const {fetchData, doclist} = this.props; | ||||||
|  |     fetchData({ | ||||||
|  |       pageIndex: page, | ||||||
|  |       pageSize: size || doclist.pageSize, | ||||||
|  |       index: doclist.index, | ||||||
|  |       cluster: doclist.cluster, | ||||||
|  |       filter: doclist.filter, | ||||||
|  |     }) | ||||||
|  |   } | ||||||
|  |   setStateValue = (payload) =>{ | ||||||
|  |     const {dispatch} = this.props; | ||||||
|  |     dispatch({ | ||||||
|  |       type: 'document/saveData', | ||||||
|  |       payload: { | ||||||
|  |         ...payload, | ||||||
|  |       } | ||||||
|  |     }) | ||||||
|  |   } | ||||||
|  |   handleEditClick = (record)=>{ | ||||||
|  |     this.setStateValue({ | ||||||
|  |       editValue: record | ||||||
|  |     }); | ||||||
|  |   } | ||||||
|  |   handleModalVisible =()=>{ | ||||||
|  |     const {doclist} = this.props; | ||||||
|  |     let payload = { | ||||||
|  |       editValue: null, | ||||||
|  |     }; | ||||||
|  |     if(doclist.isAddNew){ | ||||||
|  |       payload.isAddNew = false; | ||||||
|  |     } | ||||||
|  |     this.setStateValue(payload); | ||||||
|  |   } | ||||||
|  |   handleDeleteClick = (record)=>{ | ||||||
|  |     const {dispatch} = this.props; | ||||||
|  |     dispatch({ | ||||||
|  |       type: 'document/deleteDocItem', | ||||||
|  |       payload: { | ||||||
|  |         _id: record.id, | ||||||
|  |         _index: record._index, | ||||||
|  |         _type: record._type, | ||||||
|  |       }, | ||||||
|  |     }) | ||||||
|  |   } | ||||||
|  |   handleSaveItemClick = (values)=>{ | ||||||
|  |     const {dispatch, doclist} = this.props; | ||||||
|  |     if(doclist.isAddNew){ | ||||||
|  |       dispatch({ | ||||||
|  |         type: 'document/addDocItem', | ||||||
|  |         payload: values, | ||||||
|  |       }); | ||||||
|  |     }else { | ||||||
|  |       dispatch({ | ||||||
|  |         type: 'document/saveDocItem', | ||||||
|  |         payload: values, | ||||||
|  |       }); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   cleanRecord = (record)=>{ | ||||||
|  |     let newR = { | ||||||
|  |       ...record | ||||||
|  |     }; | ||||||
|  |     delete(newR["_type"]); | ||||||
|  |     delete(newR["_index"]); | ||||||
|  |     delete(newR["id"]); | ||||||
|  |     return newR; | ||||||
|  |   } | ||||||
|  |   render() { | ||||||
|  |     let {data, total, pageSize,pageIndex, resultKey, editValue} = this.props.doclist; | ||||||
|  |     if(total && total.value){ | ||||||
|  |       total = total.value; | ||||||
|  |     } | ||||||
|  |     let dataList = _.clone(data) || []; | ||||||
|  |     dataList = dataList.filter(item=>{ | ||||||
|  |       return item._index === resultKey; | ||||||
|  |     }) | ||||||
|  |     return( | ||||||
|  |       <div> | ||||||
|  |         {editValue ? <EditModal handleModalVisible={this.handleModalVisible} | ||||||
|  |                                            cleanRecord={this.cleanRecord} | ||||||
|  |                                            handleUpdate={this.handleSaveItemClick} | ||||||
|  |                                            values={editValue}/>: null} | ||||||
|  |       <List | ||||||
|  |         grid={{ | ||||||
|  |           gutter: 8, | ||||||
|  |           xs: 1, | ||||||
|  |           sm: 2, | ||||||
|  |           md: 2, | ||||||
|  |           lg: 2, | ||||||
|  |           xl: 3, | ||||||
|  |           xxl: 3, | ||||||
|  |         }} | ||||||
|  |         dataSource={dataList} | ||||||
|  |         pagination={{ | ||||||
|  |           onChange: (page, size) => { | ||||||
|  |             this.handleTableChange(page, size); | ||||||
|  |           }, | ||||||
|  |           onShowSizeChange: (current, size)=>{ | ||||||
|  |             this.handleTableChange(current, size); | ||||||
|  |           }, | ||||||
|  |           total: total, | ||||||
|  |           showSizeChanger: true, | ||||||
|  |           pageSizeOptions: ["3","6","10","20"], | ||||||
|  |           pageSize: pageSize || 10, | ||||||
|  |           current: pageIndex || 1, | ||||||
|  |           showTotal: (total, range) => `Total ${total} items`, | ||||||
|  |           size: 'small', | ||||||
|  |         }} | ||||||
|  |         renderItem={item => ( | ||||||
|  |           <List.Item key={item.id}> | ||||||
|  |             <Card title={item.id} | ||||||
|  |               actions={[ | ||||||
|  |                 <Icon type="edit" key="edit" onClick={()=>this.handleEditClick(item)} />, | ||||||
|  |                 <Popconfirm title="Sure to delete?" onConfirm={()=>this.handleDeleteClick(item)}> | ||||||
|  |                   <Icon type="delete" key="delete" /> | ||||||
|  |                 </Popconfirm>, | ||||||
|  |               ]}> | ||||||
|  |               <div style={{height:200, overflow:'scroll'}}> | ||||||
|  |                  <pre className="language-json">{JSON.stringify(this.cleanRecord(item), null, 2)}</pre> | ||||||
|  |               </div> | ||||||
|  |             </Card> | ||||||
|  |           </List.Item> | ||||||
|  |         )} | ||||||
|  |       /> | ||||||
|  |       </div> | ||||||
|  |     ) | ||||||
|  |   } | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| const EditableContext = React.createContext(); | const EditableContext = React.createContext(); | ||||||
| 
 | 
 | ||||||
|  | @ -128,12 +308,10 @@ class EditableCell extends React.Component { | ||||||
|         type, |         type, | ||||||
|         ...restProps |         ...restProps | ||||||
|       } = this.props; |       } = this.props; | ||||||
|       let initialValue = ''; |       let initialValue = (record && record[dataIndex]) || ''; | ||||||
|       if(editing){ |       if(editing){ | ||||||
|         if(type=='date'){ |         if(type=='date'){ | ||||||
|           initialValue = record[dataIndex] && moment(record[dataIndex]); |           initialValue = record[dataIndex] && moment(record[dataIndex]); | ||||||
|         }else{ |  | ||||||
|           initialValue = record[dataIndex]; |  | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|       return ( |       return ( | ||||||
|  | @ -250,19 +428,17 @@ class EditableCell extends React.Component { | ||||||
|           dispatch({ |           dispatch({ | ||||||
|             type: 'document/saveDocItem', |             type: 'document/saveDocItem', | ||||||
|             payload: { |             payload: { | ||||||
|               index: doclist._index, |               _index: doclist._index, | ||||||
|               _type: doclist._type, |               _type: doclist._type, | ||||||
|               data: { |               _id: key, | ||||||
|                 id: key, |               data: row, | ||||||
|                 ...row, |  | ||||||
|               } |  | ||||||
|             } |             } | ||||||
|           }) |           }) | ||||||
|         }else{ |         }else{ | ||||||
|           dispatch({ |           dispatch({ | ||||||
|             type: 'document/addDocItem', |             type: 'document/addDocItem', | ||||||
|             payload: { |             payload: { | ||||||
|               index: doclist._index, |               _index: doclist._index, | ||||||
|               _type: doclist._type, |               _type: doclist._type, | ||||||
|               data: row, |               data: row, | ||||||
|             } |             } | ||||||
|  | @ -284,11 +460,9 @@ class EditableCell extends React.Component { | ||||||
|       dispatch({ |       dispatch({ | ||||||
|         type: 'document/deleteDocItem', |         type: 'document/deleteDocItem', | ||||||
|         payload: { |         payload: { | ||||||
|           index: record._index, |           _index: record._index, | ||||||
|           _type: record._type, |           _type: record._type, | ||||||
|           data: { |           _id: record.id, | ||||||
|             id: record.id, |  | ||||||
|           } |  | ||||||
|         } |         } | ||||||
|       }); |       }); | ||||||
|     } |     } | ||||||
|  | @ -318,7 +492,11 @@ class EditableCell extends React.Component { | ||||||
|       let keys = []; |       let keys = []; | ||||||
|       let sortObj = {}; |       let sortObj = {}; | ||||||
|       if(doclist.mappings){ |       if(doclist.mappings){ | ||||||
|         keys = getFields(doclist.index, doclist.mappings) |         let index = doclist.index; | ||||||
|  |         if(!doclist.data || doclist.data.length === 0 || (doclist.data.length===1 &&doclist.data[0].id==="" )){ | ||||||
|  |           index = doclist.resultKey; | ||||||
|  |         } | ||||||
|  |         keys = getFields(index, doclist.mappings) | ||||||
|       } |       } | ||||||
|       for(let key of keys){ |       for(let key of keys){ | ||||||
|         if(["_index"].includes(key)){ |         if(["_index"].includes(key)){ | ||||||
|  | @ -358,6 +536,10 @@ class EditableCell extends React.Component { | ||||||
|       if(total.value){ |       if(total.value){ | ||||||
|         total = total.value; |         total = total.value; | ||||||
|       } |       } | ||||||
|  |       let data = _.clone(doclist.data) || []; | ||||||
|  |       data = data.filter(item=>{ | ||||||
|  |         return item._index === doclist.resultKey; | ||||||
|  |       }) | ||||||
|       return ( |       return ( | ||||||
|         <EditableContext.Provider value={this.props.form}> |         <EditableContext.Provider value={this.props.form}> | ||||||
|           <Table |           <Table | ||||||
|  | @ -367,7 +549,7 @@ class EditableCell extends React.Component { | ||||||
|             onChange={this.handleTableChange} |             onChange={this.handleTableChange} | ||||||
|             size="small" |             size="small" | ||||||
|             loading={doclist.isLoading} |             loading={doclist.isLoading} | ||||||
|             dataSource={doclist.data} |             dataSource={data} | ||||||
|             columns={columns} |             columns={columns} | ||||||
|             rowClassName="editable-row" |             rowClassName="editable-row" | ||||||
|             pagination={{ |             pagination={{ | ||||||
|  | @ -415,7 +597,7 @@ class Doucment extends React.Component { | ||||||
|       } |       } | ||||||
|   } |   } | ||||||
|   componentDidMount(){ |   componentDidMount(){ | ||||||
|       initEditor() |     //  initEditor()
 | ||||||
|     const {location, dispatch } = this.props; |     const {location, dispatch } = this.props; | ||||||
|     //console.log(match, location);
 |     //console.log(match, location);
 | ||||||
|     let index = location.query.index; |     let index = location.query.index; | ||||||
|  | @ -453,7 +635,7 @@ class Doucment extends React.Component { | ||||||
|     if(document.isAddNew){ //!document.data || document.data.length == 0 
 |     if(document.isAddNew){ //!document.data || document.data.length == 0 
 | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     let {mappings, indices} = document; |     let {mappings, indices, tableMode} = document; | ||||||
|     if(indices.length === 0) { |     if(indices.length === 0) { | ||||||
|       indices = Object.keys(mappings); |       indices = Object.keys(mappings); | ||||||
|     } |     } | ||||||
|  | @ -492,6 +674,7 @@ class Doucment extends React.Component { | ||||||
|         newDoc[key] = "" |         newDoc[key] = "" | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  |     if(tableMode !== 'JSON') { | ||||||
|       dispatch({ |       dispatch({ | ||||||
|         type: 'document/_addNew', |         type: 'document/_addNew', | ||||||
|         payload: { |         payload: { | ||||||
|  | @ -503,6 +686,17 @@ class Doucment extends React.Component { | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|       }) |       }) | ||||||
|  |     }else{ | ||||||
|  |       dispatch({ | ||||||
|  |         type: 'document/saveData', | ||||||
|  |         payload: { | ||||||
|  |           isAddNew: true, | ||||||
|  |           editValue: newDoc, | ||||||
|  |           _index, | ||||||
|  |           _type, | ||||||
|  |         }, | ||||||
|  |       }) | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   handleSearchClick = (e)=>{ |   handleSearchClick = (e)=>{ | ||||||
|  | @ -514,7 +708,7 @@ class Doucment extends React.Component { | ||||||
|       message.error('please select cluster and index'); |       message.error('please select cluster and index'); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     if(this.state.bodyDisplay != 'none'){ |     if(this.state.bodyDisplay !== 'none'){ | ||||||
|       filter = this.filterGetter(); |       filter = this.filterGetter(); | ||||||
|     } |     } | ||||||
|     this.fetchData({ |     this.fetchData({ | ||||||
|  | @ -533,9 +727,18 @@ class Doucment extends React.Component { | ||||||
|     }) |     }) | ||||||
|      |      | ||||||
|   } |   } | ||||||
|  |   handleTableModeChange = (e)=> { | ||||||
|  |     const {dispatch} = this.props; | ||||||
|  |     dispatch({ | ||||||
|  |       type: 'document/saveData', | ||||||
|  |       payload: { | ||||||
|  |         tableMode: e.target.value, | ||||||
|  |       } | ||||||
|  |     }); | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   renderNew = ()=>{ |   renderNew = ()=>{ | ||||||
|     let {indices, mappings} = this.props.document; |     let {indices, mappings, resultKey, tableMode} = this.props.document; | ||||||
|     // if((indices && indices.length > 1)){
 |     // if((indices && indices.length > 1)){
 | ||||||
|     //   return;
 |     //   return;
 | ||||||
|     // }
 |     // }
 | ||||||
|  | @ -562,13 +765,10 @@ class Doucment extends React.Component { | ||||||
|         } |         } | ||||||
|         return newItem; |         return newItem; | ||||||
|       }); |       }); | ||||||
|       this.indexSelEl && this.indexSelEl.setState({ |  | ||||||
|         value: [indices[0].value] |  | ||||||
|       }) |  | ||||||
|     } |     } | ||||||
|     return ( |     return ( | ||||||
|       <div> |       <div> | ||||||
|         {(indices && indices.length>0) ? (<Cascader ref={el=>{this.indexSelEl=el}} defaultValue={[indices[0].value]} options={indices} style={{width: 200, marginRight:5}} placeholder="please select a index"> |         {(indices && indices.length>0) ? (<Cascader ref={el=>{this.indexSelEl=el}} onChange={(vals)=>{this.handleResultTabKeyChange(vals[0])}} value={[resultKey]} options={indices} style={{width: 200, marginRight:5}} placeholder="please select a index"> | ||||||
|         </Cascader>) : ''} |         </Cascader>) : ''} | ||||||
|         {/*{(indices) ? (<Select ref={el=>{this.indexSelEl=el}} style={{width: 200, marginRight:5}} placeholder="please select a index">*/} |         {/*{(indices) ? (<Select ref={el=>{this.indexSelEl=el}} style={{width: 200, marginRight:5}} placeholder="please select a index">*/} | ||||||
|         {/*  {indices.map(item=>{*/} |         {/*  {indices.map(item=>{*/} | ||||||
|  | @ -576,9 +776,25 @@ class Doucment extends React.Component { | ||||||
|         {/*  })}*/} |         {/*  })}*/} | ||||||
|         {/*</Select>) : ''}*/} |         {/*</Select>) : ''}*/} | ||||||
|         <Button type="primary" icon="plus" onClick={this.handleNewClick}>{formatMessage({ id: 'form.button.new' })}</Button> |         <Button type="primary" icon="plus" onClick={this.handleNewClick}>{formatMessage({ id: 'form.button.new' })}</Button> | ||||||
|  |         <span style={{marginLeft:20}}> | ||||||
|  |           {/*Select Viewer:  */} | ||||||
|  |           <Radio.Group value={tableMode} onChange={this.handleTableModeChange} buttonStyle="solid"> | ||||||
|  |             <Radio.Button value="TABLE">TABLE</Radio.Button> | ||||||
|  |             <Radio.Button value="JSON">JSON</Radio.Button> | ||||||
|  |           </Radio.Group> | ||||||
|  |         </span> | ||||||
|       </div> |       </div> | ||||||
|     ) |     ) | ||||||
|   } |   } | ||||||
|  |   handleResultTabKeyChange=(key)=>{ | ||||||
|  |       const {dispatch} = this.props; | ||||||
|  |       dispatch({ | ||||||
|  |         type:'document/saveData', | ||||||
|  |         payload:{ | ||||||
|  |           resultKey: key, | ||||||
|  |         } | ||||||
|  |       }) | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   render(){ |   render(){ | ||||||
|       // const {getFieldDecorator} = this.props.form;
 |       // const {getFieldDecorator} = this.props.form;
 | ||||||
|  | @ -592,9 +808,17 @@ class Doucment extends React.Component { | ||||||
|         }; |         }; | ||||||
|       }) |       }) | ||||||
|       const clusters = ["single-es"]; |       const clusters = ["single-es"]; | ||||||
|       let {cluster, index}= this.props.document; |       let {cluster, index, indices, tableMode}= this.props.document; | ||||||
|       cluster = cluster || this.props.location.query.cluster || 'single-es'; |       cluster = cluster || this.props.location.query.cluster || 'single-es'; | ||||||
|       index = index || this.props.location.query.index; |       index = index || this.props.location.query.index; | ||||||
|  |       indices = indices || []; | ||||||
|  | 
 | ||||||
|  |       let resultTabList = indices.map(item=>{ | ||||||
|  |         return { | ||||||
|  |           key: item, | ||||||
|  |           tab: item, | ||||||
|  |         } | ||||||
|  |       }); | ||||||
|       return ( |       return ( | ||||||
|           <div> |           <div> | ||||||
|               <Card> |               <Card> | ||||||
|  | @ -608,10 +832,10 @@ class Doucment extends React.Component { | ||||||
|                           </Select> |                           </Select> | ||||||
|                           <InputSelect data={clusterIndices} onChange={()=>{this.hashChanged=true;}} defaultValue={index} ref={el=>{this.indexEl=el}} placeholder="input index or index pattern" style={{width: '25%'}}/> |                           <InputSelect data={clusterIndices} onChange={()=>{this.hashChanged=true;}} defaultValue={index} ref={el=>{this.indexEl=el}} placeholder="input index or index pattern" style={{width: '25%'}}/> | ||||||
|                           <Input |                           <Input | ||||||
|                               style={{width:"40%"}} |                               style={{width:"40%", display: this.state.bodyDisplay === 'none' ? 'inline': 'none'}} | ||||||
|                               ref={el=>this.keywordEl=el} |                               ref={el=>this.keywordEl=el} | ||||||
|                               placeholder="input search keyword" |                               placeholder="input search keyword" | ||||||
|                               disabled = {this.state.bodyDisplay != 'none'} |                               // disabled={this.state.bodyDisplay != 'none'}
 | ||||||
|                           /> |                           /> | ||||||
|                           <Button type="primary" onClick={this.handleSearchClick}>{formatMessage({ id: 'form.button.search' })}</Button> |                           <Button type="primary" onClick={this.handleSearchClick}>{formatMessage({ id: 'form.button.search' })}</Button> | ||||||
|                       </Input.Group> |                       </Input.Group> | ||||||
|  | @ -619,17 +843,21 @@ class Doucment extends React.Component { | ||||||
|                       <Col span={4}> |                       <Col span={4}> | ||||||
|                           <a style={{marginTop:5,display:'block'}} onClick={(e)=>{ |                           <a style={{marginTop:5,display:'block'}} onClick={(e)=>{ | ||||||
|                               this.setState((preState)=>{ |                               this.setState((preState)=>{ | ||||||
|                                   if(preState.bodyDisplay == 'none') { |                                   if(preState.bodyDisplay === 'none') { | ||||||
|  |                                     initEditor(); | ||||||
|                                       return { |                                       return { | ||||||
|                                           bodyDisplay: 'block', |                                           bodyDisplay: 'block', | ||||||
|                                       }; |                                       }; | ||||||
|                                   }else{ |                                   }else{ | ||||||
|  |                                     if(langDisposer != null) { | ||||||
|  |                                       langDisposer.dispose(); | ||||||
|  |                                     } | ||||||
|                                       return { |                                       return { | ||||||
|                                           bodyDisplay: 'none' |                                           bodyDisplay: 'none' | ||||||
|                                       }; |                                       }; | ||||||
|                                   } |                                   } | ||||||
|                               }); |                               }); | ||||||
|                           }}>{this.state.bodyDisplay == 'none' ? formatMessage({id:'form.button.advanced'}): formatMessage({id:'form.button.collapse'})}<Icon type="down" /></a> |                           }}>{this.state.bodyDisplay === 'none' ? formatMessage({id:'form.button.advanced'}): formatMessage({id:'form.button.collapse'})}<Icon type="down" /></a> | ||||||
|                       </Col> |                       </Col> | ||||||
|                   </Row> |                   </Row> | ||||||
|                   <Row style={{display: this.state.bodyDisplay}} gutter={[16, { xs: 8, sm: 16, md: 24, lg: 32 }]}> |                   <Row style={{display: this.state.bodyDisplay}} gutter={[16, { xs: 8, sm: 16, md: 24, lg: 32 }]}> | ||||||
|  | @ -670,9 +898,16 @@ class Doucment extends React.Component { | ||||||
|                   <Card title={`Index: ${this.props.document.index}`}  |                   <Card title={`Index: ${this.props.document.index}`}  | ||||||
|                     bodyStyle={{padding:0, paddingBottom: 24}} |                     bodyStyle={{padding:0, paddingBottom: 24}} | ||||||
|                     extra={this.renderNew()} |                     extra={this.renderNew()} | ||||||
|  |                     tabList={resultTabList} | ||||||
|  |                     onTabChange={this.handleResultTabKeyChange} | ||||||
|                     bordered={false}> |                     bordered={false}> | ||||||
|  |                     {tableMode !== 'JSON' ? | ||||||
|                       <EditableTable doclist={this.props.document} dispatch={this.props.dispatch} |                       <EditableTable doclist={this.props.document} dispatch={this.props.dispatch} | ||||||
|                       fetchData={(params)=>{this.fetchData(params)}}/> |                                      fetchData={(params) => { | ||||||
|  |                                        this.fetchData(params) | ||||||
|  |                                      }}/> : | ||||||
|  |                       <JSONTable doclist={this.props.document} dispatch={this.props.dispatch} fetchData={(params)=>{this.fetchData(params)}} /> | ||||||
|  |                     } | ||||||
|                     </Card> |                     </Card> | ||||||
|               </div> |               </div> | ||||||
|           </div> |           </div> | ||||||
|  |  | ||||||
|  | @ -2,14 +2,15 @@ import {getDocList, saveDoc, deleteDoc, addDoc}  from '@/services/doc'; | ||||||
| import {getMappings, getIndices} from '@/services/indices'; | import {getMappings, getIndices} from '@/services/indices'; | ||||||
| import {formatESSearchResult} from '@/lib/elasticsearch/util'; | import {formatESSearchResult} from '@/lib/elasticsearch/util'; | ||||||
| import { message } from 'antd'; | import { message } from 'antd'; | ||||||
|  | import moment from "moment"; | ||||||
| 
 | 
 | ||||||
| function encodeObjectField(doc){ | function encodeObjectField(doc){ | ||||||
|   //let rawData = {};
 |  | ||||||
|   for(let key of Object.keys(doc)){ |   for(let key of Object.keys(doc)){ | ||||||
|     if(typeof doc[key] == 'object'){ |     if(typeof doc[key] == 'object'){ | ||||||
|       // let docId = doc['id'];
 |       if(doc[key] instanceof moment){ | ||||||
|       // !rawData[docId] && (rawData[docId] = {});
 |         doc[key] = doc[key].toJSON(); | ||||||
|       // rawData[docId][key] = doc[key];
 |         continue; | ||||||
|  |       } | ||||||
|       doc[key] = JSON.stringify(doc[key]); |       doc[key] = JSON.stringify(doc[key]); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  | @ -18,6 +19,9 @@ function encodeObjectField(doc){ | ||||||
| 
 | 
 | ||||||
| function decodeObjectField(doc){ | function decodeObjectField(doc){ | ||||||
|   for(let key of Object.keys(doc)){ |   for(let key of Object.keys(doc)){ | ||||||
|  |     if(!doc[key]){ | ||||||
|  |       continue; | ||||||
|  |     } | ||||||
|     if(['[', '{'].includes(doc[key][0])){ |     if(['[', '{'].includes(doc[key][0])){ | ||||||
|       try{ |       try{ | ||||||
|         doc[key] = JSON.parse(doc[key]) |         doc[key] = JSON.parse(doc[key]) | ||||||
|  | @ -36,9 +40,11 @@ export default { | ||||||
|     index: '', |     index: '', | ||||||
|     editingKey: '', |     editingKey: '', | ||||||
|     isLoading: false, |     isLoading: false, | ||||||
|  |     resultKey: '', | ||||||
|  |     tableMode: 'JSON', | ||||||
|   }, |   }, | ||||||
|   effects: { |   effects: { | ||||||
|     *fetchDocList({payload}, {call, put}){ |     *fetchDocList({payload}, {call, put, select}){ | ||||||
|       yield put({ |       yield put({ | ||||||
|         type: 'saveData', |         type: 'saveData', | ||||||
|         payload: { |         payload: { | ||||||
|  | @ -56,6 +62,7 @@ export default { | ||||||
|         }) |         }) | ||||||
|         return |         return | ||||||
|       } |       } | ||||||
|  |       const {tableMode} = yield select(state=>state.document); | ||||||
|       res.payload = formatESSearchResult(res.payload); |       res.payload = formatESSearchResult(res.payload); | ||||||
|       let indices = []; //indices state can remove
 |       let indices = []; //indices state can remove
 | ||||||
|       if(res.payload.data && res.payload.data.length > 0){ |       if(res.payload.data && res.payload.data.length > 0){ | ||||||
|  | @ -63,9 +70,11 @@ export default { | ||||||
|           if(!indices.includes(doc._index)){ |           if(!indices.includes(doc._index)){ | ||||||
|             indices.push(doc._index); |             indices.push(doc._index); | ||||||
|           } |           } | ||||||
|  |           if(tableMode !== "JSON") { | ||||||
|             encodeObjectField(doc); |             encodeObjectField(doc); | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|  |       } | ||||||
|       yield put({ |       yield put({ | ||||||
|         type: 'saveData', |         type: 'saveData', | ||||||
|         payload: { |         payload: { | ||||||
|  | @ -74,6 +83,7 @@ export default { | ||||||
|           isLoading: false, |           isLoading: false, | ||||||
|           index: payload.index, |           index: payload.index, | ||||||
|           indices, |           indices, | ||||||
|  |           resultKey: indices[0] || '', | ||||||
|           cluster: payload.cluster || '', |           cluster: payload.cluster || '', | ||||||
|           filter: payload.filter || '', |           filter: payload.filter || '', | ||||||
|           ...res.payload, |           ...res.payload, | ||||||
|  | @ -89,9 +99,12 @@ export default { | ||||||
|       }); |       }); | ||||||
|       let doc = payload.data; |       let doc = payload.data; | ||||||
|       //let {rawData} = yield select(state => state.document);
 |       //let {rawData} = yield select(state => state.document);
 | ||||||
|  |       const {tableMode} = yield select(state=>state.document); | ||||||
|  |       if(tableMode !== 'JSON') { | ||||||
|         if (decodeObjectField(doc) === false) { |         if (decodeObjectField(doc) === false) { | ||||||
|           return; |           return; | ||||||
|         } |         } | ||||||
|  |       } | ||||||
|       let res = yield call(saveDoc, payload); |       let res = yield call(saveDoc, payload); | ||||||
|       if(res.status === false){ |       if(res.status === false){ | ||||||
|         message.warn("保存数据失败") |         message.warn("保存数据失败") | ||||||
|  | @ -105,18 +118,24 @@ export default { | ||||||
|         }) |         }) | ||||||
|         return |         return | ||||||
|       } |       } | ||||||
|  |       if(tableMode !== 'JSON') { | ||||||
|         encodeObjectField(doc); |         encodeObjectField(doc); | ||||||
|  |       } | ||||||
|  |       //console.log(payload.data);
 | ||||||
|       yield put({ |       yield put({ | ||||||
|         type: '_saveDocItem', |         type: '_saveDocItem', | ||||||
|         payload: { |         payload: { | ||||||
|           docItem: payload.data, |           docItem: payload.data, | ||||||
|  |           id: payload._id, | ||||||
|           extra: { |           extra: { | ||||||
|             editingKey: '', |             editingKey: '', | ||||||
|             isLoading: false, |             isLoading: false, | ||||||
|  |             editValue: null, | ||||||
|             _index: '' |             _index: '' | ||||||
|           } |           } | ||||||
|         }  |         }  | ||||||
|       }) |       }); | ||||||
|  |       message.success("保存数据成功"); | ||||||
|     }, |     }, | ||||||
|     *deleteDocItem({payload}, {call, put}){ |     *deleteDocItem({payload}, {call, put}){ | ||||||
|       yield put({ |       yield put({ | ||||||
|  | @ -136,30 +155,36 @@ export default { | ||||||
|       yield put({ |       yield put({ | ||||||
|         type: '_deleteDocItem', |         type: '_deleteDocItem', | ||||||
|         payload: { |         payload: { | ||||||
|           docItem: payload.data, |           id: payload._id, | ||||||
|           extra: { |           extra: { | ||||||
|             isLoading: false, |             isLoading: false, | ||||||
|           } |           } | ||||||
|         }  |         }  | ||||||
|       }) |       }) | ||||||
|  |       message.success("删除数据成功") | ||||||
|     }, |     }, | ||||||
|     *addDocItem({payload},{call, put}){ |     *addDocItem({payload},{call, put, select}) { | ||||||
|       yield put({ |       yield put({ | ||||||
|         type: 'saveData', |         type: 'saveData', | ||||||
|         payload: { |         payload: { | ||||||
|           isLoading: true, |           isLoading: true, | ||||||
|         } |         } | ||||||
|       }); |       }); | ||||||
|  |       const {tableMode} = yield select(state => state.document); | ||||||
|  |       if (tableMode !== 'JSON') { | ||||||
|         if (decodeObjectField(payload.data) === false) { |         if (decodeObjectField(payload.data) === false) { | ||||||
|           return; |           return; | ||||||
|         } |         } | ||||||
|  |       } | ||||||
|       let res = yield call(addDoc, payload); |       let res = yield call(addDoc, payload); | ||||||
|       if (res.status === false) { |       if (res.status === false) { | ||||||
|         message.warn("添加文档失败") |         message.warn("添加文档失败") | ||||||
|         return |         return | ||||||
|       } |       } | ||||||
|  |       if (tableMode !== 'JSON') { | ||||||
|         encodeObjectField(res.payload); |         encodeObjectField(res.payload); | ||||||
|       res.payload['_index'] = payload.index; |       } | ||||||
|  |       res.payload['_index'] = payload._index; | ||||||
|       res.payload['_type'] = payload._type; |       res.payload['_type'] = payload._type; | ||||||
|       yield put({ |       yield put({ | ||||||
|         type: '_addNew', |         type: '_addNew', | ||||||
|  | @ -168,9 +193,11 @@ export default { | ||||||
|           extra: { |           extra: { | ||||||
|             isLoading: false, |             isLoading: false, | ||||||
|             isAddNew: false, |             isAddNew: false, | ||||||
|  |             editValue: null, | ||||||
|           } |           } | ||||||
|         }  |         }  | ||||||
|       }) |       }); | ||||||
|  |       message.success("添加文档成功") | ||||||
|     }, |     }, | ||||||
|     *fetchIndices({payload}, {call, put}){ |     *fetchIndices({payload}, {call, put}){ | ||||||
|       let resp = yield call(getIndices) |       let resp = yield call(getIndices) | ||||||
|  | @ -209,7 +236,7 @@ export default { | ||||||
|     }, |     }, | ||||||
|     _saveDocItem(state, {payload}){ |     _saveDocItem(state, {payload}){ | ||||||
|       let idx = state.data.findIndex((item) => { |       let idx = state.data.findIndex((item) => { | ||||||
|         return item.id == payload.docItem.id; |         return item.id === payload.id; | ||||||
|       }); |       }); | ||||||
|       idx > -1 && (state.data[idx] = { |       idx > -1 && (state.data[idx] = { | ||||||
|         ...state.data[idx], |         ...state.data[idx], | ||||||
|  | @ -223,7 +250,7 @@ export default { | ||||||
|     }, |     }, | ||||||
|     _deleteDocItem(state, {payload}){  |     _deleteDocItem(state, {payload}){  | ||||||
|       let idx = state.data.findIndex((item) => { |       let idx = state.data.findIndex((item) => { | ||||||
|         return item.id == payload.docItem.id; |         return item.id === payload.id; | ||||||
|       }); |       }); | ||||||
|       state.data.splice(idx, 1); |       state.data.splice(idx, 1); | ||||||
|       return { |       return { | ||||||
|  | @ -237,16 +264,19 @@ export default { | ||||||
|     }, |     }, | ||||||
|     _addNew(state, {payload}){ |     _addNew(state, {payload}){ | ||||||
|       if(payload.extra && payload.extra.isAddNew){ |       if(payload.extra && payload.extra.isAddNew){ | ||||||
|         if(!state.data){ |         let data = state.data || []; | ||||||
|           state.data = []; |         data.unshift(payload.docItem); | ||||||
|         } |  | ||||||
|         state.data.unshift(payload.docItem) |  | ||||||
|         return { |         return { | ||||||
|           ...state, |           ...state, | ||||||
|  |           data: data, | ||||||
|           ...payload.extra, |           ...payload.extra, | ||||||
|         } |         } | ||||||
|       }else{ |       }else{ | ||||||
|  |         if(state.tableMode !=='JSON') { | ||||||
|           state.data[0] = payload.docItem; |           state.data[0] = payload.docItem; | ||||||
|  |         }else{ | ||||||
|  |           state.data.unshift(payload.docItem); | ||||||
|  |         } | ||||||
|         return { |         return { | ||||||
|           ...state, |           ...state, | ||||||
|           ...payload.extra, |           ...payload.extra, | ||||||
|  |  | ||||||
|  | @ -13,7 +13,7 @@ export async function getDocList(params) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export async function saveDoc(params) { | export async function saveDoc(params) { | ||||||
|   let url =  `${pathPrefix}/doc/${params.index}/${params.data.id}`; |   let url =  `${pathPrefix}/doc/${params._index}/${params._id}`; | ||||||
|   if(params._type){ |   if(params._type){ | ||||||
|     url += `?_type=${params._type}`; |     url += `?_type=${params._type}`; | ||||||
|   } |   } | ||||||
|  | @ -24,7 +24,7 @@ export async function saveDoc(params) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export async function deleteDoc(params) { | export async function deleteDoc(params) { | ||||||
|   let url =`${pathPrefix}/doc/${params.index}/${params.data.id}`; |   let url =`${pathPrefix}/doc/${params._index}/${params._id}`; | ||||||
|   if(params._type){ |   if(params._type){ | ||||||
|     url += `?_type=${params._type}`; |     url += `?_type=${params._type}`; | ||||||
|   } |   } | ||||||
|  | @ -34,9 +34,7 @@ export async function deleteDoc(params) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export async function addDoc(params) { | export async function addDoc(params) { | ||||||
|   let id = params.data.id || ''; |   let url = `${pathPrefix}/doc/${params._index}/_create`; | ||||||
|   delete(params.data, 'id'); |  | ||||||
|   let url = `${pathPrefix}/doc/${params.index}/_create`; |  | ||||||
|   if(params._type){ |   if(params._type){ | ||||||
|     url += `?_type=${params._type}`; |     url += `?_type=${params._type}`; | ||||||
|   } |   } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue