|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243 |
- <template>
- <view class="page">
- <view v-if="ready">
- <l-date-picker
- @input="setValue('EmpInfo.Birthday', $event)"
- :value="getValue('EmpInfo.Birthday')"
- :disabled="!edit"
- title="出生日期"
- />
- <l-select
- @input="setValue('EmpInfo.PartyFaceNo', $event)"
- :value="getValue('EmpInfo.PartyFaceNo')"
- :disabled="!edit"
- :range="dataSource.EmpInfo.PartyFaceNo"
- title="政治面貌"
- />
- <l-select
- @input="setValue('EmpInfo.NationalityNo', $event)"
- :value="getValue('EmpInfo.NationalityNo')"
- :disabled="!edit"
- :range="dataSource.EmpInfo.NationalityNo"
- title="民族"
- />
- <l-upload-file
- @input="setValue('EmpInfo.Photo', $event)"
- :value="getValue('EmpInfo.Photo')"
- :readonly="!edit"
- :number="1"
- title="照片上传"
- />
- <l-input
- @input="setValue('EmpInfo.mobile', $event)"
- :value="getValue('EmpInfo.mobile')"
- :disabled="!edit"
- title="电话"
- required
- />
- <l-input
- @input="setValue('EmpInfo.EMail', $event)"
- :value="getValue('EmpInfo.EMail')"
- :disabled="!edit"
- title="邮箱"
- required
- />
- </view
- >
- <view
- v-if="ready"
- class="bg-white margin-tb padding"
- style="padding-top: 0; overflow: hidden"
- >
- <l-button
- v-if="edit"
- @click="action('save')"
- size="lg"
- color="green"
- class="block margin-top"
- block
- >
- 提交保存 </l-button
- >
- <l-button
- v-if="!edit && mode !== 'create'"
- @click="action('edit')"
- size="lg"
- line="orange"
- class="block margin-top"
- block
- >
- 编辑本页 </l-button
- >
- <l-button
- v-if="edit && mode !== 'create'"
- @click="action('reset')"
- size="lg"
- line="red"
- class="block margin-top"
- block
- >
- 取消编辑 </l-button
- >
- </view
- >
- </view
- >
- </template>
-
-
- <script>
- /*
- * 版 本 Learun-ADMS V7.0.3 力软敏捷开发框架(http://www.learun.cn)
- * Copyright (c) 2013-2020 上海力软信息技术有限公司
- * 创建人:超级管理员
- * 日 期:2020-10-19 11:55
- * 描 述:个人信息
- */
- /**
- * 本段代码由移动端代码生成器输出,移动端须 2.2.0 版本及以上可以使用
- * 请在移动端 /pages.json 中的 pages 字段中添加一条记录:
- * { "path": "pages/EducationalAdministration/EmpRegister/single", "style": { "navigationBarTitleText": "表单详情页" } }
- *
- * (navigationBarTitleText 字段为本页面的标题文本,可以修改)
- * (必须自行操作该步骤,力软代码生成器不会自动帮您修改 /pages.json 文件)
- */
- import get from "lodash/get";
- import set from "lodash/set";
- import moment from "moment";
- import customPageMixins from "@/common/custompage.js";
- export default {
- mixins: [customPageMixins],
- data() {
- return {
- // 页面相关参数
- id: null,
- mode: null,
- edit: null,
- ready: false, // 表单数据
- current: {},
- origin: {}, // 表单项数据结构
- scheme: {
- EmpInfo: {
- Birthday: { type: "datetime", title: "出生日期", dateformat: "0" },
- PartyFaceNo: { type: "select", title: "政治面貌", dataSource: "0" },
- NationalityNo: { type: "select", title: "民族", dataSource: "0" },
- Photo: { type: "upload", title: "附件上传" },
- mobile: { type: "text", title: "电话", verify: "MobileOrNull" },
- EMail: { type: "text", title: "邮箱", verify: "EmailOrNull" },
- },
- }, // 数据源
- dataSource: {
- EmpInfo: {
- PartyFaceNo: [],
- NationalityNo: [],
- },
- },
- };
- },
- async onLoad({ type, id }) {
- let userInfo = this.GET_GLOBAL("loginUser");
- if(userInfo.Description!="教师"){
- this.TOAST('请使用教师账号登录!');
- return;
- }
- await this.init("", userInfo.account);
- },
- methods: {
- // 页面初始化
- async init(type, id) {
- this.LOADING("加载数据中...");
- this.id = id;
- this.mode = type;
- this.edit = ["create", "edit"].includes(this.mode); // 拉取表单数据,同时拉取所有来自数据源的选单数据
- await Promise.all([() => {}]);
- await this.fetchForm();
- this.ready = true;
- this.HIDE_LOADING();
- }, // 加载表单数据
- async fetchForm() {
- if (this.mode === "create") {
- this.origin = await this.getDefaultForm();
- } else {
- const result = await this.HTTP_GET(
- "learun/adms/EducationalAdministration/EmpRegister/formForNo",
- this.id
- );
- this.id=result.EmpInfo.EmpId;
- console.log(result);
- this.origin = await this.formatFormData(result);
- }
- this.current = this.COPY(this.origin);
- }, // 点击 「编辑」、「重置」、「保存」、「删除」 按钮
- async action(type) {
- switch (type) {
- case "edit":
- this.edit = true;
- break;
- case "reset":
- this.current = this.COPY(this.origin);
- this.edit = false;
- break;
- case "save":
- const verifyResult = this.verifyForm();
- if (verifyResult.length > 0) {
- this.CONFIRM("表单验证失败", verifyResult.join("\n"));
- return;
- }
- if (
- !(await this.CONFIRM(
- "提交确认",
- "确定要提交本页表单内容吗?",
- true
- ))
- ) {
- return;
- }
- this.LOADING("正在提交...");
- const postData = await this.getPostData(this.id);
- this.HTTP_POST(
- "learun/adms/EducationalAdministration/EmpRegister/save",
- postData,
- "表单提交保存失败"
- ).then((success) => {
- this.HIDE_LOADING();
- if (!success) {
- return;
- }
- this.EMIT("EducationalAdministrationEmpInfo-list-change");
- this.NAV_BACK();
- this.TOAST("提交保存成功");
- });
- break;
- case "delete":
- if (!(await this.CONFIRM("删除项目", "确定要删除本项吗?", true))) {
- return;
- }
- this.LOADING("提交删除中...");
- this.HTTP_POST(
- "learun/adms/EducationalAdministration/EmpRegister/delete",
- this.id,
- "删除失败"
- ).then((success) => {
- this.HIDE_LOADING();
- if (!success) {
- return;
- }
- this.EMIT("EducationalAdministrationEmpInfo-list-change");
- this.NAV_BACK();
- this.this.TOAST("删除成功", "success");
- });
- break;
- default:
- break;
- }
- }, // 获取表单值
- getValue(path) {
- return get(this.current, path);
- }, // 设置表单值
- setValue(path, val) {
- set(this.current, path, val);
- },
- },
- };
- </script>
|