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.
763 lines
33 KiB
763 lines
33 KiB
"use strict";
|
|
(self["webpackChunk"] = self["webpackChunk"] || []).push([[2737],{
|
|
|
|
/***/ 63292:
|
|
/*!**********************************************************!*\
|
|
!*** ./src/components/MultiUpload/index.tsx + 3 modules ***!
|
|
\**********************************************************/
|
|
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
|
|
|
|
// EXPORTS
|
|
__webpack_require__.d(__webpack_exports__, {
|
|
z: function() { return /* binding */ coverToFileList; },
|
|
Z: function() { return /* binding */ MultiUpload; }
|
|
});
|
|
|
|
// 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/upload/index.js + 24 modules
|
|
var upload = __webpack_require__(73598);
|
|
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/message/index.js + 4 modules
|
|
var es_message = __webpack_require__(8591);
|
|
// 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/button/index.js
|
|
var es_button = __webpack_require__(3113);
|
|
// EXTERNAL MODULE: ./src/utils/env.ts + 1 modules
|
|
var env = __webpack_require__(19351);
|
|
// EXTERNAL MODULE: ./src/pages/MoopCases/FormPanel/service.ts
|
|
var service = __webpack_require__(13813);
|
|
;// CONCATENATED MODULE: ./src/components/SingleUpload/index.tsx
|
|
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;
|
|
};
|
|
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 uploadNameSizeSeperator = "\u3000\u3000";
|
|
function bytesToSize(bytes) {
|
|
var sizes = ["Bytes", "KB", "MB", "GB", "TB"];
|
|
if (bytes == 0)
|
|
return "0 Byte";
|
|
var i = parseInt("" + Math.floor(Math.log(bytes) / Math.log(1024)), 10);
|
|
return (bytes / Math.pow(1024, i)).toFixed(1) + " " + sizes[i];
|
|
}
|
|
/* harmony default export */ var SingleUpload = (({
|
|
value = [],
|
|
action,
|
|
onChange,
|
|
className,
|
|
maxSize = 150,
|
|
title = "\u6587\u4EF6\u4E0A\u4F20",
|
|
accept = null
|
|
}) => {
|
|
const uploadProps = {
|
|
multiple: false,
|
|
fileList: value,
|
|
accept,
|
|
withCredentials: true,
|
|
beforeUpload: (file) => {
|
|
const fileSize = file.size / 1024 / 1024;
|
|
if (!(fileSize < maxSize)) {
|
|
message.error(`\u8BE5\u6587\u4EF6\u65E0\u6CD5\u4E0A\u4F20\u3002\u8D85\u8FC7\u6587\u4EF6\u5927\u5C0F\u9650\u5236(${maxSize}MB),\u5EFA\u8BAE\u4E0A\u4F20\u5230\u767E\u5EA6\u4E91\u7B49\u5176\u5B83\u5171\u4EAB\u5DE5\u5177\u91CC\uFF0C\u7136\u540E\u518Dtxt\u6587\u6863\u91CC\u7ED9\u51FA\u94FE\u63A5\u4EE5\u53CA\u5171\u4EAB\u5BC6\u7801\u5E76\u4E0A\u4F20`);
|
|
return Promise.reject();
|
|
}
|
|
return true;
|
|
},
|
|
action: `${ENV.API_SERVER}/api/attachments.json`,
|
|
// ?debug=student&randomcode=undefined&client_key=6d57f8c3dd186c5ada392546ace9620a
|
|
onChange(info) {
|
|
var _a, _b, _c, _d;
|
|
let fileList = [...info.fileList];
|
|
fileList = fileList.map((file) => {
|
|
if (file.name.indexOf(uploadNameSizeSeperator) === -1) {
|
|
file.name = `${file.name}${uploadNameSizeSeperator}${bytesToSize(
|
|
file.size
|
|
)}`;
|
|
}
|
|
return __spreadValues({}, file);
|
|
});
|
|
if (info.file.status === "done" && ((_b = (_a = info.file) == null ? void 0 : _a.response) == null ? void 0 : _b.status) === -1) {
|
|
message.error((_d = (_c = info.file) == null ? void 0 : _c.response) == null ? void 0 : _d.message);
|
|
onChange([]);
|
|
return;
|
|
}
|
|
onChange(fileList);
|
|
},
|
|
onRemove: (file) => __async(void 0, null, function* () {
|
|
const fileSize = file.size / 1024 / 1024;
|
|
if (file.status === "uploading") {
|
|
return true;
|
|
}
|
|
if (!(fileSize < maxSize)) {
|
|
return true;
|
|
} else {
|
|
let id = file.response ? file.response.id : file.uid;
|
|
if (id) {
|
|
let rs = yield removeAttachment(
|
|
file.response ? file.response.id : file.id
|
|
);
|
|
return rs;
|
|
} else {
|
|
return true;
|
|
}
|
|
}
|
|
})
|
|
};
|
|
function onCancel(e) {
|
|
e.preventDefault();
|
|
e.stopPropagation();
|
|
}
|
|
return /* @__PURE__ */ React.createElement("div", { className: `single-upload ${className ? className : ""}` }, /* @__PURE__ */ React.createElement(Upload, __spreadValues({}, uploadProps), /* @__PURE__ */ React.createElement(
|
|
Button,
|
|
{
|
|
type: "primary",
|
|
title: value.length > 0 ? "\u6BCF\u6B21\u53EA\u80FD\u4E0A\u4F20\u4E00\u4E2A\u8D44\u6E90\uFF0C \u5220\u9664\u4E0B\u9762\u8D44\u6E90\u53EF\u91CD\u65B0\u4E0A\u4F20 " : "",
|
|
disabled: value.length > 0,
|
|
ghost: true
|
|
},
|
|
title
|
|
), /* @__PURE__ */ React.createElement("span", { onClick: onCancel, style: { marginLeft: 10 } }, "(\u5355\u4E2A\u6587\u4EF6\u6700\u5927", maxSize, "M)", " ")));
|
|
});
|
|
|
|
// EXTERNAL MODULE: ./node_modules/_@ant-design_icons@5.3.1@@ant-design/icons/es/icons/InboxOutlined.js + 1 modules
|
|
var InboxOutlined = __webpack_require__(84263);
|
|
// EXTERNAL MODULE: ./node_modules/_lodash@4.17.21@lodash/lodash.js
|
|
var lodash = __webpack_require__(89392);
|
|
;// CONCATENATED MODULE: ./src/components/MultiUpload/index.less
|
|
// extracted by mini-css-extract-plugin
|
|
|
|
;// CONCATENATED MODULE: ./src/assets/images/uploadImg.svg
|
|
var uploadImg_defProp = Object.defineProperty;
|
|
var uploadImg_getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
var uploadImg_hasOwnProp = Object.prototype.hasOwnProperty;
|
|
var uploadImg_propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
var uploadImg_defNormalProp = (obj, key, value) => key in obj ? uploadImg_defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
var uploadImg_spreadValues = (a, b) => {
|
|
for (var prop in b || (b = {}))
|
|
if (uploadImg_hasOwnProp.call(b, prop))
|
|
uploadImg_defNormalProp(a, prop, b[prop]);
|
|
if (uploadImg_getOwnPropSymbols)
|
|
for (var prop of uploadImg_getOwnPropSymbols(b)) {
|
|
if (uploadImg_propIsEnum.call(b, prop))
|
|
uploadImg_defNormalProp(a, prop, b[prop]);
|
|
}
|
|
return a;
|
|
};
|
|
|
|
const SvgUploadImg = (props) => /* @__PURE__ */ React.createElement("svg", uploadImg_spreadValues({ width: 14, height: 14, xmlns: "http://www.w3.org/2000/svg" }, props), /* @__PURE__ */ React.createElement("title", null, "\u5F62\u72B6"), /* @__PURE__ */ React.createElement("path", { d: "M10.354 3.5h-2.77v8.167H6.416V3.5H3.646L7 0l3.354 3.5ZM14 7h-1.167v5.833H1.167V7H0v7h14V7Z", fill: "#3061D0", fillRule: "nonzero" }));
|
|
|
|
/* harmony default export */ var uploadImg = ("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTQiIGhlaWdodD0iMTQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTEwLjM1NCAzLjVoLTIuNzd2OC4xNjdINi40MTZWMy41SDMuNjQ2TDcgMGwzLjM1NCAzLjVaTTE0IDdoLTEuMTY3djUuODMzSDEuMTY3VjdIMHY3aDE0VjdaIiBmaWxsPSIjMzA2MUQwIiBmaWxsLXJ1bGU9Im5vbnplcm8iLz48L3N2Zz4=");
|
|
|
|
;// CONCATENATED MODULE: ./src/components/MultiUpload/index.tsx
|
|
var MultiUpload_defProp = Object.defineProperty;
|
|
var MultiUpload_getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
var MultiUpload_hasOwnProp = Object.prototype.hasOwnProperty;
|
|
var MultiUpload_propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
var MultiUpload_defNormalProp = (obj, key, value) => key in obj ? MultiUpload_defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
var MultiUpload_spreadValues = (a, b) => {
|
|
for (var prop in b || (b = {}))
|
|
if (MultiUpload_hasOwnProp.call(b, prop))
|
|
MultiUpload_defNormalProp(a, prop, b[prop]);
|
|
if (MultiUpload_getOwnPropSymbols)
|
|
for (var prop of MultiUpload_getOwnPropSymbols(b)) {
|
|
if (MultiUpload_propIsEnum.call(b, prop))
|
|
MultiUpload_defNormalProp(a, prop, b[prop]);
|
|
}
|
|
return a;
|
|
};
|
|
var MultiUpload_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 { Dragger } = upload["default"];
|
|
function coverToFileList(data) {
|
|
let rs = [];
|
|
if (data && data.length > 0) {
|
|
rs = data.map((item) => {
|
|
return {
|
|
uid: item.id,
|
|
id: item.id,
|
|
name: item.title + uploadNameSizeSeperator + item.filesize,
|
|
url: item.url,
|
|
filesize: item.filesize,
|
|
status: "done",
|
|
response: { id: item.id }
|
|
};
|
|
});
|
|
}
|
|
return rs;
|
|
}
|
|
/* harmony default export */ var MultiUpload = (({
|
|
value,
|
|
onChange,
|
|
action,
|
|
data,
|
|
className,
|
|
maxSize = 150,
|
|
title = "\u4E0A\u4F20\u9644\u4EF6",
|
|
showRemoveModal = false,
|
|
accept = "",
|
|
additionalText,
|
|
isDragger,
|
|
number = 1e3,
|
|
aloneClear = false
|
|
}) => {
|
|
const [disabled, setDisabled] = (0,_react_17_0_2_react.useState)(false);
|
|
let [fileList, setFileList] = (0,_react_17_0_2_react.useState)(value || []);
|
|
let [nums, setnums] = (0,_react_17_0_2_react.useState)(1);
|
|
(0,_react_17_0_2_react.useEffect)(() => {
|
|
if (value) {
|
|
if (nums === 1) {
|
|
setFileList([...value]);
|
|
}
|
|
setnums(2);
|
|
if (number === (value == null ? void 0 : value.length)) {
|
|
setDisabled(true);
|
|
}
|
|
}
|
|
}, [value]);
|
|
const clearLastFile = () => {
|
|
setTimeout(() => {
|
|
fileList.pop();
|
|
setFileList([...fileList]);
|
|
}, 500);
|
|
};
|
|
const uploadProps = {
|
|
multiple: true,
|
|
disabled,
|
|
accept,
|
|
withCredentials: true,
|
|
fileList,
|
|
// fileList: fileList?.length ? fileList : value,
|
|
beforeUpload: (file, fileArr) => {
|
|
const fileSize = file.size / 1024 / 1024;
|
|
if (fileList.concat(fileArr).length > number) {
|
|
fileList.pop();
|
|
setFileList([...fileList]);
|
|
es_message/* default */.ZP.error(`\u6700\u591A\u53EA\u80FD\u4E0A\u4F20${number}\u4E2A\u6587\u4EF6`);
|
|
if (aloneClear) {
|
|
return Promise.reject();
|
|
}
|
|
clearLastFile();
|
|
return false;
|
|
}
|
|
if (!(fileSize < maxSize)) {
|
|
es_message/* default */.ZP.error(`\u8BE5\u6587\u4EF6\u65E0\u6CD5\u4E0A\u4F20\u3002\u8D85\u8FC7\u6587\u4EF6\u5927\u5C0F\u9650\u5236(${maxSize}MB).`);
|
|
if (aloneClear) {
|
|
return Promise.reject();
|
|
}
|
|
clearLastFile();
|
|
return false;
|
|
}
|
|
return true;
|
|
},
|
|
data,
|
|
action: action || `${env/* default */.Z.API_SERVER}/api/attachments.json`,
|
|
// ?debug=student&randomcode=undefined&client_key=6d57f8c3dd186c5ada392546ace9620a
|
|
onChange(info) {
|
|
var _a, _b, _c, _d;
|
|
if (info.file.status === "removed") {
|
|
fileList = info.fileList;
|
|
} else {
|
|
fileList = (0,lodash.uniqBy)([...info.fileList, ...fileList], "uid");
|
|
}
|
|
if (info.file.status === "done" && ((_b = (_a = info.file) == null ? void 0 : _a.response) == null ? void 0 : _b.status) === -1) {
|
|
es_message/* default */.ZP.error((_d = (_c = info.file) == null ? void 0 : _c.response) == null ? void 0 : _d.message);
|
|
return;
|
|
}
|
|
if (fileList.length >= number)
|
|
setDisabled(true);
|
|
else
|
|
setDisabled(false);
|
|
setFileList([...fileList]);
|
|
fileList = fileList.map((file) => {
|
|
var _a2, _b2;
|
|
if ((_a2 = file == null ? void 0 : file.response) == null ? void 0 : _a2.id) {
|
|
file.url = `/api/attachments/${(_b2 = file == null ? void 0 : file.response) == null ? void 0 : _b2.id}`;
|
|
}
|
|
if (file.name.indexOf(uploadNameSizeSeperator) === -1) {
|
|
file.name = `${file.name}${uploadNameSizeSeperator}${bytesToSize(
|
|
file.size
|
|
)}`;
|
|
}
|
|
return MultiUpload_spreadValues({}, file);
|
|
});
|
|
console.log("info:", info, fileList);
|
|
onChange(fileList);
|
|
},
|
|
onRemove: (file) => MultiUpload_async(void 0, null, function* () {
|
|
const remove = () => MultiUpload_async(void 0, null, function* () {
|
|
let id = file.response ? file.response.id : file.id;
|
|
if (id) {
|
|
let rs = yield (0,service/* removeAttachment */.JZ)(
|
|
file.response ? file.response.id : file.uid
|
|
);
|
|
return Promise.resolve(rs);
|
|
} else {
|
|
return true;
|
|
}
|
|
});
|
|
if (showRemoveModal) {
|
|
return new Promise((resolve, reject) => {
|
|
modal["default"].confirm({
|
|
centered: true,
|
|
width: 530,
|
|
okText: "\u786E\u5B9A",
|
|
cancelText: "\u53D6\u6D88",
|
|
title: "\u63D0\u793A",
|
|
content: /* @__PURE__ */ _react_17_0_2_react.createElement("div", { className: "tc font16" }, "\u662F\u5426\u786E\u8BA4\u5220\u9664?"),
|
|
onOk: () => MultiUpload_async(void 0, null, function* () {
|
|
const res = yield remove();
|
|
es_message/* default */.ZP.success("\u5220\u9664\u6210\u529F");
|
|
resolve(true);
|
|
}),
|
|
onCancel: () => {
|
|
return resolve(false);
|
|
}
|
|
});
|
|
});
|
|
} else {
|
|
return yield remove();
|
|
}
|
|
})
|
|
};
|
|
function onCancel(e) {
|
|
e.preventDefault();
|
|
e.stopPropagation();
|
|
}
|
|
return /* @__PURE__ */ _react_17_0_2_react.createElement("div", { className: `multi-upload ${className ? className : ""}` }, isDragger && /* @__PURE__ */ _react_17_0_2_react.createElement(Dragger, MultiUpload_spreadValues({}, uploadProps), /* @__PURE__ */ _react_17_0_2_react.createElement("p", { className: "ant-upload-drag-icon" }, /* @__PURE__ */ _react_17_0_2_react.createElement(InboxOutlined/* default */.Z, null)), /* @__PURE__ */ _react_17_0_2_react.createElement("p", { className: "ant-upload-text" }, "\u70B9\u51FB\u4E0A\u4F20\u56FE\u6807\uFF0C\u9009\u62E9\u8981\u4E0A\u4F20\u7684\u6587\u4EF6\u6216\u5C06\u6587\u4EF6\u62D6\u62FD\u5230\u6B64", /* @__PURE__ */ _react_17_0_2_react.createElement("br", null), "(\u5355\u4E2A\u6587\u4EF6\u6700\u5927\u9650\u5236\u4E3A", maxSize, "MB)", " "), additionalText), !isDragger && /* @__PURE__ */ _react_17_0_2_react.createElement(upload["default"], MultiUpload_spreadValues({}, uploadProps), /* @__PURE__ */ _react_17_0_2_react.createElement(es_button/* default */.ZP, { disabled, className: "upload_button" }, /* @__PURE__ */ _react_17_0_2_react.createElement("img", { className: "aBtn_img", src: uploadImg }), title), /* @__PURE__ */ _react_17_0_2_react.createElement("span", { onClick: onCancel, className: "upload_text" }, "(\u5355\u4E2A\u6587\u4EF6\u6700\u5927", maxSize, "MB)", " ")));
|
|
});
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 52198:
|
|
/*!*********************************************************************************************************!*\
|
|
!*** ./src/pages/Classrooms/Lists/CommonHomework/components/SearchSortController/index.tsx + 1 modules ***!
|
|
\*********************************************************************************************************/
|
|
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
|
|
|
|
// EXPORTS
|
|
__webpack_require__.d(__webpack_exports__, {
|
|
Z: function() { return /* binding */ components_SearchSortController; }
|
|
});
|
|
|
|
// 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/dropdown/index.js + 1 modules
|
|
var dropdown = __webpack_require__(38854);
|
|
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/menu/index.js + 11 modules
|
|
var menu = __webpack_require__(20834);
|
|
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/tooltip/index.js + 3 modules
|
|
var tooltip = __webpack_require__(6848);
|
|
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/input/index.js + 5 modules
|
|
var input = __webpack_require__(20008);
|
|
;// CONCATENATED MODULE: ./src/pages/Classrooms/Lists/CommonHomework/components/SearchSortController/index.less?modules
|
|
// extracted by mini-css-extract-plugin
|
|
/* harmony default export */ var SearchSortControllermodules = ({"searchSortControllerContainer":"searchSortControllerContainer___AAq4n","btn":"btn___bMc0x","btnSort":"btnSort___vBpNG","tips":"tips___egWVQ"});
|
|
;// CONCATENATED MODULE: ./src/pages/Classrooms/Lists/CommonHomework/components/SearchSortController/index.tsx
|
|
|
|
|
|
|
|
const SearchSortController = ({
|
|
isAdmin,
|
|
dataSource,
|
|
batchStatus,
|
|
SortMenuName,
|
|
setSortMenuName,
|
|
onSearch,
|
|
onSort,
|
|
onBatch
|
|
}) => {
|
|
const SortMenus = isAdmin ? [
|
|
{ name: "\u9ED8\u8BA4\u6392\u5E8F", type: "position", direction: "desc" },
|
|
{ name: "\u521B\u5EFA\u65F6\u95F4\u5347\u5E8F", type: "created_at", direction: "asc" },
|
|
{ name: "\u521B\u5EFA\u65F6\u95F4\u964D\u5E8F", type: "created_at", direction: "desc" },
|
|
{ name: "\u66F4\u65B0\u65F6\u95F4\u5347\u5E8F", type: "updated_at", direction: "asc" },
|
|
{ name: "\u66F4\u65B0\u65F6\u95F4\u964D\u5E8F", type: "updated_at", direction: "desc" },
|
|
{ name: "\u4F5C\u4E1A\u540D\u79F0\u5347\u5E8F", type: "name_pinyin", direction: "asc" },
|
|
{ name: "\u4F5C\u4E1A\u540D\u79F0\u964D\u5E8F", type: "name_pinyin", direction: "desc" }
|
|
] : [
|
|
{ name: "\u9ED8\u8BA4\u6392\u5E8F", type: "position", direction: "desc" },
|
|
{ name: "\u6309\u53D1\u5E03\u65F6\u95F4\u5347\u5E8F", type: "created_at", direction: "asc" },
|
|
{ name: "\u6309\u53D1\u5E03\u65F6\u95F4\u964D\u5E8F", type: "created_at", direction: "desc" },
|
|
{ name: "\u6309\u622A\u6B62\u65F6\u95F4\u5347\u5E8F", type: "updated_at", direction: "asc" },
|
|
{ name: "\u6309\u622A\u6B62\u65F6\u95F4\u964D\u5E8F", type: "updated_at", direction: "desc" },
|
|
{ name: "\u4F5C\u4E1A\u540D\u79F0\u5347\u5E8F", type: "name_pinyin", direction: "asc" },
|
|
{ name: "\u4F5C\u4E1A\u540D\u79F0\u964D\u5E8F", type: "name_pinyin", direction: "desc" }
|
|
];
|
|
const sortClick = (data) => {
|
|
setSortMenuName(data.name);
|
|
onSort(data);
|
|
};
|
|
const isDefault = SortMenuName === "\u9ED8\u8BA4\u6392\u5E8F";
|
|
return /* @__PURE__ */ _react_17_0_2_react.createElement("div", { className: SearchSortControllermodules.searchSortControllerContainer }, /* @__PURE__ */ _react_17_0_2_react.createElement("div", null, /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
dropdown/* default */.Z,
|
|
{
|
|
dropdownRender: () => /* @__PURE__ */ _react_17_0_2_react.createElement(menu["default"], { selectedKeys: [SortMenuName] }, SortMenus.map((item) => {
|
|
return /* @__PURE__ */ _react_17_0_2_react.createElement(menu["default"].Item, { key: item.name, onClick: () => sortClick(item) }, item.name);
|
|
}))
|
|
},
|
|
/* @__PURE__ */ _react_17_0_2_react.createElement("div", null, /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
"span",
|
|
{
|
|
className: `${SearchSortControllermodules.btn} ${isDefault ? SearchSortControllermodules.btnSort : ""}`
|
|
},
|
|
/* @__PURE__ */ _react_17_0_2_react.createElement("i", { className: "iconfont icon-paixu font14 mr5" }),
|
|
SortMenuName
|
|
))
|
|
)), isDefault && /* @__PURE__ */ _react_17_0_2_react.createElement(tooltip/* default */.Z, { title: "\u4F18\u5148\u6309\u7167\u8C03\u6574\u6392\u5E8F\u7ED3\u679C\u5C55\u793A\uFF0C\u672A\u8BBE\u7F6E\u6392\u5E8F\u65F6\uFF0C\u6309\u7167\u521B\u5EFA\u65F6\u95F4\u964D\u5E8F\u6392\u5217" }, /* @__PURE__ */ _react_17_0_2_react.createElement("span", { className: SearchSortControllermodules.tips }, /* @__PURE__ */ _react_17_0_2_react.createElement("i", { className: "iconfont icon-a-wenhaobeifen2" }))), /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
input["default"].Search,
|
|
{
|
|
allowClear: true,
|
|
placeholder: "\u8BF7\u8F93\u5165\u540D\u79F0\u8FDB\u884C\u641C\u7D22",
|
|
onSearch: (e) => onSearch(e.trim()),
|
|
style: { width: 220, marginLeft: "auto" }
|
|
}
|
|
));
|
|
};
|
|
/* harmony default export */ var components_SearchSortController = (SearchSortController);
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 78492:
|
|
/*!****************************************************************************************************!*\
|
|
!*** ./src/pages/Classrooms/Lists/CommonHomework/components/SortShixunPanel/index.tsx + 1 modules ***!
|
|
\****************************************************************************************************/
|
|
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
|
|
|
|
// EXPORTS
|
|
__webpack_require__.d(__webpack_exports__, {
|
|
Z: function() { return /* binding */ SortShixunPanel; }
|
|
});
|
|
|
|
// EXTERNAL MODULE: ./node_modules/_react@17.0.2@react/index.js
|
|
var _react_17_0_2_react = __webpack_require__(59301);
|
|
// EXTERNAL MODULE: ./node_modules/_react-sortable-hoc@1.11.0@react-sortable-hoc/dist/react-sortable-hoc.esm.js
|
|
var react_sortable_hoc_esm = __webpack_require__(44589);
|
|
// EXTERNAL MODULE: ./node_modules/_array-move@3.0.1@array-move/index.js
|
|
var _array_move_3_0_1_array_move = __webpack_require__(39180);
|
|
var _array_move_3_0_1_array_move_default = /*#__PURE__*/__webpack_require__.n(_array_move_3_0_1_array_move);
|
|
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/drawer/index.js + 9 modules
|
|
var drawer = __webpack_require__(43428);
|
|
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/button/index.js
|
|
var es_button = __webpack_require__(3113);
|
|
;// CONCATENATED MODULE: ./src/pages/Classrooms/Lists/CommonHomework/components/SortShixunPanel/index.less
|
|
// extracted by mini-css-extract-plugin
|
|
|
|
;// CONCATENATED MODULE: ./src/pages/Classrooms/Lists/CommonHomework/components/SortShixunPanel/index.tsx
|
|
|
|
|
|
|
|
|
|
|
|
const SortableItem = (0,react_sortable_hoc_esm/* SortableElement */.W8)(({ item }) => /* @__PURE__ */ _react_17_0_2_react.createElement("li", null, /* @__PURE__ */ _react_17_0_2_react.createElement("h3", null, item.task_name), /* @__PURE__ */ _react_17_0_2_react.createElement("p", null, item.user_name, /* @__PURE__ */ _react_17_0_2_react.createElement("span", { style: { marginLeft: "20px" } }, item.category))));
|
|
const SortableList = (0,react_sortable_hoc_esm/* SortableContainer */.JN)(({ items }) => {
|
|
return /* @__PURE__ */ _react_17_0_2_react.createElement("ul", { className: "task-list-container" }, items.map((value, index) => /* @__PURE__ */ _react_17_0_2_react.createElement(SortableItem, { key: `${value.task_id}`, index, item: value })));
|
|
});
|
|
/* harmony default export */ var SortShixunPanel = (({ data, callback, onCancel, visible = false }) => {
|
|
const [values, setValues] = (0,_react_17_0_2_react.useState)(data);
|
|
function onSave() {
|
|
callback(values.map((item) => item.task_id));
|
|
}
|
|
function onSortEnd(info) {
|
|
const { newIndex, oldIndex } = info;
|
|
setValues(_array_move_3_0_1_array_move_default()(values, oldIndex, newIndex));
|
|
}
|
|
(0,_react_17_0_2_react.useEffect)(() => {
|
|
setValues(data);
|
|
}, [JSON.stringify(data)]);
|
|
return /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
drawer/* default */.Z,
|
|
{
|
|
placement: "bottom",
|
|
height: "100%",
|
|
closable: true,
|
|
onClose: onCancel,
|
|
style: { zIndex: 9999 },
|
|
open: visible,
|
|
rootClassName: "sort-list-panel"
|
|
},
|
|
/* @__PURE__ */ _react_17_0_2_react.createElement("p", { className: "sort-list-tip" }, /* @__PURE__ */ _react_17_0_2_react.createElement("span", null, "\u6E29\u99A8\u63D0\u793A\uFF1A\u8BF7\u5728\u5217\u8868\u4E2D\u957F\u6309\u9F20\u6807\u5DE6\u952E\uFF0C\u8FDB\u884C\u62D6\u653E\u6392\u5E8F\u3002\u5B8C\u6210\u6392\u5E8F\u540E\u8BF7\u70B9\u51FB\u201C\u4FDD\u5B58\u201D"), /* @__PURE__ */ _react_17_0_2_react.createElement(es_button/* default */.ZP, { type: "ghost", onClick: onCancel, style: { marginRight: 10 } }, "\u53D6\u6D88"), /* @__PURE__ */ _react_17_0_2_react.createElement(es_button/* default */.ZP, { disabled: values.length === 0, type: "primary", onClick: onSave }, "\u4FDD\u5B58")),
|
|
/* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
SortableList,
|
|
{
|
|
axis: "xy",
|
|
helperClass: "dragging-li",
|
|
items: values,
|
|
onSortEnd
|
|
}
|
|
)
|
|
);
|
|
});
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 93695:
|
|
/*!********************************************************************************************!*\
|
|
!*** ./src/pages/Classrooms/Lists/CommonHomework/components/TabMenu/index.tsx + 1 modules ***!
|
|
\********************************************************************************************/
|
|
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
|
|
|
|
// EXPORTS
|
|
__webpack_require__.d(__webpack_exports__, {
|
|
Z: function() { return /* binding */ components_TabMenu; }
|
|
});
|
|
|
|
// 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/menu/index.js + 11 modules
|
|
var menu = __webpack_require__(20834);
|
|
// 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/dropdown/index.js + 1 modules
|
|
var dropdown = __webpack_require__(38854);
|
|
// EXTERNAL MODULE: ./node_modules/_antd@5.9.0@antd/es/tooltip/index.js + 3 modules
|
|
var tooltip = __webpack_require__(6848);
|
|
;// CONCATENATED MODULE: ./src/pages/Classrooms/Lists/CommonHomework/components/TabMenu/index.less?modules
|
|
// extracted by mini-css-extract-plugin
|
|
/* harmony default export */ var TabMenumodules = ({"tabMenuContainer":"tabMenuContainer___xbZhu","control":"control___tg7XY","iconH":"iconH___CDXCm","selectBtn":"selectBtn___Da4jv"});
|
|
// EXTERNAL MODULE: ./src/.umi-production/exports.ts + 15 modules
|
|
var _umi_production_exports = __webpack_require__(23852);
|
|
// EXTERNAL MODULE: ./src/utils/authority.ts
|
|
var authority = __webpack_require__(77883);
|
|
;// CONCATENATED MODULE: ./src/pages/Classrooms/Lists/CommonHomework/components/TabMenu/index.tsx
|
|
|
|
|
|
|
|
|
|
|
|
const TabMenu = ({
|
|
isLoading,
|
|
addText,
|
|
tabDataSource,
|
|
isAdmin,
|
|
dispatch,
|
|
type,
|
|
exportType,
|
|
TooltipTitle,
|
|
categoryId,
|
|
dropdownMenu,
|
|
isShowRightControl,
|
|
defaultSelectedKeys,
|
|
classroomList,
|
|
onTabMenuClick,
|
|
onTooltipTitleClick,
|
|
onDropdownMenuClick,
|
|
onsetClick
|
|
}) => {
|
|
var _a;
|
|
const getDropdownMenu = () => {
|
|
return /* @__PURE__ */ _react_17_0_2_react.createElement(menu["default"], { onClick: ({ key }) => {
|
|
onDropdownMenuClick(key);
|
|
} }, dropdownMenu.map((item) => /* @__PURE__ */ _react_17_0_2_react.createElement(menu["default"].Item, { key: item.id }, item.name)));
|
|
};
|
|
const params = (0,_umi_production_exports.useParams)();
|
|
return /* @__PURE__ */ _react_17_0_2_react.createElement("div", { className: TabMenumodules.tabMenuContainer }, /* @__PURE__ */ _react_17_0_2_react.createElement(row/* default */.Z, null, /* @__PURE__ */ _react_17_0_2_react.createElement(col/* default */.Z, { flex: "1" }, /* @__PURE__ */ _react_17_0_2_react.createElement(menu["default"], { mode: "horizontal", selectedKeys: defaultSelectedKeys }, tabDataSource.map((item) => /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
menu["default"].Item,
|
|
{
|
|
key: item.id,
|
|
onClick: () => !isLoading ? onTabMenuClick(item) : {}
|
|
},
|
|
/* @__PURE__ */ _react_17_0_2_react.createElement("span", { className: `c-grey-666 ${isAdmin ? "mr20" : ""}` }, item.name),
|
|
item.total !== void 0 && /* @__PURE__ */ _react_17_0_2_react.createElement("span", { className: "c-grey-999" }, item.total || 0)
|
|
)))), isAdmin && isShowRightControl && /* @__PURE__ */ _react_17_0_2_react.createElement(col/* default */.Z, { className: "mr20 gutter-row", style: { display: "flex", alignItems: "center", color: "#0152d9", paddingBottom: 3 } }, /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
dropdown/* default */.Z,
|
|
{
|
|
className: "mr10",
|
|
placement: "bottom",
|
|
arrow: true,
|
|
dropdownRender: () => /* @__PURE__ */ _react_17_0_2_react.createElement(menu["default"], null, /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
menu["default"].Item,
|
|
{
|
|
key: 1,
|
|
onClick: () => {
|
|
dispatch({
|
|
type: "classroomList/setActionTabs",
|
|
payload: {
|
|
key: "\u5BFC\u51FA\u6210\u7EE9",
|
|
type,
|
|
exportType,
|
|
category_id: params.categoryId
|
|
}
|
|
});
|
|
}
|
|
},
|
|
"\u5B66\u751F\u6210\u7EE9"
|
|
), /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
menu["default"].Item,
|
|
{
|
|
key: 3,
|
|
onClick: () => {
|
|
_umi_production_exports.history.push(`/classrooms/${params == null ? void 0 : params.coursesId}/exportlist/shixun_work_list`);
|
|
}
|
|
},
|
|
"\u5386\u53F2\u5BFC\u51FA"
|
|
))
|
|
},
|
|
/* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
"div",
|
|
{
|
|
className: "c-blue font16 ml20 current",
|
|
style: { marginTop: 2 }
|
|
},
|
|
/* @__PURE__ */ _react_17_0_2_react.createElement("span", { style: { color: "#666666", cursor: "pointer" } }, /* @__PURE__ */ _react_17_0_2_react.createElement("i", { className: "iconfont icon-xiazai6" }))
|
|
)
|
|
), (0,authority/* isAssistant */.Rm)() && !((_a = classroomList.AssistantObject.normal) == null ? void 0 : _a.can_create) ? "" : /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
"span",
|
|
{
|
|
className: "c-grey-666",
|
|
style: { marginLeft: 8, cursor: "pointer", marginTop: "3px" },
|
|
onClick: onsetClick
|
|
},
|
|
/* @__PURE__ */ _react_17_0_2_react.createElement("i", { className: "iconfont icon-shezhi6 font16 mr5" })
|
|
), /* @__PURE__ */ _react_17_0_2_react.createElement("div", { className: TabMenumodules.control }, /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
"div",
|
|
{
|
|
className: "c-blue font16 ml20 current",
|
|
style: { marginTop: 2 },
|
|
onClick: onTooltipTitleClick
|
|
},
|
|
/* @__PURE__ */ _react_17_0_2_react.createElement(tooltip/* default */.Z, { title: TooltipTitle }, /* @__PURE__ */ _react_17_0_2_react.createElement(
|
|
"span",
|
|
{
|
|
className: !categoryId ? `${TabMenumodules.iconH} iconfont icon-xinjianmulu1` : `${TabMenumodules.iconH} iconfont icon-zhongmingmingmulu`
|
|
}
|
|
))
|
|
), /* @__PURE__ */ _react_17_0_2_react.createElement(dropdown/* default */.Z, { className: "ml10", dropdownRender: getDropdownMenu }, /* @__PURE__ */ _react_17_0_2_react.createElement("span", { className: TabMenumodules.selectBtn }, /* @__PURE__ */ _react_17_0_2_react.createElement("span", null, /* @__PURE__ */ _react_17_0_2_react.createElement("i", { className: "iconfont icon-tianjiadaohang" })), /* @__PURE__ */ _react_17_0_2_react.createElement("span", null, addText ? addText : "\u65B0\u5EFA\u4F5C\u4E1A")))))));
|
|
};
|
|
/* harmony default export */ var components_TabMenu = ((0,_umi_production_exports.connect)(({
|
|
classroomList
|
|
}) => ({
|
|
classroomList
|
|
}))(TabMenu));
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 13813:
|
|
/*!**************************************************!*\
|
|
!*** ./src/pages/MoopCases/FormPanel/service.ts ***!
|
|
\**************************************************/
|
|
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
|
|
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
/* harmony export */ $J: function() { return /* binding */ getMoopCase; },
|
|
/* harmony export */ JZ: function() { return /* binding */ removeAttachment; },
|
|
/* harmony export */ bN: function() { return /* binding */ updateMoopCase; },
|
|
/* harmony export */ jP: function() { return /* binding */ addMoopCase; },
|
|
/* harmony export */ rO: function() { return /* binding */ getLibraryTags; }
|
|
/* harmony export */ });
|
|
/* harmony import */ var _utils_fetch__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @/utils/fetch */ 64841);
|
|
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());
|
|
});
|
|
};
|
|
|
|
function getMoopCase(id) {
|
|
return (0,_utils_fetch__WEBPACK_IMPORTED_MODULE_0__/* .get */ .U2)(`libraries/${id}.json`);
|
|
}
|
|
function getLibraryTags() {
|
|
return (0,_utils_fetch__WEBPACK_IMPORTED_MODULE_0__/* .get */ .U2)("library_tags.json");
|
|
}
|
|
function removeAttachment(id) {
|
|
return __async(this, null, function* () {
|
|
const response = yield (0,_utils_fetch__WEBPACK_IMPORTED_MODULE_0__/* .del */ .IV)(`attachments/${id}.json`);
|
|
return response.status === 0;
|
|
});
|
|
}
|
|
function addMoopCase(params) {
|
|
return (0,_utils_fetch__WEBPACK_IMPORTED_MODULE_0__/* .post */ .v_)(`libraries.json`, params);
|
|
}
|
|
function updateMoopCase(id, params) {
|
|
return (0,_utils_fetch__WEBPACK_IMPORTED_MODULE_0__/* .put */ .gz)(`libraries/${id}.json`, params);
|
|
}
|
|
|
|
|
|
/***/ })
|
|
|
|
}]); |