+
+
+
+ 请升级您的浏览器
+
+
+
+
+
+
+请升级您的浏览器,以便我们更好的为您提供服务!
+您正在使用 Internet Explorer 的早期版本(IE11以下版本或使用该内核的浏览器)。这意味着在升级浏览器前,您将无法访问此网站。
+
+请注意:微软公司对Windows XP 及 Internet Explorer 早期版本的支持已经结束
+自 2016 年 1 月 12 日起,Microsoft 不再为 IE 11 以下版本提供相应支持和更新。没有关键的浏览器安全更新,您的电脑可能易受有害病毒、间谍软件和其他恶意软件的攻击,它们可以窃取或损害您的业务数据和信息。请参阅 微软对 Internet Explorer 早期版本的支持将于 2016 年 1 月 12 日结束的说明 。
+
+您可以选择更先进的浏览器
+推荐使用以下浏览器的最新版本。如果您的电脑已有以下浏览器的最新版本则直接使用该浏览器访问即可。
+
+
+
+
\ No newline at end of file
diff --git a/fuintAdmin/public/index.html b/fuintAdmin/public/index.html
new file mode 100644
index 0000000..a3b4312
--- /dev/null
+++ b/fuintAdmin/public/index.html
@@ -0,0 +1,202 @@
+
+
+
+
+
+
+
+
+
+ <%= webpackConfig.name %>
+
+
+
+
+
+
+
+
+
+
正在加载系统资源,请耐心等待...
+
+
+
+
diff --git a/fuintAdmin/public/robots.txt b/fuintAdmin/public/robots.txt
new file mode 100644
index 0000000..77470cb
--- /dev/null
+++ b/fuintAdmin/public/robots.txt
@@ -0,0 +1,2 @@
+User-agent: *
+Disallow: /
\ No newline at end of file
diff --git a/fuintAdmin/src/App.vue b/fuintAdmin/src/App.vue
new file mode 100644
index 0000000..391d951
--- /dev/null
+++ b/fuintAdmin/src/App.vue
@@ -0,0 +1,19 @@
+
+
+
+
+
+
+
diff --git a/fuintAdmin/src/api/article.js b/fuintAdmin/src/api/article.js
new file mode 100644
index 0000000..1ce90ea
--- /dev/null
+++ b/fuintAdmin/src/api/article.js
@@ -0,0 +1,40 @@
+import request from '@/utils/request'
+
+// 分页查询文章列表
+export function getArticleList(query) {
+ return request({
+ url: 'backendApi/article/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询文章信息
+export function getArticle(articleId) {
+ return request({
+ url: 'backendApi/article/info/' + articleId,
+ method: 'get'
+ })
+}
+
+// 更新文章状态
+export function updateStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/article/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存数据
+export function saveArticle(data) {
+ return request({
+ url: 'backendApi/article/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/balance.js b/fuintAdmin/src/api/balance.js
new file mode 100644
index 0000000..2fbf087
--- /dev/null
+++ b/fuintAdmin/src/api/balance.js
@@ -0,0 +1,67 @@
+import request from '@/utils/request'
+
+// 分页查询余额明细列表
+export function getBalanceList(query) {
+ return request({
+ url: 'backendApi/balance/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询明细详情
+export function getBalanceInfo(memberId) {
+ return request({
+ url: 'backendApi/balance/info/' + memberId,
+ method: 'get'
+ })
+}
+
+// 更新状态
+export function updateBalanceStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/balance/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 获取配置信息
+export function getSettingInfo() {
+ return request({
+ url: 'backendApi/balance/setting',
+ method: 'get'
+ })
+}
+
+// 保存配置
+export function saveSetting(data) {
+ return request({
+ url: 'backendApi/balance/saveSetting',
+ method: 'post',
+ data: data
+ })
+}
+
+// 确定充值
+export function doRecharge(data) {
+ return request({
+ url: 'backendApi/balance/doRecharge',
+ method: 'post',
+ data: data
+ })
+}
+
+// 发放余额
+export function distribute(data) {
+ return request({
+ url: 'backendApi/balance/distribute',
+ method: 'post',
+ data: data
+ })
+}
+
diff --git a/fuintAdmin/src/api/banner.js b/fuintAdmin/src/api/banner.js
new file mode 100644
index 0000000..fcc0ddb
--- /dev/null
+++ b/fuintAdmin/src/api/banner.js
@@ -0,0 +1,40 @@
+import request from '@/utils/request'
+
+// 分页查询banner列表
+export function getBannerList(query) {
+ return request({
+ url: 'backendApi/banner/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询banner信息
+export function getBannerInfo(bannerId) {
+ return request({
+ url: 'backendApi/banner/info/' + bannerId,
+ method: 'get'
+ })
+}
+
+// 更新banner状态
+export function updateBannerStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/banner/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存数据
+export function saveBanner(data) {
+ return request({
+ url: 'backendApi/banner/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/cashier.js b/fuintAdmin/src/api/cashier.js
new file mode 100644
index 0000000..2ac1fd1
--- /dev/null
+++ b/fuintAdmin/src/api/cashier.js
@@ -0,0 +1,123 @@
+import request from '@/utils/request'
+
+// 初始化数据
+export function init(userId) {
+ return request({
+ url: 'backendApi/cashier/init/' + userId,
+ method: 'get'
+ })
+}
+
+// 查询商品详情
+export function getGoodsInfo(goodsId) {
+ return request({
+ url: 'backendApi/cashier/getGoodsInfo/' + goodsId,
+ method: 'get'
+ })
+}
+
+// 查询商品
+export function searchGoods(data) {
+ return request({
+ url: 'backendApi/cashier/searchGoods',
+ method: 'post',
+ data: data
+ })
+}
+
+// 查询会员信息
+export function getMemberInfo(data) {
+ return request({
+ url: 'backendApi/cashier/getMemberInfo',
+ method: 'post',
+ data: data
+ })
+}
+
+// 查询会员信息
+export function getMemberInfoById(userId) {
+ return request({
+ url: 'backendApi/cashier/getMemberInfoById/' + userId,
+ method: 'get'
+ })
+}
+
+// 获取购物车列表
+export function getCartList(data) {
+ return request({
+ url: 'clientApi/cart/list',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存购物车
+export function saveCart(data) {
+ return request({
+ url: 'clientApi/cart/save',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除购物车
+export function removeFromCart(data) {
+ return request({
+ url: 'clientApi/cart/clear',
+ method: 'post',
+ data: data
+ })
+}
+
+// 提交结算
+export function submitSettlement(data) {
+ return request({
+ url: 'clientApi/settlement/submit',
+ method: 'post',
+ data: data
+ })
+}
+
+// 发起支付
+export function doPay(params) {
+ return request({
+ url: 'clientApi/pay/doPay',
+ method: 'get',
+ params: params
+ })
+}
+
+// 获取订单列表
+export function getOrderList(data) {
+ return request({
+ url: 'backendApi/order/latest',
+ method: 'post',
+ data: data
+ })
+}
+
+// 执行挂单
+export function doHangUp(data) {
+ return request({
+ url: 'backendApi/cashier/doHangUp',
+ method: 'post',
+ data: data
+ })
+}
+
+// 获取挂单
+export function getHangUpList() {
+ return request({
+ url: 'backendApi/cashier/getHangUpList',
+ method: 'get'
+ })
+}
+
+// 删除挂单
+export function removeHangUp(data) {
+ return request({
+ url: 'clientApi/cart/clear',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/commission/cash.js b/fuintAdmin/src/api/commission/cash.js
new file mode 100644
index 0000000..59714b5
--- /dev/null
+++ b/fuintAdmin/src/api/commission/cash.js
@@ -0,0 +1,45 @@
+import request from '@/utils/request'
+
+// 分页查询提现列表
+export function getCashList(query) {
+ return request({
+ url: 'backendApi/commissionCash/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询提现详情
+export function getCashDetail(bannerId) {
+ return request({
+ url: 'backendApi/commissionCash/info/' + bannerId,
+ method: 'get'
+ })
+}
+
+// 更新提现
+export function updateCommissionCash(data) {
+ return request({
+ url: 'backendApi/commissionCash/save',
+ method: 'post',
+ data: data
+ })
+}
+
+// 确认结算
+export function confirmCommissionCash(data) {
+ return request({
+ url: 'backendApi/commissionCash/confirm',
+ method: 'post',
+ data: data
+ })
+}
+
+// 取消结算
+export function cancelCommissionCash(data) {
+ return request({
+ url: 'backendApi/commissionCash/cancel',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/commission/log.js b/fuintAdmin/src/api/commission/log.js
new file mode 100644
index 0000000..fbacbc3
--- /dev/null
+++ b/fuintAdmin/src/api/commission/log.js
@@ -0,0 +1,45 @@
+import request from '@/utils/request'
+
+// 查询分佣记录列表
+export function getCommissionLogList(query) {
+ return request({
+ url: 'backendApi/commissionLog/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询分佣记录详情
+export function getCommissionLogDetail(query) {
+ return request({
+ url: 'backendApi/commissionLog/detail',
+ method: 'get',
+ params: query
+ })
+}
+
+// 更新分佣记录
+export function updateCommissionLog(data) {
+ return request({
+ url: 'backendApi/commissionLog/save',
+ method: 'post',
+ data: data
+ })
+}
+
+// 作废分佣记录
+export function deleteCommissionLog(id) {
+ return request({
+ url: 'backendApi/commissionLog/delete/' + id,
+ method: 'get'
+ })
+}
+
+// 结算分佣记录
+export function doSettle(data) {
+ return request({
+ url: 'backendApi/commissionLog/doSettle',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/commission/rule.js b/fuintAdmin/src/api/commission/rule.js
new file mode 100644
index 0000000..e037c20
--- /dev/null
+++ b/fuintAdmin/src/api/commission/rule.js
@@ -0,0 +1,46 @@
+import request from '@/utils/request'
+
+// 分页查询分销提成规则列表
+export function getCommissionRuleList(query) {
+ return request({
+ url: 'backendApi/commissionRule/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询分销提成规则详情
+export function getCommissionRuleInfo(ruleId) {
+ return request({
+ url: 'backendApi/commissionRule/info/' + ruleId,
+ method: 'get'
+ })
+}
+
+// 更新分销提成规则状态
+export function updateCommissionRuleStatus(ruleId, status) {
+ const data = { ruleId, status }
+ return request({
+ url: 'backendApi/commissionRule/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存分销提成规则
+export function saveCommissionRule(data) {
+ return request({
+ url: 'backendApi/commissionRule/save',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除分销提成规则
+export function removeCommissionRule(data) {
+ return request({
+ url: 'backendApi/commissionRule/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/common.js b/fuintAdmin/src/api/common.js
new file mode 100644
index 0000000..64fd674
--- /dev/null
+++ b/fuintAdmin/src/api/common.js
@@ -0,0 +1,11 @@
+import request from '@/utils/request'
+
+// 生成二维码
+export function createQrCode(data) {
+ return request({
+ url: 'backendApi/common/createQrCode',
+ method: 'post',
+ data: data
+ })
+}
+
diff --git a/fuintAdmin/src/api/coupon/confirmLog.js b/fuintAdmin/src/api/coupon/confirmLog.js
new file mode 100644
index 0000000..ec3bed3
--- /dev/null
+++ b/fuintAdmin/src/api/coupon/confirmLog.js
@@ -0,0 +1,18 @@
+import request from '@/utils/request'
+
+// 分页查询核销流水列表
+export function getConfirmLogList(query) {
+ return request({
+ url: 'backendApi/confirmLog/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 撤销已使用的卡券
+export function rollbackUserCoupon(id, userCouponId) {
+ return request({
+ url: 'backendApi/confirmLog/rollbackUserCoupon/' + id + '?userCouponId=' + userCouponId,
+ method: 'get',
+ })
+}
diff --git a/fuintAdmin/src/api/coupon/coupon.js b/fuintAdmin/src/api/coupon/coupon.js
new file mode 100644
index 0000000..6c6e9d4
--- /dev/null
+++ b/fuintAdmin/src/api/coupon/coupon.js
@@ -0,0 +1,75 @@
+import request from '@/utils/request'
+
+// 分页查询卡券列表
+export function getCouponList(query) {
+ return request({
+ url: 'backendApi/coupon/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询卡券信息
+export function getCouponInfo(id) {
+ return request({
+ url: 'backendApi/coupon/info/' + id,
+ method: 'get'
+ })
+}
+
+// 更新状态
+export function updateCouponStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/coupon/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除卡券
+export function deleteCoupon(id) {
+ return request({
+ url: 'backendApi/coupon/delete/' + id,
+ method: 'get'
+ })
+}
+
+// 保存卡券
+export function saveCoupon(data) {
+ return request({
+ url: 'backendApi/coupon/save',
+ method: 'post',
+ data: data
+ })
+}
+
+// 查询卡券核销信息
+export function getConfirmInfo(data) {
+ return request({
+ url: 'backendApi/doConfirm/info',
+ method: 'post',
+ data: data
+ })
+}
+
+// 执行核销
+export function doConfirm(data) {
+ return request({
+ url: 'backendApi/doConfirm/doConfirm',
+ method: 'post',
+ data: data
+ })
+}
+
+// 发放卡券
+export function sendCoupon(params) {
+ return request({
+ url: 'backendApi/coupon/sendCoupon',
+ method: 'get',
+ params: params
+ })
+}
diff --git a/fuintAdmin/src/api/coupon/give.js b/fuintAdmin/src/api/coupon/give.js
new file mode 100644
index 0000000..ac7cfb6
--- /dev/null
+++ b/fuintAdmin/src/api/coupon/give.js
@@ -0,0 +1,18 @@
+import request from '@/utils/request'
+
+// 分页查询转赠记录列表
+export function getGiveLogList(query) {
+ return request({
+ url: 'backendApi/give/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 获取转赠详情
+export function getGiveItem(id) {
+ return request({
+ url: 'backendApi/give/giveItem?giveId=' + id,
+ method: 'get',
+ })
+}
diff --git a/fuintAdmin/src/api/coupon/group.js b/fuintAdmin/src/api/coupon/group.js
new file mode 100644
index 0000000..e8dcda7
--- /dev/null
+++ b/fuintAdmin/src/api/coupon/group.js
@@ -0,0 +1,57 @@
+import request from '@/utils/request'
+
+// 分页查询卡券分组列表
+export function getGroupList(query) {
+ return request({
+ url: 'backendApi/couponGroup/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询卡券分组列表
+export function getAllGroupList(query) {
+ return request({
+ url: 'backendApi/couponGroup/quickSearch',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询分组信息
+export function getGroupInfo(id) {
+ return request({
+ url: 'backendApi/couponGroup/info/' + id,
+ method: 'get'
+ })
+}
+
+// 更新状态
+export function updateGroupStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/couponGroup/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除卡券分组
+export function deleteGroup(id) {
+ return request({
+ url: 'backendApi/couponGroup/delete/' + id,
+ method: 'get'
+ })
+}
+
+// 保存卡券分组数据
+export function saveGroup(data) {
+ return request({
+ url: 'backendApi/couponGroup/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/coupon/sendLog.js b/fuintAdmin/src/api/coupon/sendLog.js
new file mode 100644
index 0000000..d8b57a9
--- /dev/null
+++ b/fuintAdmin/src/api/coupon/sendLog.js
@@ -0,0 +1,18 @@
+import request from '@/utils/request'
+
+// 分页查询发券记录列表
+export function getSendLogList(query) {
+ return request({
+ url: 'backendApi/sendLog/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 撤销已发放的卡券
+export function removeUserCoupon(id) {
+ return request({
+ url: 'backendApi/sendLog/removeUserCoupon/' + id,
+ method: 'get',
+ })
+}
diff --git a/fuintAdmin/src/api/coupon/userCoupon.js b/fuintAdmin/src/api/coupon/userCoupon.js
new file mode 100644
index 0000000..d8d7ce5
--- /dev/null
+++ b/fuintAdmin/src/api/coupon/userCoupon.js
@@ -0,0 +1,19 @@
+import request from '@/utils/request'
+
+// 分页查询会员卡券列表
+export function getUserCouponList(query) {
+ return request({
+ url: 'backendApi/userCoupon/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 作废会员卡券
+export function deleteUserCoupon(id) {
+ return request({
+ url: 'backendApi/userCoupon/delete/' + id,
+ method: 'get',
+ })
+}
+
diff --git a/fuintAdmin/src/api/goods.js b/fuintAdmin/src/api/goods.js
new file mode 100644
index 0000000..ce44c40
--- /dev/null
+++ b/fuintAdmin/src/api/goods.js
@@ -0,0 +1,85 @@
+import request from '@/utils/request'
+
+// 分页查询商品列表
+export function getGoodsList(query) {
+ return request({
+ url: 'backendApi/goods/goods/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询商品详情
+export function getGoodsInfo(goodsId) {
+ return request({
+ url: 'backendApi/goods/goods/info/' + goodsId,
+ method: 'get'
+ })
+}
+
+// 更新状态
+export function updateGoodsStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/goods/goods/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存分类数据
+export function saveGoods(data) {
+ return request({
+ url: 'backendApi/goods/goods/save',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存商品规格名称
+export function saveSpecName(data) {
+ return request({
+ url: 'backendApi/goods/goods/saveSpecName',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存商品规格值
+export function saveSpecValue(data) {
+ return request({
+ url: 'backendApi/goods/goods/saveSpecValue',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除商品规格
+export function deleteSpec(query) {
+ return request({
+ url: 'backendApi/goods/goods/deleteSpec',
+ method: 'get',
+ params: query
+ })
+}
+
+// 删除商品规格值
+export function deleteSpecValue(query) {
+ return request({
+ url: 'backendApi/goods/goods/deleteSpecValue',
+ method: 'get',
+ params: query
+ })
+}
+
+// 获取选择商品列表
+export function selectGoodsList(data) {
+ return request({
+ url: 'backendApi/goods/goods/selectGoods',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/goodsCate.js b/fuintAdmin/src/api/goodsCate.js
new file mode 100644
index 0000000..e277b16
--- /dev/null
+++ b/fuintAdmin/src/api/goodsCate.js
@@ -0,0 +1,40 @@
+import request from '@/utils/request'
+
+// 分页查询商品分类列表
+export function getGoodsCateList(query) {
+ return request({
+ url: 'backendApi/goods/cate/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询商品分类详情
+export function getGoodsCateInfo(cateId) {
+ return request({
+ url: 'backendApi/goods/cate/info/' + cateId,
+ method: 'get'
+ })
+}
+
+// 更新状态
+export function updateGoodsCateStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/goods/cate/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存分类数据
+export function saveGoodsCate(data) {
+ return request({
+ url: 'backendApi/goods/cate/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/home.js b/fuintAdmin/src/api/home.js
new file mode 100644
index 0000000..a8d1e03
--- /dev/null
+++ b/fuintAdmin/src/api/home.js
@@ -0,0 +1,18 @@
+import request from '@/utils/request'
+
+// 获取首页数据
+export function getHomeData() {
+ return request({
+ url: 'backendApi/home/index',
+ method: 'get'
+ })
+}
+
+// 获取统计数据
+export function getStatisticData(query) {
+ return request({
+ url: 'backendApi/home/statistic',
+ method: 'get',
+ params: query
+ })
+}
diff --git a/fuintAdmin/src/api/login.js b/fuintAdmin/src/api/login.js
new file mode 100644
index 0000000..fca43c0
--- /dev/null
+++ b/fuintAdmin/src/api/login.js
@@ -0,0 +1,43 @@
+import request from '@/utils/request'
+
+// 登录方法
+export function login(username, password, captchaCode, uuid) {
+ const data = {
+ username,
+ password,
+ captchaCode,
+ uuid
+ }
+ return request({
+ url: 'backendApi/login/doLogin',
+ headers: {
+ isToken: false
+ },
+ method: 'post',
+ data: data
+ })
+}
+
+// 获取用户详细信息
+export function getInfo() {
+ return request({
+ url: 'backendApi/login/getInfo',
+ method: 'get'
+ })
+}
+
+// 退出方法
+export function logout() {
+ return request({
+ url: 'backendApi/login/logout',
+ method: 'post'
+ })
+}
+
+// 获取验证码
+export function getCodeImg() {
+ return request({
+ url: 'clientApi/captcha/getCode',
+ method: 'get'
+ })
+}
diff --git a/fuintAdmin/src/api/member.js b/fuintAdmin/src/api/member.js
new file mode 100644
index 0000000..5c07d71
--- /dev/null
+++ b/fuintAdmin/src/api/member.js
@@ -0,0 +1,92 @@
+import request from '@/utils/request'
+
+// 分页查询会员列表
+export function getMemberList(query) {
+ return request({
+ url: 'backendApi/member/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询会员信息
+export function getMemberInfo(memberId) {
+ return request({
+ url: 'backendApi/member/info/' + memberId,
+ method: 'get'
+ })
+}
+
+// 查询会员设置
+export function getMemberSetting() {
+ return request({
+ url: 'backendApi/member/setting',
+ method: 'get'
+ })
+}
+
+// 保存会员设置
+export function saveSetting(data) {
+ return request({
+ url: 'backendApi/member/saveSetting',
+ method: 'post',
+ data: data
+ })
+}
+
+// 更新会员状态
+export function updateMemberStatus(userId, status) {
+ const data = {
+ userId,
+ status
+ }
+ return request({
+ url: 'backendApi/member/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除会员信息
+export function deleteMember(memberId) {
+ return request({
+ url: 'backendApi/member/delete/' + memberId,
+ method: 'get'
+ })
+}
+
+// 保存会员信息
+export function saveMember(data) {
+ return request({
+ url: 'backendApi/member/save',
+ method: 'post',
+ data: data
+ })
+}
+
+// 查询会员分组列表
+export function getGroupList(query) {
+ return request({
+ url: 'backendApi/member/groupList',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查找会员
+export function searchMembers(query) {
+ return request({
+ url: 'backendApi/member/searchMembers',
+ method: 'get',
+ params: query
+ })
+}
+
+// 重置会员密码
+export function resetMemberPwd(data) {
+ return request({
+ url: 'backendApi/member/resetPwd',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/memberGroup.js b/fuintAdmin/src/api/memberGroup.js
new file mode 100644
index 0000000..a4b7586
--- /dev/null
+++ b/fuintAdmin/src/api/memberGroup.js
@@ -0,0 +1,57 @@
+import request from '@/utils/request'
+
+// 分页查询会员分组列表
+export function getGroupList(query) {
+ return request({
+ url: 'backendApi/memberGroup/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询会员分组列表
+export function getAllGroupList(query) {
+ return request({
+ url: 'backendApi/memberGroup/quickSearch',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询会员分组信息
+export function getGroupInfo(id) {
+ return request({
+ url: 'backendApi/memberGroup/info/' + id,
+ method: 'get'
+ })
+}
+
+// 更新会员分组状态
+export function updateGroupStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/memberGroup/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除会员分组
+export function deleteGroup(id) {
+ return request({
+ url: 'backendApi/memberGroup/delete/' + id,
+ method: 'get'
+ })
+}
+
+// 保存会员分组数据
+export function saveGroup(data) {
+ return request({
+ url: 'backendApi/memberGroup/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/menu.js b/fuintAdmin/src/api/menu.js
new file mode 100644
index 0000000..f65ebe0
--- /dev/null
+++ b/fuintAdmin/src/api/menu.js
@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+
+// 获取路由
+export const getRouters = () => {
+ return request({
+ url: 'backendApi/login/getRouters',
+ method: 'get'
+ })
+}
diff --git a/fuintAdmin/src/api/merchant.js b/fuintAdmin/src/api/merchant.js
new file mode 100644
index 0000000..3d9a868
--- /dev/null
+++ b/fuintAdmin/src/api/merchant.js
@@ -0,0 +1,49 @@
+import request from '@/utils/request'
+
+// 分页查询商户列表
+export function getMerchantList(query) {
+ return request({
+ url: 'backendApi/merchant/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询商户信息
+export function getMerchantInfo(merchantId) {
+ return request({
+ url: 'backendApi/merchant/info/' + merchantId,
+ method: 'get'
+ })
+}
+
+// 查询商户列表
+export function searchMerchant(param) {
+ return request({
+ url: 'backendApi/merchant/searchMerchant',
+ method: 'get',
+ params: param
+ })
+}
+
+// 更新商户状态
+export function updateMerchantStatus(merchantId, status) {
+ const data = {
+ merchantId,
+ status
+ }
+ return request({
+ url: 'backendApi/merchant/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存商户信息
+export function saveMerchant(data) {
+ return request({
+ url: 'backendApi/merchant/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/openGift.js b/fuintAdmin/src/api/openGift.js
new file mode 100644
index 0000000..1337497
--- /dev/null
+++ b/fuintAdmin/src/api/openGift.js
@@ -0,0 +1,48 @@
+import request from '@/utils/request'
+
+// 分页查询开卡赠礼列表
+export function getOpenGiftList(query) {
+ return request({
+ url: 'backendApi/openGift/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询信息
+export function getOpenGiftInfo(id) {
+ return request({
+ url: 'backendApi/openGift/info/' + id,
+ method: 'get'
+ })
+}
+
+// 更新状态
+export function updateOpenGiftStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/openGift/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除开卡赠礼
+export function deleteOpenGift(id) {
+ return request({
+ url: 'backendApi/openGift/delete/' + id,
+ method: 'get'
+ })
+}
+
+// 保存数据
+export function saveOpenGift(data) {
+ return request({
+ url: 'backendApi/openGift/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/order.js b/fuintAdmin/src/api/order.js
new file mode 100644
index 0000000..4ab73ab
--- /dev/null
+++ b/fuintAdmin/src/api/order.js
@@ -0,0 +1,83 @@
+import request from '@/utils/request'
+
+// 分页查询订单列表
+export function getOrderList(data) {
+ return request({
+ url: 'backendApi/order/list',
+ method: 'post',
+ data: data
+ })
+}
+
+// 查询订单信息
+export function getOrderInfo(orderId) {
+ return request({
+ url: 'backendApi/order/info/' + orderId,
+ method: 'get'
+ })
+}
+
+// 更新订单状态
+export function updateOrderStatus(orderId, status) {
+ const data = {
+ orderId,
+ status
+ }
+ return request({
+ url: 'backendApi/order/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除订单
+export function deleteOrder(orderId) {
+ return request({
+ url: 'backendApi/order/delete/' + orderId,
+ method: 'get'
+ })
+}
+
+// 保存订单数据
+export function saveOrder(data) {
+ return request({
+ url: 'backendApi/order/save',
+ method: 'post',
+ data: data
+ })
+}
+
+// 验证核销订单
+export function verifyOrder(data) {
+ return request({
+ url: 'backendApi/order/verify',
+ method: 'post',
+ data: data
+ })
+}
+
+// 提交发货信息
+export function delivered(data) {
+ return request({
+ url: 'backendApi/order/delivered',
+ method: 'post',
+ data: data
+ })
+}
+
+// 获取配置信息
+export function getSettingInfo() {
+ return request({
+ url: 'backendApi/order/setting',
+ method: 'get'
+ })
+}
+
+// 保存配置
+export function saveSetting(data) {
+ return request({
+ url: 'backendApi/order/saveSetting',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/point.js b/fuintAdmin/src/api/point.js
new file mode 100644
index 0000000..9427b6a
--- /dev/null
+++ b/fuintAdmin/src/api/point.js
@@ -0,0 +1,58 @@
+import request from '@/utils/request'
+
+// 分页查询积分明细列表
+export function getPointList(query) {
+ return request({
+ url: 'backendApi/point/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询明细详情
+export function getPointInfo(memberId) {
+ return request({
+ url: 'backendApi/point/info/' + memberId,
+ method: 'get'
+ })
+}
+
+// 更新状态
+export function updatePointStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/point/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 获取配置信息
+export function getSettingInfo() {
+ return request({
+ url: 'backendApi/point/setting',
+ method: 'get'
+ })
+}
+
+// 保存配置
+export function saveSetting(data) {
+ return request({
+ url: 'backendApi/point/saveSetting',
+ method: 'post',
+ data: data
+ })
+}
+
+// 确定充值
+export function doRecharge(data) {
+ return request({
+ url: 'backendApi/point/doRecharge',
+ method: 'post',
+ data: data
+ })
+}
+
diff --git a/fuintAdmin/src/api/refund.js b/fuintAdmin/src/api/refund.js
new file mode 100644
index 0000000..7cba536
--- /dev/null
+++ b/fuintAdmin/src/api/refund.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 分页查询退款订单列表
+export function getRefundList(query) {
+ return request({
+ url: 'backendApi/refund/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询订单信息
+export function getRefundInfo(refundId) {
+ return request({
+ url: 'backendApi/refund/info/' + refundId,
+ method: 'get'
+ })
+}
+
+// 订单退款
+export function doRefund(data) {
+ return request({
+ url: 'backendApi/refund/doRefund',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除退款订单
+export function deleteRefund(refundId) {
+ return request({
+ url: 'backendApi/refund/delete/' + refundId,
+ method: 'get'
+ })
+}
+
+// 保存退款订单
+export function saveRefund(data) {
+ return request({
+ url: 'backendApi/refund/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/settlement.js b/fuintAdmin/src/api/settlement.js
new file mode 100644
index 0000000..a14a760
--- /dev/null
+++ b/fuintAdmin/src/api/settlement.js
@@ -0,0 +1,39 @@
+import request from '@/utils/request'
+
+// 分页查询结算列表
+export function getSettlementList(query) {
+ return request({
+ url: 'backendApi/settlement/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询结算详情
+export function getSettlementInfo(query) {
+ return request({
+ url: 'backendApi/settlement/info/',
+ method: 'get',
+ params: query
+ })
+}
+
+// 提交结算
+export function doSubmit(data) {
+ return request({
+ url: 'backendApi/settlement/doSubmit',
+ method: 'post',
+ data: data
+ })
+}
+
+// 提交确认
+export function doConfirm(data) {
+ return request({
+ url: 'backendApi/settlement/doConfirm',
+ method: 'post',
+ data: data
+ })
+}
+
+
diff --git a/fuintAdmin/src/api/smsManager.js b/fuintAdmin/src/api/smsManager.js
new file mode 100644
index 0000000..886ad2f
--- /dev/null
+++ b/fuintAdmin/src/api/smsManager.js
@@ -0,0 +1,19 @@
+import request from '@/utils/request'
+
+// 分页查询短信列表
+export function getSmsList(query) {
+ return request({
+ url: 'backendApi/smsManager/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 发送短信
+export function sendSms(data) {
+ return request({
+ url: 'backendApi/smsManager/send',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/smsTemplate.js b/fuintAdmin/src/api/smsTemplate.js
new file mode 100644
index 0000000..9b49c3e
--- /dev/null
+++ b/fuintAdmin/src/api/smsTemplate.js
@@ -0,0 +1,48 @@
+import request from '@/utils/request'
+
+// 分页查询短信模板列表
+export function getSmsTemplateList(query) {
+ return request({
+ url: 'backendApi/smsTemplate/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询信息
+export function getSmsTemplateInfo(id) {
+ return request({
+ url: 'backendApi/smsTemplate/info/' + id,
+ method: 'get'
+ })
+}
+
+// 更新状态
+export function updateSmsTemplateStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/smsTemplate/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除短信模板
+export function deleteSmsTemplate(id) {
+ return request({
+ url: 'backendApi/smsTemplate/delete/' + id,
+ method: 'get'
+ })
+}
+
+// 保存数据
+export function saveSmsTemplate(data) {
+ return request({
+ url: 'backendApi/smsTemplate/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/staff.js b/fuintAdmin/src/api/staff.js
new file mode 100644
index 0000000..b7bc210
--- /dev/null
+++ b/fuintAdmin/src/api/staff.js
@@ -0,0 +1,56 @@
+import request from '@/utils/request'
+
+// 查询员工列表
+export function getStaffList(query) {
+ return request({
+ url: 'backendApi/staff/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询员工信息
+export function getStaffInfo(staffId) {
+ return request({
+ url: 'backendApi/staff/info/' + staffId,
+ method: 'get'
+ })
+}
+
+// 删除员工信息
+export function deleteStaff(staffId) {
+ return request({
+ url: 'backendApi/staff/delete/' + staffId,
+ method: 'get'
+ })
+}
+
+// 获取店铺员工列表
+export function getStoreStaffList(storeId) {
+ return request({
+ url: 'backendApi/staff/storeStaffList/' + storeId,
+ method: 'get'
+ })
+}
+
+// 更新员工状态
+export function updateStaffStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/staff/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存员工信息
+export function saveStaff(data) {
+ return request({
+ url: 'backendApi/staff/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/statistic.js b/fuintAdmin/src/api/statistic.js
new file mode 100644
index 0000000..0c1c93e
--- /dev/null
+++ b/fuintAdmin/src/api/statistic.js
@@ -0,0 +1,27 @@
+import request from '@/utils/request'
+
+// 获取看板数据
+export function getMainData(params) {
+ return request({
+ url: 'backendApi/statistic/main',
+ method: 'post',
+ data: params
+ })
+}
+
+// 获取排行榜数据
+export function getTopData(params) {
+ return request({
+ url: 'backendApi/statistic/top',
+ method: 'post',
+ data: params
+ })
+}
+
+// 获取总会员数量
+export function getTotalMember() {
+ return request({
+ url: 'backendApi/statistic/totalMember',
+ method: 'get'
+ })
+}
diff --git a/fuintAdmin/src/api/stock.js b/fuintAdmin/src/api/stock.js
new file mode 100644
index 0000000..fac99fa
--- /dev/null
+++ b/fuintAdmin/src/api/stock.js
@@ -0,0 +1,40 @@
+import request from '@/utils/request'
+
+// 分页查询库存管理记录列表
+export function getStockList(query) {
+ return request({
+ url: 'backendApi/stock/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 删除库存管理记录
+export function deleteStock(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/stock/delete',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存库存管理记录
+export function saveStock(data) {
+ return request({
+ url: 'backendApi/stock/save',
+ method: 'post',
+ data: data
+ })
+}
+
+// 获取库存管理记录详情
+export function getStockInfo(cateId) {
+ return request({
+ url: 'backendApi/stock/info/' + cateId,
+ method: 'get'
+ })
+}
diff --git a/fuintAdmin/src/api/store.js b/fuintAdmin/src/api/store.js
new file mode 100644
index 0000000..8f7b51c
--- /dev/null
+++ b/fuintAdmin/src/api/store.js
@@ -0,0 +1,49 @@
+import request from '@/utils/request'
+
+// 分页查询店铺列表
+export function getStoreList(query) {
+ return request({
+ url: 'backendApi/store/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询店铺信息
+export function getStoreInfo(storeId) {
+ return request({
+ url: 'backendApi/store/info/' + storeId,
+ method: 'get'
+ })
+}
+
+// 查询店铺列表
+export function searchStore(param) {
+ return request({
+ url: 'backendApi/store/searchStore',
+ method: 'get',
+ params: param
+ })
+}
+
+// 更新店铺状态
+export function updateStoreStatus(storeId, status) {
+ const data = {
+ storeId,
+ status
+ }
+ return request({
+ url: 'backendApi/store/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存店铺
+export function saveStore(data) {
+ return request({
+ url: 'backendApi/store/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/subMessage.js b/fuintAdmin/src/api/subMessage.js
new file mode 100644
index 0000000..1aeea5e
--- /dev/null
+++ b/fuintAdmin/src/api/subMessage.js
@@ -0,0 +1,48 @@
+import request from '@/utils/request'
+
+// 分页查询订阅消息列表
+export function getSubMessageList(query) {
+ return request({
+ url: 'backendApi/subMessage/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询信息
+export function getSubMessageInfo(id) {
+ return request({
+ url: 'backendApi/subMessage/info/' + id,
+ method: 'get'
+ })
+}
+
+// 更新状态
+export function updateSubMessageStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/subMessage/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除订阅消息
+export function deleteSubMessage(id) {
+ return request({
+ url: 'backendApi/subMessage/delete/' + id,
+ method: 'get'
+ })
+}
+
+// 保存数据
+export function saveSubMessage(data) {
+ return request({
+ url: 'backendApi/subMessage/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/api/system/account.js b/fuintAdmin/src/api/system/account.js
new file mode 100644
index 0000000..5820135
--- /dev/null
+++ b/fuintAdmin/src/api/system/account.js
@@ -0,0 +1,127 @@
+import request from '@/utils/request'
+import { parseStrEmpty } from "@/utils/fuint";
+
+// 查询用户列表
+export function getAccountList(query) {
+ return request({
+ url: 'backendApi/account/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询用户详细
+export function getAccount(userId) {
+ return request({
+ url: 'backendApi/account/info/' + parseStrEmpty(userId),
+ method: 'get'
+ })
+}
+
+// 新增用户
+export function addAccount(data) {
+ return request({
+ url: 'backendApi/account/doCreate',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改用户
+export function updateAccount(data) {
+ return request({
+ url: 'backendApi/account/update',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除用户
+export function delAccount(userId) {
+ return request({
+ url: 'backendApi/account/delete/' + userId,
+ method: 'get'
+ })
+}
+
+// 用户密码重置
+export function resetAccountPwd(userId, password) {
+ const data = {
+ userId,
+ password
+ }
+ return request({
+ url: 'backendApi/account/resetPwd',
+ method: 'post',
+ data: data
+ })
+}
+
+// 用户状态修改
+export function changeAccountStatus(userId, status) {
+ const data = {
+ userId,
+ status
+ }
+ return request({
+ url: 'backendApi/account/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 查询用户个人信息
+export function getAccountProfile() {
+ return request({
+ url: 'backendApi/account/profile',
+ method: 'get'
+ })
+}
+
+// 修改用户个人信息
+export function updateAccountProfile(data) {
+ return request({
+ url: 'backendApi/account/profile',
+ method: 'post',
+ data: data
+ })
+}
+
+// 用户密码重置
+export function updateAccountPwd(oldPassword, newPassword) {
+ const data = {
+ oldPassword,
+ newPassword
+ }
+ return request({
+ url: 'backendApi/account/profile/updatePwd',
+ method: 'post',
+ params: data
+ })
+}
+
+// 用户头像上传
+export function uploadAvatar(data) {
+ return request({
+ url: 'backendApi/account/profile/avatar',
+ method: 'post',
+ data: data
+ })
+}
+
+// 查询授权角色
+export function getAuthRole(userId) {
+ return request({
+ url: 'backendApi/account/authRole/' + userId,
+ method: 'get'
+ })
+}
+
+// 保存授权角色
+export function updateAuthRole(data) {
+ return request({
+ url: 'backendApi/account/authRole',
+ method: 'post',
+ params: data
+ })
+}
diff --git a/fuintAdmin/src/api/system/config.js b/fuintAdmin/src/api/system/config.js
new file mode 100644
index 0000000..a404d82
--- /dev/null
+++ b/fuintAdmin/src/api/system/config.js
@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询参数列表
+export function listConfig(query) {
+ return request({
+ url: '/system/config/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询参数详细
+export function getConfig(configId) {
+ return request({
+ url: '/system/config/' + configId,
+ method: 'get'
+ })
+}
+
+// 根据参数键名查询参数值
+export function getConfigKey(configKey) {
+ return request({
+ url: '/system/config/configKey/' + configKey,
+ method: 'get'
+ })
+}
+
+// 新增参数配置
+export function addConfig(data) {
+ return request({
+ url: '/system/config',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改参数配置
+export function updateConfig(data) {
+ return request({
+ url: '/system/config',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除参数配置
+export function delConfig(configId) {
+ return request({
+ url: '/system/config/' + configId,
+ method: 'delete'
+ })
+}
+
+// 刷新参数缓存
+export function refreshCache() {
+ return request({
+ url: '/system/config/refreshCache',
+ method: 'delete'
+ })
+}
diff --git a/fuintAdmin/src/api/system/dict/data.js b/fuintAdmin/src/api/system/dict/data.js
new file mode 100644
index 0000000..6c9eb79
--- /dev/null
+++ b/fuintAdmin/src/api/system/dict/data.js
@@ -0,0 +1,52 @@
+import request from '@/utils/request'
+
+// 查询字典数据列表
+export function listData(query) {
+ return request({
+ url: '/system/dict/data/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询字典数据详细
+export function getData(dictCode) {
+ return request({
+ url: '/system/dict/data/' + dictCode,
+ method: 'get'
+ })
+}
+
+// 根据字典类型查询字典数据信息
+export function getDicts(dictType) {
+ return request({
+ url: '/system/dict/data/type/' + dictType,
+ method: 'get'
+ })
+}
+
+// 新增字典数据
+export function addData(data) {
+ return request({
+ url: '/system/dict/data',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改字典数据
+export function updateData(data) {
+ return request({
+ url: '/system/dict/data',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除字典数据
+export function delData(dictCode) {
+ return request({
+ url: '/system/dict/data/' + dictCode,
+ method: 'delete'
+ })
+}
diff --git a/fuintAdmin/src/api/system/dict/type.js b/fuintAdmin/src/api/system/dict/type.js
new file mode 100644
index 0000000..a7a6e01
--- /dev/null
+++ b/fuintAdmin/src/api/system/dict/type.js
@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询字典类型列表
+export function listType(query) {
+ return request({
+ url: '/system/dict/type/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询字典类型详细
+export function getType(dictId) {
+ return request({
+ url: '/system/dict/type/' + dictId,
+ method: 'get'
+ })
+}
+
+// 新增字典类型
+export function addType(data) {
+ return request({
+ url: '/system/dict/type',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改字典类型
+export function updateType(data) {
+ return request({
+ url: '/system/dict/type',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除字典类型
+export function delType(dictId) {
+ return request({
+ url: '/system/dict/type/' + dictId,
+ method: 'delete'
+ })
+}
+
+// 刷新字典缓存
+export function refreshCache() {
+ return request({
+ url: '/system/dict/type/refreshCache',
+ method: 'delete'
+ })
+}
+
+// 获取字典选择框列表
+export function optionselect() {
+ return request({
+ url: '/system/dict/type/optionselect',
+ method: 'get'
+ })
+}
\ No newline at end of file
diff --git a/fuintAdmin/src/api/system/genCode.js b/fuintAdmin/src/api/system/genCode.js
new file mode 100644
index 0000000..e678359
--- /dev/null
+++ b/fuintAdmin/src/api/system/genCode.js
@@ -0,0 +1,48 @@
+import request from '@/utils/request'
+
+// 分页查询生成代码列表
+export function getGenCodeList(query) {
+ return request({
+ url: 'backendApi/genCode/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询生成代码信息
+export function getGenCodeInfo(id) {
+ return request({
+ url: 'backendApi/genCode/info/' + id,
+ method: 'get'
+ })
+}
+
+// 更新生成代码状态
+export function updateGenCodeStatus(id, status) {
+ const data = {
+ id,
+ status
+ }
+ return request({
+ url: 'backendApi/genCode/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 保存生成代码
+export function saveGenCode(data) {
+ return request({
+ url: 'backendApi/genCode/save',
+ method: 'post',
+ data: data
+ })
+}
+
+// 执行生成代码
+export function doGenCode(id) {
+ return request({
+ url: 'backendApi/genCode/gen/' + id,
+ method: 'get'
+ })
+}
diff --git a/fuintAdmin/src/api/system/logs.js b/fuintAdmin/src/api/system/logs.js
new file mode 100644
index 0000000..69ceb25
--- /dev/null
+++ b/fuintAdmin/src/api/system/logs.js
@@ -0,0 +1,18 @@
+import request from '@/utils/request'
+
+// 查询操作日志列表
+export function list(query) {
+ return request({
+ url: 'backendApi/actlog/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 删除操作日志
+export function delOperlog(logId) {
+ return request({
+ url: 'backendApi/actlog/delete/' + logId,
+ method: 'get'
+ })
+}
diff --git a/fuintAdmin/src/api/system/menu.js b/fuintAdmin/src/api/system/menu.js
new file mode 100644
index 0000000..0c5dd33
--- /dev/null
+++ b/fuintAdmin/src/api/system/menu.js
@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询菜单列表
+export function listMenu(query) {
+ return request({
+ url: 'backendApi/source/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询菜单详细
+export function getMenu(menuId) {
+ return request({
+ url: 'backendApi/source/info/' + menuId,
+ method: 'get'
+ })
+}
+
+// 查询菜单下拉树结构
+export function treeselect() {
+ return request({
+ url: 'backendApi/source/treeselect',
+ method: 'get'
+ })
+}
+
+// 根据角色ID查询菜单下拉树结构
+export function roleMenuTreeselect(roleId) {
+ return request({
+ url: 'backendApi/source/roleMenuTreeselect/' + roleId,
+ method: 'get'
+ })
+}
+
+// 新增菜单
+export function addMenu(data) {
+ return request({
+ url: 'backendApi/source/add',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改菜单
+export function updateMenu(data) {
+ return request({
+ url: 'backendApi/source/update',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除菜单
+export function delMenu(menuId) {
+ return request({
+ url: 'backendApi/source/delete/' + menuId,
+ method: 'get'
+ })
+}
diff --git a/fuintAdmin/src/api/system/notice.js b/fuintAdmin/src/api/system/notice.js
new file mode 100644
index 0000000..c274ea5
--- /dev/null
+++ b/fuintAdmin/src/api/system/notice.js
@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询公告列表
+export function listNotice(query) {
+ return request({
+ url: '/system/notice/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询公告详细
+export function getNotice(noticeId) {
+ return request({
+ url: '/system/notice/' + noticeId,
+ method: 'get'
+ })
+}
+
+// 新增公告
+export function addNotice(data) {
+ return request({
+ url: '/system/notice',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改公告
+export function updateNotice(data) {
+ return request({
+ url: '/system/notice',
+ method: 'put',
+ data: data
+ })
+}
+
+// 删除公告
+export function delNotice(noticeId) {
+ return request({
+ url: '/system/notice/' + noticeId,
+ method: 'delete'
+ })
+}
\ No newline at end of file
diff --git a/fuintAdmin/src/api/system/role.js b/fuintAdmin/src/api/system/role.js
new file mode 100644
index 0000000..8af7673
--- /dev/null
+++ b/fuintAdmin/src/api/system/role.js
@@ -0,0 +1,111 @@
+import request from '@/utils/request'
+
+// 查询角色列表
+export function listRole(query) {
+ return request({
+ url: 'backendApi/duty/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询角色详细
+export function getRole(roleId) {
+ return request({
+ url: 'backendApi/duty/info/' + roleId,
+ method: 'get'
+ })
+}
+
+// 新增角色
+export function addRole(data) {
+ return request({
+ url: 'backendApi/duty/add',
+ method: 'post',
+ data: data
+ })
+}
+
+// 修改角色
+export function updateRole(data) {
+ return request({
+ url: 'backendApi/duty/update',
+ method: 'post',
+ data: data
+ })
+}
+
+// 角色数据权限
+export function dataScope(data) {
+ return request({
+ url: 'backendApi/duty/dataScope',
+ method: 'post',
+ data: data
+ })
+}
+
+// 角色状态修改
+export function changeRoleStatus(roleId, status) {
+ const data = {
+ roleId,
+ status
+ }
+ return request({
+ url: 'backendApi/duty/changeStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除角色
+export function delRole(roleId) {
+ return request({
+ url: 'backendApi/duty/delete/' + roleId,
+ method: 'post'
+ })
+}
+
+// 查询角色已授权用户列表
+export function getRoleUserList(query) {
+ return request({
+ url: 'backendApi/duty/getRoleUserList',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询角色未授权用户列表
+export function unallocatedUserList(query) {
+ return request({
+ url: 'backendApi/duty/authUser/unallocatedList',
+ method: 'get',
+ params: query
+ })
+}
+
+// 取消用户授权角色
+export function authUserCancel(data) {
+ return request({
+ url: 'backendApi/duty/authUser/cancel',
+ method: 'post',
+ data: data
+ })
+}
+
+// 批量取消用户授权角色
+export function authUserCancelAll(data) {
+ return request({
+ url: 'backendApi/duty/authUser/cancelAll',
+ method: 'post',
+ params: data
+ })
+}
+
+// 授权用户选择
+export function authUserSelectAll(data) {
+ return request({
+ url: 'backendApi/duty/authUser/selectAll',
+ method: 'post',
+ params: data
+ })
+}
diff --git a/fuintAdmin/src/api/tool/gen.js b/fuintAdmin/src/api/tool/gen.js
new file mode 100644
index 0000000..4506927
--- /dev/null
+++ b/fuintAdmin/src/api/tool/gen.js
@@ -0,0 +1,76 @@
+import request from '@/utils/request'
+
+// 查询生成表数据
+export function listTable(query) {
+ return request({
+ url: '/tool/gen/list',
+ method: 'get',
+ params: query
+ })
+}
+// 查询db数据库列表
+export function listDbTable(query) {
+ return request({
+ url: '/tool/gen/db/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询表详细信息
+export function getGenTable(tableId) {
+ return request({
+ url: '/tool/gen/' + tableId,
+ method: 'get'
+ })
+}
+
+// 修改代码生成信息
+export function updateGenTable(data) {
+ return request({
+ url: '/tool/gen',
+ method: 'put',
+ data: data
+ })
+}
+
+// 导入表
+export function importTable(data) {
+ return request({
+ url: '/tool/gen/importTable',
+ method: 'post',
+ params: data
+ })
+}
+
+// 预览生成代码
+export function previewTable(tableId) {
+ return request({
+ url: '/tool/gen/preview/' + tableId,
+ method: 'get'
+ })
+}
+
+// 删除表数据
+export function delTable(tableId) {
+ return request({
+ url: '/tool/gen/' + tableId,
+ method: 'delete'
+ })
+}
+
+// 生成代码(自定义路径)
+export function genCode(tableName) {
+ return request({
+ url: '/tool/gen/genCode/' + tableName,
+ method: 'get'
+ })
+}
+
+// 同步数据库
+export function synchDb(tableName) {
+ return request({
+ url: '/tool/gen/synchDb/' + tableName,
+ method: 'get'
+ })
+}
diff --git a/fuintAdmin/src/api/userGrade.js b/fuintAdmin/src/api/userGrade.js
new file mode 100644
index 0000000..0f0b64d
--- /dev/null
+++ b/fuintAdmin/src/api/userGrade.js
@@ -0,0 +1,48 @@
+import request from '@/utils/request'
+
+// 分页查询会员等级列表
+export function getUserGradeList(query) {
+ return request({
+ url: 'backendApi/userGrade/list',
+ method: 'get',
+ params: query
+ })
+}
+
+// 查询等级信息
+export function getUserGradeInfo(memberId) {
+ return request({
+ url: 'backendApi/userGrade/info/' + memberId,
+ method: 'get'
+ })
+}
+
+// 更新状态
+export function updateUserGradeStatus(userGradeId, status) {
+ const data = {
+ userGradeId,
+ status
+ }
+ return request({
+ url: 'backendApi/userGrade/updateStatus',
+ method: 'post',
+ data: data
+ })
+}
+
+// 删除会员等级信息
+export function deleteUserGrade(gradeId) {
+ return request({
+ url: 'backendApi/userGrade/delete/' + gradeId,
+ method: 'get'
+ })
+}
+
+// 保存数据
+export function saveUserGrade(data) {
+ return request({
+ url: 'backendApi/userGrade/save',
+ method: 'post',
+ data: data
+ })
+}
diff --git a/fuintAdmin/src/assets/401_images/401.gif b/fuintAdmin/src/assets/401_images/401.gif
new file mode 100644
index 0000000000000000000000000000000000000000..cd6e0d9433421b3f29d0ec0c40f755e354728000
GIT binary patch
literal 164227
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