|  |  | @ -21,7 +21,6 @@ const tagArray = [ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', |  |  |  | 	'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', | 
			
		
	
		
		
			
				
					
					|  |  |  | 	'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' |  |  |  | 	'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' | 
			
		
	
		
		
			
				
					
					|  |  |  | ] |  |  |  | ] | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | //题库的试卷  单选题  组件
 |  |  |  | //题库的试卷  单选题  组件
 | 
			
		
	
		
		
			
				
					
					|  |  |  | class SingleEditor extends Component{ |  |  |  | class SingleEditor extends Component{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	constructor(props){ |  |  |  | 	constructor(props){ | 
			
		
	
	
		
		
			
				
					|  |  | @ -253,17 +252,14 @@ class SingleEditor extends Component{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		const reg = /^[\s\S]*.*[^\s][\s\S]*$/; |  |  |  | 		const reg = /^[\s\S]*.*[^\s][\s\S]*$/; | 
			
		
	
		
		
			
				
					
					|  |  |  | 		if (!reg.test(_text)) { |  |  |  | 		if (!reg.test(_text)) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 			// 处理编辑器内容为空
 |  |  |  | 			// 处理编辑器内容为空
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 			texts=""; |  |  |  | 			try { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 		} else { |  |  |  | 				texts= JSON.stringify(value) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 			if(_text.length>=301){ |  |  |  | 			}catch (e) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 				var result = _text.substring(0,300); |  |  |  | 				texts=""; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 				texts={"ops":[{"insert":result}]}; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				texts=JSON.stringify(texts); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 			}else { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				// 提交到后台的内容需要处理一下;
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				value =  JSON.stringify(value) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				texts=value; |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 			} |  |  |  | 			} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		} else { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			value =  JSON.stringify(value); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			texts=value; | 
			
		
	
		
		
			
				
					
					|  |  |  | 		} |  |  |  | 		} | 
			
		
	
		
		
			
				
					
					|  |  |  | 		let question_choices = this.state.question_choices.slice(0); |  |  |  | 		let question_choices = this.state.question_choices.slice(0); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		question_choices[index] = texts; |  |  |  | 		question_choices[index] = texts; | 
			
		
	
	
		
		
			
				
					|  |  | @ -291,30 +287,21 @@ class SingleEditor extends Component{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		const reg = /^[\s\S]*.*[^\s][\s\S]*$/; |  |  |  | 		const reg = /^[\s\S]*.*[^\s][\s\S]*$/; | 
			
		
	
		
		
			
				
					
					|  |  |  | 		if (!reg.test(_text)) { |  |  |  | 		if (!reg.test(_text)) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 			// 处理编辑器内容为空
 |  |  |  | 			// 处理编辑器内容为空
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 			this.setState({ |  |  |  | 		 try { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 				question_titleysl:"" |  |  |  | 			 this.setState({ | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 			}) |  |  |  | 				 question_titleysl: JSON.stringify(value) | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			 }) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		 }catch (e) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			 this.setState({ | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 				 question_titleysl:"" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			 }) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		 } | 
			
		
	
		
		
			
				
					
					|  |  |  | 		} else { |  |  |  | 		} else { | 
			
		
	
		
		
			
				
					
					|  |  |  | 			// 提交到后台的内容需要处理一下;
 |  |  |  | 				let texts =  JSON.stringify(value); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 			var texts=""; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 			if(_text.length>=1001){ |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				var result = _text.substring(0,1000); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				texts={"ops":[{"insert":result}]}; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				texts=JSON.stringify(texts); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 			}else { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				value =  JSON.stringify(value) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				texts=value; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 			} |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 			this.setState({ |  |  |  | 			this.setState({ | 
			
		
	
		
		
			
				
					
					|  |  |  | 				question_titleysl:texts |  |  |  | 				question_titleysl:texts | 
			
		
	
		
		
			
				
					
					|  |  |  | 			}) |  |  |  | 			}) | 
			
		
	
		
		
			
				
					
					|  |  |  | 			try { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				//console.log("onContentChange");
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				//console.log(quill.getText().length);
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 			}catch (e) { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 			} |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 		} |  |  |  | 		} | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
		
		
			
				
					
					|  |  |  | 	onContentChanges=(value,quill)=>{ |  |  |  | 	onContentChanges=(value,quill)=>{ | 
			
		
	
	
		
		
			
				
					|  |  | @ -322,19 +309,18 @@ class SingleEditor extends Component{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		const reg = /^[\s\S]*.*[^\s][\s\S]*$/; |  |  |  | 		const reg = /^[\s\S]*.*[^\s][\s\S]*$/; | 
			
		
	
		
		
			
				
					
					|  |  |  | 		if (!reg.test(_text)) { |  |  |  | 		if (!reg.test(_text)) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 			// 处理编辑器内容为空
 |  |  |  | 			// 处理编辑器内容为空
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 			this.setState({ |  |  |  | 			try { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 				question_titlesysl:"" |  |  |  | 				this.setState({ | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 			}) |  |  |  | 					question_titlesysl:JSON.stringify(value) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 		} else { |  |  |  | 				}) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 			var texts=""; |  |  |  | 			}catch (e) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 			if(_text.length>=1001){ |  |  |  | 				this.setState({ | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 				var result = _text.substring(0,1000); |  |  |  | 					question_titlesysl:"" | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 				texts={"ops":[{"insert":result}]}; |  |  |  | 				}) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 				texts=JSON.stringify(texts); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 			}else { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				value =  JSON.stringify(value) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 				texts=value; |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 			} |  |  |  | 			} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		} else { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			let texts =  JSON.stringify(value); | 
			
		
	
		
		
			
				
					
					|  |  |  | 			this.setState({ |  |  |  | 			this.setState({ | 
			
		
	
		
		
			
				
					
					|  |  |  | 				question_titlesysl:texts |  |  |  | 				question_titlesysl:texts | 
			
		
	
		
		
			
				
					
					|  |  |  | 			}) |  |  |  | 			}) | 
			
		
	
	
		
		
			
				
					|  |  | @ -368,6 +354,10 @@ class SingleEditor extends Component{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		// //////console.log("xuanzheshijuan");
 |  |  |  | 		// //////console.log("xuanzheshijuan");
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		// //////console.log(answerTagArray);
 |  |  |  | 		// //////console.log(answerTagArray);
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		// //////console.log(!exerciseIsPublish);
 |  |  |  | 		// //////console.log(!exerciseIsPublish);
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		const options=['code-block', 'image', 'formula',{size: ['14px', '16px', '18px', '20px']}, | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			{ 'color': ['#333333','#e60000','#ff9900','#ffff00','#ffffff']}, | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			{ 'font': ['Microsoft-YaHei','SimSun', 'SimHei','KaiTi','FangSong','Arial','Times-New-Roman','sans-serif']} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		] | 
			
		
	
		
		
			
				
					
					|  |  |  | 		return( |  |  |  | 		return( | 
			
		
	
		
		
			
				
					
					|  |  |  | 			<div className="padding20-30  signleEditor danxuano" id={qNumber}> |  |  |  | 			<div className="padding20-30  signleEditor danxuano" id={qNumber}> | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -389,6 +379,12 @@ class SingleEditor extends Component{ | 
			
		
	
		
		
			
				
					
					|  |  |  |               #e_tips_mdEditor_question_undefined4{ |  |  |  |               #e_tips_mdEditor_question_undefined4{ | 
			
		
	
		
		
			
				
					
					|  |  |  |                display: none; |  |  |  |                display: none; | 
			
		
	
		
		
			
				
					
					|  |  |  |               } |  |  |  |               } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               .signleEditor .quill_editor_for_react_area  .ql-toolbar .ql-formats .ql-size { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               line-height: 20px; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                .signleEditor .quill_editor_for_react_area  .ql-toolbar .ql-formats .ql-font { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               line-height: 20px; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               } | 
			
		
	
		
		
			
				
					
					|  |  |  |             `}</style>
 |  |  |  |             `}</style>
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 				<p className="mb10 clearfix"> |  |  |  | 				<p className="mb10 clearfix"> | 
			
		
	
		
		
			
				
					
					|  |  |  | 					{/* {!question_id ? '新建' : '编辑'} */} |  |  |  | 					{/* {!question_id ? '新建' : '编辑'} */} | 
			
		
	
	
		
		
			
				
					|  |  | @ -401,7 +397,7 @@ class SingleEditor extends Component{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 					imgAttrs={{width: '146px', height: '136px'}} |  |  |  | 					imgAttrs={{width: '146px', height: '136px'}} | 
			
		
	
		
		
			
				
					
					|  |  |  | 					style={{ height: '155px'}} |  |  |  | 					style={{ height: '155px'}} | 
			
		
	
		
		
			
				
					
					|  |  |  | 					placeholder="请您输入题干" |  |  |  | 					placeholder="请您输入题干" | 
			
		
	
		
		
			
				
					
					|  |  |  | 					options={['code-block', 'image', 'formula']} |  |  |  | 					options={options} | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 					value={question_title} |  |  |  | 					value={question_title} | 
			
		
	
		
		
			
				
					
					|  |  |  | 					onContentChange={this.onContentChange} |  |  |  | 					onContentChange={this.onContentChange} | 
			
		
	
		
		
			
				
					
					|  |  |  | 				/> |  |  |  | 				/> | 
			
		
	
	
		
		
			
				
					|  |  | @ -433,7 +429,7 @@ class SingleEditor extends Component{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 										imgAttrs={{width: '146px', height: '136px'}} |  |  |  | 										imgAttrs={{width: '146px', height: '136px'}} | 
			
		
	
		
		
			
				
					
					|  |  |  | 										style={{ height: '166px'}} |  |  |  | 										style={{ height: '166px'}} | 
			
		
	
		
		
			
				
					
					|  |  |  | 										placeholder="请您输入题干" |  |  |  | 										placeholder="请您输入题干" | 
			
		
	
		
		
			
				
					
					|  |  |  | 										options={['code-block', 'image', 'formula']} |  |  |  | 										options={options} | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 										value={item} |  |  |  | 										value={item} | 
			
		
	
		
		
			
				
					
					|  |  |  | 										onContentChange={(value,quill) => this.onOptionContentChange(value,quill,index)} |  |  |  | 										onContentChange={(value,quill) => this.onOptionContentChange(value,quill,index)} | 
			
		
	
		
		
			
				
					
					|  |  |  | 									/> |  |  |  | 									/> | 
			
		
	
	
		
		
			
				
					|  |  | @ -443,7 +439,7 @@ class SingleEditor extends Component{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 										imgAttrs={{width: '146px', height: '136px'}} |  |  |  | 										imgAttrs={{width: '146px', height: '136px'}} | 
			
		
	
		
		
			
				
					
					|  |  |  | 										style={{ height: '166px'}} |  |  |  | 										style={{ height: '166px'}} | 
			
		
	
		
		
			
				
					
					|  |  |  | 										placeholder="请您输入题干" |  |  |  | 										placeholder="请您输入题干" | 
			
		
	
		
		
			
				
					
					|  |  |  | 										options={['code-block', 'image', 'formula']} |  |  |  | 										options={options} | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 										value={JSON.parse(item)} |  |  |  | 										value={JSON.parse(item)} | 
			
		
	
		
		
			
				
					
					|  |  |  | 										onContentChange={(value,quill) => this.onOptionContentChange(value,quill,index)} |  |  |  | 										onContentChange={(value,quill) => this.onOptionContentChange(value,quill,index)} | 
			
		
	
		
		
			
				
					
					|  |  |  | 									/> |  |  |  | 									/> | 
			
		
	
	
		
		
			
				
					|  |  | @ -484,7 +480,7 @@ class SingleEditor extends Component{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 						imgAttrs={{width: '146px', height: '136px'}} |  |  |  | 						imgAttrs={{width: '146px', height: '136px'}} | 
			
		
	
		
		
			
				
					
					|  |  |  | 						style={{height: '166px' }} |  |  |  | 						style={{height: '166px' }} | 
			
		
	
		
		
			
				
					
					|  |  |  | 						placeholder="请您输入题目解析" |  |  |  | 						placeholder="请您输入题目解析" | 
			
		
	
		
		
			
				
					
					|  |  |  | 						options={['code-block', 'image', 'formula']} |  |  |  | 						options={options} | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 						value={question_titles} |  |  |  | 						value={question_titles} | 
			
		
	
		
		
			
				
					
					|  |  |  | 						onContentChange={this.onContentChanges} |  |  |  | 						onContentChange={this.onContentChanges} | 
			
		
	
		
		
			
				
					
					|  |  |  | 					/> |  |  |  | 					/> | 
			
		
	
	
		
		
			
				
					|  |  | 
 |