|
import moment from 'moment'
|
|
export default class SettingUtils {
|
/**
|
* @description 生成页面查询语句
|
*/
|
static getDebugSql (verify, scripts, searches, Utils, timestamp) {
|
let sql = ''
|
let _dataresource = verify.dataresource || ''
|
let regoptions = this.getRegOptions(searches)
|
let _search = this.formatSearch(searches)
|
_search = Utils.joinMainSearchkey(_search)
|
|
_search = _search.replace(/@\$@/ig, '')
|
_search = _search ? 'where ' + _search : ''
|
|
let arr_field = []
|
verify.columns.forEach(item => {
|
if (item.Column !== '$Index') {
|
arr_field.push(item.Column)
|
}
|
})
|
arr_field = arr_field.join(',')
|
|
if (!arr_field) {
|
arr_field = '*'
|
}
|
|
let _customScript = ''
|
scripts && scripts.forEach(script => {
|
if (script.status === 'false') return
|
_customScript += `
|
${script.sql}
|
`
|
})
|
|
if (_customScript) {
|
_customScript = `declare @ErrorCode nvarchar(50),@retmsg nvarchar(4000),@UserName nvarchar(50),@FullName nvarchar(50),@RoleID nvarchar(512),@mk_departmentcode nvarchar(512),@mk_organization nvarchar(512),@mk_user_type nvarchar(20),@mk_nation nvarchar(50),@mk_province nvarchar(50),@mk_city nvarchar(50),@mk_district nvarchar(50),@mk_address nvarchar(100) select @ErrorCode='',@retmsg =''
|
${_customScript}
|
`
|
}
|
|
if (verify.defaultSql === 'false') {
|
_dataresource = ''
|
}
|
|
_dataresource = _dataresource.replace(/@(BID|ID|LoginUID|SessionUid|UserID|Appkey|time_id|datam|typename)@/ig, `'${timestamp}'`)
|
_customScript = _customScript.replace(/@(BID|ID|LoginUID|SessionUid|UserID|Appkey|time_id|datam|typename)@/ig, `'${timestamp}'`)
|
_dataresource = _dataresource.replace(/@\$|\$@/ig, '')
|
_customScript = _customScript.replace(/@\$|\$@/ig, '')
|
|
// 外联数据库替换
|
if (window.GLOB.externalDatabase !== null) {
|
_dataresource = _dataresource.replace(/@db@/ig, window.GLOB.externalDatabase)
|
_customScript = _customScript.replace(/@db@/ig, window.GLOB.externalDatabase)
|
}
|
|
// 正则替换
|
let _regoptions = regoptions.map(item => {
|
return {
|
reg: new RegExp('@' + item.key + '@', 'ig'),
|
value: `'0'`
|
}
|
})
|
|
_regoptions.push({
|
reg: new RegExp('@orderBy@', 'ig'),
|
value: verify.order
|
}, {
|
reg: new RegExp('@pageSize@', 'ig'),
|
value: 10
|
}, {
|
reg: new RegExp('@pageIndex@', 'ig'),
|
value: 1
|
})
|
|
_regoptions.forEach(item => {
|
_dataresource = _dataresource.replace(item.reg, item.value)
|
_customScript = _customScript.replace(item.reg, item.value)
|
})
|
|
if (verify.queryType === 'statistics' && _dataresource) {
|
_search = ''
|
}
|
|
// 数据源处理, 存在显示列时
|
if (_dataresource) {
|
if (/\s/.test(_dataresource)) {
|
_dataresource = '(' + _dataresource + ') tb'
|
}
|
|
if (verify.order) {
|
_dataresource = `/*system_query*/select ${arr_field} from (select ${arr_field} ,ROW_NUMBER() over(order by ${verify.order}) as rows from ${_dataresource} ${_search}) tmptable order by tmptable.rows`
|
} else {
|
_dataresource = `/*system_query*/select ${arr_field} from ${_dataresource} ${_search}`
|
}
|
}
|
|
if (_customScript) {
|
sql = `/* sql 验证 */
|
${_customScript}
|
${_dataresource}
|
aaa:
|
if @ErrorCode!=''
|
insert into tmp_err_retmsg (ID, ErrorCode, retmsg, CreateUserID) select @time_id@,@ErrorCode, @retmsg,@UserID@
|
`
|
} else {
|
sql = `/* sql 验证 */
|
declare @ErrorCode nvarchar(50),@retmsg nvarchar(4000),@UserName nvarchar(50),@FullName nvarchar(50),@RoleID nvarchar(512),@mk_departmentcode nvarchar(512),@mk_organization nvarchar(512),@mk_user_type nvarchar(20),@mk_nation nvarchar(50),@mk_province nvarchar(50),@mk_city nvarchar(50),@mk_district nvarchar(50),@mk_address nvarchar(100) select @ErrorCode='',@retmsg =''
|
${_dataresource}`
|
}
|
sql = sql.replace(/\n\s{8}/ig, '\n')
|
console.info(sql)
|
sql = sql.replace(/\n/g, ' ')
|
|
return sql
|
}
|
|
/**
|
* @description 获取全部搜索条件
|
* @param {Array} searches 搜索条件数组
|
*/
|
static formatSearch (searches) {
|
if (!searches || searches.length === 0) return []
|
|
let newsearches = []
|
searches.forEach(search => {
|
if (!search.field) return
|
|
let item = {
|
key: search.field,
|
match: search.match,
|
type: search.type,
|
label: search.label,
|
value: search.initval,
|
required: search.required === 'true'
|
}
|
|
if (item.type === 'group') {
|
item.key = search.datefield
|
item.type = 'daterange'
|
item.match = 'between'
|
item.value = [moment().format('YYYY-MM-DD'), moment().format('YYYY-MM-DD')].join(',')
|
|
newsearches.push(item)
|
return
|
} else if (item.type === 'date') {
|
item.value = moment().format('YYYY-MM-DD')
|
} else if (item.type === 'datemonth') {
|
item.value = moment().format('YYYY-MM')
|
} else if (item.type === 'dateweek') {
|
item.value = moment().format('YYYY-MM-DD')
|
} else if (item.type === 'daterange') {
|
item.value = [moment().format('YYYY-MM-DD'), moment().format('YYYY-MM-DD')].join(',')
|
} else if (item.type === 'multiselect' || (item.type === 'checkcard' && search.multiple === 'true')) {
|
item.type = 'multi'
|
item.value = '@$@'
|
} else {
|
item.value = '@$@'
|
}
|
newsearches.push(item)
|
})
|
|
return newsearches
|
}
|
|
/**
|
* @description 获取搜索用于正则替换
|
* @param {Array} searches 搜索条件
|
* @return {String} searchText 拼接结果
|
*/
|
static getRegOptions (searches) {
|
if (!searches || searches.length === 0) return []
|
|
let options = []
|
let fieldmap = new Map()
|
searches.forEach(search => {
|
let item = {
|
key: search.field,
|
value: '0'
|
}
|
|
if (fieldmap.has(item.key)) {
|
item.key = item.key + '1'
|
}
|
|
fieldmap.set(item.key, true)
|
|
if (search.type === 'group') {
|
options.push({
|
key: search.field,
|
value: '0'
|
})
|
options.push({
|
key: search.datefield,
|
value: '0'
|
})
|
options.push({
|
key: search.datefield + '1',
|
value: '0'
|
})
|
options.push(item)
|
} else if (['datemonth', 'dateweek', 'daterange'].includes(search.type)) {
|
options.push(item)
|
options.push({
|
key: item.key + '1',
|
value: '0'
|
})
|
} else if (search.type === 'text' || search.type === 'select') {
|
item.key.split(',').forEach(field => {
|
let cell = JSON.parse(JSON.stringify(item))
|
cell.key = field
|
|
options.push(cell)
|
})
|
} else {
|
options.push(item)
|
}
|
})
|
|
return options
|
}
|
}
|