You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
NewEduCoderBuild/224.async.js

1775 lines
100 KiB

"use strict";
(self["webpackChunk"] = self["webpackChunk"] || []).push([[224],{
/***/ 5547:
/*!**********************************************************!*\
!*** ./src/components/QuestionEditor/index.less?modules ***!
\**********************************************************/
/***/ (function(__unused_webpack_module, __webpack_exports__) {
// extracted by mini-css-extract-plugin
/* harmony default export */ __webpack_exports__.Z = ({"wrap":"wrap___ilWvf","deleteIcon":"deleteIcon___JBDG8","keywordTag":"keywordTag___iieCb","questionTitleEditorWrap":"questionTitleEditorWrap___MHB5s","choiceListWrap":"choiceListWrap___jB8b1","choiceWrap":"choiceWrap___QFkTc","choiceIndex":"choiceIndex___Mr2YO","judgementIndex":"judgementIndex___fUVWK","setAnswerBtn":"setAnswerBtn___Whox5","activeAnswer":"activeAnswer___fGU6Y","activeJudgementAnswer":"activeJudgementAnswer___wJv8P","actionWrapper":"actionWrapper___ERQ7k","addIcon":"addIcon___L9TE0","inputBorder":"inputBorder___Q5tRE","placeholder":"placeholder___p9sFY","blankInputNumberWrapper":"blankInputNumberWrapper___uEHb0","addBtn":"addBtn___WR5ZI","blankIndex":"blankIndex___x9Pny","baseInputWrapper":"baseInputWrapper___eVsG7","collapseWrapper":"collapseWrapper___ZTysU","panelHeader":"panelHeader___QSN9g","open":"open___B6FU9","close":"close___QX19r","hide":"hide___mn25n"});
/***/ }),
/***/ 14233:
/*!*****************************************************!*\
!*** ./src/components/MathsLatexKeybords/index.tsx ***!
\*****************************************************/
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ 59301);
/* harmony import */ var _index_less_modules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./index.less?modules */ 44499);
/* harmony import */ var mathlatex__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! mathlatex */ 48136);
/* harmony import */ var _keybords__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./keybords */ 68585);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! antd */ 43418);
/* provided dependency */ var React = __webpack_require__(/*! react */ 59301);
const MathsLatex = (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(({ callback, width, onChange, disabled, readOnly, type = "", value = "", style = {} }, ref) => {
const GraphicsRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)();
const KeybordsRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)();
const [styleLeft, setStyleLeft] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(0);
const [styleTop, setStyleTop] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(0);
const [showLatex, setShowLatex] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(false);
const getData = () => {
var dom = document.createElement("div");
dom.innerHTML = GraphicsRef.current.getValue();
var str = dom.innerText;
callback && callback(str);
return str;
};
(0,react__WEBPACK_IMPORTED_MODULE_0__.useImperativeHandle)(ref, () => ({
getData
}));
const onTitleMouseDown = (e) => {
e.preventDefault();
const startPosX = e.clientX - styleLeft;
const startPosY = e.clientY - styleTop;
document.body.onmousemove = (e2) => {
let left = e2.clientX - startPosX;
let top = e2.clientY - startPosY;
const modal = document.getElementsByClassName("ant-modal")[0];
const maxWidth = window.innerWidth - modal.offsetWidth;
const maxHeight = window.innerHeight - modal.offsetHeight;
left = Math.max(0, Math.min(left, maxWidth));
top = Math.max(0, Math.min(top, maxHeight));
if (inWindow(e2.clientX, e2.clientY, startPosX, startPosY)) {
setStyleLeft(left);
setStyleTop(top);
}
};
document.body.onmouseup = function() {
document.body.onmousemove = null;
};
};
const inWindow = (left, top, startPosX, startPosY) => {
const H = document.body.clientHeight;
const W = document.body.clientWidth;
if (left < 20 && startPosX > left || left > W - 20 && startPosX < left || top < 20 && startPosY > top || top > H - 20 && startPosY < top) {
document.body.onmousemove = null;
document.body.onmouseup = null;
return false;
}
return true;
};
(0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {
if (showLatex) {
setTimeout(() => {
const modal = document.getElementsByClassName("ant-modal")[0];
const centerX = window.innerWidth / 2 - modal.offsetWidth / 2;
const centerY = window.innerHeight / 2 - modal.offsetHeight / 2;
setStyleLeft(centerX);
setStyleTop(centerY);
}, 0);
}
}, [showLatex]);
const showInput = () => {
if (disabled || readOnly)
return;
setShowLatex(true);
};
return /* @__PURE__ */ React.createElement("div", { style }, /* @__PURE__ */ React.createElement("div", { style: { width: width || "100%", position: "relative" }, className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.mathFillWrap} ${disabled || readOnly ? "cursorDefault" : ""}`, onClick: () => showInput() }, /* @__PURE__ */ React.createElement("math-field", { disabled, locale: "zh_cn", class: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.mathField} ${type}`, readOnly, placeholder: "\u8BF7\u8F93\u5165\u516C\u5F0F", ref: GraphicsRef, style: { width: "100%", fontSize: value ? 18 : 14 }, value: value || "" })), /* @__PURE__ */ React.createElement(
antd__WEBPACK_IMPORTED_MODULE_4__["default"],
{
maskClosable: false,
centered: true,
width: 860,
style: { position: "absolute", left: styleLeft, top: styleTop },
title: /* @__PURE__ */ React.createElement("div", { style: { cursor: "move" }, onMouseDown: onTitleMouseDown }, "\u8F93\u5165\u516C\u5F0F"),
open: showLatex,
onOk: () => {
const val = KeybordsRef.current.getData();
GraphicsRef.current.setValue(val);
onChange(val);
setShowLatex(false);
},
onCancel: () => {
setShowLatex(false);
},
destroyOnClose: true,
className: "markdown-popup-form"
},
/* @__PURE__ */ React.createElement(_keybords__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z, { value, ref: KeybordsRef, onChange, showSaveButton: false })
));
});
/* harmony default export */ __webpack_exports__.Z = (MathsLatex);
/***/ }),
/***/ 49270:
/*!**********************************************************************!*\
!*** ./src/components/QuestionEditor/BProgramEditor.tsx + 2 modules ***!
\**********************************************************************/
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
t: function() { return /* binding */ BProgramEditor; }
});
// EXTERNAL MODULE: ./node_modules/_react@17.0.2@react/index.js
var _react_17_0_2_react = __webpack_require__(59301);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/input/index.js + 5 modules
var input = __webpack_require__(98135);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/form/index.js + 19 modules
var es_form = __webpack_require__(78241);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/modal/index.js + 16 modules
var modal = __webpack_require__(43418);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/row/index.js
var row = __webpack_require__(95237);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/col/index.js
var col = __webpack_require__(43604);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/input-number/index.js + 14 modules
var input_number = __webpack_require__(54449);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/select/index.js
var es_select = __webpack_require__(57809);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/radio/index.js + 5 modules
var es_radio = __webpack_require__(5112);
// EXTERNAL MODULE: ./src/components/QuestionEditor/MdEditorInForm.tsx
var MdEditorInForm = __webpack_require__(57782);
// EXTERNAL MODULE: ./src/.umi-production/exports.ts + 15 modules
var _umi_production_exports = __webpack_require__(67866);
// EXTERNAL MODULE: ./src/components/QuestionEditor/index.less?modules
var QuestionEditormodules = __webpack_require__(5547);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/message/index.js + 4 modules
var message = __webpack_require__(8591);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/button/index.js
var es_button = __webpack_require__(3113);
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/spin/index.js + 1 modules
var spin = __webpack_require__(71418);
// EXTERNAL MODULE: ./node_modules/_js-base64@2.6.4@js-base64/base64.js
var base64 = __webpack_require__(24334);
;// CONCATENATED MODULE: ./src/components/SelfTestRun/index.less?modules
// extracted by mini-css-extract-plugin
/* harmony default export */ var SelfTestRunmodules = ({"flex_box_center":"flex_box_center___kOQ8P","flex_space_between":"flex_space_between___fY6jt","flex_box_vertical_center":"flex_box_vertical_center___bDSSI","flex_box_center_end":"flex_box_center_end___mQ6mU","flex_box_column":"flex_box_column___F15G0","result":"result___UYRo8","left":"left___TRaH5","right":"right___twp9s","box":"box___vwndt","li":"li___hRe2d"});
// EXTERNAL MODULE: ./src/utils/fetch.ts
var fetch = __webpack_require__(51165);
// EXTERNAL MODULE: ./src/pages/MyProblem/service.ts
var service = __webpack_require__(39078);
// EXTERNAL MODULE: ./src/components/markdown-editor/index.tsx + 15 modules
var markdown_editor = __webpack_require__(96180);
// EXTERNAL MODULE: ./node_modules/_react-copy-to-clipboard@5.0.2@react-copy-to-clipboard/lib/index.js
var lib = __webpack_require__(56102);
// EXTERNAL MODULE: ./src/pages/MyProblem/interface.ts
var MyProblem_interface = __webpack_require__(48685);
;// CONCATENATED MODULE: ./src/components/SelfTestRun/index.tsx
/* provided dependency */ var React = __webpack_require__(/*! react */ 59301);
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
var __async = (__this, __arguments, generator) => {
return new Promise((resolve, reject) => {
var fulfilled = (value) => {
try {
step(generator.next(value));
} catch (e) {
reject(e);
}
};
var rejected = (value) => {
try {
step(generator.throw(value));
} catch (e) {
reject(e);
}
};
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
step((generator = generator.apply(__this, __arguments)).next());
});
};
const SelfTestRun = ({
buttonProps,
buttonText,
form,
hackIdentifier = "",
answerKey,
data
}) => {
const [loading, setLoading] = (0,_react_17_0_2_react.useState)(false);
const [btnLoading, setBtnLoading] = (0,_react_17_0_2_react.useState)(false);
const [visible, setVisible] = (0,_react_17_0_2_react.useState)(false);
const [resultData, setResultData] = (0,_react_17_0_2_react.useState)({});
const [testHackCode, setTestHackCode] = (0,_react_17_0_2_react.useState)("");
const [testInput, setTestInput] = (0,_react_17_0_2_react.useState)("");
const identifier = (0,_react_17_0_2_react.useRef)(hackIdentifier);
const startIdentifier = (0,_react_17_0_2_react.useRef)("");
const openModal = (0,_react_17_0_2_react.useRef)(false);
(0,_react_17_0_2_react.useEffect)(() => {
visible && handlePolling();
}, [visible]);
(0,_react_17_0_2_react.useEffect)(() => {
return () => {
sessionStorage.removeItem("projectFill");
};
}, []);
const getTimeStamp = () => {
return (/* @__PURE__ */ new Date()).getTime();
};
const isAppraise = data == null ? void 0 : data.code;
const initCode = () => {
var _a, _b;
let code = isAppraise ? data == null ? void 0 : data.code : (_a = form.getFieldValue("hack_codes")) == null ? void 0 : _a.code;
let stats = isAppraise ? data == null ? void 0 : data.answer_content : form.getFieldValue(answerKey);
let test_input = isAppraise ? data == null ? void 0 : data.input : (_b = form.getFieldValue("hack_sets")) == null ? void 0 : _b.input;
stats == null ? void 0 : stats.forEach((item) => {
const answer_text = item.value || item.answer_text || "";
code = code.replace(/(@▁@|@▁▁@)/, answer_text);
});
setTestInput(test_input);
setTestHackCode(code);
setResultData({});
setVisible(true);
};
const handlePolling = () => __async(void 0, null, function* () {
var _a, _b, _c, _d;
const startTime = getTimeStamp();
const timeLimit = isAppraise ? data == null ? void 0 : data.time_limit : (_a = form.getFieldsValue()) == null ? void 0 : _a.hack.time_limit;
const answersLength = isAppraise ? (_b = data == null ? void 0 : data.answer_content) == null ? void 0 : _b.length : (_d = (_c = form.getFieldsValue()) == null ? void 0 : _c.standard_answers) == null ? void 0 : _d.length;
setLoading(true);
yield (0,service/* sumbitCode */.bM)(startIdentifier.current, { test_hack_code: testHackCode, test_input: testInput });
function executeCode() {
return __async(this, null, function* () {
const { status, data: data2 } = yield (0,service/* getOperationResult */.rX)(startIdentifier.current, "submit");
const executeTime = getTimeStamp();
const isTimeOut = executeTime - startTime > (timeLimit + 3) * 1e3 * answersLength;
if (!openModal.current)
return;
if (isTimeOut) {
message/* default */.ZP.error("\u8C03\u8BD5\u4EE3\u7801\u8D85\u65F6");
setLoading(false);
return;
}
if (status === 0) {
setLoading(false);
setResultData(__spreadProps(__spreadValues({}, data2), { showText: true }));
return;
}
setTimeout(executeCode, 1e3);
});
}
executeCode();
});
const handleClick = () => __async(void 0, null, function* () {
var _a, _b, _c, _d, _e, _f, _g;
if (!data) {
try {
yield form.validateFields();
} catch (errInfo) {
if ((_c = (_b = (_a = errInfo == null ? void 0 : errInfo.errorFields) == null ? void 0 : _a[0]) == null ? void 0 : _b.name) == null ? void 0 : _c.includes("standard_answers")) {
message/* default */.ZP.error("\u586B\u7A7A\u9879\u7B54\u6848\u4E0D\u80FD\u4E3A\u7A7A");
} else {
message/* default */.ZP.error(errInfo.errorFields[0].errors[0]);
}
form.scrollToField(errInfo.errorFields[0].name, { behavior: "smooth", block: "center" });
return;
}
setBtnLoading(true);
let res = "";
const formValues = form.getFieldsValue();
if (!identifier.current) {
res = yield (0,fetch/* default */.ZP)(`/api/problems.json`, {
method: "post",
body: __spreadProps(__spreadValues({}, formValues), {
hack: __spreadProps(__spreadValues({}, formValues == null ? void 0 : formValues.hack), {
sub_discipline_id: (_e = (_d = formValues == null ? void 0 : formValues.hack) == null ? void 0 : _d.sub_discipline_id) == null ? void 0 : _e[1],
difficult: formValues.difficulty,
item_banks_group_id: formValues.item_banks_group_id
}),
hack_codes: __spreadProps(__spreadValues({}, formValues.hack_codes), {
code: base64.Base64.encode(formValues.hack_codes.code)
}),
hack_sets: [__spreadValues({}, formValues.hack_sets)],
is_blank: true
})
});
identifier.current = res == null ? void 0 : res.identifier;
sessionStorage.projectFill = res == null ? void 0 : res.identifier;
} else {
res = yield (0,fetch/* default */.ZP)(`/api/problems/${identifier.current}.json`, {
method: "put",
body: __spreadProps(__spreadValues({}, formValues), {
hack: __spreadProps(__spreadValues({}, formValues == null ? void 0 : formValues.hack), {
sub_discipline_id: (_g = (_f = formValues == null ? void 0 : formValues.hack) == null ? void 0 : _f.sub_discipline_id) == null ? void 0 : _g[1],
difficult: formValues.difficulty,
item_banks_group_id: formValues.item_banks_group_id
}),
hack_codes: __spreadProps(__spreadValues({}, formValues.hack_codes), {
code: base64.Base64.encode(formValues.hack_codes.code)
}),
update_hack_sets: [__spreadValues({}, formValues.hack_sets)],
is_blank: true
})
});
}
}
const result = yield (0,fetch/* default */.ZP)(`/api/problems/${identifier.current}/start.json`, {
method: "get"
});
if ((result == null ? void 0 : result.status) === 0) {
startIdentifier.current = result == null ? void 0 : result.identifier;
openModal.current = true;
setBtnLoading(false);
initCode();
return;
}
setBtnLoading(false);
});
const getCommitOut = (debugResult) => {
const { status, error_msg, execute_time, output, input, expected_output } = debugResult;
let rs = null;
switch (status) {
case MyProblem_interface/* ExecuteStatus */.h.OK:
rs = /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("p", null, "\u6267\u884C\u7528\u65F6\uFF1A", execute_time / 1e3, "\u79D2"), /* @__PURE__ */ React.createElement("p", null, "\u6267\u884C\u7ED3\u679C\uFF1A\u8C03\u8BD5\u901A\u8FC7"));
break;
case MyProblem_interface/* ExecuteStatus */.h.NOMATCH:
rs = /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("div", null, "\u8F93\u5165\uFF1A"), /* @__PURE__ */ React.createElement("pre", { style: { fontFamily: "initial" } }, input), /* @__PURE__ */ React.createElement("div", null, "\u8F93\u51FA\uFF1A"), /* @__PURE__ */ React.createElement("pre", { style: { fontFamily: "initial" } }, output && base64.Base64.decode(output)), /* @__PURE__ */ React.createElement("div", null, "\u9884\u671F\u8F93\u51FA\uFF1A"), /* @__PURE__ */ React.createElement("pre", { style: { fontFamily: "initial" } }, expected_output && base64.Base64.decode(expected_output)));
break;
case MyProblem_interface/* ExecuteStatus */.h.EXECUTEFAILURE:
rs = /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("p", null, "\u6700\u540E\u6267\u884C\u7684\u8F93\u5165\uFF1A", /* @__PURE__ */ React.createElement("pre", null, input)), /* @__PURE__ */ React.createElement("p", null, "\u6267\u884C\u51FA\u9519\u4FE1\u606F\uFF1A"), /* @__PURE__ */ React.createElement("pre", { className: "error" }, base64.Base64.decode(error_msg)));
break;
case MyProblem_interface/* ExecuteStatus */.h.COMPILEFAILURE:
rs = /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("p", null, "\u6700\u540E\u6267\u884C\u7684\u8F93\u5165\uFF1A", /* @__PURE__ */ React.createElement("pre", null, input)), /* @__PURE__ */ React.createElement("p", null, "\u6267\u884C\u51FA\u9519\u4FE1\u606F\uFF1A"), /* @__PURE__ */ React.createElement("pre", { className: "error" }, base64.Base64.decode(error_msg)));
break;
case MyProblem_interface/* ExecuteStatus */.h.PODFAILURE:
rs = /* @__PURE__ */ React.createElement("p", null, "\u521B\u5EFApod\u5931\u8D25\uFF0C\u8BF7\u7A0D\u540E\u91CD\u8BD5");
break;
case MyProblem_interface/* ExecuteStatus */.h.TIMEOUT:
rs = /* @__PURE__ */ React.createElement("p", null, "\u8BC4\u6D4B\u8D85\u65F6\uFF0C\u8BF7\u7A0D\u540E\u91CD\u8BD5");
break;
}
return /* @__PURE__ */ React.createElement(React.Fragment, null, " ", rs, " ");
};
return /* @__PURE__ */ React.createElement("div", null, /* @__PURE__ */ React.createElement(
es_button/* default */.ZP,
__spreadProps(__spreadValues({
loading: btnLoading
}, buttonProps), {
onClick: handleClick
}),
buttonText
), /* @__PURE__ */ React.createElement(
modal["default"],
{
open: visible,
title: "\u8C03\u8BD5\u4EE3\u7801",
destroyOnClose: true,
width: 1200,
okText: "\u8FD0\u884C\u6D4B\u8BD5",
confirmLoading: loading,
cancelButtonProps: {
style: { display: "none" }
},
onOk: () => handlePolling(),
onCancel: () => {
openModal.current = false;
setVisible(false);
}
},
/* @__PURE__ */ React.createElement("div", { className: SelfTestRunmodules.result }, /* @__PURE__ */ React.createElement("div", { className: SelfTestRunmodules.left }, /* @__PURE__ */ React.createElement("div", { className: "mb20" }, /* @__PURE__ */ React.createElement("span", { className: "c-black" }, "\u6267\u884C\u4EE3\u7801"), !data && /* @__PURE__ */ React.createElement(
lib.CopyToClipboard,
{
text: testHackCode,
onCopy: () => message/* default */.ZP.success("\u590D\u5236\u6210\u529F")
},
/* @__PURE__ */ React.createElement("span", { style: { float: "right" }, className: "current c-light-primary" }, /* @__PURE__ */ React.createElement("i", { className: "iconfont icon-fuzhi8 mr5" }), "\u590D\u5236")
)), /* @__PURE__ */ React.createElement(
markdown_editor/* default */.Z,
{
height: 510,
className: "mb0",
hidetoolBar: true,
defaultValue: testHackCode,
onChange: (v) => setTestHackCode(v)
}
)), /* @__PURE__ */ React.createElement("div", { className: SelfTestRunmodules.right }, /* @__PURE__ */ React.createElement("div", { className: "c-black mb20" }, "\u81EA\u5B9A\u4E49\u6D4B\u8BD5\u7528\u4F8B"), /* @__PURE__ */ React.createElement("div", { className: SelfTestRunmodules.box }, /* @__PURE__ */ React.createElement("div", { className: SelfTestRunmodules.li }, /* @__PURE__ */ React.createElement(
input["default"].TextArea,
{
placeholder: "\u8BF7\u8F93\u5165",
value: testInput,
onChange: (e) => setTestInput(e.target.value),
bordered: false,
style: { height: 180 }
}
))), /* @__PURE__ */ React.createElement("div", { className: "c-black mb20 mt30" }, "\u4EE3\u7801\u6267\u884C\u7ED3\u679C"), /* @__PURE__ */ React.createElement("div", { className: SelfTestRunmodules.box }, /* @__PURE__ */ React.createElement(spin/* default */.Z, { spinning: loading, tip: "\u4EE3\u7801\u6267\u884C\u4E2D" }, /* @__PURE__ */ React.createElement("div", { className: SelfTestRunmodules.li, style: { height: 196, overflow: "auto", padding: 10 } }, getCommitOut(resultData))))))
));
};
/* harmony default export */ var components_SelfTestRun = (SelfTestRun);
// EXTERNAL MODULE: ./node_modules/_@ant-design_icons@5.3.7@@ant-design/icons/es/icons/ExclamationCircleOutlined.js + 1 modules
var ExclamationCircleOutlined = __webpack_require__(88289);
;// CONCATENATED MODULE: ./src/components/QuestionEditor/BProgramEditor.tsx
/* provided dependency */ var BProgramEditor_React = __webpack_require__(/*! react */ 59301);
var BProgramEditor_defProp = Object.defineProperty;
var BProgramEditor_defProps = Object.defineProperties;
var BProgramEditor_getOwnPropDescs = Object.getOwnPropertyDescriptors;
var BProgramEditor_getOwnPropSymbols = Object.getOwnPropertySymbols;
var BProgramEditor_hasOwnProp = Object.prototype.hasOwnProperty;
var BProgramEditor_propIsEnum = Object.prototype.propertyIsEnumerable;
var BProgramEditor_defNormalProp = (obj, key, value) => key in obj ? BProgramEditor_defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var BProgramEditor_spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (BProgramEditor_hasOwnProp.call(b, prop))
BProgramEditor_defNormalProp(a, prop, b[prop]);
if (BProgramEditor_getOwnPropSymbols)
for (var prop of BProgramEditor_getOwnPropSymbols(b)) {
if (BProgramEditor_propIsEnum.call(b, prop))
BProgramEditor_defNormalProp(a, prop, b[prop]);
}
return a;
};
var BProgramEditor_spreadProps = (a, b) => BProgramEditor_defProps(a, BProgramEditor_getOwnPropDescs(b));
var __objRest = (source, exclude) => {
var target = {};
for (var prop in source)
if (BProgramEditor_hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
target[prop] = source[prop];
if (source != null && BProgramEditor_getOwnPropSymbols)
for (var prop of BProgramEditor_getOwnPropSymbols(source)) {
if (exclude.indexOf(prop) < 0 && BProgramEditor_propIsEnum.call(source, prop))
target[prop] = source[prop];
}
return target;
};
const { TextArea } = input["default"];
const language = [
{ title: "C", key: "C" },
{ title: "C++", key: "C++" },
{ title: "Python", key: "Python" },
{ title: "Java", key: "Java" },
{ title: "JavaScript", key: "JavaScript" },
{ title: "Ruby", key: "Ruby" }
];
const ReversedSwitch = ({ value, onChange }) => {
return /* @__PURE__ */ BProgramEditor_React.createElement(
Switch,
{
checked: value,
onChange: (checked) => {
onChange(checked);
}
}
);
};
const NULL_CH = "@\u2581@";
const NULL_CH1 = "@\u2581\u2581@";
const BProgramEditor = ({
questionTitlePlaceholder,
form,
scoreByBlank = false,
hackidentifier,
answerKey
}) => {
const [editAnalysis, setEditAnalysis] = (0,_react_17_0_2_react.useState)(false);
const [isloading, setloading] = (0,_react_17_0_2_react.useState)(false);
const param = (0,_umi_production_exports.useParams)();
const isEdit = param.type === "edit";
const getChCountBeforeCursor = (cm, cursor) => {
const currentLine = cursor.line;
let placeholderCountBefore = 0;
for (let _line = 0; _line < currentLine; _line++) {
placeholderCountBefore += cm.getLine(_line).split(NULL_CH).length - 1;
}
for (let _line = 0; _line < currentLine; _line++) {
placeholderCountBefore += cm.getLine(_line).split(NULL_CH1).length - 1;
}
const currentLineStringBeforeCursor = cm.getLine(currentLine).substring(0, cursor.ch);
placeholderCountBefore += currentLineStringBeforeCursor.split(NULL_CH).length - 1;
placeholderCountBefore += currentLineStringBeforeCursor.split(NULL_CH1).length - 1;
return placeholderCountBefore;
};
const onCMBeforeChange = (cm, change, addBlank2, removeBlank2) => {
const rangeText = cm.getRange(change.from, change.to);
let newBlankNum = 0;
change.text.forEach((item) => {
newBlankNum += item.split(NULL_CH).length - 1;
});
change.text.forEach((item) => {
newBlankNum += item.split(NULL_CH1).length - 1;
});
if (change.origin === "setValue") {
return;
}
if (rangeText && (rangeText.indexOf(NULL_CH) !== -1 || rangeText.indexOf(NULL_CH1) !== -1)) {
const placeholderCountInRange = rangeText.split(NULL_CH).length - 1 + rangeText.split(NULL_CH1).length - 1;
const placeholderCountBefore = getChCountBeforeCursor(
cm,
change.from
);
console.log(
`\u5220\u9664${placeholderCountInRange}\u4E2A\uFF0C \u524D\u9762\u6709${placeholderCountBefore}\u4E2A\uFF0C\u65B0\u589E${newBlankNum}\u4E2A`
);
if (placeholderCountInRange > 1) {
const indexArray = Array.from({ length: placeholderCountInRange }, (item, index) => placeholderCountBefore + index);
removeBlank2(indexArray);
} else {
removeBlank2(placeholderCountBefore);
}
} else if (newBlankNum > 0) {
const placeholderCountBefore = getChCountBeforeCursor(
cm,
change.from
);
console.log(
`\u65B0\u589E${newBlankNum}\u4E2A\uFF0C\u4E4B\u524D\u6709${placeholderCountBefore}\u4E2A`
);
addBlank2(newBlankNum, placeholderCountBefore);
}
};
const rewritePosition = () => {
const preAnswerData = form.getFieldValue(answerKey);
form.setFieldsValue({ [answerKey]: preAnswerData == null ? void 0 : preAnswerData.map((item, index) => BProgramEditor_spreadProps(BProgramEditor_spreadValues({}, item), { position: index + 1 })) });
};
const addFnRef = (0,_react_17_0_2_react.useRef)();
const addBlank = (addNum, insertIndex) => {
for (let i = 0; i < addNum; i++) {
addFnRef.current({ position: null, answer_text: "" }, insertIndex + i);
}
rewritePosition();
};
const removeFnRef = (0,_react_17_0_2_react.useRef)();
const removeBlank = (deleteIndex) => {
removeFnRef.current(deleteIndex);
rewritePosition();
};
const standardAnswersValue = es_form["default"].useWatch(answerKey, form);
return /* @__PURE__ */ BProgramEditor_React.createElement("div", { className: QuestionEditormodules/* default */.Z.wrap }, /* @__PURE__ */ BProgramEditor_React.createElement(es_form["default"].Item, { label: "\u8BD5\u9898\u63CF\u8FF0", name: ["hack", "description"], style: { display: "table" }, className: "w100", labelCol: { span: 24 }, rules: [{ required: true }] }, /* @__PURE__ */ BProgramEditor_React.createElement(
MdEditorInForm/* MdEditorInForm */.h,
{
scrollId: "name",
watch: true,
height: 140
}
)), /* @__PURE__ */ BProgramEditor_React.createElement("div", { className: QuestionEditormodules/* default */.Z.questionTitleEditorWrap }, /* @__PURE__ */ BProgramEditor_React.createElement(es_form["default"].Item, { label: "\u7A0B\u5E8F\u4EE3\u7801", name: ["hack_codes", "code"], labelCol: { span: 24 }, rules: [{ required: true }] }, /* @__PURE__ */ BProgramEditor_React.createElement(
MdEditorInForm/* MdEditorInForm */.h,
{
scrollId: "name",
watch: true,
height: 400,
showNullProgramButton: true,
onChange: (a, b) => {
const preAnswerData = form.getFieldValue(answerKey);
console.log("--preAnswerData", preAnswerData, b);
form.setFieldsValue({ [answerKey]: preAnswerData == null ? void 0 : preAnswerData.map((item, index) => {
var _a;
return BProgramEditor_spreadProps(BProgramEditor_spreadValues({}, item), { position: index + 1, multi_line: (_a = b == null ? void 0 : b[index]) == null ? void 0 : _a.multiLine });
}) });
},
placeholder: questionTitlePlaceholder,
onCMBeforeChange: (cm, change) => {
onCMBeforeChange(cm, change, addBlank, removeBlank);
}
}
))), /* @__PURE__ */ BProgramEditor_React.createElement(
es_form["default"].List,
{
name: answerKey,
rules: [{
validator(rule, values) {
if (!(values == null ? void 0 : values.length)) {
return Promise.reject(new Error("\u7B54\u6848\u4E0D\u80FD\u4E3A\u7A7A"));
}
for (const item of values) {
const { answer_text } = item || {};
if ((answer_text == null ? void 0 : answer_text.length) === 0) {
return Promise.reject(new Error("\u586B\u7A7A\u9879\u7B54\u6848\u4E0D\u80FD\u4E3A\u7A7A"));
}
}
return Promise.resolve();
}
}]
},
(fields, { add, remove }, { errors }) => {
addFnRef.current = add;
removeFnRef.current = remove;
return /* @__PURE__ */ BProgramEditor_React.createElement(BProgramEditor_React.Fragment, null, /* @__PURE__ */ BProgramEditor_React.createElement("div", { style: { display: "flex", alignItems: "center", justifyContent: "space-between" } }, /* @__PURE__ */ BProgramEditor_React.createElement(es_form["default"].Item, { label: "\u586B\u7A7A\u9879\u7B54\u6848", required: true, labelCol: { span: 24 } }), /* @__PURE__ */ BProgramEditor_React.createElement("div", { onClick: () => {
modal["default"].warning({
title: "\u7ED9\u5206\u8BF4\u660E",
icon: null,
width: 700,
centered: true,
content: /* @__PURE__ */ BProgramEditor_React.createElement("div", null, /* @__PURE__ */ BProgramEditor_React.createElement("div", null, "1.\u5B66\u751F\u586B\u5199\u7B54\u6848\u4E4B\u540E\uFF0C\u5FC5\u987B\u63D0\u4EA4\u4EE3\u7801", /* @__PURE__ */ BProgramEditor_React.createElement("span", { style: { color: "#e30000" } }, "\u8FDB\u884C\u8BC4\u6D4B"), "\u624D\u80FD\u5F97\u5206\u3002"), /* @__PURE__ */ BProgramEditor_React.createElement("div", { style: { marginTop: 10 } }, "2.\u8BD5\u9898\u7B97\u5206\u65F6\uFF0C\u7CFB\u7EDF\u4F1A\u5C06\u7A0B\u5E8F\u91CC\u9762\u7684\u6240\u6709\u7A7A\u66FF\u6362\u6210\u5B66\u751F\u7684\u7B54\u6848\u8FDB\u884C\u8BC4\u6D4B\u3002\u8F93\u51FA\u7684\u7ED3\u679C\u4E0E\u6D4B\u8BD5\u96C6\u6BD4\u5BF9\uFF0C\u5B8C\u5168\u6B63\u786E\u5219\u5F97\u6EE1\u5206\uFF1B\u82E5\u4E0D\u5B8C\u5168\u6B63\u786E\uFF0C\u5219\u4F9D\u6B21\u5C06\u6BCF\u4E2A\u7A7A\u6362\u6210\u5B66\u751F\u63D0\u4EA4\u7684\u7B54\u6848\uFF0C\u540C\u65F6\u5C06\u5176\u4ED6\u7A7A\u66FF\u6362\u6210\u6807\u51C6\u7B54\u6848\uFF0C\u8FD0\u884C\u7A0B\u5E8F\u3002\u5982\u679C\u8FD9\u4E2A\u7A7A\u7684\u5B66\u751F\u7B54\u6848\u4E0E\u6807\u51C6\u7B54\u6848\u7ED3\u5408\u80FD\u5F97\u5230\u6B63\u786E\u8F93\u51FA\uFF0C\u5219\u8FD9\u4E2A\u7A7A\u5F97\u5230\u8BE5\u7A7A\u7684\u6EE1\u5206\uFF0C\u5426\u5219\u8BE5\u7A7A\u5F970\u5206\u3002"))
});
}, style: { minHeight: 32, color: "#3061D0", cursor: "pointer" } }, /* @__PURE__ */ BProgramEditor_React.createElement(ExclamationCircleOutlined/* default */.Z, { style: { marginRight: 3, color: "#3061D0" } }), /* @__PURE__ */ BProgramEditor_React.createElement("span", null, " \u7ED9\u5206\u8BF4\u660E"))), fields.map((_a, index) => {
var _b = _a, { key, name } = _b, restField = __objRest(_b, ["key", "name"]);
var _a2, _b2;
return /* @__PURE__ */ BProgramEditor_React.createElement(row/* default */.Z, { className: `mb20`, key, align: "middle", wrap: false }, /* @__PURE__ */ BProgramEditor_React.createElement(col/* default */.Z, { flex: "0 0 auto", className: `${QuestionEditormodules/* default */.Z.blankIndex}` }, "\u586B\u7A7A\u9879", index + 1), /* @__PURE__ */ BProgramEditor_React.createElement(col/* default */.Z, { flex: 1 }, /* @__PURE__ */ BProgramEditor_React.createElement(row/* default */.Z, { align: "top", justify: "space-between", wrap: false }, /* @__PURE__ */ BProgramEditor_React.createElement(col/* default */.Z, null, /* @__PURE__ */ BProgramEditor_React.createElement(es_form["default"].Item, BProgramEditor_spreadProps(BProgramEditor_spreadValues({}, restField), { name: [name, "answer_text"], noStyle: true }), ((_a2 = standardAnswersValue == null ? void 0 : standardAnswersValue[name]) == null ? void 0 : _a2.multi_line) || ((_b2 = standardAnswersValue == null ? void 0 : standardAnswersValue[name]) == null ? void 0 : _b2.multiLine) ? /* @__PURE__ */ BProgramEditor_React.createElement(TextArea, { spellCheck: false, style: { marginLeft: 10, width: 550 } }) : /* @__PURE__ */ BProgramEditor_React.createElement(
input["default"],
{
style: { marginLeft: 10, width: 550 },
className: QuestionEditormodules/* default */.Z.blankInput,
size: "large",
maxLength: 1e3,
onBlur: (e) => {
}
}
))), scoreByBlank && /* @__PURE__ */ BProgramEditor_React.createElement(col/* default */.Z, { flex: "224px" }, /* @__PURE__ */ BProgramEditor_React.createElement(es_form["default"].Item, BProgramEditor_spreadProps(BProgramEditor_spreadValues({}, restField), { name: [name, "score"], label: "\u5206\u503C", rules: [{ required: true }] }), /* @__PURE__ */ BProgramEditor_React.createElement(input_number/* default */.Z, { size: "large", className: QuestionEditormodules/* default */.Z.blankInput, min: 0.1, max: 100, precision: 1, style: { width: "100%" }, placeholder: "\u8BF7\u8F93\u5165\u5206\u503C" }))))));
}));
}
), /* @__PURE__ */ BProgramEditor_React.createElement("div", { onClick: () => setEditAnalysis(true) }, /* @__PURE__ */ BProgramEditor_React.createElement(es_form["default"].Item, { name: ["hack", "analysis"], label: "\u9898\u76EE\u89E3\u6790", labelCol: { span: 24 } }, /* @__PURE__ */ BProgramEditor_React.createElement(MdEditorInForm/* RegularInput */.x, { placeholder: "\u8BF7\u7F16\u8F91\u9898\u76EE\u89E3\u6790\uFF08\u975E\u5FC5\u586B\uFF09", isEdit: editAnalysis }))), /* @__PURE__ */ BProgramEditor_React.createElement(
es_form["default"].Item,
{
label: "\u7F16\u7A0B\u8BED\u8A00",
style: { marginTop: 30 },
name: ["hack_codes", "language"],
labelCol: { span: 24 },
rules: [{ required: true, message: "\u8BF7\u9009\u62E9\u7F16\u7A0B\u8BED\u8A00" }]
},
/* @__PURE__ */ BProgramEditor_React.createElement(
es_select["default"],
{
size: "large"
},
language.map((item) => /* @__PURE__ */ BProgramEditor_React.createElement(es_select["default"].Option, { key: item.title, value: item.key }, " ", item.title))
)
), /* @__PURE__ */ BProgramEditor_React.createElement(
es_form["default"].Item,
{
label: "\u6700\u5927\u8BC4\u6D4B\u65F6\u957F\uFF08\u79D2\uFF09",
style: { marginTop: 30 },
labelCol: { span: 24 },
required: true
},
/* @__PURE__ */ BProgramEditor_React.createElement(
es_form["default"].Item,
{
name: ["hack", "time_limit"],
rules: [{ required: true, message: "\u8BF7\u8F93\u5165\u5355\u4E2A\u6D4B\u8BD5\u96C6\u8BC4\u6D4B\u65F6\u957F\u9650\u5236" }, {
type: "number",
min: 3,
message: "\u6700\u5C0F\u9650\u5236\u65F6\u95F4\u662F3\u79D2"
}],
noStyle: true
},
/* @__PURE__ */ BProgramEditor_React.createElement(input_number/* default */.Z, { precision: 0, max: 10, min: 3, size: "large", style: { width: "97%" } })
),
/* @__PURE__ */ BProgramEditor_React.createElement("span", { className: "ml10 font14" }, "\u79D2")
), /* @__PURE__ */ BProgramEditor_React.createElement(
es_form["default"].Item,
{
label: "\u5B66\u751F\u7B54\u6848\u7684\u7A7A\u683C\u5904\u7406\u65B9\u5F0F",
style: { marginTop: 30 },
name: ["hack", "submit_rule"],
labelCol: { span: 24 },
rules: [{ required: true, message: "\u8BF7\u9009\u62E9\u5B66\u751F\u7B54\u6848\u7684\u7A7A\u683C\u5904\u7406\u65B9\u5F0F" }]
},
/* @__PURE__ */ BProgramEditor_React.createElement(es_radio/* default.Group */.ZP.Group, { style: { marginTop: -10 } }, /* @__PURE__ */ BProgramEditor_React.createElement(es_radio/* default */.ZP, { value: 0 }, "\u4E0D\u5FFD\u7565\u7A7A\u683C"), /* @__PURE__ */ BProgramEditor_React.createElement(es_radio/* default */.ZP, { value: 1 }, "\u5FFD\u7565\u9996\u5C3E\u7A7A\u683C"), /* @__PURE__ */ BProgramEditor_React.createElement(es_radio/* default */.ZP, { value: 2 }, "\u5FFD\u7565\u6240\u6709\u7A7A\u683C"))
), /* @__PURE__ */ BProgramEditor_React.createElement(
es_form["default"].Item,
{
label: "\u6D4B\u8BD5\u7528\u4F8B",
required: true,
style: { marginTop: 30 }
}
), /* @__PURE__ */ BProgramEditor_React.createElement("div", { style: { background: "#F6F7F9", padding: 15 } }, /* @__PURE__ */ BProgramEditor_React.createElement(
es_form["default"].Item,
{
label: "\u8F93\u5165",
labelCol: { span: 24 },
name: ["hack_sets", "input"]
},
/* @__PURE__ */ BProgramEditor_React.createElement(
TextArea,
{
rows: 4
}
)
), /* @__PURE__ */ BProgramEditor_React.createElement(
es_form["default"].Item,
{
label: "\u8F93\u51FA",
labelCol: { span: 24 },
name: ["hack_sets", "output"],
rules: [{ required: true, message: "\u8BF7\u8F93\u5165\u8F93\u51FA\u5185\u5BB9" }]
},
/* @__PURE__ */ BProgramEditor_React.createElement(
TextArea,
{
rows: 4
}
)
)), /* @__PURE__ */ BProgramEditor_React.createElement(
components_SelfTestRun,
{
form,
answerKey,
hackIdentifier: hackidentifier,
buttonText: "\u8FD0\u884C\u8C03\u8BD5",
buttonProps: {
ghost: true,
icon: /* @__PURE__ */ BProgramEditor_React.createElement("i", { className: "iconfont icon-ceshi" }),
style: { background: "rgba(55,173,131,0.05)", borderRadius: 19, border: "1px solid #37AD83", width: 116, height: 38, display: "inline-flex", fontSize: 14, alignItems: "center", justifyContent: "center", marginTop: 20, cursor: "pointer", color: "#37AD83" }
}
}
));
};
/***/ }),
/***/ 13866:
/*!****************************************************************!*\
!*** ./src/components/QuestionEditor/ChoiceQuestionEditor.tsx ***!
\****************************************************************/
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ u: function() { return /* binding */ ChoiceQuestionEditor; }
/* harmony export */ });
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ 59301);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! antd */ 95237);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! antd */ 43604);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! antd */ 6848);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! antd */ 78241);
/* harmony import */ var _index_less_modules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./index.less?modules */ 5547);
/* harmony import */ var _ant_design_icons__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @ant-design/icons */ 57703);
/* harmony import */ var _ant_design_icons__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @ant-design/icons */ 78091);
/* harmony import */ var _MdEditorInForm__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./MdEditorInForm */ 57782);
/* provided dependency */ var React = __webpack_require__(/*! react */ 59301);
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
var __objRest = (source, exclude) => {
var target = {};
for (var prop in source)
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
target[prop] = source[prop];
if (source != null && __getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(source)) {
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
target[prop] = source[prop];
}
return target;
};
const tagList = [
"A",
"B",
"C",
"D",
"E",
"F",
"G",
"H",
"I",
"J",
"K",
"L",
"M",
"N",
"O",
"P",
"Q",
"R",
"S",
"T",
"U",
"V",
"W",
"X",
"Y",
"Z"
];
const ChoiceQuestionItem = ({
value,
onChange,
choiceTextKey,
answerKey,
index,
isEdit,
setInputActive,
form,
choiceOptionsPath,
allowChangeMode,
showAddIcon,
addItem,
deleteItem
}) => {
console.log(value, "value");
const isActiveAnswer = (value == null ? void 0 : value[answerKey]) === 1;
const setAllOptionsToFalse = () => {
const options = form.getFieldValue(choiceOptionsPath);
form.setFieldValue(choiceOptionsPath, options.map((item) => __spreadProps(__spreadValues({}, item), { [answerKey]: 0 })));
};
const setActiveAnswer = () => {
if (isActiveAnswer) {
onChange(__spreadProps(__spreadValues({}, value), { [answerKey]: 0 }));
} else {
if (!allowChangeMode) {
setAllOptionsToFalse();
}
onChange(__spreadProps(__spreadValues({}, value), { [answerKey]: 1 }));
}
};
return /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z, { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.choiceWrap, align: "middle", wrap: false }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z, { onClick: setActiveAnswer, className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.choiceIndex} ${isActiveAnswer ? _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.activeAnswer : ""}` }, tagList[index]), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z, { flex: 1, className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.editorWrap} ml15`, onClick: setInputActive }, /* @__PURE__ */ React.createElement(_MdEditorInForm__WEBPACK_IMPORTED_MODULE_2__/* .RegularInput */ .x, { height: 155, placeholder: "\u8BF7\u60A8\u8F93\u5165\u9009\u9879", isEdit, value: value == null ? void 0 : value[choiceTextKey], onChange: (v) => {
onChange(__spreadProps(__spreadValues({}, value), { [choiceTextKey]: v }));
} })), /* @__PURE__ */ React.createElement(
antd__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z,
{
flex: "0 0 auto",
className: "ml15"
},
/* @__PURE__ */ React.createElement(
"div",
{
onClick: setActiveAnswer,
className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.setAnswerBtn} ${isActiveAnswer ? _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.activeAnswer : ""}`
},
isActiveAnswer ? "\u6B63\u786E\u7B54\u6848" : "\u8BBE\u4E3A\u7B54\u6848"
)
), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z, { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.actionWrapper }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { title: "\u65B0\u589E\u53C2\u8003\u7B54\u6848" }, /* @__PURE__ */ React.createElement(
_ant_design_icons__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z,
{
className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.addIcon,
onClick: addItem,
style: { visibility: showAddIcon ? "visible" : "hidden" }
}
)), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { title: "\u5220\u9664" }, /* @__PURE__ */ React.createElement(
_ant_design_icons__WEBPACK_IMPORTED_MODULE_7__/* ["default"] */ .Z,
{
className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.deleteIcon,
onClick: deleteItem,
style: { visibility: index > 1 ? "visible" : "hidden" }
}
))));
};
const ChoiceQuestionEditor = ({
questionTitlePlaceholder,
titleKey,
choiceKey,
analysisKey,
choiceTextKey,
answerKey,
choiceOptionsPath,
allowChangeMode = true,
form,
showAnalysis = true
}) => {
const [activeEditor, setActiveEditor] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)();
const [editAnalysis, setEditAnalysis] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(false);
return /* @__PURE__ */ React.createElement("div", { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.wrap }, /* @__PURE__ */ React.createElement("div", { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.questionTitleEditorWrap }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_8__["default"].Item, { label: "\u9898\u5E72", name: titleKey, labelCol: { span: 24 }, rules: [{ required: true }] }, /* @__PURE__ */ React.createElement(
_MdEditorInForm__WEBPACK_IMPORTED_MODULE_2__/* .MdEditorInForm */ .h,
{
scrollId: Array.isArray(titleKey) ? titleKey.join("_") : `${titleKey}`,
watch: true,
height: 140,
placeholder: questionTitlePlaceholder
}
))), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_8__["default"].Item, { label: "\u7B54\u6848\u9009\u9879", required: true, labelCol: { span: 24 } }), /* @__PURE__ */ React.createElement(
antd__WEBPACK_IMPORTED_MODULE_8__["default"].List,
{
name: choiceKey,
rules: [{
validator(rule, values) {
const hasAnswer = values.some((option) => option[answerKey] === 1);
const emptyAnswerIndex = values.findIndex((option) => {
var _a;
return ((_a = option[choiceTextKey]) == null ? void 0 : _a.length) <= 0;
});
if (emptyAnswerIndex !== -1) {
return Promise.reject(new Error(`\u8BF7\u5148\u8F93\u5165${tagList[emptyAnswerIndex]}\u9009\u9879\u7684\u5185\u5BB9`));
}
if (!hasAnswer) {
return Promise.reject(new Error("\u8BF7\u8BBE\u7F6E\u6B63\u786E\u7B54\u6848"));
}
return Promise.resolve();
}
}]
},
(fields, { add, remove }) => /* @__PURE__ */ React.createElement("div", { id: Array.isArray(choiceOptionsPath) ? choiceOptionsPath.join("_") : `${choiceOptionsPath}` }, fields.map((_a, index) => {
var _b = _a, { key, name } = _b, restField = __objRest(_b, ["key", "name"]);
const isEdit = activeEditor === key;
const setInputActive = () => {
setActiveEditor(key);
};
const showAddIcon = index < 7 && index === fields.length - 1;
const addItem = () => add({ [choiceTextKey]: "", [answerKey]: 0 });
const deleteItem = () => remove(name);
return /* @__PURE__ */ React.createElement(
antd__WEBPACK_IMPORTED_MODULE_8__["default"].Item,
__spreadProps(__spreadValues({}, restField), {
key,
name,
className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.choiceListWrap,
rules: [{
validator(rule, values) {
if (!(values == null ? void 0 : values.choice_text)) {
return Promise.reject(new Error(`\u8BF7\u5148\u8F93\u5165${tagList[index]}\u9009\u9879\u7684\u5185\u5BB9`));
}
return Promise.resolve();
}
}]
}),
/* @__PURE__ */ React.createElement(
ChoiceQuestionItem,
{
choiceTextKey,
answerKey,
index,
isEdit,
setInputActive,
form,
choiceOptionsPath,
allowChangeMode,
showAddIcon,
addItem,
deleteItem
}
)
);
}), fields.length < 8 && /* @__PURE__ */ React.createElement("div", { className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.addBtn} mb30`, onClick: () => add({ [choiceTextKey]: "", [answerKey]: 0 }) }, "\u6DFB\u52A0\u9009\u9879"))
), showAnalysis && /* @__PURE__ */ React.createElement("div", { onClick: () => setEditAnalysis(true) }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_8__["default"].Item, { name: analysisKey, label: "\u9898\u76EE\u89E3\u6790", labelCol: { span: 24 } }, /* @__PURE__ */ React.createElement(_MdEditorInForm__WEBPACK_IMPORTED_MODULE_2__/* .RegularInput */ .x, { placeholder: "\u8BF7\u7F16\u8F91\u9898\u76EE\u89E3\u6790\uFF08\u975E\u5FC5\u586B\uFF09", isEdit: editAnalysis }))));
};
/***/ }),
/***/ 60151:
/*!********************************************************************!*\
!*** ./src/components/QuestionEditor/CompletionQuestionEditor.tsx ***!
\********************************************************************/
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ u: function() { return /* binding */ CompletionQuestionEditor; }
/* harmony export */ });
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ 59301);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! antd */ 43418);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! antd */ 95237);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! antd */ 43604);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! antd */ 98135);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! antd */ 6848);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! antd */ 78673);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! antd */ 78241);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! antd */ 5112);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! antd */ 54449);
/* harmony import */ var _MdEditorInForm__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./MdEditorInForm */ 57782);
/* harmony import */ var _ant_design_icons__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @ant-design/icons */ 78091);
/* harmony import */ var _ant_design_icons__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! @ant-design/icons */ 85699);
/* harmony import */ var _index_less_modules__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./index.less?modules */ 5547);
/* harmony import */ var _components_MathsLatexKeybords__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @/components/MathsLatexKeybords */ 14233);
/* provided dependency */ var React = __webpack_require__(/*! react */ 59301);
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
var __objRest = (source, exclude) => {
var target = {};
for (var prop in source)
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
target[prop] = source[prop];
if (source != null && __getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(source)) {
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
target[prop] = source[prop];
}
return target;
};
const BlankEditor = ({ value, onChange }) => {
const handleDelete = (index) => {
antd__WEBPACK_IMPORTED_MODULE_4__["default"].confirm({
centered: true,
okText: "\u786E\u5B9A",
cancelText: "\u53D6\u6D88",
title: "\u63D0\u793A",
content: "\u786E\u8BA4\u8981\u5220\u9664\u8FD9\u4E2A\u53C2\u8003\u7B54\u6848\u5417\uFF1F",
className: _index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.modal,
onOk: () => {
const valueCopy = [...value];
valueCopy.splice(index, 1);
onChange(valueCopy);
}
});
};
const handleAdd = () => {
const valueCopy = [...value];
valueCopy.push("");
onChange(valueCopy);
};
return /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { className: "ml20" }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, { flex: 1 }, value == null ? void 0 : value.map((v, index) => {
return /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { key: `${v}_${index}`, className: "mb20" }, /* @__PURE__ */ React.createElement(
antd__WEBPACK_IMPORTED_MODULE_7__["default"].TextArea,
{
style: { flex: 1, minHeight: 44 },
defaultValue: v,
autoSize: { maxRows: 3 },
maxLength: 1e3,
onBlur: (e) => {
const valueCopy = [...value];
const inputTrimValue = e.target.value.trim();
valueCopy[index] = inputTrimValue;
onChange(valueCopy);
}
}
), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z, { title: "\u5220\u9664" }, /* @__PURE__ */ React.createElement(
_ant_design_icons__WEBPACK_IMPORTED_MODULE_9__/* ["default"] */ .Z,
{
className: _index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.deleteIcon,
style: { marginLeft: 15, visibility: index > 0 ? "visible" : "hidden" },
onClick: () => handleDelete(index)
}
)));
})), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, null, /* @__PURE__ */ React.createElement("div", { className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.addBtn}`, onClick: () => {
handleAdd();
} }, "\u65B0\u589E\u7B54\u6848")));
};
const BlankEditors = ({ value, onChange }) => {
const handleDelete = (index) => {
antd__WEBPACK_IMPORTED_MODULE_4__["default"].confirm({
centered: true,
okText: "\u786E\u5B9A",
cancelText: "\u53D6\u6D88",
title: "\u63D0\u793A",
content: "\u786E\u8BA4\u8981\u5220\u9664\u8FD9\u4E2A\u53C2\u8003\u7B54\u6848\u5417\uFF1F",
className: _index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.modal,
onOk: () => {
const valueCopy = [...value];
valueCopy.splice(index, 1);
onChange(valueCopy);
}
});
};
const handleAdd = () => {
const valueCopy = [...value];
valueCopy.push("");
onChange(valueCopy);
};
return /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { className: "ml20" }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, { flex: 1 }, value == null ? void 0 : value.map((v, index) => {
return /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { key: `${v}_${index}`, align: "middle", className: "mb20" }, /* @__PURE__ */ React.createElement(
_components_MathsLatexKeybords__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z,
{
value: v,
style: { flex: 1 },
onChange: (e) => {
const valueCopy = [...value];
valueCopy[index] = e;
onChange(valueCopy);
}
}
), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z, { title: "\u5220\u9664" }, /* @__PURE__ */ React.createElement(
_ant_design_icons__WEBPACK_IMPORTED_MODULE_9__/* ["default"] */ .Z,
{
className: _index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.deleteIcon,
style: { marginLeft: 15, visibility: index > 0 ? "visible" : "hidden" },
onClick: () => handleDelete(index)
}
)));
})), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, null, /* @__PURE__ */ React.createElement("div", { className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.addBtn}`, onClick: () => {
handleAdd();
} }, "\u65B0\u589E\u7B54\u6848")));
};
const ReversedSwitch = ({ value = true, onChange }) => {
return /* @__PURE__ */ React.createElement(
antd__WEBPACK_IMPORTED_MODULE_10__/* ["default"] */ .Z,
{
checked: !value,
onChange: (checked) => {
onChange(!checked);
}
}
);
};
const NULL_CH = "\u2581";
const CompletionQuestionEditor = ({
questionTitlePlaceholder,
form,
scoreByBlank = false,
answerKey
}) => {
const [editAnalysis, setEditAnalysis] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(false);
const getChCountBeforeCursor = (cm, cursor) => {
const currentLine = cursor.line;
let placeholderCountBefore = 0;
for (let _line = 0; _line < currentLine; _line++) {
placeholderCountBefore += cm.getLine(_line).split(NULL_CH).length - 1;
}
const currentLineStringBeforeCursor = cm.getLine(currentLine).substring(0, cursor.ch);
placeholderCountBefore += currentLineStringBeforeCursor.split(NULL_CH).length - 1;
return placeholderCountBefore;
};
const onCMBeforeChange = (cm, change, addBlank2, removeBlank2) => {
const rangeText = cm.getRange(change.from, change.to);
let newBlankNum = 0;
change.text.forEach((item) => {
newBlankNum += item.split(NULL_CH).length - 1;
});
if (change.origin === "setValue") {
return;
}
if (rangeText && rangeText.indexOf(NULL_CH) !== -1) {
const placeholderCountInRange = rangeText.split(NULL_CH).length - 1;
const placeholderCountBefore = getChCountBeforeCursor(
cm,
change.from
);
console.log(
`\u5220\u9664${placeholderCountInRange}\u4E2A\uFF0C \u524D\u9762\u6709${placeholderCountBefore}\u4E2A\uFF0C\u65B0\u589E${newBlankNum}\u4E2A`
);
if (placeholderCountInRange > 1) {
const indexArray = Array.from({ length: placeholderCountInRange }, (item, index) => placeholderCountBefore + index);
removeBlank2(indexArray);
} else {
removeBlank2(placeholderCountBefore);
}
} else if (newBlankNum > 0) {
const placeholderCountBefore = getChCountBeforeCursor(
cm,
change.from
);
console.log(
`\u65B0\u589E${newBlankNum}\u4E2A\uFF0C\u4E4B\u524D\u6709${placeholderCountBefore}\u4E2A`
);
addBlank2(newBlankNum, placeholderCountBefore);
}
};
const rewritePosition = () => {
const preAnswerData = form.getFieldValue(answerKey);
form.setFieldsValue({ [answerKey]: preAnswerData.map((item, index) => __spreadProps(__spreadValues({}, item), { position: index + 1 })) });
};
const addFnRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)();
const addBlank = (addNum, insertIndex) => {
for (let i = 0; i < addNum; i++) {
addFnRef.current({ position: null, answer_text: [""], model: 1 }, insertIndex + i);
}
rewritePosition();
};
const removeFnRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)();
const removeBlank = (deleteIndex) => {
removeFnRef.current(deleteIndex);
rewritePosition();
};
const standardAnswersValue = antd__WEBPACK_IMPORTED_MODULE_11__["default"].useWatch(answerKey, form);
return /* @__PURE__ */ React.createElement("div", { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.wrap }, /* @__PURE__ */ React.createElement("div", { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.questionTitleEditorWrap }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_11__["default"].Item, { label: "\u9898\u5E72", name: "name", labelCol: { span: 24 }, rules: [{ required: true }] }, /* @__PURE__ */ React.createElement(
_MdEditorInForm__WEBPACK_IMPORTED_MODULE_1__/* .MdEditorInForm */ .h,
{
scrollId: "name",
watch: true,
height: 140,
placeholder: questionTitlePlaceholder,
showNullButton: true,
onCMBeforeChange: (cm, change) => {
onCMBeforeChange(cm, change, addBlank, removeBlank);
}
}
))), /* @__PURE__ */ React.createElement(
antd__WEBPACK_IMPORTED_MODULE_11__["default"].List,
{
name: answerKey,
rules: [{
validator(rule, values) {
if (!(values == null ? void 0 : values.length)) {
return Promise.reject(new Error("\u8BF7\u5148\u5728\u9898\u5E72\u4E2D\u63D2\u5165\u586B\u7A7A\u9879"));
}
for (const item of values) {
const { answer_text } = item || {};
if (answer_text == null ? void 0 : answer_text.some((text) => (text == null ? void 0 : text.length) === 0)) {
return Promise.reject(new Error("\u586B\u7A7A\u9879\u7B54\u6848\u4E0D\u80FD\u4E3A\u7A7A"));
}
}
return Promise.resolve();
}
}]
},
(fields, { add, remove }, { errors }) => {
addFnRef.current = add;
removeFnRef.current = remove;
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_11__["default"].Item, { label: /* @__PURE__ */ React.createElement("span", null, "\u586B\u7A7A\u9879\u7B54\u6848", !(fields == null ? void 0 : fields.length) && /* @__PURE__ */ React.createElement("span", { style: { color: "#E99237" } }, "\uFF08\u8BF7\u5148\u5728\u9898\u5E72\u4E2D\u63D2\u5165\u586B\u7A7A\u9879\uFF09")), required: true, labelCol: { span: 24 } }), fields.map((_a, index) => {
var _b = _a, { key, name } = _b, restField = __objRest(_b, ["key", "name"]);
var _a2, _b2;
return /* @__PURE__ */ React.createElement("div", { style: { marginBottom: 10 }, key }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { className: `mb20`, align: "middle", wrap: false }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, { style: { marginRight: 10 }, flex: "0 0 auto", className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.blankIndex}` }, "\u586B\u7A7A\u9879", index + 1), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_11__["default"].Item, __spreadProps(__spreadValues({}, restField), { name: [name, "model"], noStyle: true }), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_12__/* ["default"].Group */ .ZP.Group, { onChange: () => {
const preAnswerData = form.getFieldValue(answerKey);
form.setFieldsValue({ [answerKey]: preAnswerData.map((item, index2) => __spreadProps(__spreadValues({}, item), { answer_text: name === index2 ? [""] : item.answer_text })) });
} }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_12__/* ["default"] */ .ZP, { value: 1 }, "\u6587\u672C\u6A21\u5F0F ", /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z, { title: "\u5B66\u751F\u7B54\u9898\u65F6\uFF0C\u9700\u8981\u5728\u6587\u672C\u6846\u4E2D\u586B\u5199\u6587\u672C\u7B54\u6848" }, /* @__PURE__ */ React.createElement(_ant_design_icons__WEBPACK_IMPORTED_MODULE_13__/* ["default"] */ .Z, null))), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_12__/* ["default"] */ .ZP, { value: 2 }, "\u6570\u5B66\u516C\u5F0F\u6A21\u5F0F ", /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z, { title: "\u5B66\u751F\u7B54\u9898\u65F6\uFF0C\u9700\u8981\u7F16\u5199\u6570\u5B66\u516C\u5F0F\u4F5C\u4E3A\u7B54\u6848" }, /* @__PURE__ */ React.createElement(_ant_design_icons__WEBPACK_IMPORTED_MODULE_13__/* ["default"] */ .Z, null)))))), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { style: { marginLeft: 20 }, align: "middle", wrap: false }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, { flex: 1 }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { align: "top", justify: "space-between", wrap: false }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, { flex: 1 }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_11__["default"].Item, __spreadProps(__spreadValues({}, restField), { name: [name, "answer_text"], noStyle: true }), ((_b2 = (_a2 = form.getFieldValue(answerKey)) == null ? void 0 : _a2[name]) == null ? void 0 : _b2.model) === 1 ? /* @__PURE__ */ React.createElement(BlankEditor, null) : /* @__PURE__ */ React.createElement(BlankEditors, null))), scoreByBlank && /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, { flex: "224px", style: { margin: "-7px 0 0 20px" } }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_11__["default"].Item, __spreadProps(__spreadValues({}, restField), { name: [name, "score"], label: "\u5206\u503C", rules: [{ required: true }], className: _index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.blankInputNumberWrapper }), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_14__/* ["default"] */ .Z, { min: 0.1, max: 100, precision: 1, style: { width: "100%" }, placeholder: "\u8BF7\u8F93\u5165\u5206\u503C" })))), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_11__["default"].Item, __spreadProps(__spreadValues({}, restField), { name: [name, "position"], noStyle: true }), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_7__["default"], { type: "hidden" })))));
}));
}
), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { align: "middle" }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_11__["default"].Item, { name: "downcase", valuePropName: "checked" }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_10__/* ["default"] */ .Z, null)), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, { className: "ml10" }, "\u5224\u5206\u65F6\u5FFD\u7565\u7B54\u6848\u4E2D\u7684\u5B57\u6BCD\u5927\u5C0F\u5199")), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { align: "middle" }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_11__["default"].Item, { name: "no_space", valuePropName: "checked" }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_10__/* ["default"] */ .Z, null)), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, { className: "ml10" }, "\u5224\u5206\u65F6\u5FFD\u7565\u7B54\u6848\u4E2D\u7684\u7A7A\u683C")), (standardAnswersValue == null ? void 0 : standardAnswersValue.length) > 1 && /* @__PURE__ */ React.createElement(
antd__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z,
{
align: "middle",
className: (standardAnswersValue == null ? void 0 : standardAnswersValue.length) > 1 ? "mb30" : `${_index_less_modules__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z.hide}`
},
/* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_11__["default"].Item, { name: "is_ordered" }, /* @__PURE__ */ React.createElement(ReversedSwitch, null)),
/* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, { className: "ml10" }, "\u5141\u8BB8\u5B66\u751F\u6BCF\u4E2A\u586B\u7A7A\u7684\u7B54\u6848\u4E0E\u6807\u51C6\u7B54\u6848\u7684\u987A\u5E8F\u4E0D\u4E00\u81F4")
), /* @__PURE__ */ React.createElement("div", { onClick: () => setEditAnalysis(true) }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_11__["default"].Item, { name: "analysis", label: "\u9898\u76EE\u89E3\u6790", labelCol: { span: 24 } }, /* @__PURE__ */ React.createElement(_MdEditorInForm__WEBPACK_IMPORTED_MODULE_1__/* .RegularInput */ .x, { placeholder: "\u8BF7\u7F16\u8F91\u9898\u76EE\u89E3\u6790\uFF08\u975E\u5FC5\u586B\uFF09", isEdit: editAnalysis }))));
};
/***/ }),
/***/ 27522:
/*!******************************************************************!*\
!*** ./src/components/QuestionEditor/JudgmentQuestionEditor.tsx ***!
\******************************************************************/
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Z: function() { return /* binding */ JudgmentQuestionEditor; }
/* harmony export */ });
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ 59301);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! antd */ 95237);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! antd */ 43604);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! antd */ 78241);
/* harmony import */ var _index_less_modules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./index.less?modules */ 5547);
/* harmony import */ var _MdEditorInForm__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./MdEditorInForm */ 57782);
/* provided dependency */ var React = __webpack_require__(/*! react */ 59301);
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
var __objRest = (source, exclude) => {
var target = {};
for (var prop in source)
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
target[prop] = source[prop];
if (source != null && __getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(source)) {
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
target[prop] = source[prop];
}
return target;
};
const tagMap = {
["\u6B63\u786E"]: "T",
["\u9519\u8BEF"]: "F"
};
const JudgmentQuestionItem = ({ value, onChange, form }) => {
const isActiveAnswer = (value == null ? void 0 : value.is_answer) === 1;
const judgementText = value == null ? void 0 : value.choice_text;
const setActiveAnswer = () => {
const formListValue = form.getFieldsValue().choices.map((choice) => ({ choice_text: choice.choice_text, is_answer: 0 }));
form.setFieldsValue({ choices: formListValue });
onChange(__spreadProps(__spreadValues({}, value), { is_answer: 1 }));
};
return /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z, { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.choiceWrap, align: "middle", wrap: false, style: { marginBottom: "20px" } }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z, { onClick: setActiveAnswer, className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.choiceIndex} ${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.judgementIndex} ${isActiveAnswer ? _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.activeAnswer : ""}` }, tagMap[judgementText]), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z, { flex: 1, className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.editorWrap} ml15` }, /* @__PURE__ */ React.createElement("div", { className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.inputBorder} ${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.placeholder} ${isActiveAnswer ? _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.activeJudgementAnswer : ""}` }, judgementText)), /* @__PURE__ */ React.createElement(
antd__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z,
{
flex: "0 0 auto",
className: "ml15"
},
/* @__PURE__ */ React.createElement(
"div",
{
onClick: setActiveAnswer,
className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.setAnswerBtn} ${isActiveAnswer ? _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.activeAnswer : ""}`
},
isActiveAnswer ? "\u6B63\u786E\u7B54\u6848" : "\u8BBE\u4E3A\u7B54\u6848"
)
));
};
const JudgmentQuestionEditor = ({
questionTitlePlaceholder,
choiceKey,
form
}) => {
const [editAnalysis, setEditAnalysis] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(false);
return /* @__PURE__ */ React.createElement("div", { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.wrap }, /* @__PURE__ */ React.createElement("div", { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.questionTitleEditorWrap }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__["default"].Item, { label: "\u9898\u5E72", name: "name", labelCol: { span: 24 }, rules: [{ required: true }] }, /* @__PURE__ */ React.createElement(
_MdEditorInForm__WEBPACK_IMPORTED_MODULE_2__/* .MdEditorInForm */ .h,
{
scrollId: "name",
watch: true,
height: 140,
placeholder: questionTitlePlaceholder
}
))), /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__["default"].Item, { label: "\u7B54\u6848\u9009\u9879", required: true, labelCol: { span: 24 } }, /* @__PURE__ */ React.createElement(
antd__WEBPACK_IMPORTED_MODULE_5__["default"].List,
{
name: "choices",
rules: [{
validator(rule, values) {
const hasAnswer = values.some((option) => (option == null ? void 0 : option.is_answer) === 1);
if (hasAnswer) {
return Promise.resolve();
}
return Promise.reject(new Error("\u8BF7\u8BBE\u7F6E\u6B63\u786E\u7B54\u6848"));
}
}]
},
(fields) => /* @__PURE__ */ React.createElement("div", { id: "choices" }, fields.map((_a) => {
var _b = _a, { key, name } = _b, restField = __objRest(_b, ["key", "name"]);
return /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__["default"].Item, __spreadProps(__spreadValues({}, restField), { key, name, noStyle: true }), /* @__PURE__ */ React.createElement(JudgmentQuestionItem, { form }));
}))
)), /* @__PURE__ */ React.createElement("div", { onClick: () => setEditAnalysis(true) }, /* @__PURE__ */ React.createElement(antd__WEBPACK_IMPORTED_MODULE_5__["default"].Item, { name: "analysis", label: "\u9898\u76EE\u89E3\u6790", labelCol: { span: 24 } }, /* @__PURE__ */ React.createElement(_MdEditorInForm__WEBPACK_IMPORTED_MODULE_2__/* .RegularInput */ .x, { placeholder: "\u8BF7\u7F16\u8F91\u9898\u76EE\u89E3\u6790\uFF08\u975E\u5FC5\u586B\uFF09", isEdit: editAnalysis }))));
};
/***/ }),
/***/ 57782:
/*!**********************************************************!*\
!*** ./src/components/QuestionEditor/MdEditorInForm.tsx ***!
\**********************************************************/
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ h: function() { return /* binding */ MdEditorInForm; },
/* harmony export */ x: function() { return /* binding */ RegularInput; }
/* harmony export */ });
/* harmony import */ var _components_markdown_editor__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @/components/markdown-editor */ 96180);
/* harmony import */ var _index_less_modules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./index.less?modules */ 5547);
/* harmony import */ var _components_RenderHtml__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @/components/RenderHtml */ 16921);
/* provided dependency */ var React = __webpack_require__(/*! react */ 59301);
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
var __objRest = (source, exclude) => {
var target = {};
for (var prop in source)
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
target[prop] = source[prop];
if (source != null && __getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(source)) {
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
target[prop] = source[prop];
}
return target;
};
const MdEditorInForm = (_a) => {
var _b = _a, { value, onChange, scrollId } = _b, props = __objRest(_b, ["value", "onChange", "scrollId"]);
return /* @__PURE__ */ React.createElement("div", { id: scrollId || "" }, /* @__PURE__ */ React.createElement(
_components_markdown_editor__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z,
__spreadProps(__spreadValues({}, props), {
defaultValue: value,
onChange: (a, b) => {
console.log("a:", a, b);
if (!!(b == null ? void 0 : b.length))
onChange(a, b);
else
onChange(a);
}
})
));
};
const RegularInput = ({ value, onChange, placeholder, height = 140, isEdit }) => {
return isEdit ? /* @__PURE__ */ React.createElement(
_components_markdown_editor__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z,
{
watch: true,
isFocus: true,
height,
placeholder,
defaultValue: value,
onChange
}
) : /* @__PURE__ */ React.createElement("div", { style: { cursor: "pointer" } }, value ? /* @__PURE__ */ React.createElement(_components_RenderHtml__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z, { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.inputBorder, value }) : /* @__PURE__ */ React.createElement("div", { className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.inputBorder} ${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.placeholder} inputBorderError` }, placeholder));
};
/***/ }),
/***/ 87546:
/*!********************************************************************!*\
!*** ./src/components/QuestionEditor/SubjectiveQuestionEditor.tsx ***!
\********************************************************************/
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ W: function() { return /* binding */ SubjectiveQuestionEditor; }
/* harmony export */ });
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ 59301);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! antd */ 8591);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! antd */ 12563);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! antd */ 78241);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! antd */ 78673);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! antd */ 95237);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! antd */ 43604);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! antd */ 6848);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! antd */ 98135);
/* harmony import */ var antd__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! antd */ 54449);
/* harmony import */ var _index_less_modules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./index.less?modules */ 5547);
/* harmony import */ var _MdEditorInForm__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./MdEditorInForm */ 57782);
/* harmony import */ var _components_markdown_editor__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @/components/markdown-editor */ 96180);
/* harmony import */ var _ant_design_icons__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! @ant-design/icons */ 85699);
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
var __objRest = (source, exclude) => {
var target = {};
for (var prop in source)
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
target[prop] = source[prop];
if (source != null && __getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(source)) {
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
target[prop] = source[prop];
}
return target;
};
const AnswerTextFormItem = (_a) => {
var _b = _a, { value, onChange } = _b, props = __objRest(_b, ["value", "onChange"]);
const handleChange = (v) => {
onChange([v]);
};
return /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(
_components_markdown_editor__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z,
__spreadProps(__spreadValues({}, props), {
defaultValue: value == null ? void 0 : value[0],
onChange: handleChange
})
);
};
const test = (str) => {
if (!str) {
return false;
}
if (/^s*$/.test(str) || str.trim() === "") {
antd__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .ZP.warning("\u5173\u952E\u8BCD\u4E0D\u80FD\u5168\u4E3A\u7A7A\u683C");
return;
}
let containSpecial = new RegExp("[ `~!@#$^&*()={}':;,\\[\\].<>/?~\uFF01@#\uFFE5\u2026\u2026&*\uFF08\uFF09\u2014\u3010\u3011\u2018\uFF1B\uFF1A\u201D\u201C\u3002\uFF0C\u3001\uFF1F\u300C\u300D\u300E\u300F_\\+\\-\xB7%\u300A\u300B]|[\\\\/]");
if (str === "|") {
antd__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .ZP.warning("\u5173\u952E\u8BCD\u4E0D\u80FD\u53EA\u8F93\u5165\u4E00\u4E2A\u201C|\u201D\u5B57\u7B26\uFF01");
return false;
}
return true;
};
const KeywordTag = ({ value = [], onClose }) => {
return /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_5__["default"], { closable: true, onClose, className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.keywordTag }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement("pre", { style: { margin: "0px", whiteSpace: "pre-wrap" } }, value.join(" \u6216 ")));
};
const SubjectiveQuestionEditor = ({
questionTitlePlaceholder,
form,
showKeywords,
isMustKeyWords = showKeywords
}) => {
const [editAnalysis, setEditAnalysis] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(false);
const [keywordsInput, setKeywordsInput] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)("");
const useKeywordsValue = antd__WEBPACK_IMPORTED_MODULE_6__["default"].useWatch("use_keywords", form);
const questionScore = antd__WEBPACK_IMPORTED_MODULE_6__["default"].useWatch("question_score", form);
return /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement("div", { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.wrap }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement("div", { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.questionTitleEditorWrap }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_6__["default"].Item, { label: "\u9898\u5E72", name: "name", labelCol: { span: 24 }, rules: [{ required: true }] }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(
_MdEditorInForm__WEBPACK_IMPORTED_MODULE_2__/* .MdEditorInForm */ .h,
{
scrollId: "name",
watch: true,
height: 140,
placeholder: questionTitlePlaceholder
}
))), /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_6__["default"].Item, { label: "\u53C2\u8003\u7B54\u6848", name: "answer_texts", labelCol: { span: 24 } }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(
AnswerTextFormItem,
{
watch: true,
height: 140,
placeholder: "\u8BF7\u7F16\u8F91\u53C2\u8003\u7B54\u6848\uFF08\u975E\u5FC5\u586B\uFF09"
}
)), showKeywords && !isMustKeyWords && /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_6__["default"].Item, { hidden: true, name: "use_keywords", valuePropName: "checked" }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_7__/* ["default"] */ .Z, { defaultChecked: true })), showKeywords && isMustKeyWords && /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z, { align: "middle", className: "mb30" }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_6__["default"].Item, { name: "use_keywords", valuePropName: "checked" }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_7__/* ["default"] */ .Z, null)), /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_9__/* ["default"] */ .Z, { className: "ml10" }, "\u5F00\u542F\u5173\u952E\u8BCD\u81EA\u52A8\u5224\u5206"), /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_9__/* ["default"] */ .Z, null, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(
antd__WEBPACK_IMPORTED_MODULE_10__/* ["default"] */ .Z,
{
placement: "right",
title: "\u9009\u4E2D\u540E\uFF0C\u9700\u8981\u8BBE\u7F6E\u6BCF\u4E2A\u5173\u952E\u8BCD\u7684\u5206\u503C\uFF0C\u7CFB\u7EDF\u4F1A\u6839\u636E\u8BBE\u7F6E\u7684\u5173\u952E\u8BCD\u8FDB\u884C\u81EA\u52A8\u5224\u5206\uFF1B \u6240\u6709\u5173\u952E\u8BCD\u5206\u503C\u4E4B\u548C\u5FC5\u987B\u5C0F\u4E8E\u7B49\u4E8E\u5C0F\u9898\u5206\u503C\u3002"
},
/* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(_ant_design_icons__WEBPACK_IMPORTED_MODULE_11__/* ["default"] */ .Z, { style: { color: "#3061D0", marginLeft: 6, cursor: "pointer" } })
))), (useKeywordsValue || !isMustKeyWords) && /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_6__["default"].List, { name: "keywords", rules: [{
validator(rule, values) {
if (!isMustKeyWords) {
return Promise.resolve();
}
if (!(values == null ? void 0 : values.length)) {
return Promise.reject(new Error("\u8BF7\u8F93\u5165\u5173\u952E\u8BCD"));
}
const keywordsScoreSum = values == null ? void 0 : values.reduce((pre, cur) => pre + cur.score, 0);
if (keywordsScoreSum > parseFloat(questionScore)) {
return Promise.reject(new Error("\u6240\u6709\u5173\u952E\u8BCD\u7684\u5206\u503C\u4E4B\u548C\u5FC5\u987B\u5C0F\u4E8E\u7B49\u4E8E\u8BE5\u5C0F\u9898\u7684\u5206\u503C"));
}
return Promise.resolve();
}
}] }, (fields, { add, remove }) => /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(react__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement("div", { className: `${_index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.title} mb10` }, !isMustKeyWords ? /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement("span", { style: { color: "#9096A3" } }, "\u5224\u5206\u5173\u952E\u8BCD") : "\u5173\u952E\u8BCD"), /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z, { align: "middle", className: "font14 mb30" }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_9__/* ["default"] */ .Z, { flex: 1 }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(
antd__WEBPACK_IMPORTED_MODULE_12__["default"],
{
value: keywordsInput,
onChange: (e) => {
setKeywordsInput(e.target.value);
},
maxLength: 50,
allowClear: true,
onPressEnter: (e) => {
var _a, _b, _c, _d;
const v = `${(_a = e.target) == null ? void 0 : _a.value}`;
const keywordArr = (_c = (_b = v == null ? void 0 : v.split("|")) == null ? void 0 : _b.filter((k) => !!k)) == null ? void 0 : _c.map((item) => item == null ? void 0 : item.trim());
const currentKeywordsValue = form.getFieldValue("keywords");
const existKeywords = ((_d = currentKeywordsValue == null ? void 0 : currentKeywordsValue.map((item) => item == null ? void 0 : item.keyword)) == null ? void 0 : _d.flat()) || [];
for (const word of keywordArr) {
if (existKeywords.includes(word)) {
antd__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .ZP.error("\u4E3A\u907F\u514D\u5224\u5206\u9519\u8BEF\uFF0C\u8BF7\u52FF\u8BBE\u7F6E\u76F8\u540C\u7684\u5173\u952E\u8BCD");
return;
}
}
if (test(v)) {
add({ keyword: keywordArr, score: 1 });
setKeywordsInput("");
}
},
className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.inputBorder,
placeholder: "\u652F\u6301\u8BBE\u7F6E\u591A\u4E2A\u5173\u952E\u8BCD\uFF1B\u5E76\u5217\u5173\u952E\u8BCD\uFF08\u6216\u7684\u5173\u7CFB\uFF09\u8BF7\u7528\u201C|\u201D\u5206\u9694\u5F00"
}
)), /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_9__/* ["default"] */ .Z, { flex: "148px", style: { textAlign: "right", color: "#9096A3" } }, "\u201C\u56DE\u8F66\u952E\u201D\u4FDD\u5B58\u5173\u952E\u8BCD")), fields.map((_a) => {
var _b = _a, { key, name } = _b, restField = __objRest(_b, ["key", "name"]);
return /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z, { key, className: "mb20", style: { marginRight: 148 } }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_9__/* ["default"] */ .Z, { flex: 1 }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z, { align: "middle", justify: "space-between" }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_6__["default"].Item, __spreadProps(__spreadValues({}, restField), { name: [name, "keyword"] }), /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(KeywordTag, { onClose: () => remove(name) })), isMustKeyWords && /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_6__["default"].Item, __spreadProps(__spreadValues({}, restField), { name: [name, "score"], label: "\u5206\u503C", rules: [{ required: true }], className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.blankInputNumberWrapper }), /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_13__/* ["default"] */ .Z, { className: _index_less_modules__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z.blankInput, min: 0.1, max: 100, precision: 1, style: { width: "100%" }, placeholder: "\u8BF7\u8F93\u5165\u5173\u952E\u8BCD\u5206\u6570" })))));
}))), /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement("div", { onClick: () => setEditAnalysis(true) }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(antd__WEBPACK_IMPORTED_MODULE_6__["default"].Item, { name: "analysis", label: "\u9898\u76EE\u89E3\u6790", labelCol: { span: 24 } }, /* @__PURE__ */ react__WEBPACK_IMPORTED_MODULE_0__.createElement(_MdEditorInForm__WEBPACK_IMPORTED_MODULE_2__/* .RegularInput */ .x, { placeholder: "\u8BF7\u7F16\u8F91\u9898\u76EE\u89E3\u6790\uFF08\u975E\u5FC5\u586B\uFF09", isEdit: editAnalysis }))));
};
/***/ }),
/***/ 48685:
/*!******************************************!*\
!*** ./src/pages/MyProblem/interface.ts ***!
\******************************************/
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ h: function() { return /* binding */ ExecuteStatus; }
/* harmony export */ });
var ExecuteStatus = /* @__PURE__ */ ((ExecuteStatus2) => {
ExecuteStatus2[ExecuteStatus2["NOMATCH"] = -1] = "NOMATCH";
ExecuteStatus2[ExecuteStatus2["OK"] = 0] = "OK";
ExecuteStatus2[ExecuteStatus2["TIMEOUT"] = 2] = "TIMEOUT";
ExecuteStatus2[ExecuteStatus2["PODFAILURE"] = 3] = "PODFAILURE";
ExecuteStatus2[ExecuteStatus2["COMPILEFAILURE"] = 4] = "COMPILEFAILURE";
ExecuteStatus2[ExecuteStatus2["EXECUTEFAILURE"] = 5] = "EXECUTEFAILURE";
return ExecuteStatus2;
})(ExecuteStatus || {});
/***/ }),
/***/ 39078:
/*!****************************************!*\
!*** ./src/pages/MyProblem/service.ts ***!
\****************************************/
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ H7: function() { return /* binding */ resetCode; },
/* harmony export */ MK: function() { return /* binding */ addNotes; },
/* harmony export */ MU: function() { return /* binding */ debugCode; },
/* harmony export */ X6: function() { return /* binding */ getRecordDetail; },
/* harmony export */ bM: function() { return /* binding */ sumbitCode; },
/* harmony export */ fi: function() { return /* binding */ syncCode; },
/* harmony export */ fu: function() { return /* binding */ getProgrammingTopic; },
/* harmony export */ n4: function() { return /* binding */ updateCode; },
/* harmony export */ rX: function() { return /* binding */ getOperationResult; },
/* harmony export */ vl: function() { return /* binding */ triggerPlus; },
/* harmony export */ zO: function() { return /* binding */ getSubmitRecords; }
/* harmony export */ });
/* harmony import */ var _utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @/utils/fetch.ts */ 51165);
var __defProp = Object.defineProperty;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
function getProgrammingTopic(id, params) {
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .get */ .U2)(`myproblems/${id}.json`, __spreadValues({ hidePopLogin: true }, params || {}));
}
function sumbitCode(id, params) {
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .post */ .v_)(`myproblems/${id}/code_submit.json`, params);
}
function debugCode(id, params) {
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .post */ .v_)(`myproblems/${id}/code_debug.json`, params);
}
function getSubmitRecords(id, params) {
if (params.language) {
params.language = encodeURIComponent(params.language);
}
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .get */ .U2)(`myproblems/${id}/submit_records.json`, params);
}
function getRecordDetail(id) {
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .get */ .U2)(`myproblems/record_detail.json`, { id });
}
function getOperationResult(id, mode) {
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .get */ .U2)(`myproblems/${id}/result.json`, { mode });
}
function addNotes(id, params) {
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .post */ .v_)(`myproblems/${id}/add_notes.json`, params);
}
function resetCode(id, params) {
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .post */ .v_)(`myproblems/${id}/restore_initial_code.json`, params);
}
function syncCode(id) {
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .post */ .v_)(`myproblems/${id}/sync_code.json`);
}
function updateCode(id, params) {
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .post */ .v_)(`myproblems/${id}/update_code.json`, params);
}
function triggerPlus(id, params) {
return (0,_utils_fetch_ts__WEBPACK_IMPORTED_MODULE_0__/* .post */ .v_)(`discusses/${id}/plus.json`, params);
}
/***/ })
}]);