| | |
| | | window.apiRoot = 'http://115.29.185.26:5101' |
| | | window.skinRoot = '/skin' |
| | | window.skinRoot = '/vue/skin' |
| | |
| | | </template> |
| | | </Menu> |
| | | </div> |
| | | <div class="view-wrap"> |
| | | <div class="navigator"> |
| | | <Tag |
| | | v-for="(view, index) in openedViewList" |
| | | :key="index" |
| | | type="dot" |
| | | :closable="openedViewList.length > 1" |
| | | :color="view.query.menuId == activeName ? 'primary' : ''" |
| | | @click="onMenuClick(view.query.menuId)" |
| | | @on-close="onMenuClose(index)" |
| | | >{{ view.title }}</Tag |
| | | > |
| | | </div> |
| | | <div class="view"> |
| | | <RouterView v-slot="{ Component }"> |
| | | <template v-if="Component"> |
| | |
| | | </KeepAlive> |
| | | </template> |
| | | </RouterView> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | |
| | | logo: "", |
| | | avatar: "http://115.29.185.26:5101/userphoto?login=sa", |
| | | userName: "用户名", |
| | | openedViewList: [], |
| | | }; |
| | | }, |
| | | computed: { |
| | |
| | | this.refMenu.updateOpened(); |
| | | }); |
| | | |
| | | let menuTitle = this.viewList.find((v) => v.id == id)?.title; |
| | | |
| | | this.$router.push({ |
| | | name: route.name, |
| | | query: { |
| | | menuId: id, |
| | | }, |
| | | }); |
| | | if (!this.openedViewList.find((view) => view.query.menuId == id)) |
| | | this.openedViewList.push({ |
| | | name: route.name, |
| | | query: { |
| | | menuId: id, |
| | | }, |
| | | title: menuTitle, |
| | | }); |
| | | }, |
| | | onMenuClose(index) { |
| | | let nextId; |
| | | if (index > 0) nextId = this.openedViewList[index - 1].query.menuId; |
| | | else nextId = this.openedViewList[index + 1].query.menuId; |
| | | this.openedViewList.splice(index, 1); |
| | | this.onMenuClick(nextId); |
| | | }, |
| | | showError(ex) { |
| | | showError(this, ex); |
| | |
| | | display: none; |
| | | } |
| | | } |
| | | .view { |
| | | .view-wrap { |
| | | width: calc(100% - 240px); |
| | | height: 100%; |
| | | .navigator { |
| | | height: 40px; |
| | | padding: 0 9px; |
| | | background-color: #f1f1f1; |
| | | .ivu-tag { |
| | | margin-top: 4px; |
| | | margin-right: 9px; |
| | | cursor: pointer; |
| | | } |
| | | } |
| | | .view { |
| | | height: calc(100% - 40px); |
| | | } |
| | | } |
| | | } |
| | | } |
| | |
| | | <div class="account-logo"> |
| | | <img src="http://115.29.185.26:5101/userphoto?login=sa" /> |
| | | </div> |
| | | <article class="ivu-typography ivu-text-center ivu-mt"> |
| | | <h1 class="ivu-typography">Vue Template<!----></h1> |
| | | <div class="ivu-typography"> |
| | | 基于 Vue3.0、VueRouter 和ViewUIPlus的管理系统模板演示 |
| | | <!----> |
| | | </div> |
| | | </article> |
| | | <Form |
| | | class="account-form" |
| | | :model="form" |
| | |
| | | label-position="top" |
| | | ref="refFormInline" |
| | | > |
| | | <div class="title">Vue仓库管理系统</div> |
| | | <div class="ivu-login"> |
| | | <FormItem prop="user"> |
| | | <Input |
| | | type="text" |
| | | v-model="form.user" |
| | | size="large" |
| | | prefix="ios-person-outline" |
| | | > |
| | | </Input> |
| | |
| | | <Input |
| | | type="password" |
| | | v-model="form.password" |
| | | size="large" |
| | | prefix="ios-lock-outline" |
| | | > |
| | | </Input> |
| | | </FormItem> |
| | | <FormItem> |
| | | <Button type="primary" @click="onSignIn" size="large" long |
| | | >登录</Button |
| | | > |
| | | <Button type="primary" @click="onSignIn" long>登录</Button> |
| | | </FormItem> |
| | | </div> |
| | | </Form> |
| | |
| | | background-image: url("../../assets/login_bg.png"); |
| | | background-attachment: fixed; |
| | | .login-wrap { |
| | | display: -webkit-box; |
| | | display: -ms-flexbox; |
| | | display: flex; |
| | | -webkit-box-orient: vertical; |
| | | -webkit-box-direction: normal; |
| | | -ms-flex-direction: column; |
| | | flex-direction: column; |
| | | height: 100vh; |
| | | overflow: auto; |
| | | } |
| | | .login-account { |
| | | -webkit-box-flex: 1; |
| | | -ms-flex: 1; |
| | | flex: 1; |
| | | width: 280px; |
| | | padding: 16px 0 0; |
| | | max-width: 420px; |
| | | margin: 0 auto; |
| | | margin: 0 300px 0 auto; |
| | | margin-top: 100px; |
| | | } |
| | | .account-logo { |
| | |
| | | .account-form { |
| | | margin-top: 32px; |
| | | } |
| | | .title { |
| | | font-size: 30px; |
| | | text-align: center; |
| | | margin-bottom: 18px; |
| | | letter-spacing: 3px; |
| | | |
| | | font-weight: bold; |
| | | background: -webkit-linear-gradient(#009df4, #00e9cf); |
| | | -webkit-background-clip: text; |
| | | -webkit-text-fill-color: transparent; |
| | | background-clip: text; |
| | | color: transparent; |
| | | } |
| | | .ivu-login { |
| | | padding: 60px 30px 3px; |
| | | background-image: url("../../assets/account_bg.png"); |
| | | background-repeat: no-repeat; |
| | | background-size: 100% 100%; |
| | | background-position: right bottom; |
| | | } |
| | | .ivu-form-item { |
| | | margin-bottom: 24px; |
| | | vertical-align: top; |
| | | zoom: 1; |
| | | .ivu-icon { |
| | | color: #0ba1f8; |
| | | } |
| | | .ivu-input { |
| | | border: 2px solid #0ba1f8; |
| | | background-color: transparent; |
| | | color: #fff; |
| | | } |
| | | } |
| | | .ivu-form-item-content { |
| | | position: relative; |
| | |
| | | mounted() { |
| | | setTimeout(() => { |
| | | this.$router.replace("/login"); |
| | | }, 3 * 1000); |
| | | }, 0 * 1000); |
| | | }, |
| | | }; |
| | | </script> |
| | |
| | | Object.assign(this.form, data); |
| | | }, |
| | | clear() { |
| | | this.code = ""; |
| | | this.name = ""; |
| | | this.leader = ""; |
| | | this.tel = ""; |
| | | this.topCode = ""; |
| | | this.address = ""; |
| | | this.isThisLevel = false; |
| | | this.isEscrow = false; |
| | | this.isEnable = false; |
| | | this.form.code = ""; |
| | | this.form.name = ""; |
| | | this.form.leader = ""; |
| | | this.form.tel = ""; |
| | | this.form.topCode = ""; |
| | | this.form.address = ""; |
| | | this.form.isThisLevel = false; |
| | | this.form.isEscrow = false; |
| | | this.form.isEnable = false; |
| | | }, |
| | | }, |
| | | watch: { |
| | |
| | | <Row> |
| | | <Col span="6"> |
| | | <FormItem label="仓库编码:"> |
| | | <Input v-model="topForm.WH_Code" size="small"></Input> |
| | | <Input v-model="topForm.code" size="small"></Input> |
| | | </FormItem> |
| | | </Col> |
| | | <Col span="6"> |
| | | <FormItem label="仓库名称:"> |
| | | <Input v-model="topForm.WH_Code" size="small"></Input> |
| | | <Input v-model="topForm.name" size="small"></Input> |
| | | </FormItem> |
| | | </Col> |
| | | <Col span="6"> |
| | | <FormItem label="仓库负责人:"> |
| | | <Input v-model="topForm.WH_Code" size="small"></Input> |
| | | <Input v-model="topForm.leader" size="small"></Input> |
| | | </FormItem> |
| | | </Col> |
| | | <Col span="6"> |
| | | <FormItem label="仓库电话:"> |
| | | <Input v-model="topForm.WH_Code" size="small"></Input> |
| | | <Input v-model="topForm.tel" size="small"></Input> |
| | | </FormItem> |
| | | </Col> |
| | | </Row> |
| | | <Row> |
| | | <Col span="6"> |
| | | <FormItem label="上级仓库编码:"> |
| | | <Input v-model="topForm.WH_Code" size="small"></Input> |
| | | <Input v-model="topForm.topCode" size="small"></Input> |
| | | </FormItem> |
| | | </Col> |
| | | <Col span="6"> |
| | | <FormItem label="地址:"> |
| | | <Input v-model="topForm.WH_Code" size="small"></Input> |
| | | <Input v-model="topForm.address" size="small"></Input> |
| | | </FormItem> |
| | | </Col> |
| | | <Col span="4"> |
| | | <FormItem :label-width="34"> |
| | | <Checkbox v-model="topForm.WH_Code" size="small" |
| | | <Checkbox v-model="topForm.isThisLevel" size="small" |
| | | >是否本级</Checkbox |
| | | > |
| | | </FormItem> |
| | | </Col> |
| | | <Col span="4"> |
| | | <FormItem :label-width="34"> |
| | | <Checkbox v-model="topForm.WH_Code" size="small" |
| | | <Checkbox v-model="topForm.isEscorw" size="small" |
| | | >是否代管</Checkbox |
| | | > |
| | | </FormItem> |
| | | </Col> |
| | | <Col span="4"> |
| | | <FormItem :label-width="34"> |
| | | <Checkbox v-model="topForm.WH_Code" size="small" |
| | | <Checkbox v-model="topForm.isEnable" size="small" |
| | | >是否启用</Checkbox |
| | | > |
| | | </FormItem> |
| | |
| | | </Form> |
| | | </div> |
| | | <div class="buttons"> |
| | | <Button type="warning" size="small">清空查询</Button> |
| | | <Button type="warning" size="small" @click="onClearClick" |
| | | >清空查询</Button |
| | | > |
| | | </div> |
| | | <DataTable |
| | | :tableHeight="tableTopHeight" |
| | |
| | | data() { |
| | | return { |
| | | // 分隔比例 |
| | | split: 0.6, |
| | | split: 0.8, |
| | | // 主表参数定义 |
| | | topColumns: [], |
| | | topData: [], |
| | | tableTopHeight: 0, |
| | | tableBottomHeight: 0, |
| | | topForm: { |
| | | WH_Code: "", |
| | | code: "", |
| | | name: "", |
| | | leader: "", |
| | | tel: "", |
| | | topCode: "", |
| | | address: "", |
| | | isThisLevel: false, |
| | | isEscorw: false, |
| | | isEnable: false, |
| | | }, |
| | | topPage: 1, |
| | | topLimit: 30, |
| | |
| | | // 从表测试数据列表 |
| | | fakeBottomDataList(topDataId) { |
| | | return new Promise((resolve) => { |
| | | let total = Math.floor(Math.random() * 10); |
| | | let total = Math.floor(Math.random() * 10 + 1); |
| | | let fakeList = []; |
| | | for (let i = 0; i < total; i++) { |
| | | let row = { |
| | |
| | | this.topPage = page; |
| | | this.loadTopData(); |
| | | }, |
| | | onClearClick() { |
| | | this.reset(); |
| | | }, |
| | | reset() { |
| | | this.topForm.code = ""; |
| | | this.topForm.name = ""; |
| | | this.topForm.leader = ""; |
| | | this.topForm.tel = ""; |
| | | this.topForm.topCode = ""; |
| | | this.topForm.address = ""; |
| | | this.topForm.isThisLevel = false; |
| | | this.topForm.isEscorw = false; |
| | | this.topForm.isEnable = false; |
| | | }, |
| | | }, |
| | | async mounted() { |
| | | await this.loadTopColumns(); |
| | |
| | | '@': fileURLToPath(new URL('./src', import.meta.url)) |
| | | }, |
| | | }, |
| | | base: '/vue/' |
| | | }) |