添加基础资料下的页面功能
This commit is contained in:
10
miniprogram/pages/base/item/edit/edit.json
Normal file
10
miniprogram/pages/base/item/edit/edit.json
Normal file
@@ -0,0 +1,10 @@
|
||||
{
|
||||
"usingComponents": {
|
||||
"t-cell": "tdesign-miniprogram/cell/cell",
|
||||
"t-textarea": "tdesign-miniprogram/textarea/textarea",
|
||||
"t-input": "tdesign-miniprogram/input/input",
|
||||
"t-radio": "tdesign-miniprogram/radio/radio",
|
||||
"t-radio-group": "tdesign-miniprogram/radio-group/radio-group"
|
||||
},
|
||||
"navigationBarTitleText": "收支项目"
|
||||
}
|
||||
113
miniprogram/pages/base/item/edit/edit.ts
Normal file
113
miniprogram/pages/base/item/edit/edit.ts
Normal file
@@ -0,0 +1,113 @@
|
||||
import { FinanceItemTypeArr } from '@/utils/config';
|
||||
import { loginStatusPage, post } from '@/utils/https';
|
||||
import {
|
||||
cloneLite,
|
||||
getAuthInfo,
|
||||
getDataSet,
|
||||
sleep,
|
||||
toastError,
|
||||
toastSuccess,
|
||||
toObject,
|
||||
} from '@/utils/util';
|
||||
|
||||
const defaultParams = { comments: '', item_name: '', item_type: FinanceItemTypeArr[0].value };
|
||||
|
||||
Page({
|
||||
/**
|
||||
* 页面的初始数据
|
||||
*/
|
||||
data: {
|
||||
params: cloneLite(defaultParams) as any,
|
||||
mode: 'new' as 'new' | 'edit',
|
||||
FinanceItemTypeArr: FinanceItemTypeArr,
|
||||
},
|
||||
handleLogin(e: any) {
|
||||
this.setData({ isLogin: e.detail });
|
||||
if (e.detail) {
|
||||
this.init();
|
||||
}
|
||||
},
|
||||
init() {
|
||||
this.setData({ authInfo: getAuthInfo() });
|
||||
},
|
||||
onChange(e: any) {
|
||||
const key = getDataSet(e).key;
|
||||
const val = e.detail.value;
|
||||
this.data.params[key] = val;
|
||||
this.setData({ params: this.data.params });
|
||||
},
|
||||
onCheckboxChange(e: any) {
|
||||
const key = getDataSet(e).key;
|
||||
this.data.params[key] = e.detail.checked ? 1 : 2;
|
||||
this.setData({ params: this.data.params });
|
||||
},
|
||||
onSave() {
|
||||
// console.log(this.data.params);
|
||||
if (this.data.params.item_name) {
|
||||
post(
|
||||
this.data.mode == 'new' ? 'ErpFinanceItem/add' : 'ErpFinanceItem/edit',
|
||||
this.data.params,
|
||||
).then(() => {
|
||||
toastSuccess('保存成功');
|
||||
sleep(() => {
|
||||
wx.navigateBack();
|
||||
}, 1000);
|
||||
});
|
||||
} else {
|
||||
toastError('项目名称必填');
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面加载
|
||||
*/
|
||||
onLoad(_options) {
|
||||
const eventChannel: any = this.getOpenerEventChannel();
|
||||
eventChannel?.on('itemEdit', (e: any) => {
|
||||
const data = toObject(e.data);
|
||||
// console.log(data);
|
||||
wx.setNavigationBarTitle({
|
||||
title: data.item_id ? `${data.item_name} 修改` : '新增订单类型',
|
||||
});
|
||||
data.item_type = data.item_type ? `${data.item_type}` : FinanceItemTypeArr[0].value;
|
||||
this.setData({ params: data, mode: data.item_id ? 'edit' : 'new' });
|
||||
});
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面初次渲染完成
|
||||
*/
|
||||
onReady() {},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面显示
|
||||
*/
|
||||
onShow() {
|
||||
loginStatusPage(this);
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面隐藏
|
||||
*/
|
||||
onHide() {},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面卸载
|
||||
*/
|
||||
onUnload() {},
|
||||
|
||||
/**
|
||||
* 页面相关事件处理函数--监听用户下拉动作
|
||||
*/
|
||||
onPullDownRefresh() {},
|
||||
|
||||
/**
|
||||
* 页面上拉触底事件的处理函数
|
||||
*/
|
||||
onReachBottom() {},
|
||||
|
||||
/**
|
||||
* 用户点击右上角分享
|
||||
*/
|
||||
onShareAppMessage() {},
|
||||
});
|
||||
24
miniprogram/pages/base/item/edit/edit.wxml
Normal file
24
miniprogram/pages/base/item/edit/edit.wxml
Normal file
@@ -0,0 +1,24 @@
|
||||
<page-plugin isAuth="{{authInfo['SF_ORDER_CATEGORY_VIEW']}}" loading="{{loading}}"
|
||||
is-login="{{isLogin}}" bind:handleLogin="handleLogin">
|
||||
<t-input placeholder="项目名称" focus value="{{params.item_name}}" data-key="item_name"
|
||||
bind:change="onChange" align="right" style="padding-left: 0;padding-right: 0;">
|
||||
<view slot="label" class="required">项目名称 </view>
|
||||
</t-input>
|
||||
<t-cell title="收支类型" align="right" style="padding-left: 0;padding-right: 0;">
|
||||
<view slot="note">
|
||||
<t-radio-group bind:change="onChange" data-key="item_type" borderless="1"
|
||||
value="{{params.item_type}}">
|
||||
<t-radio wx:for="{{FinanceItemTypeArr}}" wx:key="value" block="{{false}}"
|
||||
label="{{item.label}}" value="{{item.value}}"
|
||||
style="margin-right: {{index == FinanceItemTypeArr.length-1 ? 0: 16}}rpx;" />
|
||||
</t-radio-group>
|
||||
</view>
|
||||
</t-cell>
|
||||
<t-textarea placeholder="备注" bordered style="margin-top: 16rpx;" value="{{params.comments}}"
|
||||
data-key="comments" bind:change="onChange">
|
||||
<view slot="label" class="textarea-label">备注</view>
|
||||
</t-textarea>
|
||||
<view style="margin-top: 32rpx;display: flex;justify-content: center;">
|
||||
<t-button theme="primary" bind:tap="onSave">保存</t-button>
|
||||
</view>
|
||||
</page-plugin>
|
||||
0
miniprogram/pages/base/item/edit/edit.wxss
Normal file
0
miniprogram/pages/base/item/edit/edit.wxss
Normal file
Reference in New Issue
Block a user