瀏覽代碼

人日移动端

xujunjie 2 年之前
父節點
當前提交
d38a21c8b9
共有 14 個文件被更改,包括 785 次插入26 次删除
  1. 6 1
      manifest.json
  2. 16 0
      pages.json
  3. 16 0
      pages/Project/edit.vue
  4. 1 1
      pages/Project/list.vue
  5. 181 0
      pages/daily/daily.vue
  6. 224 0
      pages/daily/form.vue
  7. 290 0
      pages/daily/projectDaily.vue
  8. 36 21
      pages/index/index.vue
  9. 1 1
      pages/login/login.vue
  10. 11 0
      services/daily.js
  11. 2 1
      services/request.js
  12. 二進制
      static/btn-bg.png
  13. 二進制
      static/triangle@2x.png
  14. 1 1
      utils/listMixin.js

+ 6 - 1
manifest.json

@@ -58,7 +58,12 @@
     "h5" : {
         "devServer" : {
             "https" : false,
-            "port" : ""
+            "proxy" : {
+                "/api" : {
+                    "changeOrigin" : true,
+                    "target" : "http://47.96.12.136:8888"
+                }
+            }
         },
         "router" : {
             "base" : ""

+ 16 - 0
pages.json

@@ -28,6 +28,22 @@
         }
       }
     },
+    {
+      "path": "pages/daily/daily",
+      "style": {
+        "enablePullDownRefresh": true,
+        "pullToRefresh": {
+          "color": "#2979ff",
+          "offset": "60px"
+        }
+      }
+    },
+    {
+      "path": "pages/daily/form"
+    },
+    {
+      "path": "pages/daily/projectDaily"
+    },
     {
       "path": "pages/Project/add"
     },

+ 16 - 0
pages/Project/edit.vue

@@ -8,6 +8,7 @@
           </view>
           <view class="edit" v-if="canEdit(0)" @click="onEdit">编辑</view>
           <view class="edit" v-if="canEdit(0)" @click="onDelete">删除</view>
+          <view class="edit" @click="onDaily">项目日志</view>
           <view class="edit" v-if="canEdit(0)" @click="onSubmitAuth">
             提交审核
           </view>
@@ -29,6 +30,10 @@
           <view class="edit" v-if="canAuth()" @click="onHandleAudit(0)">
             审核拒绝
           </view>
+          <view class="edit empty">
+          </view>
+          <view class="edit empty">
+          </view>
         </view>
       </uni-card>
     </view>
@@ -174,6 +179,11 @@ export default {
       this.$emit("canEdit", toRet);
       return toRet;
     },
+    onDaily() {
+      uni.navigateTo({
+        url: `/pages/daily/projectDaily?project_id=${this.project.id}`,
+      });
+    },
     hideHelper() {
       setTimeout(() => {
         uni.hideToast();
@@ -479,6 +489,12 @@ export default {
     text-align: center;
     border-radius: 10rpx;
     box-shadow: 0 2rpx 2rpx #666;
+    &.empty {
+      visibility: hidden;
+      height: 1;
+      margin: 0;
+      opacity: 0;
+    }
   }
 }
 

+ 1 - 1
pages/Project/list.vue

@@ -170,7 +170,7 @@ export default {
         this.depRole = dep.Role;
       }
     },
-    async getProject(params) {
+    async getList(params) {
       let res = {};
       if (this.auth) res = await queryAuth(params);
       else res = await queryProject(params);

+ 181 - 0
pages/daily/daily.vue

@@ -0,0 +1,181 @@
+<template>
+  <view class="page">
+    <view class="content">
+      <view class="head">
+        <span class="title">项目列表</span>
+        <navigator
+          url="/pages/daily/form"
+          class="self"
+          open-type="navigate"
+          hover-class="navigator-hover"
+        >
+          写日志
+        </navigator>
+      </view>
+      <uni-search-bar
+        bgColor="#FFFFFF"
+        :radius="20"
+        placeholder="请输入日志标题"
+        v-model="searchKeyword"
+        @confirm="handelSearchConfirm"
+      />
+      <scroll-view
+        class="list"
+        :scroll-top="scrollTop"
+        scroll-y="true"
+        @scrolltolower="scrollToLower()"
+      >
+        <view class="item" v-for="item in list" :key="item.log_id">
+          <view class="time">07-12 8:50</view>
+          <view class="box">
+            <view class="title">张三的金科环境项目日志</view>
+            <view class="desc">
+              <view class="desc-title">日志概述:</view>
+              <view class="desc-content">
+                项目进展顺利项目进展顺利项目进项目进展顺利项目进展顺利项目进
+              </view>
+            </view>
+          </view>
+        </view>
+        <view class="loadmore">{{ loadMoreText }}</view>
+      </scroll-view>
+    </view>
+  </view>
+</template>
+
+<script>
+import { queryDaily } from "@/services/daily";
+import mixin from "@/utils/listMixin";
+
+export default {
+  mixins: [mixin],
+  data() {
+    return {
+      searchKeyword: "",
+      scrollTop: 0,
+      loadMoreText: '',
+      list: [],
+    };
+  },
+  onShow() {
+    this.pagination.currentPage = 1
+    this.initData()
+  },
+  methods: {
+
+    handelSearchConfirm() {},
+    scrollToLower() {
+      if (this.projectList.length >= this.pagination.total) {
+        this.loadMoreText = "没有更多数据了";
+        return;
+      }
+      this.pagination.currentPage++;
+      this.initData();
+    },
+    async getList(params){
+      let res = await queryDaily(params)
+      this.list = res.data.list
+      return res.data
+    }
+  },
+};
+</script>
+
+<style lang="less" scoped>
+.content {
+  display: flex;
+  justify-content: center;
+  flex-wrap: wrap;
+  padding-top: 150rpx;
+  ::v-deep {
+    .uni-searchbar {
+      width: 100%;
+      .uni-searchbar__box {
+        border: 1px solid #ccc;
+      }
+    }
+  }
+}
+.head {
+  width: calc(100% - 60rpx);
+  padding: 40rpx;
+  position: fixed;
+  background: url("~@/static/app-plus/menu-title-bg.png") no-repeat center;
+  background-size: 100% 100%;
+  background-color: #fff;
+  display: flex;
+  justify-content: space-between;
+  align-items: center;
+  z-index: 1;
+  top: 0;
+  .title {
+    font: 18px bold;
+    color: #fff;
+  }
+  .self {
+    font: 14px;
+    padding-left: 20rpx;
+    color: #fff;
+  }
+}
+.list {
+  width: 90%;
+  height: calc(90vh - 130rpx);
+  ::v-deep {
+    .uni-list--border-top {
+      background-color: transparent;
+    }
+    .uni-list-item__container {
+      padding: 12rpx 30rpx;
+    }
+  }
+}
+.loadmore {
+  padding: 30rpx 0px;
+  font-size: 16px;
+  color: gray;
+  text-align: center;
+}
+.item {
+  margin-top: 20rpx;
+  .time {
+    padding-left: 25rpx;
+    font-size: 24rpx;
+    color: #7a7a7a;
+    line-height: 32rpx;
+    margin-bottom: 10rpx;
+  }
+  .box {
+    padding: 40rpx;
+    border-radius: 5rpx;
+    border: 1px solid #ccc;
+    box-shadow: 0 1rpx 4rpx rgba(255, 255, 255, 0.2);
+    .title {
+      font-size: 28rpx;
+      font-weight: 400;
+      color: #4a90e2;
+      line-height: 40rpx;
+      margin-bottom: 18rpx;
+    }
+    .desc {
+      display: flex;
+      font-size: 28rpx;
+      font-weight: 400;
+      color: #4a4a4a;
+      line-height: 40rpx;
+      .desc-title {
+        flex-shrink: 1;
+      }
+      .desc-content {
+        flex: 1;
+        display: -webkit-box;
+        -webkit-line-clamp: 2; /* 显示的行数 */
+        -webkit-box-orient: vertical;
+        overflow: hidden;
+        text-overflow: ellipsis;
+        white-space: normal;
+      }
+    }
+  }
+}
+</style>

+ 224 - 0
pages/daily/form.vue

@@ -0,0 +1,224 @@
+<template>
+  <view class="page">
+    <view class="content">
+      <view class="head">
+        <span class="title">写日志</span>
+      </view>
+
+      <view class="forms">
+        <view class="title2">张三的金科环境项目日志</view>
+        <view class="title-sub">日志详情</view>
+        <uni-forms
+          :modelValue="formData"
+          label-position="left"
+          class="form"
+          ref="form"
+          :rules="rules"
+        >
+          <view class="box" v-for="item in formData" :key="item.key">
+            <view
+              v-show="formData.length > 1"
+              class="btn-remove"
+              @click="removeFormData(item.key)"
+              >-</view
+            >
+            <uni-forms-item
+              required
+              label="项目名称"
+              name="project_name"
+              class="formItem"
+              v-if="!project_id"
+            >
+              <picker
+                @change="selectProjectList"
+                :range="projectList"
+                :range-key="'name'"
+              >
+                <!-- <view class="select" v-if="formData.industry">
+                {{ `${formData.industry.name}(${formData.industry.code})` }}
+              </view> -->
+                <view class="selectPlaceholder">请选择项目</view>
+              </picker>
+            </uni-forms-item>
+            <uni-forms-item
+              required
+              label="日志概述"
+              name="project_name"
+              class="formItem"
+            >
+              <input
+                v-model="formData.project_name"
+                class="input"
+                placeholder="请输入日志概述"
+              />
+            </uni-forms-item>
+            <uni-forms-item
+              required
+              label="日志详情"
+              name="project_name"
+              class="formItem"
+            >
+              <textarea class="textarea" placeholder="请输入日志详情" />
+            </uni-forms-item>
+          </view>
+        </uni-forms>
+        <view class="btn-add" @click="addFormData">+ 新增</view>
+      </view>
+      <view class="button">提 交</view>
+    </view>
+  </view>
+</template>
+
+<script>
+export default {
+  data() {
+    return {
+      scrollTop: 0,
+      projectList: [],
+      project_id: '',
+      formData: [
+        {
+          key: +new Date(),
+          project_name: "",
+        },
+      ],
+      rules: {
+        project_name: {
+          rules: [
+            {
+              required: true,
+              errorMessage: "请选择项目名称",
+            },
+          ],
+        },
+      },
+    };
+  },
+  onLoad(options) {
+    this.project_id = options.project_id;
+  },
+  methods: {
+    selectProjectList(e) {
+      // this.formData.version = e.target.value + 1;
+      // this.formData.code.version = this.formData.version + "";
+      // this.binddata("version", e.target.value);
+    },
+    addFormData() {
+      this.formData.push({
+        key: +new Date(),
+        project_name: "",
+      });
+    },
+    removeFormData(key) {
+      let index = this.formData.findIndex((item) => item.key == key);
+      this.formData.splice(index, 1);
+    },
+  },
+};
+</script>
+
+<style lang="less" scoped>
+.head {
+  width: calc(100% - 60rpx);
+  padding: 40rpx;
+  position: fixed;
+  background: url("~@/static/app-plus/menu-title-bg.png") no-repeat center;
+  background-size: 100% 100%;
+  background-color: #fff;
+  display: flex;
+  justify-content: space-between;
+  align-items: center;
+  z-index: 1;
+  .title {
+    font: 18px bold;
+    color: #fff;
+  }
+}
+.forms {
+  padding: 40rpx 34rpx;
+  padding-top: 168rpx;
+  .title2 {
+    font-size: 28rpx;
+    font-weight: 400;
+    color: #4a90e2;
+    line-height: 40rpx;
+    padding-bottom: 18rpx;
+    border-bottom: 1px solid #e8e8e8;
+  }
+  .title-sub {
+    font-size: 28rpx;
+    font-weight: 400;
+    color: #4a4a4a;
+    line-height: 40rpx;
+    margin-top: 20rpx;
+    margin-bottom: 20rpx;
+  }
+  .formItem {
+  }
+  .input,
+  .textarea,
+  .selectPlaceholder {
+    font-size: 28rpx;
+    padding-left: 24rpx;
+    border: 1rpx solid #c0c0c0;
+  }
+  .input,
+  .selectPlaceholder {
+    line-height: 72rpx;
+    height: 72rpx;
+  }
+  .textarea {
+    padding-top: 10rpx;
+    width: 400rpx;
+    height: 200rpx;
+  }
+}
+
+.form {
+  margin: 0 20px;
+}
+.button {
+  position: fixed;
+  bottom: 0;
+  left: 0;
+  width: 100%;
+  height: 100rpx;
+  background: url("~@/static/btn-bg.png") no-repeat center;
+  background-size: 100% 100%;
+
+  font-size: 38rpx;
+  font-weight: 500;
+  color: #ffffff;
+  line-height: 100rpx;
+  text-align: center;
+}
+.btn-add {
+  width: 140rpx;
+  height: 50rpx;
+  border: 1rpx solid #329bfe;
+  color: #329bfe;
+  display: flex;
+  justify-content: center;
+  align-items: center;
+  margin-left: 48rpx;
+}
+.box {
+  position: relative;
+}
+.btn-remove {
+  position: absolute;
+  right: -10px;
+  top: -12px;
+  width: 12px;
+  height: 12px;
+  background: #f54444;
+  border-radius: 50%;
+  line-height: 20rpx;
+  text-align: center;
+  color: #fff;
+  font-weight: bold;
+}
+.forms {
+  padding-bottom: 140rpx;
+}
+</style>

+ 290 - 0
pages/daily/projectDaily.vue

@@ -0,0 +1,290 @@
+<template>
+  <view class="page">
+    <view class="content">
+      <view class="head">
+        <span class="title">项目列表</span>
+        <navigator
+          :url="`/pages/daily/form?project_id=${project_id}`"
+          class="self"
+          open-type="navigate"
+          hover-class="navigator-hover"
+        >
+          写日志
+        </navigator>
+      </view>
+
+      <view class="search">
+        <uni-search-bar
+          bgColor="#FFFFFF"
+          style="padding: 20rpx 30rpx"
+          :radius="20"
+          placeholder="请输入日志标题"
+          v-model="filter.searchKeyword"
+          @confirm="handelSearchConfirm"
+        />
+        <view class="selectRow">
+          <view class="selectCol">
+            <picker
+              style="max-width: 80%"
+              :range="[]"
+              range-key="label"
+              @change="handelChange"
+            >
+              <view class="pickerSlot">
+                <view class="itemText"> 提交人 </view>
+                <!-- v-if="selectedValues[index] === null" -->
+                <image
+                  class="triangle"
+                  src="/static/triangle@2x.png"
+                  mode="widthFix"
+                />
+              </view>
+            </picker>
+            <!-- <uni-icons
+              v-if="selectedValues[index] !== null"
+              type="closeempty"
+              size="14"
+              @click="cleanSelect(index)"
+            ></uni-icons> -->
+          </view>
+          <view class="selectCol">
+            <uniDatetimePicker
+              style="max-width: 80%"
+              type="daterange"
+              hide-second
+              clear-icon
+              @change="handelTimePickerChange"
+            >
+              <view class="pickerSlot">
+                <view class="itemText">
+                  <!-- {{
+                    timerange.length !== 0
+                      ? `${timerange[0]}~${timerange[0]}`
+                      : item.placeholder
+                  }} -->
+                  发布日期
+                </view>
+                <image
+                  class="triangle"
+                  src="/static/triangle@2x.png"
+                  mode="widthFix"
+                />
+              </view>
+            </uniDatetimePicker>
+            <!-- <uni-icons
+              v-if="timerange.length === 2"
+              type="closeempty"
+              size="14"
+              @click="cleanSelect(index)"
+            ></uni-icons> -->
+          </view>
+        </view>
+      </view>
+      <scroll-view
+        class="list"
+        :scroll-top="scrollTop"
+        scroll-y="true"
+        @scrolltolower="scrollToLower()"
+      >
+        <view class="item">
+          <view class="box">
+            <view class="title">张三的金科环境项目日志</view>
+            <view class="desc">
+              <view class="desc-title">日志概述:</view>
+              <view class="desc-content">
+                项目进展顺利项目进展顺利项目进项目进展顺利项目进展顺利项目进
+              </view>
+            </view>
+            <view class="bottom">
+              <view class="time">07-12 8:50</view>
+              <view class="user">提交人:xxx</view>
+            </view>
+          </view>
+        </view>
+      </scroll-view>
+    </view>
+  </view>
+</template>
+
+<script>
+import uniDatetimePicker from "@/uni_modules/uni-datetime-picker/components/uni-datetime-picker/uni-datetime-picker.vue";
+import moment from "moment";
+export default {
+  components: {
+    uniDatetimePicker,
+  },
+  data() {
+    return {
+      scrollTop: 0,
+      filter: { searchKeyword: "" },
+      project_id: "",
+    };
+  },
+  methods: {
+    handelSearchConfirm() {},
+    handelChange() {},
+    scrollToLower() {
+      // if (this.projectList.length >= this.pagination.total) {
+      //   this.loadMoreText = "没有更多数据了";
+      //   return;
+      // }
+      // this.pagination.currentPage++;
+      // this.initData();
+    },
+    handelTimePickerChange(time) {
+      if (time.length !== 2) {
+        return;
+      }
+      this.filter.start = moment(time[0]).format("YYYY-MM-DD 00:00:00");
+
+      this.filter.end = moment(time[1]).format("YYYY-MM-DD 23:59:59");
+    },
+  },
+  onLoad(options) {
+    this.project_id = options.project_id;
+  },
+};
+</script>
+
+<style lang="less" scoped>
+.content {
+  display: flex;
+  justify-content: center;
+  flex-wrap: wrap;
+  padding-top: 150rpx;
+}
+
+.head {
+  width: calc(100% - 60rpx);
+  padding: 40rpx;
+  position: fixed;
+  background: url("~@/static/app-plus/menu-title-bg.png") no-repeat center;
+  background-size: 100% 100%;
+  background-color: #fff;
+  display: flex;
+  justify-content: space-between;
+  align-items: center;
+  z-index: 1;
+  top: 0;
+  .title {
+    font: 18px bold;
+    color: #fff;
+  }
+  .self {
+    font: 14px;
+    padding-left: 20rpx;
+    color: #fff;
+  }
+}
+.list {
+  width: 90%;
+  height: calc(90vh - 200rpx);
+  ::v-deep {
+    .uni-list--border-top {
+      background-color: transparent;
+    }
+    .uni-list-item__container {
+      padding: 12rpx 30rpx;
+    }
+  }
+}
+.loadmore {
+  padding: 30rpx 0px;
+  font-size: 16px;
+  color: gray;
+  text-align: center;
+}
+.item {
+  margin-top: 20rpx;
+
+  .box {
+    padding: 40rpx;
+    border-radius: 5rpx;
+    border: 1px solid #ccc;
+    box-shadow: 0 1rpx 4rpx rgba(255, 255, 255, 0.2);
+    .title {
+      font-size: 28rpx;
+      font-weight: 400;
+      color: #4a90e2;
+      line-height: 40rpx;
+      margin-bottom: 18rpx;
+    }
+    .desc {
+      display: flex;
+      font-size: 28rpx;
+      font-weight: 400;
+      color: #4a4a4a;
+      line-height: 40rpx;
+      .desc-title {
+        flex-shrink: 1;
+      }
+      .desc-content {
+        flex: 1;
+        display: -webkit-box;
+        -webkit-line-clamp: 2; /* 显示的行数 */
+        -webkit-box-orient: vertical;
+        overflow: hidden;
+        text-overflow: ellipsis;
+        white-space: normal;
+      }
+    }
+    .bottom {
+      display: flex;
+      justify-content: space-between;
+      margin-top: 40rpx;
+      font-size: 22rpx;
+      font-weight: 400;
+      color: #7a7a7a;
+      line-height: 30rpx;
+    }
+  }
+}
+.search {
+  width: 100%;
+  ::v-deep {
+    .uni-searchbar {
+      width: 100%;
+      .uni-searchbar__box {
+        border: 1px solid #ccc;
+      }
+    }
+  }
+}
+.selectRow {
+  display: flex;
+  height: 40px;
+  flex-direction: row;
+  justify-content: center;
+  align-items: center;
+}
+
+.selectCol {
+  width: 200rpx;
+  display: flex;
+  justify-content: center;
+  align-items: center;
+}
+
+.pickerSlot {
+  width: 100%;
+  height: 36px;
+  display: flex;
+  justify-content: center;
+  align-items: center;
+}
+
+.itemText {
+  overflow: hidden;
+  text-overflow: ellipsis;
+  white-space: nowrap;
+  text-align: center;
+}
+
+.triangle {
+  margin: 0;
+  padding: 0;
+  margin-left: 3px;
+  width: 25rpx;
+  margin-left: 5rpx;
+}
+</style>

+ 36 - 21
pages/index/index.vue

@@ -1,25 +1,30 @@
 <template>
-<view class="page">
-  <view class="content">
-    <view class="group">
-      <button class="button" v-if="true" @click="onHandleClick(0)">
-        <uni-icons type="list" size="35" />
-        <view>项目列表</view>
-      </button>
-      <button class="button" v-if="true" @click="onHandleClick(1)">
-        <uni-icons type="checkmarkempty" size="35" />
-        <view>项目审核</view>
-      </button>
-      <button class="button" v-if="true" @click="onHandleClick(2)">
-        <uni-icons type="calendar" size="35" />
-        <view>工时上报</view>
-      </button>
-      <button class="button" v-if="true" @click="onHandleClick(3)">
-        <uni-icons type="auth" size="35" />
-        <view>工时审批</view>
-      </button>
-    </view>
-  </view></view>
+  <view class="page">
+    <view class="content">
+      <view class="group">
+        <button class="button" v-if="true" @click="onHandleClick(0)">
+          <uni-icons type="list" size="35" />
+          <view>项目列表</view>
+        </button>
+        <button class="button" v-if="true" @click="onHandleClick(1)">
+          <uni-icons type="checkmarkempty" size="35" />
+          <view>项目审核</view>
+        </button>
+        <button class="button" v-if="true" @click="onHandleClick(2)">
+          <uni-icons type="calendar" size="35" />
+          <view>工时上报</view>
+        </button>
+        <button class="button" v-if="true" @click="onHandleClick(3)">
+          <uni-icons type="auth" size="35" />
+          <view>工时审批</view>
+        </button>
+        <button class="button" v-if="true" @click="onHandleClick(4)">
+          <uni-icons type="calendar" size="35" />
+          <view>项目日志</view>
+        </button>
+        <view class="button empty"></view>
+      </view> </view
+  ></view>
 </template>
 
 <script>
@@ -67,6 +72,11 @@ export default {
             url: "../WorkingHours/audit",
           });
           break;
+        case 4:
+          uni.navigateTo({
+            url: "../daily/daily",
+          });
+          break;
       }
     },
     async getCurrentUser() {
@@ -83,6 +93,7 @@ export default {
   display: flex;
   justify-content: center;
 }
+
 .group {
   width: 90%;
   padding: 5%;
@@ -97,5 +108,9 @@ export default {
   margin: 5%;
   height: 280rpx;
   font-size: 32rpx;
+  &.empty {
+    visibility: hidden;
+    height: 0px;
+  }
 }
 </style>

+ 1 - 1
pages/login/login.vue

@@ -130,11 +130,11 @@ export default {
       const res = await queryDep({
         userName: this.username,
       });
-      this.depId = null;
       this.depList = res.data.map((item) => ({
         label: item.Name,
         value: item.ID,
       }));
+      this.depId = this.depList[0].value + "";
     },
   },
 };

+ 11 - 0
services/daily.js

@@ -0,0 +1,11 @@
+import request from "./request";
+
+export async function queryDaily() {
+  return await request("v2/approval/log-own/list", "GET");
+}
+export async function queryProjectList() {
+  return await request("v2/workload/project", "GET");
+}
+export async function createDaily(data) {
+  return await request("v2/approval/log", "POST", data);
+}

+ 2 - 1
services/request.js

@@ -55,7 +55,8 @@ function request(url, option, data = {}, noLoading) {
   if (typeof option == "object" && option.host) {
     fullUrl = option.host + url;
   } else {
-    fullUrl = host + "/api/" + url;
+    // fullUrl = host + "/api/" + url;
+    fullUrl = "/api/" + url;
   }
   var option = {
     url: fullUrl,

二進制
static/btn-bg.png


二進制
static/triangle@2x.png


+ 1 - 1
utils/listMixin.js

@@ -12,7 +12,7 @@ export default {
   methods: {
     initData() {
       var pagination = this.pagination;
-      return this.getProject({
+      return this.getList({
         ...this.projectFilter,
         pageSize: pagination.pageSize,
         currentPage: pagination.currentPage,