@qxs-bns/components-wc 0.0.24 → 0.0.26
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/subject/blank-fill.mjs +88 -34
- package/es/subject/blank-fill.mjs.map +1 -1
- package/es/subject/list.mjs +27 -35
- package/es/subject/list.mjs.map +1 -1
- package/es/subject/scale.mjs +77 -67
- package/es/subject/scale.mjs.map +1 -1
- package/es/subject/single.mjs +38 -64
- package/es/subject/single.mjs.map +1 -1
- package/es/subject/text-fill.mjs +121 -104
- package/es/subject/text-fill.mjs.map +1 -1
- package/lib/subject/blank-fill.cjs +89 -35
- package/lib/subject/blank-fill.cjs.map +1 -1
- package/lib/subject/list.cjs +25 -33
- package/lib/subject/list.cjs.map +1 -1
- package/lib/subject/scale.cjs +74 -64
- package/lib/subject/scale.cjs.map +1 -1
- package/lib/subject/single.cjs +39 -65
- package/lib/subject/single.cjs.map +1 -1
- package/lib/subject/text-fill.cjs +94 -77
- package/lib/subject/text-fill.cjs.map +1 -1
- package/package.json +1 -1
package/lib/subject/single.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";var e=require("lit"),t=require("lit/decorators.js"),s=require("../base/define.cjs"),i=require("../base/uid.cjs"),r=Object.defineProperty,o=Object.getOwnPropertyDescriptor,a=(e,t,s,i)=>{for(var a,n=i>1?void 0:i?o(t,s):t,l=e.length-1;l>=0;l--)(a=e[l])&&(n=(i?a(t,s,n):a(n))||n);return i&&n&&r(t,s,n),n};class n extends Error{constructor(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"VALIDATION_ERROR",s=arguments.length>2?arguments[2]:void 0,i=arguments.length>3?arguments[3]:void 0;super(e),this.code=t,this.field=s,this.row=i,this.name="SubjectError"}static from(e){return new n(e.message,e.code,e.field,e.row)}}const l=e.html`<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><line x1="12" y1="5" x2="12" y2="19"/><line x1="5" y1="12" x2="19" y2="12"/></svg>`,c=e.html`<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><line x1="5" y1="12" x2="19" y2="12"/></svg>`,h=e.html`<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><polyline points="6 9 12 15 18 9"/></svg>`;function p(e){return e.replace(/^\d+\.\s*/,"").replace(/[\s,,。.!!??;;::、'"“”‘’()()[\]【】\-_/\\]+/g,"").toLowerCase()}function d(e){const t=document.createElement("div");t.textContent=e,Object.assign(t.style,{position:"fixed",top:"20px",left:"50%",transform:"translateX(-50%)",padding:"10px 20px",borderRadius:"4px",fontSize:"13px",color:"#fff",background:"#f56c6c",zIndex:"99999",boxShadow:"0 4px 12px rgba(0,0,0,.15)",transition:"opacity .3s",opacity:"1"}),document.body.appendChild(t),setTimeout(()=>{t.style.opacity="0",setTimeout(()=>t.remove(),300)},2500)}exports.QxsSubjectSingle=class extends e.LitElement{constructor(){super(...arguments),this["order-index"]=0,this["is-edit"]=!1,this["is-save"]=!1,this["is-set"]=!1,this["is-key"]=!1,this["show-action"]=!0,this["show-add"]=!0,this["show-answer-setting"]=!1,this["show-key"]=!1,this["show-analysis"]=!0,this.type="single",this["answer-check-type"]=1,this["exam-answer-relation-type"]=0,this["rich-text-content"]="",this.analysis="",this["least-answer-count"]=0,this["exam-expand"]="",this["custom-id"]="",this["exam-id"]=0,this["category-id"]="",this["upload-image"]=async e=>new Promise((t,s)=>{const i=new FileReader;i.onload=e=>t(e.target?.result),i.onerror=s,i.readAsDataURL(e)}),this["tag-list"]=[],this["category-list"]=[],this["ai-answer"]="",this["resource-list"]=[],this["show-tag"]=!1,this["show-category"]=!1,this["show-ai"]=!1,this["show-resource"]=!1,this["show-jump"]=!1,this["has-jump"]=!1,this["search-api"]="",this["model-value"]="",this["use-model"]=!1,this._answers=[{title:"",isCorrect:!1},{title:"",isCorrect:!1},{title:"",isCorrect:!1},{title:"",isCorrect:!1}],this.title="",this._title="",this._analysis="",this._richText="",this._showRichText=!1,this._leastAnswerCount=0,this._answerCheckType=1,this._isKey=!1,this._orderList=[],this._selectedTagList=[],this._categoryId="",this._searchResults=[],this._searchOpen=!1,this._searchLoading=!1,this._resultDialogOpen=!1,this._resultDialogIndex=0,this._resultDialogValue="",this._sortDropdownOpen=!1,this._imageViewerOpen=!1,this._imageViewerIndex=0,this._videoViewerOpen=!1,this._correctHintDialogOpen=!1,this._hasShownCorrectHint=!1,this._searchTimer=null,this._searchToken=0,this.TITLE_MAX=200,this.ANSWER_MAX=100,this._handleDocumentClick=e=>{const t=e.composedPath(),s=this.shadowRoot?.querySelector(".multi-select-wrapper"),i=this.shadowRoot?.querySelector(".search-wrap");s&&!t.includes(s)&&(this._sortDropdownOpen=!1),i&&!t.includes(i)&&(this._searchOpen=!1),this.requestUpdate()}}get"answer-list"(){return this._answers}set"answer-list"(e){if(this["is-edit"])return;const t=Array.isArray(e)?e:[];this._answers=t.length?t.map(e=>({...e})):[{title:"",isCorrect:!1},{title:"",isCorrect:!1},{title:"",isCorrect:!1},{title:"",isCorrect:!1}],this.requestUpdate("answer-list")}connectedCallback(){super.connectedCallback(),document.addEventListener("click",this._handleDocumentClick),this._syncExternalProps()}firstUpdated(){this._syncExternalProps()}disconnectedCallback(){super.disconnectedCallback(),document.removeEventListener("click",this._handleDocumentClick),this._searchTimer&&(window.clearTimeout(this._searchTimer),this._searchTimer=null)}willUpdate(e){e.has("is-edit")&&this["is-edit"]&&this._syncProps(),!this["is-edit"]&&(e.has("title")||e.has("answer-list")||e.has("analysis")||e.has("least-answer-count")||e.has("answer-check-type")||e.has("tag-list")||e.has("category-id")||e.has("rich-text-content"))&&this._syncExternalProps(),e.has("is-key")&&(this._isKey=this["is-key"]),e.has("tag-list")&&(this._selectedTagList=Array.isArray(this["tag-list"])?this["tag-list"].map(e=>({...e})):[]),e.has("category-id")&&(this._categoryId=this["category-id"]?String(this["category-id"]):""),(e.has("exam-expand")||e.has("answer-list"))&&this._syncExamExpand(),e.has("model-value")&&this["use-model"]&&(this._title=this["model-value"])}_syncExternalProps(){this._title=this.title||"",this._analysis=this.analysis||"",this._leastAnswerCount=Number(this["least-answer-count"])||0,this._answerCheckType=this["answer-check-type"]||1,this._isKey=this["is-key"],this._selectedTagList=Array.isArray(this["tag-list"])?this["tag-list"].map(e=>({...e})):[],this._categoryId=this["category-id"]?String(this["category-id"]):"",this._richText=this["rich-text-content"]||"",this._showRichText=!!this["rich-text-content"],this["answer-list"]?.length&&(this._answers=this["answer-list"].map(e=>({...e,title:e.title||"",isCorrect:!!e.isCorrect})))}_syncProps(){this._title=this.title||"",this._analysis=this.analysis||"",this._leastAnswerCount=Number(this["least-answer-count"])||0,this._answerCheckType=this["answer-check-type"]||1,this._isKey=this["is-key"],this._selectedTagList=Array.isArray(this["tag-list"])?this["tag-list"].map(e=>({...e})):[],this._categoryId=this["category-id"]?String(this["category-id"]):"",this._richText=this["rich-text-content"]||"",this._showRichText=!!this["rich-text-content"],this["answer-list"]?.length&&(this._answers=this["answer-list"].map(e=>({...e,title:e.title||"",isCorrect:!!e.isCorrect}))),this._syncExamExpand()}_syncExamExpand(){if(!this["exam-expand"]||!this["answer-list"]?.length)return;const e=this["exam-expand"].split(","),t=this["answer-list"];this._orderList=e.map(e=>{const s=t.findIndex((t,s)=>String(t.answerId??t.orderIndex??s+1)===String(e));return s>=0?this._label(s):""}).filter(Boolean)}_emit(e,t){this.dispatchEvent(new CustomEvent(e,{bubbles:!0,composed:!0,detail:t??null}))}_searchAnswerType(){return"single"===this.type?0:"multiple"===this.type?1:5}_queueSearch(e){this._searchTimer&&(window.clearTimeout(this._searchTimer),this._searchTimer=null);const t=e.trim();if(!t||!this["search-api"]&&"function"!=typeof this["search-handler"])return this._searchResults=[],this._searchOpen=!1,void(this._searchLoading=!1);this._searchTimer=window.setTimeout(()=>{this._runSearch(t)},300)}async _runSearch(e){const t=++this._searchToken;this._searchLoading=!0,this._searchOpen=!0,this.requestUpdate();try{let s=[];if("function"==typeof this["search-handler"])s=await this["search-handler"](e,this._searchAnswerType());else if(this["search-api"]){const t=new URLSearchParams({searchKey:e,answerType:String(this._searchAnswerType())}),i=await fetch(`${this["search-api"]}${this["search-api"].includes("?")?"&":"?"}${t.toString()}`);if(!i.ok)throw new Error(`HTTP ${i.status}`);const r=await i.json();s=(Array.isArray(r)?r:Array.isArray(r?.data)?r.data:[]).map(e=>({...e,value:e?.value||e?.title||""}))}if(t!==this._searchToken)return;this._searchResults=Array.isArray(s)?s:[]}catch(e){if(t!==this._searchToken)return;this._searchResults=[],d(e?.message||"题库搜索失败")}finally{t===this._searchToken&&(this._searchLoading=!1,this.requestUpdate())}}_selectSearchResult(e){const t=e.value||e.title||"";this._title=t,this._searchResults=[],this._searchOpen=!1,this["use-model"]&&this.dispatchEvent(new CustomEvent("update:modelValue",{bubbles:!0,composed:!0,detail:this._title})),this._emit("title-select",{...e,id:e.id??e.examId??e.questionId,title:e.title||t,value:t,customId:this["custom-id"]||""})}_applyAiAnswer(){if(!this["ai-answer"]?.trim())return void d("暂无 AI 推荐答案");const e=this["ai-answer"].split(/\r?\n/).map(e=>p(e)).filter(Boolean);let t=0;if("single"===this.type){let s=!1;this._answers=this._answers.map(i=>{const r=!s&&e.includes(p(i.title||""));return r&&(s=!0,t++),{...i,isCorrect:r}})}else this._answers=this._answers.map(s=>{const i=e.includes(p(s.title||""));return i&&t++,{...s,isCorrect:i}});t?this.requestUpdate():d("未找到匹配的选项,请检查选项内容是否一致")}_removeTag(e){this._selectedTagList=this._selectedTagList.filter(t=>String(t.tagId)!==String(e)),this._emit("tag-change",{value:this._selectedTagList,customId:this["custom-id"]||"",examId:this["exam-id"]||0})}_chooseTag(){this._emit("choose-tag",{value:this._selectedTagList,customId:this["custom-id"]||"",examId:this["exam-id"]||0})}_onCategoryChange(e){this._categoryId=e,this._emit("category-change",{value:e,customId:this["custom-id"]||"",examId:this["exam-id"]||0})}_setRelation(e,t){const s=e.customAnswerId?{...e}:{...e,customAnswerId:e.answerId||i.uid()};this._answers=this._answers.map((e,i)=>i===t?s:e),this.requestUpdate(),this._emit("set-relation",{customId:this["custom-id"]||"",examId:this["exam-id"]||0,answerIndex:t,answer:s})}_relationLength(){return(arguments.length>0&&void 0!==arguments[0]?arguments[0]:[]).reduce((e,t)=>e+(Array.isArray(t?.relationAnswers)?t.relationAnswers.length:0),0)}_imageResources(){return(this["resource-list"]||[]).filter(e=>1===e.resourceType).map(e=>e.resource.middle||e.resource.url).filter(Boolean)}_videoResource(){return(this["resource-list"]||[]).find(e=>2===e.resourceType)?.resource||null}_openImageViewer(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;this._imageResources().length&&(this._imageViewerIndex=e,this._imageViewerOpen=!0)}_closeImageViewer(){this._imageViewerOpen=!1}_moveImage(e){const t=this._imageResources();t.length&&(this._imageViewerIndex=(this._imageViewerIndex+e+t.length)%t.length)}_openVideoViewer(){this._videoResource()?.url&&(this._videoViewerOpen=!0)}_closeVideoViewer(){this._videoViewerOpen=!1}_label(e){return String.fromCharCode(65+e)}get _titlePlaceholder(){return"single"===this.type?"单选题":"multiple"===this.type?"多选题":"排序题"}_setCorrect(e,t){"single"===this.type?(this._answers.forEach(e=>{e.isCorrect=!1}),e.isCorrect=t):e.isCorrect=t,this.requestUpdate()}_onTitleInput(e){const t=e.target;t.value.length>this.TITLE_MAX&&(t.value=t.value.slice(0,this.TITLE_MAX)),this._title=t.value,this._queueSearch(this._title),this["use-model"]&&this.dispatchEvent(new CustomEvent("update:modelValue",{bubbles:!0,composed:!0,detail:this._title}))}_onAnswerInput(e,t){const s=e.target;s.value.length>this.ANSWER_MAX&&(s.value=s.value.slice(0,this.ANSWER_MAX)),this._answers[t].title=s.value,this.requestUpdate()}_addAnswer(e){if(this["is-save"])return;const t=[...this._answers];t.splice(e+1,0,{title:"",isCorrect:!1,customAnswerId:i.uid()}),this._answers=t}_deleteAnswer(e){this._answers.length<3||this["is-save"]||(this._answers=this._answers.filter((t,s)=>s!==e))}_toggleSortItem(e){const t=this._orderList.indexOf(e);this._orderList=t>=0?this._orderList.filter(t=>t!==e):[...this._orderList,e],this.requestUpdate()}_removeSortItem(e){this._orderList=this._orderList.filter(t=>t!==e),this.requestUpdate()}_getSortOrder(e){const t=this._orderList.indexOf(this._label(e));return t>=0?t+1:null}_sortAnswerValue(e){const t=e.charCodeAt(0)-65,s=this._answers[t];return s?.answerId??t+1}_shouldShowCorrectHint(){return"sort"===this.type?!this._orderList.length:!this._answers.some(e=>!!e.isCorrect)}async toJSON(){return new Promise((e,t)=>{const s={customId:this["custom-id"]||void 0,answerType:this.type,orderIndex:this["order-index"]},i=this["is-edit"]?this._title:this.title||"",r=this["is-edit"]?this._answers:this["answer-list"]||[],o=this["is-edit"]?this._answerCheckType:this["answer-check-type"]||1,a=this["is-edit"]?this._leastAnswerCount:Number(this["least-answer-count"])||0,l=this["is-edit"]?this._analysis:this.analysis||"",c=this._selectedTagList||[],h=this["is-edit"]?this._orderList.map(e=>this._sortAnswerValue(e)).join(","):this["exam-expand"]||"",p=this["is-edit"]?this._showRichText:!!this["rich-text-content"],d=this["is-edit"]?this._richText:this["rich-text-content"]||"",u=this["is-edit"]?this._orderList:(()=>{const e=this["exam-expand"];return e?e.split(",").map(e=>{const t=this["answer-list"]?.findIndex((t,s)=>String(t.answerId??t.orderIndex??s+1)===String(e));return t>=0?this._label(t):""}).filter(Boolean):[]})();if(!i)return void t(new n("题目标题不能为空!","EMPTY_TITLE","title",s));if(this["show-tag"]&&0===c.length)return void t(new n("请选择标签/关键信息","EMPTY_TAGS","tagList",s));if(!o)return void t(new n("请选择答题设置","NO_ANSWER_CHECK_TYPE","answerCheckType",s));let g="",x=!1,m=0;if("multiple"===this.type||"single"===this.type)r.forEach((e,t)=>{e.title?.trim()||(g+=`选项${String.fromCharCode(65+t)}未填写。`),e.isCorrect&&(x=!0,m++)});else if("sort"===this.type&&(u.length&&(x=!0),x&&u.length<a))return void t(new n(`排序题至少需要设置${a}项排序答案`,"SORT_COUNT_INVALID","orderList",s));if(g)return void t(new n(g,"ANSWER_EMPTY","answers",s));if(new Set(r.map(e=>e.title)).size!==r.length)return void t(new n("选项不能重复","DUPLICATE_ANSWERS","answers",s));if("multiple"===this.type){if(1===m)return void t(new n("请至少设置两个支持选项","CORRECT_COUNT_INVALID","answers",s));if(x&&m<a)return void t(new n("至少选几项与支持选项数不符","LEAST_ANSWER_COUNT_INVALID","answers",s))}if((2===o||3===o)&&!x)return void t(new n("请设置支持选项","NO_CORRECT_ANSWER","answers",s));const w={answerType:String(this.type),title:i,answers:r.filter(e=>e.title).map((e,t)=>({...e,orderIndex:t+1})),examExpand:h,analysis:l,isSetCorrectAnswer:x,leastAnswerCount:a||"",examRichTextContent:p?d:"",examAnswerRelationType:this["exam-answer-relation-type"],isKey:this._isKey,answerCheckType:o,categoryId:this._categoryId||"",memberTagInfo:c,tagInfos:c,aiAnswer:this["ai-answer"]||"",resourceList:this["resource-list"]||[],examResourceBOList:this["resource-list"]||[]};this["custom-id"]&&(w.customId=this["custom-id"]),e(w)})}validate(){const e=[],t={customId:this["custom-id"]||void 0,answerType:this.type,orderIndex:this["order-index"]},s=this["is-edit"]?this._title:this.title||"",i=this["is-edit"]?this._answers:this["answer-list"]||[],r=this["is-edit"]?this._answerCheckType:this["answer-check-type"]||1,o=this["is-edit"]?this._leastAnswerCount:Number(this["least-answer-count"])||0,a=this._selectedTagList||[],l=this["is-edit"]?this._orderList:(()=>{const e=this["exam-expand"];return e?e.split(",").map(e=>{const t=this["answer-list"]?.findIndex((t,s)=>String(t.answerId??t.orderIndex??s+1)===String(e));return t>=0?this._label(t):""}).filter(Boolean):[]})();s||e.push(new n("题目标题不能为空!","EMPTY_TITLE","title",t)),this["show-tag"]&&0===a.length&&e.push(new n("请选择标签/关键信息","EMPTY_TAGS","tagList",t)),r||e.push(new n("请选择答题设置","NO_ANSWER_CHECK_TYPE","answerCheckType",t));let c=!1,h=0;"multiple"===this.type||"single"===this.type?i.forEach((s,i)=>{s.title?.trim()||e.push(new n(`选项${String.fromCharCode(65+i)}未填写`,"ANSWER_EMPTY","answers",t)),s.isCorrect&&(c=!0,h++)}):"sort"===this.type&&(l.length&&(c=!0),c&&l.length<o&&e.push(new n(`排序题至少需要设置${o}项排序答案`,"SORT_COUNT_INVALID","orderList",t)));return new Set(i.map(e=>e.title)).size!==i.length&&i.length>0&&e.push(new n("选项不能重复","DUPLICATE_ANSWERS","answers",t)),"multiple"===this.type&&(1===h&&i.length>0&&e.push(new n("请至少设置两个支持选项","CORRECT_COUNT_INVALID","answers",t)),c&&h<o&&e.push(new n("至少选几项与支持选项数不符","LEAST_ANSWER_COUNT_INVALID","answers",t))),2!==r&&3!==r||c||e.push(new n("请设置支持选项","NO_CORRECT_ANSWER","answers",t)),e}_openResultDialog(e){this._resultDialogIndex=e,this._resultDialogValue=this._answers[e].resultItem||"",this._resultDialogOpen=!0}_saveResultDialog(){this._answers[this._resultDialogIndex].resultItem=this._resultDialogValue,this._resultDialogOpen=!1,this.requestUpdate()}_renderCorrectHintDialog(){return this._correctHintDialogOpen?e.html`
|
|
1
|
+
"use strict";var e=require("lit"),t=require("lit/decorators.js"),s=require("../base/define.cjs"),i=require("../base/uid.cjs"),r=Object.defineProperty,o=Object.getOwnPropertyDescriptor,a=(e,t,s,i)=>{for(var a,n=i>1?void 0:i?o(t,s):t,l=e.length-1;l>=0;l--)(a=e[l])&&(n=(i?a(t,s,n):a(n))||n);return i&&n&&r(t,s,n),n};class n extends Error{constructor(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"VALIDATION_ERROR",s=arguments.length>2?arguments[2]:void 0,i=arguments.length>3?arguments[3]:void 0;super(e),this.code=t,this.field=s,this.row=i,this.name="SubjectError"}static from(e){return new n(e.message,e.code,e.field,e.row)}}const l=e.html`<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><line x1="12" y1="5" x2="12" y2="19"/><line x1="5" y1="12" x2="19" y2="12"/></svg>`,c=e.html`<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><line x1="5" y1="12" x2="19" y2="12"/></svg>`,p=e.html`<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><polyline points="6 9 12 15 18 9"/></svg>`;function h(e){return e.replace(/^\d+\.\s*/,"").replace(/[\s,,。.!!??;;::、'"“”‘’()()[\]【】\-_/\\]+/g,"").toLowerCase()}function d(e){const t=document.createElement("div");t.textContent=e,Object.assign(t.style,{position:"fixed",top:"20px",left:"50%",transform:"translateX(-50%)",padding:"10px 20px",borderRadius:"4px",fontSize:"13px",color:"#fff",background:"#f56c6c",zIndex:"99999",boxShadow:"0 4px 12px rgba(0,0,0,.15)",transition:"opacity .3s",opacity:"1"}),document.body.appendChild(t),setTimeout(()=>{t.style.opacity="0",setTimeout(()=>t.remove(),300)},2500)}exports.QxsSubjectSingle=class extends e.LitElement{constructor(){super(...arguments),this["order-index"]=0,this["is-edit"]=!1,this["is-save"]=!1,this["is-set"]=!1,this["is-set-correct-answer"]=!1,this.lockAnswerKey=!1,this["is-key"]=!1,this["show-action"]=!0,this["show-add"]=!0,this["show-answer-setting"]=!1,this["show-key"]=!1,this["show-analysis"]=!0,this.type="single",this["answer-check-type"]=1,this["exam-answer-relation-type"]=0,this["rich-text-content"]="",this.analysis="",this["least-answer-count"]=null,this["exam-expand"]="",this["custom-id"]="",this["exam-id"]=0,this["category-id"]="",this["upload-image"]=async e=>new Promise((t,s)=>{const i=new FileReader;i.onload=e=>t(e.target?.result),i.onerror=s,i.readAsDataURL(e)}),this["tag-list"]=[],this["category-list"]=[],this["ai-answer"]="",this["resource-list"]=[],this["show-tag"]=!1,this["show-category"]=!1,this["show-ai"]=!1,this["show-resource"]=!1,this["show-jump"]=!1,this["has-jump"]=!1,this["search-api"]="",this["model-value"]="",this["use-model"]=!1,this._answers=[{title:"",isCorrect:!1},{title:"",isCorrect:!1},{title:"",isCorrect:!1},{title:"",isCorrect:!1}],this.title="",this._title="",this._analysis="",this._richText="",this._showRichText=!1,this._leastAnswerCount=null,this._answerCheckType=1,this._isKey=!1,this._orderList=[],this._selectedTagList=[],this._categoryId="",this._searchResults=[],this._searchOpen=!1,this._searchLoading=!1,this._resultDialogOpen=!1,this._resultDialogIndex=0,this._resultDialogValue="",this._sortDropdownOpen=!1,this._imageViewerOpen=!1,this._imageViewerIndex=0,this._videoViewerOpen=!1,this._correctHintDialogOpen=!1,this._hasShownCorrectHint=!1,this._changeTypeDialogOpen=!1,this._searchTimer=null,this._searchToken=0,this.TITLE_MAX=200,this.ANSWER_MAX=100,this._handleDocumentClick=e=>{const t=e.composedPath(),s=this.shadowRoot?.querySelector(".multi-select-wrapper"),i=this.shadowRoot?.querySelector(".search-wrap");s&&!t.includes(s)&&(this._sortDropdownOpen=!1),i&&!t.includes(i)&&(this._searchOpen=!1),this.requestUpdate()}}get"answer-list"(){return this._answers}set"answer-list"(e){if(this["is-edit"])return;const t=Array.isArray(e)?e:[];this._answers=t.length?t.map(e=>this._normalizeAnswerItem(e)):[{title:"",isCorrect:!1},{title:"",isCorrect:!1},{title:"",isCorrect:!1},{title:"",isCorrect:!1}],this.requestUpdate("answer-list")}connectedCallback(){super.connectedCallback(),document.addEventListener("click",this._handleDocumentClick),this._syncExternalProps()}firstUpdated(){this._syncExternalProps()}disconnectedCallback(){super.disconnectedCallback(),document.removeEventListener("click",this._handleDocumentClick),this._searchTimer&&(window.clearTimeout(this._searchTimer),this._searchTimer=null)}willUpdate(e){e.has("is-edit")&&this["is-edit"]&&this._syncProps(),!this["is-edit"]&&(e.has("title")||e.has("answer-list")||e.has("analysis")||e.has("least-answer-count")||e.has("answer-check-type")||e.has("tag-list")||e.has("category-id")||e.has("rich-text-content"))&&this._syncExternalProps(),e.has("is-key")&&(this._isKey=this["is-key"]),e.has("tag-list")&&(this._selectedTagList=Array.isArray(this["tag-list"])?this["tag-list"].map(e=>({...e})):[]),e.has("category-id")&&(this._categoryId=this["category-id"]?String(this["category-id"]):""),(e.has("exam-expand")||e.has("answer-list"))&&this._syncExamExpand(),e.has("model-value")&&this["use-model"]&&(this._title=this["model-value"])}_supportsLeastAnswerCount(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.type;return"multiple"===e||"sort"===e}_normalizeLeastAnswerCount(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.type;if(!this._supportsLeastAnswerCount(t)||""===e||null==e)return null;const s=Number(e);return Number.isFinite(s)&&s>0?s:null}_leastAnswerCountSuffix(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.type;return this._supportsLeastAnswerCount(t)&&null!==e?`,至少选${e}项${"sort"===t?"并排序":""}`:""}_normalizeAnswerItem(e){const t={...e,title:String(e?.title??e?.answer??""),isCorrect:!!e?.isCorrect},s=e?.answerId??e?.examAnswerId;return void 0!==s&&(t.answerId=s),t}_syncExternalProps(){this._title=this.title||"",this._analysis=this.analysis||"",this._leastAnswerCount=this._normalizeLeastAnswerCount(this["least-answer-count"]),this._answerCheckType=this["answer-check-type"]||1,this._isKey=this["is-key"],this._selectedTagList=Array.isArray(this["tag-list"])?this["tag-list"].map(e=>({...e})):[],this._categoryId=this["category-id"]?String(this["category-id"]):"",this._richText=this["rich-text-content"]||"",this._showRichText=!!this["rich-text-content"],this["answer-list"]?.length&&(this._answers=this["answer-list"].map(e=>this._normalizeAnswerItem(e)))}_syncProps(){this._title=this.title||"",this._analysis=this.analysis||"",this._leastAnswerCount=this._normalizeLeastAnswerCount(this["least-answer-count"]),this._answerCheckType=this["answer-check-type"]||1,this._isKey=this["is-key"],this._selectedTagList=Array.isArray(this["tag-list"])?this["tag-list"].map(e=>({...e})):[],this._categoryId=this["category-id"]?String(this["category-id"]):"",this._richText=this["rich-text-content"]||"",this._showRichText=!!this["rich-text-content"],this["answer-list"]?.length&&(this._answers=this["answer-list"].map(e=>this._normalizeAnswerItem(e))),this._syncExamExpand()}_syncExamExpand(){if(!this["exam-expand"]||!this["answer-list"]?.length)return;const e=this["exam-expand"].split(","),t=this["answer-list"];this._orderList=e.map(e=>{const s=t.findIndex((t,s)=>String(t.answerId??t.orderIndex??s+1)===String(e));return s>=0?this._label(s):""}).filter(Boolean)}_emit(e,t){this.dispatchEvent(new CustomEvent(e,{bubbles:!0,composed:!0,detail:t??null}))}_searchAnswerType(){return"single"===this.type?0:"multiple"===this.type?1:5}_queueSearch(e){this._searchTimer&&(window.clearTimeout(this._searchTimer),this._searchTimer=null);const t=e.trim();if(!t||!this["search-api"]&&"function"!=typeof this["search-handler"])return this._searchResults=[],this._searchOpen=!1,void(this._searchLoading=!1);this._searchTimer=window.setTimeout(()=>{this._runSearch(t)},300)}async _runSearch(e){const t=++this._searchToken;this._searchLoading=!0,this._searchOpen=!0,this.requestUpdate();try{let s=[];if("function"==typeof this["search-handler"])s=await this["search-handler"](e,this._searchAnswerType());else if(this["search-api"]){const t=new URLSearchParams({searchKey:e,answerType:String(this._searchAnswerType())}),i=await fetch(`${this["search-api"]}${this["search-api"].includes("?")?"&":"?"}${t.toString()}`);if(!i.ok)throw new Error(`HTTP ${i.status}`);const r=await i.json();s=(Array.isArray(r)?r:Array.isArray(r?.data)?r.data:[]).map(e=>({...e,value:e?.value||e?.title||""}))}if(t!==this._searchToken)return;this._searchResults=Array.isArray(s)?s:[]}catch(e){if(t!==this._searchToken)return;this._searchResults=[],d(e?.message||"题库搜索失败")}finally{t===this._searchToken&&(this._searchLoading=!1,this.requestUpdate())}}_selectSearchResult(e){const t=e.value||e.title||"";this._title=t,this._searchResults=[],this._searchOpen=!1,this["use-model"]&&this.dispatchEvent(new CustomEvent("update:modelValue",{bubbles:!0,composed:!0,detail:this._title})),this._emit("title-select",{...e,id:e.id??e.examId??e.questionId,title:e.title||t,value:t,customId:this["custom-id"]||""})}_applyAiAnswer(){if(!this["ai-answer"]?.trim())return void d("暂无 AI 推荐答案");const e=this["ai-answer"].split(/\r?\n/).map(e=>h(e)).filter(Boolean);let t=0;if("single"===this.type){let s=!1;this._answers=this._answers.map(i=>{const r=!s&&e.includes(h(i.title||""));return r&&(s=!0,t++),{...i,isCorrect:r}})}else this._answers=this._answers.map(s=>{const i=e.includes(h(s.title||""));return i&&t++,{...s,isCorrect:i}});t?this.requestUpdate():d("未找到匹配的选项,请检查选项内容是否一致")}_onCategoryChange(e){this._categoryId=e,this._emit("category-change",{value:e,customId:this["custom-id"]||"",examId:this["exam-id"]||0})}_setRelation(e,t){const s=e.customAnswerId?{...e}:{...e,customAnswerId:e.answerId||i.uid()};this._answers=this._answers.map((e,i)=>i===t?s:e),this.requestUpdate(),this._emit("set-relation",{customId:this["custom-id"]||"",examId:this["exam-id"]||0,answerIndex:t,answer:s})}_relationLength(){return(arguments.length>0&&void 0!==arguments[0]?arguments[0]:[]).reduce((e,t)=>e+(Array.isArray(t?.relationAnswers)?t.relationAnswers.length:0),0)}_imageResources(){return(this["resource-list"]||[]).filter(e=>1===e.resourceType).map(e=>e.resource.middle||e.resource.url).filter(Boolean)}_videoResource(){return(this["resource-list"]||[]).find(e=>2===e.resourceType)?.resource||null}_openImageViewer(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;this._imageResources().length&&(this._imageViewerIndex=e,this._imageViewerOpen=!0)}_closeImageViewer(){this._imageViewerOpen=!1}_moveImage(e){const t=this._imageResources();t.length&&(this._imageViewerIndex=(this._imageViewerIndex+e+t.length)%t.length)}_openVideoViewer(){this._videoResource()?.url&&(this._videoViewerOpen=!0)}_closeVideoViewer(){this._videoViewerOpen=!1}_label(e){return String.fromCharCode(65+e)}get _titlePlaceholder(){return"single"===this.type?"单选题":"multiple"===this.type?"多选题":"排序题"}_setCorrect(e,t){this.lockAnswerKey||(e.isCorrect=t,this.requestUpdate())}_onTitleInput(e){const t=e.target;t.value.length>this.TITLE_MAX&&(t.value=t.value.slice(0,this.TITLE_MAX)),this._title=t.value,this._queueSearch(this._title),this["use-model"]&&this.dispatchEvent(new CustomEvent("update:modelValue",{bubbles:!0,composed:!0,detail:this._title}))}_onAnswerInput(e,t){const s=e.target;s.value.length>this.ANSWER_MAX&&(s.value=s.value.slice(0,this.ANSWER_MAX)),this._answers[t].title=s.value,this.requestUpdate()}_addAnswer(e){const t=[...this._answers];t.splice(e+1,0,{title:"",isCorrect:!1,customAnswerId:i.uid()}),this._answers=t}_deleteAnswer(e){this._answers.length<3||(this._answers=this._answers.filter((t,s)=>s!==e))}_toggleSortItem(e){const t=this._orderList.indexOf(e);this._orderList=t>=0?this._orderList.filter(t=>t!==e):[...this._orderList,e],this.requestUpdate()}_removeSortItem(e){this._orderList=this._orderList.filter(t=>t!==e),this.requestUpdate()}_getSortOrder(e){const t=this._orderList.indexOf(this._label(e));return t>=0?t+1:null}_sortAnswerValue(e){const t=e.charCodeAt(0)-65,s=this._answers[t];return s?.answerId??t+1}_rowMeta(){return{customId:this["custom-id"]||void 0,answerType:this.type,orderIndex:this["order-index"]}}_collectSnapshot(){const e=(this["is-edit"]?this._answers:this["answer-list"]||[]).map(e=>({...e,title:e?.title||"",isCorrect:!!e?.isCorrect})),t=this["is-edit"]?[...this._orderList]:(()=>{const e=this["exam-expand"];return e?e.split(",").map(e=>{const t=this["answer-list"]?.findIndex((t,s)=>String(t.answerId??t.orderIndex??s+1)===String(e));return t>=0?this._label(t):""}).filter(Boolean):[]})();return{title:this["is-edit"]?this._title:this.title||"",answers:e,analysis:this["is-edit"]?this._analysis:this.analysis||"",leastAnswerCount:this["is-edit"]?this._leastAnswerCount:this._normalizeLeastAnswerCount(this["least-answer-count"]),selectedTagList:Array.isArray(this._selectedTagList)?[...this._selectedTagList]:[],examExpand:this["is-edit"]?t.map(e=>this._sortAnswerValue(e)).join(","):this["exam-expand"]||"",showRichText:this["is-edit"]?this._showRichText:!!this["rich-text-content"],richText:this["is-edit"]?this._richText:this["rich-text-content"]||"",orderList:t}}_validateSnapshot(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.type;const s=this._rowMeta(),i=[];e.title||i.push(new n("题目标题不能为空!","EMPTY_TITLE","title",s));let r=!1,o=0;e.answers.forEach((e,a)=>{e.title?.trim()||i.push(new n(`选项${String.fromCharCode(65+a)}未填写`,"ANSWER_EMPTY","answers",s)),"sort"!==t&&e.isCorrect&&(r=!0,o++)});return new Set(e.answers.map(e=>e.title)).size!==e.answers.length&&e.answers.length>0&&i.push(new n("选项不能重复","DUPLICATE_ANSWERS","answers",s)),"single"===t&&o>1&&i.push(new n("此题为单选题,设置了多个推荐/正确选项,请保存时确认是否切换为多选题","SINGLE_MULTI_CORRECT","answers",s)),"multiple"===t&&(1===o&&i.push(new n("请设置至少两个推荐/正确选项","CORRECT_COUNT_INVALID","answers",s)),o>0&&(r=!0),r&&null!==e.leastAnswerCount&&o<e.leastAnswerCount&&i.push(new n("至少选几项与推荐/正确选项数不符","LEAST_ANSWER_COUNT_INVALID","answers",s))),"sort"===t&&(r=e.orderList.length>0,null!==e.leastAnswerCount&&e.orderList.length<e.leastAnswerCount&&i.push(new n("至少选几项与推荐/正确选项数不符","LEAST_ANSWER_COUNT_INVALID","orderList",s))),{errors:i,isSetCorrectAnswer:r,correctAnswerCount:o}}_serialize(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.type;const t=this._collectSnapshot(),{errors:s,isSetCorrectAnswer:i}=this._validateSnapshot(t,e);if(s.length)throw s[0];const r={answerType:String(e),examTypeEnum:String(e),title:t.title,answers:t.answers.map((e,t)=>{const s={...e,orderIndex:t+1,answer:e.title};return void 0!==e.answerId&&(s.examAnswerId=e.answerId),s}),examExpand:t.examExpand,analysis:t.analysis,isSetCorrectAnswer:i,examRichTextContent:t.showRichText?t.richText:""};return this._supportsLeastAnswerCount(e)&&(r.leastAnswerCount=t.leastAnswerCount),this["custom-id"]&&(r.customId=this["custom-id"]),r}_shouldShowCorrectHint(){return"sort"===this.type?!this._orderList.length:!this._answers.some(e=>!!e.isCorrect)}async toJSON(){return Promise.resolve(this._serialize())}validate(){return this._validateSnapshot(this._collectSnapshot()).errors}_openResultDialog(e){this._resultDialogIndex=e,this._resultDialogValue=this._answers[e].resultItem||"",this._resultDialogOpen=!0}_saveResultDialog(){this._answers[this._resultDialogIndex].resultItem=this._resultDialogValue,this._resultDialogOpen=!1,this.requestUpdate()}_renderCorrectHintDialog(){return this._correctHintDialogOpen?e.html`
|
|
2
2
|
<div class="modal-backdrop" @click=${()=>{this._correctHintDialogOpen=!1}}>
|
|
3
3
|
<div class="modal" @click=${e=>e.stopPropagation()}>
|
|
4
4
|
<div class="modal-header">
|
|
@@ -13,6 +13,22 @@
|
|
|
13
13
|
</div>
|
|
14
14
|
</div>
|
|
15
15
|
</div>
|
|
16
|
+
`:""}_renderChangeTypeDialog(){return this._changeTypeDialogOpen?e.html`
|
|
17
|
+
<div class="modal-backdrop" @click=${()=>{this._changeTypeDialogOpen=!1}}>
|
|
18
|
+
<div class="modal" @click=${e=>e.stopPropagation()}>
|
|
19
|
+
<div class="modal-header">
|
|
20
|
+
<span class="modal-title">提示</span>
|
|
21
|
+
<button class="modal-close" @click=${()=>{this._changeTypeDialogOpen=!1}}>✕</button>
|
|
22
|
+
</div>
|
|
23
|
+
<div class="modal-body">
|
|
24
|
+
<div class="value-text">此题为单选题,设置了多个推荐/正确选项,是否切换成多选题?</div>
|
|
25
|
+
</div>
|
|
26
|
+
<div class="modal-footer">
|
|
27
|
+
<button @click=${()=>{this._changeTypeDialogOpen=!1}}>取消</button>
|
|
28
|
+
<button class="primary" @click=${()=>{try{const e=this._serialize("multiple");this._changeTypeDialogOpen=!1,this._emit("save",e)}catch(e){d(e?.message||"保存失败")}}}>切换</button>
|
|
29
|
+
</div>
|
|
30
|
+
</div>
|
|
31
|
+
</div>
|
|
16
32
|
`:""}_renderResultDialog(){if(!this._resultDialogOpen)return"";const t=this._label(this._resultDialogIndex);return e.html`
|
|
17
33
|
<div class="modal-backdrop" @click=${()=>{this._resultDialogOpen=!1}}>
|
|
18
34
|
<div class="modal" @click=${e=>e.stopPropagation()}>
|
|
@@ -37,31 +53,12 @@
|
|
|
37
53
|
<div class="search-item" @click=${()=>this._selectSearchResult(t)}>${t.value||t.title}</div>
|
|
38
54
|
`):e.html`<div class="search-empty">暂无匹配题目</div>`}
|
|
39
55
|
</div>
|
|
40
|
-
`:""}_renderTagSection(){return this["show-tag"]?e.html`
|
|
41
|
-
<div class="flex-items-start section-row">
|
|
42
|
-
<div class="label"><span>标签:</span></div>
|
|
43
|
-
<div style="flex:1">
|
|
44
|
-
<div class="tag-list">
|
|
45
|
-
${this._selectedTagList.length?this._selectedTagList.map(t=>e.html`
|
|
46
|
-
<span class="tag-item">
|
|
47
|
-
${t.tagName}
|
|
48
|
-
${this["is-save"]?"":e.html`<span class="close" @click=${()=>this._removeTag(t.tagId)}>×</span>`}
|
|
49
|
-
</span>
|
|
50
|
-
`):e.html`<span class="tag-hint">暂无标签/关键信息</span>`}
|
|
51
|
-
</div>
|
|
52
|
-
${this["is-edit"]&&!this["is-save"]?e.html`
|
|
53
|
-
<div style="margin-top:8px">
|
|
54
|
-
<span class="el-link" @click=${()=>this._chooseTag()}>选择</span>
|
|
55
|
-
</div>
|
|
56
|
-
`:""}
|
|
57
|
-
</div>
|
|
58
|
-
</div>
|
|
59
56
|
`:""}_renderCategorySection(){return this["show-category"]?e.html`
|
|
60
57
|
<div class="flex-items-start section-row">
|
|
61
58
|
<div class="label"><span>分类:</span></div>
|
|
62
59
|
<div style="flex:1">
|
|
63
60
|
${this["is-edit"]?e.html`
|
|
64
|
-
<select class="el-select" .value=${String(this._categoryId)}
|
|
61
|
+
<select class="el-select" .value=${String(this._categoryId)}
|
|
65
62
|
@change=${e=>this._onCategoryChange(e.target.value)}>
|
|
66
63
|
<option value="">选择分类</option>
|
|
67
64
|
${this["category-list"].map(t=>e.html`
|
|
@@ -139,30 +136,20 @@
|
|
|
139
136
|
</div>
|
|
140
137
|
</div>
|
|
141
138
|
</div>
|
|
142
|
-
`:""}async _save(e){e?.stopImmediatePropagation();const t=this.validate();if(
|
|
139
|
+
`:""}async _save(e){e?.stopImmediatePropagation();const t=this.validate(),s=t.find(e=>"SINGLE_MULTI_CORRECT"===e.code),i=t.filter(e=>"SINGLE_MULTI_CORRECT"!==e.code);if(i.length)d(i[0].message);else if(s)this._changeTypeDialogOpen=!0;else if(this._hasShownCorrectHint||!this._shouldShowCorrectHint())try{const e=await this.toJSON();this._emit("save",e)}catch(e){d(e.message)}else this._correctHintDialogOpen=!0}_renderPreview(){const t="single"===this.type?"(单选题)":`(${this._titlePlaceholder}${this._leastAnswerCountSuffix(this._normalizeLeastAnswerCount(this["least-answer-count"]))})`,s=this["answer-list"];return e.html`
|
|
143
140
|
<div class="preview">
|
|
144
|
-
<div><span class="title">${this["order-index"]+1}.${this.title||""}${t}
|
|
141
|
+
<div><span class="title">${this["order-index"]+1}.${this.title||""}${t}</span></div>
|
|
145
142
|
${this["rich-text-content"]?e.html`<div class="rich-text" .innerHTML=${this["rich-text-content"]}></div>`:""}
|
|
146
143
|
<div class="preview-answer">
|
|
147
144
|
${s.map((t,s)=>e.html`
|
|
148
145
|
<label class="radio">
|
|
149
146
|
<input type="${"sort"===this.type?"checkbox":"radio"}" .checked=${!!t.isCorrect} disabled />
|
|
150
147
|
<span class="order">${this._label(s)}.</span> ${t.title}
|
|
151
|
-
${"sort"!==this.type&&t.isCorrect?e.html`<span class="correct"
|
|
152
|
-
${"sort"!==this.type&&1===this["exam-answer-relation-type"]?e.html`<span class="result-info">${t.resultItem?"(已设置结果项)":"(未设置结果项)"}</span>`:""}
|
|
153
|
-
${"sort"!==this.type&&2===this["exam-answer-relation-type"]?e.html`<span class="result-info">${t.answerRelations?.length?"(已设置关联)":"(未设置关联)"}</span>`:""}
|
|
148
|
+
${"sort"!==this.type&&t.isCorrect?e.html`<span class="correct">(推荐/正确选项)</span>`:""}
|
|
154
149
|
</label>
|
|
155
150
|
`)}
|
|
156
151
|
</div>
|
|
157
152
|
${this["show-category"]&&this._categoryId?e.html`<div class="section-row"><span class="value-text">分类:${this["category-list"].find(e=>String(e.categoryId)===String(this._categoryId))?.title||this._categoryId}</span></div>`:""}
|
|
158
|
-
${this._selectedTagList.length&&this["show-tag"]?e.html`
|
|
159
|
-
<div class="section-row">
|
|
160
|
-
<span class="value-text">标签/关键信息:</span>
|
|
161
|
-
<div class="tag-list" style="margin-top:6px">
|
|
162
|
-
${this._selectedTagList.map(t=>e.html`<span class="tag-item">${t.tagName}</span>`)}
|
|
163
|
-
</div>
|
|
164
|
-
</div>
|
|
165
|
-
`:""}
|
|
166
153
|
${this["show-resource"]?this._renderResourceSection():""}
|
|
167
154
|
</div>
|
|
168
155
|
`}_renderEdit(){return e.html`
|
|
@@ -170,7 +157,7 @@
|
|
|
170
157
|
<div class="label"><span>题目:</span></div>
|
|
171
158
|
<div style="flex:1">
|
|
172
159
|
<div class="el-input search-wrap">
|
|
173
|
-
<textarea rows="2" .value=${this._title}
|
|
160
|
+
<textarea rows="2" .value=${this._title}
|
|
174
161
|
maxlength=${this.TITLE_MAX}
|
|
175
162
|
@input=${e=>this._onTitleInput(e)}
|
|
176
163
|
placeholder="【${this._titlePlaceholder}】请输入问题"></textarea>
|
|
@@ -183,8 +170,8 @@
|
|
|
183
170
|
${["multiple","sort"].includes(this.type)?e.html`
|
|
184
171
|
<div class="flex-items-start" style="margin-top:12px">
|
|
185
172
|
<div class="label"><span>设置:</span></div>
|
|
186
|
-
<select class="el-select" .value=${this._leastAnswerCount?String(this._leastAnswerCount)
|
|
187
|
-
@change=${e=>{const t=e.target.value;this._leastAnswerCount=
|
|
173
|
+
<select class="el-select" .value=${null===this._leastAnswerCount?"":String(this._leastAnswerCount)} ?disabled=${this.lockAnswerKey}
|
|
174
|
+
@change=${e=>{const t=e.target.value;this._leastAnswerCount=this._normalizeLeastAnswerCount(t)}}>
|
|
188
175
|
<option value="">至少选择几项</option>
|
|
189
176
|
${Array.from({length:Math.max(0,this._answers.length-1)},(e,t)=>t+2).map(t=>e.html`
|
|
190
177
|
<option value=${t} ?selected=${this._leastAnswerCount===t}>至少选择${t}项</option>
|
|
@@ -198,7 +185,7 @@
|
|
|
198
185
|
<div class="answer-item">
|
|
199
186
|
<span class="label">${this._label(s)}.</span>
|
|
200
187
|
<div class="input">
|
|
201
|
-
<input type="text" .value=${t.title}
|
|
188
|
+
<input type="text" .value=${t.title}
|
|
202
189
|
maxlength=${this.ANSWER_MAX}
|
|
203
190
|
@input=${e=>this._onAnswerInput(e,s)}
|
|
204
191
|
placeholder="选项${this._label(s)}" />
|
|
@@ -209,27 +196,21 @@
|
|
|
209
196
|
|
|
210
197
|
${["single","multiple"].includes(this.type)?e.html`
|
|
211
198
|
<label class="correct ${t.isCorrect?"is-correct":""}">
|
|
212
|
-
<input type="checkbox" .checked=${t.isCorrect} ?disabled=${this
|
|
199
|
+
<input type="checkbox" .checked=${t.isCorrect} ?disabled=${this.lockAnswerKey}
|
|
213
200
|
@change=${e=>this._setCorrect(t,e.target.checked)} />
|
|
214
|
-
|
|
201
|
+
推荐/正确选项
|
|
215
202
|
</label>
|
|
216
203
|
`:""}
|
|
217
204
|
|
|
218
|
-
<span class="icon
|
|
205
|
+
<span class="icon"
|
|
219
206
|
@click=${()=>this._addAnswer(s)}>
|
|
220
207
|
${l}
|
|
221
208
|
</span>
|
|
222
|
-
<span class="icon ${this
|
|
209
|
+
<span class="icon ${this._answers.length<3?"disabled":""}"
|
|
223
210
|
@click=${()=>this._deleteAnswer(s)}>
|
|
224
211
|
${c}
|
|
225
212
|
</span>
|
|
226
213
|
|
|
227
|
-
${1===this["exam-answer-relation-type"]&&"sort"!==this.type?e.html`
|
|
228
|
-
<span class="link" @click=${()=>this._openResultDialog(s)}>${t.resultItem?"编辑结果":"添加结果"}</span>
|
|
229
|
-
`:""}
|
|
230
|
-
${2===this["exam-answer-relation-type"]&&"sort"!==this.type?e.html`
|
|
231
|
-
<span class="link" @click=${()=>this._setRelation(t,s)}>${t.answerRelations?.length?`关联了${this._relationLength(t.answerRelations)}项`:"关联检查"}</span>
|
|
232
|
-
`:""}
|
|
233
214
|
</div>
|
|
234
215
|
`)}
|
|
235
216
|
</div>
|
|
@@ -239,21 +220,21 @@
|
|
|
239
220
|
<div class="label"><span>排序答案:</span></div>
|
|
240
221
|
<div style="flex:1">
|
|
241
222
|
<div class="multi-select-wrapper">
|
|
242
|
-
<div class="multi-select ${this._sortDropdownOpen?"focused":""} ${this
|
|
243
|
-
@click=${()=>{this
|
|
223
|
+
<div class="multi-select ${this._sortDropdownOpen?"focused":""} ${this.lockAnswerKey?"disabled":""}"
|
|
224
|
+
@click=${()=>{this.lockAnswerKey||(this._sortDropdownOpen=!this._sortDropdownOpen,this.requestUpdate())}}>
|
|
244
225
|
${this._orderList.length>0?this._orderList.map(t=>e.html`
|
|
245
226
|
<span class="tag">
|
|
246
227
|
${t}
|
|
247
|
-
<span class="tag-close" @click=${e=>{e.stopPropagation(),this._removeSortItem(t)}}>✕</span>
|
|
228
|
+
<span class="tag-close" @click=${e=>{this.lockAnswerKey||(e.stopPropagation(),this._removeSortItem(t))}}>✕</span>
|
|
248
229
|
</span>
|
|
249
230
|
`):e.html`<span class="placeholder">请按顺序选择排序答案</span>`}
|
|
250
|
-
<span class="arrow">${
|
|
231
|
+
<span class="arrow">${p}</span>
|
|
251
232
|
</div>
|
|
252
233
|
${this._sortDropdownOpen?e.html`
|
|
253
234
|
<div class="multi-select-dropdown">
|
|
254
235
|
${this._answers.map((t,s)=>e.html`
|
|
255
236
|
<div class="multi-select-option ${this._orderList.includes(this._label(s))?"selected":""}"
|
|
256
|
-
@click=${()=>{this._toggleSortItem(this._label(s)),this.requestUpdate()}}>
|
|
237
|
+
@click=${()=>{this.lockAnswerKey||(this._toggleSortItem(this._label(s)),this.requestUpdate())}}>
|
|
257
238
|
${this._label(s)}
|
|
258
239
|
</div>
|
|
259
240
|
`)}
|
|
@@ -264,7 +245,7 @@
|
|
|
264
245
|
</div>
|
|
265
246
|
`:""}
|
|
266
247
|
|
|
267
|
-
|
|
248
|
+
<slot name="business-tag"></slot>
|
|
268
249
|
|
|
269
250
|
${this._renderCategorySection()}
|
|
270
251
|
|
|
@@ -297,36 +278,29 @@
|
|
|
297
278
|
</div>
|
|
298
279
|
</div>
|
|
299
280
|
`:""}
|
|
300
|
-
`}render(){return e.html`
|
|
281
|
+
`}render(){const t=this["is-edit"]?e.html`<div slot="edit">${this._renderEdit()}</div>`:e.html`<div slot="preview">${this._renderPreview()}</div>`;return e.html`
|
|
301
282
|
<qxs-subject-layout .show-edit=${this["is-edit"]}>
|
|
302
|
-
|
|
303
|
-
<div slot="edit">${this._renderEdit()}</div>
|
|
283
|
+
${t}
|
|
304
284
|
${this["show-action"]?e.html`
|
|
305
285
|
<qxs-subject-action
|
|
306
286
|
.is-edit=${this["is-edit"]}
|
|
307
287
|
.is-set=${this["is-set"]}
|
|
308
|
-
.is-key=${this._isKey}
|
|
309
288
|
.show-add=${this["show-add"]}
|
|
310
|
-
.show-answer-setting=${this["show-answer-setting"]&&["single","multiple","sort"].includes(this.type)}
|
|
311
|
-
.show-key=${this["show-key"]&&["single","multiple","sort"].includes(this.type)}
|
|
312
289
|
.show-rich-text=${this._showRichText}
|
|
313
290
|
.show-jump=${this["show-jump"]}
|
|
314
|
-
answer-check-type=${this._answerCheckType}
|
|
315
|
-
exam-answer-relation-type=${this["exam-answer-relation-type"]}
|
|
316
291
|
@delete=${()=>this._emit("delete")}
|
|
317
292
|
@save=${this._save}
|
|
318
293
|
@edit=${()=>this._emit("edit")}
|
|
319
294
|
@move=${e=>this._emit("move",e.detail)}
|
|
320
295
|
@jump=${()=>this._emit("jump",{customId:this["custom-id"]||"",examId:this["exam-id"]||0,answerType:this.type})}
|
|
321
296
|
@add=${e=>this._emit("add",e.detail)}
|
|
322
|
-
@set-key=${e=>{this._isKey=e.detail.value,this._emit("set-key",e.detail)}}
|
|
323
|
-
@set-answer-setting=${e=>{this._answerCheckType=e.detail.value}}
|
|
324
297
|
@on-show-rich-text=${()=>{this._showRichText=!this._showRichText,this._showRichText||(this._richText="")}}
|
|
325
298
|
></qxs-subject-action>
|
|
326
299
|
`:""}
|
|
327
300
|
</qxs-subject-layout>
|
|
328
301
|
${this._renderResultDialog()}
|
|
329
302
|
${this._renderCorrectHintDialog()}
|
|
303
|
+
${this._renderChangeTypeDialog()}
|
|
330
304
|
${this._renderImageViewer()}
|
|
331
305
|
${this._renderVideoViewer()}
|
|
332
306
|
`}},exports.QxsSubjectSingle.styles=e.css`
|
|
@@ -519,5 +493,5 @@
|
|
|
519
493
|
.modal-footer button:hover { color: #3D61E3; border-color: #a0cfff; }
|
|
520
494
|
.modal-footer button.primary { background: #3D61E3; border-color: #3D61E3; color: #fff; }
|
|
521
495
|
.modal-footer button.primary:hover { background: #2D4CB8; border-color: #2D4CB8; }
|
|
522
|
-
`,a([t.property({type:Number,attribute:"order-index"})],exports.QxsSubjectSingle.prototype,"order-index",2),a([t.property({type:Boolean,attribute:"is-edit"})],exports.QxsSubjectSingle.prototype,"is-edit",2),a([t.property({type:Boolean,attribute:"is-save"})],exports.QxsSubjectSingle.prototype,"is-save",2),a([t.property({type:Boolean,attribute:"is-set"})],exports.QxsSubjectSingle.prototype,"is-set",2),a([t.property({type:Boolean,attribute:"is-key"})],exports.QxsSubjectSingle.prototype,"is-key",2),a([t.property({type:Boolean,attribute:"show-action"})],exports.QxsSubjectSingle.prototype,"show-action",2),a([t.property({type:Boolean,attribute:"show-add"})],exports.QxsSubjectSingle.prototype,"show-add",2),a([t.property({type:Boolean,attribute:"show-answer-setting"})],exports.QxsSubjectSingle.prototype,"show-answer-setting",2),a([t.property({type:Boolean,attribute:"show-key"})],exports.QxsSubjectSingle.prototype,"show-key",2),a([t.property({type:Boolean,attribute:"show-analysis"})],exports.QxsSubjectSingle.prototype,"show-analysis",2),a([t.property({attribute:"question-type",reflect:!0})],exports.QxsSubjectSingle.prototype,"type",2),a([t.property({type:Number,attribute:"answer-check-type"})],exports.QxsSubjectSingle.prototype,"answer-check-type",2),a([t.property({type:Number,attribute:"exam-answer-relation-type"})],exports.QxsSubjectSingle.prototype,"exam-answer-relation-type",2),a([t.property({type:String,attribute:"rich-text-content"})],exports.QxsSubjectSingle.prototype,"rich-text-content",2),a([t.property({type:String})],exports.QxsSubjectSingle.prototype,"analysis",2),a([t.property({type:Number,attribute:"least-answer-count"})],exports.QxsSubjectSingle.prototype,"least-answer-count",2),a([t.property({type:String,attribute:"exam-expand"})],exports.QxsSubjectSingle.prototype,"exam-expand",2),a([t.property({type:String,attribute:"custom-id"})],exports.QxsSubjectSingle.prototype,"custom-id",2),a([t.property({type:Number,attribute:"exam-id"})],exports.QxsSubjectSingle.prototype,"exam-id",2),a([t.property({type:String,attribute:"category-id"})],exports.QxsSubjectSingle.prototype,"category-id",2),a([t.property({type:Object,attribute:"upload-image"})],exports.QxsSubjectSingle.prototype,"upload-image",2),a([t.property({type:Array,attribute:"answer-list"})],exports.QxsSubjectSingle.prototype,"answer-list",1),a([t.property({type:Array,attribute:"tag-list"})],exports.QxsSubjectSingle.prototype,"tag-list",2),a([t.property({type:Array,attribute:"category-list"})],exports.QxsSubjectSingle.prototype,"category-list",2),a([t.property({type:String,attribute:"ai-answer"})],exports.QxsSubjectSingle.prototype,"ai-answer",2),a([t.property({type:Array,attribute:"resource-list"})],exports.QxsSubjectSingle.prototype,"resource-list",2),a([t.property({type:Boolean,attribute:"show-tag"})],exports.QxsSubjectSingle.prototype,"show-tag",2),a([t.property({type:Boolean,attribute:"show-category"})],exports.QxsSubjectSingle.prototype,"show-category",2),a([t.property({type:Boolean,attribute:"show-ai"})],exports.QxsSubjectSingle.prototype,"show-ai",2),a([t.property({type:Boolean,attribute:"show-resource"})],exports.QxsSubjectSingle.prototype,"show-resource",2),a([t.property({type:Boolean,attribute:"show-jump"})],exports.QxsSubjectSingle.prototype,"show-jump",2),a([t.property({type:Boolean,attribute:"has-jump"})],exports.QxsSubjectSingle.prototype,"has-jump",2),a([t.property({type:String,attribute:"search-api"})],exports.QxsSubjectSingle.prototype,"search-api",2),a([t.property({type:Object,attribute:"search-handler"})],exports.QxsSubjectSingle.prototype,"search-handler",2),a([t.property({type:String,attribute:"model-value"})],exports.QxsSubjectSingle.prototype,"model-value",2),a([t.property({type:Boolean,attribute:"use-model"})],exports.QxsSubjectSingle.prototype,"use-model",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_answers",2),a([t.property({type:String})],exports.QxsSubjectSingle.prototype,"title",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_title",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_analysis",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_richText",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_showRichText",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_leastAnswerCount",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_answerCheckType",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_isKey",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_orderList",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_selectedTagList",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_categoryId",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_searchResults",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_searchOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_searchLoading",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_resultDialogOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_resultDialogIndex",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_resultDialogValue",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_sortDropdownOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_imageViewerOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_imageViewerIndex",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_videoViewerOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_correctHintDialogOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_hasShownCorrectHint",2),exports.QxsSubjectSingle=a([s.safeCustomElement("qxs-subject-single")],exports.QxsSubjectSingle),exports.SubjectError=n;
|
|
496
|
+
`,a([t.property({type:Number,attribute:"order-index"})],exports.QxsSubjectSingle.prototype,"order-index",2),a([t.property({type:Boolean,attribute:"is-edit"})],exports.QxsSubjectSingle.prototype,"is-edit",2),a([t.property({type:Boolean,attribute:"is-save"})],exports.QxsSubjectSingle.prototype,"is-save",2),a([t.property({type:Boolean,attribute:"is-set"})],exports.QxsSubjectSingle.prototype,"is-set",2),a([t.property({type:Boolean,attribute:"is-set-correct-answer"})],exports.QxsSubjectSingle.prototype,"is-set-correct-answer",2),a([t.property({type:Boolean,attribute:"lock-answer-key"})],exports.QxsSubjectSingle.prototype,"lockAnswerKey",2),a([t.property({type:Boolean,attribute:"is-key"})],exports.QxsSubjectSingle.prototype,"is-key",2),a([t.property({type:Boolean,attribute:"show-action"})],exports.QxsSubjectSingle.prototype,"show-action",2),a([t.property({type:Boolean,attribute:"show-add"})],exports.QxsSubjectSingle.prototype,"show-add",2),a([t.property({type:Boolean,attribute:"show-answer-setting"})],exports.QxsSubjectSingle.prototype,"show-answer-setting",2),a([t.property({type:Boolean,attribute:"show-key"})],exports.QxsSubjectSingle.prototype,"show-key",2),a([t.property({type:Boolean,attribute:"show-analysis"})],exports.QxsSubjectSingle.prototype,"show-analysis",2),a([t.property({attribute:"question-type",reflect:!0})],exports.QxsSubjectSingle.prototype,"type",2),a([t.property({type:Number,attribute:"answer-check-type"})],exports.QxsSubjectSingle.prototype,"answer-check-type",2),a([t.property({type:Number,attribute:"exam-answer-relation-type"})],exports.QxsSubjectSingle.prototype,"exam-answer-relation-type",2),a([t.property({type:String,attribute:"rich-text-content"})],exports.QxsSubjectSingle.prototype,"rich-text-content",2),a([t.property({type:String})],exports.QxsSubjectSingle.prototype,"analysis",2),a([t.property({type:Number,attribute:"least-answer-count"})],exports.QxsSubjectSingle.prototype,"least-answer-count",2),a([t.property({type:String,attribute:"exam-expand"})],exports.QxsSubjectSingle.prototype,"exam-expand",2),a([t.property({type:String,attribute:"custom-id"})],exports.QxsSubjectSingle.prototype,"custom-id",2),a([t.property({type:Number,attribute:"exam-id"})],exports.QxsSubjectSingle.prototype,"exam-id",2),a([t.property({type:String,attribute:"category-id"})],exports.QxsSubjectSingle.prototype,"category-id",2),a([t.property({type:Object,attribute:"upload-image"})],exports.QxsSubjectSingle.prototype,"upload-image",2),a([t.property({type:Array,attribute:"answer-list"})],exports.QxsSubjectSingle.prototype,"answer-list",1),a([t.property({type:Array,attribute:"tag-list"})],exports.QxsSubjectSingle.prototype,"tag-list",2),a([t.property({type:Array,attribute:"category-list"})],exports.QxsSubjectSingle.prototype,"category-list",2),a([t.property({type:String,attribute:"ai-answer"})],exports.QxsSubjectSingle.prototype,"ai-answer",2),a([t.property({type:Array,attribute:"resource-list"})],exports.QxsSubjectSingle.prototype,"resource-list",2),a([t.property({type:Boolean,attribute:"show-tag"})],exports.QxsSubjectSingle.prototype,"show-tag",2),a([t.property({type:Boolean,attribute:"show-category"})],exports.QxsSubjectSingle.prototype,"show-category",2),a([t.property({type:Boolean,attribute:"show-ai"})],exports.QxsSubjectSingle.prototype,"show-ai",2),a([t.property({type:Boolean,attribute:"show-resource"})],exports.QxsSubjectSingle.prototype,"show-resource",2),a([t.property({type:Boolean,attribute:"show-jump"})],exports.QxsSubjectSingle.prototype,"show-jump",2),a([t.property({type:Boolean,attribute:"has-jump"})],exports.QxsSubjectSingle.prototype,"has-jump",2),a([t.property({type:String,attribute:"search-api"})],exports.QxsSubjectSingle.prototype,"search-api",2),a([t.property({type:Object,attribute:"search-handler"})],exports.QxsSubjectSingle.prototype,"search-handler",2),a([t.property({type:String,attribute:"model-value"})],exports.QxsSubjectSingle.prototype,"model-value",2),a([t.property({type:Boolean,attribute:"use-model"})],exports.QxsSubjectSingle.prototype,"use-model",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_answers",2),a([t.property({type:String})],exports.QxsSubjectSingle.prototype,"title",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_title",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_analysis",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_richText",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_showRichText",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_leastAnswerCount",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_answerCheckType",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_isKey",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_orderList",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_selectedTagList",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_categoryId",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_searchResults",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_searchOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_searchLoading",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_resultDialogOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_resultDialogIndex",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_resultDialogValue",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_sortDropdownOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_imageViewerOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_imageViewerIndex",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_videoViewerOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_correctHintDialogOpen",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_hasShownCorrectHint",2),a([t.state()],exports.QxsSubjectSingle.prototype,"_changeTypeDialogOpen",2),exports.QxsSubjectSingle=a([s.safeCustomElement("qxs-subject-single")],exports.QxsSubjectSingle),exports.SubjectError=n;
|
|
523
497
|
//# sourceMappingURL=single.cjs.map
|