Commit bbfaaabc by fengzhaoyu

style:修改版本号 0.0.20

parents 809cd141 f8d22217
...@@ -2,6 +2,7 @@ let lock = false; ...@@ -2,6 +2,7 @@ let lock = false;
export default async function login() { export default async function login() {
if (lock == true) { if (lock == true) {
await waitLockRelease(50); await waitLockRelease(50);
return; return;
} }
lock = true; lock = true;
...@@ -50,6 +51,13 @@ export default async function login() { ...@@ -50,6 +51,13 @@ export default async function login() {
}) })
}) })
} }
// let time =setInterval(function() {
// if (lock == false) {
// clearInterval(time)
// return;
// }
// }, 100)
async function waitLockRelease(retry) { async function waitLockRelease(retry) {
for (let i = 0; i < retry; i++) { for (let i = 0; i < retry; i++) {
......
...@@ -253,3 +253,17 @@ export function getuploadResource(data) { ...@@ -253,3 +253,17 @@ export function getuploadResource(data) {
url: `/meet/meeting-log-resource/uploadResource` url: `/meet/meeting-log-resource/uploadResource`
}); });
} }
// oss 预览
export function previewOss(data) {
return $http({
method: "get",
url: `/meet/meeting-log-resource/generateIDocViewFileUrl?fileId=${data}`
});
}
// 根据id 换取 会议室
export function getDeviceBySn(data) {
return $http({
method: "get",
url: `/meet/meeting-room-device/getDeviceBySn?deviceSn=${data}`
});
}
\ No newline at end of file
...@@ -31,8 +31,13 @@ export default function xFetch({ url, method, data, type }) { ...@@ -31,8 +31,13 @@ export default function xFetch({ url, method, data, type }) {
if (err && err.status == 401) { if (err && err.status == 401) {
login(); login();
} }
if (err.errorMsg === 'socket is closed') {
} else {
console.log(err)
alertOnce((err && err.errorMsg) || '网络异常,请重试', rejects); alertOnce((err && err.errorMsg) || '网络异常,请重试', rejects);
} }
}
}); });
}); });
} }
......
import create from 'dd-store'; import create from 'dd-store';
import pageStore from '../../pages/meetingDetail/store'; import pageStore from '../../pages/meetingDetail/store';
import { previewPermissions } from '../../api/request.js' import { previewPermissions, previewOss } from '../../api/request.js'
import openLink from "dingtalk-jsapi/api/biz/util/openLink";
create.Component({ create.Component({
store: pageStore, store: pageStore,
...@@ -11,7 +12,8 @@ create.Component({ ...@@ -11,7 +12,8 @@ create.Component({
}, },
props: { props: {
isCanEdit: true, isCanEdit: true,
isCanDelete: false isCanDelete: false,
isPreview: true // 是否点击预览
}, },
didMount() { didMount() {
}, },
...@@ -28,27 +30,58 @@ create.Component({ ...@@ -28,27 +30,58 @@ create.Component({
}, },
//预览文件 //预览文件
preview(e) { preview(e) {
//如果出现编辑蒙层时阻止预览的点击事件 // 如果出现编辑蒙层时阻止预览的点击事件
if (this.store.data.logId) { if (this.store.data.logId) {
return; return;
} }
if (!this.props.isPreview) {
return
}
const file = e.target.dataset.file const file = e.target.dataset.file
const data = { const imageType = ['jpg', 'bmp', 'png', 'gif', 'jpeg']
ddUserId: getApp().globalData.userid, previewOss(file.fileId).then(res => {
type: 'download', if (res.data.code === 0) {
fileIds: file.fileId, if (imageType.includes(file.fileType)) {
projectName: 'MING_MEETING' dd.previewImage({
current: 1,
urls: [res.data.data],
success: (res) => {
console.log(JSON.stringify(res))
},
fail: (err) => {
console.log(JSON.stringify(err))
} }
previewPermissions(data).then(res => {
dd.previewFileInDingTalk({
corpId: dd.corpId,
spaceId: res.data.data,
fileId: file.fileId,
fileName: file.fileName,
fileSize: file.fileSize,
fileType: file.fileType
}) })
} else {
openLink({
url: res.data.data
})
}
}
}) })
// console.log(e)
// const data = {
// ddUserId: getApp().globalData.userid,
// type: 'download',
// fileIds: file.fileId,
// projectName: 'MING_MEETING'
// }
// previewPermissions(data).then(res => {
// dd.previewFileInDingTalk({
// corpId: dd.corpId,
// spaceId: res.data.data,
// fileId: file.fileId,
// fileName: file.fileName,
// fileSize: file.fileSize,
// fileType: file.fileType
// })
// })
}, },
//显示操作框 //显示操作框
showOperate(e) { showOperate(e) {
......
...@@ -30,23 +30,9 @@ ...@@ -30,23 +30,9 @@
<view class="associated"> <view class="associated">
可关联应用 可关联应用
</view> </view>
<view class="applicationList" a:if="{{relatedAppPlatformList.indexOf('outlook') === -1}}"> <!--<view class="applicationList" a:if="{{relatedAppPlatformList.indexOf('outlook') === -1}}"><view class="applicationLogo outlook"></view><view class="applicationMsg" data-name="" data-platform="outlook" catchTap="toAppDetails"><view><view>
<view class="applicationLogo outlook"> Outlook日历</view><view>
</view> 支持会议日程双向同步,实时同步日程信息等</view></view><view class="operateIcon"><text class="iconfont iconright"></text></view></view></view> -->
<view class="applicationMsg" data-name="" data-platform="outlook" catchTap="toAppDetails">
<view>
<view>
Outlook日历
</view>
<view>
支持会议日程双向同步,实时同步日程信息等
</view>
</view>
<view class="operateIcon">
<text class="iconfont iconright"></text>
</view>
</view>
</view>
<view class="applicationList" a:if="{{relatedAppPlatformList.indexOf('zoom') === -1}}"> <view class="applicationList" a:if="{{relatedAppPlatformList.indexOf('zoom') === -1}}">
<view class="applicationLogo zoom"> <view class="applicationLogo zoom">
</view> </view>
......
import { getThirdUserPlatForm } from "../../api/request"; import { getThirdUserPlatForm } from "../../api/request";
import { throttle } from "../../utils/utils"; import { throttle } from "../../utils/utils";
import create from "dd-store"; import create from "dd-store";
import pageStore from '../../pages/meetingDetail/store';
create.Component({ create.Component({
store: pageStore,
mixins: [], mixins: [],
data: { data: {
$data: null, $data: null,
relatedAppPlatform: null,//store
userInfo: {}, userInfo: {},
relatedAppList: [], relatedAppList: [],
relatedAppPlatformList: [] relatedAppPlatformList: []
...@@ -23,7 +26,7 @@ create.Component({ ...@@ -23,7 +26,7 @@ create.Component({
this.getData(); this.getData();
} }
}, },
didUnmount() {}, didUnmount() { },
methods: { methods: {
getData() { getData() {
let data = { let data = {
...@@ -39,7 +42,14 @@ create.Component({ ...@@ -39,7 +42,14 @@ create.Component({
relatedAppList: res.data.data, relatedAppList: res.data.data,
relatedAppPlatformList: res.data.data.map(it => it.platform) relatedAppPlatformList: res.data.data.map(it => it.platform)
}); });
/*
relatedAppPlatform 绑定平台列表
目的: 通知详情 是否可以选则zoom
*/
this.store.data.relatedAppPlatform = res.data.data.map(it => it.platform)
this.update()
}); });
}, },
preventSort() { preventSort() {
return false; return false;
......
<view class="comHList">
<view class="comHList-item" a:for="{{dataComList}}" catchTap="onSelectComHList" data-item="{{item}}">
<view class="comHList-item-image">
<image mode="scaleToFill" src="{{item.imageUrl}}"/>
</view>
<view class="comHList-item-text">
{{item.text}}
</view>
</view>
</view>
\ No newline at end of file
Component({
mixins: [],
data: {},
props: {},
didMount() { },
didUpdate() { },
didUnmount() { },
methods: {
onSelectComHList(event) {
this.props.onSelectComHList(event)
}
},
});
{
"component": true
}
\ No newline at end of file
...@@ -24,6 +24,8 @@ Component({ ...@@ -24,6 +24,8 @@ Component({
}); });
}, },
checkChange(e) { checkChange(e) {
// console.log(e.target.dataset)
let { status, id, groupId, scheduleId } = e.target.dataset; let { status, id, groupId, scheduleId } = e.target.dataset;
if (status == "0") { if (status == "0") {
status = "1"; status = "1";
......
...@@ -116,7 +116,8 @@ ...@@ -116,7 +116,8 @@
<popup title="{{popupTitle}}" show="{{popupShow}}" mask="true" onClose="closePopup"> <popup title="{{popupTitle}}" show="{{popupShow}}" mask="true" onClose="closePopup">
<meeting-time-picker a:if="{{'time' === comType}}" onComplete="onComplete" isIPX="{{isIPX}}"></meeting-time-picker> <meeting-time-picker a:if="{{'time' === comType}}" onComplete="onComplete" isIPX="{{isIPX}}"></meeting-time-picker>
<hlist a:if="{{'participator' === comType}}" dataComList="{{comHListData.contactData}}" onSelectComHList="selectComHList"></hlist> <hlist a:if="{{'participator' === comType}}" dataComList="{{comHListData.contactData}}" onSelectComHList="selectComHList"></hlist>
<list a:if="{{comType=='repeat' || comType=='meetingWayModel'}}" dataComList="{{comType=='repeat' ? comListData.repeatList : comListData.meetingWayList}}" onComSelectList="selectComList" comSelectListId="{{comType=='repeat' ? comListData.comSelectListId : comListData.meetingWayModelId}}" iconType="{{comListData.iconType}}"> <list a:if="{{comType=='repeat'}}" dataComList="{{comType=='repeat' ? comListData.repeatList : comListData.meetingWayList}}" onComSelectList="selectComList" comSelectListId="{{comType=='repeat' ? comListData.comSelectListId : comListData.meetingWayModelId}}" iconType="{{comListData.iconType}}">
</list> </list>
<list a:if="{{comType == 'meetingWayModel'}}" dataComList="{{relatedAppPlatform.includes('zoom') ? comListData.meetingWayList: [comListData.meetingWayList[0]] }}" onComSelectList="selectComList" comSelectListId="{{comListData.meetingWayModelId}}" iconType="{{comListData.iconType}}"></list>
</popup> </popup>
</view> </view>
\ No newline at end of file
import { addSchedule, getUserScheduleInTime } from '../../api/request.js' import { addSchedule, getUserScheduleInTime, getDeviceBySn } from '../../api/request.js'
import { throttle, getInterTime } from './../../utils/utils.js' import { throttle, getInterTime } from './../../utils/utils.js'
import { checkFullScren } from "../../utils/checkFullScren"; import { checkFullScren } from "../../utils/checkFullScren";
import create from 'dd-store' import create from 'dd-store'
import pageStore from '../meetingDetail/store';
create.Page({ create.Page({
store: pageStore,
data: { data: {
$data: null, $data: null,
relatedAppPlatform: null,
// 传给组件list 的所有数据 comListData // 传给组件list 的所有数据 comListData
comListData: { comListData: {
repeatList: [ repeatList: [
...@@ -16,8 +19,8 @@ create.Page({ ...@@ -16,8 +19,8 @@ create.Page({
], ],
meetingWayList: [ meetingWayList: [
// { id: 0, text: 'Webex meeting', imageUrl: '../../assests/Webex.png', meetingWayModel: { model: 'webex' } }, // { id: 0, text: 'Webex meeting', imageUrl: '../../assests/Webex.png', meetingWayModel: { model: 'webex' } },
{ id: 0, text: 'Zoom Meeting', imageUrl: '../../assests/Zoom.png', meetingWayModel: { model: 'zoom' } }, { id: 0, text: '钉钉', imageUrl: '../../assests/dingding.png', meetingWayModel: { model: 'dingtalk' } },
{ id: 1, text: '钉钉', imageUrl: '../../assests/dingding.png', meetingWayModel: { model: 'dingtalk' } } { id: 1, text: 'Zoom Meeting', imageUrl: '../../assests/Zoom.png', meetingWayModel: { model: 'zoom' } }
], ],
comSelectListId: 0, comSelectListId: 0,
meetingWayModelId: null, meetingWayModelId: null,
...@@ -64,7 +67,15 @@ create.Page({ ...@@ -64,7 +67,15 @@ create.Page({
Complete(data) { Complete(data) {
this.closePop(); this.closePop();
}, },
onLoad() { onLoad(query) {
if (query && query.sn) {
getDeviceBySn(query.sn).then(res => {
if (res.data.code === 0) {
this.$store.data.locationName = res.data.data.meetingRooomFullName
this.$store.data.roomId = res.data.data.meetingRoomId
}
})
}
dd.setNavigationBar({ dd.setNavigationBar({
title: `创建会议` title: `创建会议`
}) })
......
...@@ -51,11 +51,8 @@ ...@@ -51,11 +51,8 @@
<view class="scheduleHeader"> <view class="scheduleHeader">
<view>{{currentData.split('/')[0]}}年{{currentData.split('/')[1] || '1'}}月</view> <view>{{currentData.split('/')[0]}}年{{currentData.split('/')[1] || '1'}}月</view>
<view onTap="changesidebar" class="headerIcon"> <view onTap="changesidebar" class="headerIcon">
<text class="iconfont iconicon_app1"> <text class="iconfont iconicon_app1"></text>
</text> <view></view></view>
<view>
</view>
</view>
</view> </view>
<scroll-view class="indexScrollView" scroll-y="{{true}}" onScroll="scroll" lower-threshold="{{400}}" onScrollToLower="lower" scroll-into-view="{{todayStr}}"> <scroll-view class="indexScrollView" scroll-y="{{true}}" onScroll="scroll" lower-threshold="{{400}}" onScrollToLower="lower" scroll-into-view="{{todayStr}}">
<block a:for="{{scheduleList}}" key="{{item.dateStr}}"> <block a:for="{{scheduleList}}" key="{{item.dateStr}}">
......
...@@ -20,6 +20,7 @@ import { ...@@ -20,6 +20,7 @@ import {
getCreateShowTime getCreateShowTime
} from "../../utils/utils"; } from "../../utils/utils";
import { checkFullScren } from "../../utils/checkFullScren"; import { checkFullScren } from "../../utils/checkFullScren";
import pageStore from '../meetingDetail/store';
const currentDate = new Date(); const currentDate = new Date();
const minYear = 2020; const minYear = 2020;
const maxYear = currentDate.getFullYear() + 1; const maxYear = currentDate.getFullYear() + 1;
...@@ -27,8 +28,11 @@ let DateMap = getDateMap(minYear, maxYear); ...@@ -27,8 +28,11 @@ let DateMap = getDateMap(minYear, maxYear);
const weekList = ["周日", "周一", "周二", "周三", "周四", "周五", "周六"]; const weekList = ["周日", "周一", "周二", "周三", "周四", "周五", "周六"];
import create from "dd-store"; import create from "dd-store";
let maxClickCount = 5; let maxClickCount = 5;
create.Page({ create.Page({
store: pageStore,
data: { data: {
relatedAppPlatform: null,
sign: "", sign: "",
refresh: false, refresh: false,
$data: null, $data: null,
...@@ -89,8 +93,12 @@ create.Page({ ...@@ -89,8 +93,12 @@ create.Page({
} }
}, },
onLoad(query) { onLoad(query) {
console.log(query); if (query && query.sn) {
if (query && JSON.stringify(query) !== "{}") { this.setData({
listLoading: false
});
dd.navigateTo({ url: `./../createMeeting/createMeeting?sn=${query.sn}` });
} else if (query && JSON.stringify(query) !== "{}" && !query.sn) {
this.setData({ this.setData({
listLoading: false listLoading: false
}); });
...@@ -351,6 +359,7 @@ create.Page({ ...@@ -351,6 +359,7 @@ create.Page({
}, },
//动态修改状态 //动态修改状态
onChangeTaskStatusOnList(e) { onChangeTaskStatusOnList(e) {
// console.log(e)
const data = { const data = {
groupId: e.groupId, groupId: e.groupId,
scheduleId: e.scheduleId, scheduleId: e.scheduleId,
...@@ -366,6 +375,7 @@ create.Page({ ...@@ -366,6 +375,7 @@ create.Page({
let dataIndex1 = ""; let dataIndex1 = "";
let dataIndex2 = ""; let dataIndex2 = "";
this.data.dynamicList.forEach((item, index) => { this.data.dynamicList.forEach((item, index) => {
if (item.scheduleId === e.scheduleId) { if (item.scheduleId === e.scheduleId) {
dataIndex1 = index; dataIndex1 = index;
item.meetingLogDataList.forEach((it, index2) => { item.meetingLogDataList.forEach((it, index2) => {
...@@ -376,6 +386,7 @@ create.Page({ ...@@ -376,6 +386,7 @@ create.Page({
} }
}); });
const setData = `dynamicList[${dataIndex1}].meetingLogDataList[${dataIndex2}].meetingLogResource.taskStatus`; const setData = `dynamicList[${dataIndex1}].meetingLogDataList[${dataIndex2}].meetingLogResource.taskStatus`;
// console.log(setData)
this.setData({ this.setData({
[setData]: e.status [setData]: e.status
}); });
...@@ -798,8 +809,9 @@ create.Page({ ...@@ -798,8 +809,9 @@ create.Page({
dd.navigateTo({ url: "./../createMeeting/createMeeting" }); dd.navigateTo({ url: "./../createMeeting/createMeeting" });
}, },
nextDetail: throttle(function (e) { nextDetail: throttle(function (e) {
console.log(e.target.dataset)
const { item } = e.target.dataset; const { item } = e.target.dataset;
const scheduleItem = { scheduleId: item.id || item.scheduleId, scheduleTemplateId: item.scheduleTemplateId, planDate: item.planDate } const scheduleItem = { scheduleId: item.scheduleId || item.id, scheduleTemplateId: item.scheduleTemplateId, planDate: item.planDate }
dd.navigateTo({ dd.navigateTo({
url: `./../meetingDetail/meetingDetail?scheduleItem=${encodeURIComponent(JSON.stringify(scheduleItem))}` url: `./../meetingDetail/meetingDetail?scheduleItem=${encodeURIComponent(JSON.stringify(scheduleItem))}`
}); });
...@@ -880,7 +892,7 @@ create.Page({ ...@@ -880,7 +892,7 @@ create.Page({
maxClickCount--; maxClickCount--;
if (maxClickCount == 0) { if (maxClickCount == 0) {
dd.alert({ dd.alert({
content: "0.0.19" content: "0.0.20"
}); });
maxClickCount = 5; maxClickCount = 5;
} }
......
/*
comShareData {
isShow: false, 是否展示 默认不展示
shareDataList: [{}] 展示的数据
}
临时只做demo展示 并没有实际功能
*/
export const comShareData = {
shareTitle: '分享到',
isShow: false,
shareDataList: [
{ id: 0, text: '钉钉', imageUrl: '../../assests/dingContact.png' },
{ id: 1, text: '微信', imageUrl: '../../assests/weiXin.png' }
]
}
\ No newline at end of file
<block a:if="{{getData}}"> <block a:if="{{getData}}">
<view class=" {{(popupShow || show || centerPopup.showCenterPopup || conToastData.showToast || conSelectPopupData.showSelectPopup )? 'metingDetail' : ''}}"> <view class=" {{(popupShow || show || centerPopup.showCenterPopup || conToastData.showToast || conSelectPopupData.showSelectPopup || comShareData.isShow )? 'metingDetail' : ''}}">
<import src="../../template/deleteBtn/index.axml"/> <import src="../../template/deleteBtn/index.axml"/>
<view class="hideDetail" a:if="{{isExpand}}"> <view class="hideDetail" a:if="{{isExpand}}">
<view class="hideTitle"> <view class="hideTitle">
...@@ -139,8 +139,23 @@ ...@@ -139,8 +139,23 @@
<view class="permission" a:if="{{currentPeople != organizer}}"> <view class="permission" a:if="{{currentPeople != organizer}}">
</view> </view>
</view> </view>
<!--<view class="meetingWayShow" a:if="{{comListData.meetingWayModelId == 0}}"><view class="meetingWayShowTop"><view class=" icon iconfont iconicon_camera1"></view><view class="meetingWayText"><view onTap="setCopy" data-item="https://zoom.com.cn/j/93255954558?pwd=YmNZQkY1SGxtUFNPYjZlcUpJT0xtQT09" data-type="url"> <view class="meetingWayShow" a:if="{{comListData.meetingWayModelId == 1}}">
Zoom</view><view class="mettingWayText" onTap="setCopy" data-item="513410069"><text>ID:513410069</text><text class="icon iconfont iconicon_icon"></text></view><view class="mettingWayText passWord" onTap="setCopy" data-item="4ez3am"><text >密码:4ez3am</text><text class="icon iconfont iconicon_icon"></text></view></view></view></view> --> <view class="meetingWayShowTop">
<view class=" icon iconfont iconicon_camera1"></view>
<view class="meetingWayText">
<view onTap="setCopy" data-item="{{meetingWayModelData.data.joinUrl}}" data-type="url">
Zoom
</view>
<view class="mettingWayText" onTap="setCopy" data-item="{{meetingWayModelData.data.meetingId}}">
<text>ID:{{meetingWayModelData.data.meetingId}}</text>
<text class="icon iconfont iconicon_icon"></text></view>
<view class="mettingWayText passWord" onTap="setCopy" data-item="{{meetingWayModelData.data.password}}">
<text >密码:{{meetingWayModelData.data.password}}</text>
<text class="icon iconfont iconicon_icon"></text>
</view>
</view>
</view>
</view>
<!-- 删除该会议 --> <!-- 删除该会议 -->
<template is="deleteBtn" onhandleDelete="" data="{{title: '删除该会议' }}"/> <template is="deleteBtn" onhandleDelete="" data="{{title: '删除该会议' }}"/>
</view> </view>
...@@ -187,13 +202,11 @@ ...@@ -187,13 +202,11 @@
<view onTap="showCreateTask" data-pop="{{title: '创建任务', type: 'createTask'}}"> <view onTap="showCreateTask" data-pop="{{title: '创建任务', type: 'createTask'}}">
<text class="iconfont iconicon_task1"></text>任务 <text class="iconfont iconicon_task1"></text>任务
</view> </view>
<view onTap="addMeetingFile"> <!--<view onTap="addMeetingFile"><text class="iconfont iconicon_data"></text>文件</view> -->
<text class="iconfont iconicon_data"></text>文件
</view>
<view onTap="addOssFile" a:if="{{isShowOss}}"> <view onTap="addOssFile" a:if="{{isShowOss}}">
<text class="iconfont iconicon_data"></text> <text class="iconfont iconicon_data"></text>
<view> <view>
oss 文件
</view> </view>
</view> </view>
<text class="devider"></text> <text class="devider"></text>
...@@ -245,8 +258,12 @@ ...@@ -245,8 +258,12 @@
<popup a:if="{{popupShow}}" title="{{popupTitle}}" show="{{popupShow}}" mask="true" onClose="closePopup"> <popup a:if="{{popupShow}}" title="{{popupTitle}}" show="{{popupShow}}" mask="true" onClose="closePopup">
<meeting-time-picker a:if="{{'time' === comType}}" onComplete="onComplete" startTime="{{$data.startTime}}" endTime="{{$data.endTime}}" isIPX="{{isIPX}}"></meeting-time-picker> <meeting-time-picker a:if="{{'time' === comType}}" onComplete="onComplete" startTime="{{$data.startTime}}" endTime="{{$data.endTime}}" isIPX="{{isIPX}}"></meeting-time-picker>
<hlist a:if="{{'participator' === comType}}" dataComList="{{comHListData.contactData}}" onSelectComHList="selectComHList"></hlist> <hlist a:if="{{'participator' === comType}}" dataComList="{{comHListData.contactData}}" onSelectComHList="selectComHList"></hlist>
<list multiple="{{comListData.multiple}}" onCompelete="selectAheadtimes" comSelectList="{{comListData.aheadTimesListId}}" complete="{{comType=='aheadTime' ? true : false}}"a:if="{{comType=='repeat' || comType=='meetingWayModel' || comType=='aheadTime'}}" dataComList="{{comType=='repeat' ? comListData.repeatList : (comType=='aheadTime' ? comListData.aheadTimesList : comListData.meetingWayList)}}" onComSelectList="selectComList" comSelectListId="{{comType=='repeat' ? comListData.comSelectListId : (comType=='aheadTime'?comListData.aheadTimesListId : comListData.meetingWayModelId)}}" iconType="{{comListData.iconType}}"> <list multiple="{{comListData.multiple}}" onCompelete="selectAheadtimes" comSelectList="{{comListData.aheadTimesListId}}" complete="{{comType=='aheadTime' ? true : false}}"a:if="{{comType=='repeat' || comType=='aheadTime'}}" dataComList="{{comType=='repeat' ? comListData.repeatList : comListData.aheadTimesList}}" onComSelectList="selectComList" comSelectListId="{{comType=='repeat' ? comListData.comSelectListId : comListData.aheadTimesListId}}" iconType="{{comListData.iconType}}"></list>
</list> <list a:if="{{comType == 'meetingWayModel'}}" dataComList="{{relatedAppPlatform.includes('zoom') ? comListData.meetingWayList: [comListData.meetingWayList[0]] }}" onComSelectList="selectComList" comSelectListId="{{comListData.meetingWayModelId}}" iconType="{{comListData.iconType}}"></list>
</popup>
<!-- 分享的弹窗 -->
<popup a:if="{{comShareData.isShow}}" show="{{comShareData.isShow}}" title="{{comShareData.shareTitle}}" mask="{{true}}" onClose="closeShare">
<sharelist dataComList="{{comShareData.shareDataList}}" onSelectComHList="closeShare"></sharelist>
</popup> </popup>
<popup a:if="{{show}}" show="{{show}}" onClose="closePop" title="{{pop.title}}"> <popup a:if="{{show}}" show="{{show}}" onClose="closePop" title="{{pop.title}}">
<!-- 任务创建弹出框 --> <!-- 任务创建弹出框 -->
......
...@@ -7,6 +7,7 @@ ...@@ -7,6 +7,7 @@
"task-panel": "../../components/taskPanel/taskPanel", "task-panel": "../../components/taskPanel/taskPanel",
"list": "../../components/list/list", "list": "../../components/list/list",
"hlist": "../../components/hList/hList", "hlist": "../../components/hList/hList",
"sharelist": "../../components/shareList/shareList",
"toast": "../../components/toast/toast", "toast": "../../components/toast/toast",
"selectpopup": "../../components/selectPopup/selectPopup", "selectpopup": "../../components/selectPopup/selectPopup",
"centerpopup": "../../components/centerPopup/centerPopup", "centerpopup": "../../components/centerPopup/centerPopup",
......
...@@ -15,7 +15,8 @@ class Store { ...@@ -15,7 +15,8 @@ class Store {
scheduleId: '', scheduleId: '',
groupId: '', groupId: '',
isNeedReloadList: false, isNeedReloadList: false,
logId: '' logId: '',
relatedAppPlatform: null
} }
} }
export default new Store() export default new Store()
\ No newline at end of file
import { getRndInteger } from '../../utils/utils.js'
import { getOssPermission } from '../../api/request.js'
import { saveFileInfo, getMeetingRoomAffairs, createMeetingTask, deleteMeetingTask, updateMeetingTask, uploadPermissions } from '../../api/request';
import pageStore from './store'
// 选择图片
function getImg() {
return new Promise((resolve, rejects) => {
dd.chooseImage({
count: 1,
success: (res) => {
resolve(res)
},
fail: (err) => {
rejects({ code: -1, ...err })
}
});
})
}
// 获取的图片上传到oss
async function uploadImg(imgInfo) {
const permisson = await getOssPermission()
const timestamp = new Date().getTime()
const random = getRndInteger(1000, 10000)
const fileName = timestamp.toString() + random.toString() + '.' + imgInfo.files[0].fileType;
const key = permisson.data.data.dir + fileName;
return new Promise((resolve, rejects) => {
dd.uploadFile({
url: permisson.data.data.host,
fileType: 'image',
fileName: 'file',
filePath: imgInfo.filePaths[0],
formData: {
key: key,
policy: permisson.data.data.policy,
OSSAccessKeyId: permisson.data.data.accessId,
success_action_status: 200,
signature: permisson.data.data.signature
},
success: (res) => {
console.log(JSON.stringify(res))
resolve([{
fileId: key,
fileName: fileName,
fileType: imgInfo.files[0].fileType,
fileSize: imgInfo.files[0].size
}])
},
fail: (err) => {
rejects({ code: -1, ...err })
}
})
})
}
// 从OSS获取fileInfo
export async function getFileInfoFromOss() {
// 选择图片
const imgInfo = await getImg()
if (imgInfo.code === -1) {
return { code: -1, msg: '选择图片失败' }
}
// 上传图片
const fileInfo = await uploadImg(imgInfo)
if (fileInfo.code === -1) {
return { code: -1, msg: '选上传图片失败' }
}
// 返回fileInfo
return { code: 0, msg: 'success', data: fileInfo }
}
\ No newline at end of file
...@@ -1250,8 +1250,11 @@ create.Page({ ...@@ -1250,8 +1250,11 @@ create.Page({
if ( if (
this.$store.data.locationName != this.$store.data.locationName !=
this.$store.data.originalData.location.locationName || this.$store.data.originalData.location.locationName ||
this.$store.data.roomId != this.$store.data.originalData.meetingRoomId this.$store.data.roomId != this.$store.data.originalData.meetingRoomId ||
this.$store.data.startTime != this.$store.data.originalData.startTime.replace(/-/g, "/") ||
this.$store.data.endTime != this.$store.data.originalData.endTime.replace(/-/g, "/")
) { ) {
this.$store.data.updateInfo = { this.$store.data.updateInfo = {
updateType: "modify_location", updateType: "modify_location",
isUpate: true isUpate: true
......
...@@ -3,7 +3,7 @@ page { ...@@ -3,7 +3,7 @@ page {
font-family: PingFangSC-Regular; font-family: PingFangSC-Regular;
font-size: 34rpx; font-size: 34rpx;
color: #191F25; color: #191F25;
padding-bottom: 128rpx; padding-bottom: 205rpx;
} }
.peopleList { .peopleList {
......
...@@ -47,12 +47,7 @@ ...@@ -47,12 +47,7 @@
<view a:if="{{!loading}}"> <view a:if="{{!loading}}">
<view class="scheduleHeader"> <view class="scheduleHeader">
<view>{{currentData.split('/')[0]}}年{{currentData.split('/')[1] || '1'}}月</view> <view>{{currentData.split('/')[0]}}年{{currentData.split('/')[1] || '1'}}月</view>
<view onTap="changesidebar" class="headerIcon"> <!--<view onTap="changesidebar" class="headerIcon"><text class="iconfont iconicon_app1"></text><view></view></view> -->
<text class="iconfont iconicon_app1">
</text>
<view>
</view>
</view>
</view> </view>
<scroll-view class="indexScrollView" scroll-y="{{true}}" onScroll="scroll" lower-threshold="{{400}}" onScrollToLower="lower" scroll-into-view="{{todayStr}}"> <scroll-view class="indexScrollView" scroll-y="{{true}}" onScroll="scroll" lower-threshold="{{400}}" onScrollToLower="lower" scroll-into-view="{{todayStr}}">
<block a:for="{{scheduleList}}" key="{{item.dateStr}}"> <block a:for="{{scheduleList}}" key="{{item.dateStr}}">
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
<view class="describe"> <view class="describe">
<textarea value="{{description}}" class="textarea" onInput="inputChange" placeholder="添加文件描述..." maxlength="-1" /> <textarea value="{{description}}" class="textarea" onInput="inputChange" placeholder="添加文件描述..." maxlength="-1" />
</view> </view>
<file-list fileView="{{{fileInfos: fileInfos}}}" isCanEdit="{{false}}" isCanDelete="{{true}}"/> <file-list fileView="{{{fileInfos: fileInfos}}}" isCanEdit="{{false}}" isPreview="{{false}}" isCanDelete="{{true}}"/>
<view class="addText" onTap="add">继续添加</view> <view class="addText" onTap="add">继续添加</view>
</view> </view>
<view class="saveButton" onTap="saveUpload"> <view class="saveButton" onTap="saveUpload">
......
...@@ -2,6 +2,7 @@ import create from 'dd-store' ...@@ -2,6 +2,7 @@ import create from 'dd-store'
import { saveFileInfo, addSchedule, uploadPermissions, previewPermissions, updateMeetingTask } from '../../api/request.js' import { saveFileInfo, addSchedule, uploadPermissions, previewPermissions, updateMeetingTask } from '../../api/request.js'
import { throttle, debounce } from './../../utils/utils.js' import { throttle, debounce } from './../../utils/utils.js'
import pageStore from '../meetingDetail/store'; import pageStore from '../meetingDetail/store';
import { getFileInfoFromOss } from '../meetingDetail/uploadFile';
create.Page({ create.Page({
store: pageStore, store: pageStore,
...@@ -25,6 +26,7 @@ create.Page({ ...@@ -25,6 +26,7 @@ create.Page({
} }
}, },
onShow() { onShow() {
this.update()
}, },
inputChange: debounce(function (e) { inputChange: debounce(function (e) {
const value = e.detail.value; const value = e.detail.value;
...@@ -34,28 +36,37 @@ create.Page({ ...@@ -34,28 +36,37 @@ create.Page({
} }
}, 100), }, 100),
//添加会议文件 //添加会议文件
add() { async add() {
const data = { const res = await getFileInfoFromOss();
ddUserId: getApp().globalData.userid, if (res.code === -1) {
type: 'add', dd.alert({
projectName: 'MING_MEETING' content: res.msg
}
uploadPermissions(data).then(res => {
if (res.data.code === 0) {
const _that = this
dd.uploadAttachmentToDingTalk({
image: { multiple: true, compress: true, max: 9, spaceId: res.data.data },
space: { spaceId: res.data.data, compress: true, isCopy: 1, max: 9 },
types: ["photo", "camera", "space"],
success: (res) => {
_that.store.data.fileInfos.push(...res.data)
_that.update();
},
fail: (err) => {
}
}) })
return
} }
}) this.store.data.fileInfos.push(...res.data)
this.update();
// const data = {
// ddUserId: getApp().globalData.userid,
// type: 'add',
// projectName: 'MING_MEETING'
// }
// uploadPermissions(data).then(res => {
// if (res.data.code === 0) {
// const _that = this
// dd.uploadAttachmentToDingTalk({
// image: { multiple: true, compress: true, max: 9, spaceId: res.data.data },
// space: { spaceId: res.data.data, compress: true, isCopy: 1, max: 9 },
// types: ["photo", "camera", "space"],
// success: (res) => {
// _that.store.data.fileInfos.push(...res.data)
// _that.update();
// },
// fail: (err) => {
// }
// })
// }
// })
}, },
// 保存 // 保存
...@@ -84,7 +95,7 @@ create.Page({ ...@@ -84,7 +95,7 @@ create.Page({
groupId: this.store.data.groupId, groupId: this.store.data.groupId,
uploader: getApp().globalData.userid, uploader: getApp().globalData.userid,
creatorInfo: getApp().globalData.userInfo, creatorInfo: getApp().globalData.userInfo,
thirdStoreTenant: 'dingTalk', thirdStoreTenant: 'oss',
fileInfos: JSON.stringify(fileInfos), fileInfos: JSON.stringify(fileInfos),
description: description, description: description,
logType: 'schedule_accessory_add' logType: 'schedule_accessory_add'
...@@ -96,6 +107,8 @@ create.Page({ ...@@ -96,6 +107,8 @@ create.Page({
data.id = this.data.id data.id = this.data.id
updateMeetingTask(data).then(res => { updateMeetingTask(data).then(res => {
this.store.data.isNeedReloadList = true; this.store.data.isNeedReloadList = true;
this.store.data.fileInfos = []
this.store.data.description = ''
this.update(); this.update();
dd.navigateBack() dd.navigateBack()
}) })
......
<!-- checkbox模板 {status: status}--> <!-- checkbox模板 {status: status}-->
<template name="checkbox"> <template name="checkbox">
<view class="checkbox {{status == '1' ? 'checkbox-active': ''}}" data-id="{{id}}" data-groupId="{{groupId}}" data-scheduleId="{{scheduleId}}" data-status="{{status}}" onTap="checkChange"> <view class="checkbox {{status == '1' ? 'checkbox-active': ''}}" data-id="{{id}}" data-groupId="{{groupId}}" data-scheduleId="{{scheduleId}}" data-status="{{status}}" onTap="checkChange">
<!-- {{status}} -->
<text a:if="{{status == '1'}}" class="iconfont iconicon_ok"></text> <text a:if="{{status == '1'}}" class="iconfont iconicon_ok"></text>
</view> </view>
</template> </template>
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment