@qxs-bns/components-wc 0.0.19 → 0.0.21
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/editor/blocksuite-editor.mjs +2 -2
- package/es/editor/blocksuite-editor.mjs.map +1 -1
- package/es/subject/action.mjs +76 -22
- package/es/subject/action.mjs.map +1 -1
- package/es/subject/blank-fill.mjs +29 -24
- package/es/subject/blank-fill.mjs.map +1 -1
- package/es/subject/list.mjs +85 -55
- package/es/subject/list.mjs.map +1 -1
- package/es/subject/page-end.mjs +6 -5
- package/es/subject/page-end.mjs.map +1 -1
- package/es/subject/scale.mjs +7 -5
- package/es/subject/scale.mjs.map +1 -1
- package/es/subject/single.mjs +212 -18
- package/es/subject/single.mjs.map +1 -1
- package/es/subject/text-fill.mjs +32 -29
- package/es/subject/text-fill.mjs.map +1 -1
- package/es/subject/type.mjs +1 -1
- package/es/subject/type.mjs.map +1 -1
- package/lib/editor/blocksuite-editor.cjs +2 -2
- package/lib/editor/blocksuite-editor.cjs.map +1 -1
- package/lib/subject/action.cjs +76 -22
- package/lib/subject/action.cjs.map +1 -1
- package/lib/subject/blank-fill.cjs +28 -23
- package/lib/subject/blank-fill.cjs.map +1 -1
- package/lib/subject/list.cjs +41 -11
- package/lib/subject/list.cjs.map +1 -1
- package/lib/subject/page-end.cjs +3 -2
- package/lib/subject/page-end.cjs.map +1 -1
- package/lib/subject/scale.cjs +7 -5
- package/lib/subject/scale.cjs.map +1 -1
- package/lib/subject/single.cjs +212 -18
- package/lib/subject/single.cjs.map +1 -1
- package/lib/subject/text-fill.cjs +41 -38
- package/lib/subject/text-fill.cjs.map +1 -1
- package/lib/subject/type.cjs +1 -1
- package/lib/subject/type.cjs.map +1 -1
- package/package.json +1 -1
package/lib/subject/single.cjs
CHANGED
|
@@ -1,4 +1,19 @@
|
|
|
1
|
-
"use strict";var e=require("lit"),t=require("../node_modules/.pnpm/@lit_reactive-element@2.1.2/node_modules/@lit/reactive-element/decorators/property.cjs"),s=require("../node_modules/.pnpm/@lit_reactive-element@2.1.2/node_modules/@lit/reactive-element/decorators/state.cjs"),i=require("../base/define.cjs"),r=require("../base/uid.cjs"),o=Object.defineProperty,n=Object.getOwnPropertyDescriptor,l=(e,t,s,i)=>{for(var r,l=i>1?void 0:i?n(t,s):t,a=e.length-1;a>=0;a--)(r=e[a])&&(l=(i?r(t,s,l):r(l))||l);return i&&l&&o(t,s,l),l};class a 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 a(e.message,e.code,e.field,e.row)}}const p=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>`,h=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>`;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"><line x1="18" y1="6" x2="6" y2="18"/><line x1="6" y1="6" x2="18" y2="18"/></svg>`;const c=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>`;exports.QxsSubjectSingle=class extends e.LitElement{constructor(){super(...arguments),this.orderIndex=0,this.isEdit=!1,this.isSave=!1,this.isSet=!1,this.isKey=!1,this.showAction=!0,this.showAnalysis=!0,this.type="single",this.answerCheckType=1,this.examAnswerRelationType=0,this.richTextContent="",this.analysis="",this.leastAnswerCount=2,this.examExpand="",this.customId="",this.examId=0,this.uploadImage=async e=>new Promise((t,s)=>{const i=new FileReader;i.onload=e=>t(e.target?.result),i.onerror=s,i.readAsDataURL(e)}),this.modelValue="",this.useModel=!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=2,this._answerCheckType=1,this._isKey=!1,this._orderList=[],this._resultDialogOpen=!1,this._resultDialogIndex=0,this._resultDialogValue="",this._sortDropdownOpen=!1,this.TITLE_MAX=200,this.ANSWER_MAX=100,this._handleDocumentClick=e=>{const t=e.composedPath(),s=this.shadowRoot?.querySelector(".multi-select-wrapper");s&&!t.includes(s)&&(this._sortDropdownOpen=!1,this.requestUpdate())}}get answerList(){return this._answers}set answerList(e){if(this.isEdit)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("answerList")}connectedCallback(){super.connectedCallback(),document.addEventListener("click",this._handleDocumentClick),this._syncExternalProps(),this.richTextContent&&(this._richText=this.richTextContent,this._showRichText=!0)}firstUpdated(){this._syncExternalProps(),this.richTextContent&&(this._richText=this.richTextContent,this._showRichText=!0)}disconnectedCallback(){super.disconnectedCallback(),document.removeEventListener("click",this._handleDocumentClick)}willUpdate(e){e.has("isEdit")&&this.isEdit&&this._syncProps(),!this.isEdit&&(e.has("title")||e.has("answerList")||e.has("analysis")||e.has("leastAnswerCount")||e.has("answerCheckType"))&&this._syncExternalProps(),e.has("isKey")&&(this._isKey=this.isKey),(e.has("examExpand")||e.has("answerList"))&&this._syncExamExpand(),e.has("modelValue")&&this.useModel&&(this._title=this.modelValue)}_syncExternalProps(){this._title=this.title||"",this._analysis=this.analysis||"",this._leastAnswerCount=this.leastAnswerCount||2,this._answerCheckType=this.answerCheckType||1,this._isKey=this.isKey,this.richTextContent&&(this._richText=this.richTextContent,this._showRichText=!0),this.answerList?.length&&(this._answers=this.answerList.map(e=>({...e,title:e.title||"",isCorrect:!!e.isCorrect})))}_syncProps(){this._title=this.title||"",this._analysis=this.analysis||"",this._leastAnswerCount=this.leastAnswerCount||2,this._answerCheckType=this.answerCheckType||1,this._isKey=this.isKey,this.richTextContent&&(this._richText=this.richTextContent,this._showRichText=!0),this.answerList?.length&&(this._answers=this.answerList.map(e=>({...e,title:e.title||"",isCorrect:!!e.isCorrect}))),this._syncExamExpand()}_syncExamExpand(){if(!this.examExpand||!this.answerList?.length)return;const e=this.examExpand.split(",");this._orderList=e.map(e=>{const t=this.answerList.find(t=>t.answerId?.toString()===e);return t?String.fromCharCode(65+t.orderIndex-1):e}).filter(Boolean)}_emit(e,t){this.dispatchEvent(new CustomEvent(e,{bubbles:!0,composed:!0,detail:t??null}))}_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.useModel&&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(){this.isSave||(this._answers=[...this._answers,{title:"",isCorrect:!1,customAnswerId:r.uid()}])}_deleteAnswer(e){this._answers.length<3||this.isSave||(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}async toJSON(){return new Promise((e,t)=>{const s={customId:this.customId||void 0,answerType:this.type,orderIndex:this.orderIndex},i=this.isEdit?this._title:this.title||"",r=this.isEdit?this._answers:this.answerList||[],o=this.isEdit?this._answerCheckType:this.answerCheckType||1,n=this.isEdit?this._leastAnswerCount:this.leastAnswerCount||2,l=this.isEdit?this._analysis:this.analysis||"",p=this.isEdit?this._orderList.map(e=>e.charCodeAt(0)-65+1).join(","):this.examExpand||"",h=this.isEdit?this._showRichText:!!this.richTextContent,c=this.isEdit?this._richText:this.richTextContent||"",d=this.isEdit?this._orderList:(()=>{const e=this.examExpand;return e?e.split(",").map(e=>{const t=this.answerList?.find(t=>t.answerId?.toString()===e);return t?String.fromCharCode(65+t.orderIndex-1):e}).filter(Boolean):[]})();if(!i)return void t(new a("题目标题不能为空!","EMPTY_TITLE","title",s));if(!o)return void t(new a("请选择答题设置","NO_ANSWER_CHECK_TYPE","answerCheckType",s));let u="",x=!1,m=0;if("multiple"===this.type||"single"===this.type)r.forEach((e,t)=>{e.title?.trim()||(u+=`选项${String.fromCharCode(65+t)}未填写。`),e.isCorrect&&(x=!0,m++)});else if("sort"===this.type&&(d.length&&(x=!0),x&&d.length<n))return void t(new a(`排序题至少需要设置${n}项排序答案`,"SORT_COUNT_INVALID","orderList",s));if(u)return void t(new a(u,"ANSWER_EMPTY","answers",s));if(new Set(r.map(e=>e.title)).size!==r.length)return void t(new a("选项不能重复","DUPLICATE_ANSWERS","answers",s));if("multiple"===this.type){if(1===m)return void t(new a("请至少设置两个支持选项","CORRECT_COUNT_INVALID","answers",s));if(x&&m<n)return void t(new a("至少选几项与支持选项数不符","LEAST_ANSWER_COUNT_INVALID","answers",s))}if((2===o||3===o)&&!x)return void t(new a("请设置支持选项","NO_CORRECT_ANSWER","answers",s));const g={answerType:String(this.type),title:i,answers:r.filter(e=>e.title).map((e,t)=>({...e,orderIndex:t+1})),examExpand:p,analysis:l,isSetCorrectAnswer:x,leastAnswerCount:n,examRichTextContent:h?c:"",examAnswerRelationType:this.examAnswerRelationType,isKey:this._isKey,answerCheckType:o};this.customId&&(g.customId=this.customId),e(g)})}validate(){const e=[],t={customId:this.customId||void 0,answerType:this.type,orderIndex:this.orderIndex},s=this.isEdit?this._title:this.title||"",i=this.isEdit?this._answers:this.answerList||[],r=this.isEdit?this._answerCheckType:this.answerCheckType||1,o=this.isEdit?this._leastAnswerCount:this.leastAnswerCount||2,n=this.isEdit?this._orderList:(()=>{const e=this.examExpand;return e?e.split(",").map(e=>{const t=this.answerList?.find(t=>t.answerId?.toString()===e);return t?String.fromCharCode(65+t.orderIndex-1):e}).filter(Boolean):[]})();s||e.push(new a("题目标题不能为空!","EMPTY_TITLE","title",t)),r||e.push(new a("请选择答题设置","NO_ANSWER_CHECK_TYPE","answerCheckType",t));let l=!1,p=0;"multiple"===this.type||"single"===this.type?i.forEach((s,i)=>{s.title?.trim()||e.push(new a(`选项${String.fromCharCode(65+i)}未填写`,"ANSWER_EMPTY","answers",t)),s.isCorrect&&(l=!0,p++)}):"sort"===this.type&&(n.length&&(l=!0),l&&n.length<o&&e.push(new a(`排序题至少需要设置${o}项排序答案`,"SORT_COUNT_INVALID","orderList",t)));return new Set(i.map(e=>e.title)).size!==i.length&&i.length>0&&e.push(new a("选项不能重复","DUPLICATE_ANSWERS","answers",t)),"multiple"===this.type&&(1===p&&i.length>0&&e.push(new a("请至少设置两个支持选项","CORRECT_COUNT_INVALID","answers",t)),l&&p<o&&e.push(new a("至少选几项与支持选项数不符","LEAST_ANSWER_COUNT_INVALID","answers",t))),2!==r&&3!==r||l||e.push(new a("请设置支持选项","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()}_renderResultDialog(){if(!this._resultDialogOpen)return"";const t=this._label(this._resultDialogIndex);return e.html`
|
|
1
|
+
"use strict";var e=require("lit"),t=require("../node_modules/.pnpm/@lit_reactive-element@2.1.2/node_modules/@lit/reactive-element/decorators/property.cjs"),s=require("../node_modules/.pnpm/@lit_reactive-element@2.1.2/node_modules/@lit/reactive-element/decorators/state.cjs"),i=require("../base/define.cjs"),r=require("../base/uid.cjs"),o=Object.defineProperty,a=Object.getOwnPropertyDescriptor,n=(e,t,s,i)=>{for(var r,n=i>1?void 0:i?a(t,s):t,l=e.length-1;l>=0;l--)(r=e[l])&&(n=(i?r(t,s,n):r(n))||n);return i&&n&&o(t,s,n),n};class l 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 l(e.message,e.code,e.field,e.row)}}const 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="12" y1="5" x2="12" y2="19"/><line x1="5" y1="12" x2="19" y2="12"/></svg>`,p=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 d(e){return e.replace(/^\d+\.\s*/,"").replace(/[\s,,。.!!??;;::、'"“”‘’()()\[\]【】\-_/\\]+/g,"").toLowerCase()}function u(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.orderIndex=0,this.isEdit=!1,this.isSave=!1,this.isSet=!1,this.isKey=!1,this.showAction=!0,this.showAdd=!0,this.showAnswerSetting=!1,this.showKey=!1,this.showAnalysis=!0,this.type="single",this.answerCheckType=1,this.examAnswerRelationType=0,this.richTextContent="",this.analysis="",this.leastAnswerCount=0,this.examExpand="",this.customId="",this.examId=0,this.categoryId="",this.uploadImage=async e=>new Promise((t,s)=>{const i=new FileReader;i.onload=e=>t(e.target?.result),i.onerror=s,i.readAsDataURL(e)}),this.tagList=[],this.categoryList=[],this.aiAnswer="",this.resourceList=[],this.showTag=!1,this.showCategory=!1,this.showAi=!1,this.showResource=!1,this.showJump=!1,this.hasJump=!1,this.searchApi="",this.modelValue="",this.useModel=!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 answerList(){return this._answers}set answerList(e){if(this.isEdit)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("answerList")}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("isEdit")&&this.isEdit&&this._syncProps(),!this.isEdit&&(e.has("title")||e.has("answerList")||e.has("analysis")||e.has("leastAnswerCount")||e.has("answerCheckType")||e.has("tagList")||e.has("categoryId")||e.has("richTextContent"))&&this._syncExternalProps(),e.has("isKey")&&(this._isKey=this.isKey),e.has("tagList")&&(this._selectedTagList=Array.isArray(this.tagList)?this.tagList.map(e=>({...e})):[]),e.has("categoryId")&&(this._categoryId=this.categoryId?String(this.categoryId):""),(e.has("examExpand")||e.has("answerList"))&&this._syncExamExpand(),e.has("modelValue")&&this.useModel&&(this._title=this.modelValue)}_syncExternalProps(){this._title=this.title||"",this._analysis=this.analysis||"",this._leastAnswerCount=Number(this.leastAnswerCount)||0,this._answerCheckType=this.answerCheckType||1,this._isKey=this.isKey,this._selectedTagList=Array.isArray(this.tagList)?this.tagList.map(e=>({...e})):[],this._categoryId=this.categoryId?String(this.categoryId):"",this._richText=this.richTextContent||"",this._showRichText=!!this.richTextContent,this.answerList?.length&&(this._answers=this.answerList.map(e=>({...e,title:e.title||"",isCorrect:!!e.isCorrect})))}_syncProps(){this._title=this.title||"",this._analysis=this.analysis||"",this._leastAnswerCount=Number(this.leastAnswerCount)||0,this._answerCheckType=this.answerCheckType||1,this._isKey=this.isKey,this._selectedTagList=Array.isArray(this.tagList)?this.tagList.map(e=>({...e})):[],this._categoryId=this.categoryId?String(this.categoryId):"",this._richText=this.richTextContent||"",this._showRichText=!!this.richTextContent,this.answerList?.length&&(this._answers=this.answerList.map(e=>({...e,title:e.title||"",isCorrect:!!e.isCorrect}))),this._syncExamExpand()}_syncExamExpand(){if(!this.examExpand||!this.answerList?.length)return;const e=this.examExpand.split(","),t=this.answerList;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.searchApi&&"function"!=typeof this.searchHandler)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.searchHandler)s=await this.searchHandler(e,this._searchAnswerType());else if(this.searchApi){const t=new URLSearchParams({searchKey:e,answerType:String(this._searchAnswerType())}),i=await fetch(`${this.searchApi}${this.searchApi.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=[],u(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.useModel&&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.customId||""})}_applyAiAnswer(){if(!this.aiAnswer?.trim())return void u("暂无 AI 推荐答案");const e=this.aiAnswer.split(/\r?\n/).map(e=>d(e)).filter(Boolean);let t=0;if("single"===this.type){let s=!1;this._answers=this._answers.map(i=>{const r=!s&&e.includes(d(i.title||""));return r&&(s=!0,t++),{...i,isCorrect:r}})}else this._answers=this._answers.map(s=>{const i=e.includes(d(s.title||""));return i&&t++,{...s,isCorrect:i}});t?this.requestUpdate():u("未找到匹配的选项,请检查选项内容是否一致")}_removeTag(e){this._selectedTagList=this._selectedTagList.filter(t=>String(t.tagId)!==String(e)),this._emit("tag-change",{value:this._selectedTagList,customId:this.customId||"",examId:this.examId||0})}_chooseTag(){this._emit("choose-tag",{value:this._selectedTagList,customId:this.customId||"",examId:this.examId||0})}_onCategoryChange(e){this._categoryId=e,this._emit("category-change",{value:e,customId:this.customId||"",examId:this.examId||0})}_setRelation(e,t){const s=e.customAnswerId?{...e}:{...e,customAnswerId:e.answerId||r.uid()};this._answers=this._answers.map((e,i)=>i===t?s:e),this.requestUpdate(),this._emit("set-relation",{customId:this.customId||"",examId:this.examId||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.resourceList||[]).filter(e=>1===e.resourceType).map(e=>e.resource.middle||e.resource.url).filter(Boolean)}_videoResource(){return(this.resourceList||[]).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.useModel&&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.isSave)return;const t=[...this._answers];t.splice(e+1,0,{title:"",isCorrect:!1,customAnswerId:r.uid()}),this._answers=t}_deleteAnswer(e){this._answers.length<3||this.isSave||(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.customId||void 0,answerType:this.type,orderIndex:this.orderIndex},i=this.isEdit?this._title:this.title||"",r=this.isEdit?this._answers:this.answerList||[],o=this.isEdit?this._answerCheckType:this.answerCheckType||1,a=this.isEdit?this._leastAnswerCount:Number(this.leastAnswerCount)||0,n=this.isEdit?this._analysis:this.analysis||"",c=this._selectedTagList||[],p=this.isEdit?this._orderList.map(e=>this._sortAnswerValue(e)).join(","):this.examExpand||"",h=this.isEdit?this._showRichText:!!this.richTextContent,d=this.isEdit?this._richText:this.richTextContent||"",u=this.isEdit?this._orderList:(()=>{const e=this.examExpand;return e?e.split(",").map(e=>{const t=this.answerList?.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 l("题目标题不能为空!","EMPTY_TITLE","title",s));if(this.showTag&&0===c.length)return void t(new l("请选择标签/关键信息","EMPTY_TAGS","tagList",s));if(!o)return void t(new l("请选择答题设置","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 l(`排序题至少需要设置${a}项排序答案`,"SORT_COUNT_INVALID","orderList",s));if(g)return void t(new l(g,"ANSWER_EMPTY","answers",s));if(new Set(r.map(e=>e.title)).size!==r.length)return void t(new l("选项不能重复","DUPLICATE_ANSWERS","answers",s));if("multiple"===this.type){if(1===m)return void t(new l("请至少设置两个支持选项","CORRECT_COUNT_INVALID","answers",s));if(x&&m<a)return void t(new l("至少选几项与支持选项数不符","LEAST_ANSWER_COUNT_INVALID","answers",s))}if((2===o||3===o)&&!x)return void t(new l("请设置支持选项","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:p,analysis:n,isSetCorrectAnswer:x,leastAnswerCount:a||"",examRichTextContent:h?d:"",examAnswerRelationType:this.examAnswerRelationType,isKey:this._isKey,answerCheckType:o,categoryId:this._categoryId||"",memberTagInfo:c,tagInfos:c,aiAnswer:this.aiAnswer||"",resourceList:this.resourceList||[],examResourceBOList:this.resourceList||[]};this.customId&&(w.customId=this.customId),e(w)})}validate(){const e=[],t={customId:this.customId||void 0,answerType:this.type,orderIndex:this.orderIndex},s=this.isEdit?this._title:this.title||"",i=this.isEdit?this._answers:this.answerList||[],r=this.isEdit?this._answerCheckType:this.answerCheckType||1,o=this.isEdit?this._leastAnswerCount:Number(this.leastAnswerCount)||0,a=this._selectedTagList||[],n=this.isEdit?this._orderList:(()=>{const e=this.examExpand;return e?e.split(",").map(e=>{const t=this.answerList?.findIndex((t,s)=>String(t.answerId??t.orderIndex??s+1)===String(e));return t>=0?this._label(t):""}).filter(Boolean):[]})();s||e.push(new l("题目标题不能为空!","EMPTY_TITLE","title",t)),this.showTag&&0===a.length&&e.push(new l("请选择标签/关键信息","EMPTY_TAGS","tagList",t)),r||e.push(new l("请选择答题设置","NO_ANSWER_CHECK_TYPE","answerCheckType",t));let c=!1,p=0;"multiple"===this.type||"single"===this.type?i.forEach((s,i)=>{s.title?.trim()||e.push(new l(`选项${String.fromCharCode(65+i)}未填写`,"ANSWER_EMPTY","answers",t)),s.isCorrect&&(c=!0,p++)}):"sort"===this.type&&(n.length&&(c=!0),c&&n.length<o&&e.push(new l(`排序题至少需要设置${o}项排序答案`,"SORT_COUNT_INVALID","orderList",t)));return new Set(i.map(e=>e.title)).size!==i.length&&i.length>0&&e.push(new l("选项不能重复","DUPLICATE_ANSWERS","answers",t)),"multiple"===this.type&&(1===p&&i.length>0&&e.push(new l("请至少设置两个支持选项","CORRECT_COUNT_INVALID","answers",t)),c&&p<o&&e.push(new l("至少选几项与支持选项数不符","LEAST_ANSWER_COUNT_INVALID","answers",t))),2!==r&&3!==r||c||e.push(new l("请设置支持选项","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`
|
|
2
|
+
<div class="modal-backdrop" @click=${()=>{this._correctHintDialogOpen=!1}}>
|
|
3
|
+
<div class="modal" @click=${e=>e.stopPropagation()}>
|
|
4
|
+
<div class="modal-header">
|
|
5
|
+
<span class="modal-title">温馨提示</span>
|
|
6
|
+
<button class="modal-close" @click=${()=>{this._correctHintDialogOpen=!1}}>✕</button>
|
|
7
|
+
</div>
|
|
8
|
+
<div class="modal-body">
|
|
9
|
+
<div class="value-text">为了收集更全面、有价值的数据,建议您为问卷每题设定推荐/正确选项。</div>
|
|
10
|
+
</div>
|
|
11
|
+
<div class="modal-footer">
|
|
12
|
+
<button class="primary" @click=${()=>{this._hasShownCorrectHint=!0,this._correctHintDialogOpen=!1}}>我知道了</button>
|
|
13
|
+
</div>
|
|
14
|
+
</div>
|
|
15
|
+
</div>
|
|
16
|
+
`:""}_renderResultDialog(){if(!this._resultDialogOpen)return"";const t=this._label(this._resultDialogIndex);return e.html`
|
|
2
17
|
<div class="modal-backdrop" @click=${()=>{this._resultDialogOpen=!1}}>
|
|
3
18
|
<div class="modal" @click=${e=>e.stopPropagation()}>
|
|
4
19
|
<div class="modal-header">
|
|
@@ -16,9 +31,117 @@
|
|
|
16
31
|
</div>
|
|
17
32
|
</div>
|
|
18
33
|
</div>
|
|
19
|
-
`}
|
|
34
|
+
`}_renderSearchDropdown(){return this.isEdit&&(this._searchOpen||this._searchLoading)?e.html`
|
|
35
|
+
<div class="search-dropdown">
|
|
36
|
+
${this._searchLoading?e.html`<div class="search-empty">搜索中...</div>`:this._searchResults.length?this._searchResults.map(t=>e.html`
|
|
37
|
+
<div class="search-item" @click=${()=>this._selectSearchResult(t)}>${t.value||t.title}</div>
|
|
38
|
+
`):e.html`<div class="search-empty">暂无匹配题目</div>`}
|
|
39
|
+
</div>
|
|
40
|
+
`:""}_renderTagSection(){return this.showTag?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.isSave?"":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.isEdit&&!this.isSave?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
|
+
`:""}_renderCategorySection(){return this.showCategory?e.html`
|
|
60
|
+
<div class="flex-items-start section-row">
|
|
61
|
+
<div class="label"><span>分类:</span></div>
|
|
62
|
+
<div style="flex:1">
|
|
63
|
+
${this.isEdit?e.html`
|
|
64
|
+
<select class="el-select" .value=${String(this._categoryId)} ?disabled=${this.isSave}
|
|
65
|
+
@change=${e=>this._onCategoryChange(e.target.value)}>
|
|
66
|
+
<option value="">选择分类</option>
|
|
67
|
+
${this.categoryList.map(t=>e.html`
|
|
68
|
+
<option value=${String(t.categoryId)} ?selected=${String(t.categoryId)===String(this._categoryId)}>${t.title}</option>
|
|
69
|
+
`)}
|
|
70
|
+
</select>
|
|
71
|
+
`:e.html`<span class="value-text">${this.categoryList.find(e=>String(e.categoryId)===String(this._categoryId))?.title||"未选择分类"}</span>`}
|
|
72
|
+
</div>
|
|
73
|
+
</div>
|
|
74
|
+
`:""}_renderAiSection(){return this.showAi&&["single","multiple"].includes(this.type)?e.html`
|
|
75
|
+
<div class="flex-items-start section-row">
|
|
76
|
+
<div class="label"><span>AI推荐:</span></div>
|
|
77
|
+
<div style="flex:1">
|
|
78
|
+
<span class="value-text">${this.aiAnswer||"暂无"}</span>
|
|
79
|
+
${this.isEdit?e.html`<div style="margin-top:8px"><span class="el-link" @click=${()=>this._applyAiAnswer()}>一键勾选</span></div>`:""}
|
|
80
|
+
</div>
|
|
81
|
+
</div>
|
|
82
|
+
`:""}_renderResourceSection(){if(!this.showResource)return"";const t=this._imageResources(),s=this._videoResource();return e.html`
|
|
83
|
+
<div class="flex-items-start section-row">
|
|
84
|
+
<div class="label"><span>资源:</span></div>
|
|
85
|
+
<div style="flex:1">
|
|
86
|
+
<div class="resource-summary">
|
|
87
|
+
图片 ${t.length} 张${s?",含视频资源":""}
|
|
88
|
+
</div>
|
|
89
|
+
<div class="resource-actions">
|
|
90
|
+
${t.length?e.html`<span class="el-link" @click=${()=>this._openImageViewer(0)}>查看图片</span>`:""}
|
|
91
|
+
${s?.url?e.html`<span class="el-link" @click=${()=>this._openVideoViewer()}>查看视频</span>`:""}
|
|
92
|
+
${t.length||s?.url?"":e.html`<span class="muted-text">暂无资源</span>`}
|
|
93
|
+
</div>
|
|
94
|
+
${t.length?e.html`
|
|
95
|
+
<div class="resource-thumbs">
|
|
96
|
+
${t.slice(0,4).map((t,s)=>e.html`
|
|
97
|
+
<img class="resource-thumb" src=${t} alt="resource" @click=${()=>this._openImageViewer(s)} />
|
|
98
|
+
`)}
|
|
99
|
+
</div>
|
|
100
|
+
`:""}
|
|
101
|
+
</div>
|
|
102
|
+
</div>
|
|
103
|
+
`}_renderImageViewer(){if(!this._imageViewerOpen)return"";const t=this._imageResources(),s=t[this._imageViewerIndex];return s?e.html`
|
|
104
|
+
<div class="modal-backdrop" @click=${()=>this._closeImageViewer()}>
|
|
105
|
+
<div class="modal" @click=${e=>e.stopPropagation()}>
|
|
106
|
+
<div class="modal-header">
|
|
107
|
+
<span class="modal-title">图片预览</span>
|
|
108
|
+
<button class="modal-close" @click=${()=>this._closeImageViewer()}>✕</button>
|
|
109
|
+
</div>
|
|
110
|
+
<div class="modal-body">
|
|
111
|
+
<div class="media-stage"><img src=${s} alt="resource-preview" /></div>
|
|
112
|
+
</div>
|
|
113
|
+
<div class="modal-footer">
|
|
114
|
+
<div class="media-footer">
|
|
115
|
+
<span class="muted-text">${this._imageViewerIndex+1} / ${t.length}</span>
|
|
116
|
+
<div class="group">
|
|
117
|
+
${t.length>1?e.html`<button @click=${()=>this._moveImage(-1)}>上一张</button>`:""}
|
|
118
|
+
${t.length>1?e.html`<button @click=${()=>this._moveImage(1)}>下一张</button>`:""}
|
|
119
|
+
<button class="primary" @click=${()=>this._closeImageViewer()}>关闭</button>
|
|
120
|
+
</div>
|
|
121
|
+
</div>
|
|
122
|
+
</div>
|
|
123
|
+
</div>
|
|
124
|
+
</div>
|
|
125
|
+
`:""}_renderVideoViewer(){const t=this._videoResource();return this._videoViewerOpen&&t?.url?e.html`
|
|
126
|
+
<div class="modal-backdrop" @click=${()=>this._closeVideoViewer()}>
|
|
127
|
+
<div class="modal" @click=${e=>e.stopPropagation()}>
|
|
128
|
+
<div class="modal-header">
|
|
129
|
+
<span class="modal-title">视频预览</span>
|
|
130
|
+
<button class="modal-close" @click=${()=>this._closeVideoViewer()}>✕</button>
|
|
131
|
+
</div>
|
|
132
|
+
<div class="modal-body">
|
|
133
|
+
<div class="media-stage">
|
|
134
|
+
<video src=${t.url} controls playsinline></video>
|
|
135
|
+
</div>
|
|
136
|
+
</div>
|
|
137
|
+
<div class="modal-footer">
|
|
138
|
+
<button class="primary" @click=${()=>this._closeVideoViewer()}>关闭</button>
|
|
139
|
+
</div>
|
|
140
|
+
</div>
|
|
141
|
+
</div>
|
|
142
|
+
`:""}async _save(e){e?.stopImmediatePropagation();const t=this.validate();if(t.length)u(t[0].message);else if(this._hasShownCorrectHint||!this._shouldShowCorrectHint())try{const e=await this.toJSON();this._emit("save",e)}catch(e){u(e.message)}else this._correctHintDialogOpen=!0}_renderPreview(){const t="single"===this.type?"(单选题)":`(${this._titlePlaceholder}${this.leastAnswerCount?`,至少选${this.leastAnswerCount}项${"sort"===this.type?"并排序":""}`:""})`,s=this.answerList;return e.html`
|
|
20
143
|
<div class="preview">
|
|
21
|
-
<div><span class="title">${this.orderIndex+1}.${this.title||""}${t}${this._isKey?e.html`<span class="key-badge">核心题</span>`:""}</span></div>
|
|
144
|
+
<div><span class="title">${this.orderIndex+1}.${this.title||""}${t}${this.showKey&&this._isKey?e.html`<span class="key-badge">核心题</span>`:""}</span></div>
|
|
22
145
|
${this.richTextContent?e.html`<div class="rich-text" .innerHTML=${this.richTextContent}></div>`:""}
|
|
23
146
|
<div class="preview-answer">
|
|
24
147
|
${s.map((t,s)=>e.html`
|
|
@@ -31,17 +154,28 @@
|
|
|
31
154
|
</label>
|
|
32
155
|
`)}
|
|
33
156
|
</div>
|
|
157
|
+
${this.showCategory&&this._categoryId?e.html`<div class="section-row"><span class="value-text">分类:${this.categoryList.find(e=>String(e.categoryId)===String(this._categoryId))?.title||this._categoryId}</span></div>`:""}
|
|
158
|
+
${this._selectedTagList.length&&this.showTag?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
|
+
${this.showResource?this._renderResourceSection():""}
|
|
34
167
|
</div>
|
|
35
168
|
`}_renderEdit(){return e.html`
|
|
36
169
|
<div class="flex-items-start">
|
|
37
170
|
<div class="label"><span>题目:</span></div>
|
|
38
171
|
<div style="flex:1">
|
|
39
|
-
<div class="el-input">
|
|
172
|
+
<div class="el-input search-wrap">
|
|
40
173
|
<textarea rows="2" .value=${this._title} ?disabled=${this.isSave}
|
|
41
174
|
maxlength=${this.TITLE_MAX}
|
|
42
175
|
@input=${e=>this._onTitleInput(e)}
|
|
43
176
|
placeholder="【${this._titlePlaceholder}】请输入问题"></textarea>
|
|
44
177
|
<span class="char-counter">${this._title.length}/${this.TITLE_MAX}</span>
|
|
178
|
+
${this._renderSearchDropdown()}
|
|
45
179
|
</div>
|
|
46
180
|
</div>
|
|
47
181
|
</div>
|
|
@@ -49,8 +183,9 @@
|
|
|
49
183
|
${["multiple","sort"].includes(this.type)?e.html`
|
|
50
184
|
<div class="flex-items-start" style="margin-top:12px">
|
|
51
185
|
<div class="label"><span>设置:</span></div>
|
|
52
|
-
<select class="el-select" .value=${String(this._leastAnswerCount)} ?disabled=${this.isSave}
|
|
53
|
-
@change=${e=>{this._leastAnswerCount=Number(
|
|
186
|
+
<select class="el-select" .value=${this._leastAnswerCount?String(this._leastAnswerCount):""} ?disabled=${this.isSave}
|
|
187
|
+
@change=${e=>{const t=e.target.value;this._leastAnswerCount=t?Number(t):0}}>
|
|
188
|
+
<option value="">至少选择几项</option>
|
|
54
189
|
${Array.from({length:Math.max(0,this._answers.length-1)},(e,t)=>t+2).map(t=>e.html`
|
|
55
190
|
<option value=${t} ?selected=${this._leastAnswerCount===t}>至少选择${t}项</option>
|
|
56
191
|
`)}
|
|
@@ -81,19 +216,19 @@
|
|
|
81
216
|
`:""}
|
|
82
217
|
|
|
83
218
|
<span class="icon ${this.isSave?"disabled":""}"
|
|
84
|
-
@click=${()=>this._addAnswer()}>
|
|
85
|
-
${
|
|
219
|
+
@click=${()=>this._addAnswer(s)}>
|
|
220
|
+
${c}
|
|
86
221
|
</span>
|
|
87
222
|
<span class="icon ${this.isSave||this._answers.length<3?"disabled":""}"
|
|
88
223
|
@click=${()=>this._deleteAnswer(s)}>
|
|
89
|
-
${
|
|
224
|
+
${p}
|
|
90
225
|
</span>
|
|
91
226
|
|
|
92
227
|
${1===this.examAnswerRelationType&&"sort"!==this.type?e.html`
|
|
93
228
|
<span class="link" @click=${()=>this._openResultDialog(s)}>${t.resultItem?"编辑结果":"添加结果"}</span>
|
|
94
229
|
`:""}
|
|
95
230
|
${2===this.examAnswerRelationType&&"sort"!==this.type?e.html`
|
|
96
|
-
<span class="link"
|
|
231
|
+
<span class="link" @click=${()=>this._setRelation(t,s)}>${t.answerRelations?.length?`关联了${this._relationLength(t.answerRelations)}项`:"关联检查"}</span>
|
|
97
232
|
`:""}
|
|
98
233
|
</div>
|
|
99
234
|
`)}
|
|
@@ -112,7 +247,7 @@
|
|
|
112
247
|
<span class="tag-close" @click=${e=>{e.stopPropagation(),this._removeSortItem(t)}}>✕</span>
|
|
113
248
|
</span>
|
|
114
249
|
`):e.html`<span class="placeholder">请按顺序选择排序答案</span>`}
|
|
115
|
-
<span class="arrow">${
|
|
250
|
+
<span class="arrow">${h}</span>
|
|
116
251
|
</div>
|
|
117
252
|
${this._sortDropdownOpen?e.html`
|
|
118
253
|
<div class="multi-select-dropdown">
|
|
@@ -129,6 +264,14 @@
|
|
|
129
264
|
</div>
|
|
130
265
|
`:""}
|
|
131
266
|
|
|
267
|
+
${this._renderTagSection()}
|
|
268
|
+
|
|
269
|
+
${this._renderCategorySection()}
|
|
270
|
+
|
|
271
|
+
${this._renderAiSection()}
|
|
272
|
+
|
|
273
|
+
${this._renderResourceSection()}
|
|
274
|
+
|
|
132
275
|
${this._showRichText?e.html`
|
|
133
276
|
<div class="flex-items-start" style="margin-top:12px">
|
|
134
277
|
<div class="label"><span>富文本:</span></div>
|
|
@@ -139,7 +282,7 @@
|
|
|
139
282
|
?is-edit=${!0}
|
|
140
283
|
@input=${e=>{this._richText=e.target.getContent()}}
|
|
141
284
|
></qxs-blocksuite-editor>
|
|
142
|
-
|
|
285
|
+
${this.showAction?"":e.html`<div class="flex-justify-end" style="margin-top:8px"><span class="el-link danger" @click=${()=>{this._showRichText=!1,this._richText=""}}>删除富文本</span></div>`}
|
|
143
286
|
</div>
|
|
144
287
|
</div>
|
|
145
288
|
`:""}
|
|
@@ -163,20 +306,29 @@
|
|
|
163
306
|
?is-edit=${this.isEdit}
|
|
164
307
|
?is-set=${this.isSet}
|
|
165
308
|
?is-key=${this._isKey}
|
|
166
|
-
?show-
|
|
309
|
+
?show-add=${this.showAdd}
|
|
310
|
+
?show-answer-setting=${this.showAnswerSetting&&["single","multiple","sort"].includes(this.type)}
|
|
311
|
+
?show-key=${this.showKey&&["single","multiple","sort"].includes(this.type)}
|
|
312
|
+
?show-rich-text=${this._showRichText}
|
|
313
|
+
?show-jump=${this.showJump}
|
|
167
314
|
answer-check-type=${this._answerCheckType}
|
|
168
315
|
exam-answer-relation-type=${this.examAnswerRelationType}
|
|
169
316
|
@delete=${()=>this._emit("delete")}
|
|
170
317
|
@save=${this._save}
|
|
171
318
|
@edit=${()=>this._emit("edit")}
|
|
319
|
+
@move=${e=>this._emit("move",e.detail)}
|
|
320
|
+
@jump=${()=>this._emit("jump",{customId:this.customId||"",examId:this.examId||0,answerType:this.type})}
|
|
172
321
|
@add=${e=>this._emit("add",e.detail)}
|
|
173
322
|
@set-key=${e=>{this._isKey=e.detail.value,this._emit("set-key",e.detail)}}
|
|
174
323
|
@set-answer-setting=${e=>{this._answerCheckType=e.detail.value}}
|
|
175
|
-
@on-show-rich-text=${()=>{this._showRichText=!
|
|
324
|
+
@on-show-rich-text=${()=>{this._showRichText=!this._showRichText,this._showRichText||(this._richText="")}}
|
|
176
325
|
></qxs-subject-action>
|
|
177
326
|
`:""}
|
|
178
327
|
</qxs-subject-layout>
|
|
179
328
|
${this._renderResultDialog()}
|
|
329
|
+
${this._renderCorrectHintDialog()}
|
|
330
|
+
${this._renderImageViewer()}
|
|
331
|
+
${this._renderVideoViewer()}
|
|
180
332
|
`}},exports.QxsSubjectSingle.styles=e.css`
|
|
181
333
|
:host { display: block; font-family: system-ui, -apple-system, "PingFang SC", "Microsoft YaHei", sans-serif; font-size: 12px; color: #5a5a5a; }
|
|
182
334
|
*, ::before, ::after { box-sizing: border-box; }
|
|
@@ -264,9 +416,6 @@
|
|
|
264
416
|
}
|
|
265
417
|
.el-select:focus { border-color: #3D61E3; outline: none; }
|
|
266
418
|
.el-select:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }
|
|
267
|
-
.el-select.sort-select {
|
|
268
|
-
width: 360px; height: auto; min-height: 32px; appearance: auto;
|
|
269
|
-
}
|
|
270
419
|
|
|
271
420
|
.sort-badge { font-weight: bold; color: #3D61E3; margin-left: 10px; }
|
|
272
421
|
|
|
@@ -274,6 +423,51 @@
|
|
|
274
423
|
.el-link:hover { color: #2D4CB8; }
|
|
275
424
|
.el-link.danger { color: #f56c6c; }
|
|
276
425
|
|
|
426
|
+
.section-row { margin-top: 12px; }
|
|
427
|
+
.value-text { font-size: 13px; color: #606266; white-space: pre-wrap; }
|
|
428
|
+
.muted-text { font-size: 12px; color: #909399; }
|
|
429
|
+
|
|
430
|
+
.search-wrap { position: relative; }
|
|
431
|
+
.search-dropdown {
|
|
432
|
+
position: absolute; z-index: 120; left: 0; right: 0; top: calc(100% + 4px);
|
|
433
|
+
background: #fff; border: 1px solid #e4e7ed; border-radius: 6px;
|
|
434
|
+
box-shadow: 0 8px 20px rgba(0,0,0,.12); overflow: hidden;
|
|
435
|
+
}
|
|
436
|
+
.search-item {
|
|
437
|
+
padding: 10px 12px; cursor: pointer; transition: background .2s;
|
|
438
|
+
font-size: 13px; color: #606266; line-height: 1.4;
|
|
439
|
+
}
|
|
440
|
+
.search-item:hover { background: #f5f7fa; color: #3D61E3; }
|
|
441
|
+
.search-empty { padding: 10px 12px; font-size: 12px; color: #909399; }
|
|
442
|
+
|
|
443
|
+
.tag-list { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; min-height: 32px; }
|
|
444
|
+
.tag-item {
|
|
445
|
+
display: inline-flex; align-items: center; gap: 4px;
|
|
446
|
+
padding: 4px 8px; font-size: 12px; line-height: 1;
|
|
447
|
+
color: #3D61E3; background: #ecf5ff; border: 1px solid #d9ecff; border-radius: 4px;
|
|
448
|
+
}
|
|
449
|
+
.tag-item .close { cursor: pointer; color: #909399; }
|
|
450
|
+
.tag-item .close:hover { color: #f56c6c; }
|
|
451
|
+
.tag-hint { font-size: 12px; color: #909399; }
|
|
452
|
+
|
|
453
|
+
.resource-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 8px; }
|
|
454
|
+
.resource-summary { font-size: 12px; color: #606266; }
|
|
455
|
+
.resource-thumbs { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 8px; }
|
|
456
|
+
.resource-thumb {
|
|
457
|
+
width: 72px; height: 72px; object-fit: cover; border-radius: 6px;
|
|
458
|
+
border: 1px solid #e4e7ed; cursor: pointer; background: #f5f7fa;
|
|
459
|
+
}
|
|
460
|
+
.resource-video {
|
|
461
|
+
display: inline-flex; align-items: center; justify-content: center;
|
|
462
|
+
min-width: 88px; height: 30px; padding: 0 10px; border: 1px solid #dcdfe6; border-radius: 4px;
|
|
463
|
+
color: #606266; background: #fff; cursor: pointer; font-size: 12px; transition: all .2s;
|
|
464
|
+
}
|
|
465
|
+
.resource-video:hover { color: #3D61E3; border-color: #3D61E3; background: #ecf5ff; }
|
|
466
|
+
.media-stage { display: flex; align-items: center; justify-content: center; min-height: 240px; }
|
|
467
|
+
.media-stage img, .media-stage video { max-width: 100%; max-height: 60vh; border-radius: 6px; }
|
|
468
|
+
.media-footer { display: flex; justify-content: space-between; align-items: center; gap: 8px; width: 100%; }
|
|
469
|
+
.media-footer .group { display: flex; gap: 8px; }
|
|
470
|
+
|
|
277
471
|
/* Multi-select with tags (Element Plus style) */
|
|
278
472
|
.multi-select-wrapper { position: relative; }
|
|
279
473
|
.multi-select {
|
|
@@ -325,5 +519,5 @@
|
|
|
325
519
|
.modal-footer button:hover { color: #3D61E3; border-color: #a0cfff; }
|
|
326
520
|
.modal-footer button.primary { background: #3D61E3; border-color: #3D61E3; color: #fff; }
|
|
327
521
|
.modal-footer button.primary:hover { background: #2D4CB8; border-color: #2D4CB8; }
|
|
328
|
-
`,
|
|
522
|
+
`,n([t.property({type:Number,attribute:"order-index"})],exports.QxsSubjectSingle.prototype,"orderIndex",2),n([t.property({type:Boolean,attribute:"is-edit"})],exports.QxsSubjectSingle.prototype,"isEdit",2),n([t.property({type:Boolean,attribute:"is-save"})],exports.QxsSubjectSingle.prototype,"isSave",2),n([t.property({type:Boolean,attribute:"is-set"})],exports.QxsSubjectSingle.prototype,"isSet",2),n([t.property({type:Boolean,attribute:"is-key"})],exports.QxsSubjectSingle.prototype,"isKey",2),n([t.property({type:Boolean,attribute:"show-action"})],exports.QxsSubjectSingle.prototype,"showAction",2),n([t.property({type:Boolean,attribute:"show-add"})],exports.QxsSubjectSingle.prototype,"showAdd",2),n([t.property({type:Boolean,attribute:"show-answer-setting"})],exports.QxsSubjectSingle.prototype,"showAnswerSetting",2),n([t.property({type:Boolean,attribute:"show-key"})],exports.QxsSubjectSingle.prototype,"showKey",2),n([t.property({type:Boolean,attribute:"show-analysis"})],exports.QxsSubjectSingle.prototype,"showAnalysis",2),n([t.property({attribute:"question-type",reflect:!0})],exports.QxsSubjectSingle.prototype,"type",2),n([t.property({type:Number,attribute:"answer-check-type"})],exports.QxsSubjectSingle.prototype,"answerCheckType",2),n([t.property({type:Number,attribute:"exam-answer-relation-type"})],exports.QxsSubjectSingle.prototype,"examAnswerRelationType",2),n([t.property({type:String,attribute:"rich-text-content"})],exports.QxsSubjectSingle.prototype,"richTextContent",2),n([t.property({type:String})],exports.QxsSubjectSingle.prototype,"analysis",2),n([t.property({type:Number,attribute:"least-answer-count"})],exports.QxsSubjectSingle.prototype,"leastAnswerCount",2),n([t.property({type:String,attribute:"exam-expand"})],exports.QxsSubjectSingle.prototype,"examExpand",2),n([t.property({type:String,attribute:"custom-id"})],exports.QxsSubjectSingle.prototype,"customId",2),n([t.property({type:Number,attribute:"exam-id"})],exports.QxsSubjectSingle.prototype,"examId",2),n([t.property({type:String,attribute:"category-id"})],exports.QxsSubjectSingle.prototype,"categoryId",2),n([t.property({type:Object})],exports.QxsSubjectSingle.prototype,"uploadImage",2),n([t.property({type:Array,attribute:"answer-list"})],exports.QxsSubjectSingle.prototype,"answerList",1),n([t.property({type:Array,attribute:"tag-list"})],exports.QxsSubjectSingle.prototype,"tagList",2),n([t.property({type:Array,attribute:"category-list"})],exports.QxsSubjectSingle.prototype,"categoryList",2),n([t.property({type:String,attribute:"ai-answer"})],exports.QxsSubjectSingle.prototype,"aiAnswer",2),n([t.property({type:Array,attribute:"resource-list"})],exports.QxsSubjectSingle.prototype,"resourceList",2),n([t.property({type:Boolean,attribute:"show-tag"})],exports.QxsSubjectSingle.prototype,"showTag",2),n([t.property({type:Boolean,attribute:"show-category"})],exports.QxsSubjectSingle.prototype,"showCategory",2),n([t.property({type:Boolean,attribute:"show-ai"})],exports.QxsSubjectSingle.prototype,"showAi",2),n([t.property({type:Boolean,attribute:"show-resource"})],exports.QxsSubjectSingle.prototype,"showResource",2),n([t.property({type:Boolean,attribute:"show-jump"})],exports.QxsSubjectSingle.prototype,"showJump",2),n([t.property({type:Boolean,attribute:"has-jump"})],exports.QxsSubjectSingle.prototype,"hasJump",2),n([t.property({type:String,attribute:"search-api"})],exports.QxsSubjectSingle.prototype,"searchApi",2),n([t.property({type:Object})],exports.QxsSubjectSingle.prototype,"searchHandler",2),n([t.property({type:String,attribute:"model-value"})],exports.QxsSubjectSingle.prototype,"modelValue",2),n([t.property({type:Boolean,attribute:"use-model"})],exports.QxsSubjectSingle.prototype,"useModel",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_answers",2),n([t.property({type:String})],exports.QxsSubjectSingle.prototype,"title",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_title",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_analysis",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_richText",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_showRichText",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_leastAnswerCount",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_answerCheckType",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_isKey",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_orderList",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_selectedTagList",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_categoryId",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_searchResults",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_searchOpen",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_searchLoading",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_resultDialogOpen",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_resultDialogIndex",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_resultDialogValue",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_sortDropdownOpen",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_imageViewerOpen",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_imageViewerIndex",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_videoViewerOpen",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_correctHintDialogOpen",2),n([s.state()],exports.QxsSubjectSingle.prototype,"_hasShownCorrectHint",2),exports.QxsSubjectSingle=n([i.safeCustomElement("qxs-subject-single")],exports.QxsSubjectSingle),exports.SubjectError=l;
|
|
329
523
|
//# sourceMappingURL=single.cjs.map
|