@qxs-bns/components-wc 0.0.31 → 0.0.33
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/editor/blocksuite-editor.mjs +1 -1
- package/es/editor/blocksuite-editor.mjs.map +1 -1
- package/es/subject/layout.mjs +1 -1
- package/es/subject/layout.mjs.map +1 -1
- package/es/subject/scale.mjs +13 -7
- package/es/subject/scale.mjs.map +1 -1
- package/es/subject/shared-styles.mjs +2 -2
- package/es/subject/shared-styles.mjs.map +1 -1
- package/lib/editor/blocksuite-editor.cjs +1 -1
- package/lib/editor/blocksuite-editor.cjs.map +1 -1
- package/lib/subject/layout.cjs +1 -1
- package/lib/subject/layout.cjs.map +1 -1
- package/lib/subject/scale.cjs +9 -3
- package/lib/subject/scale.cjs.map +1 -1
- package/lib/subject/shared-styles.cjs +2 -2
- package/lib/subject/shared-styles.cjs.map +1 -1
- package/package.json +1 -1
package/lib/subject/layout.cjs
CHANGED
|
@@ -16,6 +16,6 @@
|
|
|
16
16
|
:host { display: block; width: 100%; font-family: inherit; font-size: 12px; color: #5a5a5a; }
|
|
17
17
|
.layout { }
|
|
18
18
|
.preview { padding: 12px 10px 10px; }
|
|
19
|
-
.edit { position: relative; padding: 12px 10px 10px;
|
|
19
|
+
.edit { position: relative; padding: 12px 10px 10px; border-radius: 6px; }
|
|
20
20
|
`,i([e.property({type:Boolean,attribute:"show-edit"})],exports.QxsSubjectLayout.prototype,"show-edit",2),exports.QxsSubjectLayout=i([s.safeCustomElement("qxs-subject-layout")],exports.QxsSubjectLayout);
|
|
21
21
|
//# sourceMappingURL=layout.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"layout.cjs","sources":["../../../../packages/components-wc/src/subject/layout.ts"],"sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { property } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\n\n@safeCustomElement('qxs-subject-layout')\nexport class QxsSubjectLayout extends LitElement {\n static styles = css`\n :host { display: block; width: 100%; font-family: inherit; font-size: 12px; color: #5a5a5a; }\n .layout { }\n .preview { padding: 12px 10px 10px; }\n .edit { position: relative; padding: 12px 10px 10px;
|
|
1
|
+
{"version":3,"file":"layout.cjs","sources":["../../../../packages/components-wc/src/subject/layout.ts"],"sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { property } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\n\n@safeCustomElement('qxs-subject-layout')\nexport class QxsSubjectLayout extends LitElement {\n static styles = css`\n :host { display: block; width: 100%; font-family: inherit; font-size: 12px; color: #5a5a5a; }\n .layout { }\n .preview { padding: 12px 10px 10px; }\n .edit { position: relative; padding: 12px 10px 10px; border-radius: 6px; }\n `\n\n @property({ type: Boolean, attribute: 'show-edit' }) 'show-edit' = false\n\n render() {\n if (this['show-edit']) {\n return html`\n <div class=\"layout\">\n <div class=\"edit\">\n <slot name=\"edit\"></slot>\n <slot></slot>\n </div>\n </div>\n `\n }\n return html`\n <div class=\"layout\">\n <div class=\"preview\">\n <slot name=\"preview\"></slot>\n <slot></slot>\n </div>\n </div>\n `\n }\n}\n\nexport function register() {}\n"],"names":["QxsSubjectLayout","LitElement","constructor","super","arguments","this","render","html","styles","css","__decorateClass","property","type","Boolean","attribute","prototype","safeCustomElement"],"mappings":"6RAKaA,QAAAA,iBAAN,cAA+BC,EAAAA,WAA/BC,WAAAA,GAAAC,SAAAC,WAQgDC,KAAA,cAAc,CAAA,CAEnEC,MAAAA,GACE,OAAID,KAAK,aACAE,EAAAA,IAAA;;;;;;;QASFA,EAAAA,IAAA;;;;;;;KAQT,GA7BWP,QAAAA,iBACJQ,OAASC,EAAAA,GAAA;;;;;IAOqCC,EAAA,CAApDC,EAAAA,SAAS,CAAEC,KAAMC,QAASC,UAAW,eAR3Bd,QAAAA,iBAQ0Ce,UAAA,YAAA,GAR1Cf,QAAAA,iBAANU,EAAA,CADNM,EAAAA,kBAAkB,uBACNhB,QAAAA"}
|
package/lib/subject/scale.cjs
CHANGED
|
@@ -160,13 +160,19 @@
|
|
|
160
160
|
`}},exports.QxsScale.styles=[l.sortingCardStyles,o.subjectHostStyles,o.subjectControlResetStyles,o.subjectPreviewBaseStyles,o.subjectFormBaseStyles,o.subjectTextareaStyles,t.css`
|
|
161
161
|
.scale-table-wrap {
|
|
162
162
|
margin-top: 18px;
|
|
163
|
+
border: 1px solid #e5e7eb;
|
|
164
|
+
border-radius: 12px;
|
|
165
|
+
background: #fff;
|
|
163
166
|
overflow: hidden;
|
|
164
167
|
}
|
|
165
168
|
.scale-table { width: 100%; border-collapse: collapse; table-layout: fixed; font-size: 13px; color: #4b5563; }
|
|
166
169
|
.scale-table th, .scale-table td { border-bottom: 1px solid #eef2f7; padding: 10px 8px; text-align: center; vertical-align: middle; }
|
|
167
|
-
.scale-table thead th { font-size: 12px; font-weight: 600; color: #8b95a7; }
|
|
168
|
-
.scale-table
|
|
169
|
-
|
|
170
|
+
.scale-table thead th { font-size: 12px; font-weight: 600; color: #8b95a7; background: #f8fafc; }
|
|
171
|
+
.scale-table thead th:first-child {
|
|
172
|
+
background: #f3f4f6;
|
|
173
|
+
}
|
|
174
|
+
.scale-table tbody td:first-child {
|
|
175
|
+
background: #fafafa;
|
|
170
176
|
color: #303133;
|
|
171
177
|
text-align: left;
|
|
172
178
|
font-weight: 600;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scale.cjs","sources":["../../../../packages/components-wc/src/subject/scale.ts"],"sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { property, state } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\nimport { SUB_TEXT_EDITOR_TOOLBAR } from '../editor/toolbar'\nimport { buildSubjectPreviewTitle, buildSubjectSortingTitle, emitSubjectEvent, emitSubjectModelValue, showSubjectToast } from './shared-methods'\nimport { subjectControlResetStyles, subjectFormBaseStyles, subjectHostStyles, subjectPreviewBaseStyles, subjectTextareaStyles } from './shared-styles'\nimport { SubjectError, trimText } from './single'\nimport { renderSortingCard, sortingCardStyles } from './sorting-card'\nimport { SubjectType, SubjectTypeLabel } from './types'\n\ninterface ScaleAnswer {\n title: string\n answerId?: string | number\n orderIndex?: number\n isCorrect?: boolean\n [key: string]: any\n}\n\nfunction createEmptyScaleAnswer(): ScaleAnswer {\n return { title: '' }\n}\n\nfunction createDefaultScaleAnswers(): ScaleAnswer[] {\n return Array.from({ length: 5 }, createEmptyScaleAnswer)\n}\n\nfunction normalizeScaleAnswer(answer: any): ScaleAnswer {\n const next: ScaleAnswer = {\n ...answer,\n title: trimText(answer?.title ?? answer?.answer ?? ''),\n }\n const answerId = answer?.answerId ?? answer?.examAnswerId\n if (answerId !== undefined) {\n next.answerId = answerId\n }\n delete next.answer\n delete next.examAnswerId\n delete next.isCorrect\n return next\n}\n\nfunction normalizeScaleAnswers(value: any): ScaleAnswer[] {\n return Array.isArray(value) ? value.map(normalizeScaleAnswer) : []\n}\n\nfunction normalizeScaleQuestionList(value: any): string[] {\n if (!Array.isArray(value)) {\n return []\n }\n return value\n .map(item => String(item ?? '').trim())\n .filter(Boolean)\n}\n\nfunction splitScaleQuestionLines(value: string): string[] {\n return value\n .split('\\n')\n .map(item => item.trim())\n .filter(Boolean)\n}\n\nfunction serializeScaleAnswer(answer: any, index: number): ScaleAnswer {\n const next: ScaleAnswer = {\n ...normalizeScaleAnswer(answer),\n orderIndex: index + 1,\n answer: trimText(answer?.title ?? answer?.answer ?? ''),\n }\n next.title = trimText(next.title ?? '')\n if (next.answerId !== undefined) {\n next.examAnswerId = next.answerId\n }\n if (next.answerId === undefined) {\n delete next.answerId\n }\n delete next.isCorrect\n return next\n}\n\nconst 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>`\nconst 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@safeCustomElement('qxs-scale')\nexport class QxsScale extends LitElement {\n static styles = [sortingCardStyles, subjectHostStyles, subjectControlResetStyles, subjectPreviewBaseStyles, subjectFormBaseStyles, subjectTextareaStyles, css`\n .scale-table-wrap {\n margin-top: 18px;\n overflow: hidden;\n }\n .scale-table { width: 100%; border-collapse: collapse; table-layout: fixed; font-size: 13px; color: #4b5563; }\n .scale-table th, .scale-table td { border-bottom: 1px solid #eef2f7; padding: 10px 8px; text-align: center; vertical-align: middle; }\n .scale-table thead th { font-size: 12px; font-weight: 600; color: #8b95a7; }\n .scale-table td:first-child,\n .scale-table th:first-child {\n color: #303133;\n text-align: left;\n font-weight: 600;\n }\n .scale-table tbody tr:last-child td { border-bottom: none; }\n .scale-table input[type=\"radio\"] {\n accent-color: #3D61E3;\n }\n\n .flex { display: flex; }\n .flex-items-start { display: flex; align-items: flex-start; }\n .flex-justify-end { display: flex; justify-content: flex-end; }\n .edit-grid {\n display: grid;\n grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);\n gap: 20px;\n }\n .edit-column {\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: 10px;\n }\n .edit-column-title {\n font-size: 12px;\n line-height: 1.4;\n font-weight: 600;\n color: #8b95a7;\n letter-spacing: 0.02em;\n }\n .edit-note {\n font-size: 12px;\n line-height: 1.6;\n color: #909399;\n }\n\n textarea, input[type=\"text\"] { white-space: pre-wrap; }\n input[type=\"text\"] {\n border: 1px solid #dcdfe6; border-radius: 6px; padding: 7px 11px;\n font-size: 13px; font-family: inherit; width: 100%; transition: border-color .2s;\n line-height: 1.5; display: block; box-sizing: border-box;\n }\n input[type=\"text\"]:focus { border-color: #3D61E3; outline: none; }\n input[type=\"text\"]:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n\n .el-link { color: #3D61E3; cursor: pointer; font-size: 12px; }\n .el-link.danger { color: #f56c6c; }\n\n .answer-item { display: flex; align-items: center; gap: 8px; }\n .answer-item .label { min-width: 28px; font-size: 13px; font-weight: 600; color: #6b7280; letter-spacing: 0; }\n .answer-item .input { flex: 1; max-width: 220px; }\n .answer-item .input input {\n height: 36px; padding: 0 10px;\n font-size: 13px; line-height: 32px;\n border: 1px solid #dcdfe6; border-radius: 6px; width: 100%;\n transition: border-color .2s; box-sizing: border-box;\n }\n .answer-item .input input:focus { border-color: #3D61E3; outline: none; }\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 .row-title-textarea { min-height: 220px; }\n\n @media (max-width: 720px) {\n .edit-row {\n flex-direction: column;\n gap: 8px;\n }\n\n .edit-row > .label {\n min-width: 0;\n padding-top: 0;\n }\n\n .edit-grid {\n grid-template-columns: 1fr;\n gap: 16px;\n }\n }\n `]\n\n @property({ type: Number, attribute: 'order-index' }) 'order-index' = 0\n @property({ type: String, attribute: 'subject-prefix' }) 'subject-prefix'?: string\n @property({ type: String }) title = ''\n @property({ type: String, attribute: 'custom-id' }) 'custom-id' = ''\n @property({ type: Boolean, attribute: 'is-edit' }) 'is-edit' = false\n @property({ type: Boolean, attribute: 'is-save' }) 'is-save' = false\n @property({ type: Boolean, attribute: 'is-set' }) 'is-set' = false\n @property({ type: Boolean, attribute: 'show-action' }) 'show-action' = true\n @property({ type: Boolean, attribute: 'show-add' }) 'show-add' = true\n @property({ type: Boolean, attribute: 'hide-add-rich-text' }) 'hide-add-rich-text' = false\n @property({ type: Boolean, attribute: 'show-rich-text' }) 'show-rich-text' = false\n @property({ type: Boolean, attribute: 'show-delete-action' }) 'show-delete-action' = true\n @property({ type: Boolean, attribute: 'show-save-action' }) 'show-save-action' = true\n @property({ type: Boolean, reflect: true }) sorting = false\n @property({ type: Boolean, attribute: 'show-analysis' }) 'show-analysis' = false\n @property({ type: String }) analysis = ''\n @property({ type: String, attribute: 'rich-text-content' }) 'rich-text-content' = ''\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) 'exam-answer-relation-type' = 0\n @property({ type: Object, attribute: 'upload-image' })\n 'upload-image': (file: File) => Promise<string> = async (file: File) => {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.onload = e => resolve(e.target?.result as string)\n reader.onerror = reject\n reader.readAsDataURL(file)\n })\n }\n\n @property({ type: Array, attribute: 'answer-list' })\n get 'answer-list'() { return this._answers }\n\n set 'answer-list'(value: any) {\n const answers = normalizeScaleAnswers(value)\n this._answers = answers.length ? answers : createDefaultScaleAnswers()\n this.requestUpdate('answer-list')\n }\n\n @property({ type: Array, attribute: 'scale-question-list' })\n get 'scale-question-list'() { return this._scaleQuestions }\n\n set 'scale-question-list'(value: any) {\n this._scaleQuestions = normalizeScaleQuestionList(value)\n this.requestUpdate('scale-question-list')\n }\n\n @property({ type: Array, attribute: 'scale-questions' })\n get 'scale-questions'() { return this._scaleQuestions }\n\n set 'scale-questions'(value: any) {\n this['scale-question-list'] = value\n this.requestUpdate('scale-questions')\n }\n\n @state() private _answers: ScaleAnswer[] = createDefaultScaleAnswers()\n @state() private _scaleQuestions: string[] = []\n @state() private _rowTitle = ''\n @state() private _title = ''\n @state() private _analysis = ''\n @state() private _showRichText = false\n @state() private _richText = ''\n\n @property({ type: String, attribute: 'model-value' }) 'model-value' = ''\n @property({ type: Boolean, attribute: 'use-model' }) 'use-model' = false\n\n private readonly TITLE_MAX = 200\n\n willUpdate(changed: Map<string, unknown>) {\n const shouldSyncProps = changed.has('title')\n || changed.has('answer-list')\n || changed.has('rich-text-content')\n || changed.has('scale-question-list')\n || changed.has('scale-questions')\n\n if ((changed.has('is-edit') && this['is-edit']) || (!this['is-edit'] && shouldSyncProps)) {\n this._syncProps()\n }\n\n if (changed.has('model-value') && this['use-model']) {\n this._title = this['model-value']\n }\n }\n\n private _syncProps() {\n this._title = this.title || ''\n this._analysis = this.analysis || ''\n this._rowTitle = this._scaleQuestions.join('\\n')\n this._richText = this['rich-text-content'] || ''\n this._showRichText = !!this['rich-text-content']\n }\n\n private _emit(name: string, detail?: unknown) {\n emitSubjectEvent(this, name, detail)\n }\n\n private _onTitleInput(e: Event) {\n const el = e.target as HTMLTextAreaElement\n if (el.value.length > this.TITLE_MAX) {\n el.value = el.value.slice(0, this.TITLE_MAX)\n }\n this._title = el.value\n if (this['use-model']) {\n emitSubjectModelValue(this, this._title)\n }\n }\n\n private _resolvedQuestions(): string[] {\n const rowTitle = this['is-edit'] ? this._rowTitle : this._scaleQuestions.join('\\n')\n return splitScaleQuestionLines(rowTitle)\n }\n\n private _resolvedAnswers(): ScaleAnswer[] {\n const answers = this['is-edit'] ? this._answers : this['answer-list']\n return Array.isArray(answers) ? answers.map(normalizeScaleAnswer) : []\n }\n\n private _createAnswerCountError(row: Record<string, unknown>) {\n return new SubjectError('量表题选项数量必须在 3-5 个之间!', 'ANSWER_COUNT_INVALID', 'answers', row)\n }\n\n async toJSON(): Promise<any> {\n return new Promise((resolve, reject) => {\n const row = {\n customId: this['custom-id'] || undefined,\n answerType: SubjectType.SCALE,\n orderIndex: this['order-index'],\n }\n\n const title = trimText(this['is-edit'] ? this._title : this.title || '')\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n const richText = this['is-edit'] ? this._richText : this['rich-text-content'] || ''\n const showRichText = this['show-rich-text'] && (this['is-edit'] ? this._showRichText : !!this['rich-text-content'])\n\n if (!title) {\n reject(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n return\n }\n\n if (answers.length < 3 || answers.length > 5) {\n reject(this._createAnswerCountError(row))\n return\n }\n\n for (let i = 0; i < answers.length; i++) {\n if (!answers[i].title) {\n reject(new SubjectError(`选项${String.fromCharCode(65 + i)}未填写。`, 'ANSWER_EMPTY', 'answers', row))\n return\n }\n }\n\n if (questions.length === 0) {\n reject(new SubjectError('行标题不能为空!', 'EMPTY_ROW_TITLE', 'rowTitle', row))\n return\n }\n\n const result: any = {\n answerType: SubjectType.SCALE,\n examTypeEnum: SubjectType.SCALE,\n title,\n answers: answers.map(serializeScaleAnswer),\n scaleQuestionList: questions,\n analysis: trimText(this['is-edit'] ? this._analysis : this.analysis || ''),\n examRichTextContent: showRichText ? richText : '',\n isSetCorrectAnswer: false,\n }\n\n if (this['custom-id']) {\n result.customId = this['custom-id']\n }\n if (this['exam-answer-relation-type']) {\n result.examAnswerRelationType = this['exam-answer-relation-type']\n }\n\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 showSubjectToast(err.message)\n }\n }\n\n validate(): SubjectError[] {\n const errors: SubjectError[] = []\n const row = {\n customId: this['custom-id'] || undefined,\n answerType: SubjectType.SCALE,\n orderIndex: this['order-index'],\n }\n\n const title = trimText(this['is-edit'] ? this._title : this.title || '')\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n\n if (!title) {\n errors.push(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n }\n\n if (answers.length < 3 || answers.length > 5) {\n errors.push(this._createAnswerCountError(row))\n return errors\n }\n\n answers.forEach((answer: ScaleAnswer, index: number) => {\n if (!answer.title) {\n errors.push(new SubjectError(`选项${String.fromCharCode(65 + index)}未填写`, 'ANSWER_EMPTY', 'answers', row))\n }\n })\n\n if (questions.length === 0) {\n errors.push(new SubjectError('行标题不能为空!', 'EMPTY_ROW_TITLE', 'rowTitle', row))\n }\n\n return errors\n }\n\n private _renderPreview() {\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n const colWidth = Math.floor(100 / ((answers.length || 1) + 1))\n const previewTitle = buildSubjectPreviewTitle(this['subject-prefix'], this['order-index'], this.title)\n\n return html`\n <div class=\"preview\">\n <div class=\"preview-header\">\n <div class=\"preview-title-row\">\n <span class=\"title\">${previewTitle}</span>\n <span class=\"preview-type\">量表题</span>\n </div>\n ${this['show-rich-text'] && this['rich-text-content'] ? html`<div class=\"rich-text\" .innerHTML=${this['rich-text-content']}></div>` : ''}\n </div>\n <div class=\"scale-table-wrap\">\n <table class=\"scale-table\">\n <thead>\n <tr>\n <th style=\"width:${colWidth}%\">问题</th>\n ${answers.map(answer => html`<th style=\"width:${colWidth}%\">${answer.title}</th>`)}\n </tr>\n </thead>\n <tbody>\n ${questions.map(question => html`\n <tr>\n <td>${question}</td>\n ${answers.map(() => html`<td><input type=\"radio\" disabled /></td>`)}\n </tr>\n `)}\n </tbody>\n </table>\n </div>\n </div>\n `\n }\n\n private _renderEdit() {\n return html`\n <div class=\"edit-form\">\n <div class=\"edit-row\">\n <div class=\"label\"><span>题目:</span></div>\n <div class=\"row-body\">\n <div class=\"el-input\">\n <textarea\n rows=\"2\"\n .value=${this._title}\n maxlength=${this.TITLE_MAX}\n @input=${(e: Event) => this._onTitleInput(e)}\n placeholder=\"【量表题】请输入问题\"\n ></textarea>\n <span class=\"char-counter\">${this._title.length}/${this.TITLE_MAX}</span>\n </div>\n </div>\n </div>\n\n <slot name=\"business-tag\"></slot>\n\n <div class=\"edit-row\">\n <div class=\"label\"><span>量表内容:</span></div>\n <div class=\"row-body\">\n <div class=\"edit-grid\">\n <div class=\"edit-column\">\n <div class=\"edit-column-title\">行标题</div>\n <div class=\"el-input\">\n <textarea\n class=\"row-title-textarea\"\n .value=${this._rowTitle}\n @input=${(e: Event) => { this._rowTitle = (e.target as HTMLTextAreaElement).value }}\n @keydown=${(e: KeyboardEvent) => { e.stopPropagation() }}\n placeholder=\"请输入行标题\"\n ></textarea>\n </div>\n <div class=\"edit-note\">一行一个标题,预览时会自动整理空白行。</div>\n </div>\n <div class=\"edit-column\">\n <div class=\"edit-column-title\">评分选项</div>\n ${this._answers.map((answer, index) => html`\n <div class=\"answer-item\">\n <span class=\"label\">${String.fromCharCode(65 + index)}.</span>\n <div class=\"input\">\n <input\n type=\"text\"\n .value=${answer.title}\n maxlength=\"10\"\n @input=${(e: Event) => {\n const value = (e.target as HTMLInputElement).value\n this._answers = this._answers.map((item, currentIndex) =>\n currentIndex === index ? { ...item, title: value } : item,\n )\n }}\n placeholder=\"选项${index + 1}\"\n />\n </div>\n <span\n class=\"icon\"\n @click=${() => {\n if (this._answers.length < 5) {\n this._answers = [...this._answers, createEmptyScaleAnswer()]\n }\n }}\n >${iconPlus}</span>\n <span\n class=\"icon ${this._answers.length < 3 ? 'disabled' : ''}\"\n @click=${() => {\n if (this._answers.length > 3) {\n this._answers = this._answers.filter((_, currentIndex) => currentIndex !== index)\n }\n }}\n >${iconRemove}</span>\n </div>\n `)}\n <div class=\"edit-note\">量表题需保持 3-5 个选项,保存时会校验。</div>\n </div>\n </div>\n </div>\n </div>\n\n ${this['show-rich-text'] && this._showRichText\n ? html`\n <div class=\"edit-row\">\n <div class=\"label\"><span>副文本:</span></div>\n <div class=\"row-body\">\n <slot name=\"sub-text\">\n <qxs-blocksuite-editor\n .content=${this._richText}\n .toolbar=${SUB_TEXT_EDITOR_TOOLBAR}\n .upload-image=${this['upload-image']}\n ?is-edit=${true}\n @input=${(e: CustomEvent) => { this._richText = (e.target as any).getContent() }}\n ></qxs-blocksuite-editor>\n </slot>\n ${!this['show-action']\n ? html`\n <div class=\"flex-justify-end\" style=\"margin-top:8px\">\n <span\n class=\"el-link danger\"\n @click=${() => {\n this._showRichText = false\n this._richText = ''\n }}\n >删除富文本</span>\n </div>\n `\n : ''}\n </div>\n </div>\n `\n : ''}\n\n ${this['show-analysis']\n ? html`\n <div class=\"edit-row\">\n <div class=\"label\"><span>解析:</span></div>\n <div class=\"row-body\">\n <div class=\"el-input\">\n <textarea\n rows=\"2\"\n .value=${this._analysis}\n @input=${(e: Event) => { this._analysis = (e.target as HTMLTextAreaElement).value }}\n placeholder=\"请输入题目解析\"\n ></textarea>\n </div>\n </div>\n </div>\n `\n : ''}\n </div>\n `\n }\n\n private _renderSorting() {\n const title = trimText(this['is-edit'] ? this._title : this.title || '') || '未命名题目'\n const orderText = buildSubjectSortingTitle(this['subject-prefix'], this['order-index'], title)\n return renderSortingCard(orderText, SubjectTypeLabel[SubjectType.SCALE] || SubjectType.SCALE)\n }\n\n render() {\n if (this.sorting) {\n return this._renderSorting()\n }\n\n const content = this['is-edit']\n ? html`<div slot=\"edit\">${this._renderEdit()}</div>`\n : html`<div slot=\"preview\">${this._renderPreview()}</div>`\n\n return html`\n <qxs-subject-layout .show-edit=${this['is-edit']}>\n ${content}\n ${this['show-action']\n ? html`\n <qxs-subject-action\n .is-edit=${this['is-edit']}\n .is-set=${this['is-set']}\n .show-add=${this['show-add']}\n .show-rich-text=${this['show-rich-text'] && this._showRichText}\n .hide-add-rich-text=${!this['show-rich-text'] || this['hide-add-rich-text']}\n .show-delete-action=${this['show-delete-action']}\n .show-save-action=${this['show-save-action']}\n .show-other-option=${false}\n exam-answer-relation-type=${this['exam-answer-relation-type']}\n @delete=${() => this._emit('delete')}\n @save=${this._save}\n @edit=${() => this._emit('edit')}\n @add=${(e: CustomEvent) => this._emit('add', e.detail)}\n @on-show-rich-text=${() => {\n this._showRichText = !this._showRichText\n if (!this._showRichText) {\n this._richText = ''\n }\n }}\n ></qxs-subject-action>\n `\n : ''}\n <slot name=\"action\"></slot>\n </qxs-subject-layout>\n `\n }\n}\n\nexport function register() {}\n"],"names":["createEmptyScaleAnswer","title","createDefaultScaleAnswers","Array","from","length","normalizeScaleAnswer","answer","next","trimText","answerId","examAnswerId","isCorrect","serializeScaleAnswer","index","orderIndex","iconPlus","html","iconRemove","QxsScale","LitElement","constructor","super","arguments","this","sorting","analysis","async","Promise","resolve","reject","reader","FileReader","onload","e","target","result","onerror","readAsDataURL","file","_answers","_scaleQuestions","_rowTitle","_title","_analysis","_showRichText","_richText","TITLE_MAX","value","answers","isArray","map","normalizeScaleAnswers","requestUpdate","item","String","trim","filter","Boolean","normalizeScaleQuestionList","willUpdate","changed","shouldSyncProps","has","_syncProps","join","_emit","name","detail","emitSubjectEvent","_onTitleInput","el","slice","emitSubjectModelValue","_resolvedQuestions","rowTitle","split","_resolvedAnswers","_createAnswerCountError","row","SubjectError","toJSON","customId","answerType","SubjectType","SCALE","questions","richText","showRichText","i","fromCharCode","examTypeEnum","scaleQuestionList","examRichTextContent","isSetCorrectAnswer","examAnswerRelationType","_save","stopImmediatePropagation","data","err","showSubjectToast","message","validate","errors","push","forEach","_renderPreview","colWidth","Math","floor","previewTitle","buildSubjectPreviewTitle","question","_renderEdit","stopPropagation","currentIndex","_","SUB_TEXT_EDITOR_TOOLBAR","getContent","_renderSorting","orderText","buildSubjectSortingTitle","renderSortingCard","SubjectTypeLabel","render","content","styles","sortingCardStyles","subjectHostStyles","subjectControlResetStyles","subjectPreviewBaseStyles","subjectFormBaseStyles","subjectTextareaStyles","css","__decorateClass","property","type","Number","attribute","prototype","reflect","Object","state","safeCustomElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"scale.cjs","sources":["../../../../packages/components-wc/src/subject/scale.ts"],"sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { property, state } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\nimport { SUB_TEXT_EDITOR_TOOLBAR } from '../editor/toolbar'\nimport { buildSubjectPreviewTitle, buildSubjectSortingTitle, emitSubjectEvent, emitSubjectModelValue, showSubjectToast } from './shared-methods'\nimport { subjectControlResetStyles, subjectFormBaseStyles, subjectHostStyles, subjectPreviewBaseStyles, subjectTextareaStyles } from './shared-styles'\nimport { SubjectError, trimText } from './single'\nimport { renderSortingCard, sortingCardStyles } from './sorting-card'\nimport { SubjectType, SubjectTypeLabel } from './types'\n\ninterface ScaleAnswer {\n title: string\n answerId?: string | number\n orderIndex?: number\n isCorrect?: boolean\n [key: string]: any\n}\n\nfunction createEmptyScaleAnswer(): ScaleAnswer {\n return { title: '' }\n}\n\nfunction createDefaultScaleAnswers(): ScaleAnswer[] {\n return Array.from({ length: 5 }, createEmptyScaleAnswer)\n}\n\nfunction normalizeScaleAnswer(answer: any): ScaleAnswer {\n const next: ScaleAnswer = {\n ...answer,\n title: trimText(answer?.title ?? answer?.answer ?? ''),\n }\n const answerId = answer?.answerId ?? answer?.examAnswerId\n if (answerId !== undefined) {\n next.answerId = answerId\n }\n delete next.answer\n delete next.examAnswerId\n delete next.isCorrect\n return next\n}\n\nfunction normalizeScaleAnswers(value: any): ScaleAnswer[] {\n return Array.isArray(value) ? value.map(normalizeScaleAnswer) : []\n}\n\nfunction normalizeScaleQuestionList(value: any): string[] {\n if (!Array.isArray(value)) {\n return []\n }\n return value\n .map(item => String(item ?? '').trim())\n .filter(Boolean)\n}\n\nfunction splitScaleQuestionLines(value: string): string[] {\n return value\n .split('\\n')\n .map(item => item.trim())\n .filter(Boolean)\n}\n\nfunction serializeScaleAnswer(answer: any, index: number): ScaleAnswer {\n const next: ScaleAnswer = {\n ...normalizeScaleAnswer(answer),\n orderIndex: index + 1,\n answer: trimText(answer?.title ?? answer?.answer ?? ''),\n }\n next.title = trimText(next.title ?? '')\n if (next.answerId !== undefined) {\n next.examAnswerId = next.answerId\n }\n if (next.answerId === undefined) {\n delete next.answerId\n }\n delete next.isCorrect\n return next\n}\n\nconst 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>`\nconst 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@safeCustomElement('qxs-scale')\nexport class QxsScale extends LitElement {\n static styles = [sortingCardStyles, subjectHostStyles, subjectControlResetStyles, subjectPreviewBaseStyles, subjectFormBaseStyles, subjectTextareaStyles, css`\n .scale-table-wrap {\n margin-top: 18px;\n border: 1px solid #e5e7eb;\n border-radius: 12px;\n background: #fff;\n overflow: hidden;\n }\n .scale-table { width: 100%; border-collapse: collapse; table-layout: fixed; font-size: 13px; color: #4b5563; }\n .scale-table th, .scale-table td { border-bottom: 1px solid #eef2f7; padding: 10px 8px; text-align: center; vertical-align: middle; }\n .scale-table thead th { font-size: 12px; font-weight: 600; color: #8b95a7; background: #f8fafc; }\n .scale-table thead th:first-child {\n background: #f3f4f6;\n }\n .scale-table tbody td:first-child {\n background: #fafafa;\n color: #303133;\n text-align: left;\n font-weight: 600;\n }\n .scale-table tbody tr:last-child td { border-bottom: none; }\n .scale-table input[type=\"radio\"] {\n accent-color: #3D61E3;\n }\n\n .flex { display: flex; }\n .flex-items-start { display: flex; align-items: flex-start; }\n .flex-justify-end { display: flex; justify-content: flex-end; }\n .edit-grid {\n display: grid;\n grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);\n gap: 20px;\n }\n .edit-column {\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: 10px;\n }\n .edit-column-title {\n font-size: 12px;\n line-height: 1.4;\n font-weight: 600;\n color: #8b95a7;\n letter-spacing: 0.02em;\n }\n .edit-note {\n font-size: 12px;\n line-height: 1.6;\n color: #909399;\n }\n\n textarea, input[type=\"text\"] { white-space: pre-wrap; }\n input[type=\"text\"] {\n border: 1px solid #dcdfe6; border-radius: 6px; padding: 7px 11px;\n font-size: 13px; font-family: inherit; width: 100%; transition: border-color .2s;\n line-height: 1.5; display: block; box-sizing: border-box;\n }\n input[type=\"text\"]:focus { border-color: #3D61E3; outline: none; }\n input[type=\"text\"]:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n\n .el-link { color: #3D61E3; cursor: pointer; font-size: 12px; }\n .el-link.danger { color: #f56c6c; }\n\n .answer-item { display: flex; align-items: center; gap: 8px; }\n .answer-item .label { min-width: 28px; font-size: 13px; font-weight: 600; color: #6b7280; letter-spacing: 0; }\n .answer-item .input { flex: 1; max-width: 220px; }\n .answer-item .input input {\n height: 36px; padding: 0 10px;\n font-size: 13px; line-height: 32px;\n border: 1px solid #dcdfe6; border-radius: 6px; width: 100%;\n transition: border-color .2s; box-sizing: border-box;\n }\n .answer-item .input input:focus { border-color: #3D61E3; outline: none; }\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 .row-title-textarea { min-height: 220px; }\n\n @media (max-width: 720px) {\n .edit-row {\n flex-direction: column;\n gap: 8px;\n }\n\n .edit-row > .label {\n min-width: 0;\n padding-top: 0;\n }\n\n .edit-grid {\n grid-template-columns: 1fr;\n gap: 16px;\n }\n }\n `]\n\n @property({ type: Number, attribute: 'order-index' }) 'order-index' = 0\n @property({ type: String, attribute: 'subject-prefix' }) 'subject-prefix'?: string\n @property({ type: String }) title = ''\n @property({ type: String, attribute: 'custom-id' }) 'custom-id' = ''\n @property({ type: Boolean, attribute: 'is-edit' }) 'is-edit' = false\n @property({ type: Boolean, attribute: 'is-save' }) 'is-save' = false\n @property({ type: Boolean, attribute: 'is-set' }) 'is-set' = false\n @property({ type: Boolean, attribute: 'show-action' }) 'show-action' = true\n @property({ type: Boolean, attribute: 'show-add' }) 'show-add' = true\n @property({ type: Boolean, attribute: 'hide-add-rich-text' }) 'hide-add-rich-text' = false\n @property({ type: Boolean, attribute: 'show-rich-text' }) 'show-rich-text' = false\n @property({ type: Boolean, attribute: 'show-delete-action' }) 'show-delete-action' = true\n @property({ type: Boolean, attribute: 'show-save-action' }) 'show-save-action' = true\n @property({ type: Boolean, reflect: true }) sorting = false\n @property({ type: Boolean, attribute: 'show-analysis' }) 'show-analysis' = false\n @property({ type: String }) analysis = ''\n @property({ type: String, attribute: 'rich-text-content' }) 'rich-text-content' = ''\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) 'exam-answer-relation-type' = 0\n @property({ type: Object, attribute: 'upload-image' })\n 'upload-image': (file: File) => Promise<string> = async (file: File) => {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.onload = e => resolve(e.target?.result as string)\n reader.onerror = reject\n reader.readAsDataURL(file)\n })\n }\n\n @property({ type: Array, attribute: 'answer-list' })\n get 'answer-list'() { return this._answers }\n\n set 'answer-list'(value: any) {\n const answers = normalizeScaleAnswers(value)\n this._answers = answers.length ? answers : createDefaultScaleAnswers()\n this.requestUpdate('answer-list')\n }\n\n @property({ type: Array, attribute: 'scale-question-list' })\n get 'scale-question-list'() { return this._scaleQuestions }\n\n set 'scale-question-list'(value: any) {\n this._scaleQuestions = normalizeScaleQuestionList(value)\n this.requestUpdate('scale-question-list')\n }\n\n @property({ type: Array, attribute: 'scale-questions' })\n get 'scale-questions'() { return this._scaleQuestions }\n\n set 'scale-questions'(value: any) {\n this['scale-question-list'] = value\n this.requestUpdate('scale-questions')\n }\n\n @state() private _answers: ScaleAnswer[] = createDefaultScaleAnswers()\n @state() private _scaleQuestions: string[] = []\n @state() private _rowTitle = ''\n @state() private _title = ''\n @state() private _analysis = ''\n @state() private _showRichText = false\n @state() private _richText = ''\n\n @property({ type: String, attribute: 'model-value' }) 'model-value' = ''\n @property({ type: Boolean, attribute: 'use-model' }) 'use-model' = false\n\n private readonly TITLE_MAX = 200\n\n willUpdate(changed: Map<string, unknown>) {\n const shouldSyncProps = changed.has('title')\n || changed.has('answer-list')\n || changed.has('rich-text-content')\n || changed.has('scale-question-list')\n || changed.has('scale-questions')\n\n if ((changed.has('is-edit') && this['is-edit']) || (!this['is-edit'] && shouldSyncProps)) {\n this._syncProps()\n }\n\n if (changed.has('model-value') && this['use-model']) {\n this._title = this['model-value']\n }\n }\n\n private _syncProps() {\n this._title = this.title || ''\n this._analysis = this.analysis || ''\n this._rowTitle = this._scaleQuestions.join('\\n')\n this._richText = this['rich-text-content'] || ''\n this._showRichText = !!this['rich-text-content']\n }\n\n private _emit(name: string, detail?: unknown) {\n emitSubjectEvent(this, name, detail)\n }\n\n private _onTitleInput(e: Event) {\n const el = e.target as HTMLTextAreaElement\n if (el.value.length > this.TITLE_MAX) {\n el.value = el.value.slice(0, this.TITLE_MAX)\n }\n this._title = el.value\n if (this['use-model']) {\n emitSubjectModelValue(this, this._title)\n }\n }\n\n private _resolvedQuestions(): string[] {\n const rowTitle = this['is-edit'] ? this._rowTitle : this._scaleQuestions.join('\\n')\n return splitScaleQuestionLines(rowTitle)\n }\n\n private _resolvedAnswers(): ScaleAnswer[] {\n const answers = this['is-edit'] ? this._answers : this['answer-list']\n return Array.isArray(answers) ? answers.map(normalizeScaleAnswer) : []\n }\n\n private _createAnswerCountError(row: Record<string, unknown>) {\n return new SubjectError('量表题选项数量必须在 3-5 个之间!', 'ANSWER_COUNT_INVALID', 'answers', row)\n }\n\n async toJSON(): Promise<any> {\n return new Promise((resolve, reject) => {\n const row = {\n customId: this['custom-id'] || undefined,\n answerType: SubjectType.SCALE,\n orderIndex: this['order-index'],\n }\n\n const title = trimText(this['is-edit'] ? this._title : this.title || '')\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n const richText = this['is-edit'] ? this._richText : this['rich-text-content'] || ''\n const showRichText = this['show-rich-text'] && (this['is-edit'] ? this._showRichText : !!this['rich-text-content'])\n\n if (!title) {\n reject(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n return\n }\n\n if (answers.length < 3 || answers.length > 5) {\n reject(this._createAnswerCountError(row))\n return\n }\n\n for (let i = 0; i < answers.length; i++) {\n if (!answers[i].title) {\n reject(new SubjectError(`选项${String.fromCharCode(65 + i)}未填写。`, 'ANSWER_EMPTY', 'answers', row))\n return\n }\n }\n\n if (questions.length === 0) {\n reject(new SubjectError('行标题不能为空!', 'EMPTY_ROW_TITLE', 'rowTitle', row))\n return\n }\n\n const result: any = {\n answerType: SubjectType.SCALE,\n examTypeEnum: SubjectType.SCALE,\n title,\n answers: answers.map(serializeScaleAnswer),\n scaleQuestionList: questions,\n analysis: trimText(this['is-edit'] ? this._analysis : this.analysis || ''),\n examRichTextContent: showRichText ? richText : '',\n isSetCorrectAnswer: false,\n }\n\n if (this['custom-id']) {\n result.customId = this['custom-id']\n }\n if (this['exam-answer-relation-type']) {\n result.examAnswerRelationType = this['exam-answer-relation-type']\n }\n\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 showSubjectToast(err.message)\n }\n }\n\n validate(): SubjectError[] {\n const errors: SubjectError[] = []\n const row = {\n customId: this['custom-id'] || undefined,\n answerType: SubjectType.SCALE,\n orderIndex: this['order-index'],\n }\n\n const title = trimText(this['is-edit'] ? this._title : this.title || '')\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n\n if (!title) {\n errors.push(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n }\n\n if (answers.length < 3 || answers.length > 5) {\n errors.push(this._createAnswerCountError(row))\n return errors\n }\n\n answers.forEach((answer: ScaleAnswer, index: number) => {\n if (!answer.title) {\n errors.push(new SubjectError(`选项${String.fromCharCode(65 + index)}未填写`, 'ANSWER_EMPTY', 'answers', row))\n }\n })\n\n if (questions.length === 0) {\n errors.push(new SubjectError('行标题不能为空!', 'EMPTY_ROW_TITLE', 'rowTitle', row))\n }\n\n return errors\n }\n\n private _renderPreview() {\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n const colWidth = Math.floor(100 / ((answers.length || 1) + 1))\n const previewTitle = buildSubjectPreviewTitle(this['subject-prefix'], this['order-index'], this.title)\n\n return html`\n <div class=\"preview\">\n <div class=\"preview-header\">\n <div class=\"preview-title-row\">\n <span class=\"title\">${previewTitle}</span>\n <span class=\"preview-type\">量表题</span>\n </div>\n ${this['show-rich-text'] && this['rich-text-content'] ? html`<div class=\"rich-text\" .innerHTML=${this['rich-text-content']}></div>` : ''}\n </div>\n <div class=\"scale-table-wrap\">\n <table class=\"scale-table\">\n <thead>\n <tr>\n <th style=\"width:${colWidth}%\">问题</th>\n ${answers.map(answer => html`<th style=\"width:${colWidth}%\">${answer.title}</th>`)}\n </tr>\n </thead>\n <tbody>\n ${questions.map(question => html`\n <tr>\n <td>${question}</td>\n ${answers.map(() => html`<td><input type=\"radio\" disabled /></td>`)}\n </tr>\n `)}\n </tbody>\n </table>\n </div>\n </div>\n `\n }\n\n private _renderEdit() {\n return html`\n <div class=\"edit-form\">\n <div class=\"edit-row\">\n <div class=\"label\"><span>题目:</span></div>\n <div class=\"row-body\">\n <div class=\"el-input\">\n <textarea\n rows=\"2\"\n .value=${this._title}\n maxlength=${this.TITLE_MAX}\n @input=${(e: Event) => this._onTitleInput(e)}\n placeholder=\"【量表题】请输入问题\"\n ></textarea>\n <span class=\"char-counter\">${this._title.length}/${this.TITLE_MAX}</span>\n </div>\n </div>\n </div>\n\n <slot name=\"business-tag\"></slot>\n\n <div class=\"edit-row\">\n <div class=\"label\"><span>量表内容:</span></div>\n <div class=\"row-body\">\n <div class=\"edit-grid\">\n <div class=\"edit-column\">\n <div class=\"edit-column-title\">行标题</div>\n <div class=\"el-input\">\n <textarea\n class=\"row-title-textarea\"\n .value=${this._rowTitle}\n @input=${(e: Event) => { this._rowTitle = (e.target as HTMLTextAreaElement).value }}\n @keydown=${(e: KeyboardEvent) => { e.stopPropagation() }}\n placeholder=\"请输入行标题\"\n ></textarea>\n </div>\n <div class=\"edit-note\">一行一个标题,预览时会自动整理空白行。</div>\n </div>\n <div class=\"edit-column\">\n <div class=\"edit-column-title\">评分选项</div>\n ${this._answers.map((answer, index) => html`\n <div class=\"answer-item\">\n <span class=\"label\">${String.fromCharCode(65 + index)}.</span>\n <div class=\"input\">\n <input\n type=\"text\"\n .value=${answer.title}\n maxlength=\"10\"\n @input=${(e: Event) => {\n const value = (e.target as HTMLInputElement).value\n this._answers = this._answers.map((item, currentIndex) =>\n currentIndex === index ? { ...item, title: value } : item,\n )\n }}\n placeholder=\"选项${index + 1}\"\n />\n </div>\n <span\n class=\"icon\"\n @click=${() => {\n if (this._answers.length < 5) {\n this._answers = [...this._answers, createEmptyScaleAnswer()]\n }\n }}\n >${iconPlus}</span>\n <span\n class=\"icon ${this._answers.length < 3 ? 'disabled' : ''}\"\n @click=${() => {\n if (this._answers.length > 3) {\n this._answers = this._answers.filter((_, currentIndex) => currentIndex !== index)\n }\n }}\n >${iconRemove}</span>\n </div>\n `)}\n <div class=\"edit-note\">量表题需保持 3-5 个选项,保存时会校验。</div>\n </div>\n </div>\n </div>\n </div>\n\n ${this['show-rich-text'] && this._showRichText\n ? html`\n <div class=\"edit-row\">\n <div class=\"label\"><span>副文本:</span></div>\n <div class=\"row-body\">\n <slot name=\"sub-text\">\n <qxs-blocksuite-editor\n .content=${this._richText}\n .toolbar=${SUB_TEXT_EDITOR_TOOLBAR}\n .upload-image=${this['upload-image']}\n ?is-edit=${true}\n @input=${(e: CustomEvent) => { this._richText = (e.target as any).getContent() }}\n ></qxs-blocksuite-editor>\n </slot>\n ${!this['show-action']\n ? html`\n <div class=\"flex-justify-end\" style=\"margin-top:8px\">\n <span\n class=\"el-link danger\"\n @click=${() => {\n this._showRichText = false\n this._richText = ''\n }}\n >删除富文本</span>\n </div>\n `\n : ''}\n </div>\n </div>\n `\n : ''}\n\n ${this['show-analysis']\n ? html`\n <div class=\"edit-row\">\n <div class=\"label\"><span>解析:</span></div>\n <div class=\"row-body\">\n <div class=\"el-input\">\n <textarea\n rows=\"2\"\n .value=${this._analysis}\n @input=${(e: Event) => { this._analysis = (e.target as HTMLTextAreaElement).value }}\n placeholder=\"请输入题目解析\"\n ></textarea>\n </div>\n </div>\n </div>\n `\n : ''}\n </div>\n `\n }\n\n private _renderSorting() {\n const title = trimText(this['is-edit'] ? this._title : this.title || '') || '未命名题目'\n const orderText = buildSubjectSortingTitle(this['subject-prefix'], this['order-index'], title)\n return renderSortingCard(orderText, SubjectTypeLabel[SubjectType.SCALE] || SubjectType.SCALE)\n }\n\n render() {\n if (this.sorting) {\n return this._renderSorting()\n }\n\n const content = this['is-edit']\n ? html`<div slot=\"edit\">${this._renderEdit()}</div>`\n : html`<div slot=\"preview\">${this._renderPreview()}</div>`\n\n return html`\n <qxs-subject-layout .show-edit=${this['is-edit']}>\n ${content}\n ${this['show-action']\n ? html`\n <qxs-subject-action\n .is-edit=${this['is-edit']}\n .is-set=${this['is-set']}\n .show-add=${this['show-add']}\n .show-rich-text=${this['show-rich-text'] && this._showRichText}\n .hide-add-rich-text=${!this['show-rich-text'] || this['hide-add-rich-text']}\n .show-delete-action=${this['show-delete-action']}\n .show-save-action=${this['show-save-action']}\n .show-other-option=${false}\n exam-answer-relation-type=${this['exam-answer-relation-type']}\n @delete=${() => this._emit('delete')}\n @save=${this._save}\n @edit=${() => this._emit('edit')}\n @add=${(e: CustomEvent) => this._emit('add', e.detail)}\n @on-show-rich-text=${() => {\n this._showRichText = !this._showRichText\n if (!this._showRichText) {\n this._richText = ''\n }\n }}\n ></qxs-subject-action>\n `\n : ''}\n <slot name=\"action\"></slot>\n </qxs-subject-layout>\n `\n }\n}\n\nexport function register() {}\n"],"names":["createEmptyScaleAnswer","title","createDefaultScaleAnswers","Array","from","length","normalizeScaleAnswer","answer","next","trimText","answerId","examAnswerId","isCorrect","serializeScaleAnswer","index","orderIndex","iconPlus","html","iconRemove","QxsScale","LitElement","constructor","super","arguments","this","sorting","analysis","async","Promise","resolve","reject","reader","FileReader","onload","e","target","result","onerror","readAsDataURL","file","_answers","_scaleQuestions","_rowTitle","_title","_analysis","_showRichText","_richText","TITLE_MAX","value","answers","isArray","map","normalizeScaleAnswers","requestUpdate","item","String","trim","filter","Boolean","normalizeScaleQuestionList","willUpdate","changed","shouldSyncProps","has","_syncProps","join","_emit","name","detail","emitSubjectEvent","_onTitleInput","el","slice","emitSubjectModelValue","_resolvedQuestions","rowTitle","split","_resolvedAnswers","_createAnswerCountError","row","SubjectError","toJSON","customId","answerType","SubjectType","SCALE","questions","richText","showRichText","i","fromCharCode","examTypeEnum","scaleQuestionList","examRichTextContent","isSetCorrectAnswer","examAnswerRelationType","_save","stopImmediatePropagation","data","err","showSubjectToast","message","validate","errors","push","forEach","_renderPreview","colWidth","Math","floor","previewTitle","buildSubjectPreviewTitle","question","_renderEdit","stopPropagation","currentIndex","_","SUB_TEXT_EDITOR_TOOLBAR","getContent","_renderSorting","orderText","buildSubjectSortingTitle","renderSortingCard","SubjectTypeLabel","render","content","styles","sortingCardStyles","subjectHostStyles","subjectControlResetStyles","subjectPreviewBaseStyles","subjectFormBaseStyles","subjectTextareaStyles","css","__decorateClass","property","type","Number","attribute","prototype","reflect","Object","state","safeCustomElement"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared-styles.cjs","sources":["../../../../packages/components-wc/src/subject/shared-styles.ts"],"sourcesContent":["import { css } from 'lit'\n\nexport const subjectControlResetStyles = css`\n *, ::before, ::after { box-sizing: border-box; }\n input[type=\"radio\"], input[type=\"checkbox\"] { margin: 0; }\n`\n\nexport const subjectHostStyles = css`\n :host {\n display: block;\n font-family: inherit;\n font-size: 12px;\n color: #5a5a5a;\n }\n`\n\nexport const subjectPreviewBaseStyles = css`\n .preview { padding: 10px 0 4px; }\n .preview-header { display: flex; flex-direction: column; gap: 12px; }\n .preview-title-row { display: flex; flex-wrap: wrap; align-items: baseline; gap: 10px; }\n .preview .title { font-size: 16px; line-height: 1.75; font-weight: 600; color: #303133; }\n .preview-type { font-size: 12px; line-height: 1.4; font-weight: 600; color: #8b95a7; letter-spacing: 0.02em; }\n .preview .rich-text { font-size: 14px; line-height: 1.8; color: #4b5563; }\n .preview .rich-text p { margin: 0; }\n .preview .rich-text p + p { margin-top: 0.75em; }\n .preview .rich-text img { max-width: 100%; }\n .preview .rich-text img[data-align=\"left\"] { display: block !important; margin: 0 auto 0 0 !important; }\n .preview .rich-text img[data-align=\"center\"] { display: block !important; margin: 0 auto !important; }\n .preview .rich-text img[data-align=\"right\"] { display: block !important; margin: 0 0 0 auto !important; }\n .preview-section { margin-top: 18px; }\n .preview-section-label { font-size: 12px; line-height: 1.4; font-weight: 600; color: #8b95a7; }\n .preview-section-body { margin-top: 8px; }\n`\n\nexport const subjectFormBaseStyles = css`\n .label { min-width: 72px; font-size: 12px; line-height: 1.4; font-weight: 600; color: #8b95a7; letter-spacing: 0.02em; }\n\n .edit-form { display: flex; flex-direction: column; gap: 16px; }\n .edit-row,\n .section-row {\n display: flex;\n align-items: flex-start;\n gap: 16px;\n margin-top: 0;\n }\n .edit-row
|
|
1
|
+
{"version":3,"file":"shared-styles.cjs","sources":["../../../../packages/components-wc/src/subject/shared-styles.ts"],"sourcesContent":["import { css } from 'lit'\n\nexport const subjectControlResetStyles = css`\n *, ::before, ::after { box-sizing: border-box; }\n input[type=\"radio\"], input[type=\"checkbox\"] { margin: 0; }\n`\n\nexport const subjectHostStyles = css`\n :host {\n display: block;\n font-family: inherit;\n font-size: 12px;\n color: #5a5a5a;\n }\n`\n\nexport const subjectPreviewBaseStyles = css`\n .preview { padding: 10px 0 4px; }\n .preview-header { display: flex; flex-direction: column; gap: 12px; }\n .preview-title-row { display: flex; flex-wrap: wrap; align-items: baseline; gap: 10px; }\n .preview .title { font-size: 16px; line-height: 1.75; font-weight: 600; color: #303133; }\n .preview-type { font-size: 12px; line-height: 1.4; font-weight: 600; color: #8b95a7; letter-spacing: 0.02em; }\n .preview .rich-text { font-size: 14px; line-height: 1.8; color: #4b5563; }\n .preview .rich-text p { margin: 0; }\n .preview .rich-text p + p { margin-top: 0.75em; }\n .preview .rich-text img { max-width: 100%; }\n .preview .rich-text img[data-align=\"left\"] { display: block !important; margin: 0 auto 0 0 !important; }\n .preview .rich-text img[data-align=\"center\"] { display: block !important; margin: 0 auto !important; }\n .preview .rich-text img[data-align=\"right\"] { display: block !important; margin: 0 0 0 auto !important; }\n .preview-section { margin-top: 18px; }\n .preview-section-label { font-size: 12px; line-height: 1.4; font-weight: 600; color: #8b95a7; }\n .preview-section-body { margin-top: 8px; }\n`\n\nexport const subjectFormBaseStyles = css`\n .label { min-width: 72px; font-size: 12px; line-height: 1.4; font-weight: 600; color: #8b95a7; letter-spacing: 0.02em; }\n\n .edit-form { display: flex; flex-direction: column; gap: 16px; }\n .edit-row,\n .section-row {\n display: flex;\n align-items: flex-start;\n gap: 16px;\n margin-top: 0;\n }\n .edit-row .label,\n .section-row .label {\n padding-top: 8px;\n }\n .row-body {\n flex: 1;\n min-width: 0;\n }\n`\n\nexport const subjectTextareaStyles = css`\n textarea {\n border: 1px solid #dcdfe6;\n border-radius: 6px;\n padding: 7px 11px;\n font-size: 13px;\n font-family: inherit;\n width: 100%;\n resize: none;\n transition: border-color .2s;\n line-height: 1.5;\n display: block;\n box-sizing: border-box;\n }\n textarea:focus { border-color: #3D61E3; outline: none; }\n textarea:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n\n .el-input { position: relative; display: block; }\n .el-input textarea { padding-bottom: 24px; }\n .el-input .char-counter {\n position: absolute;\n right: 12px;\n bottom: 8px;\n font-size: 12px;\n color: #909399;\n line-height: 1;\n pointer-events: none;\n }\n`\n"],"names":["subjectControlResetStyles","css","subjectHostStyles","subjectPreviewBaseStyles","subjectFormBaseStyles","subjectTextareaStyles"],"mappings":"kCAEO,MAAMA,EAA4BC,EAAAA,GAAA;;;EAK5BC,EAAoBD,EAAAA,GAAA;;;;;;;EASpBE,EAA2BF,EAAAA,GAAA;;;;;;;;;;;;;;;;EAkB3BG,EAAwBH,EAAAA,GAAA;;;;;;;;;;;;;;;;;;;EAqBxBI,EAAwBJ,EAAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@qxs-bns/components-wc",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "0.0.
|
|
4
|
+
"version": "0.0.33",
|
|
5
5
|
"description": "QXS Business Components - Web Components (framework agnostic)",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"homepage": "https://qxs-bns.pages.dev/guide/components-wc/",
|