@qxs-bns/components-wc 0.0.11 → 0.0.12

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 +1 @@
1
- {"version":3,"file":"text-fill.mjs","sources":["../../../../packages/components-wc/src/subject/text-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 { ExamType } from './types'\n\ninterface TextAnswer { title: string, tag: string, showInput: boolean }\n\nconst TAG_COLORS = [\n { bg: '#ecf5ff', color: '#3D61E3', border: '#d9ecff' }, // primary\n { bg: '#f0f9eb', color: '#67c23a', border: '#c2e7b0' }, // success\n { bg: '#fdf6ec', color: '#e6a23c', border: '#faecd8' }, // warning\n { bg: '#fef0f0', color: '#f56c6c', border: '#fde2e2' }, // danger\n { bg: '#f4f4f5', color: '#909399', border: '#e9e9eb' }, // info\n]\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-text-fill')\nexport class QxsTextFill extends LitElement {\n private readonly _iconPlus = 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>`\n private readonly _iconRemove = 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>`\n\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-answer { display: flex; flex-direction: column; margin-top: 12px; }\n .preview-answer .radio { margin-top: 8px; padding-left: 8px; display: flex; align-items: center; gap: 6px; }\n .preview-answer .order { color: #909399; }\n .preview-answer .correct { color: #67c23a; }\n .preview-answer .result-info { color: #909399; }\n\n .flex { display: flex; }\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: 60px; 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 .answer-list { margin-top: 12px; }\n .answer-item { display: flex; align-items: center; margin-top: 6px; border-radius: 4px; }\n .answer-item .label { min-width: 60px; font-size: 13px; color: #909399; }\n .answer-item .input { flex: 1; max-width: 360px; position: relative; display: block; }\n .answer-item .input input {\n height: 32px; padding: 0 50px 0 8px;\n font-size: 13px; line-height: 32px;\n border: 1px solid #dcdfe6; border-radius: 3px; width: 100%;\n transition: border-color .2s; box-sizing: border-box;\n }\n .answer-item .input input:focus { border-color: #3D61E3; outline: none; }\n .answer-item .input input:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n .answer-item .input .char-counter {\n position: absolute; right: 8px; top: 50%; transform: translateY(-50%);\n font-size: 12px; color: #909399; line-height: 1; pointer-events: none;\n }\n\n .answer-item .correct { margin: 0 10px; color: #909399; cursor: pointer; display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; }\n .answer-item .correct:hover { color: #3D61E3; }\n .answer-item .correct.is-correct { color: #67c23a; }\n .answer-item .correct input { width: 14px; height: 14px; cursor: pointer; accent-color: #3D61E3; }\n\n .answer-item .icon {\n margin-left: 6px; cursor: pointer; display: inline-flex;\n align-items: center; justify-content: center;\n width: 24px; height: 24px; border-radius: 4px;\n border: 1px solid #dcdfe6; background: #fff; color: #909399;\n transition: all 0.2s;\n }\n .answer-item .icon:hover { color: #3D61E3; border-color: #3D61E3; background: #ecf5ff; }\n .answer-item .icon.disabled { color: #e4e7ed; border-color: #e4e7ed; cursor: not-allowed; }\n\n .answer-item .link { margin-left: 8px; color: #3D61E3; cursor: pointer; font-size: 12px; white-space: nowrap; }\n .answer-item .link:hover { color: #2D4CB8; }\n\n .answer-item .link { color: #3D61E3; cursor: pointer; font-size: 12px; white-space: nowrap; background: none; border: none; padding: 0; margin: 0; font-family: inherit; }\n .answer-item .link:hover { color: #2D4CB8; }\n\n .el-link { color: #3D61E3; cursor: pointer; font-size: 12px; background: none; border: none; padding: 0; margin: 0; font-family: inherit; line-height: 1; }\n .el-link:hover { color: #2D4CB8; }\n .el-link.danger { color: #f56c6c; }\n\n .modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 9000; display: flex; align-items: center; justify-content: center; }\n .modal { background: #fff; border-radius: 6px; width: 520px; max-width: 90vw; box-shadow: 0 12px 32px rgba(0,0,0,.12); display: flex; flex-direction: column; }\n .modal-header { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px 12px; border-bottom: 1px solid #e4e7ed; }\n .modal-title { font-size: 14px; font-weight: 600; color: #303133; }\n .modal-close { background: none; border: none; font-size: 18px; cursor: pointer; color: #909399; padding: 0; line-height: 1; }\n .modal-close:hover { color: #3D61E3; }\n .modal-body { padding: 20px; }\n .modal-body textarea { min-height: 120px; }\n .modal-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 12px 20px; border-top: 1px solid #e4e7ed; }\n .modal-footer button { padding: 6px 16px; font-size: 12px; border-radius: 3px; cursor: pointer; border: 1px solid #dcdfe6; background: #fff; color: #606266; }\n .modal-footer button:hover { color: #3D61E3; border-color: #a0cfff; }\n .modal-footer button.primary { background: #3D61E3; border-color: #3D61E3; color: #fff; }\n .modal-footer button.primary:hover { background: #2D4CB8; border-color: #2D4CB8; }\n `\n\n @property({ type: Number, attribute: 'order-index' }) orderIndex = 0\n @property({ type: String }) title = ''\n @property({ type: String, attribute: 'custom-id' }) customId = ''\n @property({ type: Boolean, attribute: 'is-edit' }) isEdit = false\n @property({ type: Boolean, attribute: 'is-save' }) isSave = false\n @property({ type: Boolean, attribute: 'is-set' }) isSet = false\n @property({ type: Boolean, attribute: 'is-key' }) isKey = false\n @property({ type: Boolean, attribute: 'show-action' }) showAction = true\n @property({ type: Boolean, attribute: 'show-analysis' }) showAnalysis = true\n @property({ type: String, attribute: 'rich-text-content' }) richTextContent = ''\n @property({ type: String }) analysis = ''\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) examAnswerRelationType = 0\n @property({ type: String, attribute: 'exam-expand' }) examExpand = ''\n @property({ type: Object, attribute: 'exam-answer-setting' })\n examAnswerSetting: { isInOrder: boolean, isIgnoreCase: boolean, keywordCount: number } = { isInOrder: true, isIgnoreCase: true, keywordCount: 1 }\n @property({ type: Object })\n uploadImage: (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' }) answerList: any[] = []\n\n // 双向绑定支持\n @property({ type: String, attribute: 'model-value' }) modelValue = ''\n @property({ type: Boolean, attribute: 'use-model' }) useModel = false\n\n @state() private _answers: TextAnswer[] = [{ title: '', tag: '', showInput: false }]\n @state() private _title = ''\n @state() private _analysis = ''\n @state() private _isInOrder = true\n @state() private _isIgnoreCase = true\n @state() private _keywordCount = 1\n @state() private _correct = ''\n @state() private _showRichText = false\n @state() private _richText = ''\n\n private readonly TITLE_MAX = 200\n\n willUpdate(changed: Map<string, unknown>) {\n if (changed.has('isEdit') && this.isEdit) { this._syncProps() }\n // 当外部 modelValue 变化时同步内部状态\n if (changed.has('modelValue') && this.useModel) {\n this._title = this.modelValue\n }\n }\n\n private _syncProps() {\n this._title = this.title || ''\n this._analysis = this.analysis || ''\n if (this.answerList?.length) {\n this._answers = this.answerList.map((a: any) => ({ title: a.title || '', tag: '', showInput: false }))\n }\n if (this.examAnswerSetting) {\n this._isInOrder = !!this.examAnswerSetting.isInOrder\n this._isIgnoreCase = !!this.examAnswerSetting.isIgnoreCase\n this._keywordCount = this.examAnswerSetting.keywordCount || 1\n }\n if (this.richTextContent) {\n this._richText = this.richTextContent\n this._showRichText = true\n }\n if (this.examExpand) {\n this._correct = this.examExpand\n }\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 _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 // 双向绑定:通知外部更新\n if (this.useModel) {\n this.dispatchEvent(new CustomEvent('update:modelValue', {\n bubbles: true,\n composed: true,\n detail: this._title,\n }))\n }\n }\n\n private _addTag(i: number) {\n const a = { ...this._answers[i] }\n if (a.tag) {\n a.title = a.title ? [a.title, a.tag].join(',') : a.tag\n a.tag = ''\n }\n a.showInput = false\n this._answers = this._answers.map((x, j) => j === i ? a : x)\n }\n\n private _closeTag(tag: string, i: number) {\n const a = { ...this._answers[i] }\n a.title = a.title.split(',').filter(t => t !== tag).join(',')\n this._answers = this._answers.map((x, j) => j === i ? a : x)\n }\n\n async toJSON(): Promise<any> {\n return new Promise((resolve, reject) => {\n const row = { customId: this.customId || undefined, answerType: 'text_fill', orderIndex: this.orderIndex }\n\n const title = this.isEdit ? this._title : this.title || ''\n const answers = this.isEdit ? this._answers : (this.answerList || [])\n const analysis = this.isEdit ? this._analysis : this.analysis || ''\n const correct = this.isEdit ? this._correct : (this as any).examExpand || ''\n const keywordCount = this.isEdit ? this._keywordCount : this.examAnswerSetting?.keywordCount || 1\n const isInOrder = this.isEdit ? this._isInOrder : this.examAnswerSetting?.isInOrder ?? true\n const isIgnoreCase = this.isEdit ? this._isIgnoreCase : this.examAnswerSetting?.isIgnoreCase ?? true\n const showRichText = this.isEdit ? this._showRichText : !!this.richTextContent\n const richText = this.isEdit ? this._richText : this.richTextContent || ''\n\n if (!title) {\n reject(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n return\n }\n if (keywordCount || correct) {\n if (!keywordCount) {\n reject(new SubjectError('请完善答题设置!', 'NO_KEYWORD_COUNT', 'keywordCount', row))\n return\n }\n if (!correct) {\n reject(new SubjectError('请输入问题正确答案!', 'NO_CORRECT_ANSWER', 'correct', row))\n return\n }\n if (answers.length !== keywordCount) {\n reject(new SubjectError('关键词个数设置有误!', 'KEYWORD_COUNT_MISMATCH', 'answers', row))\n return\n }\n const msg: string[] = []\n answers.forEach((item: any, i: number) => {\n if (!item.title) { msg.push(`关键词${i + 1}未设置`) }\n })\n if (msg.length) {\n reject(new SubjectError(msg.join(','), 'KEYWORD_EMPTY', 'answers', row))\n return\n }\n }\n const result: any = {\n answerType: ExamType.TEXT_FILL,\n title,\n answers: answers.filter((a: any) => a.title).map((a: any) => ({ title: a.title })),\n analysis,\n isSetCorrectAnswer: !!correct,\n isKey: this.isKey,\n examExpand: correct,\n examAnswerSettingBO: { isIgnoreCase, isInOrder, keywordCount },\n examRichTextContent: showRichText ? richText : '',\n }\n if (this.customId) { result.customId = this.customId }\n resolve(result)\n })\n }\n\n private _addAnswer() {\n if (this.isSave) { return }\n this._answers = [...this._answers, { title: '', tag: '', showInput: false }]\n }\n\n private _deleteAnswer(index: number) {\n if (this._answers.length < 2 || this.isSave) { return }\n this._answers = this._answers.filter((_, i) => i !== index)\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.customId || undefined, answerType: 'text_fill', orderIndex: this.orderIndex }\n\n const title = this.isEdit ? this._title : this.title || ''\n const answers = this.isEdit ? this._answers : (this.answerList || [])\n const correct = this.isEdit ? this._correct : (this as any).examExpand || ''\n const keywordCount = this.isEdit ? this._keywordCount : this.examAnswerSetting?.keywordCount || 1\n\n if (!title) {\n errors.push(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n }\n if (keywordCount || correct) {\n if (!keywordCount) {\n errors.push(new SubjectError('请完善答题设置!', 'NO_KEYWORD_COUNT', 'keywordCount', row))\n }\n if (!correct) {\n errors.push(new SubjectError('请输入问题正确答案!', 'NO_CORRECT_ANSWER', 'correct', row))\n }\n if (answers.length !== keywordCount) {\n errors.push(new SubjectError('关键词个数设置有误!', 'KEYWORD_COUNT_MISMATCH', 'answers', row))\n }\n answers.forEach((item: any, i: number) => {\n if (!item.title) {\n errors.push(new SubjectError(`关键词${i + 1}未设置`, 'KEYWORD_EMPTY', 'answers', row))\n }\n })\n }\n\n return errors\n }\n\n private _renderPreview() {\n return html`\n <div class=\"preview\">\n <span class=\"title\">${this.orderIndex + 1}.${this.title}(问答题)</span>\n ${this.richTextContent ? html`<div class=\"rich-text\" .innerHTML=${this.richTextContent}></div>` : ''}\n ${this._answers.some(a => a.title)\n ? html`\n <div style=\"margin-top:8px;color:#a8abb2\">\n ${this._answers.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._correct ? html`<div style=\"margin-top:8px;color:#a8abb2\">正确答案:${this._correct}</div>` : ''}\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-items-start\">\n <div class=\"label\"><span>题目:</span></div>\n <div style=\"flex:1\">\n <div class=\"el-input\">\n <textarea rows=\"2\" .value=${this._title} ?disabled=${this.isSave}\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-items-start\" style=\"margin-top:12px\">\n <div class=\"label\"><span>答题设置:</span></div>\n <div style=\"flex:1;display:flex;align-items:center;flex-wrap:wrap;gap:8px\">\n <span style=\"font-size:13px;color:#606266\">共答对</span>\n <input type=\"number\" style=\"width:60px;height:24px;border:1px solid #dcdfe6;border-radius:3px;padding:0 8px;font-size:13px\"\n .value=${String(this._keywordCount)} min=\"1\"\n @change=${(e: Event) => { this._keywordCount = Number((e.target as HTMLInputElement).value) }} />\n <span style=\"font-size:13px;color:#606266\">个关键词,算是正确的</span>\n <label style=\"display:inline-flex;align-items:center;gap:4px;cursor:pointer;font-size:12px;color:#606266\">\n <input type=\"checkbox\" .checked=${this._isInOrder}\n @change=${(e: Event) => { this._isInOrder = (e.target as HTMLInputElement).checked }} />\n 答案不分顺序\n </label>\n <label style=\"display:inline-flex;align-items:center;gap:4px;cursor:pointer;font-size:12px;color:#606266\">\n <input type=\"checkbox\" .checked=${this._isIgnoreCase}\n @change=${(e: Event) => { this._isIgnoreCase = (e.target as HTMLInputElement).checked }} />\n 忽略大小写\n </label>\n </div>\n </div>\n\n <div class=\"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._correct} ?disabled=${this.isSave}\n maxlength=\"200\"\n @input=${(e: Event) => { this._correct = (e.target as HTMLTextAreaElement).value }}\n placeholder=\"请输入正确答案\"></textarea>\n <span class=\"char-counter\">${this._correct.length}/200</span>\n </div>\n </div>\n </div>\n\n <div class=\"answer-list\" style=\"margin-top:12px\">\n <span style=\"padding-left:60px;font-size:12px;color:#909399\">*如遇包含特殊字符的关键词,需添加多个同义词,例:'CO₂'需添加同义词'CO2'</span>\n ${this._answers.map((a, i) => html`\n <div class=\"answer-item\">\n <span class=\"label\">关键词${i + 1}:</span>\n <div class=\"answer-tags\" style=\"display:flex;flex-wrap:wrap;gap:5px;align-items:center;flex:1;max-width:360px\">\n ${a.title.split(',').filter(Boolean).map((tag) => {\n const c = TAG_COLORS[i % TAG_COLORS.length]; return html`\n <span style=\"display:inline-flex;align-items:center;background:${c.bg};color:${c.color};border:1px solid ${c.border};border-radius:3px;padding:2px 8px;font-size:12px;line-height:16px\">\n ${tag}\n ${!this.isSave ? html`<span style=\"cursor:pointer;margin-left:4px;color:#909399\" @click=${() => this._closeTag(tag, i)}>×</span>` : ''}\n </span>\n `\n })}\n ${!this.isSave\n ? html`\n ${a.showInput\n ? html`\n <input type=\"text\" style=\"width:80px;height:24px;border:1px solid #dcdfe6;border-radius:3px;padding:0 8px;font-size:12px\"\n @keydown=${(e: KeyboardEvent) => {\n if (e.key === 'Enter') { this._addTag(i) }\n }}\n @input=${(e: Event) => { a.tag = (e.target as HTMLInputElement).value }}\n @blur=${() => this._addTag(i)} />\n <button class=\"el-link\" @click=${() => this._addTag(i)}>确认</button>\n `\n : html`\n <button class=\"link\" @click=${() => { this._answers = this._answers.map((x, j) => j === i ? { ...x, showInput: true } : x); this.updateComplete.then(() => { (this.shadowRoot?.querySelector(`input[style*=\"width:80px\"]`) as HTMLInputElement)?.focus() }) }}>\n ${a.title ? '添加同义词' : '添加关键词'}\n </button>\n `}\n `\n : ''}\n </div>\n <span class=\"icon ${this.isSave ? 'disabled' : ''}\" @click=${() => this._addAnswer()}>${this._iconPlus}</span>\n <span class=\"icon ${this.isSave || this._answers.length < 2 ? 'disabled' : ''}\" @click=${() => this._deleteAnswer(i)}>${this._iconRemove}</span>\n </div>\n `)}\n </div>\n\n ${this._showRichText\n ? html`\n <div class=\"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 .uploadImage=${this.uploadImage}\n ?is-edit=${true}\n ></qxs-blocksuite-editor>\n <div class=\"flex-justify-end\" style=\"margin-top:8px\"><span class=\"el-link danger\" @click=${() => { this._showRichText = false; this._richText = '' }}>删除富文本</span></div>\n </div>\n </div>\n `\n : ''}\n\n ${this.showAnalysis\n ? html`\n <div class=\"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.isEdit}>\n <div slot=\"preview\">${this._renderPreview()}</div>\n <div slot=\"edit\">${this._renderEdit()}</div>\n ${this.showAction\n ? html`\n <qxs-subject-action\n ?is-edit=${this.isEdit}\n ?is-set=${this.isSet}\n ?show-other-option=${false}\n exam-answer-relation-type=${this.examAnswerRelationType}\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=${() => { this._showRichText = true }}\n ></qxs-subject-action>\n `\n : ''}\n </qxs-subject-layout>\n `\n }\n}\n\nexport function register() {}\n"],"names":["TAG_COLORS","bg","color","border","QxsTextFill","LitElement","constructor","super","arguments","this","_iconPlus","html","_iconRemove","orderIndex","title","customId","isEdit","isSave","isSet","isKey","showAction","showAnalysis","richTextContent","analysis","examAnswerRelationType","examExpand","examAnswerSetting","isInOrder","isIgnoreCase","keywordCount","uploadImage","async","Promise","resolve","reject","reader","FileReader","onload","e","target","result","onerror","readAsDataURL","file","answerList","modelValue","useModel","_answers","tag","showInput","_title","_analysis","_isInOrder","_isIgnoreCase","_keywordCount","_correct","_showRichText","_richText","TITLE_MAX","willUpdate","changed","has","_syncProps","length","map","a","_emit","name","detail","dispatchEvent","CustomEvent","bubbles","composed","_onTitleInput","el","value","slice","_addTag","i","join","x","j","_closeTag","split","filter","t","toJSON","row","answerType","answers","correct","showRichText","richText","SubjectError","msg","forEach","item","push","ExamType","TEXT_FILL","isSetCorrectAnswer","examAnswerSettingBO","examRichTextContent","_addAnswer","_deleteAnswer","index","_","_save","stopImmediatePropagation","data","err","document","createElement","textContent","Object","assign","style","position","top","left","transform","padding","borderRadius","fontSize","background","zIndex","boxShadow","transition","opacity","body","appendChild","setTimeout","remove","showToast","message","validate","errors","_renderPreview","some","_renderEdit","String","Number","checked","Boolean","c","key","updateComplete","then","shadowRoot","querySelector","focus","render","styles","css","__decorateClass","property","type","attribute","prototype","Array","state","safeCustomElement"],"mappings":"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"}
1
+ {"version":3,"file":"text-fill.mjs","sources":["../../../../packages/components-wc/src/subject/text-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 TextAnswer { title: string, tag: string, showInput: boolean }\n\nconst TAG_COLORS = [\n { bg: '#ecf5ff', color: '#3D61E3', border: '#d9ecff' }, // primary\n { bg: '#f0f9eb', color: '#67c23a', border: '#c2e7b0' }, // success\n { bg: '#fdf6ec', color: '#e6a23c', border: '#faecd8' }, // warning\n { bg: '#fef0f0', color: '#f56c6c', border: '#fde2e2' }, // danger\n { bg: '#f4f4f5', color: '#909399', border: '#e9e9eb' }, // info\n]\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-text-fill')\nexport class QxsTextFill extends LitElement {\n private readonly _iconPlus = 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>`\n private readonly _iconRemove = 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>`\n\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-answer { display: flex; flex-direction: column; margin-top: 12px; }\n .preview-answer .radio { margin-top: 8px; padding-left: 8px; display: flex; align-items: center; gap: 6px; }\n .preview-answer .order { color: #909399; }\n .preview-answer .correct { color: #67c23a; }\n .preview-answer .result-info { color: #909399; }\n\n .flex { display: flex; }\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: 60px; 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 .answer-list { margin-top: 12px; }\n .answer-item { display: flex; align-items: center; margin-top: 6px; border-radius: 4px; }\n .answer-item .label { min-width: 60px; font-size: 13px; color: #909399; }\n .answer-item .input { flex: 1; max-width: 360px; position: relative; display: block; }\n .answer-item .input input {\n height: 32px; padding: 0 50px 0 8px;\n font-size: 13px; line-height: 32px;\n border: 1px solid #dcdfe6; border-radius: 3px; width: 100%;\n transition: border-color .2s; box-sizing: border-box;\n }\n .answer-item .input input:focus { border-color: #3D61E3; outline: none; }\n .answer-item .input input:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n .answer-item .input .char-counter {\n position: absolute; right: 8px; top: 50%; transform: translateY(-50%);\n font-size: 12px; color: #909399; line-height: 1; pointer-events: none;\n }\n\n .answer-item .correct { margin: 0 10px; color: #909399; cursor: pointer; display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; }\n .answer-item .correct:hover { color: #3D61E3; }\n .answer-item .correct.is-correct { color: #67c23a; }\n .answer-item .correct input { width: 14px; height: 14px; cursor: pointer; accent-color: #3D61E3; }\n\n .answer-item .icon {\n margin-left: 6px; cursor: pointer; display: inline-flex;\n align-items: center; justify-content: center;\n width: 24px; height: 24px; border-radius: 4px;\n border: 1px solid #dcdfe6; background: #fff; color: #909399;\n transition: all 0.2s;\n }\n .answer-item .icon:hover { color: #3D61E3; border-color: #3D61E3; background: #ecf5ff; }\n .answer-item .icon.disabled { color: #e4e7ed; border-color: #e4e7ed; cursor: not-allowed; }\n\n .answer-item .link { margin-left: 8px; color: #3D61E3; cursor: pointer; font-size: 12px; white-space: nowrap; }\n .answer-item .link:hover { color: #2D4CB8; }\n\n .answer-item .link { color: #3D61E3; cursor: pointer; font-size: 12px; white-space: nowrap; background: none; border: none; padding: 0; margin: 0; font-family: inherit; }\n .answer-item .link:hover { color: #2D4CB8; }\n\n .el-link { color: #3D61E3; cursor: pointer; font-size: 12px; background: none; border: none; padding: 0; margin: 0; font-family: inherit; line-height: 1; }\n .el-link:hover { color: #2D4CB8; }\n .el-link.danger { color: #f56c6c; }\n\n .modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 9000; display: flex; align-items: center; justify-content: center; }\n .modal { background: #fff; border-radius: 6px; width: 520px; max-width: 90vw; box-shadow: 0 12px 32px rgba(0,0,0,.12); display: flex; flex-direction: column; }\n .modal-header { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px 12px; border-bottom: 1px solid #e4e7ed; }\n .modal-title { font-size: 14px; font-weight: 600; color: #303133; }\n .modal-close { background: none; border: none; font-size: 18px; cursor: pointer; color: #909399; padding: 0; line-height: 1; }\n .modal-close:hover { color: #3D61E3; }\n .modal-body { padding: 20px; }\n .modal-body textarea { min-height: 120px; }\n .modal-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 12px 20px; border-top: 1px solid #e4e7ed; }\n .modal-footer button { padding: 6px 16px; font-size: 12px; border-radius: 3px; cursor: pointer; border: 1px solid #dcdfe6; background: #fff; color: #606266; }\n .modal-footer button:hover { color: #3D61E3; border-color: #a0cfff; }\n .modal-footer button.primary { background: #3D61E3; border-color: #3D61E3; color: #fff; }\n .modal-footer button.primary:hover { background: #2D4CB8; border-color: #2D4CB8; }\n `\n\n @property({ type: Number, attribute: 'order-index' }) orderIndex = 0\n @property({ type: String }) title = ''\n @property({ type: String, attribute: 'custom-id' }) customId = ''\n @property({ type: Boolean, attribute: 'is-edit' }) isEdit = false\n @property({ type: Boolean, attribute: 'is-save' }) isSave = false\n @property({ type: Boolean, attribute: 'is-set' }) isSet = false\n @property({ type: Boolean, attribute: 'is-key' }) isKey = false\n @property({ type: Boolean, attribute: 'show-action' }) showAction = true\n @property({ type: Boolean, attribute: 'show-analysis' }) showAnalysis = true\n @property({ type: String, attribute: 'rich-text-content' }) richTextContent = ''\n @property({ type: String }) analysis = ''\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) examAnswerRelationType = 0\n @property({ type: String, attribute: 'exam-expand' }) examExpand = ''\n @property({ type: Object, attribute: 'exam-answer-setting' })\n examAnswerSetting: { isInOrder: boolean, isIgnoreCase: boolean, keywordCount: number } = { isInOrder: true, isIgnoreCase: true, keywordCount: 1 }\n @property({ type: Object })\n uploadImage: (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' }) answerList: any[] = []\n\n // 双向绑定支持\n @property({ type: String, attribute: 'model-value' }) modelValue = ''\n @property({ type: Boolean, attribute: 'use-model' }) useModel = false\n\n @state() private _answers: TextAnswer[] = [{ title: '', tag: '', showInput: false }]\n @state() private _title = ''\n @state() private _analysis = ''\n @state() private _isInOrder = true\n @state() private _isIgnoreCase = true\n @state() private _keywordCount = 1\n @state() private _correct = ''\n @state() private _showRichText = false\n @state() private _richText = ''\n\n private readonly TITLE_MAX = 200\n\n willUpdate(changed: Map<string, unknown>) {\n if (changed.has('isEdit') && this.isEdit) { this._syncProps() }\n // 当外部 modelValue 变化时同步内部状态\n if (changed.has('modelValue') && this.useModel) {\n this._title = this.modelValue\n }\n }\n\n private _syncProps() {\n this._title = this.title || ''\n this._analysis = this.analysis || ''\n if (this.answerList?.length) {\n this._answers = this.answerList.map((a: any) => ({ title: a.title || '', tag: '', showInput: false }))\n }\n if (this.examAnswerSetting) {\n this._isInOrder = !!this.examAnswerSetting.isInOrder\n this._isIgnoreCase = !!this.examAnswerSetting.isIgnoreCase\n this._keywordCount = this.examAnswerSetting.keywordCount || 1\n }\n if (this.richTextContent) {\n this._richText = this.richTextContent\n this._showRichText = true\n }\n if (this.examExpand) {\n this._correct = this.examExpand\n }\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 _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 // 双向绑定:通知外部更新\n if (this.useModel) {\n this.dispatchEvent(new CustomEvent('update:modelValue', {\n bubbles: true,\n composed: true,\n detail: this._title,\n }))\n }\n }\n\n private _addTag(i: number) {\n const a = { ...this._answers[i] }\n if (a.tag) {\n a.title = a.title ? [a.title, a.tag].join(',') : a.tag\n a.tag = ''\n }\n a.showInput = false\n this._answers = this._answers.map((x, j) => j === i ? a : x)\n }\n\n private _closeTag(tag: string, i: number) {\n const a = { ...this._answers[i] }\n a.title = a.title.split(',').filter(t => t !== tag).join(',')\n this._answers = this._answers.map((x, j) => j === i ? a : x)\n }\n\n async toJSON(): Promise<any> {\n return new Promise((resolve, reject) => {\n const row = { customId: this.customId || undefined, answerType: 'text_fill', orderIndex: this.orderIndex }\n\n const title = this.isEdit ? this._title : this.title || ''\n const answers = this.isEdit ? this._answers : (this.answerList || [])\n const analysis = this.isEdit ? this._analysis : this.analysis || ''\n const correct = this.isEdit ? this._correct : (this as any).examExpand || ''\n const keywordCount = this.isEdit ? this._keywordCount : this.examAnswerSetting?.keywordCount || 1\n const isInOrder = this.isEdit ? this._isInOrder : this.examAnswerSetting?.isInOrder ?? true\n const isIgnoreCase = this.isEdit ? this._isIgnoreCase : this.examAnswerSetting?.isIgnoreCase ?? true\n const showRichText = this.isEdit ? this._showRichText : !!this.richTextContent\n const richText = this.isEdit ? this._richText : this.richTextContent || ''\n\n if (!title) {\n reject(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n return\n }\n if (keywordCount || correct) {\n if (!keywordCount) {\n reject(new SubjectError('请完善答题设置!', 'NO_KEYWORD_COUNT', 'keywordCount', row))\n return\n }\n if (!correct) {\n reject(new SubjectError('请输入问题正确答案!', 'NO_CORRECT_ANSWER', 'correct', row))\n return\n }\n if (answers.length !== keywordCount) {\n reject(new SubjectError('关键词个数设置有误!', 'KEYWORD_COUNT_MISMATCH', 'answers', row))\n return\n }\n const msg: string[] = []\n answers.forEach((item: any, i: number) => {\n if (!item.title) { msg.push(`关键词${i + 1}未设置`) }\n })\n if (msg.length) {\n reject(new SubjectError(msg.join(','), 'KEYWORD_EMPTY', 'answers', row))\n return\n }\n }\n const result: any = {\n answerType: SubjectType.TEXT_FILL,\n title,\n answers: answers.filter((a: any) => a.title).map((a: any) => ({ title: a.title })),\n analysis,\n isSetCorrectAnswer: !!correct,\n isKey: this.isKey,\n examExpand: correct,\n examAnswerSettingBO: { isIgnoreCase, isInOrder, keywordCount },\n examRichTextContent: showRichText ? richText : '',\n }\n if (this.customId) { result.customId = this.customId }\n resolve(result)\n })\n }\n\n private _addAnswer() {\n if (this.isSave) { return }\n this._answers = [...this._answers, { title: '', tag: '', showInput: false }]\n }\n\n private _deleteAnswer(index: number) {\n if (this._answers.length < 2 || this.isSave) { return }\n this._answers = this._answers.filter((_, i) => i !== index)\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.customId || undefined, answerType: 'text_fill', orderIndex: this.orderIndex }\n\n const title = this.isEdit ? this._title : this.title || ''\n const answers = this.isEdit ? this._answers : (this.answerList || [])\n const correct = this.isEdit ? this._correct : (this as any).examExpand || ''\n const keywordCount = this.isEdit ? this._keywordCount : this.examAnswerSetting?.keywordCount || 1\n\n if (!title) {\n errors.push(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n }\n if (keywordCount || correct) {\n if (!keywordCount) {\n errors.push(new SubjectError('请完善答题设置!', 'NO_KEYWORD_COUNT', 'keywordCount', row))\n }\n if (!correct) {\n errors.push(new SubjectError('请输入问题正确答案!', 'NO_CORRECT_ANSWER', 'correct', row))\n }\n if (answers.length !== keywordCount) {\n errors.push(new SubjectError('关键词个数设置有误!', 'KEYWORD_COUNT_MISMATCH', 'answers', row))\n }\n answers.forEach((item: any, i: number) => {\n if (!item.title) {\n errors.push(new SubjectError(`关键词${i + 1}未设置`, 'KEYWORD_EMPTY', 'answers', row))\n }\n })\n }\n\n return errors\n }\n\n private _renderPreview() {\n return html`\n <div class=\"preview\">\n <span class=\"title\">${this.orderIndex + 1}.${this.title}(问答题)</span>\n ${this.richTextContent ? html`<div class=\"rich-text\" .innerHTML=${this.richTextContent}></div>` : ''}\n ${this._answers.some(a => a.title)\n ? html`\n <div style=\"margin-top:8px;color:#a8abb2\">\n ${this._answers.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._correct ? html`<div style=\"margin-top:8px;color:#a8abb2\">正确答案:${this._correct}</div>` : ''}\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-items-start\">\n <div class=\"label\"><span>题目:</span></div>\n <div style=\"flex:1\">\n <div class=\"el-input\">\n <textarea rows=\"2\" .value=${this._title} ?disabled=${this.isSave}\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-items-start\" style=\"margin-top:12px\">\n <div class=\"label\"><span>答题设置:</span></div>\n <div style=\"flex:1;display:flex;align-items:center;flex-wrap:wrap;gap:8px\">\n <span style=\"font-size:13px;color:#606266\">共答对</span>\n <input type=\"number\" style=\"width:60px;height:24px;border:1px solid #dcdfe6;border-radius:3px;padding:0 8px;font-size:13px\"\n .value=${String(this._keywordCount)} min=\"1\"\n @change=${(e: Event) => { this._keywordCount = Number((e.target as HTMLInputElement).value) }} />\n <span style=\"font-size:13px;color:#606266\">个关键词,算是正确的</span>\n <label style=\"display:inline-flex;align-items:center;gap:4px;cursor:pointer;font-size:12px;color:#606266\">\n <input type=\"checkbox\" .checked=${this._isInOrder}\n @change=${(e: Event) => { this._isInOrder = (e.target as HTMLInputElement).checked }} />\n 答案不分顺序\n </label>\n <label style=\"display:inline-flex;align-items:center;gap:4px;cursor:pointer;font-size:12px;color:#606266\">\n <input type=\"checkbox\" .checked=${this._isIgnoreCase}\n @change=${(e: Event) => { this._isIgnoreCase = (e.target as HTMLInputElement).checked }} />\n 忽略大小写\n </label>\n </div>\n </div>\n\n <div class=\"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._correct} ?disabled=${this.isSave}\n maxlength=\"200\"\n @input=${(e: Event) => { this._correct = (e.target as HTMLTextAreaElement).value }}\n placeholder=\"请输入正确答案\"></textarea>\n <span class=\"char-counter\">${this._correct.length}/200</span>\n </div>\n </div>\n </div>\n\n <div class=\"answer-list\" style=\"margin-top:12px\">\n <span style=\"padding-left:60px;font-size:12px;color:#909399\">*如遇包含特殊字符的关键词,需添加多个同义词,例:'CO₂'需添加同义词'CO2'</span>\n ${this._answers.map((a, i) => html`\n <div class=\"answer-item\">\n <span class=\"label\">关键词${i + 1}:</span>\n <div class=\"answer-tags\" style=\"display:flex;flex-wrap:wrap;gap:5px;align-items:center;flex:1;max-width:360px\">\n ${a.title.split(',').filter(Boolean).map((tag) => {\n const c = TAG_COLORS[i % TAG_COLORS.length]; return html`\n <span style=\"display:inline-flex;align-items:center;background:${c.bg};color:${c.color};border:1px solid ${c.border};border-radius:3px;padding:2px 8px;font-size:12px;line-height:16px\">\n ${tag}\n ${!this.isSave ? html`<span style=\"cursor:pointer;margin-left:4px;color:#909399\" @click=${() => this._closeTag(tag, i)}>×</span>` : ''}\n </span>\n `\n })}\n ${!this.isSave\n ? html`\n ${a.showInput\n ? html`\n <input type=\"text\" style=\"width:80px;height:24px;border:1px solid #dcdfe6;border-radius:3px;padding:0 8px;font-size:12px\"\n @keydown=${(e: KeyboardEvent) => {\n if (e.key === 'Enter') { this._addTag(i) }\n }}\n @input=${(e: Event) => { a.tag = (e.target as HTMLInputElement).value }}\n @blur=${() => this._addTag(i)} />\n <button class=\"el-link\" @click=${() => this._addTag(i)}>确认</button>\n `\n : html`\n <button class=\"link\" @click=${() => { this._answers = this._answers.map((x, j) => j === i ? { ...x, showInput: true } : x); this.updateComplete.then(() => { (this.shadowRoot?.querySelector(`input[style*=\"width:80px\"]`) as HTMLInputElement)?.focus() }) }}>\n ${a.title ? '添加同义词' : '添加关键词'}\n </button>\n `}\n `\n : ''}\n </div>\n <span class=\"icon ${this.isSave ? 'disabled' : ''}\" @click=${() => this._addAnswer()}>${this._iconPlus}</span>\n <span class=\"icon ${this.isSave || this._answers.length < 2 ? 'disabled' : ''}\" @click=${() => this._deleteAnswer(i)}>${this._iconRemove}</span>\n </div>\n `)}\n </div>\n\n ${this._showRichText\n ? html`\n <div class=\"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 .uploadImage=${this.uploadImage}\n ?is-edit=${true}\n ></qxs-blocksuite-editor>\n <div class=\"flex-justify-end\" style=\"margin-top:8px\"><span class=\"el-link danger\" @click=${() => { this._showRichText = false; this._richText = '' }}>删除富文本</span></div>\n </div>\n </div>\n `\n : ''}\n\n ${this.showAnalysis\n ? html`\n <div class=\"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.isEdit}>\n <div slot=\"preview\">${this._renderPreview()}</div>\n <div slot=\"edit\">${this._renderEdit()}</div>\n ${this.showAction\n ? html`\n <qxs-subject-action\n ?is-edit=${this.isEdit}\n ?is-set=${this.isSet}\n ?show-other-option=${false}\n exam-answer-relation-type=${this.examAnswerRelationType}\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=${() => { this._showRichText = true }}\n ></qxs-subject-action>\n `\n : ''}\n </qxs-subject-layout>\n `\n }\n}\n\nexport function register() {}\n"],"names":["TAG_COLORS","bg","color","border","QxsTextFill","LitElement","constructor","super","arguments","this","_iconPlus","html","_iconRemove","orderIndex","title","customId","isEdit","isSave","isSet","isKey","showAction","showAnalysis","richTextContent","analysis","examAnswerRelationType","examExpand","examAnswerSetting","isInOrder","isIgnoreCase","keywordCount","uploadImage","async","Promise","resolve","reject","reader","FileReader","onload","e","target","result","onerror","readAsDataURL","file","answerList","modelValue","useModel","_answers","tag","showInput","_title","_analysis","_isInOrder","_isIgnoreCase","_keywordCount","_correct","_showRichText","_richText","TITLE_MAX","willUpdate","changed","has","_syncProps","length","map","a","_emit","name","detail","dispatchEvent","CustomEvent","bubbles","composed","_onTitleInput","el","value","slice","_addTag","i","join","x","j","_closeTag","split","filter","t","toJSON","row","answerType","answers","correct","showRichText","richText","SubjectError","msg","forEach","item","push","SubjectType","TEXT_FILL","isSetCorrectAnswer","examAnswerSettingBO","examRichTextContent","_addAnswer","_deleteAnswer","index","_","_save","stopImmediatePropagation","data","err","document","createElement","textContent","Object","assign","style","position","top","left","transform","padding","borderRadius","fontSize","background","zIndex","boxShadow","transition","opacity","body","appendChild","setTimeout","remove","showToast","message","validate","errors","_renderPreview","some","_renderEdit","String","Number","checked","Boolean","c","key","updateComplete","then","shadowRoot","querySelector","focus","render","styles","css","__decorateClass","property","type","attribute","prototype","Array","state","safeCustomElement"],"mappings":"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"}
@@ -1,9 +1,9 @@
1
- import{css as e,LitElement as t,html as i}from"lit";import{safeCustomElement as s}from"../base/define.mjs";var l=Object.getOwnPropertyDescriptor;const a=[{type:"single",label:"单选题"},{type:"multiple",label:"多选题"},{type:"blank_fill",label:"填空题"},{type:"text_fill",label:"问答题"},{type:"scale",label:"量表题"},{type:"sort",label:"排序题"}],p=[{type:"rich_text",label:"富文本"},{type:"page_end",label:"分页器"}],n=[{type:"single",label:"单选题"},{type:"multiple",label:"多选题"}];let c=class extends t{emit(e){let t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];this.dispatchEvent(new CustomEvent("select",{bubbles:!0,composed:!0,detail:{type:e,canSet:t}}))}render(){return i`
1
+ import{css as e,LitElement as t,html as i}from"lit";import{safeCustomElement as s}from"../base/define.mjs";import{SubjectType as l}from"./types.mjs";var a=Object.getOwnPropertyDescriptor;const p=[{type:l.SINGLE,label:"单选题"},{type:l.MULTIPLE,label:"多选题"},{type:l.BLANK_FILL,label:"填空题"},{type:l.TEXT_FILL,label:"问答题"},{type:l.SCALE,label:"量表题"},{type:l.SORT,label:"排序题"}],o=[{type:"rich_text",label:"富文本"},{type:"page_end",label:"分页器"}],c=[{type:l.SINGLE,label:"单选题"},{type:l.MULTIPLE,label:"多选题"}];let n=class extends t{emit(e){let t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];this.dispatchEvent(new CustomEvent("select",{bubbles:!0,composed:!0,detail:{type:e,canSet:t}}))}render(){return i`
2
2
  <div class="container">
3
3
  <div class="type-item">
4
4
  <div class="section-title">普通题目类型</div>
5
5
  <div class="base-subject">
6
- ${a.map(e=>i`
6
+ ${p.map(e=>i`
7
7
  <span class="item" @click=${()=>this.emit(e.type)}>${e.label}</span>
8
8
  `)}
9
9
  </div>
@@ -11,7 +11,7 @@ import{css as e,LitElement as t,html as i}from"lit";import{safeCustomElement as
11
11
  <div class="type-item">
12
12
  <div class="section-title">其他</div>
13
13
  <div class="base-subject">
14
- ${p.map(e=>i`
14
+ ${o.map(e=>i`
15
15
  <span class="item" @click=${()=>this.emit(e.type)}>${e.label}</span>
16
16
  `)}
17
17
  </div>
@@ -19,13 +19,13 @@ import{css as e,LitElement as t,html as i}from"lit";import{safeCustomElement as
19
19
  <div class="type-item">
20
20
  <div class="section-title">互动问答类型(支持设置结果项)</div>
21
21
  <div class="base-subject">
22
- ${n.map(e=>i`
22
+ ${c.map(e=>i`
23
23
  <span class="item" @click=${()=>this.emit(e.type,!0)}>${e.label}</span>
24
24
  `)}
25
25
  </div>
26
26
  </div>
27
27
  </div>
28
- `}};c.styles=e`
28
+ `}};n.styles=e`
29
29
  :host { display: block; font-family: system-ui, -apple-system, "PingFang SC", "Microsoft YaHei", sans-serif; font-size: 13px; }
30
30
  .container { padding: 16px; }
31
31
  .type-item { margin-bottom: 20px; }
@@ -38,5 +38,5 @@ import{css as e,LitElement as t,html as i}from"lit";import{safeCustomElement as
38
38
  border: 1px solid #dcdfe6; border-radius: 4px; transition: all 0.15s;
39
39
  }
40
40
  .item:hover { color: #409eff; border-color: #409eff; }
41
- `,c=((e,t,i,s)=>{for(var a,p=s>1?void 0:s?l(t,i):t,n=e.length-1;n>=0;n--)(a=e[n])&&(p=a(p)||p);return p})([s("qxs-subject-type")],c);export{c as QxsSubjectType};
41
+ `,n=((e,t,i,s)=>{for(var l,p=s>1?void 0:s?a(t,i):t,o=e.length-1;o>=0;o--)(l=e[o])&&(p=l(p)||p);return p})([s("qxs-subject-type")],n);export{n as QxsSubjectType};
42
42
  //# sourceMappingURL=type.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"type.mjs","sources":["../../../../packages/components-wc/src/subject/type.ts"],"sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\n\nconst subjectOptions = [\n { type: 'single', label: '单选题' },\n { type: 'multiple', label: '多选题' },\n { type: 'blank_fill', label: '填空题' },\n { type: 'text_fill', label: '问答题' },\n { type: 'scale', label: '量表题' },\n { type: 'sort', label: '排序题' },\n]\n\nconst otherOptions = [\n { type: 'rich_text', label: '富文本' },\n { type: 'page_end', label: '分页器' },\n]\n\nconst interactionOptions = [\n { type: 'single', label: '单选题' },\n { type: 'multiple', label: '多选题' },\n]\n\n@safeCustomElement('qxs-subject-type')\nexport class QxsSubjectType extends LitElement {\n static styles = css`\n :host { display: block; font-family: system-ui, -apple-system, \"PingFang SC\", \"Microsoft YaHei\", sans-serif; font-size: 13px; }\n .container { padding: 16px; }\n .type-item { margin-bottom: 20px; }\n .section-title { margin-bottom: 10px; font-size: 13px; color: #909399; }\n .base-subject { display: flex; flex-wrap: wrap; gap: 8px; }\n .item {\n display: inline-flex; align-items: center; justify-content: center;\n min-width: 64px; height: 28px; padding: 0 12px; font-size: 13px;\n color: #606266; cursor: pointer; background: #fff;\n border: 1px solid #dcdfe6; border-radius: 4px; transition: all 0.15s;\n }\n .item:hover { color: #409eff; border-color: #409eff; }\n `\n\n private emit(type: string, canSet = false) {\n this.dispatchEvent(new CustomEvent('select', {\n bubbles: true, composed: true,\n detail: { type, canSet },\n }))\n }\n\n render() {\n return html`\n <div class=\"container\">\n <div class=\"type-item\">\n <div class=\"section-title\">普通题目类型</div>\n <div class=\"base-subject\">\n ${subjectOptions.map(item => html`\n <span class=\"item\" @click=${() => this.emit(item.type)}>${item.label}</span>\n `)}\n </div>\n </div>\n <div class=\"type-item\">\n <div class=\"section-title\">其他</div>\n <div class=\"base-subject\">\n ${otherOptions.map(item => html`\n <span class=\"item\" @click=${() => this.emit(item.type)}>${item.label}</span>\n `)}\n </div>\n </div>\n <div class=\"type-item\">\n <div class=\"section-title\">互动问答类型(支持设置结果项)</div>\n <div class=\"base-subject\">\n ${interactionOptions.map(item => html`\n <span class=\"item\" @click=${() => this.emit(item.type, true)}>${item.label}</span>\n `)}\n </div>\n </div>\n </div>\n `\n }\n}\n\nexport function register() {\n // auto-registered via @safeCustomElement\n}\n"],"names":["subjectOptions","type","label","otherOptions","interactionOptions","QxsSubjectType","LitElement","emit","canSet","arguments","length","undefined","this","dispatchEvent","CustomEvent","bubbles","composed","detail","render","html","map","item","styles","css","__decorateClass","safeCustomElement"],"mappings":"iJAIA,MAAMA,EAAiB,CACrB,CAAEC,KAAM,SAAUC,MAAO,OACzB,CAAED,KAAM,WAAYC,MAAO,OAC3B,CAAED,KAAM,aAAcC,MAAO,OAC7B,CAAED,KAAM,YAAaC,MAAO,OAC5B,CAAED,KAAM,QAASC,MAAO,OACxB,CAAED,KAAM,OAAQC,MAAO,QAGnBC,EAAe,CACnB,CAAEF,KAAM,YAAaC,MAAO,OAC5B,CAAED,KAAM,WAAYC,MAAO,QAGvBE,EAAqB,CACzB,CAAEH,KAAM,SAAUC,MAAO,OACzB,CAAED,KAAM,WAAYC,MAAO,QAItB,IAAMG,EAAN,cAA6BC,EAgB1BC,IAAAA,CAAKN,GAA8B,IAAhBO,EAAAC,UAAAC,OAAA,QAAAC,IAAAF,UAAA,IAAAA,UAAA,GACzBG,KAAKC,cAAc,IAAIC,YAAY,SAAU,CAC3CC,SAAS,EAAMC,UAAU,EACzBC,OAAQ,CAAEhB,OAAMO,YAEpB,CAEAU,MAAAA,GACE,OAAOC,CAAA;;;;;cAKGnB,EAAeoB,IAAIC,GAAQF,CAAA;0CACC,IAAMP,KAAKL,KAAKc,EAAKpB,SAASoB,EAAKnB;;;;;;;cAO/DC,EAAaiB,IAAIC,GAAQF,CAAA;0CACG,IAAMP,KAAKL,KAAKc,EAAKpB,SAASoB,EAAKnB;;;;;;;cAO/DE,EAAmBgB,IAAIC,GAAQF,CAAA;0CACH,IAAMP,KAAKL,KAAKc,EAAKpB,MAAM,MAASoB,EAAKnB;;;;;KAMjF,GApDWG,EACJiB,OAASC,CAAA;;;;;;;;;;;;;IADLlB,uGAANmB,CAAA,CADNC,EAAkB,qBACNpB"}
1
+ {"version":3,"file":"type.mjs","sources":["../../../../packages/components-wc/src/subject/type.ts"],"sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\nimport { SubjectType } from './types'\n\nconst subjectOptions = [\n { type: SubjectType.SINGLE, label: '单选题' },\n { type: SubjectType.MULTIPLE, label: '多选题' },\n { type: SubjectType.BLANK_FILL, label: '填空题' },\n { type: SubjectType.TEXT_FILL, label: '问答题' },\n { type: SubjectType.SCALE, label: '量表题' },\n { type: SubjectType.SORT, label: '排序题' },\n]\n\nconst otherOptions = [\n { type: 'rich_text', label: '富文本' },\n { type: 'page_end', label: '分页器' },\n]\n\nconst interactionOptions = [\n { type: SubjectType.SINGLE, label: '单选题' },\n { type: SubjectType.MULTIPLE, label: '多选题' },\n]\n\n@safeCustomElement('qxs-subject-type')\nexport class QxsSubjectType extends LitElement {\n static styles = css`\n :host { display: block; font-family: system-ui, -apple-system, \"PingFang SC\", \"Microsoft YaHei\", sans-serif; font-size: 13px; }\n .container { padding: 16px; }\n .type-item { margin-bottom: 20px; }\n .section-title { margin-bottom: 10px; font-size: 13px; color: #909399; }\n .base-subject { display: flex; flex-wrap: wrap; gap: 8px; }\n .item {\n display: inline-flex; align-items: center; justify-content: center;\n min-width: 64px; height: 28px; padding: 0 12px; font-size: 13px;\n color: #606266; cursor: pointer; background: #fff;\n border: 1px solid #dcdfe6; border-radius: 4px; transition: all 0.15s;\n }\n .item:hover { color: #409eff; border-color: #409eff; }\n `\n\n private emit(type: string, canSet = false) {\n this.dispatchEvent(new CustomEvent('select', {\n bubbles: true, composed: true,\n detail: { type, canSet },\n }))\n }\n\n render() {\n return html`\n <div class=\"container\">\n <div class=\"type-item\">\n <div class=\"section-title\">普通题目类型</div>\n <div class=\"base-subject\">\n ${subjectOptions.map(item => html`\n <span class=\"item\" @click=${() => this.emit(item.type)}>${item.label}</span>\n `)}\n </div>\n </div>\n <div class=\"type-item\">\n <div class=\"section-title\">其他</div>\n <div class=\"base-subject\">\n ${otherOptions.map(item => html`\n <span class=\"item\" @click=${() => this.emit(item.type)}>${item.label}</span>\n `)}\n </div>\n </div>\n <div class=\"type-item\">\n <div class=\"section-title\">互动问答类型(支持设置结果项)</div>\n <div class=\"base-subject\">\n ${interactionOptions.map(item => html`\n <span class=\"item\" @click=${() => this.emit(item.type, true)}>${item.label}</span>\n `)}\n </div>\n </div>\n </div>\n `\n }\n}\n\nexport function register() {\n // auto-registered via @safeCustomElement\n}\n"],"names":["subjectOptions","type","SubjectType","SINGLE","label","MULTIPLE","BLANK_FILL","TEXT_FILL","SCALE","SORT","otherOptions","interactionOptions","QxsSubjectType","LitElement","emit","canSet","arguments","length","undefined","this","dispatchEvent","CustomEvent","bubbles","composed","detail","render","html","map","item","styles","css","__decorateClass","safeCustomElement"],"mappings":"2LAKA,MAAMA,EAAiB,CACrB,CAAEC,KAAMC,EAAYC,OAAQC,MAAO,OACnC,CAAEH,KAAMC,EAAYG,SAAUD,MAAO,OACrC,CAAEH,KAAMC,EAAYI,WAAYF,MAAO,OACvC,CAAEH,KAAMC,EAAYK,UAAWH,MAAO,OACtC,CAAEH,KAAMC,EAAYM,MAAOJ,MAAO,OAClC,CAAEH,KAAMC,EAAYO,KAAML,MAAO,QAG7BM,EAAe,CACnB,CAAET,KAAM,YAAaG,MAAO,OAC5B,CAAEH,KAAM,WAAYG,MAAO,QAGvBO,EAAqB,CACzB,CAAEV,KAAMC,EAAYC,OAAQC,MAAO,OACnC,CAAEH,KAAMC,EAAYG,SAAUD,MAAO,QAIhC,IAAMQ,EAAN,cAA6BC,EAgB1BC,IAAAA,CAAKb,GAA8B,IAAhBc,EAAAC,UAAAC,OAAA,QAAAC,IAAAF,UAAA,IAAAA,UAAA,GACzBG,KAAKC,cAAc,IAAIC,YAAY,SAAU,CAC3CC,SAAS,EAAMC,UAAU,EACzBC,OAAQ,CAAEvB,OAAMc,YAEpB,CAEAU,MAAAA,GACE,OAAOC,CAAA;;;;;cAKG1B,EAAe2B,IAAIC,GAAQF,CAAA;0CACC,IAAMP,KAAKL,KAAKc,EAAK3B,SAAS2B,EAAKxB;;;;;;;cAO/DM,EAAaiB,IAAIC,GAAQF,CAAA;0CACG,IAAMP,KAAKL,KAAKc,EAAK3B,SAAS2B,EAAKxB;;;;;;;cAO/DO,EAAmBgB,IAAIC,GAAQF,CAAA;0CACH,IAAMP,KAAKL,KAAKc,EAAK3B,MAAM,MAAS2B,EAAKxB;;;;;KAMjF,GApDWQ,EACJiB,OAASC,CAAA;;;;;;;;;;;;;IADLlB,uGAANmB,CAAA,CADNC,EAAkB,qBACNpB"}
@@ -1,2 +1,2 @@
1
- var l=(l=>(l[l.SINGLE=0]="SINGLE",l[l.MULTIPLE=1]="MULTIPLE",l[l.BLANK_FILL=2]="BLANK_FILL",l[l.TEXT_FILL=3]="TEXT_FILL",l[l.SORT=5]="SORT",l[l.SCALE=6]="SCALE",l))(l||{});const L={0:"single",1:"multiple",2:"blank_fill",3:"text_fill",5:"sort",6:"scale"};function t(l){return{single:0,multiple:1,blank_fill:2,text_fill:3,sort:5,scale:6}[l]??0}function e(l){return L[l]||"single"}export{l as ExamType,L as ExamTypeMap,t as getExamType,e as getSubjectType};
1
+ var l=(l=>(l.SINGLE="single",l.MULTIPLE="multiple",l.BLANK_FILL="blank_fill",l.TEXT_FILL="text_fill",l.SORT="sort",l.SCALE="scale",l.RICH_TEXT="rich_text",l.PAGE_END="page_end",l))(l||{});export{l as SubjectType};
2
2
  //# sourceMappingURL=types.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.mjs","sources":["../../../../packages/components-wc/src/subject/types.ts"],"sourcesContent":["export enum ExamType {\n SINGLE = 0,\n MULTIPLE = 1,\n BLANK_FILL = 2,\n TEXT_FILL = 3,\n SORT = 5,\n SCALE = 6,\n}\n\nexport const ExamTypeMap = {\n [ExamType.SINGLE]: 'single',\n [ExamType.MULTIPLE]: 'multiple',\n [ExamType.BLANK_FILL]: 'blank_fill',\n [ExamType.TEXT_FILL]: 'text_fill',\n [ExamType.SORT]: 'sort',\n [ExamType.SCALE]: 'scale',\n} as const\n\nexport const ExamTypeLabelMap = {\n [ExamType.SINGLE]: '单选题',\n [ExamType.MULTIPLE]: '多选题',\n [ExamType.BLANK_FILL]: '填空题',\n [ExamType.TEXT_FILL]: '问答题',\n [ExamType.SORT]: '排序题',\n [ExamType.SCALE]: '量表题',\n} as const\n\nexport type SubjectType = 'single' | 'multiple' | 'blank_fill' | 'text_fill' | 'sort' | 'scale'\n\nexport function getExamType(type: SubjectType): ExamType {\n const map: Record<SubjectType, ExamType> = {\n 'single': ExamType.SINGLE,\n 'multiple': ExamType.MULTIPLE,\n 'blank_fill': ExamType.BLANK_FILL,\n 'text_fill': ExamType.TEXT_FILL,\n 'sort': ExamType.SORT,\n 'scale': ExamType.SCALE,\n }\n return map[type] ?? ExamType.SINGLE\n}\n\nexport function getSubjectType(examType: number): SubjectType {\n return ExamTypeMap[examType as ExamType] || 'single'\n}\n"],"names":["ExamType","ExamTypeMap","getExamType","type","single","multiple","blank_fill","text_fill","sort","scale","getSubjectType","examType"],"mappings":"IAAYA,GAAAA,IACVA,EAAAA,SAAS,GAAT,SACAA,EAAAA,WAAW,GAAX,WACAA,EAAAA,aAAa,GAAb,aACAA,EAAAA,YAAY,GAAZ,YACAA,EAAAA,OAAO,GAAP,OACAA,EAAAA,QAAQ,GAAR,QANUA,IAAAA,GAAA,CAAA,GASL,MAAMC,EAAc,CACzB,EAAmB,SACnB,EAAqB,WACrB,EAAuB,aACvB,EAAsB,YACtB,EAAiB,OACjB,EAAkB,SAcb,SAASC,EAAYC,GAS1B,MAR2C,CACzCC,OAAU,EACVC,SAAY,EACZC,WAAc,EACdC,UAAa,EACbC,KAAQ,EACRC,MAAS,GAEAN,IAAS,CACtB,CAEO,SAASO,EAAeC,GAC7B,OAAOV,EAAYU,IAAyB,QAC9C"}
1
+ {"version":3,"file":"types.mjs","sources":["../../../../packages/components-wc/src/subject/types.ts"],"sourcesContent":["export enum SubjectType {\n SINGLE = 'single',\n MULTIPLE = 'multiple',\n BLANK_FILL = 'blank_fill',\n TEXT_FILL = 'text_fill',\n SORT = 'sort',\n SCALE = 'scale',\n RICH_TEXT = 'rich_text',\n PAGE_END = 'page_end',\n}\n\nexport const SubjectTypeLabel: Record<SubjectType, string> = {\n [SubjectType.SINGLE]: '单选题',\n [SubjectType.MULTIPLE]: '多选题',\n [SubjectType.BLANK_FILL]: '填空题',\n [SubjectType.TEXT_FILL]: '问答题',\n [SubjectType.SORT]: '排序题',\n [SubjectType.SCALE]: '量表题',\n [SubjectType.RICH_TEXT]: '富文本块',\n [SubjectType.PAGE_END]: '分页符',\n}\n"],"names":["SubjectType"],"mappings":"IAAYA,GAAAA,IACVA,EAAA,OAAS,SACTA,EAAA,SAAW,WACXA,EAAA,WAAa,aACbA,EAAA,UAAY,YACZA,EAAA,KAAO,OACPA,EAAA,MAAQ,QACRA,EAAA,UAAY,YACZA,EAAA,SAAW,WARDA,IAAAA,GAAA,CAAA"}
@@ -2,7 +2,7 @@
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>`;exports.QxsBlankFill=class extends t.LitElement{constructor(){super(...arguments),this.orderIndex=0,this.title="",this.customId="",this.isEdit=!1,this.isSave=!1,this.isSet=!1,this.isKey=!1,this.showAction=!0,this.showAnalysis=!0,this.richTextContent="",this.analysis="",this.examAnswerRelationType=0,this.examExpand="",this.examAnswerSetting={isInOrder:!1,isIgnoreCase:!0},this.uploadImage=async t=>new Promise((e,s)=>{const i=new FileReader;i.onload=t=>e(t.target?.result),i.onerror=s,i.readAsDataURL(t)}),this.answerList=[],this.modelValue="",this.useModel=!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("isEdit")&&this.isEdit&&this._syncProps(),t.has("modelValue")&&this.useModel&&(this._title=this.modelValue.replaceAll(/<filter><\/filter>/g," ______"))}_syncProps(){if(this._title=(this.title||"").replaceAll(/<filter><\/filter>/g," ______"),this._analysis=this.analysis||"",this.answerList?.length)this._answers=this.answerList.map(t=>({title:t.title||"",tag:"",showInput:!1}));else{const t=(this._title.match(/ ______/g)||[]).length||1;this._answers=Array.from({length:t},()=>({title:"",tag:"",showInput:!1}))}this.examAnswerSetting&&(this._isInOrder=!!this.examAnswerSetting.isInOrder,this._isIgnoreCase=!!this.examAnswerSetting.isIgnoreCase),this.richTextContent&&(this._richText=this.richTextContent,this._showRichText=!0)}_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.useModel){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 s=e.title.split(","),i=s.findIndex(e=>e===t);i>-1&&(s.splice(i,1),e.title=s.join(",")),this.requestUpdate()}}async toJSON(){return new Promise((t,e)=>{const s={customId:this.customId||void 0,answerType:"blank_fill",orderIndex:this.orderIndex},i=this.isEdit?this._title:this.title?.replaceAll(/<filter><\/filter>/g," ______")||"",a=this.isEdit?this._answers:this.answerList||[],o=this.isEdit?this._analysis:this.analysis||"",n=this.isEdit?this._isInOrder:this.examAnswerSetting?.isInOrder??!1,p=this.isEdit?this._isIgnoreCase:this.examAnswerSetting?.isIgnoreCase??!0,h=this.isEdit?this._showRichText:!!this.richTextContent,d=this.isEdit?this._richText:this.richTextContent||"";if(!i)return void e(new l.SubjectError("题目标题不能为空!","EMPTY_TITLE","title",s));if(a.length<1)return void e(new l.SubjectError("至少添加一个填空符!","NO_BLANK","answers",s));const c={answerType:r.ExamType.BLANK_FILL,title:i.replaceAll(/ ______/g,"<filter></filter>"),answers:a.map(t=>({title:t.title,isCorrect:!0})),analysis:o,isSetCorrectAnswer:!0,isKey:this.isKey,examAnswerSettingBO:{isIgnoreCase:p,isInOrder:n},examRichTextContent:h?d:""};this.customId&&(c.customId=this.customId),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.customId||void 0,answerType:"blank_fill",orderIndex:this.orderIndex},s=this.isEdit?this._title:this.title?.replaceAll(/<filter><\/filter>/g," ______")||"",i=this.isEdit?this._answers:this.answerList||[];return s||t.push(new l.SubjectError("题目标题不能为空!","EMPTY_TITLE","title",e)),i.length<1&&t.push(new l.SubjectError("至少添加一个填空符!","NO_BLANK","answers",e)),t}_renderPreview(){const e=this.title.replaceAll(/<filter><\/filter>/g," ______");return t.html`
5
+ </svg>`;exports.QxsBlankFill=class extends t.LitElement{constructor(){super(...arguments),this.orderIndex=0,this.title="",this.customId="",this.isEdit=!1,this.isSave=!1,this.isSet=!1,this.isKey=!1,this.showAction=!0,this.showAnalysis=!0,this.richTextContent="",this.analysis="",this.examAnswerRelationType=0,this.examExpand="",this.examAnswerSetting={isInOrder:!1,isIgnoreCase:!0},this.uploadImage=async t=>new Promise((e,s)=>{const i=new FileReader;i.onload=t=>e(t.target?.result),i.onerror=s,i.readAsDataURL(t)}),this.answerList=[],this.modelValue="",this.useModel=!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("isEdit")&&this.isEdit&&this._syncProps(),t.has("modelValue")&&this.useModel&&(this._title=this.modelValue.replaceAll(/<filter><\/filter>/g," ______"))}_syncProps(){if(this._title=(this.title||"").replaceAll(/<filter><\/filter>/g," ______"),this._analysis=this.analysis||"",this.answerList?.length)this._answers=this.answerList.map(t=>({title:t.title||"",tag:"",showInput:!1}));else{const t=(this._title.match(/ ______/g)||[]).length||1;this._answers=Array.from({length:t},()=>({title:"",tag:"",showInput:!1}))}this.examAnswerSetting&&(this._isInOrder=!!this.examAnswerSetting.isInOrder,this._isIgnoreCase=!!this.examAnswerSetting.isIgnoreCase),this.richTextContent&&(this._richText=this.richTextContent,this._showRichText=!0)}_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.useModel){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 s=e.title.split(","),i=s.findIndex(e=>e===t);i>-1&&(s.splice(i,1),e.title=s.join(",")),this.requestUpdate()}}async toJSON(){return new Promise((t,e)=>{const s={customId:this.customId||void 0,answerType:"blank_fill",orderIndex:this.orderIndex},i=this.isEdit?this._title:this.title?.replaceAll(/<filter><\/filter>/g," ______")||"",a=this.isEdit?this._answers:this.answerList||[],o=this.isEdit?this._analysis:this.analysis||"",n=this.isEdit?this._isInOrder:this.examAnswerSetting?.isInOrder??!1,p=this.isEdit?this._isIgnoreCase:this.examAnswerSetting?.isIgnoreCase??!0,h=this.isEdit?this._showRichText:!!this.richTextContent,d=this.isEdit?this._richText:this.richTextContent||"";if(!i)return void e(new l.SubjectError("题目标题不能为空!","EMPTY_TITLE","title",s));if(a.length<1)return void e(new l.SubjectError("至少添加一个填空符!","NO_BLANK","answers",s));const c={answerType:r.SubjectType.BLANK_FILL,title:i.replaceAll(/ ______/g,"<filter></filter>"),answers:a.map(t=>({title:t.title,isCorrect:!0})),analysis:o,isSetCorrectAnswer:!0,isKey:this.isKey,examAnswerSettingBO:{isIgnoreCase:p,isInOrder:n},examRichTextContent:h?d:""};this.customId&&(c.customId=this.customId),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.customId||void 0,answerType:"blank_fill",orderIndex:this.orderIndex},s=this.isEdit?this._title:this.title?.replaceAll(/<filter><\/filter>/g," ______")||"",i=this.isEdit?this._answers:this.answerList||[];return s||t.push(new l.SubjectError("题目标题不能为空!","EMPTY_TITLE","title",e)),i.length<1&&t.push(new l.SubjectError("至少添加一个填空符!","NO_BLANK","answers",e)),t}_renderPreview(){const e=this.title.replaceAll(/<filter><\/filter>/g," ______");return t.html`
6
6
  <div class="preview">
7
7
  <span class="title">${this.orderIndex+1}.${e}(填空题)</span>
8
8
  ${this.richTextContent?t.html`<div class="rich-text" .innerHTML=${this.richTextContent}></div>`:""}
@@ -1 +1 @@
1
- {"version":3,"file":"blank-fill.cjs","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 { ExamType } 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' }) orderIndex = 0\n @property({ type: String }) title = ''\n @property({ type: String, attribute: 'custom-id' }) customId = ''\n @property({ type: Boolean, attribute: 'is-edit' }) isEdit = false\n @property({ type: Boolean, attribute: 'is-save' }) isSave = false\n @property({ type: Boolean, attribute: 'is-set' }) isSet = false\n @property({ type: Boolean, attribute: 'is-key' }) isKey = false\n @property({ type: Boolean, attribute: 'show-action' }) showAction = true\n @property({ type: Boolean, attribute: 'show-analysis' }) showAnalysis = true\n @property({ type: String, attribute: 'rich-text-content' }) richTextContent = ''\n @property({ type: String }) analysis = ''\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) examAnswerRelationType = 0\n @property({ type: String, attribute: 'exam-expand' }) examExpand = ''\n @property({ type: Object, attribute: 'exam-answer-setting' })\n examAnswerSetting: { isInOrder: boolean, isIgnoreCase: boolean } = { isInOrder: false, isIgnoreCase: true }\n @property({ type: Object })\n uploadImage: (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' }) answerList: any[] = []\n\n // 双向绑定支持\n @property({ type: String, attribute: 'model-value' }) modelValue = ''\n @property({ type: Boolean, attribute: 'use-model' }) useModel = 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('isEdit') && this.isEdit) { this._syncProps() }\n // 当外部 modelValue 变化时同步内部状态\n if (changed.has('modelValue') && this.useModel) {\n this._title = this.modelValue.replaceAll(/<filter><\\/filter>/g, ' ______')\n }\n }\n\n private _syncProps() {\n this._title = (this.title || '').replaceAll(/<filter><\\/filter>/g, ' ______')\n this._analysis = this.analysis || ''\n if (this.answerList?.length) {\n this._answers = this.answerList.map((a: any) => ({ title: a.title || '', 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.examAnswerSetting) {\n this._isInOrder = !!this.examAnswerSetting.isInOrder\n this._isIgnoreCase = !!this.examAnswerSetting.isIgnoreCase\n }\n if (this.richTextContent) { this._richText = this.richTextContent; this._showRichText = true }\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.useModel) {\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.customId || undefined, answerType: 'blank_fill', orderIndex: this.orderIndex }\n\n const title = this.isEdit ? this._title : this.title?.replaceAll(/<filter><\\/filter>/g, ' ______') || ''\n const answers = this.isEdit ? this._answers : (this.answerList || [])\n const analysis = this.isEdit ? this._analysis : this.analysis || ''\n const isInOrder = this.isEdit ? this._isInOrder : this.examAnswerSetting?.isInOrder ?? false\n const isIgnoreCase = this.isEdit ? this._isIgnoreCase : this.examAnswerSetting?.isIgnoreCase ?? true\n const showRichText = this.isEdit ? this._showRichText : !!this.richTextContent\n const richText = this.isEdit ? this._richText : this.richTextContent || ''\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: ExamType.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.isKey,\n examAnswerSettingBO: { isIgnoreCase, isInOrder },\n examRichTextContent: showRichText ? richText : '',\n }\n if (this.customId) { result.customId = this.customId }\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.customId || undefined, answerType: 'blank_fill', orderIndex: this.orderIndex }\n\n const title = this.isEdit ? this._title : this.title?.replaceAll(/<filter><\\/filter>/g, ' ______') || ''\n const answers = this.isEdit ? this._answers : (this.answerList || [])\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 return html`\n <div class=\"preview\">\n <span class=\"title\">${this.orderIndex + 1}.${displayTitle}(填空题)</span>\n ${this.richTextContent ? html`<div class=\"rich-text\" .innerHTML=${this.richTextContent}></div>` : ''}\n ${this._answers.some(a => a.title)\n ? html`\n <div class=\"content flex flex-wrap\">\n <span>正确答案:</span>\n ${this._answers.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.isSave}\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.isSave ? 'is-disabled' : ''}\"\n @click=${() => {\n if (!this.isSave) { 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._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.isSave ? html`<span class=\"el-tag__close\" @click=${() => this._closeTag(tag, a)}>×</span>` : ''}\n </span>\n `)}\n ${!this.isSave\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 .uploadImage=${this.uploadImage}\n ?is-edit=${true}\n ></qxs-blocksuite-editor>\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 </div>\n </div>\n `\n : ''}\n\n ${this.showAnalysis\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.isEdit}>\n <div slot=\"preview\">${this._renderPreview()}</div>\n <div slot=\"edit\">${this._renderEdit()}</div>\n ${this.showAction\n ? html`\n <qxs-subject-action\n ?is-edit=${this.isEdit}\n ?is-set=${this.isSet}\n ?show-other-option=${false}\n exam-answer-relation-type=${this.examAnswerRelationType}\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=${() => { this._showRichText = true }}\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","orderIndex","title","customId","isEdit","isSave","isSet","isKey","showAction","showAnalysis","richTextContent","analysis","examAnswerRelationType","examExpand","examAnswerSetting","isInOrder","isIgnoreCase","uploadImage","async","Promise","resolve","reject","reader","FileReader","onload","e","target","result","onerror","readAsDataURL","file","answerList","modelValue","useModel","_title","_analysis","_answers","tag","showInput","_isInOrder","_isIgnoreCase","_showRichText","_richText","TITLE_MAX","willUpdate","changed","has","_syncProps","replaceAll","length","map","a","blankCount","match","Array","from","_emit","name","detail","dispatchEvent","CustomEvent","bubbles","composed","_addBlank","requestUpdate","_emitModelUpdate","_onTitleInput","el","value","slice","i","_handleAddTag","item","join","_closeTag","tags","split","idx","findIndex","t","splice","toJSON","row","answerType","answers","showRichText","richText","SubjectError","ExamType","BLANK_FILL","isCorrect","isSetCorrectAnswer","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","some","_renderEdit","checked","filter","Boolean","key","updateComplete","then","shadowRoot","querySelector","focus","render","styles","css","__decorateClass","property","type","Number","attribute","prototype","String","state","safeCustomElement"],"mappings":"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"}
1
+ {"version":3,"file":"blank-fill.cjs","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' }) orderIndex = 0\n @property({ type: String }) title = ''\n @property({ type: String, attribute: 'custom-id' }) customId = ''\n @property({ type: Boolean, attribute: 'is-edit' }) isEdit = false\n @property({ type: Boolean, attribute: 'is-save' }) isSave = false\n @property({ type: Boolean, attribute: 'is-set' }) isSet = false\n @property({ type: Boolean, attribute: 'is-key' }) isKey = false\n @property({ type: Boolean, attribute: 'show-action' }) showAction = true\n @property({ type: Boolean, attribute: 'show-analysis' }) showAnalysis = true\n @property({ type: String, attribute: 'rich-text-content' }) richTextContent = ''\n @property({ type: String }) analysis = ''\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) examAnswerRelationType = 0\n @property({ type: String, attribute: 'exam-expand' }) examExpand = ''\n @property({ type: Object, attribute: 'exam-answer-setting' })\n examAnswerSetting: { isInOrder: boolean, isIgnoreCase: boolean } = { isInOrder: false, isIgnoreCase: true }\n @property({ type: Object })\n uploadImage: (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' }) answerList: any[] = []\n\n // 双向绑定支持\n @property({ type: String, attribute: 'model-value' }) modelValue = ''\n @property({ type: Boolean, attribute: 'use-model' }) useModel = 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('isEdit') && this.isEdit) { this._syncProps() }\n // 当外部 modelValue 变化时同步内部状态\n if (changed.has('modelValue') && this.useModel) {\n this._title = this.modelValue.replaceAll(/<filter><\\/filter>/g, ' ______')\n }\n }\n\n private _syncProps() {\n this._title = (this.title || '').replaceAll(/<filter><\\/filter>/g, ' ______')\n this._analysis = this.analysis || ''\n if (this.answerList?.length) {\n this._answers = this.answerList.map((a: any) => ({ title: a.title || '', 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.examAnswerSetting) {\n this._isInOrder = !!this.examAnswerSetting.isInOrder\n this._isIgnoreCase = !!this.examAnswerSetting.isIgnoreCase\n }\n if (this.richTextContent) { this._richText = this.richTextContent; this._showRichText = true }\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.useModel) {\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.customId || undefined, answerType: 'blank_fill', orderIndex: this.orderIndex }\n\n const title = this.isEdit ? this._title : this.title?.replaceAll(/<filter><\\/filter>/g, ' ______') || ''\n const answers = this.isEdit ? this._answers : (this.answerList || [])\n const analysis = this.isEdit ? this._analysis : this.analysis || ''\n const isInOrder = this.isEdit ? this._isInOrder : this.examAnswerSetting?.isInOrder ?? false\n const isIgnoreCase = this.isEdit ? this._isIgnoreCase : this.examAnswerSetting?.isIgnoreCase ?? true\n const showRichText = this.isEdit ? this._showRichText : !!this.richTextContent\n const richText = this.isEdit ? this._richText : this.richTextContent || ''\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.isKey,\n examAnswerSettingBO: { isIgnoreCase, isInOrder },\n examRichTextContent: showRichText ? richText : '',\n }\n if (this.customId) { result.customId = this.customId }\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.customId || undefined, answerType: 'blank_fill', orderIndex: this.orderIndex }\n\n const title = this.isEdit ? this._title : this.title?.replaceAll(/<filter><\\/filter>/g, ' ______') || ''\n const answers = this.isEdit ? this._answers : (this.answerList || [])\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 return html`\n <div class=\"preview\">\n <span class=\"title\">${this.orderIndex + 1}.${displayTitle}(填空题)</span>\n ${this.richTextContent ? html`<div class=\"rich-text\" .innerHTML=${this.richTextContent}></div>` : ''}\n ${this._answers.some(a => a.title)\n ? html`\n <div class=\"content flex flex-wrap\">\n <span>正确答案:</span>\n ${this._answers.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.isSave}\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.isSave ? 'is-disabled' : ''}\"\n @click=${() => {\n if (!this.isSave) { 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._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.isSave ? html`<span class=\"el-tag__close\" @click=${() => this._closeTag(tag, a)}>×</span>` : ''}\n </span>\n `)}\n ${!this.isSave\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 .uploadImage=${this.uploadImage}\n ?is-edit=${true}\n ></qxs-blocksuite-editor>\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 </div>\n </div>\n `\n : ''}\n\n ${this.showAnalysis\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.isEdit}>\n <div slot=\"preview\">${this._renderPreview()}</div>\n <div slot=\"edit\">${this._renderEdit()}</div>\n ${this.showAction\n ? html`\n <qxs-subject-action\n ?is-edit=${this.isEdit}\n ?is-set=${this.isSet}\n ?show-other-option=${false}\n exam-answer-relation-type=${this.examAnswerRelationType}\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=${() => { this._showRichText = true }}\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","orderIndex","title","customId","isEdit","isSave","isSet","isKey","showAction","showAnalysis","richTextContent","analysis","examAnswerRelationType","examExpand","examAnswerSetting","isInOrder","isIgnoreCase","uploadImage","async","Promise","resolve","reject","reader","FileReader","onload","e","target","result","onerror","readAsDataURL","file","answerList","modelValue","useModel","_title","_analysis","_answers","tag","showInput","_isInOrder","_isIgnoreCase","_showRichText","_richText","TITLE_MAX","willUpdate","changed","has","_syncProps","replaceAll","length","map","a","blankCount","match","Array","from","_emit","name","detail","dispatchEvent","CustomEvent","bubbles","composed","_addBlank","requestUpdate","_emitModelUpdate","_onTitleInput","el","value","slice","i","_handleAddTag","item","join","_closeTag","tags","split","idx","findIndex","t","splice","toJSON","row","answerType","answers","showRichText","richText","SubjectError","SubjectType","BLANK_FILL","isCorrect","isSetCorrectAnswer","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","some","_renderEdit","checked","filter","Boolean","key","updateComplete","then","shadowRoot","querySelector","focus","render","styles","css","__decorateClass","property","type","Number","attribute","prototype","String","state","safeCustomElement"],"mappings":"kiBAQA,MAAMA,EAAWC,EAAAA,IAAA;;;;UAoBJC,QAAAA,aAAN,cAA2BC,EAAAA,WAA3BC,WAAAA,GAAAC,SAAAC,WAiFiDC,KAAAC,WAAa,EACvCD,KAAAE,MAAQ,GACgBF,KAAAG,SAAW,GACZH,KAAAI,QAAS,EACTJ,KAAAK,QAAS,EACVL,KAAAM,OAAQ,EACRN,KAAAO,OAAQ,EACHP,KAAAQ,YAAa,EACXR,KAAAS,cAAe,EACZT,KAAAU,gBAAkB,GAClDV,KAAAW,SAAW,GAC6BX,KAAAY,uBAAyB,EACvCZ,KAAAa,WAAa,GAEnEb,KAAAc,kBAAmE,CAAEC,WAAW,EAAOC,cAAc,GAErGhB,KAAAiB,YAA+CC,SACtC,IAAIC,QAAQ,CAACC,EAASC,KAC3B,MAAMC,EAAS,IAAIC,WACnBD,EAAOE,OAAUC,GAAML,EAAQK,EAAEC,QAAQC,QACzCL,EAAOM,QAAUP,EACjBC,EAAOO,cAAcC,KAI4B9B,KAAA+B,WAAoB,GAGnB/B,KAAAgC,WAAa,GACdhC,KAAAiC,UAAW,EAEvDjC,KAAQkC,OAAS,GACjBlC,KAAQmC,UAAY,GACpBnC,KAAQoC,SAA0B,CAAC,CAAElC,MAAO,GAAImC,IAAK,GAAIC,WAAW,IACpEtC,KAAQuC,YAAa,EACrBvC,KAAQwC,eAAgB,EACxBxC,KAAQyC,eAAgB,EACxBzC,KAAQ0C,UAAY,GAE7B1C,KAAiB2C,UAAY,GAAA,CAE7BC,UAAAA,CAAWC,GACLA,EAAQC,IAAI,WAAa9C,KAAKI,QAAUJ,KAAK+C,aAE7CF,EAAQC,IAAI,eAAiB9C,KAAKiC,WACpCjC,KAAKkC,OAASlC,KAAKgC,WAAWgB,WAAW,sBAAuB,WAEpE,CAEQD,UAAAA,GAGN,GAFA/C,KAAKkC,QAAUlC,KAAKE,OAAS,IAAI8C,WAAW,sBAAuB,WACnEhD,KAAKmC,UAAYnC,KAAKW,UAAY,GAC9BX,KAAK+B,YAAYkB,OACnBjD,KAAKoC,SAAWpC,KAAK+B,WAAWmB,IAAKC,IAAA,CAAcjD,MAAOiD,EAAEjD,OAAS,GAAImC,IAAK,GAAIC,WAAW,SAE1F,CACH,MAAMc,GAAcpD,KAAKkC,OAAOmB,MAAM,aAAe,IAAIJ,QAAU,EACnEjD,KAAKoC,SAAWkB,MAAMC,KAAK,CAAEN,OAAQG,GAAc,KAAA,CAASlD,MAAO,GAAImC,IAAK,GAAIC,WAAW,IAC7F,CACItC,KAAKc,oBACPd,KAAKuC,aAAevC,KAAKc,kBAAkBC,UAC3Cf,KAAKwC,gBAAkBxC,KAAKc,kBAAkBE,cAE5ChB,KAAKU,kBAAmBV,KAAK0C,UAAY1C,KAAKU,gBAAiBV,KAAKyC,eAAgB,EAC1F,CAEQe,KAAAA,CAAMC,EAAcC,GAC1B1D,KAAK2D,cAAc,IAAIC,YAAYH,EAAM,CAAEI,SAAS,EAAMC,UAAU,EAAMJ,OAAQA,GAAU,OAC9F,CAEQK,SAAAA,GACN/D,KAAKkC,QAAU,UACflC,KAAKoC,SAAW,IAAIpC,KAAKoC,SAAU,CAAElC,MAAO,GAAImC,IAAK,GAAIC,WAAW,IACpEtC,KAAKgE,gBACLhE,KAAKiE,kBACP,CAEQC,aAAAA,CAAczC,GACpB,MAAM0C,EAAK1C,EAAEC,OACTyC,EAAGC,MAAMnB,OAASjD,KAAK2C,YAAawB,EAAGC,MAAQD,EAAGC,MAAMC,MAAM,EAAGrE,KAAK2C,YAC1E3C,KAAKkC,OAASiC,EAAGC,MACjB,MAAMhB,GAAcpD,KAAKkC,OAAOmB,MAAM,aAAe,IAAIJ,OACzD,GAAIG,IAAepD,KAAKoC,SAASa,OAC/B,GAAIG,EAAapD,KAAKoC,SAASa,OAC7B,IAAA,IAASqB,EAAItE,KAAKoC,SAASa,OAAQqB,EAAIlB,EAAYkB,IACjDtE,KAAKoC,SAAW,IAAIpC,KAAKoC,SAAU,CAAElC,MAAO,GAAImC,IAAK,GAAIC,WAAW,SAItEtC,KAAKoC,SAAWpC,KAAKoC,SAASiC,MAAM,EAAGjB,GAG3CpD,KAAKiE,kBACP,CAGQA,gBAAAA,GACN,GAAIjE,KAAKiC,SAAU,CACjB,MAAMD,EAAahC,KAAKkC,OAAOc,WAAW,WAAY,qBACtDhD,KAAK2D,cAAc,IAAIC,YAAY,oBAAqB,CACtDC,SAAS,EACTC,UAAU,EACVJ,OAAQ1B,IAEZ,CACF,CAEQuC,aAAAA,CAAcC,GACpBA,EAAKlC,WAAY,EACbkC,EAAKnC,MACPmC,EAAKtE,MAAQsE,EAAKtE,MAAQ,CAACsE,EAAKtE,MAAOsE,EAAKnC,KAAKoC,KAAK,KAAOD,EAAKnC,IAClEmC,EAAKnC,IAAM,IAEbrC,KAAKgE,eACP,CAEQU,SAAAA,CAAUrC,EAAamC,GAC7B,GAAInC,EAAK,CACP,MAAMsC,EAAOH,EAAKtE,MAAM0E,MAAM,KACxBC,EAAMF,EAAKG,UAAWC,GAAcA,IAAM1C,GAC5CwC,GAAM,IAAMF,EAAKK,OAAOH,EAAK,GAAIL,EAAKtE,MAAQyE,EAAKF,KAAK,MAC5DzE,KAAKgE,eACP,CACF,CAEA,YAAMiB,GACJ,OAAO,IAAI9D,QAAQ,CAACC,EAASC,KAC3B,MAAM6D,EAAM,CAAE/E,SAAUH,KAAKG,eAAY,EAAWgF,WAAY,aAAclF,WAAYD,KAAKC,YAEzFC,EAAQF,KAAKI,OAASJ,KAAKkC,OAASlC,KAAKE,OAAO8C,WAAW,sBAAuB,YAAc,GAChGoC,EAAUpF,KAAKI,OAASJ,KAAKoC,SAAYpC,KAAK+B,YAAc,GAC5DpB,EAAWX,KAAKI,OAASJ,KAAKmC,UAAYnC,KAAKW,UAAY,GAC3DI,EAAYf,KAAKI,OAASJ,KAAKuC,WAAavC,KAAKc,mBAAmBC,YAAa,EACjFC,EAAehB,KAAKI,OAASJ,KAAKwC,cAAgBxC,KAAKc,mBAAmBE,eAAgB,EAC1FqE,EAAerF,KAAKI,OAASJ,KAAKyC,gBAAkBzC,KAAKU,gBACzD4E,EAAWtF,KAAKI,OAASJ,KAAK0C,UAAY1C,KAAKU,iBAAmB,GAExE,IAAKR,EAEH,YADAmB,EAAO,IAAIkE,EAAAA,aAAa,YAAa,cAAe,QAASL,IAG/D,GAAIE,EAAQnC,OAAS,EAEnB,YADA5B,EAAO,IAAIkE,EAAAA,aAAa,aAAc,WAAY,UAAWL,IAG/D,MAAMvD,EAAc,CAClBwD,WAAYK,EAAAA,YAAYC,WACxBvF,MAAOA,EAAM8C,WAAW,WAAY,qBACpCoC,QAASA,EAAQlC,IAAKC,IAAA,CAAcjD,MAAOiD,EAAEjD,MAAOwF,WAAW,KAC/D/E,WACAgF,oBAAoB,EACpBpF,MAAOP,KAAKO,MACZqF,oBAAqB,CAAE5E,eAAcD,aACrC8E,oBAAqBR,EAAeC,EAAW,IAE7CtF,KAAKG,WAAYwB,EAAOxB,SAAWH,KAAKG,UAC5CiB,EAAQO,IAEZ,CAEA,WAAcmE,CAAMrE,GAClBA,GAAGsE,2BACH,IACE,MAAMC,QAAahG,KAAKiF,SACxBjF,KAAKwD,MAAM,OAAQwC,EACrB,OACOC,IArQX,SAAmBC,GACjB,MAAM/B,EAAKgC,SAASC,cAAc,OAClCjC,EAAGkC,YAAcH,EACjBI,OAAOC,OAAOpC,EAAGqC,MAAO,CACtBC,SAAU,QAASC,IAAK,OAAQC,KAAM,MAAOC,UAAW,mBACxDC,QAAS,YAAaC,aAAc,MAAOC,SAAU,OAAQC,MAAO,OACpEC,WAAY,UAAWC,OAAQ,QAASC,UAAW,6BACnDC,WAAY,cAAeC,QAAS,MAEtClB,SAASmB,KAAKC,YAAYpD,GAC1BqD,WAAW,KAAQrD,EAAGqC,MAAMa,QAAU,IAAKG,WAAW,IAAMrD,EAAGsD,SAAU,MAAQ,KACnF,CA2PMC,CAAUzB,EAAI0B,QAChB,CACF,CAEAC,QAAAA,GACE,MAAMC,EAAyB,GACzB3C,EAAM,CAAE/E,SAAUH,KAAKG,eAAY,EAAWgF,WAAY,aAAclF,WAAYD,KAAKC,YAEzFC,EAAQF,KAAKI,OAASJ,KAAKkC,OAASlC,KAAKE,OAAO8C,WAAW,sBAAuB,YAAc,GAChGoC,EAAUpF,KAAKI,OAASJ,KAAKoC,SAAYpC,KAAK+B,YAAc,GASlE,OAPK7B,GACH2H,EAAOC,KAAK,IAAIvC,EAAAA,aAAa,YAAa,cAAe,QAASL,IAEhEE,EAAQnC,OAAS,GACnB4E,EAAOC,KAAK,IAAIvC,EAAAA,aAAa,aAAc,WAAY,UAAWL,IAG7D2C,CACT,CAEQE,cAAAA,GACN,MAAMC,EAAehI,KAAKE,MAAM8C,WAAW,sBAAuB,WAClE,OAAOtD,EAAAA,IAAA;;8BAEmBM,KAAKC,WAAa,KAAK+H;UAC3ChI,KAAKU,gBAAkBhB,MAAA,qCAAyCM,KAAKU,yBAA2B;UAChGV,KAAKoC,SAAS6F,KAAK9E,GAAKA,EAAEjD,OACxBR,EAAAA,IAAA;;;cAGEM,KAAKoC,SAASc,IAAI,CAACC,EAAGmB,IAAMnB,EAAEjD,MAC5BR,EAAAA,IAAA;kDACkC4E,EAAI,MAAMnB,EAAEjD;cAE9C;;UAGJ;UACFF,KAAKW,SAAWjB,MAAA,gEAAoEM,KAAKW,iBAAmB;;KAGpH,CAEQuH,WAAAA,GACN,OAAOxI,EAAAA,IAAA;;;;;wCAK6BM,KAAKkC,oBAAoBlC,KAAKK;0BAC5CL,KAAK2C;uBACPlB,GAAazB,KAAKkE,cAAczC;;yCAEfzB,KAAKkC,OAAOe,UAAUjD,KAAK2C;;;;;;+BAMrC3C,KAAKK,OAAS,cAAgB;mBAC1C,KACFL,KAAKK,QAAUL,KAAK+D;;;;;;4CAOO/D,KAAKuC;sBAC1Bd,IAAezB,KAAKuC,WAAcd,EAAEC,OAA4ByG;;;;4CAI3CnI,KAAKwC;sBAC1Bf,IAAezB,KAAKwC,cAAiBf,EAAEC,OAA4ByG;;;;;QAKlFnI,KAAKoC,SAASc,IAAI,CAACC,EAAGmB,IAAM5E,EAAAA,IAAA;;sCAEE4E,EAAI;;cAE5BnB,EAAEjD,MAAM0E,MAAM,KAAKwD,OAAOC,SAASnF,IAAIb,GAAO3C,EAAAA,IAAA;;kBAE1C2C;kBACCrC,KAAKK,OAA6F,GAApFX,EAAAA,IAAA,sCAA0C,IAAMM,KAAK0E,UAAUrC,EAAKc;;;cAGtFnD,KAAKK,OAkBJ,GAjBAX,EAAAA,IAAA;gBACAyD,EAAEb,UACA5C,EAAAA,IAAA;;6BAEY+B,IACI,UAAVA,EAAE6G,KAAmBtI,KAAKuE,cAAcpB;2BAEpC1B,IAAe0B,EAAEd,IAAOZ,EAAEC,OAA4B0C;0BACxD,IAAMpE,KAAKuE,cAAcpB;gBAEjCzD,EAAAA,IAAA;wDACsC,KAAQyD,EAAEb,WAAY,EAAMtC,KAAKgE,gBAAiBhE,KAAKuI,eAAeC,KAAK,KAASxI,KAAKyI,YAAYC,cAAc,qBAA0CC;oBACjMlJ;0BACM0D,EAAEjD,MAAQ,QAAU;;;;;;;;QAStCF,KAAKyC,cACH/C,EAAAA,IAAA;;;;;yBAKeM,KAAK0C;6BACD1C,KAAKiB;0BACT;;;mEAG0C,KAAQjB,KAAKyC,eAAgB,EAAOzC,KAAK0C,UAAY;;;;QAK9G;;QAEF1C,KAAKS,aACHf,EAAAA,IAAA;;;;;0CAKgCM,KAAKmC;yBACrBV,IAAezB,KAAKmC,UAAaV,EAAEC,OAA+B0C;;;;;QAMlF;KAER,CAEAwE,MAAAA,GACE,OAAOlJ,EAAAA,IAAA;uCAC4BM,KAAKI;8BACdJ,KAAK+H;2BACR/H,KAAKkI;UACtBlI,KAAKQ,WACHd,EAAAA,IAAA;;uBAEWM,KAAKI;sBACNJ,KAAKM;kCACM;wCACON,KAAKY;sBACvB,IAAMZ,KAAKwD,MAAM;oBACnBxD,KAAK8F;oBACL,IAAM9F,KAAKwD,MAAM;mBACjB/B,GAAmBzB,KAAKwD,MAAM,MAAO/B,EAAEiC;uBACnCjC,IAAqBzB,KAAKwD,MAAM,UAAW/B,EAAEiC;iCACpC,KAAQ1D,KAAKyC,eAAgB;;UAGlD;;KAGV,GAnaW9C,QAAAA,aACJkJ,OAASC,EAAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAgFsCC,EAAA,CAArDC,EAAAA,SAAS,CAAEC,KAAMC,OAAQC,UAAW,iBAjF1BxJ,QAAAA,aAiF2CyJ,UAAA,aAAA,GAC1BL,EAAA,CAA3BC,EAAAA,SAAS,CAAEC,KAAMI,UAlFP1J,QAAAA,aAkFiByJ,UAAA,QAAA,GACwBL,EAAA,CAAnDC,EAAAA,SAAS,CAAEC,KAAMI,OAAQF,UAAW,eAnF1BxJ,QAAAA,aAmFyCyJ,UAAA,WAAA,GACDL,EAAA,CAAlDC,EAAAA,SAAS,CAAEC,KAAMZ,QAASc,UAAW,aApF3BxJ,QAAAA,aAoFwCyJ,UAAA,SAAA,GACAL,EAAA,CAAlDC,EAAAA,SAAS,CAAEC,KAAMZ,QAASc,UAAW,aArF3BxJ,QAAAA,aAqFwCyJ,UAAA,SAAA,GACDL,EAAA,CAAjDC,EAAAA,SAAS,CAAEC,KAAMZ,QAASc,UAAW,YAtF3BxJ,QAAAA,aAsFuCyJ,UAAA,QAAA,GACAL,EAAA,CAAjDC,EAAAA,SAAS,CAAEC,KAAMZ,QAASc,UAAW,YAvF3BxJ,QAAAA,aAuFuCyJ,UAAA,QAAA,GACKL,EAAA,CAAtDC,EAAAA,SAAS,CAAEC,KAAMZ,QAASc,UAAW,iBAxF3BxJ,QAAAA,aAwF4CyJ,UAAA,aAAA,GACEL,EAAA,CAAxDC,EAAAA,SAAS,CAAEC,KAAMZ,QAASc,UAAW,mBAzF3BxJ,QAAAA,aAyF8CyJ,UAAA,eAAA,GACGL,EAAA,CAA3DC,EAAAA,SAAS,CAAEC,KAAMI,OAAQF,UAAW,uBA1F1BxJ,QAAAA,aA0FiDyJ,UAAA,kBAAA,GAChCL,EAAA,CAA3BC,EAAAA,SAAS,CAAEC,KAAMI,UA3FP1J,QAAAA,aA2FiByJ,UAAA,WAAA,GACwCL,EAAA,CAAnEC,EAAAA,SAAS,CAAEC,KAAMC,OAAQC,UAAW,+BA5F1BxJ,QAAAA,aA4FyDyJ,UAAA,yBAAA,GACdL,EAAA,CAArDC,EAAAA,SAAS,CAAEC,KAAMI,OAAQF,UAAW,iBA7F1BxJ,QAAAA,aA6F2CyJ,UAAA,aAAA,GAEtDL,EAAA,CADCC,EAAAA,SAAS,CAAEC,KAAM3C,OAAQ6C,UAAW,yBA9F1BxJ,QAAAA,aA+FXyJ,UAAA,oBAAA,GAEAL,EAAA,CADCC,EAAAA,SAAS,CAAEC,KAAM3C,UAhGP3G,QAAAA,aAiGXyJ,UAAA,cAAA,GASqDL,EAAA,CAApDC,EAAAA,SAAS,CAAEC,KAAM3F,MAAO6F,UAAW,iBA1GzBxJ,QAAAA,aA0G0CyJ,UAAA,aAAA,GAGCL,EAAA,CAArDC,EAAAA,SAAS,CAAEC,KAAMI,OAAQF,UAAW,iBA7G1BxJ,QAAAA,aA6G2CyJ,UAAA,aAAA,GACDL,EAAA,CAApDC,EAAAA,SAAS,CAAEC,KAAMZ,QAASc,UAAW,eA9G3BxJ,QAAAA,aA8G0CyJ,UAAA,WAAA,GAEpCL,EAAA,CAAhBO,EAAAA,SAhHU3J,QAAAA,aAgHMyJ,UAAA,SAAA,GACAL,EAAA,CAAhBO,EAAAA,SAjHU3J,QAAAA,aAiHMyJ,UAAA,YAAA,GACAL,EAAA,CAAhBO,EAAAA,SAlHU3J,QAAAA,aAkHMyJ,UAAA,WAAA,GACAL,EAAA,CAAhBO,EAAAA,SAnHU3J,QAAAA,aAmHMyJ,UAAA,aAAA,GACAL,EAAA,CAAhBO,EAAAA,SApHU3J,QAAAA,aAoHMyJ,UAAA,gBAAA,GACAL,EAAA,CAAhBO,EAAAA,SArHU3J,QAAAA,aAqHMyJ,UAAA,gBAAA,GACAL,EAAA,CAAhBO,EAAAA,SAtHU3J,QAAAA,aAsHMyJ,UAAA,YAAA,GAtHNzJ,QAAAA,aAANoJ,EAAA,CADNQ,EAAAA,kBAAkB,mBACN5J,QAAAA"}
@@ -1,4 +1,4 @@
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("sortablejs"),a=require("../base/define.cjs"),r=require("../base/uid.cjs"),n=require("./single.cjs"),o=require("./types.cjs");require("./action.cjs"),require("./blank-fill.cjs"),require("./layout.cjs"),require("./text-fill.cjs"),require("./scale.cjs"),require("./page-end.cjs"),require("./rich-text.cjs"),require("./type.cjs");var l=Object.defineProperty,d=Object.getOwnPropertyDescriptor,c=(e,t,s,i)=>{for(var a,r=i>1?void 0:i?d(t,s):t,n=e.length-1;n>=0;n--)(a=e[n])&&(r=(i?a(t,s,r):a(r))||r);return i&&r&&l(t,s,r),r};exports.QxsSubjectList=class extends e.LitElement{constructor(){super(...arguments),this.isPreview=!1,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._list=[],this._sortMode=!1,this._sortable=null,this._initialDataProcessed=!1}get subjectList(){return this._list}set subjectList(e){if(e){if("string"==typeof e)try{e=JSON.parse(e)}catch{return this._list=[],void this.requestUpdate()}if(!Array.isArray(e))return this._list=[],void this.requestUpdate();this._list=e.map(e=>({...e,customId:e.customId||r.uid()})),this.requestUpdate()}else this._list=[]}attributeChangedCallback(e,t,s){if(super.attributeChangedCallback(e,t,s),"subject-list"===e&&s&&!this._list.length){if(s.includes("[object Object]"))return;try{const e=JSON.parse(s);Array.isArray(e)&&(this._list=e.map(e=>({...e,customId:e.customId||r.uid()})),this.requestUpdate())}catch{}}}get _isPreviewValue(){const e=this.isPreview;return"string"==typeof e?"false"!==e:!!e}connectedCallback(){super.connectedCallback(),this._initialDataProcessed||(this._initialDataProcessed=!0,Promise.resolve().then(()=>{0===this._list.length&&this._processAttributeList()}))}_processAttributeList(){const e=this.getAttribute("subject-list");if(e&&"[]"!==e&&!e.includes("[object Object]"))try{const t=JSON.parse(e);Array.isArray(t)&&t.length>0&&(this._list=t.map(e=>({...e,customId:e.customId||r.uid()})),this.requestUpdate())}catch{}}firstUpdated(){this.updateComplete.then(()=>this._initSortable())}updated(e){e.has("_sortMode")&&(this._sortable?.destroy(),this._sortable=null,this.updateComplete.then(()=>this._initSortable())),e.has("_list")&&this._sortMode&&setTimeout(()=>{this._sortable&&(this._sortable.destroy(),this._sortable=null),this._initSortable()},50)}disconnectedCallback(){super.disconnectedCallback(),this._sortable?.destroy(),this._sortable=null}_initSortable(){if(!this._sortMode)return;this.querySelector(".sort-list")&&(this._sortable&&(this._sortable.destroy(),this._sortable=null),requestAnimationFrame(()=>{const e=this.querySelector(".sort-list");e&&!this._sortable&&(this._sortable=i.create(e,{handle:".sort-handle",animation:200,ghostClass:"sort-ghost",chosenClass:"sort-chosen",onEnd:e=>{const{oldIndex:t,newIndex:s}=e;if(void 0===t||void 0===s||t===s)return;const i=[...this._list],[a]=i.splice(t,1);i.splice(s,0,a),this._list=i,this._emit("change",this._list)}}))}))}_emit(e,t){this.dispatchEvent(new CustomEvent(e,{bubbles:!0,composed:!0,detail:t??null}))}async toJSON(){const e=this.querySelectorAll("qxs-subject-single, qxs-blank-fill, qxs-text-fill, qxs-scale, qxs-subject-rich-text");if(!e||0===e.length)return[];const t=[],s=[];for(const i of e)if("function"==typeof i.toJSON)try{const e=await i.toJSON();t.push(e)}catch(e){e instanceof n.SubjectError?s.push(e):s.push(new n.SubjectError(e.message||"未知错误","UNKNOWN","unknown"))}if(s.length>0)throw s;return t}async validate(){const e=this.querySelectorAll("qxs-subject-single, qxs-blank-fill, qxs-text-fill, qxs-scale, qxs-subject-rich-text");if(!e||0===e.length)return{valid:!0,errors:[]};const t=[];for(const s of e)if("function"==typeof s.validate){const e=s.validate();e?.length&&t.push(...e)}return{valid:0===t.length,errors:t}}get currentList(){return this._list}addSubject(e,t){let s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null;const i={customId:r.uid(),answerType:e,title:"",answers:[],analysis:"",scaleQuestionList:[],isEdit:!0,isSave:!1,isRealCanDel:!0,hasSet:!1,isKey:!1,answerCheckType:1,examAnswerRelationType:s??0},a=[...this._list];"number"==typeof t&&t>=0?a.splice(t+1,0,i):a.push(i),this._list=a,this.requestUpdate(),this._emit("change",this._list)}addExam(e){let t=1;const s=[];e.forEach(e=>{const i={...e,customId:e.customId||r.uid(),answers:e.answers?.map(e=>({...e,title:e.answer,answerId:e.examAnswerId,isCorrect:e.isCorrect}))||[],isEdit:!0,isSave:!1,isRealCanDel:!0,hasSet:!1};e.richTextContent||(i.answerType=o.getSubjectType(e.examTypeEnum)),i.pageIndex>t&&(s.push({customId:r.uid(),answerType:"page_end",analysis:"",scaleQuestionList:[],isEdit:!0,isSave:!1,isRealCanDel:!0,hasSet:!1,examAnswerRelationType:0}),t=i.pageIndex),s.push(i)}),this._list=[...this._list,...s],this._emit("change",this._list)}uploadExcel(e){this._list=[...this._list,...e.map(e=>({...e,customId:e.customId||r.uid(),isRealCanDel:!0}))],this._emit("change",this._list)}setAnswerRelation(e,t,s){const i=this._list.find(e=>e.customId===t);if(i){const t=i.answers?.find(e=>e.customAnswerId===s);t&&(t.answerRelations=e)}this.requestUpdate(),this._emit("change",this._list)}_orderIndex(e){let t=0,s=0;return this._list.forEach(i=>{"page_end"!==i.answerType&&(t++,i.customId===e&&(s=t))}),s-1}_pageIndex(e){return this._list.filter(e=>"page_end"===e.answerType).findIndex(t=>t.customId===e)+1}_totalPages(){return this._list.filter(e=>"page_end"===e.answerType).length}_move(e,t){const s=[...this._list];"up"===t&&e>0?[s[e-1],s[e]]=[s[e],s[e-1]]:"down"===t&&e<s.length-1&&([s[e],s[e+1]]=[s[e+1],s[e]]),this._list=s,this._emit("change",this._list)}_save(e,t){this._list=this._list.map((s,i)=>i===e?{...s,...t.detail,isEdit:!1,isSave:!0}:s),this._emit("change",this._list)}_deleteByCustomId(e){this._list=this._list.filter(t=>t.customId!==e),this._emit("change",this._list)}_delete(e){const t=[...this._list];t.splice(e,1),this._list=t,this._emit("change",this._list)}_setEdit(e,t){this._list=this._list.map((s,i)=>i===e?{...s,isEdit:t}:s)}_renderItem(t,s){const i=this._orderIndex(t.customId),a=(t.isEdit,t.hasSet,t.isRealCanDel,this._isPreviewValue,t.examAnswerRelationType,e=>this._move(s,e.detail)),r=()=>this._deleteByCustomId(t.customId),n=e=>this._save(s,e),o=()=>this._setEdit(s,!0),l=e=>this.addSubject(e.detail?.type??e.detail,s);return["single","multiple","sort"].includes(t.answerType)?e.html`<qxs-subject-single
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("sortablejs"),r=require("../base/define.cjs"),a=require("../base/uid.cjs"),n=require("./single.cjs"),o=require("./types.cjs");require("./action.cjs"),require("./blank-fill.cjs"),require("./layout.cjs"),require("./text-fill.cjs"),require("./scale.cjs"),require("./page-end.cjs"),require("./rich-text.cjs"),require("./type.cjs");var l=Object.defineProperty,c=Object.getOwnPropertyDescriptor,d=(e,t,s,i)=>{for(var r,a=i>1?void 0:i?c(t,s):t,n=e.length-1;n>=0;n--)(r=e[n])&&(a=(i?r(t,s,a):r(a))||a);return i&&a&&l(t,s,a),a};o.SubjectType.SINGLE,o.SubjectType.MULTIPLE,o.SubjectType.SORT,o.SubjectType.BLANK_FILL,o.SubjectType.TEXT_FILL,o.SubjectType.SCALE,o.SubjectType.RICH_TEXT,o.SubjectType.PAGE_END,exports.QxsSubjectList=class extends e.LitElement{constructor(){super(...arguments),this.isPreview=!1,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._list=[],this._sortMode=!1,this._sortable=null,this._initialDataProcessed=!1}get subjectList(){return this._list}set subjectList(e){if(e){if("string"==typeof e)try{e=JSON.parse(e)}catch{return this._list=[],void this.requestUpdate()}if(!Array.isArray(e))return this._list=[],void this.requestUpdate();this._list=e.map(e=>({...e,customId:e.customId||a.uid()})),this.requestUpdate()}else this._list=[]}attributeChangedCallback(e,t,s){if(super.attributeChangedCallback(e,t,s),"subject-list"===e&&s&&!this._list.length){if(s.includes("[object Object]"))return;try{const e=JSON.parse(s);Array.isArray(e)&&(this._list=e.map(e=>({...e,customId:e.customId||a.uid()})),this.requestUpdate())}catch{}}}get _isPreviewValue(){const e=this.isPreview;return"string"==typeof e?"false"!==e:!!e}connectedCallback(){super.connectedCallback(),this._initialDataProcessed||(this._initialDataProcessed=!0,Promise.resolve().then(()=>{0===this._list.length&&this._processAttributeList()}))}_processAttributeList(){const e=this.getAttribute("subject-list");if(e&&"[]"!==e&&!e.includes("[object Object]"))try{const t=JSON.parse(e);Array.isArray(t)&&t.length>0&&(this._list=t.map(e=>({...e,customId:e.customId||a.uid()})),this.requestUpdate())}catch{}}firstUpdated(){this.updateComplete.then(()=>this._initSortable())}updated(e){e.has("_sortMode")&&(this._sortable?.destroy(),this._sortable=null,this.updateComplete.then(()=>this._initSortable())),e.has("_list")&&this._sortMode&&setTimeout(()=>{this._sortable&&(this._sortable.destroy(),this._sortable=null),this._initSortable()},50)}disconnectedCallback(){super.disconnectedCallback(),this._sortable?.destroy(),this._sortable=null}_initSortable(){if(!this._sortMode)return;this.querySelector(".sort-list")&&(this._sortable&&(this._sortable.destroy(),this._sortable=null),requestAnimationFrame(()=>{const e=this.querySelector(".sort-list");e&&!this._sortable&&(this._sortable=i.create(e,{handle:".sort-handle",animation:200,ghostClass:"sort-ghost",chosenClass:"sort-chosen",onEnd:e=>{const{oldIndex:t,newIndex:s}=e;if(void 0===t||void 0===s||t===s)return;const i=[...this._list],[r]=i.splice(t,1);i.splice(s,0,r),this._list=i,this._emit("change",this._list)}}))}))}_emit(e,t){this.dispatchEvent(new CustomEvent(e,{bubbles:!0,composed:!0,detail:t??null}))}async toJSON(){const e=this.querySelectorAll("qxs-subject-single, qxs-blank-fill, qxs-text-fill, qxs-scale, qxs-subject-rich-text");if(!e||0===e.length)return[];const t=[],s=[];for(const i of e)if("function"==typeof i.toJSON)try{const e=await i.toJSON();t.push(e)}catch(e){e instanceof n.SubjectError?s.push(e):s.push(new n.SubjectError(e.message||"未知错误","UNKNOWN","unknown"))}if(s.length>0)throw s;return t}async validate(){const e=this.querySelectorAll("qxs-subject-single, qxs-blank-fill, qxs-text-fill, qxs-scale, qxs-subject-rich-text");if(!e||0===e.length)return{valid:!0,errors:[]};const t=[];for(const s of e)if("function"==typeof s.validate){const e=s.validate();e?.length&&t.push(...e)}return{valid:0===t.length,errors:t}}get currentList(){return this._list}addSubject(e,t){let s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null;const i={customId:a.uid(),answerType:e,title:"",answers:[],analysis:"",scaleQuestionList:[],isEdit:!0,isSave:!1,isRealCanDel:!0,hasSet:!1,isKey:!1,answerCheckType:1,examAnswerRelationType:s??0},r=[...this._list];"number"==typeof t&&t>=0?r.splice(t+1,0,i):r.push(i),this._list=r,this.requestUpdate(),this._emit("change",this._list)}addExam(e){let t=1;const s=[];e.forEach(e=>{const i={...e,customId:e.customId||a.uid(),answers:e.answers?.map(e=>({...e,title:e.answer,answerId:e.examAnswerId,isCorrect:e.isCorrect}))||[],isEdit:!0,isSave:!1,isRealCanDel:!0,hasSet:!1};e.richTextContent||(i.answerType=e.examTypeEnum),i.pageIndex>t&&(s.push({customId:a.uid(),answerType:"page_end",analysis:"",scaleQuestionList:[],isEdit:!0,isSave:!1,isRealCanDel:!0,hasSet:!1,examAnswerRelationType:0}),t=i.pageIndex),s.push(i)}),this._list=[...this._list,...s],this._emit("change",this._list)}uploadExcel(e){this._list=[...this._list,...e.map(e=>({...e,customId:e.customId||a.uid(),isRealCanDel:!0}))],this._emit("change",this._list)}setAnswerRelation(e,t,s){const i=this._list.find(e=>e.customId===t);if(i){const t=i.answers?.find(e=>e.customAnswerId===s);t&&(t.answerRelations=e)}this.requestUpdate(),this._emit("change",this._list)}_orderIndex(e){let t=0,s=0;return this._list.forEach(i=>{"page_end"!==i.answerType&&(t++,i.customId===e&&(s=t))}),s-1}_pageIndex(e){return this._list.filter(e=>"page_end"===e.answerType).findIndex(t=>t.customId===e)+1}_totalPages(){return this._list.filter(e=>"page_end"===e.answerType).length}_move(e,t){const s=[...this._list];"up"===t&&e>0?[s[e-1],s[e]]=[s[e],s[e-1]]:"down"===t&&e<s.length-1&&([s[e],s[e+1]]=[s[e+1],s[e]]),this._list=s,this._emit("change",this._list)}_save(e,t){this._list=this._list.map((s,i)=>i===e?{...s,...t.detail,isEdit:!1,isSave:!0}:s),this._emit("change",this._list)}_deleteByCustomId(e){this._list=this._list.filter(t=>t.customId!==e),this._emit("change",this._list)}_delete(e){const t=[...this._list];t.splice(e,1),this._list=t,this._emit("change",this._list)}_setEdit(e,t){this._list=this._list.map((s,i)=>i===e?{...s,isEdit:t}:s)}_renderItem(t,s){const i=this._orderIndex(t.customId),r=(t.isEdit,t.hasSet,t.isRealCanDel,this._isPreviewValue,t.examAnswerRelationType,e=>this._move(s,e.detail)),a=()=>this._deleteByCustomId(t.customId),n=e=>this._save(s,e),l=()=>this._setEdit(s,!0),c=e=>this.addSubject(e.detail?.type??e.detail,s);return[o.SubjectType.SINGLE,o.SubjectType.MULTIPLE,o.SubjectType.SORT].includes(t.answerType)?e.html`<qxs-subject-single
2
2
  .title=${t.title||""}
3
3
  .answerList=${t.answers||[]}
4
4
  .uploadImage=${this.uploadImage}
@@ -17,9 +17,9 @@
17
17
  exam-expand=${t.examExpand||""}
18
18
  custom-id=${t.customId||""}
19
19
  exam-id=${t.examId??0}
20
- @move=${a} @delete=${r} @save=${n} @edit=${o} @add=${l}
20
+ @move=${r} @delete=${a} @save=${n} @edit=${l} @add=${c}
21
21
  @set-relation=${e=>this._emit("set-relation",e.detail)}
22
- ></qxs-subject-single>`:"blank_fill"===t.answerType?e.html`<qxs-blank-fill
22
+ ></qxs-subject-single>`:t.answerType===o.SubjectType.BLANK_FILL?e.html`<qxs-blank-fill
23
23
  .title=${t.title||""}
24
24
  .answerList=${t.answers||[]}
25
25
  .examAnswerSetting=${t.examAnswerSettingVO||{}}
@@ -31,8 +31,8 @@
31
31
  rich-text-content=${t.examRichTextContent||""}
32
32
  analysis=${t.analysis||""}
33
33
  custom-id=${t.customId||""}
34
- @move=${a} @delete=${r} @save=${n} @edit=${o} @add=${l}
35
- ></qxs-blank-fill>`:"text_fill"===t.answerType?e.html`<qxs-text-fill
34
+ @move=${r} @delete=${a} @save=${n} @edit=${l} @add=${c}
35
+ ></qxs-blank-fill>`:t.answerType===o.SubjectType.TEXT_FILL?e.html`<qxs-text-fill
36
36
  .title=${t.title||""}
37
37
  .answerList=${t.answers||[]}
38
38
  .examAnswerSetting=${t.examAnswerSettingVO||{}}
@@ -44,8 +44,8 @@
44
44
  rich-text-content=${t.examRichTextContent||""}
45
45
  analysis=${t.analysis||""}
46
46
  custom-id=${t.customId||""}
47
- @move=${a} @delete=${r} @save=${n} @edit=${o} @add=${l}
48
- ></qxs-text-fill>`:"scale"===t.answerType?e.html`<qxs-scale
47
+ @move=${r} @delete=${a} @save=${n} @edit=${l} @add=${c}
48
+ ></qxs-text-fill>`:t.answerType===o.SubjectType.SCALE?e.html`<qxs-scale
49
49
  .title=${t.title||""}
50
50
  .answerList=${t.answers||[]}
51
51
  .scaleQuestions=${t.scaleQuestionList||[]}
@@ -56,7 +56,7 @@
56
56
  rich-text-content=${t.examRichTextContent||""}
57
57
  analysis=${t.analysis||""}
58
58
  custom-id=${t.customId||""}
59
- @move=${a} @delete=${r} @save=${n} @edit=${o} @add=${l}
59
+ @move=${r} @delete=${a} @save=${n} @edit=${l} @add=${c}
60
60
  ></qxs-scale>`:"rich_text"===t.answerType?e.html`<qxs-subject-rich-text
61
61
  .uploadImage=${this.uploadImage}
62
62
  order-index=${i}
@@ -64,12 +64,12 @@
64
64
  exam-answer-relation-type=${t.examAnswerRelationType??0}
65
65
  rich-text-content=${t.richTextContent||t.examRichTextContent||""}
66
66
  custom-id=${t.customId||""}
67
- @move=${a} @delete=${r} @save=${n} @edit=${o} @add=${l}
67
+ @move=${r} @delete=${a} @save=${n} @edit=${l} @add=${c}
68
68
  ></qxs-subject-rich-text>`:"page_end"===t.answerType?e.html`<qxs-page-end
69
69
  current-page-index=${this._pageIndex(t.customId)}
70
70
  total-page=${this._totalPages()}
71
71
  ?show-action=${!this._isPreviewValue}
72
- @move=${a} @delete=${r} @add=${l}
72
+ @move=${r} @delete=${a} @add=${c}
73
73
  ></qxs-page-end>`:e.html`<div style="color:#909399;padding:8px">未知题型: ${t.answerType}</div>`}render(){return e.html`
74
74
  <div class="subject-list">
75
75
  ${this._list.map((e,t)=>this._renderItem(e,t))}
@@ -96,5 +96,5 @@
96
96
  .sort-index { font-size: 13px; color: #606266; font-weight: 500; margin-right: 8px; min-width: 24px; flex-shrink: 0; }
97
97
  .sort-title { flex: 1; font-size: 14px; color: #303133; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
98
98
  .sort-type { font-size: 12px; color: #909399; margin-left: 12px; padding: 2px 8px; background: #f0f0f0; border-radius: 4px; flex-shrink: 0; }
99
- `,c([t.property({attribute:"is-preview"})],exports.QxsSubjectList.prototype,"isPreview",2),c([t.property({type:Object})],exports.QxsSubjectList.prototype,"uploadImage",2),c([t.property({type:Array})],exports.QxsSubjectList.prototype,"subjectList",1),c([s.state()],exports.QxsSubjectList.prototype,"_list",2),c([s.state()],exports.QxsSubjectList.prototype,"_sortMode",2),exports.QxsSubjectList=c([a.safeCustomElement("qxs-subject-list")],exports.QxsSubjectList);
99
+ `,d([t.property({attribute:"is-preview"})],exports.QxsSubjectList.prototype,"isPreview",2),d([t.property({type:Object})],exports.QxsSubjectList.prototype,"uploadImage",2),d([t.property({type:Array})],exports.QxsSubjectList.prototype,"subjectList",1),d([s.state()],exports.QxsSubjectList.prototype,"_list",2),d([s.state()],exports.QxsSubjectList.prototype,"_sortMode",2),exports.QxsSubjectList=d([r.safeCustomElement("qxs-subject-list")],exports.QxsSubjectList);
100
100
  //# sourceMappingURL=list.cjs.map