@qxs-bns/components-wc 0.0.24 → 0.0.25

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.
@@ -1,20 +1,72 @@
1
- import{html as t,css as e,LitElement as i}from"lit";import{property as s,state as a}from"lit/decorators.js";import{safeCustomElement as l}from"../base/define.mjs";import{SubjectError as n}from"./single.mjs";import{SubjectType as r}from"./types.mjs";var o=Object.defineProperty,h=Object.getOwnPropertyDescriptor,p=(t,e,i,s)=>{for(var a,l=s>1?void 0:s?h(e,i):e,n=t.length-1;n>=0;n--)(a=t[n])&&(l=(s?a(e,i,l):a(l))||l);return s&&l&&o(e,i,l),l};const d=t`
1
+ import{html as t,css as e,LitElement as s}from"lit";import{property as i,state as a}from"lit/decorators.js";import{safeCustomElement as r}from"../base/define.mjs";import{SubjectError as o}from"./single.mjs";import{SubjectType as l}from"./types.mjs";var n=Object.defineProperty,h=Object.getOwnPropertyDescriptor,c=(t,e,s,i)=>{for(var a,r=i>1?void 0:i?h(e,s):e,o=t.length-1;o>=0;o--)(a=t[o])&&(r=(i?a(e,s,r):a(r))||r);return i&&r&&n(e,s,r),r};const d=t`
2
2
  <svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 24 24" fill="none"
3
3
  stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
4
4
  <line x1="12" y1="5" x2="12" y2="19"/><line x1="5" y1="12" x2="19" y2="12"/>
5
- </svg>`;let c=class extends i{constructor(){super(...arguments),this["order-index"]=0,this.title="",this["custom-id"]="",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-analysis"]=!0,this["rich-text-content"]="",this.analysis="",this["exam-answer-relation-type"]=0,this["exam-expand"]="",this["exam-answer-setting"]={isInOrder:!1,isIgnoreCase:!0},this["upload-image"]=async t=>new Promise((e,i)=>{const s=new FileReader;s.onload=t=>e(t.target?.result),s.onerror=i,s.readAsDataURL(t)}),this["answer-list"]=[],this["model-value"]="",this["use-model"]=!1,this._title="",this._analysis="",this._answers=[{title:"",tag:"",showInput:!1}],this._isInOrder=!1,this._isIgnoreCase=!0,this._showRichText=!1,this._richText="",this.TITLE_MAX=400}willUpdate(t){t.has("is-edit")&&this["is-edit"]&&this._syncProps(),!this["is-edit"]&&(t.has("title")||t.has("answer-list")||t.has("analysis")||t.has("exam-answer-setting")||t.has("rich-text-content"))&&this._syncProps(),t.has("model-value")&&this["use-model"]&&(this._title=this["model-value"].replaceAll(/<filter><\/filter>/g," ______"))}_normalizeAnswerTitle(t){return String(t?.title??t?.answer??"")}_syncProps(){if(this._title=(this.title||"").replaceAll(/<filter><\/filter>/g," ______"),this._analysis=this.analysis||"",this["answer-list"]?.length)this._answers=this["answer-list"].map(t=>({title:this._normalizeAnswerTitle(t),tag:"",showInput:!1}));else{const t=(this._title.match(/ ______/g)||[]).length||1;this._answers=Array.from({length:t},()=>({title:"",tag:"",showInput:!1}))}this["exam-answer-setting"]&&(this._isInOrder=!!this["exam-answer-setting"].isInOrder,this._isIgnoreCase=!!this["exam-answer-setting"].isIgnoreCase),this._richText=this["rich-text-content"]||"",this._showRichText=!!this["rich-text-content"]}_emit(t,e){this.dispatchEvent(new CustomEvent(t,{bubbles:!0,composed:!0,detail:e??null}))}_addBlank(){this._title+=" ______",this._answers=[...this._answers,{title:"",tag:"",showInput:!1}],this.requestUpdate(),this._emitModelUpdate()}_onTitleInput(t){const e=t.target;e.value.length>this.TITLE_MAX&&(e.value=e.value.slice(0,this.TITLE_MAX)),this._title=e.value;const i=(this._title.match(/ ______/g)||[]).length;if(i!==this._answers.length)if(i>this._answers.length)for(let t=this._answers.length;t<i;t++)this._answers=[...this._answers,{title:"",tag:"",showInput:!1}];else this._answers=this._answers.slice(0,i);this._emitModelUpdate()}_emitModelUpdate(){if(this["use-model"]){const t=this._title.replaceAll(/ ______/g,"<filter></filter>");this.dispatchEvent(new CustomEvent("update:modelValue",{bubbles:!0,composed:!0,detail:t}))}}_handleAddTag(t){t.showInput=!1,t.tag&&(t.title=t.title?[t.title,t.tag].join(","):t.tag,t.tag=""),this.requestUpdate()}_closeTag(t,e){if(t){const i=e.title.split(","),s=i.findIndex(e=>e===t);s>-1&&(i.splice(s,1),e.title=i.join(",")),this.requestUpdate()}}async toJSON(){return new Promise((t,e)=>{const i={customId:this["custom-id"]||void 0,answerType:"blank_fill",orderIndex:this["order-index"]},s=this["is-edit"]?this._title:this.title?.replaceAll(/<filter><\/filter>/g," ______")||"",a=this["is-edit"]?this._answers:(this["answer-list"]||[]).map(t=>({...t,title:this._normalizeAnswerTitle(t)})),l=this["is-edit"]?this._analysis:this.analysis||"",o=this["is-edit"]?this._isInOrder:this["exam-answer-setting"]?.isInOrder??!1,h=this["is-edit"]?this._isIgnoreCase:this["exam-answer-setting"]?.isIgnoreCase??!0,p=this["is-edit"]?this._showRichText:!!this["rich-text-content"],d=this["is-edit"]?this._richText:this["rich-text-content"]||"";if(!s)return void e(new n("题目标题不能为空!","EMPTY_TITLE","title",i));if(a.length<1)return void e(new n("至少添加一个填空符!","NO_BLANK","answers",i));const c={answerType:r.BLANK_FILL,title:s.replaceAll(/ ______/g,"<filter></filter>"),answers:a.map(t=>({title:t.title,isCorrect:!0})),analysis:l,isSetCorrectAnswer:!0,isKey:this["is-key"],examAnswerSettingBO:{isIgnoreCase:h,isInOrder:o},examRichTextContent:p?d:""};this["custom-id"]&&(c.customId=this["custom-id"]),t(c)})}async _save(t){t?.stopImmediatePropagation();try{const t=await this.toJSON();this._emit("save",t)}catch(t){!function(t){const e=document.createElement("div");e.textContent=t,Object.assign(e.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(e),setTimeout(()=>{e.style.opacity="0",setTimeout(()=>e.remove(),300)},2500)}(t.message)}}validate(){const t=[],e={customId:this["custom-id"]||void 0,answerType:"blank_fill",orderIndex:this["order-index"]},i=this["is-edit"]?this._title:this.title?.replaceAll(/<filter><\/filter>/g," ______")||"",s=this["is-edit"]?this._answers:(this["answer-list"]||[]).map(t=>({...t,title:this._normalizeAnswerTitle(t)}));return i||t.push(new n("题目标题不能为空!","EMPTY_TITLE","title",e)),s.length<1&&t.push(new n("至少添加一个填空符!","NO_BLANK","answers",e)),t}_renderPreview(){const e=this.title.replaceAll(/<filter><\/filter>/g," ______"),i=this["is-edit"]?this._answers:(this["answer-list"]||[]).map(t=>({...t,title:this._normalizeAnswerTitle(t)}));return t`
5
+ </svg>`;let p=class extends s{constructor(){super(...arguments),this["order-index"]=0,this.title="",this["custom-id"]="",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-analysis"]=!0,this["rich-text-content"]="",this.analysis="",this["exam-answer-relation-type"]=0,this["exam-expand"]="",this["exam-id"]=0,this["category-id"]="",this["exam-answer-setting"]={isInOrder:!1,isIgnoreCase:!0},this["upload-image"]=async t=>new Promise((e,s)=>{const i=new FileReader;i.onload=t=>e(t.target?.result),i.onerror=s,i.readAsDataURL(t)}),this["answer-list"]=[],this["tag-list"]=[],this["category-list"]=[],this["resource-list"]=[],this["show-tag"]=!1,this["show-category"]=!1,this["show-resource"]=!1,this["model-value"]="",this["use-model"]=!1,this._title="",this._analysis="",this._answers=[{title:"",tag:"",showInput:!1}],this._isInOrder=!1,this._isIgnoreCase=!0,this._showRichText=!1,this._richText="",this._selectedTagList=[],this._categoryId="",this.TITLE_MAX=400}willUpdate(t){t.has("is-edit")&&this["is-edit"]&&this._syncProps(),!this["is-edit"]&&(t.has("title")||t.has("answer-list")||t.has("analysis")||t.has("exam-answer-setting")||t.has("rich-text-content")||t.has("tag-list")||t.has("category-id"))&&this._syncProps(),t.has("model-value")&&this["use-model"]&&(this._title=this["model-value"].replaceAll(/<filter><\/filter>/g," ______")),t.has("tag-list")&&(this._selectedTagList=Array.isArray(this["tag-list"])?this["tag-list"].map(t=>({...t})):[]),t.has("category-id")&&(this._categoryId=this["category-id"]?String(this["category-id"]):"")}_normalizeAnswerTitle(t){return String(t?.title??t?.answer??"")}_syncProps(){if(this._title=(this.title||"").replaceAll(/<filter><\/filter>/g," ______"),this._analysis=this.analysis||"",this["answer-list"]?.length)this._answers=this["answer-list"].map(t=>({title:this._normalizeAnswerTitle(t),tag:"",showInput:!1,answerId:t?.answerId??t?.examAnswerId}));else{const t=(this._title.match(/ ______/g)||[]).length||1;this._answers=Array.from({length:t},()=>({title:"",tag:"",showInput:!1}))}this["exam-answer-setting"]&&(this._isInOrder=!!this["exam-answer-setting"].isInOrder,this._isIgnoreCase=!!this["exam-answer-setting"].isIgnoreCase),this._richText=this["rich-text-content"]||"",this._showRichText=!!this["rich-text-content"],this._selectedTagList=Array.isArray(this["tag-list"])?this["tag-list"].map(t=>({...t})):[],this._categoryId=this["category-id"]?String(this["category-id"]):""}_emit(t,e){this.dispatchEvent(new CustomEvent(t,{bubbles:!0,composed:!0,detail:e??null}))}_addBlank(){this._title+=" ______",this._answers=[...this._answers,{title:"",tag:"",showInput:!1}],this.requestUpdate(),this._emitModelUpdate()}_onTitleInput(t){const e=t.target;e.value.length>this.TITLE_MAX&&(e.value=e.value.slice(0,this.TITLE_MAX)),this._title=e.value;const s=(this._title.match(/ ______/g)||[]).length;if(s!==this._answers.length)if(s>this._answers.length)for(let t=this._answers.length;t<s;t++)this._answers=[...this._answers,{title:"",tag:"",showInput:!1}];else this._answers=this._answers.slice(0,s);this._emitModelUpdate()}_emitModelUpdate(){if(this["use-model"]){const t=this._title.replaceAll(/ ______/g,"<filter></filter>");this.dispatchEvent(new CustomEvent("update:modelValue",{bubbles:!0,composed:!0,detail:t}))}}_handleAddTag(t){t.showInput=!1,t.tag&&(t.title=t.title?[t.title,t.tag].join(","):t.tag,t.tag=""),this.requestUpdate()}_closeTag(t,e){if(!t)return;const s=e.title.split(","),i=s.findIndex(e=>e===t);i>-1&&(s.splice(i,1),e.title=s.join(",")),this.requestUpdate()}_removeTag(t){this._selectedTagList=this._selectedTagList.filter(e=>String(e.tagId)!==String(t)),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(t){this._categoryId=t,this._emit("category-change",{value:t,customId:this["custom-id"]||"",examId:this["exam-id"]||0})}_imageResources(){return(this["resource-list"]||[]).filter(t=>1===t.resourceType).map(t=>t.resource.middle||t.resource.url).filter(Boolean)}_videoResource(){return(this["resource-list"]||[]).find(t=>2===t.resourceType)?.resource||null}_categoryLabel(){const t=this["category-list"].find(t=>String(t.categoryId)===String(this._categoryId));return t?.title||t?.categoryName||this._categoryId||"未选择分类"}async toJSON(){return new Promise((t,e)=>{const s={customId:this["custom-id"]||void 0,answerType:"blank_fill",orderIndex:this["order-index"]},i=this["is-edit"]?this._title:this.title?.replaceAll(/<filter><\/filter>/g," ______")||"",a=this["is-edit"]?this._answers:(this["answer-list"]||[]).map(t=>({...t,title:this._normalizeAnswerTitle(t),answerId:t?.answerId??t?.examAnswerId})),r=this["is-edit"]?this._analysis:this.analysis||"",n=this["is-edit"]?this._isInOrder:this["exam-answer-setting"]?.isInOrder??!1,h=this["is-edit"]?this._isIgnoreCase:this["exam-answer-setting"]?.isIgnoreCase??!0,c=this["is-edit"]?this._showRichText:!!this["rich-text-content"],d=this["is-edit"]?this._richText:this["rich-text-content"]||"",p=this._selectedTagList||[],g=a.filter(t=>this._normalizeAnswerTitle(t));if(!i)return void e(new o("题目标题不能为空!","EMPTY_TITLE","title",s));if(a.length<1)return void e(new o("至少添加一个填空符!","NO_BLANK","answers",s));const x={answerType:l.BLANK_FILL,title:i.replaceAll(/ ______/g,"<filter></filter>"),answers:g.map(t=>({title:this._normalizeAnswerTitle(t),isCorrect:!0,...t.answerId?{answerId:t.answerId}:{}})),analysis:r,isSetCorrectAnswer:g.length>0,isKey:this["is-key"],examAnswerSettingBO:{isIgnoreCase:h,isInOrder:n},examRichTextContent:c?d:"",categoryId:this._categoryId||"",memberTagInfo:p,tagInfos:p,resourceList:this["resource-list"]||[],examResourceBOList:this["resource-list"]||[]};this["custom-id"]&&(x.customId=this["custom-id"]),t(x)})}async _save(t){t?.stopImmediatePropagation();try{const t=await this.toJSON();this._emit("save",t)}catch(t){!function(t){const e=document.createElement("div");e.textContent=t,Object.assign(e.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(e),setTimeout(()=>{e.style.opacity="0",setTimeout(()=>e.remove(),300)},2500)}(t.message)}}validate(){const t=[],e={customId:this["custom-id"]||void 0,answerType:"blank_fill",orderIndex:this["order-index"]},s=this["is-edit"]?this._title:this.title?.replaceAll(/<filter><\/filter>/g," ______")||"",i=this["is-edit"]?this._answers:(this["answer-list"]||[]).map(t=>({...t,title:this._normalizeAnswerTitle(t)}));return s||t.push(new o("题目标题不能为空!","EMPTY_TITLE","title",e)),i.length<1&&t.push(new o("至少添加一个填空符!","NO_BLANK","answers",e)),t}_renderPreview(){const e=this.title.replaceAll(/<filter><\/filter>/g," ______"),s=this["is-edit"]?this._answers:(this["answer-list"]||[]).map(t=>({...t,title:this._normalizeAnswerTitle(t)}));return t`
6
6
  <div class="preview">
7
7
  <span class="title">${this["order-index"]+1}.${e}(填空题)</span>
8
8
  ${this["rich-text-content"]?t`<div class="rich-text" .innerHTML=${this["rich-text-content"]}></div>`:""}
9
- ${i.some(t=>t.title)?t`
9
+ ${s.some(t=>t.title)?t`
10
10
  <div class="content flex flex-wrap">
11
11
  <span>正确答案:</span>
12
- ${i.map((e,i)=>e.title?t`
13
- <span style="margin-right:10px">填空${i+1}: ${e.title}</span>
14
- `:"")}
12
+ ${s.map((e,s)=>e.title?t`<span style="margin-right:10px">填空${s+1}: ${e.title}</span>`:"")}
15
13
  </div>
16
14
  `:""}
17
15
  ${this.analysis?t`<div style="color:#909399;font-size:12px;margin-top:8px">解析: ${this.analysis}</div>`:""}
16
+ ${this["show-category"]&&this._categoryId?t`<div class="section-row"><span class="value-text">分类:${this._categoryLabel()}</span></div>`:""}
17
+ ${this["show-tag"]&&this._selectedTagList.length?t`
18
+ <div class="section-row">
19
+ <span class="value-text">标签/关键信息:</span>
20
+ <div class="tag-list" style="margin-top:6px">
21
+ ${this._selectedTagList.map(e=>t`<span class="tag-item">${e.tagName}</span>`)}
22
+ </div>
23
+ </div>
24
+ `:""}
25
+ ${this._renderResourceSection()}
26
+ </div>
27
+ `}_renderTagSection(){return this["show-tag"]?t`
28
+ <div class="flex flex-items-start section-row">
29
+ <div class="label"><span>标签:</span></div>
30
+ <div style="flex:1">
31
+ <div class="tag-list">
32
+ ${this._selectedTagList.length?this._selectedTagList.map(e=>t`
33
+ <span class="tag-item">
34
+ ${e.tagName}
35
+ ${this["is-save"]?"":t`<span class="close" @click=${()=>this._removeTag(e.tagId)}>×</span>`}
36
+ </span>
37
+ `):t`<span class="tag-hint">暂无标签/关键信息</span>`}
38
+ </div>
39
+ ${this["is-edit"]&&!this["is-save"]?t`<div style="margin-top:8px"><span class="el-link" @click=${()=>this._chooseTag()}>选择</span></div>`:""}
40
+ </div>
41
+ </div>
42
+ `:""}_renderCategorySection(){return this["show-category"]?t`
43
+ <div class="flex flex-items-start section-row">
44
+ <div class="label"><span>分类:</span></div>
45
+ <div style="flex:1">
46
+ ${this["is-edit"]?t`
47
+ <select class="el-select" .value=${String(this._categoryId)} ?disabled=${this["is-save"]}
48
+ @change=${t=>this._onCategoryChange(t.target.value)}>
49
+ <option value="">选择分类</option>
50
+ ${this["category-list"].map(e=>t`
51
+ <option value=${String(e.categoryId)} ?selected=${String(e.categoryId)===String(this._categoryId)}>${e.title||e.categoryName}</option>
52
+ `)}
53
+ </select>
54
+ `:t`<span class="value-text">${this._categoryLabel()}</span>`}
55
+ </div>
56
+ </div>
57
+ `:""}_renderResourceSection(){if(!this["show-resource"])return"";const e=this._imageResources(),s=this._videoResource();return t`
58
+ <div class="flex flex-items-start section-row">
59
+ <div class="label"><span>资源:</span></div>
60
+ <div style="flex:1">
61
+ <div class="resource-summary">图片 ${e.length} 张${s?.url?",含视频资源":""}</div>
62
+ ${e.length?t`
63
+ <div class="resource-thumbs">
64
+ ${e.slice(0,4).map(e=>t`<img class="resource-thumb" src=${e} alt="resource" />`)}
65
+ </div>
66
+ `:""}
67
+ ${s?.url?t`<div style="margin-top:8px"><a class="el-link" href=${s.url} target="_blank" rel="noreferrer">查看视频</a></div>`:""}
68
+ ${e.length||s?.url?"":t`<div class="tag-hint">暂无资源</div>`}
69
+ </div>
18
70
  </div>
19
71
  `}_renderEdit(){return t`
20
72
  <div class="flex flex-items-start">
@@ -35,30 +87,34 @@ import{html as t,css as e,LitElement as i}from"lit";import{property as s,state a
35
87
  @click=${()=>{this["is-save"]||this._addBlank()}}>插入填空符</span>
36
88
  </div>
37
89
 
38
- ${this["show-answer-setting"]?t`
39
- <div class="flex flex-items-center" style="margin-top:12px">
40
- <div class="label"><span>答题设置:</span></div>
41
- <label class="el-checkbox">
42
- <input type="checkbox" .checked=${this._isInOrder}
43
- @change=${t=>{this._isInOrder=t.target.checked}} />
44
- 答案不分顺序
45
- </label>
46
- <label class="el-checkbox">
47
- <input type="checkbox" .checked=${this._isIgnoreCase}
48
- @change=${t=>{this._isIgnoreCase=t.target.checked}} />
49
- 忽略大小写
50
- </label>
51
- </div>
52
- `:""}
90
+ <div class="flex flex-items-center" style="margin-top:12px">
91
+ <div class="label"><span>答题设置:</span></div>
92
+ <label class="el-checkbox">
93
+ <input type="checkbox" .checked=${this._isInOrder}
94
+ @change=${t=>{this._isInOrder=t.target.checked}} />
95
+ 答案不分顺序
96
+ </label>
97
+ <label class="el-checkbox">
98
+ <input type="checkbox" .checked=${this._isIgnoreCase}
99
+ @change=${t=>{this._isIgnoreCase=t.target.checked}} />
100
+ 忽略大小写
101
+ </label>
102
+ </div>
103
+
104
+ ${this._renderTagSection()}
105
+
106
+ ${this._renderCategorySection()}
107
+
108
+ ${this._renderResourceSection()}
53
109
 
54
- ${this._answers.map((e,i)=>t`
110
+ ${this._answers.map((e,s)=>t`
55
111
  <div class="answer-item" style="margin-top:12px">
56
- <div class="label"><span>第${i+1}空答案:</span></div>
112
+ <div class="label"><span>第${s+1}空答案:</span></div>
57
113
  <div class="answer-tags">
58
- ${e.title.split(",").filter(Boolean).map(i=>t`
114
+ ${e.title.split(",").filter(Boolean).map(s=>t`
59
115
  <span class="el-tag">
60
- ${i}
61
- ${this["is-save"]?"":t`<span class="el-tag__close" @click=${()=>this._closeTag(i,e)}>×</span>`}
116
+ ${s}
117
+ ${this["is-save"]?"":t`<span class="el-tag__close" @click=${()=>this._closeTag(s,e)}>×</span>`}
62
118
  </span>
63
119
  `)}
64
120
  ${this["is-save"]?"":t`
@@ -128,7 +184,7 @@ import{html as t,css as e,LitElement as i}from"lit";import{property as s,state a
128
184
  ></qxs-subject-action>
129
185
  `:""}
130
186
  </qxs-subject-layout>
131
- `}};c.styles=e`
187
+ `}};p.styles=e`
132
188
  :host { display: block; font-family: system-ui, -apple-system, "PingFang SC", "Microsoft YaHei", sans-serif; font-size: 12px; color: #5a5a5a; }
133
189
  *, ::before, ::after { box-sizing: border-box; }
134
190
 
@@ -159,7 +215,6 @@ import{html as t,css as e,LitElement as i}from"lit";import{property as s,state a
159
215
  font-size: 12px; color: #909399; line-height: 1; pointer-events: none;
160
216
  }
161
217
 
162
- /* Tag style */
163
218
  .el-tag {
164
219
  display: inline-flex; align-items: center; height: 24px; padding: 0 9px;
165
220
  font-size: 12px; line-height: 1; color: #3D61E3; background: #ecf5ff;
@@ -172,7 +227,6 @@ import{html as t,css as e,LitElement as i}from"lit";import{property as s,state a
172
227
  }
173
228
  .el-tag .el-tag__close:hover { background: #909399; color: #fff; }
174
229
 
175
- /* Button small style */
176
230
  .el-button--small {
177
231
  display: inline-flex; align-items: center; gap: 4px;
178
232
  height: 24px; padding: 0 10px; font-size: 12px; line-height: 1;
@@ -181,12 +235,10 @@ import{html as t,css as e,LitElement as i}from"lit";import{property as s,state a
181
235
  }
182
236
  .el-button--small:hover { color: #3D61E3; border-color: #c6e2ff; background-color: #ecf5ff; }
183
237
 
184
- /* Link style */
185
238
  .el-link { color: #3D61E3; cursor: pointer; font-size: 12px; text-decoration: none; }
186
239
  .el-link:hover { color: #2D4CB8; }
187
240
  .el-link.is-disabled { color: #c0c4cc; cursor: not-allowed; }
188
241
 
189
- /* Input small for tag */
190
242
  .el-input--small { width: 80px; }
191
243
  .el-input--small input {
192
244
  height: 24px; padding: 0 8px; font-size: 12px; line-height: 24px;
@@ -194,7 +246,6 @@ import{html as t,css as e,LitElement as i}from"lit";import{property as s,state a
194
246
  }
195
247
  .el-input--small input:focus { border-color: #3D61E3; outline: none; }
196
248
 
197
- /* Checkbox style */
198
249
  .el-checkbox {
199
250
  display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
200
251
  font-size: 13px; color: #606266; user-select: none; margin-right: 16px;
@@ -206,5 +257,33 @@ import{html as t,css as e,LitElement as i}from"lit";import{property as s,state a
206
257
  .answer-item { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
207
258
  .answer-item .label { min-width: 70px; padding-top: 0; color: #909399; }
208
259
  .answer-tags { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; flex: 1; }
209
- `,p([s({type:Number,attribute:"order-index"})],c.prototype,"order-index",2),p([s({type:String})],c.prototype,"title",2),p([s({type:String,attribute:"custom-id"})],c.prototype,"custom-id",2),p([s({type:Boolean,attribute:"is-edit"})],c.prototype,"is-edit",2),p([s({type:Boolean,attribute:"is-save"})],c.prototype,"is-save",2),p([s({type:Boolean,attribute:"is-set"})],c.prototype,"is-set",2),p([s({type:Boolean,attribute:"is-key"})],c.prototype,"is-key",2),p([s({type:Boolean,attribute:"show-action"})],c.prototype,"show-action",2),p([s({type:Boolean,attribute:"show-add"})],c.prototype,"show-add",2),p([s({type:Boolean,attribute:"show-answer-setting"})],c.prototype,"show-answer-setting",2),p([s({type:Boolean,attribute:"show-analysis"})],c.prototype,"show-analysis",2),p([s({type:String,attribute:"rich-text-content"})],c.prototype,"rich-text-content",2),p([s({type:String})],c.prototype,"analysis",2),p([s({type:Number,attribute:"exam-answer-relation-type"})],c.prototype,"exam-answer-relation-type",2),p([s({type:String,attribute:"exam-expand"})],c.prototype,"exam-expand",2),p([s({type:Object,attribute:"exam-answer-setting"})],c.prototype,"exam-answer-setting",2),p([s({type:Object,attribute:"upload-image"})],c.prototype,"upload-image",2),p([s({type:Array,attribute:"answer-list"})],c.prototype,"answer-list",2),p([s({type:String,attribute:"model-value"})],c.prototype,"model-value",2),p([s({type:Boolean,attribute:"use-model"})],c.prototype,"use-model",2),p([a()],c.prototype,"_title",2),p([a()],c.prototype,"_analysis",2),p([a()],c.prototype,"_answers",2),p([a()],c.prototype,"_isInOrder",2),p([a()],c.prototype,"_isIgnoreCase",2),p([a()],c.prototype,"_showRichText",2),p([a()],c.prototype,"_richText",2),c=p([l("qxs-blank-fill")],c);export{c as QxsBlankFill};
260
+
261
+ .section-row { margin-top: 12px; }
262
+ .value-text { font-size: 13px; color: #606266; white-space: pre-wrap; }
263
+ .tag-list { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; min-height: 32px; }
264
+ .tag-item {
265
+ display: inline-flex; align-items: center; gap: 4px;
266
+ padding: 4px 8px; font-size: 12px; line-height: 1;
267
+ color: #3D61E3; background: #ecf5ff; border: 1px solid #d9ecff; border-radius: 4px;
268
+ }
269
+ .tag-item .close { cursor: pointer; color: #909399; }
270
+ .tag-item .close:hover { color: #f56c6c; }
271
+ .tag-hint { font-size: 12px; color: #909399; }
272
+
273
+ .el-select {
274
+ width: 150px; height: 32px; border: 1px solid #dcdfe6; border-radius: 3px;
275
+ padding: 0 8px; font-size: 13px; background: #fff; appearance: none;
276
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23c0c4cc' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
277
+ background-repeat: no-repeat; background-position: right 8px center;
278
+ }
279
+ .el-select:focus { border-color: #3D61E3; outline: none; }
280
+ .el-select:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }
281
+
282
+ .resource-summary { font-size: 12px; color: #606266; }
283
+ .resource-thumbs { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 8px; }
284
+ .resource-thumb {
285
+ width: 72px; height: 72px; object-fit: cover; border-radius: 6px;
286
+ border: 1px solid #e4e7ed; background: #f5f7fa;
287
+ }
288
+ `,c([i({type:Number,attribute:"order-index"})],p.prototype,"order-index",2),c([i({type:String})],p.prototype,"title",2),c([i({type:String,attribute:"custom-id"})],p.prototype,"custom-id",2),c([i({type:Boolean,attribute:"is-edit"})],p.prototype,"is-edit",2),c([i({type:Boolean,attribute:"is-save"})],p.prototype,"is-save",2),c([i({type:Boolean,attribute:"is-set"})],p.prototype,"is-set",2),c([i({type:Boolean,attribute:"is-key"})],p.prototype,"is-key",2),c([i({type:Boolean,attribute:"show-action"})],p.prototype,"show-action",2),c([i({type:Boolean,attribute:"show-add"})],p.prototype,"show-add",2),c([i({type:Boolean,attribute:"show-answer-setting"})],p.prototype,"show-answer-setting",2),c([i({type:Boolean,attribute:"show-analysis"})],p.prototype,"show-analysis",2),c([i({type:String,attribute:"rich-text-content"})],p.prototype,"rich-text-content",2),c([i({type:String})],p.prototype,"analysis",2),c([i({type:Number,attribute:"exam-answer-relation-type"})],p.prototype,"exam-answer-relation-type",2),c([i({type:String,attribute:"exam-expand"})],p.prototype,"exam-expand",2),c([i({type:Number,attribute:"exam-id"})],p.prototype,"exam-id",2),c([i({type:String,attribute:"category-id"})],p.prototype,"category-id",2),c([i({type:Object,attribute:"exam-answer-setting"})],p.prototype,"exam-answer-setting",2),c([i({type:Object,attribute:"upload-image"})],p.prototype,"upload-image",2),c([i({type:Array,attribute:"answer-list"})],p.prototype,"answer-list",2),c([i({type:Array,attribute:"tag-list"})],p.prototype,"tag-list",2),c([i({type:Array,attribute:"category-list"})],p.prototype,"category-list",2),c([i({type:Array,attribute:"resource-list"})],p.prototype,"resource-list",2),c([i({type:Boolean,attribute:"show-tag"})],p.prototype,"show-tag",2),c([i({type:Boolean,attribute:"show-category"})],p.prototype,"show-category",2),c([i({type:Boolean,attribute:"show-resource"})],p.prototype,"show-resource",2),c([i({type:String,attribute:"model-value"})],p.prototype,"model-value",2),c([i({type:Boolean,attribute:"use-model"})],p.prototype,"use-model",2),c([a()],p.prototype,"_title",2),c([a()],p.prototype,"_analysis",2),c([a()],p.prototype,"_answers",2),c([a()],p.prototype,"_isInOrder",2),c([a()],p.prototype,"_isIgnoreCase",2),c([a()],p.prototype,"_showRichText",2),c([a()],p.prototype,"_richText",2),c([a()],p.prototype,"_selectedTagList",2),c([a()],p.prototype,"_categoryId",2),p=c([r("qxs-blank-fill")],p);export{p as QxsBlankFill};
210
289
  //# sourceMappingURL=blank-fill.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"blank-fill.mjs","sources":["../../../../packages/components-wc/src/subject/blank-fill.ts"],"sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { property, state } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\nimport { SubjectError } from './single'\nimport { SubjectType } from './types'\n\ninterface BlankAnswer { title: string, tag: string, showInput: boolean }\n\nconst iconPlus = html`\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\"\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <line x1=\"12\" y1=\"5\" x2=\"12\" y2=\"19\"/><line x1=\"5\" y1=\"12\" x2=\"19\" y2=\"12\"/>\n </svg>`\n\nfunction showToast(msg: string) {\n const el = document.createElement('div')\n el.textContent = msg\n Object.assign(el.style, {\n position: 'fixed', top: '20px', left: '50%', transform: 'translateX(-50%)',\n padding: '10px 20px', borderRadius: '4px', fontSize: '13px', color: '#fff',\n background: '#f56c6c', zIndex: '99999', boxShadow: '0 4px 12px rgba(0,0,0,.15)',\n transition: 'opacity .3s', opacity: '1',\n })\n document.body.appendChild(el)\n setTimeout(() => { el.style.opacity = '0'; setTimeout(() => el.remove(), 300) }, 2500)\n}\n\n@safeCustomElement('qxs-blank-fill')\nexport class QxsBlankFill extends LitElement {\n static styles = css`\n :host { display: block; font-family: system-ui, -apple-system, \"PingFang SC\", \"Microsoft YaHei\", sans-serif; font-size: 12px; color: #5a5a5a; }\n *, ::before, ::after { box-sizing: border-box; }\n\n .preview { padding: 12px 0; }\n .preview .title { font-size: 14px; color: #303133; }\n .preview .rich-text { margin-top: 8px; }\n .preview .rich-text img { max-width: 100%; }\n .preview .content { color: #a8abb2; margin-top: 10px; }\n\n .flex { display: flex; }\n .flex-wrap { flex-wrap: wrap; }\n .flex-items-center { display: flex; align-items: center; }\n .flex-items-start { display: flex; align-items: flex-start; }\n .flex-justify-end { display: flex; justify-content: flex-end; }\n .label { min-width: 70px; font-size: 13px; color: #606266; }\n\n textarea {\n border: 1px solid #dcdfe6; border-radius: 3px; padding: 5px 11px;\n font-size: 13px; font-family: inherit; width: 100%; resize: none; transition: border-color .2s;\n line-height: 1.5; display: block; box-sizing: border-box;\n }\n textarea:focus { border-color: #3D61E3; outline: none; }\n textarea:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n .el-input { position: relative; display: block; }\n .el-input textarea { padding-bottom: 24px; }\n .el-input .char-counter {\n position: absolute; right: 12px; bottom: 8px;\n font-size: 12px; color: #909399; line-height: 1; pointer-events: none;\n }\n\n /* Tag style */\n .el-tag {\n display: inline-flex; align-items: center; height: 24px; padding: 0 9px;\n font-size: 12px; line-height: 1; color: #3D61E3; background: #ecf5ff;\n border: 1px solid #d9ecff; border-radius: 4px; white-space: nowrap;\n }\n .el-tag .el-tag__close {\n display: inline-flex; align-items: center; justify-content: center;\n margin-left: 4px; width: 16px; height: 16px; border-radius: 50%;\n font-size: 12px; color: #909399; cursor: pointer; transition: all .2s;\n }\n .el-tag .el-tag__close:hover { background: #909399; color: #fff; }\n\n /* Button small style */\n .el-button--small {\n display: inline-flex; align-items: center; gap: 4px;\n height: 24px; padding: 0 10px; font-size: 12px; line-height: 1;\n border: 1px solid #dcdfe6; border-radius: 3px; background: #fff; color: #606266;\n cursor: pointer; transition: all .2s; white-space: nowrap;\n }\n .el-button--small:hover { color: #3D61E3; border-color: #c6e2ff; background-color: #ecf5ff; }\n\n /* Link style */\n .el-link { color: #3D61E3; cursor: pointer; font-size: 12px; text-decoration: none; }\n .el-link:hover { color: #2D4CB8; }\n .el-link.is-disabled { color: #c0c4cc; cursor: not-allowed; }\n\n /* Input small for tag */\n .el-input--small { width: 80px; }\n .el-input--small input {\n height: 24px; padding: 0 8px; font-size: 12px; line-height: 24px;\n border: 1px solid #dcdfe6; border-radius: 3px; width: 100%;\n }\n .el-input--small input:focus { border-color: #3D61E3; outline: none; }\n\n /* Checkbox style */\n .el-checkbox {\n display: inline-flex; align-items: center; gap: 6px; cursor: pointer;\n font-size: 13px; color: #606266; user-select: none; margin-right: 16px;\n }\n .el-checkbox input[type=\"checkbox\"] {\n width: 14px; height: 14px; cursor: pointer; accent-color: #3D61E3;\n }\n\n .answer-item { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }\n .answer-item .label { min-width: 70px; padding-top: 0; color: #909399; }\n .answer-tags { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; flex: 1; }\n `\n\n @property({ type: Number, attribute: 'order-index' }) 'order-index' = 0\n @property({ type: String }) title = ''\n @property({ type: String, attribute: 'custom-id' }) 'custom-id' = ''\n @property({ type: Boolean, attribute: 'is-edit' }) 'is-edit' = false\n @property({ type: Boolean, attribute: 'is-save' }) 'is-save' = false\n @property({ type: Boolean, attribute: 'is-set' }) 'is-set' = false\n @property({ type: Boolean, attribute: 'is-key' }) 'is-key' = false\n @property({ type: Boolean, attribute: 'show-action' }) 'show-action' = true\n @property({ type: Boolean, attribute: 'show-add' }) 'show-add' = true\n @property({ type: Boolean, attribute: 'show-answer-setting' }) 'show-answer-setting' = false\n @property({ type: Boolean, attribute: 'show-analysis' }) 'show-analysis' = true\n @property({ type: String, attribute: 'rich-text-content' }) 'rich-text-content' = ''\n @property({ type: String }) analysis = ''\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) 'exam-answer-relation-type' = 0\n @property({ type: String, attribute: 'exam-expand' }) 'exam-expand' = ''\n @property({ type: Object, attribute: 'exam-answer-setting' })\n 'exam-answer-setting': { isInOrder: boolean, isIgnoreCase: boolean } = { isInOrder: false, isIgnoreCase: true }\n\n @property({ type: Object, attribute: 'upload-image' })\n 'upload-image': (file: File) => Promise<string> = async (file: File) => {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.onload = e => resolve(e.target?.result as string)\n reader.onerror = reject\n reader.readAsDataURL(file)\n })\n }\n\n @property({ type: Array, attribute: 'answer-list' }) 'answer-list': any[] = []\n\n // 双向绑定支持\n @property({ type: String, attribute: 'model-value' }) 'model-value' = ''\n @property({ type: Boolean, attribute: 'use-model' }) 'use-model' = false\n\n @state() private _title = ''\n @state() private _analysis = ''\n @state() private _answers: BlankAnswer[] = [{ title: '', tag: '', showInput: false }]\n @state() private _isInOrder = false\n @state() private _isIgnoreCase = true\n @state() private _showRichText = false\n @state() private _richText = ''\n\n private readonly TITLE_MAX = 400\n\n willUpdate(changed: Map<string, unknown>) {\n if (changed.has('is-edit') && this['is-edit']) { this._syncProps() }\n if (!this['is-edit'] && (changed.has('title') || changed.has('answer-list') || changed.has('analysis') || changed.has('exam-answer-setting') || changed.has('rich-text-content'))) {\n this._syncProps()\n }\n // 当外部 modelValue 变化时同步内部状态\n if (changed.has('model-value') && this['use-model']) {\n this._title = this['model-value'].replaceAll(/<filter><\\/filter>/g, ' ______')\n }\n }\n\n private _normalizeAnswerTitle(answer: any) {\n return String(answer?.title ?? answer?.answer ?? '')\n }\n\n private _syncProps() {\n this._title = (this.title || '').replaceAll(/<filter><\\/filter>/g, ' ______')\n this._analysis = this.analysis || ''\n if (this['answer-list']?.length) {\n this._answers = this['answer-list'].map((a: any) => ({ title: this._normalizeAnswerTitle(a), tag: '', showInput: false }))\n }\n else {\n const blankCount = (this._title.match(/ ______/g) || []).length || 1\n this._answers = Array.from({ length: blankCount }, () => ({ title: '', tag: '', showInput: false }))\n }\n if (this['exam-answer-setting']) {\n this._isInOrder = !!this['exam-answer-setting'].isInOrder\n this._isIgnoreCase = !!this['exam-answer-setting'].isIgnoreCase\n }\n this._richText = this['rich-text-content'] || ''\n this._showRichText = !!this['rich-text-content']\n }\n\n private _emit(name: string, detail?: unknown) {\n this.dispatchEvent(new CustomEvent(name, { bubbles: true, composed: true, detail: detail ?? null }))\n }\n\n private _addBlank() {\n this._title += ' ______'\n this._answers = [...this._answers, { title: '', tag: '', showInput: false }]\n this.requestUpdate()\n this._emitModelUpdate()\n }\n\n private _onTitleInput(e: Event) {\n const el = e.target as HTMLTextAreaElement\n if (el.value.length > this.TITLE_MAX) { el.value = el.value.slice(0, this.TITLE_MAX) }\n this._title = el.value\n const blankCount = (this._title.match(/ ______/g) || []).length\n if (blankCount !== this._answers.length) {\n if (blankCount > this._answers.length) {\n for (let i = this._answers.length; i < blankCount; i++) {\n this._answers = [...this._answers, { title: '', tag: '', showInput: false }]\n }\n }\n else {\n this._answers = this._answers.slice(0, blankCount)\n }\n }\n this._emitModelUpdate()\n }\n\n // 双向绑定:通知外部更新\n private _emitModelUpdate() {\n if (this['use-model']) {\n const modelValue = this._title.replaceAll(/ ______/g, '<filter></filter>')\n this.dispatchEvent(new CustomEvent('update:modelValue', {\n bubbles: true,\n composed: true,\n detail: modelValue,\n }))\n }\n }\n\n private _handleAddTag(item: BlankAnswer) {\n item.showInput = false\n if (item.tag) {\n item.title = item.title ? [item.title, item.tag].join(',') : item.tag\n item.tag = ''\n }\n this.requestUpdate()\n }\n\n private _closeTag(tag: string, item: BlankAnswer) {\n if (tag) {\n const tags = item.title.split(',')\n const idx = tags.findIndex((t: string) => t === tag)\n if (idx > -1) { tags.splice(idx, 1); item.title = tags.join(',') }\n this.requestUpdate()\n }\n }\n\n async toJSON(): Promise<any> {\n return new Promise((resolve, reject) => {\n const row = { customId: this['custom-id'] || undefined, answerType: 'blank_fill', orderIndex: this['order-index'] }\n\n const title = this['is-edit'] ? this._title : this.title?.replaceAll(/<filter><\\/filter>/g, ' ______') || ''\n const answers = this['is-edit'] ? this._answers : (this['answer-list'] || []).map((answer: any) => ({ ...answer, title: this._normalizeAnswerTitle(answer) }))\n const analysis = this['is-edit'] ? this._analysis : this.analysis || ''\n const isInOrder = this['is-edit'] ? this._isInOrder : this['exam-answer-setting']?.isInOrder ?? false\n const isIgnoreCase = this['is-edit'] ? this._isIgnoreCase : this['exam-answer-setting']?.isIgnoreCase ?? true\n const showRichText = this['is-edit'] ? this._showRichText : !!this['rich-text-content']\n const richText = this['is-edit'] ? this._richText : this['rich-text-content'] || ''\n\n if (!title) {\n reject(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n return\n }\n if (answers.length < 1) {\n reject(new SubjectError('至少添加一个填空符!', 'NO_BLANK', 'answers', row))\n return\n }\n const result: any = {\n answerType: SubjectType.BLANK_FILL,\n title: title.replaceAll(/ ______/g, '<filter></filter>'),\n answers: answers.map((a: any) => ({ title: a.title, isCorrect: true })),\n analysis,\n isSetCorrectAnswer: true,\n isKey: this['is-key'],\n examAnswerSettingBO: { isIgnoreCase, isInOrder },\n examRichTextContent: showRichText ? richText : '',\n }\n if (this['custom-id']) { result.customId = this['custom-id'] }\n resolve(result)\n })\n }\n\n private async _save(e?: Event) {\n e?.stopImmediatePropagation()\n try {\n const data = await this.toJSON()\n this._emit('save', data)\n }\n catch (err: any) {\n showToast(err.message)\n }\n }\n\n validate(): SubjectError[] {\n const errors: SubjectError[] = []\n const row = { customId: this['custom-id'] || undefined, answerType: 'blank_fill', orderIndex: this['order-index'] }\n\n const title = this['is-edit'] ? this._title : this.title?.replaceAll(/<filter><\\/filter>/g, ' ______') || ''\n const answers = this['is-edit'] ? this._answers : (this['answer-list'] || []).map((answer: any) => ({ ...answer, title: this._normalizeAnswerTitle(answer) }))\n\n if (!title) {\n errors.push(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n }\n if (answers.length < 1) {\n errors.push(new SubjectError('至少添加一个填空符!', 'NO_BLANK', 'answers', row))\n }\n\n return errors\n }\n\n private _renderPreview() {\n const displayTitle = this.title.replaceAll(/<filter><\\/filter>/g, ' ______')\n const previewAnswers = this['is-edit'] ? this._answers : (this['answer-list'] || []).map((answer: any) => ({ ...answer, title: this._normalizeAnswerTitle(answer) }))\n return html`\n <div class=\"preview\">\n <span class=\"title\">${this['order-index'] + 1}.${displayTitle}(填空题)</span>\n ${this['rich-text-content'] ? html`<div class=\"rich-text\" .innerHTML=${this['rich-text-content']}></div>` : ''}\n ${previewAnswers.some(a => a.title)\n ? html`\n <div class=\"content flex flex-wrap\">\n <span>正确答案:</span>\n ${previewAnswers.map((a, i) => a.title\n ? html`\n <span style=\"margin-right:10px\">填空${i + 1}: ${a.title}</span>\n `\n : '')}\n </div>\n `\n : ''}\n ${this.analysis ? html`<div style=\"color:#909399;font-size:12px;margin-top:8px\">解析: ${this.analysis}</div>` : ''}\n </div>\n `\n }\n\n private _renderEdit() {\n return html`\n <div class=\"flex flex-items-start\">\n <div class=\"label\"><span>题目:</span></div>\n <div style=\"flex:1\">\n <div class=\"el-input\">\n <textarea rows=\"3\" .value=${this._title} ?disabled=${this['is-save']}\n maxlength=${this.TITLE_MAX}\n @input=${(e: Event) => this._onTitleInput(e)}\n placeholder=\"【填空题】请输入问题\"></textarea>\n <span class=\"char-counter\">${this._title.length}/${this.TITLE_MAX}</span>\n </div>\n </div>\n </div>\n\n <div class=\"flex flex-justify-end\">\n <span class=\"el-link ${this['is-save'] ? 'is-disabled' : ''}\"\n @click=${() => {\n if (!this['is-save']) { this._addBlank() }\n }}>插入填空符</span>\n </div>\n\n ${this['show-answer-setting']\n ? html`\n <div class=\"flex flex-items-center\" style=\"margin-top:12px\">\n <div class=\"label\"><span>答题设置:</span></div>\n <label class=\"el-checkbox\">\n <input type=\"checkbox\" .checked=${this._isInOrder}\n @change=${(e: Event) => { this._isInOrder = (e.target as HTMLInputElement).checked }} />\n 答案不分顺序\n </label>\n <label class=\"el-checkbox\">\n <input type=\"checkbox\" .checked=${this._isIgnoreCase}\n @change=${(e: Event) => { this._isIgnoreCase = (e.target as HTMLInputElement).checked }} />\n 忽略大小写\n </label>\n </div>\n `\n : ''}\n\n ${this._answers.map((a, i) => html`\n <div class=\"answer-item\" style=\"margin-top:12px\">\n <div class=\"label\"><span>第${i + 1}空答案:</span></div>\n <div class=\"answer-tags\">\n ${a.title.split(',').filter(Boolean).map(tag => html`\n <span class=\"el-tag\">\n ${tag}\n ${!this['is-save'] ? html`<span class=\"el-tag__close\" @click=${() => this._closeTag(tag, a)}>×</span>` : ''}\n </span>\n `)}\n ${!this['is-save']\n ? html`\n ${a.showInput\n ? html`\n <input type=\"text\" class=\"el-input--small\"\n @keydown=${(e: KeyboardEvent) => {\n if (e.key === 'Enter') { this._handleAddTag(a) }\n }}\n @input=${(e: Event) => { a.tag = (e.target as HTMLInputElement).value }}\n @blur=${() => this._handleAddTag(a)} />\n `\n : html`\n <span class=\"el-button--small\" @click=${() => { a.showInput = true; this.requestUpdate(); this.updateComplete.then(() => { (this.shadowRoot?.querySelector('.el-input--small') as HTMLInputElement)?.focus() }) }}>\n ${iconPlus}\n <span>${a.title ? '添加同义词' : '添加答案'}</span>\n </span>\n `}\n `\n : ''}\n </div>\n </div>\n `)}\n\n ${this._showRichText\n ? html`\n <div class=\"flex flex-items-start\" style=\"margin-top:12px\">\n <div class=\"label\"><span>富文本:</span></div>\n <div style=\"flex:1\">\n <qxs-blocksuite-editor\n .content=${this._richText}\n .upload-image=${this['upload-image']}\n ?is-edit=${true}\n ></qxs-blocksuite-editor>\n ${!this['show-action']\n ? html`\n <div class=\"flex flex-justify-end\" style=\"margin-top:8px\">\n <span class=\"el-link\" style=\"color:#f56c6c\" @click=${() => { this._showRichText = false; this._richText = '' }}>删除富文本</span>\n </div>\n `\n : ''}\n </div>\n </div>\n `\n : ''}\n\n ${this['show-analysis']\n ? html`\n <div class=\"flex flex-items-start\" style=\"margin-top:12px\">\n <div class=\"label\"><span>解析:</span></div>\n <div style=\"flex:1\">\n <div class=\"el-input\">\n <textarea rows=\"2\" .value=${this._analysis}\n @input=${(e: Event) => { this._analysis = (e.target as HTMLTextAreaElement).value }}\n placeholder=\"请输入题目解析\"></textarea>\n </div>\n </div>\n </div>\n `\n : ''}\n `\n }\n\n render() {\n return html`\n <qxs-subject-layout .show-edit=${this['is-edit']}>\n <div slot=\"preview\">${this._renderPreview()}</div>\n <div slot=\"edit\">${this._renderEdit()}</div>\n ${this['show-action']\n ? html`\n <qxs-subject-action\n .is-edit=${this['is-edit']}\n .is-set=${this['is-set']}\n .show-add=${this['show-add']}\n .show-rich-text=${this._showRichText}\n exam-answer-relation-type=${this['exam-answer-relation-type']}\n @delete=${() => this._emit('delete')}\n @save=${this._save}\n @edit=${() => this._emit('edit')}\n @add=${(e: CustomEvent) => this._emit('add', e.detail)}\n @set-key=${(e: CustomEvent) => { this._emit('set-key', e.detail) }}\n @on-show-rich-text=${() => {\n this._showRichText = !this._showRichText\n if (!this._showRichText) {\n this._richText = ''\n }\n }}\n ></qxs-subject-action>\n `\n : ''}\n </qxs-subject-layout>\n `\n }\n}\n\nexport function register() {}\n"],"names":["iconPlus","html","QxsBlankFill","LitElement","constructor","super","arguments","this","title","analysis","isInOrder","isIgnoreCase","async","Promise","resolve","reject","reader","FileReader","onload","e","target","result","onerror","readAsDataURL","file","_title","_analysis","_answers","tag","showInput","_isInOrder","_isIgnoreCase","_showRichText","_richText","TITLE_MAX","willUpdate","changed","has","_syncProps","replaceAll","_normalizeAnswerTitle","answer","String","length","map","a","blankCount","match","Array","from","_emit","name","detail","dispatchEvent","CustomEvent","bubbles","composed","_addBlank","requestUpdate","_emitModelUpdate","_onTitleInput","el","value","slice","i","modelValue","_handleAddTag","item","join","_closeTag","tags","split","idx","findIndex","t","splice","toJSON","row","customId","answerType","orderIndex","answers","showRichText","richText","SubjectError","SubjectType","BLANK_FILL","isCorrect","isSetCorrectAnswer","isKey","examAnswerSettingBO","examRichTextContent","_save","stopImmediatePropagation","data","err","msg","document","createElement","textContent","Object","assign","style","position","top","left","transform","padding","borderRadius","fontSize","color","background","zIndex","boxShadow","transition","opacity","body","appendChild","setTimeout","remove","showToast","message","validate","errors","push","_renderPreview","displayTitle","previewAnswers","some","_renderEdit","checked","filter","Boolean","key","updateComplete","then","shadowRoot","querySelector","focus","render","styles","css","__decorateClass","property","type","Number","attribute","prototype","state","safeCustomElement"],"mappings":"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"}
1
+ {"version":3,"file":"blank-fill.mjs","sources":["../../../../packages/components-wc/src/subject/blank-fill.ts"],"sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { property, state } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\nimport { type Category, type Resource, SubjectError, type TagItem } from './single'\nimport { SubjectType } from './types'\n\ninterface BlankAnswer {\n title: string\n tag: string\n showInput: boolean\n answerId?: string | number\n}\n\nconst iconPlus = html`\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\"\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <line x1=\"12\" y1=\"5\" x2=\"12\" y2=\"19\"/><line x1=\"5\" y1=\"12\" x2=\"19\" y2=\"12\"/>\n </svg>`\n\nfunction showToast(msg: string) {\n const el = document.createElement('div')\n el.textContent = msg\n Object.assign(el.style, {\n position: 'fixed', top: '20px', left: '50%', transform: 'translateX(-50%)',\n padding: '10px 20px', borderRadius: '4px', fontSize: '13px', color: '#fff',\n background: '#f56c6c', zIndex: '99999', boxShadow: '0 4px 12px rgba(0,0,0,.15)',\n transition: 'opacity .3s', opacity: '1',\n })\n document.body.appendChild(el)\n setTimeout(() => { el.style.opacity = '0'; setTimeout(() => el.remove(), 300) }, 2500)\n}\n\n@safeCustomElement('qxs-blank-fill')\nexport class QxsBlankFill extends LitElement {\n static styles = css`\n :host { display: block; font-family: system-ui, -apple-system, \"PingFang SC\", \"Microsoft YaHei\", sans-serif; font-size: 12px; color: #5a5a5a; }\n *, ::before, ::after { box-sizing: border-box; }\n\n .preview { padding: 12px 0; }\n .preview .title { font-size: 14px; color: #303133; }\n .preview .rich-text { margin-top: 8px; }\n .preview .rich-text img { max-width: 100%; }\n .preview .content { color: #a8abb2; margin-top: 10px; }\n\n .flex { display: flex; }\n .flex-wrap { flex-wrap: wrap; }\n .flex-items-center { display: flex; align-items: center; }\n .flex-items-start { display: flex; align-items: flex-start; }\n .flex-justify-end { display: flex; justify-content: flex-end; }\n .label { min-width: 70px; font-size: 13px; color: #606266; }\n\n textarea {\n border: 1px solid #dcdfe6; border-radius: 3px; padding: 5px 11px;\n font-size: 13px; font-family: inherit; width: 100%; resize: none; transition: border-color .2s;\n line-height: 1.5; display: block; box-sizing: border-box;\n }\n textarea:focus { border-color: #3D61E3; outline: none; }\n textarea:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n .el-input { position: relative; display: block; }\n .el-input textarea { padding-bottom: 24px; }\n .el-input .char-counter {\n position: absolute; right: 12px; bottom: 8px;\n font-size: 12px; color: #909399; line-height: 1; pointer-events: none;\n }\n\n .el-tag {\n display: inline-flex; align-items: center; height: 24px; padding: 0 9px;\n font-size: 12px; line-height: 1; color: #3D61E3; background: #ecf5ff;\n border: 1px solid #d9ecff; border-radius: 4px; white-space: nowrap;\n }\n .el-tag .el-tag__close {\n display: inline-flex; align-items: center; justify-content: center;\n margin-left: 4px; width: 16px; height: 16px; border-radius: 50%;\n font-size: 12px; color: #909399; cursor: pointer; transition: all .2s;\n }\n .el-tag .el-tag__close:hover { background: #909399; color: #fff; }\n\n .el-button--small {\n display: inline-flex; align-items: center; gap: 4px;\n height: 24px; padding: 0 10px; font-size: 12px; line-height: 1;\n border: 1px solid #dcdfe6; border-radius: 3px; background: #fff; color: #606266;\n cursor: pointer; transition: all .2s; white-space: nowrap;\n }\n .el-button--small:hover { color: #3D61E3; border-color: #c6e2ff; background-color: #ecf5ff; }\n\n .el-link { color: #3D61E3; cursor: pointer; font-size: 12px; text-decoration: none; }\n .el-link:hover { color: #2D4CB8; }\n .el-link.is-disabled { color: #c0c4cc; cursor: not-allowed; }\n\n .el-input--small { width: 80px; }\n .el-input--small input {\n height: 24px; padding: 0 8px; font-size: 12px; line-height: 24px;\n border: 1px solid #dcdfe6; border-radius: 3px; width: 100%;\n }\n .el-input--small input:focus { border-color: #3D61E3; outline: none; }\n\n .el-checkbox {\n display: inline-flex; align-items: center; gap: 6px; cursor: pointer;\n font-size: 13px; color: #606266; user-select: none; margin-right: 16px;\n }\n .el-checkbox input[type=\"checkbox\"] {\n width: 14px; height: 14px; cursor: pointer; accent-color: #3D61E3;\n }\n\n .answer-item { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }\n .answer-item .label { min-width: 70px; padding-top: 0; color: #909399; }\n .answer-tags { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; flex: 1; }\n\n .section-row { margin-top: 12px; }\n .value-text { font-size: 13px; color: #606266; white-space: pre-wrap; }\n .tag-list { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; min-height: 32px; }\n .tag-item {\n display: inline-flex; align-items: center; gap: 4px;\n padding: 4px 8px; font-size: 12px; line-height: 1;\n color: #3D61E3; background: #ecf5ff; border: 1px solid #d9ecff; border-radius: 4px;\n }\n .tag-item .close { cursor: pointer; color: #909399; }\n .tag-item .close:hover { color: #f56c6c; }\n .tag-hint { font-size: 12px; color: #909399; }\n\n .el-select {\n width: 150px; height: 32px; border: 1px solid #dcdfe6; border-radius: 3px;\n padding: 0 8px; font-size: 13px; background: #fff; appearance: none;\n background-image: url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23c0c4cc' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E\");\n background-repeat: no-repeat; background-position: right 8px center;\n }\n .el-select:focus { border-color: #3D61E3; outline: none; }\n .el-select:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n\n .resource-summary { font-size: 12px; color: #606266; }\n .resource-thumbs { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 8px; }\n .resource-thumb {\n width: 72px; height: 72px; object-fit: cover; border-radius: 6px;\n border: 1px solid #e4e7ed; background: #f5f7fa;\n }\n `\n\n @property({ type: Number, attribute: 'order-index' }) 'order-index' = 0\n @property({ type: String }) title = ''\n @property({ type: String, attribute: 'custom-id' }) 'custom-id' = ''\n @property({ type: Boolean, attribute: 'is-edit' }) 'is-edit' = false\n @property({ type: Boolean, attribute: 'is-save' }) 'is-save' = false\n @property({ type: Boolean, attribute: 'is-set' }) 'is-set' = false\n @property({ type: Boolean, attribute: 'is-key' }) 'is-key' = false\n @property({ type: Boolean, attribute: 'show-action' }) 'show-action' = true\n @property({ type: Boolean, attribute: 'show-add' }) 'show-add' = true\n @property({ type: Boolean, attribute: 'show-answer-setting' }) 'show-answer-setting' = false\n @property({ type: Boolean, attribute: 'show-analysis' }) 'show-analysis' = true\n @property({ type: String, attribute: 'rich-text-content' }) 'rich-text-content' = ''\n @property({ type: String }) analysis = ''\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) 'exam-answer-relation-type' = 0\n @property({ type: String, attribute: 'exam-expand' }) 'exam-expand' = ''\n @property({ type: Number, attribute: 'exam-id' }) 'exam-id' = 0\n @property({ type: String, attribute: 'category-id' }) 'category-id' = ''\n @property({ type: Object, attribute: 'exam-answer-setting' })\n 'exam-answer-setting': { isInOrder: boolean, isIgnoreCase: boolean } = { isInOrder: false, isIgnoreCase: true }\n\n @property({ type: Object, attribute: 'upload-image' })\n 'upload-image': (file: File) => Promise<string> = async (file: File) => {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.onload = e => resolve(e.target?.result as string)\n reader.onerror = reject\n reader.readAsDataURL(file)\n })\n }\n\n @property({ type: Array, attribute: 'answer-list' }) 'answer-list': any[] = []\n @property({ type: Array, attribute: 'tag-list' }) 'tag-list': TagItem[] = []\n @property({ type: Array, attribute: 'category-list' }) 'category-list': Category[] = []\n @property({ type: Array, attribute: 'resource-list' }) 'resource-list': Resource[] = []\n @property({ type: Boolean, attribute: 'show-tag' }) 'show-tag' = false\n @property({ type: Boolean, attribute: 'show-category' }) 'show-category' = false\n @property({ type: Boolean, attribute: 'show-resource' }) 'show-resource' = false\n\n @property({ type: String, attribute: 'model-value' }) 'model-value' = ''\n @property({ type: Boolean, attribute: 'use-model' }) 'use-model' = false\n\n @state() private _title = ''\n @state() private _analysis = ''\n @state() private _answers: BlankAnswer[] = [{ title: '', tag: '', showInput: false }]\n @state() private _isInOrder = false\n @state() private _isIgnoreCase = true\n @state() private _showRichText = false\n @state() private _richText = ''\n @state() private _selectedTagList: TagItem[] = []\n @state() private _categoryId = ''\n\n private readonly TITLE_MAX = 400\n\n willUpdate(changed: Map<string, unknown>) {\n if (changed.has('is-edit') && this['is-edit']) { this._syncProps() }\n if (!this['is-edit'] && (changed.has('title') || changed.has('answer-list') || changed.has('analysis') || changed.has('exam-answer-setting') || changed.has('rich-text-content') || changed.has('tag-list') || changed.has('category-id'))) {\n this._syncProps()\n }\n if (changed.has('model-value') && this['use-model']) {\n this._title = this['model-value'].replaceAll(/<filter><\\/filter>/g, ' ______')\n }\n if (changed.has('tag-list')) {\n this._selectedTagList = Array.isArray(this['tag-list']) ? this['tag-list'].map(item => ({ ...item })) : []\n }\n if (changed.has('category-id')) {\n this._categoryId = this['category-id'] ? String(this['category-id']) : ''\n }\n }\n\n private _normalizeAnswerTitle(answer: any) {\n return String(answer?.title ?? answer?.answer ?? '')\n }\n\n private _syncProps() {\n this._title = (this.title || '').replaceAll(/<filter><\\/filter>/g, ' ______')\n this._analysis = this.analysis || ''\n if (this['answer-list']?.length) {\n this._answers = this['answer-list'].map((a: any) => ({\n title: this._normalizeAnswerTitle(a),\n tag: '',\n showInput: false,\n answerId: a?.answerId ?? a?.examAnswerId,\n }))\n }\n else {\n const blankCount = (this._title.match(/ ______/g) || []).length || 1\n this._answers = Array.from({ length: blankCount }, () => ({ title: '', tag: '', showInput: false }))\n }\n if (this['exam-answer-setting']) {\n this._isInOrder = !!this['exam-answer-setting'].isInOrder\n this._isIgnoreCase = !!this['exam-answer-setting'].isIgnoreCase\n }\n this._richText = this['rich-text-content'] || ''\n this._showRichText = !!this['rich-text-content']\n this._selectedTagList = Array.isArray(this['tag-list']) ? this['tag-list'].map(item => ({ ...item })) : []\n this._categoryId = this['category-id'] ? String(this['category-id']) : ''\n }\n\n private _emit(name: string, detail?: unknown) {\n this.dispatchEvent(new CustomEvent(name, { bubbles: true, composed: true, detail: detail ?? null }))\n }\n\n private _addBlank() {\n this._title += ' ______'\n this._answers = [...this._answers, { title: '', tag: '', showInput: false }]\n this.requestUpdate()\n this._emitModelUpdate()\n }\n\n private _onTitleInput(e: Event) {\n const el = e.target as HTMLTextAreaElement\n if (el.value.length > this.TITLE_MAX) { el.value = el.value.slice(0, this.TITLE_MAX) }\n this._title = el.value\n const blankCount = (this._title.match(/ ______/g) || []).length\n if (blankCount !== this._answers.length) {\n if (blankCount > this._answers.length) {\n for (let i = this._answers.length; i < blankCount; i++) {\n this._answers = [...this._answers, { title: '', tag: '', showInput: false }]\n }\n }\n else {\n this._answers = this._answers.slice(0, blankCount)\n }\n }\n this._emitModelUpdate()\n }\n\n private _emitModelUpdate() {\n if (this['use-model']) {\n const modelValue = this._title.replaceAll(/ ______/g, '<filter></filter>')\n this.dispatchEvent(new CustomEvent('update:modelValue', {\n bubbles: true,\n composed: true,\n detail: modelValue,\n }))\n }\n }\n\n private _handleAddTag(item: BlankAnswer) {\n item.showInput = false\n if (item.tag) {\n item.title = item.title ? [item.title, item.tag].join(',') : item.tag\n item.tag = ''\n }\n this.requestUpdate()\n }\n\n private _closeTag(tag: string, item: BlankAnswer) {\n if (!tag) { return }\n const tags = item.title.split(',')\n const idx = tags.findIndex((t: string) => t === tag)\n if (idx > -1) {\n tags.splice(idx, 1)\n item.title = tags.join(',')\n }\n this.requestUpdate()\n }\n\n private _removeTag(tagId: string | number) {\n this._selectedTagList = this._selectedTagList.filter(item => String(item.tagId) !== String(tagId))\n this._emit('tag-change', {\n value: this._selectedTagList,\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n })\n }\n\n private _chooseTag() {\n this._emit('choose-tag', {\n value: this._selectedTagList,\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n })\n }\n\n private _onCategoryChange(value: string) {\n this._categoryId = value\n this._emit('category-change', {\n value,\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n })\n }\n\n private _imageResources() {\n return (this['resource-list'] || [])\n .filter(item => item.resourceType === 1)\n .map(item => item.resource.middle || item.resource.url)\n .filter(Boolean) as string[]\n }\n\n private _videoResource() {\n return (this['resource-list'] || []).find(item => item.resourceType === 2)?.resource || null\n }\n\n private _categoryLabel() {\n const matched = this['category-list'].find((item: any) => String(item.categoryId) === String(this._categoryId))\n return matched?.title || matched?.categoryName || this._categoryId || '未选择分类'\n }\n\n async toJSON(): Promise<any> {\n return new Promise((resolve, reject) => {\n const row = { customId: this['custom-id'] || undefined, answerType: 'blank_fill', orderIndex: this['order-index'] }\n\n const title = this['is-edit'] ? this._title : this.title?.replaceAll(/<filter><\\/filter>/g, ' ______') || ''\n const answers = this['is-edit']\n ? this._answers\n : (this['answer-list'] || []).map((answer: any) => ({\n ...answer,\n title: this._normalizeAnswerTitle(answer),\n answerId: answer?.answerId ?? answer?.examAnswerId,\n }))\n const analysis = this['is-edit'] ? this._analysis : this.analysis || ''\n const isInOrder = this['is-edit'] ? this._isInOrder : this['exam-answer-setting']?.isInOrder ?? false\n const isIgnoreCase = this['is-edit'] ? this._isIgnoreCase : this['exam-answer-setting']?.isIgnoreCase ?? true\n const showRichText = this['is-edit'] ? this._showRichText : !!this['rich-text-content']\n const richText = this['is-edit'] ? this._richText : this['rich-text-content'] || ''\n const selectedTagList = this._selectedTagList || []\n const filledAnswers = answers.filter((answer: any) => this._normalizeAnswerTitle(answer))\n\n if (!title) {\n reject(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n return\n }\n if (answers.length < 1) {\n reject(new SubjectError('至少添加一个填空符!', 'NO_BLANK', 'answers', row))\n return\n }\n\n const result: any = {\n answerType: SubjectType.BLANK_FILL,\n title: title.replaceAll(/ ______/g, '<filter></filter>'),\n answers: filledAnswers.map((answer: any) => ({\n title: this._normalizeAnswerTitle(answer),\n isCorrect: true,\n ...(answer.answerId ? { answerId: answer.answerId } : {}),\n })),\n analysis,\n isSetCorrectAnswer: filledAnswers.length > 0,\n isKey: this['is-key'],\n examAnswerSettingBO: { isIgnoreCase, isInOrder },\n examRichTextContent: showRichText ? richText : '',\n categoryId: this._categoryId || '',\n memberTagInfo: selectedTagList,\n tagInfos: selectedTagList,\n resourceList: this['resource-list'] || [],\n examResourceBOList: this['resource-list'] || [],\n }\n if (this['custom-id']) { result.customId = this['custom-id'] }\n resolve(result)\n })\n }\n\n private async _save(e?: Event) {\n e?.stopImmediatePropagation()\n try {\n const data = await this.toJSON()\n this._emit('save', data)\n }\n catch (err: any) {\n showToast(err.message)\n }\n }\n\n validate(): SubjectError[] {\n const errors: SubjectError[] = []\n const row = { customId: this['custom-id'] || undefined, answerType: 'blank_fill', orderIndex: this['order-index'] }\n\n const title = this['is-edit'] ? this._title : this.title?.replaceAll(/<filter><\\/filter>/g, ' ______') || ''\n const answers = this['is-edit'] ? this._answers : (this['answer-list'] || []).map((answer: any) => ({ ...answer, title: this._normalizeAnswerTitle(answer) }))\n\n if (!title) {\n errors.push(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n }\n if (answers.length < 1) {\n errors.push(new SubjectError('至少添加一个填空符!', 'NO_BLANK', 'answers', row))\n }\n\n return errors\n }\n\n private _renderPreview() {\n const displayTitle = this.title.replaceAll(/<filter><\\/filter>/g, ' ______')\n const previewAnswers = this['is-edit'] ? this._answers : (this['answer-list'] || []).map((answer: any) => ({ ...answer, title: this._normalizeAnswerTitle(answer) }))\n return html`\n <div class=\"preview\">\n <span class=\"title\">${this['order-index'] + 1}.${displayTitle}(填空题)</span>\n ${this['rich-text-content'] ? html`<div class=\"rich-text\" .innerHTML=${this['rich-text-content']}></div>` : ''}\n ${previewAnswers.some(a => a.title)\n ? html`\n <div class=\"content flex flex-wrap\">\n <span>正确答案:</span>\n ${previewAnswers.map((a, i) => a.title\n ? html`<span style=\"margin-right:10px\">填空${i + 1}: ${a.title}</span>`\n : '')}\n </div>\n `\n : ''}\n ${this.analysis ? html`<div style=\"color:#909399;font-size:12px;margin-top:8px\">解析: ${this.analysis}</div>` : ''}\n ${this['show-category'] && this._categoryId\n ? html`<div class=\"section-row\"><span class=\"value-text\">分类:${this._categoryLabel()}</span></div>`\n : ''}\n ${this['show-tag'] && this._selectedTagList.length\n ? html`\n <div class=\"section-row\">\n <span class=\"value-text\">标签/关键信息:</span>\n <div class=\"tag-list\" style=\"margin-top:6px\">\n ${this._selectedTagList.map(item => html`<span class=\"tag-item\">${item.tagName}</span>`)}\n </div>\n </div>\n `\n : ''}\n ${this._renderResourceSection()}\n </div>\n `\n }\n\n private _renderTagSection() {\n if (!this['show-tag']) { return '' }\n return html`\n <div class=\"flex flex-items-start section-row\">\n <div class=\"label\"><span>标签:</span></div>\n <div style=\"flex:1\">\n <div class=\"tag-list\">\n ${this._selectedTagList.length\n ? this._selectedTagList.map(item => html`\n <span class=\"tag-item\">\n ${item.tagName}\n ${!this['is-save'] ? html`<span class=\"close\" @click=${() => this._removeTag(item.tagId)}>×</span>` : ''}\n </span>\n `)\n : html`<span class=\"tag-hint\">暂无标签/关键信息</span>`}\n </div>\n ${this['is-edit'] && !this['is-save']\n ? html`<div style=\"margin-top:8px\"><span class=\"el-link\" @click=${() => this._chooseTag()}>选择</span></div>`\n : ''}\n </div>\n </div>\n `\n }\n\n private _renderCategorySection() {\n if (!this['show-category']) { return '' }\n return html`\n <div class=\"flex flex-items-start section-row\">\n <div class=\"label\"><span>分类:</span></div>\n <div style=\"flex:1\">\n ${this['is-edit']\n ? html`\n <select class=\"el-select\" .value=${String(this._categoryId)} ?disabled=${this['is-save']}\n @change=${(e: Event) => this._onCategoryChange((e.target as HTMLSelectElement).value)}>\n <option value=\"\">选择分类</option>\n ${this['category-list'].map((item: any) => html`\n <option value=${String(item.categoryId)} ?selected=${String(item.categoryId) === String(this._categoryId)}>${item.title || item.categoryName}</option>\n `)}\n </select>\n `\n : html`<span class=\"value-text\">${this._categoryLabel()}</span>`}\n </div>\n </div>\n `\n }\n\n private _renderResourceSection() {\n if (!this['show-resource']) { return '' }\n const images = this._imageResources()\n const video = this._videoResource()\n return html`\n <div class=\"flex flex-items-start section-row\">\n <div class=\"label\"><span>资源:</span></div>\n <div style=\"flex:1\">\n <div class=\"resource-summary\">图片 ${images.length} 张${video?.url ? ',含视频资源' : ''}</div>\n ${images.length\n ? html`\n <div class=\"resource-thumbs\">\n ${images.slice(0, 4).map(src => html`<img class=\"resource-thumb\" src=${src} alt=\"resource\" />`)}\n </div>\n `\n : ''}\n ${video?.url ? html`<div style=\"margin-top:8px\"><a class=\"el-link\" href=${video.url} target=\"_blank\" rel=\"noreferrer\">查看视频</a></div>` : ''}\n ${!images.length && !video?.url ? html`<div class=\"tag-hint\">暂无资源</div>` : ''}\n </div>\n </div>\n `\n }\n\n private _renderEdit() {\n return html`\n <div class=\"flex flex-items-start\">\n <div class=\"label\"><span>题目:</span></div>\n <div style=\"flex:1\">\n <div class=\"el-input\">\n <textarea rows=\"3\" .value=${this._title} ?disabled=${this['is-save']}\n maxlength=${this.TITLE_MAX}\n @input=${(e: Event) => this._onTitleInput(e)}\n placeholder=\"【填空题】请输入问题\"></textarea>\n <span class=\"char-counter\">${this._title.length}/${this.TITLE_MAX}</span>\n </div>\n </div>\n </div>\n\n <div class=\"flex flex-justify-end\">\n <span class=\"el-link ${this['is-save'] ? 'is-disabled' : ''}\"\n @click=${() => {\n if (!this['is-save']) { this._addBlank() }\n }}>插入填空符</span>\n </div>\n\n <div class=\"flex flex-items-center\" style=\"margin-top:12px\">\n <div class=\"label\"><span>答题设置:</span></div>\n <label class=\"el-checkbox\">\n <input type=\"checkbox\" .checked=${this._isInOrder}\n @change=${(e: Event) => { this._isInOrder = (e.target as HTMLInputElement).checked }} />\n 答案不分顺序\n </label>\n <label class=\"el-checkbox\">\n <input type=\"checkbox\" .checked=${this._isIgnoreCase}\n @change=${(e: Event) => { this._isIgnoreCase = (e.target as HTMLInputElement).checked }} />\n 忽略大小写\n </label>\n </div>\n\n ${this._renderTagSection()}\n\n ${this._renderCategorySection()}\n\n ${this._renderResourceSection()}\n\n ${this._answers.map((a, i) => html`\n <div class=\"answer-item\" style=\"margin-top:12px\">\n <div class=\"label\"><span>第${i + 1}空答案:</span></div>\n <div class=\"answer-tags\">\n ${a.title.split(',').filter(Boolean).map(tag => html`\n <span class=\"el-tag\">\n ${tag}\n ${!this['is-save'] ? html`<span class=\"el-tag__close\" @click=${() => this._closeTag(tag, a)}>×</span>` : ''}\n </span>\n `)}\n ${!this['is-save']\n ? html`\n ${a.showInput\n ? html`\n <input type=\"text\" class=\"el-input--small\"\n @keydown=${(e: KeyboardEvent) => {\n if (e.key === 'Enter') { this._handleAddTag(a) }\n }}\n @input=${(e: Event) => { a.tag = (e.target as HTMLInputElement).value }}\n @blur=${() => this._handleAddTag(a)} />\n `\n : html`\n <span class=\"el-button--small\" @click=${() => { a.showInput = true; this.requestUpdate(); this.updateComplete.then(() => { (this.shadowRoot?.querySelector('.el-input--small') as HTMLInputElement)?.focus() }) }}>\n ${iconPlus}\n <span>${a.title ? '添加同义词' : '添加答案'}</span>\n </span>\n `}\n `\n : ''}\n </div>\n </div>\n `)}\n\n ${this._showRichText\n ? html`\n <div class=\"flex flex-items-start\" style=\"margin-top:12px\">\n <div class=\"label\"><span>富文本:</span></div>\n <div style=\"flex:1\">\n <qxs-blocksuite-editor\n .content=${this._richText}\n .upload-image=${this['upload-image']}\n ?is-edit=${true}\n ></qxs-blocksuite-editor>\n ${!this['show-action']\n ? html`\n <div class=\"flex flex-justify-end\" style=\"margin-top:8px\">\n <span class=\"el-link\" style=\"color:#f56c6c\" @click=${() => { this._showRichText = false; this._richText = '' }}>删除富文本</span>\n </div>\n `\n : ''}\n </div>\n </div>\n `\n : ''}\n\n ${this['show-analysis']\n ? html`\n <div class=\"flex flex-items-start\" style=\"margin-top:12px\">\n <div class=\"label\"><span>解析:</span></div>\n <div style=\"flex:1\">\n <div class=\"el-input\">\n <textarea rows=\"2\" .value=${this._analysis}\n @input=${(e: Event) => { this._analysis = (e.target as HTMLTextAreaElement).value }}\n placeholder=\"请输入题目解析\"></textarea>\n </div>\n </div>\n </div>\n `\n : ''}\n `\n }\n\n render() {\n return html`\n <qxs-subject-layout .show-edit=${this['is-edit']}>\n <div slot=\"preview\">${this._renderPreview()}</div>\n <div slot=\"edit\">${this._renderEdit()}</div>\n ${this['show-action']\n ? html`\n <qxs-subject-action\n .is-edit=${this['is-edit']}\n .is-set=${this['is-set']}\n .show-add=${this['show-add']}\n .show-rich-text=${this._showRichText}\n exam-answer-relation-type=${this['exam-answer-relation-type']}\n @delete=${() => this._emit('delete')}\n @save=${this._save}\n @edit=${() => this._emit('edit')}\n @add=${(e: CustomEvent) => this._emit('add', e.detail)}\n @set-key=${(e: CustomEvent) => { this._emit('set-key', e.detail) }}\n @on-show-rich-text=${() => {\n this._showRichText = !this._showRichText\n if (!this._showRichText) {\n this._richText = ''\n }\n }}\n ></qxs-subject-action>\n `\n : ''}\n </qxs-subject-layout>\n `\n }\n}\n\nexport function register() {}\n"],"names":["iconPlus","html","QxsBlankFill","LitElement","constructor","super","arguments","this","title","analysis","isInOrder","isIgnoreCase","async","Promise","resolve","reject","reader","FileReader","onload","e","target","result","onerror","readAsDataURL","file","_title","_analysis","_answers","tag","showInput","_isInOrder","_isIgnoreCase","_showRichText","_richText","_selectedTagList","_categoryId","TITLE_MAX","willUpdate","changed","has","_syncProps","replaceAll","Array","isArray","map","item","String","_normalizeAnswerTitle","answer","length","a","answerId","examAnswerId","blankCount","match","from","_emit","name","detail","dispatchEvent","CustomEvent","bubbles","composed","_addBlank","requestUpdate","_emitModelUpdate","_onTitleInput","el","value","slice","i","modelValue","_handleAddTag","join","_closeTag","tags","split","idx","findIndex","t","splice","_removeTag","tagId","filter","customId","examId","_chooseTag","_onCategoryChange","_imageResources","resourceType","resource","middle","url","Boolean","_videoResource","find","_categoryLabel","matched","categoryId","categoryName","toJSON","row","answerType","orderIndex","answers","showRichText","richText","selectedTagList","filledAnswers","SubjectError","SubjectType","BLANK_FILL","isCorrect","isSetCorrectAnswer","isKey","examAnswerSettingBO","examRichTextContent","memberTagInfo","tagInfos","resourceList","examResourceBOList","_save","stopImmediatePropagation","data","err","msg","document","createElement","textContent","Object","assign","style","position","top","left","transform","padding","borderRadius","fontSize","color","background","zIndex","boxShadow","transition","opacity","body","appendChild","setTimeout","remove","showToast","message","validate","errors","push","_renderPreview","displayTitle","previewAnswers","some","tagName","_renderResourceSection","_renderTagSection","_renderCategorySection","images","video","src","_renderEdit","checked","key","updateComplete","then","shadowRoot","querySelector","focus","render","styles","css","__decorateClass","property","type","Number","attribute","prototype","state","safeCustomElement"],"mappings":"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"}