Commit 8832469f authored by 罗超's avatar 罗超

修改

parent ce42cba9
...@@ -17,6 +17,7 @@ ...@@ -17,6 +17,7 @@
"@types/webpack-env": "^1.16.2", "@types/webpack-env": "^1.16.2",
"axios": "^0.21.1", "axios": "^0.21.1",
"core-js": "^3.6.5", "core-js": "^3.6.5",
"echarts": "^5.6.0",
"html2canvas": "^1.4.1", "html2canvas": "^1.4.1",
"js-md5": "^0.7.3", "js-md5": "^0.7.3",
"katex": "^0.13.18", "katex": "^0.13.18",
......
...@@ -64,7 +64,7 @@ module.exports = configure(function (ctx) { ...@@ -64,7 +64,7 @@ module.exports = configure(function (ctx) {
publicPath: ctx.dev ? '/' : './', publicPath: ctx.dev ? '/' : './',
env: ctx.dev env: ctx.dev
? { ? {
BASE_APP_API: 'http://192.168.5.204:8030/api/common/post', BASE_APP_API: 'http://reborn.oytour.com/api/common/post',
JAVA_URL_API: 'http://efficient.oytour.com', JAVA_URL_API: 'http://efficient.oytour.com',
VERSION:require('./package.json').version, VERSION:require('./package.json').version,
......
import { HttpResponse } from '../@types'
import request from './request'
class NoticeService {
// 提交訂單
static async getNoticeList(param:any):Promise<HttpResponse>{
return request('User_get_NoticeGetPageList',param)
}
}
export default NoticeService
...@@ -22,9 +22,9 @@ declare module 'vue-i18n' { ...@@ -22,9 +22,9 @@ declare module 'vue-i18n' {
} }
let Language let Language
if (getDomainName()) { if (getDomainName()) {
Language = localStorage.getItem('lanuage') ?? 'inID' Language = localStorage.getItem('lanuage2') ?? 'enUS'
} else { } else {
Language = localStorage.getItem('lanuage') ?? 'inID' Language = localStorage.getItem('lanuage2') ?? 'enUS'
} }
const i18n = createI18n({ const i18n = createI18n({
locale: Language, locale: Language,
......
...@@ -115,7 +115,7 @@ export default defineComponent({ ...@@ -115,7 +115,7 @@ export default defineComponent({
getLanguage(val: SitLang) { getLanguage(val: SitLang) {
locale.value = val.langLocale ?? ""; locale.value = val.langLocale ?? "";
data.currentLang = val; data.currentLang = val;
localStorage.setItem("lanuage", val.langLocale ?? ""); localStorage.setItem("lanuage2", val.langLocale ?? "");
window.location.reload(); window.location.reload();
}, },
signOut() { signOut() {
......
...@@ -31,7 +31,7 @@ ...@@ -31,7 +31,7 @@
}}</q-item-section> }}</q-item-section>
</q-item> </q-item>
<template v-if="user && user.groupId == 2"> <template v-if="user && user.groupId == 2">
<q-item clickable v-ripple class="rounded-borders lang-demo"> <!-- <q-item clickable v-ripple class="rounded-borders lang-demo">
<q-item-section> <q-item-section>
<div class="row items-center"> <div class="row items-center">
<div class="q-mr-md">{{ $t("userMenu.myfinace") }}</div> <div class="q-mr-md">{{ $t("userMenu.myfinace") }}</div>
...@@ -42,15 +42,15 @@ ...@@ -42,15 +42,15 @@
/> />
</div> </div>
</q-item-section> </q-item-section>
</q-item> </q-item> -->
<q-item clickable v-ripple class="rounded-borders lang-demo"> <q-item clickable v-ripple class="rounded-borders lang-demo">
<q-item-section>{{ $t("userMenu.fapiao") }}</q-item-section> <q-item-section>{{ $t("userMenu.fapiao") }}</q-item-section>
</q-item> </q-item>
<q-item clickable v-ripple class="rounded-borders lang-demo"> <!-- <q-item clickable v-ripple class="rounded-borders lang-demo">
<q-item-section @click="goUrl('/passbook')">{{ <q-item-section @click="goUrl('/passbook')">{{
$t("v104.passbook.pageTitle") $t("v104.passbook.pageTitle")
}}</q-item-section> }}</q-item-section>
</q-item> </q-item> -->
</template> </template>
</q-list> </q-list>
...@@ -119,7 +119,7 @@ export default defineComponent({ ...@@ -119,7 +119,7 @@ export default defineComponent({
if (data.langs && data.langs.length > 0) { if (data.langs && data.langs.length > 0) {
data.currentLang = data.langs.find((x) => x.langLocale == locale.value) ?? {}; data.currentLang = data.langs.find((x) => x.langLocale == locale.value) ?? {};
} }
console.log(props.user)
// 切换语言 // 切换语言
const methods = { const methods = {
goUrl(url: string) { goUrl(url: string) {
...@@ -128,7 +128,7 @@ export default defineComponent({ ...@@ -128,7 +128,7 @@ export default defineComponent({
getLanguage(val: SitLang) { getLanguage(val: SitLang) {
locale.value = val.langLocale ?? ""; locale.value = val.langLocale ?? "";
data.currentLang = val; data.currentLang = val;
localStorage.setItem("lanuage", val.langLocale ?? ""); localStorage.setItem("lanuage2", val.langLocale ?? "");
window.location.reload(); window.location.reload();
}, },
signOut() { signOut() {
......
<template> <template>
<div class="bg-white q-mt-lg" :style="{'margin':$q.platform.is.mobile?'0 10px':''}"> <div class="bg-white q-mt-lg" :style="{'margin':$q.platform.is.mobile?'0 10px':''}">
<rebatehead :title="titleHead"/> <rebatehead :title="titleHead"/>
<q-separator color="grey-3" class="q-my-sm" /> <q-separator color="grey-3" class="q-my-sm" />
<div class=" q-pt-md" <div class=" q-pt-md"
:class="[$q.platform.is.desktop?'q-px-lg':'q-px-md']"> :class="[$q.platform.is.desktop?'q-px-lg':'q-px-md']">
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
<div class="self-center full-width no-outline" tabindex="0">{{ queryTime }}</div> <div class="self-center full-width no-outline" tabindex="0">{{ queryTime }}</div>
<q-popup-proxy cover transition-show="scale" <q-popup-proxy cover transition-show="scale"
:offset="[0, 7]" transition-hide="scale" ref="qDateProxy" > :offset="[0, 7]" transition-hide="scale" ref="qDateProxy" >
<q-date v-model="queryTime" mask="YYYY-MM" <q-date v-model="queryTime" mask="YYYY-MM"
reason="month" reason="month"
default-view="Months" default-view="Months"
default-year-month="2024-01" default-year-month="2024-01"
...@@ -49,7 +49,7 @@ ...@@ -49,7 +49,7 @@
<q-separator color="grey-3" /> <q-separator color="grey-3" />
<div class="column"> <div class="column">
<template v-if="dataList&&dataList.length>0"> <template v-if="dataList&&dataList.length>0">
<div <div
v-for="(item,index) in dataList" v-for="(item,index) in dataList"
class="row items-center left-text text-dark"> class="row items-center left-text text-dark">
<div>{{item.updateTime}}</div> <div>{{item.updateTime}}</div>
...@@ -66,7 +66,7 @@ ...@@ -66,7 +66,7 @@
</div> </div>
</template> </template>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
...@@ -95,7 +95,7 @@ ...@@ -95,7 +95,7 @@
const main = ref(); const main = ref();
const timeStamp = Date.now() const timeStamp = Date.now()
const formattedString = date.formatDate(timeStamp, 'MM') const formattedString = date.formatDate(timeStamp, 'MM')
const data=reactive({ const data=reactive({
dateRange: {} as any, dateRange: {} as any,
queryTime: '', queryTime: '',
...@@ -109,12 +109,12 @@ ...@@ -109,12 +109,12 @@
const methods = { const methods = {
dateRangeHandler(event) { dateRangeHandler(event) {
if(event&&event.year&&event.month){ if(event&&event.year&&event.month){
data.queryTime = event.year+'-'+(event.month>10?event.month:'0'+event.month) data.queryTime = event.year+'-'+(event.month>10?event.month:'0'+event.month)
} }
else data.queryTime = '' else data.queryTime = ''
if(qDateProxy.value) qDateProxy.value.hide() if(qDateProxy.value) qDateProxy.value.hide()
methods.getList() methods.getList()
}, },
getList(){ getList(){
let CustomerId let CustomerId
...@@ -127,7 +127,7 @@ ...@@ -127,7 +127,7 @@
// let list = r.data.data.pageData.forEach(item=>{ // let list = r.data.data.pageData.forEach(item=>{
// item.updateTime = date.formatDate(item.updateTime, 'YYYY/MM/DD') // item.updateTime = date.formatDate(item.updateTime, 'YYYY/MM/DD')
// }) // })
data.dataList= r.data.data.pageData; data.dataList= r.data.data.pageData;
} else { } else {
message.errorMsg(r.data.message) message.errorMsg(r.data.message)
} }
......
...@@ -15,8 +15,10 @@ class DirtionmaryHelper { ...@@ -15,8 +15,10 @@ class DirtionmaryHelper {
*/ */
static readonly MENU_KEYS='Current_Menu_Cehck' static readonly MENU_KEYS='Current_Menu_Cehck'
/**
* 公告彈窗數據
*/
static readonly NOTICE_DIALOG_DATA = 'noticeDialogData'
/** /**
* 菜單選項 * 菜單選項
*/ */
...@@ -33,7 +35,7 @@ class DirtionmaryHelper { ...@@ -33,7 +35,7 @@ class DirtionmaryHelper {
* 酒店查詢參數 * 酒店查詢參數
*/ */
static readonly HOTEL_QUERY_PARAM = 'hotelqueryparam' static readonly HOTEL_QUERY_PARAM = 'hotelqueryparam'
/** /**
* 道旅酒店查詢參數 * 道旅酒店查詢參數
*/ */
......
export default { export default {
lanuage: 'Language',
failed: 'Execution failed', failed: 'Execution failed',
success: 'Execution successful', success: 'Execution successful',
appsuffix: 'PIC Interbank Booking System', appsuffix: 'PIC Interbank Booking System',
siteName: 'Interbank Booking System', siteName: 'Interbank Booking System',
language: 'System language', language: 'Language',
loginout: 'Login information invalid, please log in again', loginout: 'Login information invalid, please log in again',
timeout: 'Current network environment is abnormal, request timeout', timeout: 'Current network environment is abnormal, request timeout',
syslog: 'System Upgrade Notice', syslog: 'System Upgrade Notice',
sysmsg: 'System notification', sysmsg: 'System notification',
daterange: 'Please select the retrieval date', daterange: 'Please choose a date',
morequery: 'More filtering options', morequery: 'More filtering options',
query: 'Search', query: 'Search',
noneData: 'No relevant data found', noneData: 'No relevant data found',
...@@ -33,19 +34,20 @@ export default { ...@@ -33,19 +34,20 @@ export default {
d: 'Seaside Resort Hotel' d: 'Seaside Resort Hotel'
}, },
personal: { personal: {
ProfileDetails: 'Detail Profile',
pageTitle: 'Personal Profile', pageTitle: 'Personal Profile',
trading: 'Accumulated transaction amount', trading: 'Accumulated transaction amount',
order: 'Order quantity', order: 'Order quantity',
cancel: 'Cancellation rate', cancel: 'Cancellation rate',
profileDetails: 'Data details', profileDetails: 'Data details',
travelAgency: 'Name of travel agency', TravelAgency: 'Travel Name',
numbering: 'Unified numbering (unified)', numbering: 'Unified numbering (unified)',
LINEID: 'LINE ID', LINEID: 'LINE ID',
Phone: 'Contact number', Phone: 'Contact number',
address: 'Office address', addreess: 'Address',
Name: 'Name', Name: 'Name',
Email: 'Email', Email: 'Email',
post: 'Responsible person', post: 'PIC',
profile: 'Overview', profile: 'Overview',
security: 'Account security', security: 'Account security',
accountUpdate: 'Account information modification prompt', accountUpdate: 'Account information modification prompt',
...@@ -134,12 +136,12 @@ export default { ...@@ -134,12 +136,12 @@ export default {
recovery: 'Order Recycle Bin', recovery: 'Order Recycle Bin',
copy: 'Copy', copy: 'Copy',
copyed: 'Copied', copyed: 'Copied',
createTime: 'Order time', createTime: 'Booking Time',
priceTips: 'Based on the number of occupants * unit price of room type=subtotal of total room type price (excluding tax)', priceTips: 'Based on the number of occupants * unit price of room type=subtotal of total room type price (excluding tax)',
people: 'Number of people', people: 'Number of people',
unitPrice: 'Unit price', unitPrice: 'Unit price',
xj: 'Sub', xj: 'Sub',
orderMoney: 'Total order amount', orderMoney: 'Total Amount',
payed: 'Paid', payed: 'Paid',
warn: 'View reserved precautions', warn: 'View reserved precautions',
taxed: 'including tax', taxed: 'including tax',
...@@ -173,7 +175,7 @@ export default { ...@@ -173,7 +175,7 @@ export default {
}, },
search: { search: {
status: 'Order status', status: 'Order status',
orderNum: 'Order number', orderNum: 'Booking Number',
daterange: 'Order placement time', daterange: 'Order placement time',
roomType: 'Hotel Room Type', roomType: 'Hotel Room Type',
orderId: 'Order serial number', orderId: 'Order serial number',
...@@ -256,7 +258,7 @@ export default { ...@@ -256,7 +258,7 @@ export default {
title1: 'Days, check-in', title1: 'Days, check-in',
title2: 'Hotels', title2: 'Hotels',
subtitle: 'Hotel Purchase Order', subtitle: 'Hotel Purchase Order',
sumPrice: 'Total order amount' sumPrice: 'Total Amount'
}, },
shopping: { shopping: {
labelNum: 'Number of rooms', labelNum: 'Number of rooms',
...@@ -321,7 +323,7 @@ export default { ...@@ -321,7 +323,7 @@ export default {
mypro: 'Personal profile', mypro: 'Personal profile',
myfinace: 'Request letter', myfinace: 'Request letter',
fapiao: 'Request invoice', fapiao: 'Request invoice',
lang: 'System Language', lang: 'Language',
signOut: 'Log out' signOut: 'Log out'
}, },
menu: { menu: {
...@@ -357,88 +359,120 @@ export default { ...@@ -357,88 +359,120 @@ export default {
three: 'Remittance instructions' three: 'Remittance instructions'
}, },
travel: { travel: {
first: 'PAK', first: 'Consrotium',
second: 'PAK group', second: 'Group Detail',
three: 'PAK order', three: 'Booking list',
four: 'PAK settlement', four: 'Settlement',
} },
notice: {
first: 'Announcement',
second: 'List',
}
}, },
notice: {
pageTitle: 'Announcement',
search: {
title: 'Announcement Title',
},
column: {
title: 'Announcement Title',
publisher: 'Publisher',
releaseDate: 'Release Date',
action: 'Action',
},
placeholder: {
title: 'Please enter the title',
},
view:'View',
detail: {
title: 'Announcement Details',
file: 'Attachment',
}
},
travel: { travel: {
status:{
normal:'All',
regular:'Regular',
reserve:'Reserve',
waiting:'Waiting List',
cancel:'Cancel'
},
start:'Departure', start:'Departure',
download:'Download itinerary', download:'Download itinerary',
returnMoney:'Current return amount', returnMoney:'Return Amount',
queryDetail:'View return details', queryDetail:'View Return Amount',
peopleRequired:'Number of people required', peopleRequired:'Number of People',
totalSeat:'Total team', totalSeat:'Total Seat',
ratio:'Return ratio', ratio:'Return Amount',
current:'Current', current:'Current',
people:'person', people:'person',
startCity:'Departure city', startCity:'Departure city',
man: 'Number of adults', man: 'Adult',
addTitle: 'Add/Modify Order', addTitle: 'Additional/Edit',
oldPeople: 'Number of elderly people', oldPeople: 'Number of elderly people',
childNeedBed: 'Children occupying beds', childNeedBed: 'Child w bed',
children: 'Number of children', children: 'Child',
ChirdNoNeedBedNum: 'Children do not occupy beds', ChirdNoNeedBedNum: 'Child w/o bed',
NoNeedBed: 'No bed occupied', NoNeedBed: 'Child w/o bed',
Baby: 'Baby', Baby: 'Infant',
BabyNum: 'Number of Babies', BabyNum: 'Infant',
SingleRoomNum: 'Number of rooms per unit', SingleRoomNum: 'Total Single Room',
VisaNum: 'Number of visas', VisaNum: 'Visa',
OneSex: 'Single men and women', OneSex: 'Additional Person',
male: 'Male', male: 'Male',
woman: 'Female', woman: 'Female',
PredictRoomNum: 'Expected room usage', PredictRoomNum: 'Total Room',
YSeatNum: 'Economy Class', YSeatNum: 'Economy Class',
FSeatNum: 'First Class', FSeatNum: 'First Class',
ESeatNum: 'Business Class', ESeatNum: 'Business Class',
ContactName: 'Contact', ContactName: 'Contact',
ContactMobile: 'Contact phone number', ContactMobile: 'Contact phone number',
Remarks: 'Remarks', Remarks: 'Remarks',
PreferPrice: 'Order price', PreferPrice: 'Total Amount',
cancel: 'Cancel', cancel: 'Cancel',
submit: 'Confirm', submit: 'Confirm',
pays: 'Received amount', pays: 'Receive Amount',
startDate: 'Departure date', startDate: 'Departure date',
guestNum: 'Number of customers', guestNum: 'Total Pax',
unit_Price: 'Transaction Unit Price', unit_Price: 'Final Price',
tC_Price: 'Unit price of this group', tC_Price: 'Selling Price',
tradeWay: 'Payment method', tradeWay: 'Payment method',
online: 'Online', online: 'Online',
notLine: 'Offline', notLine: 'Offline',
all: 'unlimited', all: 'All',
notPay: 'Deposit to be collected', notPay: 'Deposit to be collected',
payed: 'Pending final payment', payed: 'Pending final payment',
orderStatus: 'Order status', orderStatus: 'Booking Status',
createDate: 'Creation date', createDate: 'Booking Date',
payStatus: 'Payment Status', payStatus: 'Payment Status',
id: 'Team ID', id: 'Code Group',
planInfo: 'Charter flight information', planInfo: 'Charter flight information',
groupInfo: 'Team Information', groupInfo: 'Team Information',
airInfo: 'Flight information', airInfo: 'Flight information',
tmp: 'tentative', tmp: 'tentative',
airSeatInfo: 'Location information', airSeatInfo: 'Seat lnformation',
YSeat: 'Economy Class', YSeat: 'Economy Class',
unUseNum: 'Remaining', unUseNum: 'Seat Availability',
CSeat: 'Business Class', CSeat: 'Business Class',
FSeat: 'First Class', FSeat: 'First Class',
priceInfo: 'Price information', priceInfo: 'Price information',
midPrice: 'Center Price', midPrice: 'Consortium Price',
BabyChargePrice: "Children's Surcharge", BabyChargePrice: "Children's Surcharge",
OldManChargePrice: 'Elderly Surcharge', OldManChargePrice: 'Elderly Surcharge',
VisaPrice: 'Visa', VisaPrice: 'Visa',
SingleRoomPrice: 'Single room price difference', SingleRoomPrice: 'Single Supplement',
OtherPrice: 'Miscellaneous fees', OtherPrice: 'Other',
buy: 'Place an order', buy: 'Booking',
payOrder: 'Charter flight settlement', payOrder: 'Settlement',
noData: 'There is currently no data available', noData: 'There is currently no data available',
ContactNamePay: 'Partner', ContactNamePay: 'Partner',
EntGuestNum: 'Number of people on the list', EntGuestNum: 'Name List Receive',
GuestNum: 'Total number of registrations', GuestNum: 'Total Registration',
PreferPricePay: 'Total amount receivable', PreferPricePay: 'Total amount receivable',
Refund: 'Refund amount', Refund: 'Refund amount',
PlatformTax: 'Platform Tax', PlatformTax: 'Platform Tax',
Income: 'Received', Income: 'Receive',
ZaiTuMoney: 'In transit amount', ZaiTuMoney: 'In transit amount',
DiscountMoney: 'Discount amount', DiscountMoney: 'Discount amount',
RedEnvelopeMoney: 'Deduction amount for large red envelopes', RedEnvelopeMoney: 'Deduction amount for large red envelopes',
...@@ -449,10 +483,10 @@ export default { ...@@ -449,10 +483,10 @@ export default {
notaccess: 'Do you have any interbank member accounts?', notaccess: 'Do you have any interbank member accounts?',
registerlink: 'Apply for registration', registerlink: 'Apply for registration',
title: 'Login', title: 'Login',
subTitle: 'Welcome to our store and start our urgent procurement.', subTitle: '',//'Welcome to our store and start our urgent procurement.',
account: 'Account (EMail/Unified Editor)', account: 'ID',
password: 'Password', password: 'Password',
forgot: 'Forgot password?', forgot: 'Forget Password?',
signin: 'Login', signin: 'Login',
pageTitle: 'Login', pageTitle: 'Login',
ruleTipsAccount: 'Please fill in the correct account', ruleTipsAccount: 'Please fill in the correct account',
...@@ -513,7 +547,7 @@ export default { ...@@ -513,7 +547,7 @@ export default {
dindanbaojia: 'Hotel order quotation', dindanbaojia: 'Hotel order quotation',
zhutuanhao: 'Group number', zhutuanhao: 'Group number',
lianxiren: 'Contact person', lianxiren: 'Contact person',
dindanhao: 'Order number', dindanhao: 'Booking Number',
riqi: 'Date', riqi: 'Date',
HotelDate: 'check-in time', HotelDate: 'check-in time',
HotelName: 'Hotel name', HotelName: 'Hotel name',
...@@ -799,7 +833,7 @@ export default { ...@@ -799,7 +833,7 @@ export default {
baojiaqueren: 'Is the quotation not confirmed immediately?', baojiaqueren: 'Is the quotation not confirmed immediately?',
jiagejihua: 'Price plan name', jiagejihua: 'Price plan name',
lutiankefang: 'Outdoor Guestroom', lutiankefang: 'Outdoor Guestroom',
ordermount: 'Total order amount', ordermount: 'Total Amount',
renmingbi: 'RMB', renmingbi: 'RMB',
youhui: 'Discount', youhui: 'Discount',
shifu: 'Actual payment', shifu: 'Actual payment',
...@@ -870,7 +904,7 @@ export default { ...@@ -870,7 +904,7 @@ export default {
shiyong: 'Using', shiyong: 'Using',
youxiaoqi: 'Validity period', youxiaoqi: 'Validity period',
notiaojian: 'This coupon does not meet the usage requirements!', notiaojian: 'This coupon does not meet the usage requirements!',
dindanhao: 'Order number', dindanhao: 'Booking Number',
}, },
scatteredOrderList: { scatteredOrderList: {
state1: 'To be paid', state1: 'To be paid',
...@@ -878,7 +912,7 @@ export default { ...@@ -878,7 +912,7 @@ export default {
state3: 'Canceled', state3: 'Canceled',
first: 'Hotel name', first: 'Hotel name',
table1: 'Hotel Name', table1: 'Hotel Name',
table2: 'Order Number', table2: 'Booking Number',
table3: 'Number of rooms', table3: 'Number of rooms',
table4: 'Total amount', table4: 'Total amount',
table5: 'Actual payment', table5: 'Actual payment',
...@@ -973,7 +1007,7 @@ export default { ...@@ -973,7 +1007,7 @@ export default {
rtc: 'Non consumption can be refunded at any time, partial refund is not supported for multiple ticket orders', rtc: 'Non consumption can be refunded at any time, partial refund is not supported for multiple ticket orders',
ms: 'Ticket booking details', ms: 'Ticket booking details',
nt: 'No ticket selected', nt: 'No ticket selected',
ds: 'Total order amount', ds: 'Total Amount',
sb: 'Submit Order', sb: 'Submit Order',
or: 'Order remarks', or: 'Order remarks',
zqa: 'Self pickup address', zqa: 'Self pickup address',
...@@ -1158,9 +1192,9 @@ export default { ...@@ -1158,9 +1192,9 @@ export default {
c11: 'Flight number', c11: 'Flight number',
c12: 'Flight arrival time', c12: 'Flight arrival time',
c13: 'Flight departure time', c13: 'Flight departure time',
c14: 'Number of adults', c14: 'Adult',
c15: 'Number of children', c15: 'Child',
c16: 'Number of infants', c16: 'Infant',
c17: 'Number of hand luggage', c17: 'Number of hand luggage',
c18: 'Number of running bags', c18: 'Number of running bags',
c19: 'Product name', c19: 'Product name',
......
...@@ -428,7 +428,7 @@ export default { ...@@ -428,7 +428,7 @@ export default {
SingleRoomPrice: 'Harga kamar single', SingleRoomPrice: 'Harga kamar single',
OtherPrice: 'Biaya lain-lain', OtherPrice: 'Biaya lain-lain',
buy: 'Pesan', buy: 'Pesan',
payOrder: 'Penyelesaian penerbangan charter', payOrder: 'Keselesaian komisi',
noData: 'Belum ada data', noData: 'Belum ada data',
ContactNamePay: 'Mitra', ContactNamePay: 'Mitra',
EntGuestNum: 'Jumlah orang dalam daftar', EntGuestNum: 'Jumlah orang dalam daftar',
......
import enUS from './en-US' import enUS from './en-US'
import zhTW from './zh-TW' import zhTW from './zh-TW'
import zhSW from './zh-SW' import zhSW from './zh-SW'
import koHG from './ko-HG' // import koHG from './ko-HG'
import jaRB from './ja-RB' import jaRB from './ja-RB'
import inID from './in-ID' // import inID from './in-ID'
export default { export default {
enUS, enUS,
zhTW, zhTW,
zhSW, zhSW,
koHG, //koHG,
jaRB, jaRB,
inID //inID
} }
...@@ -361,9 +361,20 @@ export default { ...@@ -361,9 +361,20 @@ export default {
second: 'PAK 団', second: 'PAK 団',
three: 'PAK オーダー', three: 'PAK オーダー',
four: 'PAK 決済', four: 'PAK 決済',
},
notice: {
first: 'お知らせ',
second: 'リスト',
} }
}, },
travel: { travel: {
status:{
normal:'すべて',
regular:'正常',
reserve:'占位',
waiting:'候補',
cancel:'取消'
},
start:'出発', start:'出発',
download:'行程をダウンロード', download:'行程をダウンロード',
returnMoney:'現在の返佣金額', returnMoney:'現在の返佣金額',
...@@ -430,7 +441,7 @@ export default { ...@@ -430,7 +441,7 @@ export default {
SingleRoomPrice: 'シングルルーム差額', SingleRoomPrice: 'シングルルーム差額',
OtherPrice: '雑費', OtherPrice: '雑費',
buy: '注文する', buy: '注文する',
payOrder: 'チャーターチェックアウト', payOrder: '佣金結算',
noData: 'データなし', noData: 'データなし',
ContactNamePay: 'パートナー', ContactNamePay: 'パートナー',
EntGuestNum: 'リストの人数', EntGuestNum: 'リストの人数',
......
...@@ -364,6 +364,13 @@ export default { ...@@ -364,6 +364,13 @@ export default {
} }
}, },
travel: { travel: {
status:{
normal:'전체',
regular:'정상',
reserve:'예약',
waiting:'대기',
cancel:'취소'
},
start:'출발', start:'출발',
download:'여정 다운로드', download:'여정 다운로드',
returnMoney:'현재 반환 금액', returnMoney:'현재 반환 금액',
...@@ -430,7 +437,7 @@ export default { ...@@ -430,7 +437,7 @@ export default {
SingleRoomPrice: '싱글 룸 차이', SingleRoomPrice: '싱글 룸 차이',
OtherPrice: '기타 비용', OtherPrice: '기타 비용',
buy: '주문하기', buy: '주문하기',
payOrder: '전세 체크아웃', payOrder: '커미션 결제',
noData: '전세 체크아웃', noData: '전세 체크아웃',
ContactNamePay: '파트너', ContactNamePay: '파트너',
EntGuestNum: '목록에 있는 사람 수', EntGuestNum: '목록에 있는 사람 수',
......
...@@ -361,9 +361,20 @@ export default { ...@@ -361,9 +361,20 @@ export default {
second: 'PAK团表', second: 'PAK团表',
three: 'PAK订单', three: 'PAK订单',
four: 'PAK結算', four: 'PAK結算',
},
notice: {
first: '公告栏',
second: '列表',
} }
}, },
travel: { travel: {
status:{
normal:'全部',
regular:'正常',
reserve:'占位',
waiting:'候补',
cancel:'取消'
},
start:'出发', start:'出发',
download:'下载行程', download:'下载行程',
returnMoney:'当前返佣金額', returnMoney:'当前返佣金額',
...@@ -430,7 +441,7 @@ export default { ...@@ -430,7 +441,7 @@ export default {
SingleRoomPrice: '单房差', SingleRoomPrice: '单房差',
OtherPrice: '杂费', OtherPrice: '杂费',
buy: '下单', buy: '下单',
payOrder: '包机结算', payOrder: '佣金结算',
noData: '暂无数据', noData: '暂无数据',
ContactNamePay: '合作伙伴', ContactNamePay: '合作伙伴',
EntGuestNum: '已入名单人数', EntGuestNum: '已入名单人数',
......
...@@ -361,9 +361,24 @@ export default { ...@@ -361,9 +361,24 @@ export default {
second: 'PAK团表', second: 'PAK团表',
three: 'PAK订单', three: 'PAK订单',
four: 'PAK結算', four: 'PAK結算',
},
notice: {
first: '公告欄',
second: '列表',
} }
}, },
notice: {
pageTitle: '公告欄',
},
travel: { travel: {
status:{
normal:'全部',
regular:'正常',
reserve:'占位',
waiting:'候補',
cancel:'取消'
},
start:'出發', start:'出發',
download:'下載行程', download:'下載行程',
returnMoney:'当前返佣金額', returnMoney:'当前返佣金額',
...@@ -430,7 +445,7 @@ export default { ...@@ -430,7 +445,7 @@ export default {
SingleRoomPrice: '單房差', SingleRoomPrice: '單房差',
OtherPrice: '雜費', OtherPrice: '雜費',
buy: '下單', buy: '下單',
payOrder: '包機結算', payOrder: '佣金结算',
noData: '暫無數據', noData: '暫無數據',
ContactNamePay: '合作夥伴', ContactNamePay: '合作夥伴',
EntGuestNum: '已入名單人數', EntGuestNum: '已入名單人數',
......
...@@ -10,37 +10,22 @@ ...@@ -10,37 +10,22 @@
<div class="mobile-only q-ml-md text-dark text-h6 text-weight-bold">PIC</div> <div class="mobile-only q-ml-md text-dark text-h6 text-weight-bold">PIC</div>
<div class="mls text-h6 text-dark desktop-only">{{ childPageTitle }}</div> <div class="mls text-h6 text-dark desktop-only">{{ childPageTitle }}</div>
</div> </div>
<div <div class="bg-grey-2 rounded-borders q-px-md f12 text-grey-800 q-mr-md desktop-only">
class="bg-grey-2 rounded-borders q-px-md f12 text-grey-800 q-mr-md desktop-only"
>
{{ version }} {{ version }}
</div> </div>
<div class="rounded-borders header-item q-mr-lg"> <div class="rounded-borders header-item q-mr-lg">
<svg-icon <svg-icon color="grey" icon="design/component.svg" :size="25" :tips="$t('syslog')"></svg-icon>
color="grey"
icon="design/component.svg"
:size="25"
:tips="$t('syslog')"
></svg-icon>
</div> </div>
<div class="rounded-borders header-item q-mr-lg" style="position: right"> <div class="rounded-borders header-item q-mr-lg" style="position: right">
<div v-if="isDadge" class="header-badge bg-green-4"></div> <div v-if="isDadge" class="header-badge bg-green-4"></div>
<svg-icon <svg-icon color="grey" icon="Communication/Chat6.svg" :size="25" :tips="$t('sysmsg')"> </svg-icon>
color="grey"
icon="Communication/Chat6.svg"
:size="25"
:tips="$t('sysmsg')"
>
</svg-icon>
<q-popup-proxy :offset="[0, 15]" class="no-shadow"> <q-popup-proxy :offset="[0, 15]" class="no-shadow">
<Notifications :user="userInfo"></Notifications> <Notifications :user="userInfo"></Notifications>
</q-popup-proxy> </q-popup-proxy>
</div> </div>
<q-avatar size="40px" rounded class="bg-blue-2 cursor-pointer"> <q-avatar size="40px" rounded class="bg-blue-2 cursor-pointer">
<q-img :src="userInfo.photo" v-if="userInfo?.photo" mode="cover" /> <q-img :src="userInfo.photo" v-if="userInfo?.photo" mode="cover" />
<span class="text-primary text-h6" v-else>{{ <span class="text-primary text-h6" v-else>{{ userInfo.name?.substring(0, 1) }}</span>
userInfo.name?.substring(0, 1)
}}</span>
<q-popup-proxy :offset="[0, 15]" class="no-shadow"> <q-popup-proxy :offset="[0, 15]" class="no-shadow">
<user-info :user="userInfo"></user-info> <user-info :user="userInfo"></user-info>
</q-popup-proxy> </q-popup-proxy>
...@@ -49,47 +34,26 @@ ...@@ -49,47 +34,26 @@
</q-toolbar> </q-toolbar>
</q-header> </q-header>
<q-drawer <q-drawer show-if-above v-model="leftDrawerOpen" style="background: #1e1e2d; width: 265px" side="left"
show-if-above class="column">
v-model="leftDrawerOpen" <div class="column items-center q-mt-sm" style="color: #fff;zoom: .5;">
style="background: #1e1e2d; width: 265px" <img src="../assets/img/newLogo.jpg" style="height: 80px; filter: brightness(0) invert(1);">
side="left" <!-- <div style="width: 50px; overflow: hidden">
class="column" <img v-if="isDomainName_PIC" src="../assets/images/jvs-log.png" style="height: 40px" />
> <img v-else src="http://imgfile.oytour.com/Upload/WebSite/202303170746500900000000054.png" style="height: 40px" />
<div </div>
style="box-sizing: border-box; height: 66px; border-bottom: 1px dashed #444" <div class="text-h6 text-weight-bold" style="font-family: math">PEACE INTERNATIONAL</div>
class="row items-center q-px-md desktop-only" <div class="text-body2 text-weight-thin text-italic" style="font-family: math">by MILLENNIUM</div> -->
>
<img
v-if="isDomainName_PIC"
src="../assets/images/pic-log.png"
alt=""
style="height: 30px"
/>
<img
v-else
src="https://viitto-1301420277.cos.ap-chengdu.myqcloud.com/Test/Upload/Goods/1679454107000_656.png"
alt=""
style="height: 30px"
/>
<!-- <div class="text-white text-weight-bold text-subtitle1 q-ml-md">{{ $t('siteName') }}</div> -->
</div> </div>
<q-scroll-area <q-scroll-area :thumb-style="scrollStyle.thumbStyle" :bar-style="scrollStyle.barStyle"
:thumb-style="scrollStyle.thumbStyle" class="col nav-list q-pl-lg">
:bar-style="scrollStyle.barStyle"
class="col nav-list q-pl-lg"
>
<navs></navs> <navs></navs>
</q-scroll-area> </q-scroll-area>
</q-drawer> </q-drawer>
<q-page-container class="window-height" id="scrollId"> <q-page-container class="window-height" id="scrollId">
<q-scroll-area <q-scroll-area ref="scrollAreaRef" :thumb-style="scrollStyle.thumbStyle" :bar-style="scrollStyle.barStyle"
ref="scrollAreaRef" class="full-height">
:thumb-style="scrollStyle.thumbStyle"
:bar-style="scrollStyle.barStyle"
class="full-height"
>
<router-view /> <router-view />
</q-scroll-area> </q-scroll-area>
</q-page-container> </q-page-container>
...@@ -102,120 +66,180 @@ ...@@ -102,120 +66,180 @@
</q-toolbar> </q-toolbar>
</q-footer> --> </q-footer> -->
</q-layout> </q-layout>
<q-dialog class="no-padding" v-model="noticeDialogVisible" persistent>
<q-card flat class="q-pa-md column" style="width:60vw;min-width: 375px; height: 80vh;">
<div class="text-h6 text-weight-bold full-width text-center">
{{ noticeDialogData.Title }}
</div>
<div class="text-center" style="font-size: 12px; font-weight: 400;">
<span class="text-grey-500">{{ $t('notice.column.publisher') }}{{ noticeDialogData.UpdateName }}</span>
<span class="text-grey-500 q-ml-md">{{ $t('notice.column.releaseDate') }} {{ noticeDialogData.Notice_date }}</span>
</div>
<div style="overflow-y: auto;" class="text-body2 q-mt-md full-width col q-pa-md" v-html="noticeDialogData.Content"></div>
<div class="q-mt-md row items-center" v-if="fileList.length > 0">
<span class="text-grey-500">{{ $t('notice.detail.file') }}</span>
<q-btn v-for="(x,i) in fileList" dense :key="i" color="primary" flat unelevated :label="x.Name" @click="downloadFile(x)" />
</div>
<div class="q-mt-md text-right">
<q-btn color="primary" flat unelevated @click="noticeDialogVisible = false" :label="$t('close')" />
</div>
</q-card>
</q-dialog>
</template> </template>
<script lang="ts"> <script lang="ts">
import { import { inject, provide, reactive, ref, toRefs, onMounted, watch } from 'vue'
inject, import { getStoreGetter } from '../store/utils'
provide, import { UserGetter } from '../store/modules/user/getters'
reactive, import svgIcon from '../components/global/svg-icon.vue'
ref, import useScrollModule from '../module/scrollbar/scrollModule'
toRefs, import Navs from '../components/layout/navs.vue'
onMounted, import userInfo from '../components/layout/userInfo.vue'
computed, import Notifications from '../components/layout/Notifications.vue'
watch, import { DirtionmaryHelper } from '../config/dictionary'
nextTick, import { AppConfig } from 'src/config/app'
} from "vue"; import scheduledTripService from 'src/api/scheduledTrip'
import { getStoreGetter } from "../store/utils"; import Store from '../store'
import { UserGetter } from "../store/modules/user/getters"; import { ApiResult } from 'src/@types/enumHelper'
import svgIcon from "../components/global/svg-icon.vue"; import message from 'src/utils/message'
import useScrollModule from "../module/scrollbar/scrollModule"; import { useI18n } from 'vue-i18n'
import Navs from "../components/layout/navs.vue"; import NoticeService from 'src/api/notice'
import userInfo from "../components/layout/userInfo.vue";
import Notifications from "../components/layout/Notifications.vue";
import { DirtionmaryHelper } from "../config/dictionary";
import { env } from "process";
import { AppConfig } from "src/config/app";
import scheduledTripService from "src/api/scheduledTrip";
import Store from "../store";
import { ApiResult } from "src/@types/enumHelper";
import message from "src/utils/message";
export default { export default {
components: { svgIcon, Navs, userInfo, Notifications }, components: { svgIcon, Navs, userInfo, Notifications },
setup() { setup() {
const leftDrawerOpen = ref(false); const leftDrawerOpen = ref(false)
const noticeDialogVisible = ref(false)
const noticeDialogData = ref<any>(null)
const fileList = ref<any[]>([])
const data = reactive({ const data = reactive({
userInfo: {} as any, userInfo: {} as any,
leftDrawerOpen: false, leftDrawerOpen: false,
scrollStyle: {} as any, scrollStyle: {} as any,
timer: 0, timer: 0,
isDadge: true, isDadge: true,
version: "", version: '',
isDomainName_PIC: true, isDomainName_PIC: true
}); })
const { t } = useI18n()
const downloadFile = async (file: any) => {
const url = 'http://imgfile.oytour.com/'+file.Url
try {
const response = await fetch(url)
const blob = await response.blob()
const filename = url.split('/').pop() || 'download'
const link = document.createElement('a')
link.href = window.URL.createObjectURL(blob)
link.download = filename
document.body.appendChild(link)
link.click()
document.body.removeChild(link)
window.URL.revokeObjectURL(link.href)
} catch (error) {
//message.errorMsg(t('downloadFailed'))
}
}
// 根据域名渲染logo // 根据域名渲染logo
data.isDomainName_PIC = inject(DirtionmaryHelper.DOMAIN_NAME); data.isDomainName_PIC = inject(DirtionmaryHelper.DOMAIN_NAME)
const childPageTitle = ref("");
provide(DirtionmaryHelper.PAGE_TITLE_KEY, childPageTitle);
const activeMenu = ref(0);
provide(DirtionmaryHelper.MENU_KEYS, activeMenu);
data.userInfo = getStoreGetter<UserGetter>("user", "getUser");
data.scrollStyle = useScrollModule().scrollStyle; const childPageTitle = ref('')
provide(DirtionmaryHelper.NOTICE_DIALOG_DATA, noticeDialogData)
provide(DirtionmaryHelper.PAGE_TITLE_KEY, childPageTitle)
const activeMenu = ref(0)
provide(DirtionmaryHelper.MENU_KEYS, activeMenu)
data.userInfo = getStoreGetter<UserGetter>('user', 'getUser')
data.scrollStyle = useScrollModule().scrollStyle
const scrollAreaRef = ref(); const scrollAreaRef = ref()
const scrollArea = reactive({ const scrollArea = reactive({
pagesTop: 0, pagesTop: 0
}); })
// 储存滚动位置 // 储存滚动位置
provide(DirtionmaryHelper.SCROLL_AREA_OBJ, scrollArea); provide(DirtionmaryHelper.SCROLL_AREA_OBJ, scrollArea)
watch( watch(
() => scrollArea.pagesTop, () => scrollArea.pagesTop,
(n, o) => { (n, o) => {
scrollAreaRef.value.setScrollPosition("vertical", n, 100); scrollAreaRef.value.setScrollPosition('vertical', n, 100)
} }
); )
watch(
() => noticeDialogData.value,
(n, o) => {
console.log(n)
noticeDialogVisible.value = (noticeDialogData.value && noticeDialogData.value?.Id > 0)
console.log(noticeDialogVisible.value)
if(noticeDialogData.value?.File_url){
fileList.value = JSON.parse(noticeDialogData.value?.File_url)
}else{
fileList.value = []
}
},
{ immediate: true, deep: true }
)
const methods = { const methods = {
toggleLeftDrawer() { toggleLeftDrawer() {
data.leftDrawerOpen = !data.leftDrawerOpen; data.leftDrawerOpen = !data.leftDrawerOpen
}, },
//获取网站配置数据 //获取网站配置数据
getConfigData() { getConfigData() {
scheduledTripService scheduledTripService
.GetWebSiteConfig({ .GetWebSiteConfig({
RB_Group_Id: Store.state.user?.userDetail?.groupId, RB_Group_Id: Store.state.user?.userDetail?.groupId,
B2BDomain: Store.state.user?.userDetail?.name, B2BDomain: Store.state.user?.userDetail?.name
}) })
.then((r) => { .then(r => {
if (r.data.resultCode == ApiResult.SUCCESS) { if (r.data.resultCode == ApiResult.SUCCESS) {
if (r.data.data) { if (r.data.data) {
var jsonData = JSON.stringify(r.data.data); var jsonData = JSON.stringify(r.data.data)
localStorage.setItem("baseifo", jsonData); localStorage.setItem('baseifo', jsonData)
} }
} else { } else {
message.errorMsg(r.data.message); message.errorMsg(r.data.message)
} }
}) })
.catch((e) => { .catch(e => {
message.errorMsg(e.message); message.errorMsg(e.message)
}); })
}, }
}; }
const getNoticeList = async () => {
// @TODO 获取公告列表
// const res = await NoticeService.getNoticeList({
// pageIndex: 1,
// pageSize: 100,
// Title: '',
// StartDate: '',
// EndDate: '',
// status: 1
// })
// console.log(res)
}
onMounted(() => { onMounted(() => {
if (!localStorage.getItem("baseifo")) { if (!localStorage.getItem('baseifo')) {
methods.getConfigData(); methods.getConfigData()
} }
setInterval(() => { setInterval(() => {
data.isDadge = false; data.isDadge = false
setTimeout(() => { setTimeout(() => {
data.isDadge = true; data.isDadge = true
}, 200); }, 200)
}, 1000); }, 1000)
}); })
data.version = AppConfig.$version ?? ""; data.version = AppConfig.$version ?? ''
return { return {
...toRefs(data), ...toRefs(data),
...methods, ...methods,
childPageTitle, childPageTitle,
scrollAreaRef, scrollAreaRef,
scrollArea, scrollArea,
}; noticeDialogVisible,
}, noticeDialogData,
}; downloadFile,
fileList
}
}
}
</script> </script>
<style> <style>
.header-item { .header-item {
...@@ -226,17 +250,21 @@ export default { ...@@ -226,17 +250,21 @@ export default {
align-items: center; align-items: center;
justify-content: center; justify-content: center;
} }
.header-item svg g [fill] { .header-item svg g [fill] {
fill: rgb(161, 165, 183) !important; fill: rgb(161, 165, 183) !important;
cursor: pointer; cursor: pointer;
padding: 4px; padding: 4px;
} }
.header-item:hover { .header-item:hover {
background: rgba(0, 0, 0, 0.05); background: rgba(0, 0, 0, 0.05);
} }
.header-item:hover svg g [fill] { .header-item:hover svg g [fill] {
fill: var(--q-primary) !important; fill: var(--q-primary) !important;
} }
.header-badge { .header-badge {
width: 6px; width: 6px;
height: 6px; height: 6px;
......
...@@ -171,7 +171,7 @@ export default defineComponent({ ...@@ -171,7 +171,7 @@ export default defineComponent({
getLanguage(val: SitLang) { getLanguage(val: SitLang) {
locale.value = val.langLocale ?? ""; locale.value = val.langLocale ?? "";
localStorage.setItem("lanuage", val.langLocale ?? ""); localStorage.setItem("lanuage2", val.langLocale ?? "");
}, },
}; };
......
...@@ -2,12 +2,17 @@ ...@@ -2,12 +2,17 @@
<div class="row full-height"> <div class="row full-height">
<div class="col q-pa-xl fit row justify-center height"> <div class="col q-pa-xl fit row justify-center height">
<div style="width:450px;" class="column justify-between content-between"> <div style="width:450px;" class="column justify-between content-between">
<div :class="{'row':$q.platform.is.desktop,'column':$q.platform.is.mobile}"> <div class='column items-center'>
<div class="col" :class="{'text-center q-mb-md':$q.platform.is.mobile}"> <!-- <div style="width:50px;overflow: hidden;">
<img v-if="isDomainName_PIC" src="../../assets/images/jvs-log.png" style="width:80%;" /> <img v-if="isDomainName_PIC" src="../../assets/images/jvs-log.png" style="height: 40px;" />
<img v-else src="http://imgfile.oytour.com/Upload/WebSite/202303170746500900000000054.png" style="width:80%;" /> <img v-else src="http://imgfile.oytour.com/Upload/WebSite/202303170746500900000000054.png" style="height: 40px;" />
</div> </div>
<div class="text-h6 text-weight-bold" style="font-family: math;" >PEACE INTERNATIONAL</div>
<div class="text-body2 text-weight-thin text-italic" style="font-family: math;" >by MILLENNIUM</div> -->
<img src="../../assets/img/newLogo.jpg" :style="{'height': $q.platform.is.mobile ? '100px' : '250px'}">
</div> </div>
<div class="q-py-xxl full-width"> <div class="q-py-xxl full-width">
<div class="text-h3 text-weight-bold">{{$t("login.title")}}</div> <div class="text-h3 text-weight-bold">{{$t("login.title")}}</div>
<div class="text-grey-6 q-mt-sm q-mb-lg">{{$t("login.subTitle")}}</div> <div class="text-grey-6 q-mt-sm q-mb-lg">{{$t("login.subTitle")}}</div>
...@@ -102,7 +107,7 @@ export default defineComponent({ ...@@ -102,7 +107,7 @@ export default defineComponent({
const getLanguage = (val:any) => { const getLanguage = (val:any) => {
locale.value = val.langLocale; locale.value = val.langLocale;
localStorage.setItem('lanuage', val.langLocale) localStorage.setItem('lanuage2', val.langLocale)
} }
return { userModel, usernameRef, passwordRef, userValidateRule, loginSubmit, dtNow, stateManager,getLanguage,...data} return { userModel, usernameRef, passwordRef, userValidateRule, loginSubmit, dtNow, stateManager,getLanguage,...data}
......
<template>
<div class="fix-height-subpage column no-wrap q-pa-md">
<div class="rounded-borders bg-white row items-center q-pa-md full-width">
<q-field :class="$q.platform.is.desktop ? '' : 'q-mb-md'" stack-label :label="$t('daterange')" standout
class="col-2" style="min-width: 190px" dense clearable v-model="dateRangeFormat" @clear="getFormat"
v-if="$q.platform.is.desktop">
<div class="self-center full-width no-outline" tabindex="0">{{ dateRangeFormat }}</div>
<q-popup-proxy :offset="[0, 10]" ref="qDateProxy">
<q-date v-model="dateRange" :options="optionsFn" range mask="YYYY/MM/DD" landscape
@range-end="dateRangeHandler"></q-date>
</q-popup-proxy>
</q-field>
<q-input class="q-mr-md q-ml-md" v-model="queryParams.Title" dense standout :label="$t('notice.search.title')"
:placeholder="$t('notice.placeholder.title')" v-if="$q.platform.is.desktop" />
<div class="col"></div>
<q-btn unelevated class="bg-grey-3 hover q-mr-md" :title="$t('morequery')" v-if="$q.platform.is.mobile">
<q-badge rounded class="din bg-red-2 text-red-14 text-weight-bold" floating :label="searchCnt"
v-if="searchCnt > 0" />
<svg-icon color="dark" icon="Text/Filter.svg" :tips="$t('morequery')" :size="20"></svg-icon>
<q-tooltip>{{ $t("morequery") }}</q-tooltip>
<q-popup-proxy class="no-shadow" style="box-shadow: 0 0 50px #ddd !important" :offset="[0, 20]"
:model-value="canHide">
<q-card class="q-pa-md rounded-borders" style="width: 300px">
<div class="q-mb-md text-subtitle2">{{ $t("morequery") }}</div>
<div class="q-my-md">
<q-field :class="$q.platform.is.desktop ? '' : 'q-mb-md'" stack-label :label="$t('daterange')" standout
class="col-2" style="min-width: 190px" dense clearable v-model="dateRangeFormat" @clear="getFormat">
<div class="self-center full-width no-outline" tabindex="0">{{ dateRangeFormat }}</div>
<q-popup-proxy :offset="[0, 10]" ref="qDateProxy">
<q-date v-model="dateRange" :options="optionsFn" range mask="YYYY/MM/DD" landscape
@range-end="dateRangeHandler"></q-date>
</q-popup-proxy>
</q-field>
</div>
<div class="q-my-md">
<q-input v-model="queryParams.Title" dense standout :label="$t('notice.search.title')"
:placeholder="$t('notice.placeholder.title')" />
</div>
</q-card>
</q-popup-proxy>
</q-btn>
<q-btn color="primary" unelevated :label="$t('query')" @click="setQueryHandler" />
</div>
<div class="q-pt-md col full-width" :style="{'overflow-y':$q.platform.is.mobile ? 'auto' : 'unset'}">
<q-table separator="cell" :grid="$q.platform.is.mobile" hide-bottom :rows="rows" :pagination="{rowsPerPage:100}" bordered :columns="$q.platform.is.mobile ? columnsMobile : columns" @row-click="rowClickHandler"
class="sticky-rightrowspan-column-table light-border col no-shadow full-height">
<template v-slot:body-cell-Action="props">
<q-td :props="props">
<q-btn color="primary" flat dense :label="$t('notice.view')" @click="viewHandler(props.row)" />
</q-td>
</template>
</q-table>
</div>
<q-pagination
class="full-width justify-end"
v-model="queryParams.pageIndex"
color="primary"
:max="queryParams.pageCount"
:input="true"
@update:model-value="changePageHandler"
/>
</div>
</template>
<script setup lang="ts">
import svgIcon from "../../components/global/svg-icon.vue";
import { computed, inject, reactive, ref } from "vue";
import useMetaModule from "../../module/meta/metaModule";
import { useI18n } from 'vue-i18n'
import { DirtionmaryHelper } from "src/config/dictionary";
import { date, useQuasar } from 'quasar'
import NoticeService from "src/api/notice";
import { ApiResult } from "src/@types/enumHelper";
const { setTitle } = useMetaModule();
const { t } = useI18n();
const q = useQuasar()
setTitle(t("notice.pageTitle"));
const pageTitle = inject(DirtionmaryHelper.PAGE_TITLE_KEY) as any
pageTitle.value = t("notice.pageTitle");
const dateRange = reactive({ from: '', to: '' })
const dateRangeFormat = ref(`${dateRange.from} - ${dateRange.to}`)
const noticeDialogData = inject(DirtionmaryHelper.NOTICE_DIALOG_DATA) as any
const qDateProxy = ref(null)
const queryParams = reactive({
StartDate: '',
EndDate: '',
Title: '',
Is_top: -1,
Status: 1,
pageIndex: 1,
pageSize: 10,
UpdateBy: -1,
total: 0,
pageCount: 0
})
const loading = ref(false)
const canHide = ref(false)
const rows = ref<any[]>([])
const columns = ref([
{ name: 'Title', label: t('notice.search.title'), align: 'left', field: 'Title' },
{ name: 'UpdateName', label: t('notice.column.publisher'), align: 'left', field: 'UpdateName' },
{ name: 'Notice_date', label: t('notice.column.releaseDate'), align: 'left', field: 'Notice_date' },
{ name: 'Action', label: t('notice.column.action'), align: 'left' },
])
const columnsMobile = ref([
{ name: 'Title', label: t('notice.search.title'), align: 'left', field: 'Title' },
{ name: 'UpdateName', label: t('notice.column.publisher'), align: 'left', field: 'UpdateName' },
{ name: 'Notice_date', label: t('notice.column.releaseDate'), align: 'left', field: 'Notice_date' }
])
const searchCnt = computed(() => {
let cnt = 0
if (queryParams.Title != '') cnt++
if (queryParams.StartDate != '') cnt++
if (queryParams.EndDate != '') cnt++
return cnt
})
const setQueryHandler = () => {
queryParams.pageIndex = 1
queryNoticeList()
}
const getFormat = () => {
if (!dateRangeFormat.value) {
queryParams.StartDate = ''
queryParams.EndDate = ''
}
}
const dateRangeHandler = (e: any) => {
queryParams.StartDate = `${e.from.year}/${e.from.month}/${e.from.day}`
queryParams.EndDate = `${e.to.year}/${e.to.month}/${e.to.day}`
dateRangeFormat.value = `${queryParams.StartDate} - ${queryParams.EndDate}`
if (qDateProxy.value) (qDateProxy.value as any).hide()
}
const optionsFn = (cd: any) => {
return cd >= date.formatDate(date.adjustDate(new Date(), { year: 2000, month: 1, days: 1 }), 'YYYY/MM/DD')
}
const changePageHandler = (n: number) => {
queryParams.pageIndex = n
console.log(queryParams,n)
queryNoticeList()
}
const queryNoticeList = async () => {
loading.value = true
rows.value = []
if(queryParams.pageIndex == 1){
queryParams.total = 0
queryParams.pageCount = 0
}
try {
const res = await NoticeService.getNoticeList(queryParams)
if (res.data.resultCode == ApiResult.SUCCESS) {
rows.value = res.data.data.pageData
queryParams.total = res.data.data.count
queryParams.pageCount = res.data.data.pageCount
}else {
rows.value = mockData().data.pageData
queryParams.total = mockData().data.count
queryParams.pageCount = mockData().data.pageCount
}
} catch (error) {
} finally {
loading.value = false
}
}
const mockData = () => {
return {
"resultCode": 1,
"message": "",
"data": {
"pageIndex": 1,
"pageSize": 15,
"count": 189,
"pageCount": 13,
"pageData": [
{
"Id": 243,
"Content": "<p class=\"ql-align-center\">\t<span class=\"ql-size-large\">关于规范日常付款流程的通知</span></p><p><span class=\"ql-size-large\">\t为进一步优化资金统筹管理,提高付款工作效率,现就日常付款流程规范如下:</span></p><p><span class=\"ql-size-large\">一、提报要求</span></p><p><span class=\"ql-size-large\">1. 提报时间:每日15:00前;</span></p><p><span class=\"ql-size-large\">2. 提报范围:流程到会计且确需当日支付的紧急款项;</span></p><p><span class=\"ql-size-large\">3. 提报内容:报销单号、付款金额(单据需递交财务部);</span></p><p><span class=\"ql-size-large\">4. 提报方式:通过企业微信提报-对接至单据审核会计;</span></p><p><span class=\"ql-size-large\">二、处理流程</span></p><p><span class=\"ql-size-large\">1. 会计人员每日15:30前完成汇总审核;</span></p><p><span class=\"ql-size-large\">2. 出纳根据当日资金存量按紧急程度安排付款;</span></p><p><span class=\"ql-size-large\">3. 非紧急款项纳入资金池滚动支付;</span></p><p><span class=\"ql-size-large\">三、注意事项</span></p><p><span class=\"ql-size-large\">1. 逾期提报将顺延至次工作日处理;</span></p><p><span class=\"ql-size-large\">2. 未标注\"加急\"字样的报销默认按常规流程处理;</span></p><p><span class=\"ql-size-large\">\t本通知自2025年04月09日起执行,请各部门严格把控报销审批时效性,共同维护公司资金运作效率,如有人不遵守规则后果自行承担。</span></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2025-04-11T18:27:56",
"File_url": null,
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2025-04-11 18:27:56",
"Status": 1,
"Title": "关于规范日常付款流程的通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2025-04-11 18:27:56"
},
{
"Id": 242,
"Content": "<p><span class=\"ql-size-large\"> 关于规范日常付款流程的通知</span></p><p><span class=\"ql-size-large\">为进一步优化资金统筹管理,提高付款工作效率,现就日常付款流程规范如下:</span></p><p><span class=\"ql-size-large\">一、提报要求</span></p><p><span class=\"ql-size-large\">1. 提报时间:每日15:00前;</span></p><p><span class=\"ql-size-large\">2. 提报范围:流程到会计且确需当日支付的紧急款项;</span></p><p><span class=\"ql-size-large\">3. 提报内容:报销单号、付款金额(单据需递交财务部);</span></p><p><span class=\"ql-size-large\">4. 提报方式:通过企业微信提报-对接至单据审核会计;</span></p><p><span class=\"ql-size-large\">二、处理流程</span></p><p><span class=\"ql-size-large\">1. 会计人员每日15:30前完成汇总审核;</span></p><p><span class=\"ql-size-large\">2. 出纳根据当日资金存量按紧急程度安排付款;</span></p><p><span class=\"ql-size-large\">3. 非紧急款项纳入资金池滚动支付;</span></p><p><span class=\"ql-size-large\">三、注意事项</span></p><p><span class=\"ql-size-large\">1. 逾期提报将顺延至次工作日处理;</span></p><p><span class=\"ql-size-large\">2. 未标注\"加急\"字样的报销默认按常规流程处理;</span></p><p><span class=\"ql-size-large\">本通知自2025年04月09日起执行,请各部门严格把控报销审批时效性,共同维护公司资金运作效率。</span></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2025-04-09T11:02:54",
"File_url": null,
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2025-04-09 11:02:54",
"Status": 1,
"Title": "关于规范日常付款流程的通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2025-04-09 11:02:54"
},
{
"Id": 241,
"Content": "<p class=\"ql-align-center\"><span class=\"ql-size-large\">关于2025年清明节放假的通知</span></p><p><span class=\"ql-size-large\">\t根据《国务院办公厅关于2025年部份假日安排的通知》,并结合公司实际情况与工作安排,现将清明放假相关事宜通知如下:</span></p><p><span class=\"ql-size-large\">一、放假时间:</span></p><p><span class=\"ql-size-large\">\t04月04日(周五)至04月6日(周日)放假,共3天。</span></p><p><span class=\"ql-size-large\">\t</span><span style=\"color: rgb(255, 0, 0);\" class=\"ql-size-large\">注:避免放假期间工作脱节,各部门人员自觉完成工作,如:销售检查团款是否收齐并已系统制单,操作部检查团账制单是否完成,旅游团是否跟进完成等,以上事宜请主管做好监督)。</span></p><p><span class=\"ql-size-large\">二、假期期间安排及注意事项</span></p><p><span class=\"ql-size-large\">(1)放假在即,请各位加油,努力收客。</span></p><p><span class=\"ql-size-large\">(2)放假前销售人员团款收齐至2025年04月07日出发团期。</span></p><p><span class=\"ql-size-large\">(3)假期期间,为保证业务不受影响,线上业务做到及时回复或处理,请全体人员保持通讯联络畅通(企业微信中有全体人员通讯录)。如遇紧急、重要事项或重大突发事件要立即向上级上报,并及时妥善处理。</span></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2025-04-02T17:48:16",
"File_url": null,
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2025-04-02 17:48:16",
"Status": 1,
"Title": "关于2025年清明节放假的通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2025-04-02 17:48:16"
},
{
"Id": 240,
"Content": "<p class=\"ql-align-center\"><strong class=\"ql-size-large\">印象之旅&nbsp;暑假业绩竞赛</strong></p><p><span class=\"ql-size-large\">一、参赛人员:成都公司全体销售。</span></p><p><span class=\"ql-size-large\">二、参赛线路:公司全线散拼。</span></p><p><span class=\"ql-size-large\">三、具体说明:</span></p><p><span class=\"ql-size-large\">1、比赛时间范围(按照出团日期):2025年6月1日~2025年8月31日。</span></p><p><span class=\"ql-size-large\">2、参赛订单需收机位订金。</span></p><p><span class=\"ql-size-large\">3、仅限散拼报名,按照人头计算(其中欧洲线每人按照2个人头计算,其他线路每人按照1个人头计算;签证、单机票、单酒店等所有单项产品不计算)。</span></p><p><span class=\"ql-size-large\">四、参赛人员分组情况:</span></p><p><span class=\"ql-size-large\">&nbsp;&nbsp;一组:周杨,赵江林,陆刚,邵玮,陈勇胜</span></p><p><span class=\"ql-size-large\">\t二组:魏俞婷,赵颖,谢燕,朱林,白京钟</span></p><p><span class=\"ql-size-large\">\t三组:唐萍,钟伟,李苹,付志豪</span></p><p><span class=\"ql-size-large\">\t四组:吴攀,邱磊,李军</span></p><p><span class=\"ql-size-large\">\t奖励方案:</span></p><p><span class=\"ql-size-large\">\t个人奖励方案(取前五名):</span></p><p><br></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2025-03-21T18:11:53",
"File_url": "[{\"Url\":\"/New/Upload/Notice/202503210611192510000000001.pdf\",\"Name\":\"成都业绩竞赛公告.pdf\",\"VideoPath\":null,\"FileType\":null}]",
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2025-03-21 18:11:53",
"Status": 1,
"Title": "印象之旅成都区域暑假业绩竞赛",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2025-03-21 18:11:53"
},
{
"Id": 239,
"Content": "<p class=\"ql-align-center\"><span class=\"ql-size-large\">关于旅小友推广会员的通知</span></p><p><span class=\"ql-size-large\">\t围绕“渠道深耕,精准获客”2025年同业转型通过“旅小友”小程序以会员体系为重点。2024年年度会议结束后,会员推广为公司全员重点工作,同时确保目标有效达成,在2025年2月7日周会中制定责任制度,具体如下:</span></p><p><span class=\"ql-size-large\">\t2025年同业销售转型责任额分拆如下:</span></p><p><span class=\"ql-size-large\">第一季度:每位销售每个月要完成100个以上的会员,三个月共计300个。</span></p><p><span class=\"ql-size-large\">第二季度:每位销售每个月要完成50个以上的会员,三个月共计150个。</span></p><p><span class=\"ql-size-large\">第三季度:每位销售每个月要完成20个以上会员,三个月共计60个。</span></p><p><span class=\"ql-size-large\">第四季度:每位销售每个月要完成10个以上会员,三个月共计40个。</span></p><p><span class=\"ql-size-large\">\t公司全员销售需按以上规定完成会员注册且激活,若任务目标未达成,则销售需按50元/个进行责任分担,补足所差会员数量(例:第一季度完成280个,差20个,则责任分担1000元)。</span></p><p><span class=\"ql-size-large\">\t组员未完成会员目标,组长存在监督不到位,也有不可推卸责任,给予1000元/人责任分担(例:组员4人,2人未完成,责任分担2000元)。</span></p><p><span class=\"ql-size-large\" style=\"color: rgb(230, 0, 0);\">\t2025年同业销售转型责任额,入职公司不足半年,任务量减半。</span></p><p><span class=\"ql-size-large\">\t以上规定请大家充分理解并严格执行!!</span></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2025-02-11T18:06:42",
"File_url": "[{\"Url\":\"/New/Upload/Notice/202502110606096610000000034.jpg\",\"Name\":\"关于旅小友推广会员的通知.jpg\",\"VideoPath\":null,\"FileType\":null}]",
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2025-02-11 18:06:42",
"Status": 1,
"Title": "关于旅小友推广会员的通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2025-02-11 18:06:42"
},
{
"Id": 238,
"Content": "<p class=\"ql-align-center\"><span class=\"ql-size-large\">关于2025年春节放假的通知</span></p><p><span class=\"ql-size-large\">\t2025年春节来临之际,根据《国务院办公厅关于2025年部份假日安排的通知》,并结合公司实际情况与工作安排,现将春节放假相关事宜通知如下:</span></p><p><span class=\"ql-size-large\">一、放假时间:</span></p><p><span class=\"ql-size-large\">\t01月27日(周一)至02月04日(周二)放假,共9天。</span></p><p><span class=\"ql-size-large\">\t01月25日-1月26日(周六、周天),02月08日(周六),正常上班。</span></p><p><span class=\"ql-size-large\">\t如有特殊原因需提前离开,可请年假。</span></p><p><span class=\"ql-size-large\">\t</span><span style=\"color: rgb(255, 0, 0);\" class=\"ql-size-large\">注:因春节放假时间较长,避免放假期间工作脱节,各部门人员自觉完成工作,如:销售检查团款是否收齐并已系统制单,操作部检查团账制单是否完成,旅游团是否跟进完成等,以上事宜请主管做好监督,如未完成,不允放假)。</span></p><p><span class=\"ql-size-large\">二、假期期间安排及注意事项</span></p><p><span class=\"ql-size-large\">(1)放假在即,收客不要松懈,且放假前团款需收齐至2025年02月13日出发团期;</span></p><p><span class=\"ql-size-large\">(2)假期期间,为保证业务不受影响,线上业务做到及时回复或处理,请全体人员保持通讯联络畅通(企业微信中有全体人员通讯录)。如遇紧急、重要事项或重大突发事件要立即向上级上报,并及时妥善处理。</span></p><p class=\"ql-align-justify\"><br></p><p class=\"ql-align-justify\"><strong class=\"ql-size-large\">祝大家新年快乐,心想事成,万事如意!!</strong></p><p><br></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2025-01-23T15:26:42",
"File_url": "[{\"Url\":\"/New/Upload/Notice/202501230326357830000000335.jpg\",\"Name\":\"关于2025年春节放假的通知.jpg\",\"VideoPath\":null,\"FileType\":null}]",
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2025-01-23 15:26:42",
"Status": 1,
"Title": "关于2025年春节放假的通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2025-01-23 15:26:42"
},
{
"Id": 237,
"Content": "<p class=\"ql-align-center\"><span class=\"ql-size-large\">关于提成年后发放的相关说明</span></p><p><span class=\"ql-size-large\">印象各位同仁:</span></p><p><span class=\"ql-size-large\">\t首先感谢大家这一年来工作中的努力付出,疫情三年以来,有各位的陪伴,公司才能一直坚持到2024年,迎来旅游业重新焕发生机。</span></p><p><span class=\"ql-size-large\">理想中的旅游井喷,现实中终归还是有所差距。疫情虽然已经过去,但出境游市场整体的恢复却不乐观。大家在销售第一线,相信对获客的艰难更有体会,而且旅游行业的机票、房、餐、车等环节,团队价格都较疫情前大幅上涨,导致出团运行成本大幅增加,但成团价格和成团数量都远远不能和疫情前相提并论,因此成团的利润率也极大的降低。</span></p><p><span class=\"ql-size-large\">\t春节在即,为了保证2025年各线路团队运营,公司在航空公司、团队出行团款开支上占用了较大金额的资金,所以2024年12月提成的发放时间,抱歉延后到节后才能发放,希望能得到各位的谅解与理解。</span></p><p><span class=\"ql-size-large\">\t如因个人资金确实困难者,可向部门主管提出,单独向公司预支费用!</span></p><p class=\"ql-align-justify\"><br></p><p class=\"ql-align-justify\"><strong class=\"ql-size-large\">祝大家新年快乐,心想事成,万事如意!!</strong></p><p><br></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2025-01-23T15:24:58",
"File_url": "[{\"Url\":\"/New/Upload/Notice/202501230324520750000000333.jpg\",\"Name\":\"关于提成年后发放的相关说明.jpg\",\"VideoPath\":null,\"FileType\":null}]",
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2025-01-23 15:24:58",
"Status": 1,
"Title": "关于提成年后发放的相关说明",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2025-01-23 15:24:58"
},
{
"Id": 236,
"Content": "<p class=\"ql-align-center\">\t<span class=\"ql-size-large\">关于办公室停电的通知</span></p><p><span class=\"ql-size-large\">\t接阳光新业物业通知,2025年01月07日阳光新业2栋,因配合供电局对10KV检修停电,现对停电做以下通知:</span></p><p><span class=\"ql-size-large\">\t(1)停电时间:2025年01月07日(周二)早上08:00-18:00点;</span></p><p><span class=\"ql-size-large\">\t(2)由于停电导致无法正常工作,公司根据实际情况作出安排,后勤部人员将进行居家办公,并通过后台ERP系统打卡(后台将记录登录时间以供考勤查询)。销售部的员工则需外出跑市场,并通过在门店拍照的方式进行考勤打卡。</span></p><p><span class=\"ql-size-large\">\t(3)请各部门提前做好工作安排,同时请保持电话通畅,方便联系(企业微信中通讯录)。</span></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2025-01-06T14:50:38",
"File_url": null,
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2025-01-06 14:50:38",
"Status": 1,
"Title": "关于办公室停电的通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2025-01-06 14:50:38"
},
{
"Id": 235,
"Content": "<p><span class=\"ql-size-large\">\t随着年末的临近,我们向您致以冬日的问候。在此,元旦佳节即将到来之际,依据《国务院办公厅关于2025年部分假日安排的通知》,并考虑到公司的实际情况与工作计划,现将有关放假的具体事宜通知如下:</span></p><p><span class=\"ql-size-large\">一、放假时间:</span></p><p><span class=\"ql-size-large\">\t2025年1月1日(周三)放假1天。</span></p><p><span class=\"ql-size-large\">\t</span><span style=\"color: rgb(255, 0, 0);\" class=\"ql-size-large\">注:日本领事馆将于新年期间放假,请密切关注团队签证的送签进度。</span></p><p><span class=\"ql-size-large\">二、假期期间安排及注意事项</span></p><p><span class=\"ql-size-large\">(1)春节放假在即,请各位加油,努力收客,同时注意款项的收取。</span></p><p><span class=\"ql-size-large\">(2)假期期间,为保证业务不受影响(部份部门请安排好调休工作),线上业务做到及时回复或处理,请全体人员保持通讯联络畅通(企业微信中有全体人员通讯录)。如遇紧急、重要事项或重大突发事件要立即向上级上报,并及时妥善处理。</span></p><p class=\"ql-align-center\"><strong class=\"ql-size-large\">祝大家新年快乐,财源广进,阖家幸福安康,万事如意顺心。</strong></p><p><br></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2024-12-30T15:29:31",
"File_url": null,
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2024-12-30 15:29:31",
"Status": 1,
"Title": "关于元旦节放假通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2024-12-30 15:29:31"
},
{
"Id": 234,
"Content": "<p class=\"ql-align-center\"><span class=\"ql-size-large\">关于旅游团定金收取的通知</span></p><p><span class=\"ql-size-large\">\t近期频繁出现旅游团,定金未收足情况,临近出发客人取消行程,导致机损严重,且无法认损。为了确保旅游行程正常安排,不影响旅客的体验和服务质量,我们特此通知关于旅游团定金的收取事宜如下:</span></p><p><span class=\"ql-size-large\">(1)收团时收定必须大于团费20%;</span></p><p><span class=\"ql-size-large\">(2)出发前一周需收完全款;</span></p><p><span class=\"ql-size-large\">(3)如出现旅客取消并产生损失,销售需按公司“</span><strong style=\"color: rgb(33, 33, 33);\" class=\"ql-size-large\">赔偿处罚规定”</strong><span class=\"ql-size-large\">执行。</span></p><p><img src=\"\"></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2024-11-12T17:45:13",
"File_url": "[{\"Url\":\"/New/Upload/Notice/202411120544522070000000127.jpg\",\"Name\":\"关于旅游团定金收取的通知.jpg\",\"VideoPath\":null,\"FileType\":null}]",
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2024-11-12 17:45:13",
"Status": 1,
"Title": "关于旅游团定金收取的通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2024-11-12 17:45:13"
},
{
"Id": 232,
"Content": "<p class=\"ql-align-center\"><span class=\"ql-size-large\">关于2024年中秋、国庆放假的通知</span></p><p><span class=\"ql-size-large\">\t根据《国务院办公厅关于2024年部份假日安排的通知》,并结合公司实际情况与工作安排,现将放假相关事宜通知如下:</span></p><p><span class=\"ql-size-large\">一、放假时间:</span></p><p><span class=\"ql-size-large\">\t中秋:09月15日(周天)至09月17日(周二)放假,共3天。</span></p><p><span class=\"ql-size-large\">\t国庆:10月1日(周二)至10月7日(周一)放假,共7天。</span></p><p><span class=\"ql-size-large\">\t09月14日(周六)正常上班;9月29日(周日);10月12日(星期六)正常上班。</span></p><p><span class=\"ql-size-large\">\t</span><span style=\"color: rgb(255, 0, 0);\" class=\"ql-size-large\">注:避免放假期间,团款催收遗漏,请各销售检查团款是否收齐并已系统制单)。</span></p><p><span class=\"ql-size-large\">二、假期期间安排及注意事项</span></p><p><span class=\"ql-size-large\">(1)放假在即,请各位加油,努力收客,放假前销售人员团款收齐至2024年09月18日出发团期。</span></p><p><span class=\"ql-size-large\">(2)假期期间,为保证业务不受影响(部份部门请安排好调休工作),线上业务做到及时回复或处理,请全体人员保持通讯联络畅通(企业微信中有全体人员通讯录)。如遇紧急、重要事项或重大突发事件要立即向上级上报,并及时妥善处理。</span></p><p class=\"ql-align-center\"><strong class=\"ql-size-large\">祝大家中秋快乐,阖家幸福安康,万事如意顺心。</strong></p><p><br></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2024-09-13T16:11:46",
"File_url": "[{\"Url\":\"/New/Upload/Notice/202409130411394020000000309.jpg\",\"Name\":\"关于2024年中秋、国庆放假的通知.jpg\",\"VideoPath\":null,\"FileType\":null}]",
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2024-09-13 16:11:46",
"Status": 1,
"Title": "关于2024年中秋、国庆放假的通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2024-09-13 16:11:46"
},
{
"Id": 231,
"Content": "<p class=\"ql-align-center\">\t关于郑州负责人处罚公告</p><p>\t<span class=\"ql-size-large\">现有郑州负责人张兆峰,于2024年8月14日至8月22日,负责人谢富强,于2024年8月22至08月26日,在没有办理任何请假手续的情况下,无故旷工(张兆峰6天,谢富强3天,未计入周末),该行为已严重违反了公司考勤规章管理制度,同时影响了郑州办事处机位事宜滞后。对于郑州负责人没有认真履行工作职责,导致工作效率低下。为严肃纪律,维护正常的工作秩序,确保公司考勤制度的实施,经研究决定,对郑州负责做以下处罚:</span></p><p><span class=\"ql-size-large\">\t1、张兆峰 计旷工6天,明知故犯,未向负责人清晰或准确告之回程时间,导致工作脱节,缺乏有效的交接机制,导致工作滞后,作为负责人未起到以身作责,性质恶劣,故加重处罚,给予旷工天数2倍的处理办法。</span></p><p><span class=\"ql-size-large\">\t2、谢富强 计旷工3天,明知故犯,未明确详细与负责人张兆峰交接并沟通工作到位,导致工作脱节,缺乏有效的交接机制,导致工作滞后,作为负责人之一,未起到良好的领头作用,故加重处罚,给予旷工天数的2倍处理办法。</span></p><p><span class=\"ql-size-large\">\t3、以上人员如再次出现类似问题,公司将给予解除劳动关系。</span></p><p><span class=\"ql-size-large\">&nbsp;&nbsp;</span><span style=\"color: rgb(230, 0, 0);\" class=\"ql-size-large\">&nbsp;望所有人员引以为戒,遵守公司管理制度,加强工作责任心。杜绝随意旷工、怠工等不良现象,如确有事,请提前告之并走请假流程。</span></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2024-08-27T12:10:35",
"File_url": "[{\"Url\":\"/New/Upload/Notice/202408271210294780000000050.jpg\",\"Name\":\"关于郑州负责人处罚公告.jpg\",\"VideoPath\":null,\"FileType\":null}]",
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2024-08-27 12:10:35",
"Status": 1,
"Title": "关于郑州负责人处罚公告",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2024-08-27 12:10:35"
},
{
"Id": 228,
"Content": "<p class=\"ql-align-center\">\t<span class=\"ql-size-large\">关于旅客滞留境外处罚公告</span></p><p class=\"ql-align-justify\"><span class=\"ql-size-large\">\t疫情结束后,恢复出境旅游,我司韩国线路陆续发生6人滞留事故,日本1人滞留事故,同时我司也受到领馆不同时长停签处罚,发生这样的事故,经查销售人员和对应签证审核人员工作均有失职,检查资料不够严谨,为了规范员工工作行为,提高员工责任意识,本次滞留旅客按200元/人,对相应人员进行处罚,以赔偿公司所遭受的部份经济损失。</span></p><p class=\"ql-align-justify\"><span class=\"ql-size-large\">\t此次事故责任人及赔偿金额如下:</span></p><p class=\"ql-align-justify\"><span class=\"ql-size-large\">\t销售部:(1)赵颖200元;钟伟400元(已在提成中扣除200元);斐倩600元,周杨200元。</span></p><p class=\"ql-align-justify\"><span class=\"ql-size-large\">\t签证部:(1)粱萍1200元;陈羚菲200元。</span></p><p class=\"ql-align-justify\"><span class=\"ql-size-large\">\t操作部:(1)肖红霞1200元,李瑶600。</span></p><p><span class=\"ql-size-large\">\t望所有同事引以为戒,如再次发生相关事故,则按2024-A-017发布《关于签证资料审核的通知》执行,(</span><span style=\"color: rgb(255, 0, 0);\" class=\"ql-size-large\">公司将给予相关销售和签证部审核人各罚款人民币1万元。出现滞留事故,相关人员还需承担公司签证外送费用</span><span class=\"ql-size-large\">)。</span></p><p><span class=\"ql-size-large\">\t另:公司考虑生活压力及对员工的关怀,本次赔偿同意斐倩,李瑶,分2个月从薪资中扣除,从 7月到 8 月,每月300 元,粱萍、肖红霞分3个月工资中扣除,从7月到10月,每月400元,赵颖,陈羚菲,钟伟3人在7月工资中扣除,行政部将处罚费用制单做入团成本,若该赔偿未完成前辞职,应一次性缴纳完赔偿金后办理手续。</span></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2024-08-05T15:30:40",
"File_url": "[{\"Url\":\"/New/Upload/Notice/202408050330238220000000072.pdf\",\"Name\":\"关于旅客滞留境外处罚公告.pdf\",\"VideoPath\":null,\"FileType\":null}]",
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2024-08-05 15:30:40",
"Status": 1,
"Title": "关于旅客滞留境外处罚公告",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2024-08-05 15:30:40"
},
{
"Id": 227,
"Content": "<p class=\"ql-align-center\">\t<span class=\"ql-size-large\">关于成都销售部新员工转正标准通知</span></p><p><span class=\"ql-size-large\">\t为考量试用期内新进人员实际工作能力,试用期更积极学习,发现其潜在能力,避免考核标准模糊不清。作为员工转正,劳动关系缔结或解除依据,就成都销售部试用转正考核制度公布如下:</span></p><p><span class=\"ql-size-large\">\t</span><span class=\"ql-size-large\" style=\"color: rgb(230, 0, 0);\">(1)试用期1-3个月,入职团队收客第一个月5人,第二个月10人,第三个月15人,合计30人(不限路线),如提前达成目标,可提前转正;</span></p><p><span class=\"ql-size-large\">\t(2)对于通过试用期转正员工,公司与签证正式的劳动合同,按正式员工享受公司一切福利待遇;</span></p><p><span class=\"ql-size-large\">\t(3)试用期3个月,考核者未达到收客标准,公司给予不予录用、或延期试用。</span></p><p><span class=\"ql-size-large\">\t(4)延期试用期时长为1-3个月,试用者针对未通过的因素进行改善,针对未完成任务作出努力;延期试用考核仍不通过者予以辞退。</span></p><p><span class=\"ql-size-large\">注:销售任务艰巨,请销售主管应对销售人员进行适度辅导,尽力使其胜任该岗位,同时请各部门协作。</span></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2024-07-29T17:18:25",
"File_url": "[{\"Url\":\"/New/Upload/Notice/202407290518048170000000272.jpg\",\"Name\":\"关于销售部新员工转正标准通知.jpg\",\"VideoPath\":null,\"FileType\":null}]",
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2024-07-29 17:18:25",
"Status": 1,
"Title": "关于成都销售部新员工转正标准通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2024-07-29 17:18:25"
},
{
"Id": 226,
"Content": "<p class=\"ql-align-center\"><span class=\"ql-size-large\">关于签证资料审核的通知</span></p><p><span class=\"ql-size-large\">\t2024年从1月至7月,韩国团3团陆续发生总计6人滞留事故,因此我社受到韩领馆的严重警告,并从2024年8月开始我社受到了韩国签证停签处罚。为尽早重新获得韩国送签权,以及韩国团队的正常操作,避免再次出现滞留事故,现就韩国团的相关操作再次重申以下规定:</span></p><p><span class=\"ql-size-large\">\t</span><span class=\"ql-size-large\" style=\"color: rgb(230, 0, 0);\">(1)对于整套签证资料严格审核,如通过企查查查询在职证明单位的真实性,或检查在职证明上公章真伪等;</span></p><p><span class=\"ql-size-large\" style=\"color: rgb(230, 0, 0);\">\t(2)旅客为东北三省,农村,乐山犍为等偏僻高危地区、单女、单男收件,全部需收取3万/人保证金费用;</span></p><p><span class=\"ql-size-large\">\t</span><span class=\"ql-size-large\" style=\"color: rgb(230, 0, 0);\">即日起公司任何路线,如再次发生相关事故,公司将给予相关销售和签证部审核人各罚款人民币1万元。出现滞留事故,相关人员还需承担公司签证外送费用。</span></p>",
"Count": 0,
"CreateBy": 400,
"CreateTime": "2024-07-29T15:32:57",
"File_url": "[{\"Url\":\"/New/Upload/Notice/202407290332547350000000184.jpg\",\"Name\":\"关于签证资料审核的通知.jpg\",\"VideoPath\":null,\"FileType\":null}]",
"Is_delete": 0,
"Is_top": 0,
"Notice_date": "2024-07-29 15:32:57",
"Status": 1,
"Title": "关于签证资料审核的通知",
"UpdateBy": 400,
"UpdateName": "何娟",
"UpdateTime": "2024-07-29 15:32:57"
}
]
},
"attach": null
}
}
const rowClickHandler = (evt:any, row:any, index:any) => {
console.log(row)
if(q.platform.is.mobile){
noticeDialogData.value = row
}
}
const viewHandler = (row: any) => {
noticeDialogData.value = row
}
queryNoticeList()
</script>
\ No newline at end of file
...@@ -97,12 +97,12 @@ ...@@ -97,12 +97,12 @@
<div class="col text-subtitle2 text-weight-bolder">{{ customerInfo.uniqueCode }}</div> <div class="col text-subtitle2 text-weight-bolder">{{ customerInfo.uniqueCode }}</div>
</div> </div>
</div> </div>
<div class="q-px-lg"> <!-- <div class="q-px-lg">
<div class="q-mt-lg row items-center"> <div class="q-mt-lg row items-center">
<div class="col-5 f12 text-grey-500">{{ $t('personal.LINEID') }}</div> <div class="col-5 f12 text-grey-500">{{ $t('personal.LINEID') }}</div>
<div class="col text-subtitle2 text-weight-bolder">{{ customerInfo.lineid}}</div> <div class="col text-subtitle2 text-weight-bolder">{{ customerInfo.lineid}}</div>
</div> </div>
</div> </div> -->
<div class="q-px-lg"> <div class="q-px-lg">
<div class="q-mt-lg row items-center"> <div class="q-mt-lg row items-center">
<div class="col-5 f12 text-grey-500">{{ $t('personal.Phone') }}</div> <div class="col-5 f12 text-grey-500">{{ $t('personal.Phone') }}</div>
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
</style> </style>
<template> <template>
<div class="q-pa-md"> <div class="q-pa-md">
<!-- <div class="rounded-borders bg-white row items-center q-pa-md"> <!-- <div class="rounded-borders bg-white row items-center q-pa-md">
<q-field :class="$q.platform.is.desktop ? '' : 'q-mb-md'" stack-label :label="$t('daterange')" standout class="q-ml-lg col-2" style="min-width: 190px" dense> <q-field :class="$q.platform.is.desktop ? '' : 'q-mb-md'" stack-label :label="$t('daterange')" standout class="q-ml-lg col-2" style="min-width: 190px" dense>
<div class="self-center full-width no-outline" tabindex="0">{{ dateRangeFormat }}</div> <div class="self-center full-width no-outline" tabindex="0">{{ dateRangeFormat }}</div>
...@@ -22,7 +22,7 @@ ...@@ -22,7 +22,7 @@
<q-btn color="primary" unelevated :label="$t('query')" @click="setQueryHandler"/> <q-btn color="primary" unelevated :label="$t('query')" @click="setQueryHandler"/>
</div> --> </div> -->
<!-- <div class="row"> <!-- <div class="row">
<div>合作伙伴:<span>{{item.ContactName}}</span></div> <div>合作伙伴:<span>{{item.ContactName}}</span></div>
<div>已入名单人数:<span>{{item.EntGuestNum}}</span></div> <div>已入名单人数:<span>{{item.EntGuestNum}}</span></div>
<div>已入名单人数:<span>{{item.IsHaveFinance}}</span></div> <div>已入名单人数:<span>{{item.IsHaveFinance}}</span></div>
...@@ -37,36 +37,46 @@ ...@@ -37,36 +37,46 @@
<div>代收总金额:<span>{{item.DueInMoney}}</span></div> <div>代收总金额:<span>{{item.DueInMoney}}</span></div>
<div>利润:<span>{{item.CommissionRate}}</span></div></div> <div>利润:<span>{{item.CommissionRate}}</span></div></div>
</div> --> </div> -->
<div class="row q-py-md"> <!-- <div class="row q-py-md full-width">
<div class="col-1">{{$t('travel.ContactNamePay')}}</div> <div class="col">{{$t('travel.ContactNamePay')}}</div>
<div class="col-1">{{$t('travel.EntGuestNum')}}</div> <div class="col">{{$t('travel.EntGuestNum')}}</div>
<div class="col-1">{{$t('travel.GuestNum')}}</div> <div class="col">{{$t('travel.GuestNum')}}</div>
<div class="col-1">{{$t('travel.PreferPricePay')}}</div> <div class="col">{{$t('travel.PreferPricePay')}}</div>
<div class="col-1">{{$t('travel.Refund')}}</div> <div class="col">{{$t('travel.Refund')}}</div>
<div class="col-1">{{$t('travel.PlatformTax')}}</div> <div class="col-1">{{$t('travel.PlatformTax')}}</div>
<div class="col-1">{{$t('travel.Income')}}</div> <div class="col">{{$t('travel.Income')}}</div>
<div class="col-1">{{$t('travel.ZaiTuMoney')}}</div> <div class="col-1">{{$t('travel.ZaiTuMoney')}}</div>
<div class="col-1">{{$t('travel.DiscountMoney')}}</div> <div class="col">{{$t('travel.DiscountMoney')}}</div>
<div class="col-1">{{$t('travel.RedEnvelopeMoney')}}</div> <div class="col-1">{{$t('travel.RedEnvelopeMoney')}}</div>
<div class="col-1">{{$t('travel.DueInMoney')}}</div> <div class="col-1">{{$t('travel.DueInMoney')}}</div>
<div class="col-1">{{$t('travel.CommissionRate')}}</div> <div class="col">{{$t('travel.CommissionRate')}}</div>
</div> </div>
<div class="row q-py-md" v-for="item in orders" :key="item.id"> <div class="row q-py-md full-width" v-for="item in orders" :key="item.id">
<div class="col-1"><span>{{item.ContactName}}</span></div> <div class="col"><span>{{item.ContactName}}</span></div>
<div class="col-1 text-center"><span>{{item.EntGuestNum}}</span></div> <div class="col text-center"><span>{{item.EntGuestNum}}</span></div>
<div class="col-1"><span>{{item.GuestNum}}</span></div> <div class="col"><span>{{item.GuestNum}}</span></div>
<div class="col-1"><span>{{item.PreferPrice}}</span></div> <div class="col"><span>{{item.PreferPrice}}</span></div>
<div class="col-1"><span>{{item.Refund}}</span></div> <div class="col"><span>{{item.Refund}}</span></div>
<div class="col-1"><span>{{item.PlatformTax}}</span></div> <div class="col-1"><span>{{item.PlatformTax}}</span></div>
<div class="col-1"><span>{{item.Income}}</span></div> <div class="col"><span>{{item.Income}}</span></div>
<div class="col-1"><span>{{item.ZaiTuMoney}}</span></div> <div class="col-1"><span>{{item.ZaiTuMoney}}</span></div>
<div class="col-1"><span>{{item.DiscountMoney}}</span></div> <div class="col"><span>{{item.DiscountMoney}}</span></div>
<div class="col-1"><span>{{item.RedEnvelopeMoney}}</span></div> <div class="col-1"><span>{{item.RedEnvelopeMoney}}</span></div>
<div class="col-1"><span>{{item.DueInMoney}}</span></div> <div class="col-1"><span>{{item.DueInMoney}}</span></div>
<div class="col-1"><span>{{item.CommissionRate}}</span></div> <div class="col"><span>{{item.CommissionRate}}</span></div>
</div> </div> -->
<div v-if="!orders.length" class="none">{{$t('travel.noData')}}</div> <!-- <div v-if="!orders.length" class="none">{{$t('travel.noData')}}</div> -->
<q-table
separator="cell"
:pagination="{ rowsPerPage: 100 }"
dense
:rows="orders"
bordered
:columns="cols"
class="sticky-rightrowspan-column-table light-border col no-shadow"
>
</q-table>
</div> </div>
</template> </template>
<script lang="ts"> <script lang="ts">
...@@ -91,15 +101,25 @@ export default defineComponent({ ...@@ -91,15 +101,25 @@ export default defineComponent({
dateRange.to = date.formatDate(date.addToDate(new Date(), { days: 50 }), 'YYYY/MM/DD') dateRange.to = date.formatDate(date.addToDate(new Date(), { days: 50 }), 'YYYY/MM/DD')
dateRange.from = date.formatDate(date.addToDate(new Date(), { days: 20 }), 'YYYY/MM/DD') dateRange.from = date.formatDate(date.addToDate(new Date(), { days: 20 }), 'YYYY/MM/DD')
const dateRangeFormat = ref(`${dateRange.from} - ${dateRange.to}`) const dateRangeFormat = ref(`${dateRange.from} - ${dateRange.to}`)
const cols = ref([
{ name: 'ContactName', label: t('travel.ContactNamePay'), align: 'left', field: 'ContactName' },
{ name: 'EntGuestNum', label: t('travel.EntGuestNum'), align: 'left', field: 'EntGuestNum' },
{ name: 'GuestNum', label: t('travel.GuestNum'), align: 'left', field: 'GuestNum' },
{ name: 'PreferPrice', label: t('travel.PreferPricePay'), align: 'left', field: 'PreferPrice' },
{ name: 'Refund', label: t('travel.Refund'), align: 'left', field: 'Refund' },
{ name: 'Income', label: t('travel.Income'), align: 'left', field: 'Income' },
{ name: 'DiscountMoney', label: t('travel.DiscountMoney'), align: 'left', field: 'DiscountMoney' },
{ name: 'CommissionRate', label: t('travel.CommissionRate'), align: 'left', field: 'CommissionRate' },
])
const {query, params} = useRoute() const {query, params} = useRoute()
const search = { const search = {
TCID: query.id, TCID: query.id,
// GTeamName: '', // GTeamName: '',
// SelectEndDate: '', // SelectEndDate: '',
// SelectStartDate: '', // SelectStartDate: '',
} }
const data = reactive({ const data = reactive({
info: {}, info: {},
copyId: 0, copyId: 0,
showAddOrder: false, showAddOrder: false,
...@@ -157,7 +177,8 @@ export default defineComponent({ ...@@ -157,7 +177,8 @@ export default defineComponent({
...methods, ...methods,
search, search,
dateRangeFormat, dateRangeFormat,
dateRange dateRange,
cols
}; };
} }
}) })
......
...@@ -262,38 +262,40 @@ export default defineComponent({ ...@@ -262,38 +262,40 @@ export default defineComponent({
label: t("travel.startDate"), label: t("travel.startDate"),
align: "left", align: "left",
}, },
{ // {
name: "oldPeopleNum", // name: "oldPeopleNum",
field: "oldPeopleNum", // field: "oldPeopleNum",
label: t("travel.oldPeople"), // label: t("travel.oldPeople"),
align: "left", // align: "left",
}, // },
{ name: "manNum", field: "manNum", label: t("travel.man"), align: "left" }, { name: "manNum", field: "manNum", label: t("travel.man"), align: "left" },
{ name: "babyNum", field: "babyNum", label: t("travel.BabyNum"), align: "left" },
{ {
name: "chirdNum", name: "chirdNum",
field: "chirdNum", field: "chirdNum",
label: t("travel.children"), label: t("travel.children"),
align: "left", align: "left",
}, },
{ name: "babyNum", field: "babyNum", label: t("travel.BabyNum"), align: "left" },
{ {
name: "guestNum", name: "guestNum",
field: "guestNum", field: "guestNum",
label: t("travel.guestNum"), label: t("travel.guestNum"),
align: "left", align: "left",
}, },
{
name: "unit_Price",
field: "unit_Price",
label: t("travel.unit_Price"),
align: "left",
},
{ {
name: "tC_Price", name: "tC_Price",
field: "tC_Price", field: "tC_Price",
label: t("travel.tC_Price"), label: t("travel.tC_Price"),
align: "left", align: "left",
}, },
{
name: "unit_Price",
field: "unit_Price",
label: t("travel.unit_Price"),
align: "left",
},
{ {
name: "tradeWay", name: "tradeWay",
field: "tradeWay", field: "tradeWay",
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
参考 参考
http://dev.api.oytour.com/#/home/project/inside/api/detail?groupID=157&childGroupID=170&apiID=1010&projectName=REBORN&projectID=2 http://dev.api.oytour.com/#/home/project/inside/api/detail?groupID=157&childGroupID=170&apiID=1010&projectName=REBORN&projectID=2
--> -->
<div> <div>
<div class="rounded-borders bg-white row items-center q-pa-md"> <div class="rounded-borders bg-white row items-center q-pa-md">
...@@ -241,7 +241,13 @@ export default defineComponent({ ...@@ -241,7 +241,13 @@ export default defineComponent({
setup(props) { setup(props) {
const canHide = ref(false) const canHide = ref(false)
const { t } = useI18n(); const { t } = useI18n();
const orderStateList = ref([{ Name: t("travel.all"), Id: 0 }]); const orderStateList = ref([
{ Name: t("travel.status.normal"), Id: 0 },
{ Name: t("travel.status.regular"), Id: 1 },
{ Name: t("travel.status.reserve"), Id: 2 },
{ Name: t("travel.status.waiting"), Id: 3 },
{ Name: t("travel.status.cancel"), Id: 4 },
]);
const payStateList = reactive([ const payStateList = reactive([
{ label: t("travel.all"), value: -1 }, { label: t("travel.all"), value: -1 },
{ label: t("travel.notPay"), value: 1 }, { label: t("travel.notPay"), value: 1 },
...@@ -313,18 +319,18 @@ export default defineComponent({ ...@@ -313,18 +319,18 @@ export default defineComponent({
); );
}, },
initOrders() { initOrders() {
travelService // travelService
.getOrderStateList({}) // .getOrderStateList({})
.then((r) => { // .then((r) => {
if (r.data.resultCode == ApiResult.SUCCESS) { // if (r.data.resultCode == ApiResult.SUCCESS) {
orderStateList.value = orderStateList.value.concat(r.data.data); // orderStateList.value = orderStateList.value.concat(r.data.data);
} else { // } else {
message.errorMsg(r.data.message); // message.errorMsg(r.data.message);
} // }
}) // })
.catch((e) => { // .catch((e) => {
message.errorMsg(e.message); // message.errorMsg(e.message);
}); // });
}, },
}; };
methods.initOrders(); methods.initOrders();
......
...@@ -35,7 +35,7 @@ ...@@ -35,7 +35,7 @@
" "
></q-input> ></q-input>
</div> </div>
<div class="col"> <!-- <div class="col">
<div class="title">{{ $t("travel.oldPeople") }}</div> <div class="title">{{ $t("travel.oldPeople") }}</div>
<q-input <q-input
v-model="addMsg.OldPeopleNum" v-model="addMsg.OldPeopleNum"
...@@ -53,7 +53,7 @@ ...@@ -53,7 +53,7 @@
autoRemarks('OldPeopleNum', '老人人数'); autoRemarks('OldPeopleNum', '老人人数');
" "
></q-input> ></q-input>
</div> </div> -->
</div> </div>
<div class="row"> <div class="row">
<div class="col"> <div class="col">
......
<template> <template>
<div class="rounded-borders bg-white row items-center q-pa-md"> <div class="rounded-borders bg-white row items-center q-pa-md">
<q-field :class="$q.platform.is.desktop ? '' : 'q-mb-md'" stack-label :label="$t('daterange')" standout class="q-ml-lg col-2" style="min-width: 190px" dense clearable v-model="dateRangeFormat" @clear="getFormat"> <template v-if="$q.platform.is.desktop">
<div class="self-center full-width no-outline" tabindex="0">{{ dateRangeFormat }}</div> <q-field stack-label :label="$t('daterange')" standout
<q-popup-proxy :offset="[0, 10]" ref="qDateProxy"> class="col-2" style="min-width: 190px" dense clearable v-model="dateRangeFormat" @clear="getFormat">
<q-date v-model="dateRange" :options="optionsFn" range mask="YYYY/MM/DD" landscape <div class="self-center full-width no-outline" tabindex="0">{{ dateRangeFormat }}</div>
@range-end="dateRangeHandler"></q-date> <q-popup-proxy :offset="[0, 10]" ref="qDateProxy">
</q-popup-proxy> <q-date v-model="dateRange" :options="optionsFn" range mask="YYYY/MM/DD" landscape
</q-field> @range-end="dateRangeHandler"></q-date>
<q-input class="q-mr-md q-ml-md" v-model="search.TCID" dense standout :label="$t('travel.id')"/> </q-popup-proxy>
<q-input class="q-mr-md q-ml-md" v-model="search.StartAddress" dense standout :label="$t('travel.startCity')"/> </q-field>
<q-input class="q-mr-md q-ml-md" v-model="search.TCID" dense standout :label="$t('travel.id')" />
<q-input class="q-mr-md q-ml-md" v-model="search.StartAddress" dense standout :label="$t('travel.startCity')" />
</template>
<div class="col"></div> <div class="col"></div>
<q-btn color="primary" unelevated :label="$t('query')" @click="setQueryHandler"/> <q-btn unelevated class="bg-grey-3 hover q-mr-md" :title="$t('morequery')" v-if="$q.platform.is.mobile">
<q-badge rounded class="din bg-red-2 text-red-14 text-weight-bold" floating :label="searchCnt"
v-if="searchCnt > 0" />
<svg-icon color="dark" icon="Text/Filter.svg" :tips="$t('morequery')" :size="20"></svg-icon>
<q-tooltip>{{ $t("morequery") }}</q-tooltip>
<q-popup-proxy class="no-shadow" style="box-shadow: 0 0 50px #ddd !important" :offset="[0, 20]"
:model-value="canHide">
<q-card class="q-pa-md rounded-borders" style="width: 300px">
<div class="q-mb-md text-subtitle2">{{ $t("morequery") }}</div>
<div class="q-my-md">
<q-field stack-label :label="$t('daterange')" standout
class="col-2" style="min-width: 190px" dense clearable v-model="dateRangeFormat"
@clear="getFormat">
<div class="self-center full-width no-outline" tabindex="0">{{ dateRangeFormat }}</div>
<q-popup-proxy :offset="[0, 10]" ref="qDateProxy">
<q-date v-model="dateRange" :options="optionsFn" range mask="YYYY/MM/DD" landscape
@range-end="dateRangeHandler"></q-date>
</q-popup-proxy>
</q-field>
</div>
<div class="q-my-md">
<q-input class="q-mr-md q-ml-md" v-model="search.TCID" dense standout :label="$t('travel.id')" />
</div>
<div class="q-my-md">
<q-input class="q-mr-md q-ml-md" v-model="search.StartAddress" dense standout
:label="$t('travel.startCity')" />
</div>
</q-card>
</q-popup-proxy>
</q-btn>
<q-btn color="primary" unelevated :label="$t('query')" @click="setQueryHandler" />
</div> </div>
</template> </template>
<script lang="ts"> <script lang="ts">
import { DirtionmaryHelper } from '../../../config/dictionary' import { DirtionmaryHelper } from '../../../config/dictionary'
import { defineComponent, inject, reactive, ref } from 'vue' import { computed, defineComponent, inject, reactive, ref } from 'vue'
import { date } from 'quasar' import { date } from 'quasar'
import svgIcon from 'src/components/global/svg-icon.vue'
export default defineComponent({ export default defineComponent({
components: { svgIcon },
setup(props) { setup(props) {
const qDateProxy = ref(null) as any const qDateProxy = ref(null) as any
const realSearch = inject(DirtionmaryHelper.TRAVEL_ORDER_OBJ) as any const realSearch = inject(DirtionmaryHelper.TRAVEL_ORDER_OBJ) as any
const search = reactive(JSON.parse(JSON.stringify(realSearch))) const search = reactive(JSON.parse(JSON.stringify(realSearch)))
const dateRange = reactive({from: '', to: ''}) const dateRange = reactive({ from: '', to: '' })
const searchCnt = computed(() => {
let cnt = 0
if (search.TCID != '') cnt++
if (search.StartAddress != '') cnt++
if (search.SelectStartDate != '') cnt++
if (search.SelectEndDate != '') cnt++
return cnt
})
// dateRange.to = date.formatDate(date.addToDate(new Date(), { days: 50 }), 'YYYY/MM/DD') // dateRange.to = date.formatDate(date.addToDate(new Date(), { days: 50 }), 'YYYY/MM/DD')
// dateRange.from = date.formatDate(date.addToDate(new Date(), { days: 20 }), 'YYYY/MM/DD') // dateRange.from = date.formatDate(date.addToDate(new Date(), { days: 20 }), 'YYYY/MM/DD')
const dateRangeFormat = ref(`${dateRange.from} - ${dateRange.to}`) const dateRangeFormat = ref(`${dateRange.from} - ${dateRange.to}`)
search.SelectStartDate = dateRange.from search.SelectStartDate = dateRange.from
search.SelectEndDate = dateRange.to search.SelectEndDate = dateRange.to
const canHide = ref(false)
const methods = { const methods = {
getFormat() { getFormat() {
if(!dateRangeFormat.value) { if (!dateRangeFormat.value) {
search.SelectStartDate = '' search.SelectStartDate = ''
search.SelectEndDate = '' search.SelectEndDate = ''
} }
}, },
setQueryHandler(){ setQueryHandler() {
realSearch.SelectStartDate=search.SelectStartDate realSearch.SelectStartDate = search.SelectStartDate
realSearch.SelectEndDate=search.SelectEndDate realSearch.SelectEndDate = search.SelectEndDate
realSearch.TCID=search.TCID realSearch.TCID = search.TCID
realSearch.StartAddress=search.StartAddress realSearch.StartAddress = search.StartAddress
}, },
dateRangeHandler(e: any) { dateRangeHandler(e: any) {
search.SelectStartDate = `${e.from.year}/${e.from.month}/${e.from.day}` search.SelectStartDate = `${e.from.year}/${e.from.month}/${e.from.day}`
...@@ -50,15 +94,16 @@ export default defineComponent({ ...@@ -50,15 +94,16 @@ export default defineComponent({
if (qDateProxy.value) qDateProxy.value.hide() if (qDateProxy.value) qDateProxy.value.hide()
}, },
optionsFn(cd: any) { optionsFn(cd: any) {
return cd >= date.formatDate(date.adjustDate(new Date(), {year: 2000, month: 1, days: 1 }), 'YYYY/MM/DD') return cd >= date.formatDate(date.adjustDate(new Date(), { year: 2000, month: 1, days: 1 }), 'YYYY/MM/DD')
}, },
} }
return { return {
...methods, ...methods,
search, search,
dateRange, dateRange,
dateRangeFormat dateRangeFormat,
searchCnt,
canHide
} }
} }
}) })
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
<q-card class="light-shadow q-pa-md bg-white rounded-borders q-mb-md" flat :class="$q.platform.is.desktop ? 'row' : ''" v-for="(x, index) in orders"> <q-card class="light-shadow q-pa-md bg-white rounded-borders q-mb-md" flat :class="$q.platform.is.desktop ? 'row' : ''" v-for="(x, index) in orders">
<div class="col-2 "> <div class="col-2 ">
<div class="mb-title"> <div class="mb-title">
<i class="iconfont icon-biaoti1"></i><span>{{ $t('travel.planInfo') }}</span> <i class="iconfont icon-biaoti1"></i><span>{{ $t('travel.airInfo') }}</span>
</div> </div>
{{ x.GTeamName }} {{ x.GTeamName }}
<div class="mb"> <div class="mb">
...@@ -19,9 +19,9 @@ ...@@ -19,9 +19,9 @@
<span v-if="x.StartAddress" class="q-mt-md text-weight-bold text-negative">{{ x.StartAddress }} {{ $t('travel.start') }}</span> <span v-if="x.StartAddress" class="q-mt-md text-weight-bold text-negative">{{ x.StartAddress }} {{ $t('travel.start') }}</span>
</div> </div>
</div> </div>
<div class="col-4 q-pl-md"> <div class="col-4" :class="$q.platform.is.desktop ? 'q-pl-md' : ''">
<div class="mb-title"> <div class="mb-title">&nbsp;
<i class="iconfont icon-hangban1"></i><span>{{ $t('travel.airInfo') }}</span> <!-- <i class="iconfont icon-hangban1"></i><span>{{ $t('travel.airInfo') }}</span> -->
</div> </div>
<div class="FlightDiv-TCL cursor-pointer" @click="showDialogF(x)"> <div class="FlightDiv-TCL cursor-pointer" @click="showDialogF(x)">
<div v-for="(subItem, subIndex) in x.TravelTeamFlightList" :key="subIndex + 1000" class="TCL-flighInfoList"> <div v-for="(subItem, subIndex) in x.TravelTeamFlightList" :key="subIndex + 1000" class="TCL-flighInfoList">
...@@ -58,10 +58,15 @@ ...@@ -58,10 +58,15 @@
>{{ x.YSeat }} <span class="item-title q-ml-md">{{ $t('travel.unUseNum') }}:</span>{{ x.SurplusYSeatNum }}</span >{{ x.YSeat }} <span class="item-title q-ml-md">{{ $t('travel.unUseNum') }}:</span>{{ x.SurplusYSeatNum }}</span
> >
</div> </div>
<div class="q-mt-sm"> <div class="mb bold">
<span class="item-title">{{ $t('travel.returnMoney') }}:</span><span class="text-negative">{{ x.RakeBackRatio }} / {{ $t('travel.people') }}</span> <span class="item-title">{{ $t('travel.status.waiting') }}:</span
><span
>0 </span>
</div> </div>
<div class="q-mt-sm"> <div class="q-mt-sm" v-if="isMember">
<span class="item-title">{{ $t('travel.returnMoney') }}:</span><span class="text-negative">{{ x.RakeBackRatio }} / pax</span>
</div>
<div class="q-mt-sm" v-if="isMember">
<span class="item-title text-primary cursor-pointer">{{ $t('travel.queryDetail') }}</span> <span class="item-title text-primary cursor-pointer">{{ $t('travel.queryDetail') }}</span>
<q-popup-proxy :offset="[0, 10]"> <q-popup-proxy :offset="[0, 10]">
<q-card class="" flat> <q-card class="" flat>
...@@ -71,8 +76,10 @@ ...@@ -71,8 +76,10 @@
<div class="q-pa-sm text-center col" style="border-right: 1px solid #eee;">{{ $t('travel.ratio') }}</div> <div class="q-pa-sm text-center col" style="border-right: 1px solid #eee;">{{ $t('travel.ratio') }}</div>
</div> </div>
<div class="row items-center" v-for="(item, index) in x.RakeBackList" :key="index" :class="{'bg-green-2': x.RakeBackRatio == item.Ratio}"> <div class="row items-center" v-for="(item, index) in x.RakeBackList" :key="index" :class="{'bg-green-2': x.RakeBackRatio == item.Ratio}">
<div class="q-pa-sm text-center col" style="border-right: 1px solid #eee;">{{ item.MinGuest }}-{{ item.MaxGuest }}{{ $t('travel.people') }}</div> <div class="q-pa-sm text-center col" style="border-right: 1px solid #eee;">{{ item.MinGuest }}-{{ item.MaxGuest }}
<div class="q-pa-sm text-center col" style="border-right: 1px solid #eee;">{{ item.Ratio }}/{{ $t('travel.people') }}</div> pax
</div>
<div class="q-pa-sm text-center col" style="border-right: 1px solid #eee;">{{ item.Ratio }}/pax</div>
<!-- <div class="q-pa-sm text-center col"> <!-- <div class="q-pa-sm text-center col">
<div class="bg-green" style="width:10px;height:10px;border-radius:50%; display: inline-block;" v-if="x.RakeBackRatio == item.Ratio"></div> <div class="bg-green" style="width:10px;height:10px;border-radius:50%; display: inline-block;" v-if="x.RakeBackRatio == item.Ratio"></div>
</div> --> </div> -->
...@@ -104,7 +111,7 @@ ...@@ -104,7 +111,7 @@
<div class="mb-title"> <div class="mb-title">
<i class="iconfont icon-jiage"></i><span>{{ $t('travel.priceInfo') }}</span> <i class="iconfont icon-jiage"></i><span>{{ $t('travel.priceInfo') }}</span>
</div> </div>
<div class="mb bold"> <div class="mb bold" v-if="isMember">
<span class="item-title">{{ $t('travel.midPrice') }}: </span>{{ x.B2BMemberPrice }} <span class="item-title">{{ $t('travel.midPrice') }}: </span>{{ x.B2BMemberPrice }}
</div> </div>
<div class="mb bold"> <div class="mb bold">
...@@ -113,13 +120,15 @@ ...@@ -113,13 +120,15 @@
{{ x.ChildNoNeedPrice }} {{ x.ChildNoNeedPrice }}
</div> </div>
<div class="mb bold"> <div class="mb bold">
<span class="item-title">{{ $t('travel.Baby') }}:</span> {{ x.BabyPrice }} <span class="item-title q-ml-md">{{ $t('travel.BabyChargePrice') }}: </span>{{ x.BabyChargePrice }} <span class="item-title">{{ $t('travel.Baby') }}:</span> {{ x.BabyPrice }}
<!-- <span class="item-title q-ml-md">{{ $t('travel.BabyChargePrice') }}: </span>{{ x.BabyChargePrice }} -->
<span class="item-title q-ml-md">{{ $t('travel.VisaPrice') }}: </span>{{ x.VisaPrice }}
</div> </div>
<div class="mb bold"> <!-- <div class="mb bold">
<span class="item-title">{{ $t('travel.OldManChargePrice') }}:</span> <span class="item-title">{{ $t('travel.OldManChargePrice') }}:</span>
{{ x.OldManChargePrice }} {{ x.OldManChargePrice }}
<span class="item-title q-ml-md">{{ $t('travel.VisaPrice') }}: </span>{{ x.VisaPrice }} <span class="item-title q-ml-md">{{ $t('travel.VisaPrice') }}: </span>{{ x.VisaPrice }}
</div> </div> -->
<div class="mb bold"> <div class="mb bold">
<span class="item-title">{{ $t('travel.SingleRoomPrice') }}:</span> <span class="item-title">{{ $t('travel.SingleRoomPrice') }}:</span>
{{ x.SingleRoomPrice }} {{ x.SingleRoomPrice }}
...@@ -127,8 +136,8 @@ ...@@ -127,8 +136,8 @@
</div> </div>
</div> </div>
<div class="col-1"> <div class="col-1">
<q-btn color="primary" unelevated @click="ViewPayment(x)">{{ $t('travel.buy') }}</q-btn> <q-btn color="primary" flat dense @click="ViewPayment(x)">{{ $t('travel.buy') }}</q-btn>
<q-btn :class="$q.platform.is.desktop ? 'q-mt-md' : 'q-ml-md'" color="primary" unelevated @click="gotoUrl(x)">{{ $t('travel.payOrder') }}</q-btn> <q-btn v-if="isMember" flat dense :class="$q.platform.is.desktop ? 'q-mt-md' : 'q-ml-md'" color="primary" @click="gotoUrl(x)">{{ $t('travel.payOrder') }}</q-btn>
</div> </div>
<q-dialog width="900" v-model="showItem" trigger="click"> <q-dialog width="900" v-model="showItem" trigger="click">
<div class="TC_tripDetails" style="width: 900px; background-color: #fff"> <div class="TC_tripDetails" style="width: 900px; background-color: #fff">
...@@ -206,6 +215,8 @@ import { currentRouter } from '../../../router' ...@@ -206,6 +215,8 @@ import { currentRouter } from '../../../router'
// import BankAccount from '../../BankAccount.vue' // import BankAccount from '../../BankAccount.vue'
import AddOrder from './addOrder.vue' import AddOrder from './addOrder.vue'
import { useRouter } from 'vue-router' import { useRouter } from 'vue-router'
import { UserGetter } from 'src/store/modules/user/getters'
import { getStoreGetter } from 'src/store/utils'
export default defineComponent({ export default defineComponent({
components: { AddOrder }, components: { AddOrder },
...@@ -214,7 +225,9 @@ export default defineComponent({ ...@@ -214,7 +225,9 @@ export default defineComponent({
const search = inject(DirtionmaryHelper.TRAVEL_ORDER_OBJ) as any const search = inject(DirtionmaryHelper.TRAVEL_ORDER_OBJ) as any
const { t } = useI18n() const { t } = useI18n()
const $q = useQuasar() const $q = useQuasar()
const userInfo = getStoreGetter<UserGetter>('user', 'getUser')
const isMember = userInfo.isMember==1
console.log(userInfo)
watch(search, (n, o) => { watch(search, (n, o) => {
if (data.loading) return if (data.loading) return
data.pages.pageIndex = 1 data.pages.pageIndex = 1
...@@ -374,7 +387,8 @@ export default defineComponent({ ...@@ -374,7 +387,8 @@ export default defineComponent({
return { return {
...toRefs(data), ...toRefs(data),
...methods, ...methods,
moneyFormat moneyFormat,
isMember
} }
} }
}) })
......
...@@ -7,7 +7,11 @@ const routes: RouteRecordRaw[] = [{ ...@@ -7,7 +7,11 @@ const routes: RouteRecordRaw[] = [{
component: () => import('layouts/MainLayout.vue'), component: () => import('layouts/MainLayout.vue'),
children: [{ children: [{
path: '', path: '',
component: () => import('pages/Index.vue') component: () => import('pages/travel/order.vue')
},
{
path: '/notice',
component: () => import('pages/notice/List.vue'),
}, },
{ {
path: '/hotel', path: '/hotel',
...@@ -43,7 +47,7 @@ const routes: RouteRecordRaw[] = [{ ...@@ -43,7 +47,7 @@ const routes: RouteRecordRaw[] = [{
path: '/didahotel', //道旅酒店 path: '/didahotel', //道旅酒店
component: () => import('pages/scattered/didaHotel.vue') component: () => import('pages/scattered/didaHotel.vue')
}, },
{ {
path: '/scattered/HotelDetails/:hotelId/:groupBookingFlg/:lowrateBySetCurrency', path: '/scattered/HotelDetails/:hotelId/:groupBookingFlg/:lowrateBySetCurrency',
component: () => import('pages/scattered/hotelDetails.vue') }, component: () => import('pages/scattered/hotelDetails.vue') },
{ {
......
...@@ -144,6 +144,21 @@ const useMenus = { ...@@ -144,6 +144,21 @@ const useMenus = {
} }
] ]
}) })
menus.push({
name: t('menu.notice.first'),
url: '/notice',
id: 23,
parentId: 0,
icon: 'Shopping/Box1.svg',
childs: [
{
name: t('menu.notice.second'),
url: '/notice',
id: 24,
parentId: 23,
}
]
})
// menus.push({ // menus.push({
// name: t('menu.finance.first'), // name: t('menu.finance.first'),
// url: '', // url: '',
......
...@@ -459,28 +459,28 @@ export function getLangs() { ...@@ -459,28 +459,28 @@ export function getLangs() {
langLocale:"enUS", langLocale:"enUS",
langName:"English" langName:"English"
} }
const koHG:SitLang={ // const koHG:SitLang={
langLocale:"koHG", // langLocale:"koHG",
langName:"한국어", // langName:"한국어",
quasarLang:'ko-KR' // quasarLang:'ko-KR'
} // }
const jaRB:SitLang={ const jaRB:SitLang={
langLocale:"jaRB", langLocale:"jaRB",
langName:"日本語", langName:"日本語",
quasarLang:'zh-TW' quasarLang:'zh-TW'
} }
const inID:SitLang={ // const inID:SitLang={
langLocale:"inID", // langLocale:"inID",
langName:"Indonesia", // langName:"Indonesia",
quasarLang:'in-ID' // quasarLang:'in-ID'
} // }
let langs:SitLang[]=[] let langs:SitLang[]=[]
// 根据域名渲染简体 // 根据域名渲染简体
if(!getDomainName()){ if(!getDomainName()){
langs.push(zhSw) langs.push(zhSw)
}else{ }else{
langs.push(zhTw,koHG,enUs,jaRB,inID) langs.push(zhTw,enUs,jaRB)
} }
return langs return langs
......
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