123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680 |
- <template>
- <div class="app-container">
- <el-form ref="form" :model="form" :rules="rules" label-width="130px" border>
- <table width="100%" border="1">
- <tr>
- <td colspan="2"><p class="title">发文起草</p></td>
- </tr>
- <!--<tr>
- <td>
- <el-form-item label="机关待字" prop="senderName">
- <el-select v-model="form.officeNumber" placeholder="请选择">
- <el-option label="001" value=""></el-option>
- <el-option label="002" value=""></el-option>
- </el-select>
- </el-form-item>
- </td>
- <td>
- <el-form-item label="文号" prop="number">
- <el-input v-model="form.number" placeholder="请输入发件人-账号" />
- </el-form-item>
- </td>
- </tr>-->
- <tr>
- <td>
- <el-form-item label="缓急" prop="ponderance">
- <el-select v-model="form.ponderance" placeholder="请选择">
- <el-option label="一般" value="4"></el-option>
- <el-option label="平急" value="3"></el-option>
- <el-option label="加急" value="2"></el-option>
- <el-option label="特急" value="1"></el-option>
- <el-option label="特提" value="0"></el-option>
- </el-select>
- </el-form-item>
- </td>
- <td>
- <el-form-item label="密级" prop="securityClass">
- <el-select v-model="form.securityClass" placeholder="请选择">
- <el-option label="一般" value="3"></el-option>
- <el-option label="秘密" value="2"></el-option>
- <el-option label="机密" value="1"></el-option>
- <el-option label="绝密" value="0"></el-option>
- </el-select>
- </el-form-item>
- </td>
- </tr>
- <tr>
- <td colspan="2">
- <el-form-item label="标题:" prop="fwtitle">
- <el-input v-model="form.fwtitle" type="text" placeholder=""/>
- </el-form-item>
- </td>
- </tr>
- <!--园林局样式-->
- <tr>
- <td colspan="2">
- <el-form-item label="发文字号:" prop="fwtitle">
- <el-input v-model="form.referenceNumber" type="text" placeholder=""/>
- </el-form-item>
- </td>
- </tr>
- <!--<tr>
- <td colspan="2">
- <el-form-item label="部门:" prop="fwdept">
- <!– <el-input v-model="form.fwdept" type="text" placeholder=""/>–>
- <el-input title="选择发文部门" v-model="form.fwdept" placeholder="请选择发文部门" prop="avtiveSend" :disabled="true">
- <template slot="append">
- <el-button
- type="primary"
- icon="el-icon-plus"
- size="mini"
- @click="handleSelectDept">
- 选择发文部门
- </el-button>
- </template>
- </el-input>
- </el-form-item>
- </td>
- </tr>
- <tr>
- <td colspan="2">
- <el-form-item label="主送:" :disabled="true" prop="avtiveSend">
- <el-input v-model="form.avtiveSend" placeholder="请选择主送人" :disabled="true">
- <template slot="append">
- <el-button
- type="primary"
- icon="el-icon-plus"
- size="mini"
- @click="handleSelect(0)">
- 选择主送部门
- </el-button>
- </template>
- </el-input>
- </el-form-item>
- </td>
- </tr>
- <tr>
- <td colspan="2">
- <el-form-item label=" 抄送:" :disabled="true" prop="copyTo" >
- <el-input v-model="form.copyTo" placeholder="请选择抄送人":disabled="true">
- <template slot="append">
- <el-button
- type="primary"
- icon="el-icon-plus"
- size="mini"
- @click="handleSelect(1)">
- 选择抄送部门
- </el-button>
- </template>
- </el-input>
- </el-form-item>
- </td>
- </tr>-->
- <tr>
- <td colspan="2">
- <el-form-item label="上传附件:" prop="accessory">
- <el-upload
- accept=".jpg, .png"
- :action="upload.url"
- :headers="upload.headers"
- :file-list="upload.oldFileList"
- multiple
- :show-file-list="true"
- :on-progress="handleFileUploadProgress"
- :on-preview="handlePreview"
- :http-request="submitUpload"
- :on-remove="handleRemove"
- :before-remove="beforeRemove"
- >
- <el-button slot="trigger" size="small" :loading="upload.isUploading" type="primary">上传文件</el-button>
- <!-- <el-button style="margin-left: 10px;" size="small" type="success" :loading="upload.isUploading" @click="submitUpload">上传文件</el-button>-->
- <div slot="tip" class="el-upload__tip">只能上传文件,且不超过1mb</div>
- </el-upload>
- <ul v-show="!!upload.oldFileList.length" class="old-file-list"></ul>
- </el-form-item>
- </td>
- </tr>
- <tr>
- <td colspan="6">
- <el-form-item label="正文:" prop="content" v-if="contentOpen" :loading="contentOpen">
- <!-- <el-button size="small" type="primary" @click="openIweboffice" v-loading.fullscreen.lock="fullscreenLoading">打开正文</el-button>-->
- <!-- <el-input v-model="form.content" type="primary" placeholder=""/>-->
- <i-web-office :key="timer" @func="getcontent" :fileData="fileData" ></i-web-office>
- </el-form-item>
- </td>
- </tr>
- <tr v-show="false">
- <td>
- <el-form-item label="actkey:" prop="actkey">
- <el-input v-model="form.actkey" type="textarea" placeholder=""/>
- </el-form-item>
- </td>
- </tr>
- </table>
- </el-form>
- <div slot="footer" class="dialog-footer" v-show="open3">
- <el-button type="primary" @click="submitForm(1)">提交</el-button>
- <!-- <el-button type="primary" @click="submitForm(0)">保存草稿</el-button>-->
- <el-button @click="cancel">取 消</el-button>
- </div>
- <div slot="footer" class="dialog-footer" v-show="open4">
- <el-button type="primary" @click="submitToDo()">同意</el-button>
- <el-button type="primary" @click="deleteToDo()">拒绝</el-button>
- <el-button @click="cancel">取 消</el-button>
- </div>
- <!-- <el-dialog id="content" title="正文修改"
- :visible.sync="contentOpen"
- :before-close="cancel1" append-to-body
- width="80%"
- top="10"
- height="900px">
- <i-web-office :key="timer" @func="getcontent" :fileData="fileData" ></i-web-office>
- <span slot="footer" class="dialog-footer">
- <el-button @click="contentOpen = false">取 消</el-button>
- </span>
- </el-dialog>-->
- <!-- <select-user-by-dept ref="selectUserByDept" :title="title" :open="Renopen" @ok="selectOK"/>-->
- <el-dialog :title="title" :visible.sync="deptOpen" width="40%" append-to-body style="size: 30px">
- <el-tree
- :data="deptOptions"
- show-checkbox
- default-expand-all
- ref="dept"
- node-key="id"
- empty-text="加载中,请稍后"
- :props="defaultProps"
- ></el-tree>
- <div slot="footer" class="dialog-footer">
- <el-button type="primary" @click="getDeptAllCheckedKeys">确 定</el-button>
- <el-button @click="cancelDept">取 消</el-button>
- </div>
- </el-dialog>
- </div>
- </template>
- <script>
- import SelectUserByDept from "@/components/SelectRen/selectUserByDept";
- import iWebOffice from "./iWebOffice";
- import SelectRen from '@/components/SelectRen';
- import {treeselect} from "@/api/system/dept";
- import {submitApply, getFormData, deleteToDoItem, submitToDoItem,updateInfo,uploadFujian} from "@/api/activiti/form/fw";
- import Treeselect from "@riophae/vue-treeselect";
- import {getToken} from "@/utils/auth";
- export default {
- components: {
- SelectUserByDept, iWebOffice, SelectRen,
- Treeselect,
- },
- props: {
- data: '',
- actOpen: false,
- },
- data() {
- return {
- Renopen: false,
- receiverName: [],
- timer: '',
- contentOpen: false,
- receiverAccount: [],
- dialogTableVisible: false,
- fullscreenLoading: false,
- //正文的文件地址
- fileData: {
- filePath: '/profile/doc/NewCreate.doc',
- user: 'xxx',
- EditType: '1',
- },
- fileList3: [],
- // 选中数组
- ids: [],
- // 非单个禁用
- single: true,
- // 非多个禁用
- multiple: true,
- // 总条数
- total: 0,
- // 【请填写功能名称】表格数据
- infoList: [],
- // 弹出层标题
- title: "",
- // 是否显示弹出层
- open: false,
- open1: false,
- // 查询参数
- queryParams: {
- pageNum: 1,
- pageSize: 10,
- status: undefined,
- deleteTime: undefined
- },
- // 表单参数
- form: {
- actkey: '',
- content: '',
- fwdept: '',
- referenceNumber: '',
- ponderance: '',
- securityClass: '',
- copyTo: '',
- accessory: '',
- avtiveSend: '',
- }, // 表单参数
- flg: '',
- // 表单校验
- rules: {
- fwtitle: [
- { required: true, message: "标题题不能为空", trigger: "blur" }
- ],
- /*fwdept: [
- { required: true, message: "请选择发文部门", trigger: "blur" }
- ],
- copyTo: [
- { required: true, message: "请选择抄送部门", trigger: "blur" }
- ],
- avtiveSend: [
- { required: true, message: "请选择主送部门", trigger: "blur" }
- ],*/
- ponderance: [
- { required: true, message: "请选择缓急程度", trigger: "blur" }
- ],
- securityClass: [
- { required: true, message: "请选择密级等级", trigger: "blur" }
- ],
- },
- // 判断是否为提交,还是添加
- open3: false,
- // 判断是否为提交,还是添加
- open4: false,
- // 部门
- deptOpen: false,
- // 部门树选项
- deptOptions: [],
- defaultProps: {
- children: "children",
- label: "label"
- },
- // 部门id
- depid: [],
- depname: [],
- deptflgOptions: [{
- "label": "单位",
- "value": 1
- }],
- loading: true,
- // 上传参数
- upload: {
- // 是否禁用上传
- isUploading: false,
- // 设置上传的请求头部
- headers: {Authorization: "Bearer " + getToken()},
- // 上传的地址
- url: process.env.VUE_APP_BASE_API + "/common/upload",
- // 上传的文件列表
- fileList: [],
- oldFileList:[]
- },
- };
- },
- created() {
- //flg 为流程状态,undefined:创建新的流程 1:打开代办中的流程, eles为查看流程详情
- this.flg = this.data.flg;
- //为 启动流程时的key值
- this.form.actkey = this.data.getactkey;
- //加载部门树表
- this.getTreeselect();
- //flg=undefined 新增发文时; flg=1 页面正在流程中;else 查看详情时
- if (this.flg == undefined) {
- this.open3 = true;
- //打开weboffice
- this.contentOpen = true;
- }
- else if (this.flg == '1') {
- this.form = this.data;
- this.getDetails();
- this.open4 = true;
- }
- else {
- this.form = this.data;
- this.getDetails();
- }
- },
- methods: {
- /** 写 选择人员 按钮弹窗操作 */
- handleSelect(type) {
- this.deptOpen = true;
- if (type == 0) {
- this.title = "主送部门";
- } else {
- this.title = "抄送部门";
- }
- }, /** 写 选择人员 按钮弹窗操作 */
- handleSelectDept() {
- this.deptOpen = true;
- this.title = "发文部门";
- },
- /** --------------查询部门下拉树结构---------------- */
- getTreeselect() {
- treeselect().then(response => {
- this.deptOptions = response.data;
- var a = this.deptOptions;
- for (let i = 0; i < a.length; i++) {
- console.log(this.deptOptions[i].children[0].id)
- console.log(a[i].id)
- }
- });
- },
- // 所有部门节点数据
- getDeptAllCheckedKeys() {
- // 目前被选中的部门节点
- let checkedKeys = this.$refs.dept.getHalfCheckedKeys();
- // 半选中的部门节点
- let halfCheckedKeys = this.$refs.dept.getCheckedKeys();
- let a = this.$refs.dept.getCheckedNodes();
- var q = this.deptOptions;
- let e = "";
- for (let w = 0; w < q.length; w++) {
- e += q[w].children[w].id
- }
- for (let i = 0; i < a.length; i++) {
- if (a[i].id != 100 && a[i].id != e) {
- this.depname.push(a[i].label)
- this.depid.push(a[i].id)
- }
- }
- console.log(a)
- checkedKeys.unshift.apply(checkedKeys, halfCheckedKeys);
- // this.form.fwdept =this.depid;
- if (this.title == "主送部门") {
- this.form.avtiveSend = this.depname.toString();
- } else if (this.title == "抄送部门"){
- this.form.copyTo = this.depname.toString();;
- }else {
- this.form.fwdept = this.depname.toString();
- }
- this.deptOpen = false;
- this.depname = [];
- this.depid = [];
- return halfCheckedKeys;
- },
- //返回正文
- getcontent(data) {
- this.contentOpen = false;
- this.form.content = data;
- this.fileData.filePath = data;
- },
- // 文件提交处理
- submitUpload(item) {
- let uploadData = new FormData()
- uploadData.append('file',item.file)
- uploadFujian(uploadData).then(response => {
- if (response.code === 200) {
- this.upload.fileList.push(response.fileName);
- this.form.accessory=this.upload.fileList.toString()
- this.upload.oldFileList.push({
- name: response.fileName.substring(response.fileName.lastIndexOf("/")+1,response.fileName.length),
- url: response.url
- });
- this.msgSuccess("上传成功");
- this.upload.isUploading = false;
- }
- });
- },
- // 文件上传中处理
- handleFileUploadProgress(event, file, fileList) {
- this.upload.isUploading = true;
- },
- handlePreview(file) {
- // 预览,一些文件因为格式问题无法预览。推荐使用a标签,src为文件的下载地址,点击即可下载,参照录音
- window.open(file.url);
- },
- beforeRemove(file, fileList) {
- return this.$confirm(`确定移除 ${ file.name }?`);
- },
- handleRemove(file) {
- // 移除
- this.upload.oldFileList.forEach((item, index) => {
- if (item.uid === file.uid) {
- this.mail.oldFileList.splice(index, 1);
- //删除
- }
- });
- },
- //获取详细信息,修改用到
- getDetails() {
- getFormData(this.form.formId).then(response => {
- this.form = response.data;
- this.fileData.filePath = this.form.content==""?"/profile/doc/NewCreate.doc":this.form.content;
- this.fileData.user = this.form.user;
- //打开weboffice
- this.contentOpen = true;
- if (response.data.accessory!=""){
- var files= response.data.accessory.split(",")
- for (var i=0;i<files.length;i++){
- var fiellist={
- "name":files[i].substring(files[i].lastIndexOf("/")+1,files[i].length),
- "url":process.env.VUE_APP_BASE_API+files[i]
- }
- this.upload.oldFileList.push(fiellist)
- }
- }
- });
- },
- openda() {
- this.open1 = false;
- },
- //打开weboffice 页面添加正文
- openIweboffice() {
- // this.$router.push({path:'/actwork/fw/iweboffice'})
- this.timer = new Date().getTime()
- this.contentOpen = true;
- },
- // 取消按钮
- cancel() {
- this.$emit('getList');
- this.open = false;
- this.reset();
- },
- cancel1(){
- this.contentOpen = false;
- },
- // 表单重置
- reset() {
- this.form = {
- everyone: undefined,
- };
- this.resetForm("form");
- },
- /** 搜索按钮操作 */
- handleQuery() {
- this.queryParams.pageNum = 1;
- // this.getList();
- },
- /** 重置按钮操作 */
- resetQuery() {
- this.resetForm("queryForm");
- this.handleQuery();
- },
- // 多选框选中数据
- handleSelectionChange(selection) {
- this.ids = selection.map(item => item.id)
- this.single = selection.length != 1
- this.multiple = !selection.length
- },
- /** 新增按钮操作 */
- handleAdd() {
- this.reset();
- this.open = true;
- this.title = "公文发文";
- },
- //关闭部门窗口
- cancelDept(){
- this.deptOpen=false;
- },
- /** 修改按钮操作 */
- handleUpdate(row) {
- this.reset();
- const id = row.id || this.ids
- getInfo(id).then(response => {
- this.form = response.data;
- this.open = true;
- this.title = "公文发文";
- });
- },
- handleUpdate1(row) {
- this.reset();
- const id = row.id || this.ids
- getInfo(id).then(response => {
- this.form = response.data;
- this.open1 = true;
- this.title = "公文发文";
- });
- },
- /** 提交按钮 */
- submitForm: function (flg) {
- this.$refs["form"].validate(valid => {
- this.$set(this.form, "sendFlg", flg)
- if (valid) {
- if (this.form.id != undefined) {
- updateInfo(this.form).then(response => {
- if (response.code === 200) {
- this.msgSuccess("修改成功");
- // this.getList();
- }
- });
- } else {
- submitApply(this.form).then(response => {
- console.log(response.code)
- if (response.code === 200) {
- console.log(response.code)
- this.msgSuccess("提交成功");
- // this.open = false;
- this.$emit('transferUser', this.open)
- }
- });
- }
- }
- });
- },
- submitToDo() {
- updateInfo(this.form).then(response => {
- submitToDoItem(this.form.taskid).then(response1 => {
- this.msgSuccess("提交成功");
- console.log(response1.code)
- this.$emit('getList');
- });
- })
- },
- //拒绝按钮
- deleteToDo() {
- this.$confirm('是否确认拒绝这这个申请吗?', '警告', {
- confirmButtonText: '确定',
- cancelButtonText: '取消',
- type: 'warning'
- }).then(() => {
- deleteToDoItem(this.form.taskid).then(response => {
- this.msgSuccess("拒绝成功")
- this.$emit('getList');
- })
- }).catch(() => {
- });
- },
- /** 删除按钮操作 */
- handleDelete(row) {
- const ids = row.id || this.ids;
- this.$confirm('是否确认删除这一封邮件?', "警告", {
- confirmButtonText: "确定",
- cancelButtonText: "取消",
- type: "warning"
- }).then(function () {
- return delInfo(ids);
- }).then(() => {
- // this.getList();
- this.msgSuccess("删除成功");
- }).catch(function () {
- });
- },
- /** 导出按钮操作 */
- handleExport() {
- const queryParams = this.queryParams;
- this.$confirm('是否确认导出所有【请填写功能名称】数据项?', "警告", {
- confirmButtonText: "确定",
- cancelButtonText: "取消",
- type: "warning"
- }).then(function () {
- return exportInfo(queryParams);
- }).then(response => {
- this.download(response.msg);
- }).catch(function () {
- });
- }
- },
- };
- </script>
- <style lang="less" scoped>
- .apple {
- width: 150px;
- overflow: hidden;
- white-space: nowrap;
- text-overflow: ellipsis;
- }
- .title {
- font-size: 30px;
- text-align: center;
- margin-top: 30px;
- }
- .bottom10 {
- margin-bottom: 20px;
- }
- .el-dialog__title {
- text-align: center;
- font-weight: bold;
- }
- table {
- border-collapse: collapse;
- }
- .el-form-item {
- margin-bottom: 10px !important;
- margin-top: 10px;
- }
- .dialog-footer {
- text-align: center;
- margin-top: 20px;
- }
- </style>
|