| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691 |
- import { getData } from '@/api/platform/desktop/column'
- import { getFile } from '@/utils/avatar'
- import { mapState } from 'vuex'
- import { taskTypeOptions, dashboardStatus, genderOptions, favoritesOptions, noticeOptions, unreadMessageOptions, imgOptionsData } from '@/business/platform/bpmn/constants'
- import ActionUtils from '@/utils/action'
- import Utils from '@/utils/util'
- import { findAllByCurrUserId, saveCalendarInfos, removeCalendarInfos, delNavigation, addNavigation, getNavigation, sortNavigation } from '@/api/detection/newHomeApi'
- import { isEqual } from 'lodash'
- import Bus from '@/utils/EventBus'
- import newPng from '@/assets/images/homepage/new.png'
- import { BASE_URL } from '@/constant'
- import dayjs from 'dayjs'
- import { scheduleType } from '@/views/constants/schedule'
- /**
- * 创建组件
- */
- export function buildComponent (name, column, preview, vm) {
- try {
- return {
- name,
- components: {
- VueDraggable: () => import('vuedraggable')
- },
- props: {
- params: {
- type: Object,
- default: () => {}
- },
- height: {
- type: Number,
- default: column.height || 300
- },
- visible: {
- type: Boolean,
- default: false
- },
- fullScreen: {
- type: Boolean,
- default: false
- }
- },
- filters: {
- filterStatus (val, type) {
- if (Utils.isEmpty(val)) {
- return ''
- }
- const typeMap = {
- pending: taskTypeOptions,
- already: dashboardStatus,
- myRequest: dashboardStatus,
- gender: genderOptions,
- favorites: favoritesOptions,
- notice: noticeOptions,
- unreadMessage: unreadMessageOptions
- }
- if (!typeMap[type]) {
- return val
- }
- return typeMap[type].find(x => x['value'] === val) ? typeMap[type].find(x => x['value'] === val).label : val
- }
- },
- data () {
- const { first = '', second = '' } = this.$store.getters.level
- const { userId, userList = [], deptList = [], menus, userInfo } = this.$store.getters
- const t1 = deptList.find(i => i.positionId === first) || {}
- const t2 = deptList.find(i => i.positionId === second) || {}
- const locationName = second ? t1.positionName + t2.positionName : t1.positionName
- return {
- userId,
- userList,
- deptList,
- menus,
- locationName,
- newPng,
- imgOptionsData,
- positions: userInfo.positions,
- loading: false,
- title: `${column.name}`,
- alias: `${column.alias}`,
- attrs: this.getAttrs(),
- variables: {}, // 一些变量,比如分页信息
- data: null,
- totalCount: 0,
- quickNavigationData: [],
- navigationList: [],
- stautusOptions: [],
- bpmnFormrenderDialogVisible: false, // 表单
- editId: '',
- bodyShow: true,
- show: false,
- showHeight: '',
- cardHeight: '100%',
- activeName: 'innerMessage',
- unreadMessageOption: {},
- formName: 'quickNavform',
- dialogFormVisible: false,
- formLabelWidth: '120px',
- quickNavform: {
- urlName: '',
- urlAddr: '',
- display: '_blank',
- diDian: second || first
- },
- defaultForm: {},
- pendingTabActiveName: 'user-type',
- bodyParams: ActionUtils.formatParams({}, {}, {}),
- pendingBusinessOption: {},
- bpmn: [],
- rules: {
- urlName: [
- {
- required: true,
- message: this.$t('validate.required')
- }
- ],
- urlAddr: [
- {
- required: true,
- message: this.$t('validate.required')
- }
- ],
- display: [
- {
- required: true,
- message: this.$t('validate.required')
- }
- ]
- },
- calendarDialogForm: {
- id: '',
- biaoTi: '',
- neiRong: '',
- kaiShiShiJian: '',
- jieShuShiJian: '',
- formDate: []
- },
- colorStatus: ['#e7505a', '#f3c200', '#578ebe', '#1BBC9B'],
- // const status = ['急', '重', '轻','缓']
- isDragging: false,
- draggableOptions: {
- handle: '.draggable',
- ghostClass: 'sortable-ghost',
- distance: 1,
- disabled: false,
- animation: 200,
- axis: 'y'
- },
- calendarToolbar: this.fullScreen ? [{ key: 'refresh' }] : [{ key: 'refresh' }, { key: 'fullscreen' }, { key: 'collapse' }],
- isFirstAlert: true, // 是否首次日程提醒
- scheduleData: [],
- scheduleShift: [],
- todaySchedule: []
- }
- },
- computed: {
- ...mapState({
- userInfo: state => state.ibps.user.info
- })
- },
- mounted () {
- this.defaultForm = JSON.parse(JSON.stringify(this.quickNavform))
- this.$nextTick(async () => {
- this.fetchData()
- this.scheduleData = await this.getScheduleData()
- })
- },
- methods: {
- fetchData (columns, params = {}) {
- this.loading = true
- this.data = []
- this.showHeight = this.getHeight()
- const param = Utils.isNotEmpty(columns) && (column.alias === 'unreadMessage' || column.alias === 'pendingBusiness')
- ? { dataMode: column.dataMode, dataFrom: column.dataFrom }
- : column
- if (param.alias === 'myCalendar') {
- const { getFormatDate, getDate } = this.$common
- findAllByCurrUserId().then(res => {
- const { data = [] } = res || {}
- if (this.isFirstAlert) {
- this.isFirstAlert = false
- this.showAlert(data)
- }
- this.data = data.map(i => ({
- id: i.id,
- title: i.title,
- content: i.content,
- start: i.startTime,
- // 日期组件日程显示里,end的时间需要多加一天,end:2024-01-02时,日程条只到2024-01-01的日期位置上
- end: getFormatDate('string', 10, getDate('day', 1, i.endTime)),
- jieShuShiJian: i.endTime,
- zhuangTai: i.emergencyState,
- color: this.colorStatus[Number(i.emergencyState) - 1]
- }))
- }).catch(() => {
- this.$message.error('获取日历日程失败!')
- })
- } else if (param.alias === 'quickNavigation') {
- getNavigation().then(res => {
- const { data = [] } = res || {}
- data.forEach(item => {
- if (!item.userId) {
- item.urlAddr = `${BASE_URL}#${item.urlAddr}`
- }
- })
- this.quickNavigationData = data
- })
- } else {
- getData(param, params).then(res => {
- let { data } = res || {}
- if (Utils.isNotEmpty(data) && Utils.isString(data)) {
- data = Utils.parseData(res.data)
- }
- this.data = data && data.dataResult ? data.dataResult : data
- this.totalCount = data && data.pageResult ? data.pageResult.totalCount : 0
- // 更新小铃铛消息数量
- if (param.alias === 'unreadMessage') {
- Bus.$emit('getMessageCount', this.totalCount)
- }
- this.variables = res.variables
- this.loading = false
- }).catch((e) => {
- this.loading = false
- })
- }
- },
- // 过滤日程提醒数据
- filterAlertData (data, dayNumber = 3) {
- if (dayNumber <= 0) return
- const today = dayjs()
- const tempCalendarAlertData = data.filter(day => {
- const startTime = dayjs(day.startTime)
- const endTime = dayjs(day.endTime)
- if (day.popUp) {
- if ((startTime.diff(today, 'day') <= 0 && endTime.diff(today, 'day') >= 0) || (startTime.diff(today, 'day') <= dayNumber - 2 && startTime.diff(today, 'day') >= 0)) {
- return true
- }
- }
- })
- tempCalendarAlertData.sort((a, b) => new Date(a.startTime) - new Date(b.startTime))
- const calendarIds = tempCalendarAlertData.map(item => item.id)
- const calendarAlertData = {}
- tempCalendarAlertData.forEach(item => {
- if (calendarAlertData[item.startTime]) {
- calendarAlertData[item.startTime].push(item)
- } else {
- calendarAlertData[item.startTime] = []
- calendarAlertData[item.startTime].push(item)
- }
- })
- return { calendarAlertData, calendarIds }
- },
- // 日程提醒
- showAlert (data) {
- const calendarAlertData = this.filterAlertData(data)
- this.$emit('action-event', 'calendarAlert', calendarAlertData)
- },
- getPhoto (photo) {
- return getFile(photo)
- },
- getTaskDesc (v) {
- if (!v.includes('#')) {
- return ''
- }
- return v.split('#')[1] || ''
- },
- getTaskInfo (val, arg) {
- const arr = val.split('#')
- if (!arr[2]) {
- return ''
- }
- // 中文冒号转英文冒号 防止流程定义时输入的冒号格式错误导致转换报错
- arr[2] = arr[2].replace(':', ':')
- const result = JSON.parse(`{${arr[2]}}`)
- if (!result.dept) {
- return ''
- }
- const depts = result.dept.split(',')
- const deptNames = []
- depts.forEach(item => {
- const t = this.deptList.find(i => i.positionId === item)
- deptNames.push(t ? t.positionName : result.dept)
- })
- result.deptName = deptNames.join(',')
- return result[arg]
- },
- transformData (val, dataset, from, to) {
- if (!val) {
- return ''
- }
- const temp = this[dataset].find(u => u[from] === val)
- return temp ? temp[to] : ''
- },
- getHeightNoUnit () {
- // 高度 - header - 边框
- if (!this.visible) {
- return this.height ? (this.height - 60 - 20) : 150
- } else {
- return 150
- }
- },
- getHeight (h = 20) {
- // 高度 - header - 边框
- if (!this.visible) {
- return this.height ? `${(this.height - 60 - h)}px` : '150px'
- } else {
- return '100%'
- }
- },
- getDashboardHeight () {
- return this.height ? `${this.height + 20}px` : '150px'
- },
- getAttrs () {
- const item = JSON.parse(JSON.stringify(column))
- item.templateHtml = null
- return item
- },
- /**
- * 构建首页日期组件的参数
- * @param {*} data
- * @returns
- */
- getFullCalendarConfig (data) {
- const events = data === null ? [] : Utils.parseJSON(data)
- const config = {
- height: preview ? '100%' : (this.height ? this.height : 180),
- // editable: true, // 允许拖动缩放,不写默认就是false
- selectable: true,
- dayMaxEvents: 1, // 最多显示3个日程
- locale: this.$i18n.locale ? this.$i18n.locale.toLowerCase() : 'zh-cn',
- events: events,
- buttonText: {
- today: '今天',
- dayGridMonth: '月',
- listMonth: '日程'
- // week: '周视图',
- // day: '日视图',
- // prev: '<i class="icon-chevron-left">后退</i>',
- // next: '<i class="icon-chevron-right">前进</i>'
- },
- dateClick: this.handleDateClick, // 日期点击
- eventClick: this.handleEventClick,
- moreLinkClick: this.handleMoreLinkClick
- }
- if (preview) {
- config.headerToolbar = {
- start: '',
- center: 'title',
- end: 'prev,next,today'
- // end: 'prev,next,today,month,agendaWeek,agendaDay,listWeek'
- }
- delete config['dayMaxEvents']
- }
- return config
- },
- handleDateClick (param) {
- this.$emit(
- 'open',
- 'calendar',
- [param.dateStr, param.dateStr],
- this.data
- )
- },
- handleEventClick (param) {
- this.$emit(
- 'open',
- 'calendar',
- [param.event.startStr, param.event._def.extendedProps.jieShuShiJian],
- this.data,
- param.event.id
- )
- },
- handleMoreLinkClick (date) {
- this.$emit(
- 'open',
- 'calendar',
- [date.allSegs[0].event.startStr, date.allSegs[0].event._def.extendedProps.jieShuShiJian],
- this.data,
- date.allSegs[0].event.id
- )
- },
- refreshData () {
- this.fetchData()
- },
- /**
- * 处理按钮事件
- * @param {*} command
- * @param {*} position
- * @param {*} data
- * @param {*} actions
- */
- handleActionEvent (command, position, data, actions) {
- switch (command) {
- case 'refresh': // 刷新
- this.refreshData()
- break
- case 'fullscreen': // 全屏
- this.handleFullscreen()
- break
- case 'more': // 更多
- this.handleMore()
- break
- case 'collapse': // 收缩
- case 'expansion': // 展开
- this.handleCollapseExpand(command, data, actions)
- break
- case 'add': // 新增
- this.getFormData()
- break
- default:
- break
- }
- },
- emitActionEventHandler (command) {
- this.$emit('action-event', command, ...Array.from(arguments).slice(1))
- },
- // 公告栏目点击事件
- handleApprove (id, title) {
- this.$emit('action-event', 'approve', {
- id, title
- })
- },
- handleUnreadMessage (id, tableId, tableName) {
- this.$emit('action-event', 'unRead', { id, tableId, tableName })
- },
- // 处理全屏
- handleFullscreen () {
- this.emitActionEventHandler('fullscreen', { id: this.attrs.id })
- },
- openPlate (url) {
- const menuMap = {
- myTraining: 'rygl/rypx/wdpx',
- myTesting: 'rygl/kszx/wdks',
- myDevices: 'sbgls/mywh',
- myDiscard: 'lhjcgl/ypgl/ypgqcl',
- notice: 'tygl/tzgg',
- myFacility: 'sshjgl/sshjjk/sshjkzzl',
- quickNavigation: 'xtgl/xtsjpz/tyglpz/kjdhpz'
- }
- if (menuMap[url]) {
- const alias = menuMap[url].split('/')[0]
- const resInfo = this.menus.find(i => i.alias === alias)
- this.$store.dispatch('ibps/menu/activeHeaderSet', { activeHeader: resInfo.id, vm: this })
- }
- this.$router.push(`/${menuMap[url] || url}`)
- },
- /**
- * 处理更多
- */
- handleMore () {
- if (this.attrs.alias === 'quickNavigation') {
- return this.openPlate('quickNavigation')
- }
- if (!this.attrs.colUrl) {
- return this.$message.warning('未设置更多路径的url')
- }
- this.openPlate(this.attrs.colUrl)
- },
- // 未读消息
- handleClick (option) {
- this.unreadMessageOption = option
- option[this.activeName].dataMode = column.dataMode
- this.fetchData(option[this.activeName])
- },
- // 待办事务
- handleTabClick (option) {
- this.pendingBusinessOption = option
- option[this.pendingTabActiveName].dataMode = column.dataMode
- this.fetchData(option[this.pendingTabActiveName])
- },
- handleFlowClick (params) {
- params.$alias = this.alias
- this.emitActionEventHandler('flow', params)
- },
- handleCollapseExpand (command, data, actions) {
- this.bodyShow = !this.bodyShow
- const index = actions.findIndex((action) => action.key === data.key)
- actions[index].key = this.bodyShow ? 'collapse' : 'expansion'
- if (!this.visible) {
- this.emitActionEventHandler(command, {})
- return
- }
- this.showHeight = this.bodyShow ? this.getHeight() : 0
- this.$refs['toolbar'].callback(actions)
- },
- formValidate (formName) {
- this.$nextTick(() => {
- this.$refs[formName].validate(() => {})
- })
- },
- getFormData () {
- this.quickNavform = JSON.parse(JSON.stringify(this.defaultForm))
- this.formValidate('quickNavform')
- this.dialogFormVisible = true
- },
- handleNavRemove (navId, i) {
- this.$confirm('是否确认删除该快捷导航?', '提示', {
- confirmButtonText: '确认',
- cancelButtonText: '取消',
- type: 'warning',
- showClose: false,
- closeOnClickModal: false
- }).then(() => {
- delNavigation({ navigateIds: navId }).then(() => {
- this.$message.success('删除成功')
- this.quickNavigationData.splice(i, 1)
- })
- })
- },
- // 错误头像的照片
- errorAvatarHandler (data) {
- // data.photo = require('https://cube.elemecdn.com/e/fd/0fc7d20532fdaf769a25683617711png.png')
- return true
- },
- close () {
- this.$refs[this.formName].resetFields()
- this.dialogFormVisible = false
- },
- saveQuickNav () {
- this.$refs[this.formName].validate(valid => {
- if (valid) {
- addNavigation({ id: '', ...this.quickNavform }).then(res => {
- this.$message.success('添加成功!')
- const { id } = res.variables || {}
- this.quickNavigationData.unshift({ id, ...this.quickNavform, userId: this.userId })
- this.dialogFormVisible = false
- })
- } else {
- ActionUtils.saveErrorMessage()
- }
- })
- },
- handleSortChange () {
- this.isDragging = false
- const newSort = this.quickNavigationData.map(i => i.id)
- if (isEqual(this.navigationList, newSort)) {
- return
- }
- this.navigationList = newSort
- sortNavigation({ orders: this.navigationList.join(',') }).then(() => {
- this.$message.success('排序成功!')
- })
- },
- // 父组件调用该方法给日程添加数据
- async setCalendarEvents (param) {
- const { name = '' } = this.$store.getters
- const form = param.form
- const paramObject = {
- id: form.id ? form.id : '11111',
- // diDian: "string", // 地点
- userId: this.userId, // 用户id
- userName: name, // 用户名
- title: form.biaoTi, // 标题
- content: form.neiRong, // 内容
- startTime: form.formDate[0], // 开始时间
- endTime: form.formDate[1], // 结束时间
- emergencyState: form.zhuangTai // 紧急状态
- }
- await saveCalendarInfos(paramObject)
- this.refreshData()
- },
- async hanldeCalendardel (param) {
- if (param.form.id) {
- await removeCalendarInfos({
- calendarIds: param.form.id
- })
- }
- this.refreshData()
- },
- // 公告栏是否显示new图标
- showNewIcon (date, days) {
- const nowDate = new Date().getTime()
- const targetDate = new Date(date).getTime()
- return targetDate + days * 24 * 60 * 60 * 1000 > nowDate
- },
- handleOverflow (val, length) {
- if (val.length > length) {
- return val.slice(0, length - 2) + '...'
- }
- return val
- },
- getDays (start, end) {
- if (!start || !end) {
- return 0
- }
- return Math.ceil((new Date(end) - new Date(start)) / (1000 * 60 * 60 * 24))
- },
- getScheduleData () {
- const { first, second } = this.$store.getters.level || {}
- // const sql = `select a.*, b.title_,b.type_, b.start_date_, b.end_date_, b.config_, b.overview_ from t_schedule_detail a, t_schedule b where a.parent_id_ = b.id_ and b.di_dian_ = '${second || first}' and a.user_id_ = '${this.userId}'`
- return new Promise((resolve, reject) => {
- this.$common.request('query', {
- key: 'getScheduleDetailByUid',
- params: [second || first, this.userId]
- }).then(res => {
- const { data = [] } = res.variables || {}
- const eventList = []
- const self = this
- data.forEach(item => {
- const days = this.getDays(item.start_date_, item.end_date_)
- const config = item.config_ ? JSON.parse(item.config_) : {}
- const scheduleTypeLabel = scheduleType.filter(obj => obj.value === item.type_)[0]?.label || ''
- const scheduleCreateBy = self.userList.filter(obj => obj.userId === item.create_by_)[0]?.userName || ''
- const { scheduleShift } = config
- this.scheduleShift = scheduleShift
- for (let i = 1; i <= days; i++) {
- const shift = item[`d${i}_`]
- if (shift) {
- const date = this.$common.getFormatDate('string', 10, this.$common.getDate('day', i - 1, item.start_date_))
- const shiftList = shift.split(',')
- shiftList.forEach(s => {
- const t = scheduleShift.find(i => i.alias === s)
- eventList.push({
- scheduleName: item.title_ ? item.title_ : '', // 排班表名字
- scheduleTypeLabel: scheduleTypeLabel || '', // 排班类型
- scheduleCreateBy: scheduleCreateBy || '', // 排班创建人
- content: t.dateRange.map(d => {
- return d.type === 'allday' ? '全天' : (`当天 ${d.startTime}` + ' 至 ' + `${d.isSecondDay === 'Y' ? '第二天' : '当天'} ${d.endTime}`)
- }).join('\n'),
- title: s,
- start: date,
- end: date,
- jieShuShiJian: date,
- zhuangTai: '',
- id: i,
- bcolor: t.color,
- ...t
- })
- })
- }
- }
- })
- const today = this.$common.getDateNow()
- this.todaySchedule = eventList.filter(i => i.start === today).map(i => i.title)
- console.log(this.todaySchedule)
- resolve(eventList)
- }).catch(error => {
- reject(error)
- })
- })
- },
- handleScheduleEventClick (param) { // 排班点击事件
- this.$emit(
- 'open',
- 'banci',
- param.event._def.extendedProps,
- this.scheduleShift,
- param.event._def.title
- )
- },
- showMySchedule () {
- const scheduleConfig = {
- height: '100%',
- locale: 'zh-cn', // 语言
- selectable: true, // 是否可以选中日历格
- buttonText: { // 日历头部按钮中文转换
- today: '今天',
- dayGridMonth: '月',
- listMonth: '',
- month: '月',
- week: '周视图',
- day: '日视图',
- list: '表'
- // prev: '<i class="icon-chevron-left">后退</i>',
- // next: '<i class="icon-chevron-right">前进</i>'
- },
- headerToolbar: { // 日历头部按钮位置
- // left: 'prev,next today',
- // start: '',
- right: 'prev,next today',
- center: 'title'
- // right: 'dayGridMonth,timeGridWeek,timeGridDay'
- // end: 'prev,next,today,month,agendaWeek,agendaDay,listWeek'
- },
- events: this.scheduleData, // 排班数组
- eventClick: this.handleScheduleEventClick, // 排班点击信息展示
- scheduleShift: this.scheduleShift
- }
- this.$emit('action-event', 'mySchedule', scheduleConfig)
- }
- },
- template: column.templateHtml !== '' ? `${column.templateHtml}` : `<div></div>`
- }
- } catch (error) {
- console.error(error)
- }
- }
|