2024-10-22 17:24:02 +08:00
|
|
|
|
"use client";
|
|
|
|
|
|
|
|
|
|
import React, { useState, useRef, useMemo, Fragment } from "react";
|
2024-11-01 15:46:26 +08:00
|
|
|
|
import {
|
|
|
|
|
Switch,
|
|
|
|
|
Space,
|
|
|
|
|
Checkbox,
|
|
|
|
|
Button,
|
|
|
|
|
Toast,
|
|
|
|
|
TextArea,
|
2025-03-27 17:25:42 +08:00
|
|
|
|
Form,
|
2024-11-01 15:46:26 +08:00
|
|
|
|
} from "antd-mobile";
|
2024-10-22 17:24:02 +08:00
|
|
|
|
import { useRouter, useSearchParams } from "next/navigation";
|
|
|
|
|
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
|
|
|
|
|
import { faAngleLeft } from "@fortawesome/free-solid-svg-icons";
|
|
|
|
|
import OwnInput from "@/components/OwnInput";
|
|
|
|
|
import requireAPI from "@/utils/requireAPI";
|
2024-10-24 21:28:49 +08:00
|
|
|
|
|
|
|
|
|
// getStreamerInfo
|
|
|
|
|
|
2024-10-22 17:24:02 +08:00
|
|
|
|
const superSingles = [
|
|
|
|
|
{ key: 0, text: "永久" },
|
2024-11-05 17:59:29 +08:00
|
|
|
|
{ key: 1, text: "按月生效" },
|
|
|
|
|
{ key: 2, text: "按季度生效" },
|
|
|
|
|
{ key: 3, text: "按半年生效" },
|
|
|
|
|
{ key: 4, text: "按年生效" },
|
2024-10-22 17:24:02 +08:00
|
|
|
|
];
|
2024-11-05 17:59:29 +08:00
|
|
|
|
// const superSingles = [
|
|
|
|
|
// { key: 0, text: "永久" },
|
|
|
|
|
// { key: 1, text: "按年生效" },
|
|
|
|
|
// { key: 2, text: "按半年生效" },
|
|
|
|
|
// { key: 3, text: "按季度生效" },
|
|
|
|
|
// { key: 4, text: "按月生效" },
|
|
|
|
|
// ];
|
2024-10-22 17:24:02 +08:00
|
|
|
|
const ListItemWithCheckbox = ({
|
|
|
|
|
superSingle,
|
2025-03-27 17:25:42 +08:00
|
|
|
|
superSinglesContr,
|
|
|
|
|
setSuperSinglesContr,
|
2024-10-22 17:24:02 +08:00
|
|
|
|
superSingleCheckeds,
|
2025-03-27 17:25:42 +08:00
|
|
|
|
index,
|
2024-10-22 17:24:02 +08:00
|
|
|
|
}) => {
|
|
|
|
|
return (
|
2024-11-05 19:43:11 +08:00
|
|
|
|
<li className="mt-4" onClick={() => {}}>
|
2024-10-22 17:24:02 +08:00
|
|
|
|
<div onClick={(e) => e.stopPropagation()}>
|
2025-03-14 18:43:22 +08:00
|
|
|
|
{/* <Radio
|
2024-11-01 15:46:26 +08:00
|
|
|
|
value={superSingle.key}
|
|
|
|
|
onChange={(value) => {
|
|
|
|
|
const newFormData = { ...formData };
|
|
|
|
|
newFormData.superSingle.forEach((el) => {
|
|
|
|
|
el.enable = 0;
|
|
|
|
|
});
|
|
|
|
|
newFormData.superSingle[superSingle.key].enable = value;
|
|
|
|
|
// newFormData.superSingle[superSingle.key].price = 0;
|
|
|
|
|
// newFormData.superSingle[superSingle.key].wechatFree = false;
|
|
|
|
|
setFormData(newFormData);
|
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
{superSingle.text}
|
2025-03-14 18:43:22 +08:00
|
|
|
|
</Radio> */}
|
|
|
|
|
<Checkbox
|
2025-03-27 17:25:42 +08:00
|
|
|
|
value={index}
|
2024-10-22 17:24:02 +08:00
|
|
|
|
onChange={(value) => {
|
2025-03-27 17:25:42 +08:00
|
|
|
|
const newSuperSinglesContr = [...superSinglesContr];
|
|
|
|
|
newSuperSinglesContr[index].enable = value;
|
|
|
|
|
// newSuperSinglesContr[index].price = 0;
|
|
|
|
|
// newSuperSinglesContr[index].wechatFree = false;
|
|
|
|
|
setSuperSinglesContr(newSuperSinglesContr);
|
2024-10-22 17:24:02 +08:00
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
{superSingle.text}
|
2025-03-14 18:43:22 +08:00
|
|
|
|
</Checkbox>
|
2024-10-22 17:24:02 +08:00
|
|
|
|
<div
|
2024-11-01 15:46:26 +08:00
|
|
|
|
// className={`mt-2 px-4 h-12 py-3 rounded-[0.8rem] bg-[#FFFFFF1a] flex justify-between items-center ${
|
2025-03-27 17:25:42 +08:00
|
|
|
|
// superSingleCheckeds != index
|
2024-11-01 15:46:26 +08:00
|
|
|
|
// ? "mt-0 px-0 py-0 hidden"
|
|
|
|
|
// : ""
|
|
|
|
|
// }`}
|
2025-03-14 18:43:22 +08:00
|
|
|
|
className={`mt-2 px-4 h-12 py-3 rounded-[0.8rem] bg-[#FFFFFF1a] flex justify-between items-center ${
|
2025-03-27 17:25:42 +08:00
|
|
|
|
!superSingleCheckeds.includes(index) ? "mt-0 px-0 py-0 hidden" : ""
|
2025-03-14 18:43:22 +08:00
|
|
|
|
}`}
|
2024-10-22 17:24:02 +08:00
|
|
|
|
>
|
|
|
|
|
<div className="flex items-center">
|
|
|
|
|
<span className="mr-1 text-[#ffffffae] text-sm">¥</span>
|
|
|
|
|
<OwnInput
|
|
|
|
|
type="number"
|
2025-03-27 17:25:42 +08:00
|
|
|
|
className="text-2xl"
|
|
|
|
|
value={superSinglesContr[index].price}
|
2024-10-22 17:24:02 +08:00
|
|
|
|
onChange={(value) => {
|
2025-03-27 17:25:42 +08:00
|
|
|
|
const newSuperSinglesContr = [...superSinglesContr];
|
|
|
|
|
newSuperSinglesContr[index].price = value;
|
|
|
|
|
setSuperSinglesContr(newSuperSinglesContr);
|
2024-10-22 17:24:02 +08:00
|
|
|
|
}}
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
<div className="flex items-center">
|
2024-10-23 13:52:52 +08:00
|
|
|
|
<span className="text-[#ffffff26] mr-2">|</span>
|
2024-11-05 17:53:13 +08:00
|
|
|
|
<Checkbox
|
2024-11-01 15:46:26 +08:00
|
|
|
|
block
|
2025-03-27 17:25:42 +08:00
|
|
|
|
checked={superSinglesContr[index].wechatFree}
|
2024-11-01 15:46:26 +08:00
|
|
|
|
onChange={(value) => {
|
2025-03-27 17:25:42 +08:00
|
|
|
|
const newSuperSinglesContr = [...superSinglesContr];
|
|
|
|
|
newSuperSinglesContr[index].wechatFree = value;
|
|
|
|
|
setSuperSinglesContr(newSuperSinglesContr);
|
2024-11-01 15:46:26 +08:00
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
<p className="text-sm whitespace-nowrap">赠送微信</p>
|
2024-11-05 17:53:13 +08:00
|
|
|
|
</Checkbox>
|
2024-10-22 17:24:02 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</li>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
export default function CreateProfile() {
|
|
|
|
|
const router = useRouter();
|
2025-03-27 17:25:42 +08:00
|
|
|
|
const [form] = Form.useForm();
|
|
|
|
|
const [openSuper, setOpenSuper] = useState(false);
|
2024-10-22 17:24:02 +08:00
|
|
|
|
const [isSubmitting, setIsSubmitting] = useState(false);
|
2025-03-14 18:43:22 +08:00
|
|
|
|
const [superSingleCheckeds, setSuperSingleCheckeds] = useState([]);
|
2025-03-27 17:25:42 +08:00
|
|
|
|
const [superSinglesContr, setSuperSinglesContr] = useState([
|
|
|
|
|
{ enable: false, price: 0, wechatFree: false, key: 0 },
|
|
|
|
|
{ enable: false, price: 0, wechatFree: false, key: 4 },
|
|
|
|
|
{ enable: false, price: 0, wechatFree: false, key: 3 },
|
|
|
|
|
{ enable: false, price: 0, wechatFree: false, key: 2 },
|
|
|
|
|
{ enable: false, price: 0, wechatFree: false, key: 1 },
|
|
|
|
|
]);
|
|
|
|
|
// const [superSingleChecked, setSuperSingleChecked] = useState(0);
|
2024-10-22 17:24:02 +08:00
|
|
|
|
const listItemWithCheckboxMemo = useMemo(() => {
|
2025-03-27 17:25:42 +08:00
|
|
|
|
return superSingles.map((item, index) => (
|
2024-10-22 17:24:02 +08:00
|
|
|
|
<Fragment key={item.key}>
|
|
|
|
|
<ListItemWithCheckbox
|
|
|
|
|
superSingle={item}
|
2025-03-27 17:25:42 +08:00
|
|
|
|
superSinglesContr={superSinglesContr}
|
|
|
|
|
setSuperSinglesContr={setSuperSinglesContr}
|
2025-03-14 18:43:22 +08:00
|
|
|
|
// superSingleCheckeds={superSingleChecked}
|
|
|
|
|
superSingleCheckeds={superSingleCheckeds}
|
2025-03-27 17:25:42 +08:00
|
|
|
|
index={index}
|
2024-10-22 17:24:02 +08:00
|
|
|
|
/>
|
|
|
|
|
</Fragment>
|
|
|
|
|
));
|
2025-03-27 17:25:42 +08:00
|
|
|
|
}, [superSingleCheckeds, superSinglesContr]);
|
2024-10-24 21:28:49 +08:00
|
|
|
|
|
2025-03-27 17:25:42 +08:00
|
|
|
|
const handleSubmit = async (newFormData) => {
|
|
|
|
|
const { spaceIntro, spacePrice, ironFanPrice } = newFormData;
|
|
|
|
|
const superSingle = [...superSinglesContr];
|
2024-10-30 21:42:23 +08:00
|
|
|
|
const openSuperEveryFalse = Object.values(superSingle).every(
|
|
|
|
|
(it) => !it.enable
|
|
|
|
|
);
|
2025-03-27 17:25:42 +08:00
|
|
|
|
if (openSuper && openSuperEveryFalse) {
|
2024-10-22 17:24:02 +08:00
|
|
|
|
Toast.show({
|
|
|
|
|
icon: "fail",
|
|
|
|
|
content: "请完善内容后提交",
|
|
|
|
|
position: "top",
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
const _spacePrice = parseInt(spacePrice * 100, 10);
|
|
|
|
|
const _ironFanPrice = parseInt(ironFanPrice * 100, 10);
|
2024-10-25 19:19:41 +08:00
|
|
|
|
let isPrice = false;
|
2024-10-22 17:24:02 +08:00
|
|
|
|
if (openSuper) {
|
2025-03-14 18:43:22 +08:00
|
|
|
|
Object.values(superSingle).forEach((it) => {
|
|
|
|
|
if (it.enable) {
|
|
|
|
|
const superFanPrice = it.price;
|
2024-10-22 17:24:02 +08:00
|
|
|
|
if (!superFanPrice) {
|
|
|
|
|
Toast.show({
|
|
|
|
|
icon: "fail",
|
2025-03-27 17:25:42 +08:00
|
|
|
|
content: "请输入有效的超粉价格",
|
2024-10-22 17:24:02 +08:00
|
|
|
|
position: "top",
|
|
|
|
|
});
|
2024-11-01 15:46:26 +08:00
|
|
|
|
isPrice = true;
|
|
|
|
|
return;
|
2024-10-22 17:24:02 +08:00
|
|
|
|
} else {
|
|
|
|
|
const _superFanPrice = parseInt(superFanPrice * 100, 10);
|
|
|
|
|
if (
|
|
|
|
|
openSuper &&
|
|
|
|
|
(isNaN(_superFanPrice) ||
|
|
|
|
|
_superFanPrice < 100 ||
|
|
|
|
|
_superFanPrice > 388800)
|
|
|
|
|
) {
|
2024-10-25 19:19:41 +08:00
|
|
|
|
isPrice = true;
|
2024-10-22 17:24:02 +08:00
|
|
|
|
Toast.show({
|
|
|
|
|
icon: "fail",
|
|
|
|
|
content: "请输入有效的超粉价格",
|
|
|
|
|
position: "top",
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (openSuper && _superFanPrice <= _ironFanPrice) {
|
2024-10-25 19:19:41 +08:00
|
|
|
|
isPrice = true;
|
2024-10-22 17:24:02 +08:00
|
|
|
|
Toast.show({
|
|
|
|
|
icon: "fail",
|
|
|
|
|
content: "请输入大于铁粉价格的超粉价格",
|
|
|
|
|
position: "top",
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-03-14 18:43:22 +08:00
|
|
|
|
});
|
|
|
|
|
// if (superSingleChecked == null) {
|
|
|
|
|
// Toast.show({
|
|
|
|
|
// icon: "fail",
|
|
|
|
|
// content: "请选择铁粉类型",
|
|
|
|
|
// position: "top",
|
|
|
|
|
// });
|
|
|
|
|
// } else {
|
|
|
|
|
// const superChecked = superSingle.filter(
|
|
|
|
|
// (_, index) => index == superSingleChecked
|
|
|
|
|
// )[0];
|
|
|
|
|
// if (superChecked) {
|
|
|
|
|
// const superFanPrice = superChecked.price;
|
|
|
|
|
// if (!superFanPrice) {
|
|
|
|
|
// Toast.show({
|
|
|
|
|
// icon: "fail",
|
|
|
|
|
// content: "请填写超粉价格",
|
|
|
|
|
// position: "top",
|
|
|
|
|
// });
|
|
|
|
|
// isPrice = true;
|
|
|
|
|
// return;
|
|
|
|
|
// } else {
|
|
|
|
|
// const _superFanPrice = parseInt(superFanPrice * 100, 10);
|
|
|
|
|
// if (
|
|
|
|
|
// openSuper &&
|
|
|
|
|
// (isNaN(_superFanPrice) ||
|
|
|
|
|
// _superFanPrice < 100 ||
|
|
|
|
|
// _superFanPrice > 388800)
|
|
|
|
|
// ) {
|
|
|
|
|
// isPrice = true;
|
|
|
|
|
// Toast.show({
|
|
|
|
|
// icon: "fail",
|
|
|
|
|
// content: "请输入有效的超粉价格",
|
|
|
|
|
// position: "top",
|
|
|
|
|
// });
|
|
|
|
|
// return;
|
|
|
|
|
// }
|
|
|
|
|
// if (openSuper && _superFanPrice <= _ironFanPrice) {
|
|
|
|
|
// isPrice = true;
|
|
|
|
|
// Toast.show({
|
|
|
|
|
// icon: "fail",
|
|
|
|
|
// content: "请输入大于铁粉价格的超粉价格",
|
|
|
|
|
// position: "top",
|
|
|
|
|
// });
|
|
|
|
|
// return;
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
2024-11-04 14:55:23 +08:00
|
|
|
|
}
|
|
|
|
|
if (isPrice) return;
|
2024-11-05 17:53:13 +08:00
|
|
|
|
// 旧版本
|
2025-03-14 18:43:22 +08:00
|
|
|
|
// const superfanList = superSingle.map((it, index) => ({
|
2024-11-05 17:53:13 +08:00
|
|
|
|
// period: index,
|
|
|
|
|
// enable: it.enable ? 1 : 0,
|
|
|
|
|
// price: parseInt(it.price * 100, 10),
|
|
|
|
|
// is_superfanship_give_wechat: it.wechatFree ? 1 : 0,
|
|
|
|
|
// }));
|
2025-03-14 18:43:22 +08:00
|
|
|
|
// const superfanObj = superfanList.filter((it) => it.enable)[0];
|
|
|
|
|
// 新版本代码
|
2025-03-27 17:25:42 +08:00
|
|
|
|
const superfan_price_list = superSinglesContr.map((it) => ({
|
|
|
|
|
period: it.key,
|
2025-03-14 18:43:22 +08:00
|
|
|
|
enable: it.enable ? 1 : 0,
|
|
|
|
|
price: parseInt(it.price * 100, 10),
|
|
|
|
|
is_superfanship_give_wechat: it.wechatFree ? 1 : 0,
|
|
|
|
|
}));
|
2024-11-04 14:55:23 +08:00
|
|
|
|
setIsSubmitting(true);
|
|
|
|
|
try {
|
|
|
|
|
const body = {
|
|
|
|
|
profile: spaceIntro,
|
2025-03-27 17:25:42 +08:00
|
|
|
|
admission_price: _spacePrice,
|
|
|
|
|
ironfanship_price: _ironFanPrice,
|
2024-11-04 14:55:23 +08:00
|
|
|
|
is_superfanship_enabled: openSuper ? 1 : 0,
|
2024-11-05 17:53:13 +08:00
|
|
|
|
// 旧版本
|
2025-03-14 18:43:22 +08:00
|
|
|
|
// superfanship_price: superfanObj.price,
|
|
|
|
|
// superfanship_valid_period: superfanObj.period,
|
|
|
|
|
// is_superfanship_give_wechat: superfanObj.is_superfanship_give_wechat,
|
2024-11-05 17:53:13 +08:00
|
|
|
|
// 新版本
|
2025-03-14 18:43:22 +08:00
|
|
|
|
superfan_price_list,
|
2024-11-04 14:55:23 +08:00
|
|
|
|
};
|
|
|
|
|
const _data = await requireAPI(
|
|
|
|
|
"POST",
|
|
|
|
|
"/api/zone/create",
|
|
|
|
|
{
|
|
|
|
|
body,
|
|
|
|
|
},
|
|
|
|
|
true
|
|
|
|
|
);
|
|
|
|
|
if (_data.ret === -1) {
|
2024-10-31 18:16:47 +08:00
|
|
|
|
Toast.show({
|
2024-11-04 14:55:23 +08:00
|
|
|
|
icon: "fail",
|
|
|
|
|
content: _data.msg,
|
2024-10-31 18:16:47 +08:00
|
|
|
|
position: "top",
|
|
|
|
|
});
|
2024-11-04 14:55:23 +08:00
|
|
|
|
return;
|
2024-10-31 18:16:47 +08:00
|
|
|
|
}
|
2024-11-04 14:55:23 +08:00
|
|
|
|
Toast.show({
|
|
|
|
|
icon: "success",
|
|
|
|
|
content: "开通空间成功!空间简介将在审核完成后生效。",
|
|
|
|
|
position: "top",
|
|
|
|
|
});
|
|
|
|
|
router.back();
|
|
|
|
|
} catch (error) {
|
|
|
|
|
console.error(error);
|
|
|
|
|
} finally {
|
|
|
|
|
setIsSubmitting(false);
|
2024-10-31 18:16:47 +08:00
|
|
|
|
}
|
2024-10-22 17:24:02 +08:00
|
|
|
|
};
|
2025-03-27 17:25:42 +08:00
|
|
|
|
const messageEle = (message) => <p className="text-right">{message}</p>;
|
2024-10-22 17:24:02 +08:00
|
|
|
|
return (
|
|
|
|
|
<div>
|
|
|
|
|
{/* 头部标题 */}
|
|
|
|
|
<div className="p-4 fixed top-0 z-10 w-full bg-black">
|
|
|
|
|
<div className="w-9 h-9 flex items-center justify-center bg-[#FFFFFF1A] rounded-full absolute">
|
|
|
|
|
<FontAwesomeIcon
|
|
|
|
|
icon={faAngleLeft}
|
|
|
|
|
style={{ maxWidth: "12px" }}
|
|
|
|
|
size="xl"
|
|
|
|
|
onClick={() => {
|
|
|
|
|
router.back();
|
|
|
|
|
}}
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
2024-10-23 13:52:52 +08:00
|
|
|
|
<p className="text-base text-center leading-9 whitespace-nowrap">
|
2024-10-31 18:16:47 +08:00
|
|
|
|
开通空间
|
2024-10-23 13:52:52 +08:00
|
|
|
|
</p>
|
2024-10-22 17:24:02 +08:00
|
|
|
|
</div>
|
|
|
|
|
{/* 内容 */}
|
|
|
|
|
<div className="pt-16 p-4">
|
2025-03-27 17:25:42 +08:00
|
|
|
|
<Form
|
|
|
|
|
requiredMarkStyle="none"
|
|
|
|
|
form={form}
|
|
|
|
|
initialValues={{
|
|
|
|
|
spaceIntro: "",
|
|
|
|
|
spacePrice: undefined,
|
|
|
|
|
ironFanPrice: undefined,
|
|
|
|
|
}}
|
|
|
|
|
onFinishFailed={(error) => {
|
|
|
|
|
Toast.show({
|
|
|
|
|
icon: "fail",
|
|
|
|
|
content: "请检查所填内容",
|
|
|
|
|
position: "top",
|
|
|
|
|
});
|
|
|
|
|
}}
|
|
|
|
|
onFinish={handleSubmit}
|
|
|
|
|
onValuesChange={(values) => {
|
|
|
|
|
console.log("onValuesChange:", values);
|
|
|
|
|
// setFormData(values);
|
|
|
|
|
}}
|
|
|
|
|
// hasFeedback={false}
|
|
|
|
|
validateMessages={{
|
|
|
|
|
required: (name) => {
|
|
|
|
|
return <p className="text-right">{`请输入${name}`}</p>;
|
|
|
|
|
},
|
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
<div className="mt-4">
|
|
|
|
|
<div className="flex justify-between items-center">
|
|
|
|
|
<p className="text-sm">
|
|
|
|
|
<span className="whitespace-nowrap">空间介绍</span>
|
|
|
|
|
<span className="text-[#f00]">*</span>
|
|
|
|
|
</p>
|
|
|
|
|
<p className="text-[#ffffffae] text-xs"></p>
|
2024-10-22 17:24:02 +08:00
|
|
|
|
</div>
|
2025-03-27 17:25:42 +08:00
|
|
|
|
<Form.Item
|
|
|
|
|
required
|
|
|
|
|
name="spaceIntro"
|
|
|
|
|
// childElementPosition="left"
|
|
|
|
|
layout="vertical"
|
|
|
|
|
rules={[
|
|
|
|
|
{
|
|
|
|
|
required: true,
|
|
|
|
|
message: messageEle("请输入空间介绍"),
|
|
|
|
|
// 匹配两为小数
|
|
|
|
|
// pattern: /^[0-9]+(.[0-9]{1,2})?$/,
|
|
|
|
|
// validator: (rule, value) => {
|
|
|
|
|
// const regex = /^[0-9]+(.[0-9]{1,2})?$/;
|
|
|
|
|
// const result = regex.test(value);
|
|
|
|
|
// if (value < 0 || value > 3888 || !result) {
|
|
|
|
|
// return Promise.reject(
|
|
|
|
|
// messageEle("请填写你的空间介绍")
|
|
|
|
|
// );
|
|
|
|
|
// }
|
|
|
|
|
// return Promise.resolve();
|
|
|
|
|
// },
|
|
|
|
|
},
|
|
|
|
|
]}
|
2024-10-22 17:24:02 +08:00
|
|
|
|
>
|
2025-03-27 17:25:42 +08:00
|
|
|
|
<div className="mt-2 px-4 py-3 rounded-[0.8rem] bg-[#FFFFFF1a] flex justify-between items-center">
|
|
|
|
|
<TextArea
|
|
|
|
|
id="spaceIntro"
|
|
|
|
|
style={{ "--font-size": `16px` }}
|
|
|
|
|
placeholder="介绍下你的空间吧~"
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
</Form.Item>
|
2024-10-22 17:24:02 +08:00
|
|
|
|
</div>
|
2025-03-27 17:25:42 +08:00
|
|
|
|
<div className="mt-3">
|
|
|
|
|
<Form.Item
|
|
|
|
|
required
|
|
|
|
|
name="spacePrice"
|
|
|
|
|
// childElementPosition="left"
|
|
|
|
|
label={
|
|
|
|
|
<div className="flex justify-between items-center">
|
|
|
|
|
<p className="text-sm whitespace-nowrap">
|
|
|
|
|
<span>解锁空间价格</span>
|
|
|
|
|
<span className="text-[#f00]">*</span>
|
|
|
|
|
</p>
|
|
|
|
|
<p className="text-[#ffffffae] text-xs">
|
|
|
|
|
(成为空间成员,可查看免费帖)
|
|
|
|
|
</p>
|
|
|
|
|
</div>
|
|
|
|
|
}
|
|
|
|
|
layout="vertical"
|
|
|
|
|
rules={[
|
|
|
|
|
{
|
|
|
|
|
required: true,
|
|
|
|
|
// message: messageEle("请填写正确的解锁空间的价格"),
|
|
|
|
|
// 匹配两为小数
|
|
|
|
|
// pattern: /^[0-9]+(.[0-9]{1,2})?$/,
|
|
|
|
|
validator: (rule, value) => {
|
|
|
|
|
const regex = /^[0-9]+(.[0-9]{1,2})?$/;
|
|
|
|
|
const result = regex.test(value);
|
|
|
|
|
if (value < 0 || value > 3888 || !result) {
|
|
|
|
|
return Promise.reject(
|
|
|
|
|
messageEle("请输入有效的解锁空间价格")
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
return Promise.resolve();
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
]}
|
2024-10-22 17:24:02 +08:00
|
|
|
|
>
|
2025-03-27 17:25:42 +08:00
|
|
|
|
<div className="mt-2 px-4 py-3 h-12 rounded-[0.8rem] bg-[#FFFFFF1a] flex justify-between items-center">
|
|
|
|
|
<div className="flex items-center">
|
|
|
|
|
<span className="mr-1 text-[#ffffffae] text-sm">¥</span>
|
|
|
|
|
<Form.Item name="spacePrice">
|
|
|
|
|
<OwnInput
|
|
|
|
|
id="spacePriceInput"
|
|
|
|
|
type="number"
|
|
|
|
|
placeholder="价格区间为0~3888"
|
|
|
|
|
inputClassName="placeholder:text-[14px]"
|
|
|
|
|
/>
|
|
|
|
|
</Form.Item>
|
|
|
|
|
</div>
|
|
|
|
|
<label
|
|
|
|
|
htmlFor="spacePriceInput"
|
|
|
|
|
className="text-[#ffffff40] text-xs whitespace-nowrap"
|
|
|
|
|
>
|
|
|
|
|
点击编辑
|
|
|
|
|
</label>
|
|
|
|
|
</div>
|
|
|
|
|
</Form.Item>
|
2024-10-22 17:24:02 +08:00
|
|
|
|
</div>
|
2025-03-27 17:25:42 +08:00
|
|
|
|
<div className="mt-3">
|
|
|
|
|
{/* <div className="flex justify-between items-center">
|
|
|
|
|
<p className="text-sm whitespace-nowrap">
|
|
|
|
|
<span>铁粉价格</span>
|
|
|
|
|
<span className="text-[#f00]">*</span>
|
|
|
|
|
</p>
|
|
|
|
|
<p className="text-[#ffffffae] text-xs">
|
|
|
|
|
(累计消费达成后解锁铁粉权益)
|
|
|
|
|
</p>
|
|
|
|
|
</div> */}
|
|
|
|
|
<Form.Item
|
|
|
|
|
name="ironFanPrice"
|
|
|
|
|
// childElementPosition="left"
|
|
|
|
|
label={
|
|
|
|
|
<div className="flex justify-between items-center">
|
|
|
|
|
<p className="text-sm whitespace-nowrap">
|
|
|
|
|
<span className="text-white">铁粉价格</span>
|
|
|
|
|
<span className="text-[#f00]">*</span>
|
|
|
|
|
</p>
|
|
|
|
|
<p className="text-[#ffffffb3] text-xs">
|
|
|
|
|
(累计消费达成后解锁铁粉权益)
|
|
|
|
|
</p>
|
|
|
|
|
</div>
|
|
|
|
|
}
|
|
|
|
|
layout="vertical"
|
|
|
|
|
rules={[
|
|
|
|
|
{
|
|
|
|
|
required: true,
|
|
|
|
|
// message: messageEle("请填写正确的铁粉价格"),
|
|
|
|
|
// 匹配两为小数
|
|
|
|
|
// pattern: /^[0-9]+(.[0-9]{1,2})?$/,
|
|
|
|
|
validator: (rule, value) => {
|
|
|
|
|
const regex = /^[0-9]+(.[0-9]{1,2})?$/;
|
|
|
|
|
const result = regex.test(value);
|
|
|
|
|
if (value < 1 || value > 3888 || !result) {
|
|
|
|
|
return Promise.reject(messageEle("请输入有效的铁粉价格"));
|
|
|
|
|
}
|
|
|
|
|
return Promise.resolve();
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
]}
|
|
|
|
|
>
|
|
|
|
|
<div className="mt-2 px-4 py-3 h-12 rounded-[0.8rem] bg-[#FFFFFF1a] flex justify-between items-center">
|
|
|
|
|
<div className="flex items-center">
|
|
|
|
|
<span className="mr-1 text-[#ffffffae] text-sm">¥</span>
|
|
|
|
|
<Form.Item name="ironFanPrice">
|
|
|
|
|
<OwnInput
|
|
|
|
|
id="ironPriceInput"
|
|
|
|
|
type="number"
|
|
|
|
|
placeholder="价格区间为1~3888"
|
|
|
|
|
inputClassName="placeholder:text-[14px]"
|
|
|
|
|
/>
|
|
|
|
|
</Form.Item>
|
|
|
|
|
</div>
|
|
|
|
|
<label
|
|
|
|
|
htmlFor="ironPriceInput"
|
|
|
|
|
className="text-[#ffffff40] text-xs whitespace-nowrap"
|
|
|
|
|
>
|
|
|
|
|
点击编辑
|
|
|
|
|
</label>
|
|
|
|
|
</div>
|
|
|
|
|
</Form.Item>
|
2024-10-22 17:24:02 +08:00
|
|
|
|
</div>
|
2024-10-30 21:42:23 +08:00
|
|
|
|
<div className="mt-3">
|
|
|
|
|
<div className="flex justify-between items-center">
|
|
|
|
|
<p className="text-sm">
|
2025-03-27 17:25:42 +08:00
|
|
|
|
<span>超粉功能</span>
|
2024-10-30 21:42:23 +08:00
|
|
|
|
<span className="text-[#f00]">*</span>
|
|
|
|
|
</p>
|
2025-03-27 17:25:42 +08:00
|
|
|
|
<div className="flex items-center">
|
|
|
|
|
<p className="text-[#ffffffae] text-xs mr-2">是否启用</p>
|
|
|
|
|
<Form.Item>
|
|
|
|
|
<Switch
|
|
|
|
|
checked={openSuper}
|
|
|
|
|
onChange={() => setOpenSuper((old) => !old)}
|
|
|
|
|
style={{
|
|
|
|
|
"--checked-color": "#FF669E",
|
|
|
|
|
"--height": "24px",
|
|
|
|
|
"--width": "36px",
|
|
|
|
|
}}
|
|
|
|
|
/>
|
|
|
|
|
</Form.Item>
|
|
|
|
|
</div>
|
2024-10-30 21:42:23 +08:00
|
|
|
|
</div>
|
2024-10-22 17:24:02 +08:00
|
|
|
|
</div>
|
2025-03-27 17:25:42 +08:00
|
|
|
|
{openSuper && (
|
|
|
|
|
<Form.Item
|
|
|
|
|
name="superSingleCheckeds"
|
|
|
|
|
// childElementPosition="left"
|
|
|
|
|
label={
|
|
|
|
|
<div className="flex justify-between items-center">
|
|
|
|
|
<p className="text-sm">
|
|
|
|
|
<span className="text-white">超粉单次开通类型</span>
|
|
|
|
|
<span className="text-[#f00]">*</span>
|
|
|
|
|
</p>
|
|
|
|
|
<p className="text-[#ffffffb3] text-xs">
|
|
|
|
|
(付费后解锁对应期限超粉权益)
|
|
|
|
|
</p>
|
|
|
|
|
</div>
|
|
|
|
|
}
|
|
|
|
|
layout="vertical"
|
|
|
|
|
>
|
|
|
|
|
<Space direction="vertical" block>
|
|
|
|
|
{/* <Radio.Group
|
|
|
|
|
value={superSingleChecked}
|
|
|
|
|
// value={superSingleCheckeds}
|
|
|
|
|
onChange={(values) => {
|
|
|
|
|
setSuperSingleChecked(values);
|
|
|
|
|
// setSuperSingleCheckeds(values);
|
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
<ul>{listItemWithCheckboxMemo}</ul>
|
|
|
|
|
</Radio.Group> */}
|
|
|
|
|
<Checkbox.Group
|
|
|
|
|
value={superSingleCheckeds}
|
|
|
|
|
onChange={(values) => {
|
|
|
|
|
setSuperSingleCheckeds(values);
|
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
<ul>{listItemWithCheckboxMemo}</ul>
|
|
|
|
|
</Checkbox.Group>
|
|
|
|
|
</Space>
|
|
|
|
|
</Form.Item>
|
|
|
|
|
)}
|
|
|
|
|
<Form.Item label={null} className="mt-10 flex-1 flex justify-center">
|
|
|
|
|
<Button
|
|
|
|
|
size="middle"
|
|
|
|
|
shape="rounded"
|
|
|
|
|
block
|
|
|
|
|
style={{
|
|
|
|
|
"--background-color": "#FF669E",
|
|
|
|
|
paddingLeft: "32px",
|
|
|
|
|
paddingRight: "32px",
|
|
|
|
|
}}
|
|
|
|
|
type="primary"
|
|
|
|
|
htmlType="submit"
|
|
|
|
|
disabled={isSubmitting}
|
|
|
|
|
>
|
|
|
|
|
{isSubmitting ? "正在保存..." : "保存设置"}
|
|
|
|
|
</Button>
|
|
|
|
|
</Form.Item>
|
|
|
|
|
</Form>
|
2024-10-22 17:24:02 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
}
|