Commit 77df13d1 authored by lijin's avatar lijin

增加地域组管理功能

parent b2002460
import request from '@/utils/request'
const baseUrl = '/location-groups'
// 获取所有地域组
export function getLocationGroupList(params) {
return request({
url: process.env.PUTIN_API + baseUrl,
method: 'get',
params
})
}
// 根据ID获取地域组
export function getLocationGroupById(id) {
return request({
url: process.env.PUTIN_API + `${baseUrl}/${id}`,
method: 'get'
})
}
// 创建地域组
export function createLocationGroup(data) {
return request({
url: process.env.PUTIN_API + baseUrl,
method: 'post',
data
})
}
// 更新地域组
export function updateLocationGroup(data) {
return request({
url: process.env.PUTIN_API + `${baseUrl}/${data.id}`,
method: 'put',
data
})
}
// 删除地域组
export function deleteLocationGroup(id) {
return request({
url: process.env.PUTIN_API + `${baseUrl}/${id}`,
method: 'delete'
})
}
<template>
<el-transfer
v-model="selectedCountries"
:data="countryOptions"
:titles="['可选国家', '已选国家']"
:props="{
key: 'code',
label: 'nameCn'
}"
filterable
filter-placeholder="请输入国家名称"
@change="handleChange"
></el-transfer>
</template>
<script>
export default {
name: 'CountryTransfer',
props: {
value: {
type: Array,
default: () => []
},
countries: {
type: Array,
default: () => [{'code': 'AF', 'nameCn': '阿富汗', 'nameEn': 'Afghanistan', 'flag': '🇦🇫', 'criterionId': 2004}, {'code': 'AL', 'nameCn': '阿尔巴尼亚', 'nameEn': 'Albania', 'flag': '🇦🇱', 'criterionId': 2008}, {'code': 'DZ', 'nameCn': '阿尔及利亚', 'nameEn': 'Algeria', 'flag': '🇩🇿', 'criterionId': 2012}, {'code': 'AD', 'nameCn': '安道尔', 'nameEn': 'Andorra', 'flag': '🇦🇩', 'criterionId': 2020}, {'code': 'AO', 'nameCn': '安哥拉', 'nameEn': 'Angola', 'flag': '🇦🇴', 'criterionId': 2024}, {'code': 'AG', 'nameCn': '安提瓜和巴布达', 'nameEn': 'Antigua and Barbuda', 'flag': '🇦🇬', 'criterionId': 2028}, {'code': 'AR', 'nameCn': '阿根廷', 'nameEn': 'Argentina', 'flag': '🇦🇷', 'criterionId': 2032}, {'code': 'AM', 'nameCn': '亚美尼亚', 'nameEn': 'Armenia', 'flag': '🇦🇲', 'criterionId': 2051}, {'code': 'AU', 'nameCn': '澳大利亚', 'nameEn': 'Australia', 'flag': '🇦🇺', 'criterionId': 2036}, {'code': 'AT', 'nameCn': '奥地利', 'nameEn': 'Austria', 'flag': '🇦🇹', 'criterionId': 2040}, {'code': 'AZ', 'nameCn': '阿塞拜疆', 'nameEn': 'Azerbaijan', 'flag': '🇦🇿', 'criterionId': 2031}, {'code': 'BS', 'nameCn': '巴哈马', 'nameEn': 'Bahamas', 'flag': '🇧🇸', 'criterionId': 2044}, {'code': 'BH', 'nameCn': '巴林', 'nameEn': 'Bahrain', 'flag': '🇧🇭', 'criterionId': 2048}, {'code': 'BD', 'nameCn': '孟加拉国', 'nameEn': 'Bangladesh', 'flag': '🇧🇩', 'criterionId': 2050}, {'code': 'BB', 'nameCn': '巴巴多斯', 'nameEn': 'Barbados', 'flag': '🇧🇧', 'criterionId': 2052}, {'code': 'BY', 'nameCn': '白俄罗斯', 'nameEn': 'Belarus', 'flag': '🇧🇾', 'criterionId': 2112}, {'code': 'BE', 'nameCn': '比利时', 'nameEn': 'Belgium', 'flag': '🇧🇪', 'criterionId': 2056}, {'code': 'BZ', 'nameCn': '伯利兹', 'nameEn': 'Belize', 'flag': '🇧🇿', 'criterionId': 2084}, {'code': 'BJ', 'nameCn': '贝宁', 'nameEn': 'Benin', 'flag': '🇧🇯', 'criterionId': 2204}, {'code': 'BT', 'nameCn': '不丹', 'nameEn': 'Bhutan', 'flag': '🇧🇹', 'criterionId': 2064}, {'code': 'BO', 'nameCn': '玻利维亚', 'nameEn': 'Bolivia', 'flag': '🇧🇴', 'criterionId': 2068}, {'code': 'BA', 'nameCn': '波斯尼亚和黑塞哥维那', 'nameEn': 'Bosnia and Herzegovina', 'flag': '🇧🇦', 'criterionId': 2070}, {'code': 'BW', 'nameCn': '博茨瓦纳', 'nameEn': 'Botswana', 'flag': '🇧🇼', 'criterionId': 2072}, {'code': 'BR', 'nameCn': '巴西', 'nameEn': 'Brazil', 'flag': '🇧🇷', 'criterionId': 2076}, {'code': 'BN', 'nameCn': '文莱', 'nameEn': 'Brunei', 'flag': '🇧🇳', 'criterionId': 2096}, {'code': 'BG', 'nameCn': '保加利亚', 'nameEn': 'Bulgaria', 'flag': '🇧🇬', 'criterionId': 2100}, {'code': 'BF', 'nameCn': '布基纳法索', 'nameEn': 'Burkina Faso', 'flag': '🇧🇫', 'criterionId': 2854}, {'code': 'BI', 'nameCn': '布隆迪', 'nameEn': 'Burundi', 'flag': '🇧🇮', 'criterionId': 2108}, {'code': 'KH', 'nameCn': '柬埔寨', 'nameEn': 'Cambodia', 'flag': '🇰🇭', 'criterionId': 2116}, {'code': 'CM', 'nameCn': '喀麦隆', 'nameEn': 'Cameroon', 'flag': '🇨🇲', 'criterionId': 2120}, {'code': 'CA', 'nameCn': '加拿大', 'nameEn': 'Canada', 'flag': '🇨🇦', 'criterionId': 2124}, {'code': 'CV', 'nameCn': '佛得角', 'nameEn': 'Cape Verde', 'flag': '🇨🇻', 'criterionId': 2132}, {'code': 'CF', 'nameCn': '中非共和国', 'nameEn': 'Central African Republic', 'flag': '🇨🇫', 'criterionId': 2140}, {'code': 'TD', 'nameCn': '乍得', 'nameEn': 'Chad', 'flag': '🇹🇩', 'criterionId': 2148}, {'code': 'CL', 'nameCn': '智利', 'nameEn': 'Chile', 'flag': '🇨🇱', 'criterionId': 2152}, {'code': 'CN', 'nameCn': '中国', 'nameEn': 'China', 'flag': '🇨🇳', 'criterionId': 2156}, {'code': 'CO', 'nameCn': '哥伦比亚', 'nameEn': 'Colombia', 'flag': '🇨🇴', 'criterionId': 2170}, {'code': 'KM', 'nameCn': '科摩罗', 'nameEn': 'Comoros', 'flag': '🇰🇲', 'criterionId': 2174}, {'code': 'CG', 'nameCn': '刚果(布)', 'nameEn': 'Congo', 'flag': '🇨🇬', 'criterionId': 2178}, {'code': 'CD', 'nameCn': '刚果(金)', 'nameEn': 'Congo, Democratic Republic of the', 'flag': '🇨🇩', 'criterionId': 2180}, {'code': 'CR', 'nameCn': '哥斯达黎加', 'nameEn': 'Costa Rica', 'flag': '🇨🇷', 'criterionId': 2188}, {'code': 'CI', 'nameCn': '科特迪瓦', 'nameEn': "Côte d'Ivoire", 'flag': '🇨🇮', 'criterionId': 2384}, {'code': 'HR', 'nameCn': '克罗地亚', 'nameEn': 'Croatia', 'flag': '🇭🇷', 'criterionId': 2191}, {'code': 'CU', 'nameCn': '古巴', 'nameEn': 'Cuba', 'flag': '🇨🇺'}, {'code': 'CY', 'nameCn': '塞浦路斯', 'nameEn': 'Cyprus', 'flag': '🇨🇾', 'criterionId': 2196}, {'code': 'CZ', 'nameCn': '捷克', 'nameEn': 'Czech Republic', 'flag': '🇨🇿', 'criterionId': 2203}, {'code': 'DK', 'nameCn': '丹麦', 'nameEn': 'Denmark', 'flag': '🇩🇰', 'criterionId': 2208}, {'code': 'DJ', 'nameCn': '吉布提', 'nameEn': 'Djibouti', 'flag': '🇩🇯', 'criterionId': 2262}, {'code': 'DM', 'nameCn': '多米尼克', 'nameEn': 'Dominica', 'flag': '🇩🇲', 'criterionId': 2212}, {'code': 'DO', 'nameCn': '多米尼加共和国', 'nameEn': 'Dominican Republic', 'flag': '🇩🇴', 'criterionId': 2214}, {'code': 'EC', 'nameCn': '厄瓜多尔', 'nameEn': 'Ecuador', 'flag': '🇪🇨', 'criterionId': 2218}, {'code': 'EG', 'nameCn': '埃及', 'nameEn': 'Egypt', 'flag': '🇪🇬', 'criterionId': 2818}, {'code': 'SV', 'nameCn': '萨尔瓦多', 'nameEn': 'El Salvador', 'flag': '🇸🇻', 'criterionId': 2222}, {'code': 'GQ', 'nameCn': '赤道几内亚', 'nameEn': 'Equatorial Guinea', 'flag': '🇬🇶', 'criterionId': 2226}, {'code': 'ER', 'nameCn': '厄立特里亚', 'nameEn': 'Eritrea', 'flag': '🇪🇷', 'criterionId': 2232}, {'code': 'EE', 'nameCn': '爱沙尼亚', 'nameEn': 'Estonia', 'flag': '🇪🇪', 'criterionId': 2233}, {'code': 'ET', 'nameCn': '埃塞俄比亚', 'nameEn': 'Ethiopia', 'flag': '🇪🇹', 'criterionId': 2231}, {'code': 'FJ', 'nameCn': '斐济', 'nameEn': 'Fiji', 'flag': '🇫🇯', 'criterionId': 2242}, {'code': 'FI', 'nameCn': '芬兰', 'nameEn': 'Finland', 'flag': '🇫🇮', 'criterionId': 2246}, {'code': 'FR', 'nameCn': '法国', 'nameEn': 'France', 'flag': '🇫🇷', 'criterionId': 2250}, {'code': 'GA', 'nameCn': '加蓬', 'nameEn': 'Gabon', 'flag': '🇬🇦', 'criterionId': 2266}, {'code': 'GM', 'nameCn': '冈比亚', 'nameEn': 'Gambia', 'flag': '🇬🇲', 'criterionId': 2270}, {'code': 'GE', 'nameCn': '格鲁吉亚', 'nameEn': 'Georgia', 'flag': '🇬🇪', 'criterionId': 2268}, {'code': 'DE', 'nameCn': '德国', 'nameEn': 'Germany', 'flag': '🇩🇪', 'criterionId': 2276}, {'code': 'GH', 'nameCn': '加纳', 'nameEn': 'Ghana', 'flag': '🇬🇭', 'criterionId': 2288}, {'code': 'GR', 'nameCn': '希腊', 'nameEn': 'Greece', 'flag': '🇬🇷', 'criterionId': 2300}, {'code': 'GD', 'nameCn': '格林纳达', 'nameEn': 'Grenada', 'flag': '🇬🇩', 'criterionId': 2308}, {'code': 'GT', 'nameCn': '危地马拉', 'nameEn': 'Guatemala', 'flag': '🇬🇹', 'criterionId': 2320}, {'code': 'GN', 'nameCn': '几内亚', 'nameEn': 'Guinea', 'flag': '🇬🇳', 'criterionId': 2324}, {'code': 'GW', 'nameCn': '几内亚比绍', 'nameEn': 'Guinea-Bissau', 'flag': '🇬🇼', 'criterionId': 2624}, {'code': 'GY', 'nameCn': '圭亚那', 'nameEn': 'Guyana', 'flag': '🇬🇾', 'criterionId': 2328}, {'code': 'HT', 'nameCn': '海地', 'nameEn': 'Haiti', 'flag': '🇭🇹', 'criterionId': 2332}, {'code': 'HN', 'nameCn': '洪都拉斯', 'nameEn': 'Honduras', 'flag': '🇭��', 'criterionId': 2340}, {'code': 'HU', 'nameCn': '匈牙利', 'nameEn': 'Hungary', 'flag': '🇭🇺', 'criterionId': 2348}, {'code': 'IS', 'nameCn': '冰岛', 'nameEn': 'Iceland', 'flag': '🇮🇸', 'criterionId': 2352}, {'code': 'IN', 'nameCn': '印度', 'nameEn': 'India', 'flag': '🇮🇳', 'criterionId': 2356}, {'code': 'ID', 'nameCn': '印度尼西亚', 'nameEn': 'Indonesia', 'flag': '🇮🇩', 'criterionId': 2360}, {'code': 'IR', 'nameCn': '伊朗', 'nameEn': 'Iran', 'flag': '🇮🇷'}, {'code': 'IQ', 'nameCn': '伊拉克', 'nameEn': 'Iraq', 'flag': '🇮🇶', 'criterionId': 2368}, {'code': 'IE', 'nameCn': '爱尔兰', 'nameEn': 'Ireland', 'flag': '🇮🇪', 'criterionId': 2372}, {'code': 'IL', 'nameCn': '以色列', 'nameEn': 'Israel', 'flag': '🇮🇱', 'criterionId': 2376}, {'code': 'IT', 'nameCn': '意大利', 'nameEn': 'Italy', 'flag': '🇮🇹', 'criterionId': 2380}, {'code': 'JM', 'nameCn': '牙买加', 'nameEn': 'Jamaica', 'flag': '🇯🇲', 'criterionId': 2388}, {'code': 'JP', 'nameCn': '日本', 'nameEn': 'Japan', 'flag': '🇯🇵', 'criterionId': 2392}, {'code': 'JO', 'nameCn': '约旦', 'nameEn': 'Jordan', 'flag': '🇯🇴', 'criterionId': 2400}, {'code': 'KZ', 'nameCn': '哈萨克斯坦', 'nameEn': 'Kazakhstan', 'flag': '🇰🇿', 'criterionId': 2398}, {'code': 'KE', 'nameCn': '肯尼亚', 'nameEn': 'Kenya', 'flag': '🇰🇪', 'criterionId': 2404}, {'code': 'KI', 'nameCn': '基里巴斯', 'nameEn': 'Kiribati', 'flag': '🇰🇮', 'criterionId': 2296}, {'code': 'KP', 'nameCn': '朝鲜', 'nameEn': 'North Korea', 'flag': '🇰🇵'}, {'code': 'KR', 'nameCn': '韩国', 'nameEn': 'South Korea', 'flag': '🇰🇷', 'criterionId': 2410}, {'code': 'KW', 'nameCn': '科威特', 'nameEn': 'Kuwait', 'flag': '🇰🇼', 'criterionId': 2414}, {'code': 'KG', 'nameCn': '吉尔吉斯斯坦', 'nameEn': 'Kyrgyzstan', 'flag': '🇰🇬', 'criterionId': 2417}, {'code': 'LA', 'nameCn': '老挝', 'nameEn': 'Laos', 'flag': '🇱🇦', 'criterionId': 2418}, {'code': 'LV', 'nameCn': '拉脱维亚', 'nameEn': 'Latvia', 'flag': '🇱🇻', 'criterionId': 2428}, {'code': 'LB', 'nameCn': '黎巴嫩', 'nameEn': 'Lebanon', 'flag': '🇱🇧', 'criterionId': 2422}, {'code': 'LS', 'nameCn': '莱索托', 'nameEn': 'Lesotho', 'flag': '🇱🇸', 'criterionId': 2426}, {'code': 'LR', 'nameCn': '利比里亚', 'nameEn': 'Liberia', 'flag': '🇱🇷', 'criterionId': 2430}, {'code': 'LY', 'nameCn': '利比亚', 'nameEn': 'Libya', 'flag': '🇱🇾', 'criterionId': 2434}, {'code': 'LI', 'nameCn': '列支敦士登', 'nameEn': 'Liechtenstein', 'flag': '🇱🇮', 'criterionId': 2438}, {'code': 'LT', 'nameCn': '立陶宛', 'nameEn': 'Lithuania', 'flag': '🇱🇹', 'criterionId': 2440}, {'code': 'LU', 'nameCn': '卢森堡', 'nameEn': 'Luxembourg', 'flag': '🇱🇺', 'criterionId': 2442}, {'code': 'MG', 'nameCn': '马达加斯加', 'nameEn': 'Madagascar', 'flag': '🇲🇬', 'criterionId': 2450}, {'code': 'MW', 'nameCn': '马拉维', 'nameEn': 'Malawi', 'flag': '🇲🇼', 'criterionId': 2454}, {'code': 'MY', 'nameCn': '马来西亚', 'nameEn': 'Malaysia', 'flag': '🇲🇾', 'criterionId': 2458}, {'code': 'MV', 'nameCn': '马尔代夫', 'nameEn': 'Maldives', 'flag': '🇲🇻', 'criterionId': 2462}, {'code': 'ML', 'nameCn': '马里', 'nameEn': 'Mali', 'flag': '🇲🇱', 'criterionId': 2466}, {'code': 'MT', 'nameCn': '马耳他', 'nameEn': 'Malta', 'flag': '🇲🇹', 'criterionId': 2470}, {'code': 'MH', 'nameCn': '马绍尔群岛', 'nameEn': 'Marshall Islands', 'flag': '🇲🇭', 'criterionId': 2584}, {'code': 'MR', 'nameCn': '毛里塔尼亚', 'nameEn': 'Mauritania', 'flag': '🇲🇷', 'criterionId': 2478}, {'code': 'MU', 'nameCn': '毛里求斯', 'nameEn': 'Mauritius', 'flag': '🇲🇺', 'criterionId': 2480}, {'code': 'MX', 'nameCn': '墨西哥', 'nameEn': 'Mexico', 'flag': '🇲🇽', 'criterionId': 2484}, {'code': 'FM', 'nameCn': '密克罗尼西亚', 'nameEn': 'Micronesia', 'flag': '🇫🇲', 'criterionId': 2583}, {'code': 'MD', 'nameCn': '摩尔多瓦', 'nameEn': 'Moldova', 'flag': '🇲🇩', 'criterionId': 2498}, {'code': 'MC', 'nameCn': '摩纳哥', 'nameEn': 'Monaco', 'flag': '🇲🇨', 'criterionId': 2492}, {'code': 'MN', 'nameCn': '蒙古', 'nameEn': 'Mongolia', 'flag': '🇲🇳', 'criterionId': 2496}, {'code': 'ME', 'nameCn': '黑山', 'nameEn': 'Montenegro', 'flag': '🇲🇪', 'criterionId': 2499}, {'code': 'MA', 'nameCn': '摩洛哥', 'nameEn': 'Morocco', 'flag': '🇲🇦', 'criterionId': 2504}, {'code': 'MZ', 'nameCn': '莫桑比克', 'nameEn': 'Mozambique', 'flag': '🇲🇿', 'criterionId': 2508}, {'code': 'MM', 'nameCn': '缅甸', 'nameEn': 'Myanmar', 'flag': '🇲🇲', 'criterionId': 2104}, {'code': 'NA', 'nameCn': '纳米比亚', 'nameEn': 'Namibia', 'flag': '🇳🇦', 'criterionId': 2516}, {'code': 'NR', 'nameCn': '瑙鲁', 'nameEn': 'Nauru', 'flag': '🇳🇷', 'criterionId': 2520}, {'code': 'NP', 'nameCn': '尼泊尔', 'nameEn': 'Nepal', 'flag': '🇳🇵', 'criterionId': 2524}, {'code': 'NL', 'nameCn': '荷兰', 'nameEn': 'Netherlands', 'flag': '🇳🇱', 'criterionId': 2528}, {'code': 'NZ', 'nameCn': '新西兰', 'nameEn': 'New Zealand', 'flag': '🇳🇿', 'criterionId': 2554}, {'code': 'NI', 'nameCn': '尼加拉瓜', 'nameEn': 'Nicaragua', 'flag': '🇳🇮', 'criterionId': 2558}, {'code': 'NE', 'nameCn': '尼日尔', 'nameEn': 'Niger', 'flag': '🇳🇪', 'criterionId': 2562}, {'code': 'NG', 'nameCn': '尼日利亚', 'nameEn': 'Nigeria', 'flag': '🇳🇬', 'criterionId': 2566}, {'code': 'MK', 'nameCn': '北马其顿', 'nameEn': 'North Macedonia', 'flag': '🇲🇰', 'criterionId': 2807}, {'code': 'NO', 'nameCn': '挪威', 'nameEn': 'Norway', 'flag': '🇳🇴', 'criterionId': 2578}, {'code': 'OM', 'nameCn': '阿曼', 'nameEn': 'Oman', 'flag': '🇴🇲', 'criterionId': 2512}, {'code': 'PK', 'nameCn': '巴基斯坦', 'nameEn': 'Pakistan', 'flag': '🇵🇰', 'criterionId': 2586}, {'code': 'PW', 'nameCn': '帕劳', 'nameEn': 'Palau', 'flag': '🇵🇼', 'criterionId': 2585}, {'code': 'PA', 'nameCn': '巴拿马', 'nameEn': 'Panama', 'flag': '🇵🇦', 'criterionId': 2591}, {'code': 'PG', 'nameCn': '巴布亚新几内亚', 'nameEn': 'Papua New Guinea', 'flag': '🇵🇬', 'criterionId': 2598}, {'code': 'PY', 'nameCn': '巴拉圭', 'nameEn': 'Paraguay', 'flag': '🇵🇾', 'criterionId': 2600}, {'code': 'PE', 'nameCn': '秘鲁', 'nameEn': 'Peru', 'flag': '🇵🇪', 'criterionId': 2604}, {'code': 'PH', 'nameCn': '菲律宾', 'nameEn': 'Philippines', 'flag': '🇵🇭', 'criterionId': 2608}, {'code': 'PL', 'nameCn': '波兰', 'nameEn': 'Poland', 'flag': '🇵🇱', 'criterionId': 2616}, {'code': 'PT', 'nameCn': '葡萄牙', 'nameEn': 'Portugal', 'flag': '🇵🇹', 'criterionId': 2620}, {'code': 'QA', 'nameCn': '卡塔尔', 'nameEn': 'Qatar', 'flag': '🇶🇦', 'criterionId': 2634}, {'code': 'RO', 'nameCn': '罗马尼亚', 'nameEn': 'Romania', 'flag': '🇷🇴', 'criterionId': 2642}, {'code': 'RU', 'nameCn': '俄罗斯', 'nameEn': 'Russia', 'flag': '🇷🇺', 'criterionId': 2643}, {'code': 'RW', 'nameCn': '卢旺达', 'nameEn': 'Rwanda', 'flag': '🇷🇼', 'criterionId': 2646}, {'code': 'KN', 'nameCn': '圣基茨和尼维斯', 'nameEn': 'Saint Kitts and Nevis', 'flag': '🇰🇳', 'criterionId': 2659}, {'code': 'LC', 'nameCn': '圣卢西亚', 'nameEn': 'Saint Lucia', 'flag': '🇱🇨', 'criterionId': 2662}, {'code': 'VC', 'nameCn': '圣文森特和格林纳丁斯', 'nameEn': 'Saint Vincent and the Grenadines', 'flag': '🇻🇨', 'criterionId': 2670}, {'code': 'WS', 'nameCn': '萨摩亚', 'nameEn': 'Samoa', 'flag': '🇼🇸', 'criterionId': 2882}, {'code': 'SM', 'nameCn': '圣马力诺', 'nameEn': 'San Marino', 'flag': '🇸🇲', 'criterionId': 2674}, {'code': 'ST', 'nameCn': '圣多美和普林西比', 'nameEn': 'Sao Tome and Principe', 'flag': '🇸🇹', 'criterionId': 2678}, {'code': 'SA', 'nameCn': '沙特阿拉伯', 'nameEn': 'Saudi Arabia', 'flag': '🇸🇦', 'criterionId': 2682}, {'code': 'SN', 'nameCn': '塞内加尔', 'nameEn': 'Senegal', 'flag': '🇸🇳', 'criterionId': 2686}, {'code': 'RS', 'nameCn': '塞尔维亚', 'nameEn': 'Serbia', 'flag': '🇷🇸', 'criterionId': 2688}, {'code': 'SC', 'nameCn': '塞舌尔', 'nameEn': 'Seychelles', 'flag': '🇸🇨', 'criterionId': 2690}, {'code': 'SL', 'nameCn': '塞拉利昂', 'nameEn': 'Sierra Leone', 'flag': '🇸🇱', 'criterionId': 2694}, {'code': 'SG', 'nameCn': '新加坡', 'nameEn': 'Singapore', 'flag': '🇸🇬', 'criterionId': 2702}, {'code': 'SK', 'nameCn': '斯洛伐克', 'nameEn': 'Slovakia', 'flag': '🇸🇰', 'criterionId': 2703}, {'code': 'SI', 'nameCn': '斯洛文尼亚', 'nameEn': 'Slovenia', 'flag': '🇸🇮', 'criterionId': 2705}, {'code': 'SB', 'nameCn': '所罗门群岛', 'nameEn': 'Solomon Islands', 'flag': '🇸🇧', 'criterionId': 2090}, {'code': 'SO', 'nameCn': '索马里', 'nameEn': 'Somalia', 'flag': '🇸🇴', 'criterionId': 2706}, {'code': 'ZA', 'nameCn': '南非', 'nameEn': 'South Africa', 'flag': '🇿🇦', 'criterionId': 2710}, {'code': 'SS', 'nameCn': '南苏丹', 'nameEn': 'South Sudan', 'flag': '🇸🇸', 'criterionId': 2728}, {'code': 'ES', 'nameCn': '西班牙', 'nameEn': 'Spain', 'flag': '🇪🇸', 'criterionId': 2724}, {'code': 'LK', 'nameCn': '斯里兰卡', 'nameEn': 'Sri Lanka', 'flag': '🇱🇰', 'criterionId': 2144}, {'code': 'SD', 'nameCn': '苏丹', 'nameEn': 'Sudan', 'flag': '🇸🇩', 'criterionId': 2736}, {'code': 'SR', 'nameCn': '苏里南', 'nameEn': 'Suriname', 'flag': '🇸🇷', 'criterionId': 2740}, {'code': 'SE', 'nameCn': '瑞典', 'nameEn': 'Sweden', 'flag': '🇸🇪', 'criterionId': 2752}, {'code': 'CH', 'nameCn': '瑞士', 'nameEn': 'Switzerland', 'flag': '🇨🇭', 'criterionId': 2756}, {'code': 'SY', 'nameCn': '叙利亚', 'nameEn': 'Syria', 'flag': '🇸🇾'}, {'code': 'TJ', 'nameCn': '塔吉克斯坦', 'nameEn': 'Tajikistan', 'flag': '🇹🇯', 'criterionId': 2762}, {'code': 'TZ', 'nameCn': '坦桑尼亚', 'nameEn': 'Tanzania', 'flag': '🇹🇿', 'criterionId': 2834}, {'code': 'TH', 'nameCn': '泰国', 'nameEn': 'Thailand', 'flag': '🇹🇭', 'criterionId': 2764}, {'code': 'TL', 'nameCn': '东帝汶', 'nameEn': 'Timor-Leste', 'flag': '🇹🇱', 'criterionId': 2626}, {'code': 'TG', 'nameCn': '多哥', 'nameEn': 'Togo', 'flag': '🇹🇬', 'criterionId': 2768}, {'code': 'TO', 'nameCn': '汤加', 'nameEn': 'Tonga', 'flag': '🇹🇴', 'criterionId': 2776}, {'code': 'TT', 'nameCn': '特立尼达和多巴哥', 'nameEn': 'Trinidad and Tobago', 'flag': '🇹🇹', 'criterionId': 2780}, {'code': 'TN', 'nameCn': '突尼斯', 'nameEn': 'Tunisia', 'flag': '🇹🇳', 'criterionId': 2788}, {'code': 'TR', 'nameCn': '土耳其', 'nameEn': 'Turkey', 'flag': '🇹🇷', 'criterionId': 2792}, {'code': 'TM', 'nameCn': '土库曼斯坦', 'nameEn': 'Turkmenistan', 'flag': '🇹🇲', 'criterionId': 2795}, {'code': 'TV', 'nameCn': '图瓦卢', 'nameEn': 'Tuvalu', 'flag': '🇹🇻', 'criterionId': 2798}, {'code': 'UG', 'nameCn': '乌干达', 'nameEn': 'Uganda', 'flag': '🇺🇬', 'criterionId': 2800}, {'code': 'UA', 'nameCn': '乌克兰', 'nameEn': 'Ukraine', 'flag': '🇺🇦', 'criterionId': 2804}, {'code': 'AE', 'nameCn': '阿联酋', 'nameEn': 'United Arab Emirates', 'flag': '🇦🇪', 'criterionId': 2784}, {'code': 'GB', 'nameCn': '英国', 'nameEn': 'United Kingdom', 'flag': '🇬🇧', 'criterionId': 2826}, {'code': 'US', 'nameCn': '美国', 'nameEn': 'United States', 'flag': '🇺🇸', 'criterionId': 2840}, {'code': 'UY', 'nameCn': '乌拉圭', 'nameEn': 'Uruguay', 'flag': '🇺🇾', 'criterionId': 2858}, {'code': 'UZ', 'nameCn': '乌兹别克斯坦', 'nameEn': 'Uzbekistan', 'flag': '🇺🇿', 'criterionId': 2860}, {'code': 'VU', 'nameCn': '瓦努阿图', 'nameEn': 'Vanuatu', 'flag': '🇻🇺', 'criterionId': 2548}, {'code': 'VA', 'nameCn': '梵蒂冈', 'nameEn': 'Vatican City', 'flag': '🇻🇦', 'criterionId': 2336}, {'code': 'VE', 'nameCn': '委内瑞拉', 'nameEn': 'Venezuela', 'flag': '🇻🇪', 'criterionId': 2862}, {'code': 'VN', 'nameCn': '越南', 'nameEn': 'Vietnam', 'flag': '🇻🇳', 'criterionId': 2704}, {'code': 'YE', 'nameCn': '也门', 'nameEn': 'Yemen', 'flag': '🇾🇪', 'criterionId': 2887}, {'code': 'ZM', 'nameCn': '赞比亚', 'nameEn': 'Zambia', 'flag': '🇿🇲', 'criterionId': 2894}, {'code': 'ZW', 'nameCn': '津巴布韦', 'nameEn': 'Zimbabwe', 'flag': '🇿🇼', 'criterionId': 2716}]
}
},
data() {
return {
countryOptions: [],
selectedCountries: []
}
},
watch: {
value: {
handler(newVal) {
this.selectedCountries = newVal || []
},
immediate: true
}
},
created() {
this.countryOptions = this.countries
},
methods: {
handleChange(value) {
this.$emit('input', value)
this.$emit('change', value)
}
}
}
</script>
<style scoped>
.el-transfer {
width: 100%;
}
.el-transfer-panel {
width: 45%;
}
</style>
...@@ -132,6 +132,12 @@ export const constantRouterMap = [ ...@@ -132,6 +132,12 @@ export const constantRouterMap = [
component: () => import("@/views/copywritingLibrary"), component: () => import("@/views/copywritingLibrary"),
meta: { title: "文案库", icon: "document" } meta: { title: "文案库", icon: "document" }
}, },
{
path: '/assetManagement/location-group',
name: 'assetManagement.location-group',
component: () => import('@/views/locationGroup/LocationGroupManage'),
meta: { title: '地域组管理' }
},
] ]
}, },
......
...@@ -28,7 +28,7 @@ ...@@ -28,7 +28,7 @@
<template slot="title">资产管理</template> <template slot="title">资产管理</template>
<el-menu-item index="/assetManagement/copywritingLibrary">文案管理</el-menu-item> <el-menu-item index="/assetManagement/copywritingLibrary">文案管理</el-menu-item>
<el-menu-item index="/assetManagement/app-group">产品组管理</el-menu-item> <el-menu-item index="/assetManagement/app-group">产品组管理</el-menu-item>
<el-menu-item index="/assetManagement/createDelivery">地域组</el-menu-item> <el-menu-item index="/assetManagement/location-group">地域组管理</el-menu-item>
<el-menu-item index="/assetManagement/createDelivery">素材组</el-menu-item> <el-menu-item index="/assetManagement/createDelivery">素材组</el-menu-item>
<el-menu-item index="/assetManagement/createDelivery">标题组</el-menu-item> <el-menu-item index="/assetManagement/createDelivery">标题组</el-menu-item>
<el-menu-item index="/assetManagement/createDelivery">描述组</el-menu-item> <el-menu-item index="/assetManagement/createDelivery">描述组</el-menu-item>
......
<template>
<div class="location-group-container">
<!-- 表格头部操作 -->
<div class="header-actions">
<el-button type="primary" @click="showAddDialog">新增地域组</el-button>
<div class="header-right">
<el-button icon="el-icon-refresh" @click="fetchData">刷新</el-button>
</div>
</div>
<!-- 主表格 -->
<el-table
:data="tableData"
border
style="width: 100%;"
v-loading="loading">
<el-table-column prop="id" label="ID" width="80"></el-table-column>
<el-table-column prop="name" label="名称" width="250"></el-table-column>
<el-table-column label="国家" min-width="300">
<template slot-scope="scope">
{{ getCountryNames(scope.row.countryCodes) }}
</template>
</el-table-column>
<el-table-column prop="createdAt" label="创建时间" width="180">
<template slot-scope="scope">
{{ formatDate(scope.row.createdAt) }}
</template>
</el-table-column>
<el-table-column label="操作" align="center" width="180">
<template slot-scope="scope">
<el-button
size="mini"
type="primary"
@click="handleEdit(scope.row)">编辑</el-button>
<el-button
size="mini"
type="danger"
@click="handleDelete(scope.row)">删除</el-button>
</template>
</el-table-column>
</el-table>
<!-- 分页 -->
<div class="pagination-container">
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="currentPage"
:page-sizes="[10, 20, 50, 100]"
:page-size="pageSize"
:total="total"
layout="total, prev, pager, next, sizes">
</el-pagination>
</div>
<!-- 新增/编辑对话框 -->
<el-dialog :title="dialogTitle" :visible.sync="dialogVisible" width="50%">
<el-form :model="form" :rules="rules" ref="form" label-width="120px">
<el-form-item label="地域组名称" prop="name">
<el-input v-model="form.name"></el-input>
</el-form-item>
<el-form-item label="选择国家" prop="countryCodes">
<country-transfer v-model="form.countryCodes" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button @click="dialogVisible = false">取 消</el-button>
<el-button type="primary" @click="submitForm">确 定</el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import CountryTransfer from '@/components/CountryTransfer'
import { getLocationGroupList, createLocationGroup, updateLocationGroup, deleteLocationGroup } from '@/api/locationGroup'
export default {
name: 'LocationGroupManage',
components: {
CountryTransfer
},
data() {
return {
loading: false,
tableData: [],
currentPage: 1,
pageSize: 10,
total: 0,
dialogVisible: false,
dialogTitle: '',
form: {
name: '',
countryCodes: []
},
rules: {
name: [
{ required: true, message: '请输入地域组名称', trigger: 'blur' }
],
countryCodes: [
{ type: 'array', required: true, message: '请至少选择一个国家', trigger: 'change' }
]
},
countries: [{'code': 'AF', 'nameCn': '阿富汗', 'nameEn': 'Afghanistan', 'flag': '🇦🇫', 'criterionId': 2004}, {'code': 'AL', 'nameCn': '阿尔巴尼亚', 'nameEn': 'Albania', 'flag': '🇦🇱', 'criterionId': 2008}, {'code': 'DZ', 'nameCn': '阿尔及利亚', 'nameEn': 'Algeria', 'flag': '🇩🇿', 'criterionId': 2012}, {'code': 'AD', 'nameCn': '安道尔', 'nameEn': 'Andorra', 'flag': '🇦🇩', 'criterionId': 2020}, {'code': 'AO', 'nameCn': '安哥拉', 'nameEn': 'Angola', 'flag': '🇦🇴', 'criterionId': 2024}, {'code': 'AG', 'nameCn': '安提瓜和巴布达', 'nameEn': 'Antigua and Barbuda', 'flag': '🇦🇬', 'criterionId': 2028}, {'code': 'AR', 'nameCn': '阿根廷', 'nameEn': 'Argentina', 'flag': '🇦🇷', 'criterionId': 2032}, {'code': 'AM', 'nameCn': '亚美尼亚', 'nameEn': 'Armenia', 'flag': '🇦🇲', 'criterionId': 2051}, {'code': 'AU', 'nameCn': '澳大利亚', 'nameEn': 'Australia', 'flag': '🇦🇺', 'criterionId': 2036}, {'code': 'AT', 'nameCn': '奥地利', 'nameEn': 'Austria', 'flag': '🇦🇹', 'criterionId': 2040}, {'code': 'AZ', 'nameCn': '阿塞拜疆', 'nameEn': 'Azerbaijan', 'flag': '🇦🇿', 'criterionId': 2031}, {'code': 'BS', 'nameCn': '巴哈马', 'nameEn': 'Bahamas', 'flag': '🇧🇸', 'criterionId': 2044}, {'code': 'BH', 'nameCn': '巴林', 'nameEn': 'Bahrain', 'flag': '🇧🇭', 'criterionId': 2048}, {'code': 'BD', 'nameCn': '孟加拉国', 'nameEn': 'Bangladesh', 'flag': '🇧🇩', 'criterionId': 2050}, {'code': 'BB', 'nameCn': '巴巴多斯', 'nameEn': 'Barbados', 'flag': '🇧🇧', 'criterionId': 2052}, {'code': 'BY', 'nameCn': '白俄罗斯', 'nameEn': 'Belarus', 'flag': '🇧🇾', 'criterionId': 2112}, {'code': 'BE', 'nameCn': '比利时', 'nameEn': 'Belgium', 'flag': '🇧🇪', 'criterionId': 2056}, {'code': 'BZ', 'nameCn': '伯利兹', 'nameEn': 'Belize', 'flag': '🇧🇿', 'criterionId': 2084}, {'code': 'BJ', 'nameCn': '贝宁', 'nameEn': 'Benin', 'flag': '🇧🇯', 'criterionId': 2204}, {'code': 'BT', 'nameCn': '不丹', 'nameEn': 'Bhutan', 'flag': '🇧🇹', 'criterionId': 2064}, {'code': 'BO', 'nameCn': '玻利维亚', 'nameEn': 'Bolivia', 'flag': '🇧🇴', 'criterionId': 2068}, {'code': 'BA', 'nameCn': '波斯尼亚和黑塞哥维那', 'nameEn': 'Bosnia and Herzegovina', 'flag': '🇧🇦', 'criterionId': 2070}, {'code': 'BW', 'nameCn': '博茨瓦纳', 'nameEn': 'Botswana', 'flag': '🇧🇼', 'criterionId': 2072}, {'code': 'BR', 'nameCn': '巴西', 'nameEn': 'Brazil', 'flag': '🇧🇷', 'criterionId': 2076}, {'code': 'BN', 'nameCn': '文莱', 'nameEn': 'Brunei', 'flag': '🇧🇳', 'criterionId': 2096}, {'code': 'BG', 'nameCn': '保加利亚', 'nameEn': 'Bulgaria', 'flag': '🇧🇬', 'criterionId': 2100}, {'code': 'BF', 'nameCn': '布基纳法索', 'nameEn': 'Burkina Faso', 'flag': '🇧🇫', 'criterionId': 2854}, {'code': 'BI', 'nameCn': '布隆迪', 'nameEn': 'Burundi', 'flag': '🇧🇮', 'criterionId': 2108}, {'code': 'KH', 'nameCn': '柬埔寨', 'nameEn': 'Cambodia', 'flag': '🇰🇭', 'criterionId': 2116}, {'code': 'CM', 'nameCn': '喀麦隆', 'nameEn': 'Cameroon', 'flag': '🇨🇲', 'criterionId': 2120}, {'code': 'CA', 'nameCn': '加拿大', 'nameEn': 'Canada', 'flag': '🇨🇦', 'criterionId': 2124}, {'code': 'CV', 'nameCn': '佛得角', 'nameEn': 'Cape Verde', 'flag': '🇨🇻', 'criterionId': 2132}, {'code': 'CF', 'nameCn': '中非共和国', 'nameEn': 'Central African Republic', 'flag': '🇨🇫', 'criterionId': 2140}, {'code': 'TD', 'nameCn': '乍得', 'nameEn': 'Chad', 'flag': '🇹🇩', 'criterionId': 2148}, {'code': 'CL', 'nameCn': '智利', 'nameEn': 'Chile', 'flag': '🇨🇱', 'criterionId': 2152}, {'code': 'CN', 'nameCn': '中国', 'nameEn': 'China', 'flag': '🇨🇳', 'criterionId': 2156}, {'code': 'CO', 'nameCn': '哥伦比亚', 'nameEn': 'Colombia', 'flag': '🇨🇴', 'criterionId': 2170}, {'code': 'KM', 'nameCn': '科摩罗', 'nameEn': 'Comoros', 'flag': '🇰🇲', 'criterionId': 2174}, {'code': 'CG', 'nameCn': '刚果(布)', 'nameEn': 'Congo', 'flag': '🇨🇬', 'criterionId': 2178}, {'code': 'CD', 'nameCn': '刚果(金)', 'nameEn': 'Congo, Democratic Republic of the', 'flag': '🇨🇩', 'criterionId': 2180}, {'code': 'CR', 'nameCn': '哥斯达黎加', 'nameEn': 'Costa Rica', 'flag': '🇨🇷', 'criterionId': 2188}, {'code': 'CI', 'nameCn': '科特迪瓦', 'nameEn': "Côte d'Ivoire", 'flag': '🇨🇮', 'criterionId': 2384}, {'code': 'HR', 'nameCn': '克罗地亚', 'nameEn': 'Croatia', 'flag': '🇭🇷', 'criterionId': 2191}, {'code': 'CU', 'nameCn': '古巴', 'nameEn': 'Cuba', 'flag': '🇨🇺'}, {'code': 'CY', 'nameCn': '塞浦路斯', 'nameEn': 'Cyprus', 'flag': '🇨🇾', 'criterionId': 2196}, {'code': 'CZ', 'nameCn': '捷克', 'nameEn': 'Czech Republic', 'flag': '🇨🇿', 'criterionId': 2203}, {'code': 'DK', 'nameCn': '丹麦', 'nameEn': 'Denmark', 'flag': '🇩🇰', 'criterionId': 2208}, {'code': 'DJ', 'nameCn': '吉布提', 'nameEn': 'Djibouti', 'flag': '🇩🇯', 'criterionId': 2262}, {'code': 'DM', 'nameCn': '多米尼克', 'nameEn': 'Dominica', 'flag': '🇩🇲', 'criterionId': 2212}, {'code': 'DO', 'nameCn': '多米尼加共和国', 'nameEn': 'Dominican Republic', 'flag': '🇩🇴', 'criterionId': 2214}, {'code': 'EC', 'nameCn': '厄瓜多尔', 'nameEn': 'Ecuador', 'flag': '🇪🇨', 'criterionId': 2218}, {'code': 'EG', 'nameCn': '埃及', 'nameEn': 'Egypt', 'flag': '🇪🇬', 'criterionId': 2818}, {'code': 'SV', 'nameCn': '萨尔瓦多', 'nameEn': 'El Salvador', 'flag': '🇸🇻', 'criterionId': 2222}, {'code': 'GQ', 'nameCn': '赤道几内亚', 'nameEn': 'Equatorial Guinea', 'flag': '🇬🇶', 'criterionId': 2226}, {'code': 'ER', 'nameCn': '厄立特里亚', 'nameEn': 'Eritrea', 'flag': '🇪🇷', 'criterionId': 2232}, {'code': 'EE', 'nameCn': '爱沙尼亚', 'nameEn': 'Estonia', 'flag': '🇪🇪', 'criterionId': 2233}, {'code': 'ET', 'nameCn': '埃塞俄比亚', 'nameEn': 'Ethiopia', 'flag': '🇪🇹', 'criterionId': 2231}, {'code': 'FJ', 'nameCn': '斐济', 'nameEn': 'Fiji', 'flag': '🇫🇯', 'criterionId': 2242}, {'code': 'FI', 'nameCn': '芬兰', 'nameEn': 'Finland', 'flag': '🇫🇮', 'criterionId': 2246}, {'code': 'FR', 'nameCn': '法国', 'nameEn': 'France', 'flag': '🇫🇷', 'criterionId': 2250}, {'code': 'GA', 'nameCn': '加蓬', 'nameEn': 'Gabon', 'flag': '🇬🇦', 'criterionId': 2266}, {'code': 'GM', 'nameCn': '冈比亚', 'nameEn': 'Gambia', 'flag': '🇬🇲', 'criterionId': 2270}, {'code': 'GE', 'nameCn': '格鲁吉亚', 'nameEn': 'Georgia', 'flag': '🇬🇪', 'criterionId': 2268}, {'code': 'DE', 'nameCn': '德国', 'nameEn': 'Germany', 'flag': '🇩🇪', 'criterionId': 2276}, {'code': 'GH', 'nameCn': '加纳', 'nameEn': 'Ghana', 'flag': '🇬🇭', 'criterionId': 2288}, {'code': 'GR', 'nameCn': '希腊', 'nameEn': 'Greece', 'flag': '🇬🇷', 'criterionId': 2300}, {'code': 'GD', 'nameCn': '格林纳达', 'nameEn': 'Grenada', 'flag': '🇬🇩', 'criterionId': 2308}, {'code': 'GT', 'nameCn': '危地马拉', 'nameEn': 'Guatemala', 'flag': '🇬🇹', 'criterionId': 2320}, {'code': 'GN', 'nameCn': '几内亚', 'nameEn': 'Guinea', 'flag': '🇬🇳', 'criterionId': 2324}, {'code': 'GW', 'nameCn': '几内亚比绍', 'nameEn': 'Guinea-Bissau', 'flag': '🇬🇼', 'criterionId': 2624}, {'code': 'GY', 'nameCn': '圭亚那', 'nameEn': 'Guyana', 'flag': '🇬🇾', 'criterionId': 2328}, {'code': 'HT', 'nameCn': '海地', 'nameEn': 'Haiti', 'flag': '🇭🇹', 'criterionId': 2332}, {'code': 'HN', 'nameCn': '洪都拉斯', 'nameEn': 'Honduras', 'flag': '🇭��', 'criterionId': 2340}, {'code': 'HU', 'nameCn': '匈牙利', 'nameEn': 'Hungary', 'flag': '🇭🇺', 'criterionId': 2348}, {'code': 'IS', 'nameCn': '冰岛', 'nameEn': 'Iceland', 'flag': '🇮🇸', 'criterionId': 2352}, {'code': 'IN', 'nameCn': '印度', 'nameEn': 'India', 'flag': '🇮🇳', 'criterionId': 2356}, {'code': 'ID', 'nameCn': '印度尼西亚', 'nameEn': 'Indonesia', 'flag': '🇮🇩', 'criterionId': 2360}, {'code': 'IR', 'nameCn': '伊朗', 'nameEn': 'Iran', 'flag': '🇮🇷'}, {'code': 'IQ', 'nameCn': '伊拉克', 'nameEn': 'Iraq', 'flag': '🇮🇶', 'criterionId': 2368}, {'code': 'IE', 'nameCn': '爱尔兰', 'nameEn': 'Ireland', 'flag': '🇮🇪', 'criterionId': 2372}, {'code': 'IL', 'nameCn': '以色列', 'nameEn': 'Israel', 'flag': '🇮🇱', 'criterionId': 2376}, {'code': 'IT', 'nameCn': '意大利', 'nameEn': 'Italy', 'flag': '🇮🇹', 'criterionId': 2380}, {'code': 'JM', 'nameCn': '牙买加', 'nameEn': 'Jamaica', 'flag': '🇯🇲', 'criterionId': 2388}, {'code': 'JP', 'nameCn': '日本', 'nameEn': 'Japan', 'flag': '🇯🇵', 'criterionId': 2392}, {'code': 'JO', 'nameCn': '约旦', 'nameEn': 'Jordan', 'flag': '🇯🇴', 'criterionId': 2400}, {'code': 'KZ', 'nameCn': '哈萨克斯坦', 'nameEn': 'Kazakhstan', 'flag': '🇰🇿', 'criterionId': 2398}, {'code': 'KE', 'nameCn': '肯尼亚', 'nameEn': 'Kenya', 'flag': '🇰🇪', 'criterionId': 2404}, {'code': 'KI', 'nameCn': '基里巴斯', 'nameEn': 'Kiribati', 'flag': '🇰🇮', 'criterionId': 2296}, {'code': 'KP', 'nameCn': '朝鲜', 'nameEn': 'North Korea', 'flag': '🇰🇵'}, {'code': 'KR', 'nameCn': '韩国', 'nameEn': 'South Korea', 'flag': '🇰🇷', 'criterionId': 2410}, {'code': 'KW', 'nameCn': '科威特', 'nameEn': 'Kuwait', 'flag': '🇰🇼', 'criterionId': 2414}, {'code': 'KG', 'nameCn': '吉尔吉斯斯坦', 'nameEn': 'Kyrgyzstan', 'flag': '🇰🇬', 'criterionId': 2417}, {'code': 'LA', 'nameCn': '老挝', 'nameEn': 'Laos', 'flag': '🇱🇦', 'criterionId': 2418}, {'code': 'LV', 'nameCn': '拉脱维亚', 'nameEn': 'Latvia', 'flag': '🇱🇻', 'criterionId': 2428}, {'code': 'LB', 'nameCn': '黎巴嫩', 'nameEn': 'Lebanon', 'flag': '🇱🇧', 'criterionId': 2422}, {'code': 'LS', 'nameCn': '莱索托', 'nameEn': 'Lesotho', 'flag': '🇱🇸', 'criterionId': 2426}, {'code': 'LR', 'nameCn': '利比里亚', 'nameEn': 'Liberia', 'flag': '🇱🇷', 'criterionId': 2430}, {'code': 'LY', 'nameCn': '利比亚', 'nameEn': 'Libya', 'flag': '🇱🇾', 'criterionId': 2434}, {'code': 'LI', 'nameCn': '列支敦士登', 'nameEn': 'Liechtenstein', 'flag': '🇱🇮', 'criterionId': 2438}, {'code': 'LT', 'nameCn': '立陶宛', 'nameEn': 'Lithuania', 'flag': '🇱🇹', 'criterionId': 2440}, {'code': 'LU', 'nameCn': '卢森堡', 'nameEn': 'Luxembourg', 'flag': '🇱🇺', 'criterionId': 2442}, {'code': 'MG', 'nameCn': '马达加斯加', 'nameEn': 'Madagascar', 'flag': '🇲🇬', 'criterionId': 2450}, {'code': 'MW', 'nameCn': '马拉维', 'nameEn': 'Malawi', 'flag': '🇲🇼', 'criterionId': 2454}, {'code': 'MY', 'nameCn': '马来西亚', 'nameEn': 'Malaysia', 'flag': '🇲🇾', 'criterionId': 2458}, {'code': 'MV', 'nameCn': '马尔代夫', 'nameEn': 'Maldives', 'flag': '🇲🇻', 'criterionId': 2462}, {'code': 'ML', 'nameCn': '马里', 'nameEn': 'Mali', 'flag': '🇲🇱', 'criterionId': 2466}, {'code': 'MT', 'nameCn': '马耳他', 'nameEn': 'Malta', 'flag': '🇲🇹', 'criterionId': 2470}, {'code': 'MH', 'nameCn': '马绍尔群岛', 'nameEn': 'Marshall Islands', 'flag': '🇲🇭', 'criterionId': 2584}, {'code': 'MR', 'nameCn': '毛里塔尼亚', 'nameEn': 'Mauritania', 'flag': '🇲🇷', 'criterionId': 2478}, {'code': 'MU', 'nameCn': '毛里求斯', 'nameEn': 'Mauritius', 'flag': '🇲🇺', 'criterionId': 2480}, {'code': 'MX', 'nameCn': '墨西哥', 'nameEn': 'Mexico', 'flag': '🇲🇽', 'criterionId': 2484}, {'code': 'FM', 'nameCn': '密克罗尼西亚', 'nameEn': 'Micronesia', 'flag': '🇫🇲', 'criterionId': 2583}, {'code': 'MD', 'nameCn': '摩尔多瓦', 'nameEn': 'Moldova', 'flag': '🇲🇩', 'criterionId': 2498}, {'code': 'MC', 'nameCn': '摩纳哥', 'nameEn': 'Monaco', 'flag': '🇲🇨', 'criterionId': 2492}, {'code': 'MN', 'nameCn': '蒙古', 'nameEn': 'Mongolia', 'flag': '🇲🇳', 'criterionId': 2496}, {'code': 'ME', 'nameCn': '黑山', 'nameEn': 'Montenegro', 'flag': '🇲🇪', 'criterionId': 2499}, {'code': 'MA', 'nameCn': '摩洛哥', 'nameEn': 'Morocco', 'flag': '🇲🇦', 'criterionId': 2504}, {'code': 'MZ', 'nameCn': '莫桑比克', 'nameEn': 'Mozambique', 'flag': '🇲🇿', 'criterionId': 2508}, {'code': 'MM', 'nameCn': '缅甸', 'nameEn': 'Myanmar', 'flag': '🇲🇲', 'criterionId': 2104}, {'code': 'NA', 'nameCn': '纳米比亚', 'nameEn': 'Namibia', 'flag': '🇳🇦', 'criterionId': 2516}, {'code': 'NR', 'nameCn': '瑙鲁', 'nameEn': 'Nauru', 'flag': '🇳🇷', 'criterionId': 2520}, {'code': 'NP', 'nameCn': '尼泊尔', 'nameEn': 'Nepal', 'flag': '🇳🇵', 'criterionId': 2524}, {'code': 'NL', 'nameCn': '荷兰', 'nameEn': 'Netherlands', 'flag': '🇳🇱', 'criterionId': 2528}, {'code': 'NZ', 'nameCn': '新西兰', 'nameEn': 'New Zealand', 'flag': '🇳🇿', 'criterionId': 2554}, {'code': 'NI', 'nameCn': '尼加拉瓜', 'nameEn': 'Nicaragua', 'flag': '🇳🇮', 'criterionId': 2558}, {'code': 'NE', 'nameCn': '尼日尔', 'nameEn': 'Niger', 'flag': '🇳🇪', 'criterionId': 2562}, {'code': 'NG', 'nameCn': '尼日利亚', 'nameEn': 'Nigeria', 'flag': '🇳🇬', 'criterionId': 2566}, {'code': 'MK', 'nameCn': '北马其顿', 'nameEn': 'North Macedonia', 'flag': '🇲🇰', 'criterionId': 2807}, {'code': 'NO', 'nameCn': '挪威', 'nameEn': 'Norway', 'flag': '🇳🇴', 'criterionId': 2578}, {'code': 'OM', 'nameCn': '阿曼', 'nameEn': 'Oman', 'flag': '🇴🇲', 'criterionId': 2512}, {'code': 'PK', 'nameCn': '巴基斯坦', 'nameEn': 'Pakistan', 'flag': '🇵🇰', 'criterionId': 2586}, {'code': 'PW', 'nameCn': '帕劳', 'nameEn': 'Palau', 'flag': '🇵🇼', 'criterionId': 2585}, {'code': 'PA', 'nameCn': '巴拿马', 'nameEn': 'Panama', 'flag': '🇵🇦', 'criterionId': 2591}, {'code': 'PG', 'nameCn': '巴布亚新几内亚', 'nameEn': 'Papua New Guinea', 'flag': '🇵🇬', 'criterionId': 2598}, {'code': 'PY', 'nameCn': '巴拉圭', 'nameEn': 'Paraguay', 'flag': '🇵🇾', 'criterionId': 2600}, {'code': 'PE', 'nameCn': '秘鲁', 'nameEn': 'Peru', 'flag': '🇵🇪', 'criterionId': 2604}, {'code': 'PH', 'nameCn': '菲律宾', 'nameEn': 'Philippines', 'flag': '🇵🇭', 'criterionId': 2608}, {'code': 'PL', 'nameCn': '波兰', 'nameEn': 'Poland', 'flag': '🇵🇱', 'criterionId': 2616}, {'code': 'PT', 'nameCn': '葡萄牙', 'nameEn': 'Portugal', 'flag': '🇵🇹', 'criterionId': 2620}, {'code': 'QA', 'nameCn': '卡塔尔', 'nameEn': 'Qatar', 'flag': '🇶🇦', 'criterionId': 2634}, {'code': 'RO', 'nameCn': '罗马尼亚', 'nameEn': 'Romania', 'flag': '🇷🇴', 'criterionId': 2642}, {'code': 'RU', 'nameCn': '俄罗斯', 'nameEn': 'Russia', 'flag': '🇷🇺', 'criterionId': 2643}, {'code': 'RW', 'nameCn': '卢旺达', 'nameEn': 'Rwanda', 'flag': '🇷🇼', 'criterionId': 2646}, {'code': 'KN', 'nameCn': '圣基茨和尼维斯', 'nameEn': 'Saint Kitts and Nevis', 'flag': '🇰🇳', 'criterionId': 2659}, {'code': 'LC', 'nameCn': '圣卢西亚', 'nameEn': 'Saint Lucia', 'flag': '🇱🇨', 'criterionId': 2662}, {'code': 'VC', 'nameCn': '圣文森特和格林纳丁斯', 'nameEn': 'Saint Vincent and the Grenadines', 'flag': '🇻🇨', 'criterionId': 2670}, {'code': 'WS', 'nameCn': '萨摩亚', 'nameEn': 'Samoa', 'flag': '🇼🇸', 'criterionId': 2882}, {'code': 'SM', 'nameCn': '圣马力诺', 'nameEn': 'San Marino', 'flag': '🇸🇲', 'criterionId': 2674}, {'code': 'ST', 'nameCn': '圣多美和普林西比', 'nameEn': 'Sao Tome and Principe', 'flag': '🇸🇹', 'criterionId': 2678}, {'code': 'SA', 'nameCn': '沙特阿拉伯', 'nameEn': 'Saudi Arabia', 'flag': '🇸🇦', 'criterionId': 2682}, {'code': 'SN', 'nameCn': '塞内加尔', 'nameEn': 'Senegal', 'flag': '🇸🇳', 'criterionId': 2686}, {'code': 'RS', 'nameCn': '塞尔维亚', 'nameEn': 'Serbia', 'flag': '🇷🇸', 'criterionId': 2688}, {'code': 'SC', 'nameCn': '塞舌尔', 'nameEn': 'Seychelles', 'flag': '🇸🇨', 'criterionId': 2690}, {'code': 'SL', 'nameCn': '塞拉利昂', 'nameEn': 'Sierra Leone', 'flag': '🇸🇱', 'criterionId': 2694}, {'code': 'SG', 'nameCn': '新加坡', 'nameEn': 'Singapore', 'flag': '🇸🇬', 'criterionId': 2702}, {'code': 'SK', 'nameCn': '斯洛伐克', 'nameEn': 'Slovakia', 'flag': '🇸🇰', 'criterionId': 2703}, {'code': 'SI', 'nameCn': '斯洛文尼亚', 'nameEn': 'Slovenia', 'flag': '🇸🇮', 'criterionId': 2705}, {'code': 'SB', 'nameCn': '所罗门群岛', 'nameEn': 'Solomon Islands', 'flag': '🇸🇧', 'criterionId': 2090}, {'code': 'SO', 'nameCn': '索马里', 'nameEn': 'Somalia', 'flag': '🇸🇴', 'criterionId': 2706}, {'code': 'ZA', 'nameCn': '南非', 'nameEn': 'South Africa', 'flag': '🇿🇦', 'criterionId': 2710}, {'code': 'SS', 'nameCn': '南苏丹', 'nameEn': 'South Sudan', 'flag': '🇸🇸', 'criterionId': 2728}, {'code': 'ES', 'nameCn': '西班牙', 'nameEn': 'Spain', 'flag': '🇪🇸', 'criterionId': 2724}, {'code': 'LK', 'nameCn': '斯里兰卡', 'nameEn': 'Sri Lanka', 'flag': '🇱🇰', 'criterionId': 2144}, {'code': 'SD', 'nameCn': '苏丹', 'nameEn': 'Sudan', 'flag': '🇸🇩', 'criterionId': 2736}, {'code': 'SR', 'nameCn': '苏里南', 'nameEn': 'Suriname', 'flag': '🇸🇷', 'criterionId': 2740}, {'code': 'SE', 'nameCn': '瑞典', 'nameEn': 'Sweden', 'flag': '🇸🇪', 'criterionId': 2752}, {'code': 'CH', 'nameCn': '瑞士', 'nameEn': 'Switzerland', 'flag': '🇨🇭', 'criterionId': 2756}, {'code': 'SY', 'nameCn': '叙利亚', 'nameEn': 'Syria', 'flag': '🇸🇾'}, {'code': 'TJ', 'nameCn': '塔吉克斯坦', 'nameEn': 'Tajikistan', 'flag': '🇹🇯', 'criterionId': 2762}, {'code': 'TZ', 'nameCn': '坦桑尼亚', 'nameEn': 'Tanzania', 'flag': '🇹🇿', 'criterionId': 2834}, {'code': 'TH', 'nameCn': '泰国', 'nameEn': 'Thailand', 'flag': '🇹🇭', 'criterionId': 2764}, {'code': 'TL', 'nameCn': '东帝汶', 'nameEn': 'Timor-Leste', 'flag': '🇹🇱', 'criterionId': 2626}, {'code': 'TG', 'nameCn': '多哥', 'nameEn': 'Togo', 'flag': '🇹🇬', 'criterionId': 2768}, {'code': 'TO', 'nameCn': '汤加', 'nameEn': 'Tonga', 'flag': '🇹🇴', 'criterionId': 2776}, {'code': 'TT', 'nameCn': '特立尼达和多巴哥', 'nameEn': 'Trinidad and Tobago', 'flag': '🇹🇹', 'criterionId': 2780}, {'code': 'TN', 'nameCn': '突尼斯', 'nameEn': 'Tunisia', 'flag': '🇹🇳', 'criterionId': 2788}, {'code': 'TR', 'nameCn': '土耳其', 'nameEn': 'Turkey', 'flag': '🇹🇷', 'criterionId': 2792}, {'code': 'TM', 'nameCn': '土库曼斯坦', 'nameEn': 'Turkmenistan', 'flag': '🇹🇲', 'criterionId': 2795}, {'code': 'TV', 'nameCn': '图瓦卢', 'nameEn': 'Tuvalu', 'flag': '🇹🇻', 'criterionId': 2798}, {'code': 'UG', 'nameCn': '乌干达', 'nameEn': 'Uganda', 'flag': '🇺🇬', 'criterionId': 2800}, {'code': 'UA', 'nameCn': '乌克兰', 'nameEn': 'Ukraine', 'flag': '🇺🇦', 'criterionId': 2804}, {'code': 'AE', 'nameCn': '阿联酋', 'nameEn': 'United Arab Emirates', 'flag': '🇦🇪', 'criterionId': 2784}, {'code': 'GB', 'nameCn': '英国', 'nameEn': 'United Kingdom', 'flag': '🇬🇧', 'criterionId': 2826}, {'code': 'US', 'nameCn': '美国', 'nameEn': 'United States', 'flag': '🇺🇸', 'criterionId': 2840}, {'code': 'UY', 'nameCn': '乌拉圭', 'nameEn': 'Uruguay', 'flag': '🇺🇾', 'criterionId': 2858}, {'code': 'UZ', 'nameCn': '乌兹别克斯坦', 'nameEn': 'Uzbekistan', 'flag': '🇺🇿', 'criterionId': 2860}, {'code': 'VU', 'nameCn': '瓦努阿图', 'nameEn': 'Vanuatu', 'flag': '🇻🇺', 'criterionId': 2548}, {'code': 'VA', 'nameCn': '梵蒂冈', 'nameEn': 'Vatican City', 'flag': '🇻🇦', 'criterionId': 2336}, {'code': 'VE', 'nameCn': '委内瑞拉', 'nameEn': 'Venezuela', 'flag': '🇻🇪', 'criterionId': 2862}, {'code': 'VN', 'nameCn': '越南', 'nameEn': 'Vietnam', 'flag': '🇻🇳', 'criterionId': 2704}, {'code': 'YE', 'nameCn': '也门', 'nameEn': 'Yemen', 'flag': '🇾🇪', 'criterionId': 2887}, {'code': 'ZM', 'nameCn': '赞比亚', 'nameEn': 'Zambia', 'flag': '🇿🇲', 'criterionId': 2894}, {'code': 'ZW', 'nameCn': '津巴布韦', 'nameEn': 'Zimbabwe', 'flag': '🇿🇼', 'criterionId': 2716}]
}
},
created() {
this.fetchData()
},
methods: {
async fetchData() {
this.loading = true
try {
const response = await getLocationGroupList({
page: this.currentPage,
size: this.pageSize
})
if (response && response.status === 200 && response.result) {
this.tableData = response.result.data || []
this.total = response.result.total || 0
} else {
this.$message.error('获取数据失败')
}
} catch (error) {
console.error('获取数据失败:', error)
this.$message.error('获取数据失败')
}
this.loading = false
},
getCountryNames(codes) {
return codes.map(code => {
const country = this.countries.find(c => c.code === code)
return country ? country.nameCn : code
}).join(', ')
},
formatDate(timestamp) {
if (!timestamp) return ''
const date = new Date(timestamp)
const year = date.getFullYear()
const month = String(date.getMonth() + 1).padStart(2, '0')
const day = String(date.getDate()).padStart(2, '0')
const hours = String(date.getHours()).padStart(2, '0')
const minutes = String(date.getMinutes()).padStart(2, '0')
const seconds = String(date.getSeconds()).padStart(2, '0')
return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`
},
handleSizeChange(val) {
this.pageSize = val
this.currentPage = 1
this.fetchData()
},
handleCurrentChange(val) {
this.currentPage = val
this.fetchData()
},
showAddDialog() {
this.dialogTitle = '新增地域组'
this.form = {
name: '',
countryCodes: []
}
this.dialogVisible = true
this.$nextTick(() => {
this.$refs.form && this.$refs.form.clearValidate()
})
},
handleEdit(row) {
this.dialogTitle = '编辑地域组'
this.form = {
id: row.id,
name: row.name,
countryCodes: row.countryCodes || []
}
this.dialogVisible = true
this.$nextTick(() => {
this.$refs.form && this.$refs.form.clearValidate()
})
},
async handleDelete(row) {
try {
await this.$confirm('确认删除该地域组吗?', '提示', {
type: 'warning'
})
const response = await deleteLocationGroup(row.id)
if (response.status === 200) {
this.$message.success('删除成功')
this.fetchData()
} else {
this.$message.error(response.msg || '删除失败')
}
} catch (error) {
if (error !== 'cancel') {
console.error('删除失败:', error)
this.$message.error('删除失败')
}
}
},
async submitForm() {
this.$refs.form.validate(async (valid) => {
if (valid) {
const formData = {
...this.form
}
try {
let response
if (formData.id) {
response = await updateLocationGroup(formData)
} else {
response = await createLocationGroup(formData)
}
if (response.status === 200) {
this.$message.success(formData.id ? '更新成功' : '创建成功')
this.dialogVisible = false
this.fetchData()
} else {
this.$message.error(response.msg || (formData.id ? '更新失败' : '创建失败'))
}
} catch (error) {
console.error(formData.id ? '更新失败:' : '创建失败:', error)
this.$message.error(formData.id ? '更新失败' : '创建失败')
}
}
})
}
}
}
</script>
<style scoped>
.location-group-container {
padding: 20px;
}
.header-actions {
margin: 20px 0;
display: flex;
justify-content: space-between;
}
.header-right {
display: flex;
gap: 10px;
}
.el-table--enable-row-hover .el-table__body tr:hover > td {
background-color: #f5f7fa;
}
.el-button--primary {
background-color: #1890ff;
border-color: #1890ff;
}
.el-button--primary:hover,
.el-button--primary:focus {
background-color: #40a9ff;
border-color: #40a9ff;
}
.pagination-container {
margin-top: 20px;
display: flex;
justify-content: flex-end;
padding: 10px 0;
}
.el-pagination {
font-weight: normal;
}
.el-pagination .el-select .el-input {
width: 110px;
}
.el-pagination .el-select .el-input__inner {
padding-right: 25px;
}
.el-pagination .btn-prev,
.el-pagination .btn-next {
background: transparent;
}
.el-pagination .el-pager li {
background: transparent;
border: none;
}
.el-pagination .el-pager li.active {
color: #1890ff;
background-color: #e6f7ff;
border-radius: 2px;
}
</style>
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