From 02104d85e7e2f6e495274591892d6028169d2323 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Fri, 01 Aug 2025 18:18:26 +0800
Subject: [PATCH] feat(ai): 新增产品题目功能
---
src/main/resources/templates/febs/views/modules/ai/productQuestion/info.html | 282 +++++++++++++++++++++++++++++++++++++++----------------
1 files changed, 199 insertions(+), 83 deletions(-)
diff --git a/src/main/resources/templates/febs/views/modules/ai/productQuestion/info.html b/src/main/resources/templates/febs/views/modules/ai/productQuestion/info.html
index 0d86d8b..d82441f 100644
--- a/src/main/resources/templates/febs/views/modules/ai/productQuestion/info.html
+++ b/src/main/resources/templates/febs/views/modules/ai/productQuestion/info.html
@@ -1,8 +1,8 @@
-<div class="layui-fluid layui-anim febs-anim" id="febs-productPoint-Info" lay-title="编辑">
+<div class="layui-fluid layui-anim febs-anim" id="febs-productQuestion-Info" lay-title="编辑">
<div class="layui-row febs-container">
<div class="layui-col-md12">
- <div class="layui-fluid" id="productPoint-info">
- <form class="layui-form" action="" lay-filter="productPoint-info-form">
+ <div class="layui-fluid" id="productQuestion-info">
+ <form class="layui-form" action="" lay-filter="productQuestion-info-form">
<div class="layui-tab layui-tab-brief" lay-filter="docDemoTabBrief">
<ul class="layui-tab-title">
<li class="layui-this">基础信息</li>
@@ -14,35 +14,15 @@
<div class="layui-row layui-col-space10 layui-form-item">
<div class="layui-col-lg6">
- <label class="layui-form-label febs-form-item-require">类型:</label>
+ <label class="layui-form-label febs-form-item-require">分类:</label>
<div class="layui-input-block">
- <select name="isNormal" class="point-type" lay-filter="point-type-select">
- <option value="1">普通内容</option>
- <option value="2">视频号内容</option>
- </select>
- </div>
- </div>
- </div>
-
- <blockquote class="layui-elem-quote blue-border febs-hide tc-set">视频号信息</blockquote>
- <div class="layui-form-item febs-hide tc-set">
- <div class="layui-col-lg6">
- <label class="layui-form-label">视频号 id:</label>
- <div class="layui-input-block">
- <input type="text" name="finderUserName" placeholder="请输入" autocomplete="off" class="layui-input">
- <div class="layui-form-mid layui-word-aux">视频号 id,以“sph”开头的id,可在视频号助手获取。</div>
- </div>
- </div>
- <div class="layui-col-lg6">
- <label class="layui-form-label">视频 feedId:</label>
- <div class="layui-input-block">
- <input type="text" name="feedId" placeholder="请输入" autocomplete="off" class="layui-input">
+ <div id="product-category"></div>
</div>
</div>
</div>
<div class="layui-row layui-col-space10 layui-form-item">
<div class="layui-col-lg6">
- <label class="layui-form-label febs-form-item-require">标题:</label>
+ <label class="layui-form-label febs-form-item-require">题目:</label>
<div class="layui-input-block">
<input type="text" name="title" lay-verify="required"
placeholder="" autocomplete="off" class="layui-input">
@@ -50,12 +30,33 @@
</div>
</div>
- <div class="layui-form-item">
- <label class="layui-form-label febs-form-item-require">详情:</label>
- <div class="layui-input-block">
- <div style="border: 1px solid #ccc;">
- <div id="product-point-toolbar-container" class="toolbar"></div>
- <div id="product-point-text-container" class="text" style="height: 450px;"></div>
+ <div class="layui-row layui-col-space10 layui-form-item">
+ <div class="layui-col-lg6">
+ <label class="layui-form-label febs-form-item-require">难度:</label>
+ <div class="layui-input-block">
+ <input type="radio" name="difficulty" value="1" title="简单" checked="">
+ <input type="radio" name="difficulty" value="2" title="中等" >
+ <input type="radio" name="difficulty" value="3" title="困难" >
+ </div>
+ </div>
+ </div>
+
+ <div class="layui-form-item multi-sku-table">
+ <div class="layui-row layui-col-space10 layui-form-item">
+ <div class="layui-col-lg6">
+ <label class="layui-form-label febs-form-item-require">答案:</label>
+ </div>
+ <div class="layui-col-lg1">
+ <button type="button"
+ class="layui-btn layui-btn-normal layui-btn" id="test3">
+ 添加
+ </button>
+ </div>
+ </div>
+
+ <div class="layui-form-item">
+ <div class="layui-input-block">
+ <table id="multiSku" lay-filter="multiSku"></table>
</div>
</div>
</div>
@@ -64,7 +65,7 @@
</div>
</div>
<div class="layui-form-item febs-hide">
- <button class="layui-btn" lay-submit="" lay-filter="productPoint-info-form-submit" id="submit">保存</button>
+ <button class="layui-btn" lay-submit="" lay-filter="productQuestion-info-form-submit" id="submit">保存</button>
</div>
</form>
</div>
@@ -86,6 +87,12 @@
margin: 0 5px !important;
}
</style>
+
+<script type="text/html" id="toolbar">
+ <div class="layui-btn-container">
+ <button class="layui-btn layui-btn-danger layui-btn-sm" type="button" lay-event="delSku">删除</button>
+ </div>
+</script>
<!-- 表格操作栏 end -->
<script data-th-inline="javascript">
layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree','dropdown', 'laydate', 'layedit', 'upload', 'element', 'table', 'xmSelect','jquery'], function () {
@@ -94,73 +101,182 @@
layer = layui.layer,
table = layui.table,
form = layui.form,
- $view = $('#productPoint-info'),
- aiProductPoint = [[${aiProductPoint}]],
+ $view = $('#productQuestion-info'),
+ aiProductQuestion = [[${aiProductQuestion}]],
upload = layui.upload,
validate = layui.validate;
form.render();
- const E = window.wangEditor;
- const editor = new E('#product-point-toolbar-container', '#product-point-text-container'); // 传入两个元素
- editor.config.showLinkImg = false;
- editor.config.uploadFileName = 'file';
- editor.config.customUploadImg = function (files, insertImgFn) {
- // files 是 input 中选中的文件列表
- // insertImgFn 是获取图片 url 后,插入到编辑器的方法
- // 上传图片,返回结果,将图片插入到编辑器中
- for (let i = 0; i < files.length; i++){
- var form = new FormData();
- form.append("file", files[0]);
- $.ajax({
- url:'/admin/goods/uploadFileBase64',
- type: "post",
- processData: false,
- contentType: false,
- data: form,
- dataType: 'json',
- success(res) {
- // 上传代码返回结果之后,将图片插入到编辑器中
- insertImgFn(res.data.src, res.data.title, '')
- }
- })
- }
- };
- editor.create();
+ var category = xmSelect.render({
+ el: '#product-category',
+ language: 'zn',
+ prop : {
+ value : 'id',
+ children : 'child'
+ },
+ iconfont: {
+ parent: 'hidden',
+ },
+ tips: '请选择',
+ filterable: true,
+ radio: true,
+ clickClose: true,
+ tree: {
+ show: true,
+ //非严格模式
+ strict: false,
+ },
+ data: []
+ })
- form.on('select(point-type-select)', function(data){
- $('.tc-set').each(function() {
- if (data.value == 2) {
- $(this).show();
- } else {
- $(this).hide();
+ febs.get(ctx + 'admin/productCategory/categoryTree', null, function(res) {
+ category.update({
+ data : res.data,
+ autoRow: true,
+ });
+ })
+
+ var tableSkuData=[];
+ var tableIns = table.render({
+ elem: '#multiSku'
+ ,limit:999
+ ,toolbar:"#toolbar"
+ ,defaultToolbar:[]
+ ,cols: [[ //表头
+ {type: 'checkbox'}
+ ,{field: 'index', title: '序号', width:70}
+ ,{field: 'answer', title: '答案', edit:'text', width:500}
+ ,{field: 'correctAnswer', title: '正确答案', templet: function(d){
+ var options = '';
+ if(d.correctAnswer == 1) {
+ options = '<option value="0">否</option><option value="1" selected>是</option>';
+ } else {
+ options = '<option value="0" selected>否</option><option value="1">是</option>';
+ }
+ return '<select lay-ignore name="correctAnswer" lay-filter="correctAnswerSelect">' + options + '</select>';
+ }, width:200}
+ ,{field: 'answerAnalysis', title: '答案解析', edit:'text', width:500}
+ ]]
+ ,data: []
+ });
+
+ // 监听下拉框变化
+ $(document).on('change', 'select[name="correctAnswer"]', function() {
+ var selectIndex = $(this).closest('tr').index(); // 获取行索引
+ var newValue = $(this).val(); // 获取新值
+
+ // 更新表格数据
+ var hasData = table.cache['multiSku'];
+ if (hasData && hasData[selectIndex]) {
+ hasData[selectIndex].correctAnswer = parseInt(newValue);
+
+ // 更新全局数据
+ for (let i = 0; i < tableSkuData.length; i++) {
+ if (tableSkuData[i].index == hasData[selectIndex].index) {
+ tableSkuData[i].correctAnswer = parseInt(newValue);
+ break;
+ }
}
- })
+ }
+ });
+
+
+ table.on('toolbar(multiSku)', function(obj){
+ var data = obj.data;
+
+ var hasData = table.cache['multiSku'];
+ var checkData = table.checkStatus('multiSku').data;
+
+ if (checkData.length <= 0) {
+ febs.alert.warn('请选择删除数据');
+ return;
+ }
+ if(obj.event === 'delSku'){
+ for (let i = 0; i < checkData.length; i++) {
+ var delData = checkData[i];
+ for (let j = 0; j < hasData.length; j++) {
+ if (hasData[j].index == delData.index) {
+ hasData.splice(j, 1);
+ break;
+ }
+ }
+ }
+
+ for (let i = 0; i < hasData.length; i++) {
+ hasData[i].index = i + 1;
+ }
+
+ tableSkuData=hasData;
+ reloadTable(hasData);
+ }
+ });
+
+ function addTableDate(data) {
+ var hasData = table.cache['multiSku'];
+
+ data.index = hasData.length + 1;
+ tableSkuData.push(data);
+
+ reloadTable(tableSkuData);
+ return data.index;
+ }
+
+ function reloadTable(data) {
+ table.reload('multiSku', {
+ data : data
+ });
+ }
+
+ table.on('edit(multiSku)', function(obj){
+ var value = obj.value //得到修改后的值
+ ,data = obj.data //得到所在行所有键值
+ ,field = obj.field; //得到字段
+
+ for (let i = 0; i < tableSkuData.length; i++) {
+ if (tableSkuData[i].index == data.index) {
+ tableSkuData[i] = data;
+ }
+ }
+ });
+
+ $('#test3').on('click', function (){
+ var data = {};
+ addTableDate(data);
});
setTimeout(() => {
- initProductPointInfo();
+ initProductQuestionInfo();
}, 500);
- function initProductPointInfo() {
- form.val("productPoint-info-form", {
- "id": aiProductPoint.id,
- "title": aiProductPoint.title,
- "isNormal": aiProductPoint.isNormal,
- "finderUserName": aiProductPoint.finderUserName,
- "feedId": aiProductPoint.feedId,
+ function initProductQuestionInfo() {
+ form.val("productQuestion-info-form", {
+ "id": aiProductQuestion.id,
+ "title": aiProductQuestion.title,
+ "difficulty": aiProductQuestion.difficulty,
});
- editor.txt.html(aiProductPoint.description);
- if (aiProductPoint.isNormal == 2) {
- $(".tc-set").show();
+ var categoryList = [];
+ categoryList.push(aiProductQuestion.productCategoryId)
+ category.setValue(categoryList);
+
+ let aiProductQuestionItems = aiProductQuestion.aiProductQuestionItems;
+ if(Array.isArray(aiProductQuestionItems) && aiProductQuestionItems.length){
+ for (let i = 0; i < aiProductQuestionItems.length; i++) {
+ aiProductQuestionItems[i].index = i+1;
+ }
+ }
+ if (aiProductQuestionItems) {
+ tableSkuData = aiProductQuestionItems;
+ reloadTable(aiProductQuestionItems);
}
}
- form.on('submit(productPoint-info-form-submit)', function (data) {
- data.field.description = editor.txt.html();
+ form.on('submit(productQuestion-info-form-submit)', function (data) {
+ data.field.productCategoryId = category.getValue('valueStr');
+ data.field.aiProductQuestionItems = tableSkuData;
$.ajax({
- 'url':ctx + 'admin/productPoint/update',
+ 'url':ctx + 'admin/productQuestion/update',
'type':'post',
'dataType':'json',
'headers' : {'Content-Type' : 'application/json;charset=utf-8'}, //接口json格式
@@ -170,7 +286,7 @@
if(data.code==200){
layer.closeAll();
febs.alert.success(data.message);
- $('#febs-productPoint').find('#query').click();
+ $('#febs-productQuestion').find('#query').click();
}else{
febs.alert.warn(data.message);
}
--
Gitblit v1.9.1