Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
I
ibizlab-generator
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
ibiz4jteam
ibizlab-generator
提交
894e2457
提交
894e2457
编写于
1月 20, 2022
作者:
Shine-zwj
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update:更新徽标和格式化指令
上级
a90e910d
变更
11
隐藏空白字符变更
内嵌
并排
正在显示
11 个修改的文件
包含
928 行增加
和
7 行删除
+928
-7
span.hbs
...main/resources/templ/r7/@macro/front-end/editors/span.hbs
+4
-0
form-details-model.hbs
...acro/front-end/widgets/form-detail/form-details-model.hbs
+1
-1
package.json
...ore/src/main/resources/templ/r7/app_{{apps}}/package.json
+2
-1
app-span.vue
...templ/r7/app_{{apps}}/src/components/editors/app-span.vue
+2
-2
util.ts
...in/resources/templ/r7/app_{{apps}}/src/core/utils/util.ts
+10
-0
badge.scss
...ces/templ/r7/app_{{apps}}/src/directives/badge/badge.scss
+50
-0
badge.ts
...urces/templ/r7/app_{{apps}}/src/directives/badge/badge.ts
+151
-0
directives.ts
...ources/templ/r7/app_{{apps}}/src/directives/directives.ts
+7
-0
format.scss
...s/templ/r7/app_{{apps}}/src/directives/format/format.scss
+39
-0
format.ts
...ces/templ/r7/app_{{apps}}/src/directives/format/format.ts
+658
-0
main.ts
...core/src/main/resources/templ/r7/app_{{apps}}/src/main.ts
+4
-3
未找到文件。
modules/ibizlab-generator-core/src/main/resources/templ/r7/@macro/front-end/editors/span.hbs
浏览文件 @
894e2457
...
@@ -15,6 +15,10 @@
...
@@ -15,6 +15,10 @@
{{/if}}
{{/if}}
{{#if
item
.
psEditor
.
editorParams
.
valueFormat
}}
{{#if
item
.
psEditor
.
editorParams
.
valueFormat
}}
valueFormat=
"
{{
item
.
psEditor
.
editorParams
.
valueFormat
}}
"
valueFormat=
"
{{
item
.
psEditor
.
editorParams
.
valueFormat
}}
"
{{else
if
(
item
.
valueFormat
)
}}
valueFormat=
"
{{
item
.
valueFormat
}}
"
{{else
if
(
item
.
psAppDEField
.
valueFormat
)
}}
valueFormat=
"
{{
item
.
psAppDEField
.
valueFormat
}}
"
{{/if}}
{{/if}}
{{#if
item
.
psEditor
.
precision
}}
{{#if
item
.
psEditor
.
precision
}}
:precision=
"
{{
item
.
psEditor
.
precision
}}
"
:precision=
"
{{
item
.
psEditor
.
precision
}}
"
...
...
modules/ibizlab-generator-core/src/main/resources/templ/r7/@macro/front-end/widgets/form-detail/form-details-model.hbs
浏览文件 @
894e2457
'
{{
formDetail
.
codeName
}}
'
: {
{{
formDetail
.
codeName
}}
: {
caption: '
{{
formDetail
.
caption
}}
',
caption: '
{{
formDetail
.
caption
}}
',
name: '
{{
formDetail
.
name
}}
',
name: '
{{
formDetail
.
name
}}
',
disabled: false,
disabled: false,
...
...
modules/ibizlab-generator-core/src/main/resources/templ/r7/app_{{apps}}/package.json
浏览文件 @
894e2457
...
@@ -24,7 +24,8 @@
...
@@ -24,7 +24,8 @@
"rxjs"
:
"^7.4.0"
,
"rxjs"
:
"^7.4.0"
,
"vue"
:
"^3.2.23"
,
"vue"
:
"^3.2.23"
,
"vue-global-api"
:
"^0.4.1"
,
"vue-global-api"
:
"^0.4.1"
,
"vue-router"
:
"^4.0.12"
"vue-router"
:
"^4.0.12"
,
"moment"
:
"2.24.0"
},
},
"devDependencies"
:
{
"devDependencies"
:
{
"@types/node"
:
"^16.11.12"
,
"@types/node"
:
"^16.11.12"
,
...
...
modules/ibizlab-generator-core/src/main/resources/templ/r7/app_{{apps}}/src/components/editors/app-span.vue
浏览文件 @
894e2457
...
@@ -8,7 +8,7 @@ interface SpanProps {
...
@@ -8,7 +8,7 @@ interface SpanProps {
* @type {*}
* @type {*}
* @memberof AppSpan
* @memberof AppSpan
*/
*/
value
?
:
string
;
value
:
string
;
/**
/**
* 传入表单数据
* 传入表单数据
...
@@ -134,7 +134,7 @@ onBeforeMount(() => {
...
@@ -134,7 +134,7 @@ onBeforeMount(() => {
<
template
>
<
template
>
<div
:class=
"['app-editor-container', 'app-span', `app-span-$
{name}`]">
<div
:class=
"['app-editor-container', 'app-span', `app-span-$
{name}`]">
<span>
\
{{
text
}}
</span>
<span
v-format=
"textFormat"
>
\
{{
text
}}
</span>
</div>
</div>
</
template
>
</
template
>
...
...
modules/ibizlab-generator-core/src/main/resources/templ/r7/app_{{apps}}/src/core/utils/util.ts
浏览文件 @
894e2457
...
@@ -97,6 +97,16 @@ export function hasFunction(arg: any, fnName: string): boolean{
...
@@ -97,6 +97,16 @@ export function hasFunction(arg: any, fnName: string): boolean{
return
arg
[
fnName
]
&&
arg
[
fnName
]
instanceof
Function
;
return
arg
[
fnName
]
&&
arg
[
fnName
]
instanceof
Function
;
}
}
/**
* @description 字符串是否存在并且不为空
* @export
* @param {(string | undefined | null)} str
* @return {*} {boolean}
*/
export
function
isExistAndNotEmpty
(
str
:
string
|
undefined
|
null
):
boolean
{
return
isExist
(
str
)
&&
!
isEmpty
(
str
);
}
/**
/**
* @description 获取当前数据值类型
* @description 获取当前数据值类型
* @export
* @export
...
...
modules/ibizlab-generator-core/src/main/resources/templ/r7/app_{{apps}}/src/directives/badge/badge.scss
0 → 100644
浏览文件 @
894e2457
sup
.ibiz-badge
{
position
:
absolute
;
top
:
-0
.2rem
;
z-index
:
10
;
min-width
:
0
.4rem
;
height
:
0
.4rem
;
padding
:
0
0
.12rem
;
font-size
:
0
.24rem
;
line-height
:
0
.36rem
;
color
:
#fff
;
text-align
:
center
;
white-space
:
nowrap
;
vertical-align
:
middle
;
background
:
#ed4014
;
border
:
1px
solid
transparent
;
border-radius
:
0
.2rem
;
//预设类型颜色
&
.primary
{
background
:
#2d8cf0
;
}
&
.success
{
background
:
#19be6b
;
}
&
.normal
{
color
:
#808695
;
background
:
#e6ebf1
;
}
&
.error
{
background
:
#ed4014
;
}
&
.warning
{
background
:
#f90
;
}
&
.info
{
background
:
#2db7f5
;
}
//预设为标大小
&
.small
{
min-width
:
0
.32rem
;
height
:
0
.28rem
;
padding
:
0
0
.08rem
;
line-height
:
0
.24rem
;
}
&
.large
{
min-width
:
0
.48rem
;
height
:
0
.48rem
;
padding
:
0
0
.16rem
;
line-height
:
0
.4rem
;
}
}
modules/ibizlab-generator-core/src/main/resources/templ/r7/app_{{apps}}/src/directives/badge/badge.ts
0 → 100644
浏览文件 @
894e2457
import
{
VNode
}
from
'vue'
;
import
{
isExistAndNotEmpty
}
from
'@/core'
;
/**
* 微标指令
*
* @export
* @class Badge
*/
export
const
Badge
:
any
=
{
/**
* 指令初始化
*
* @param {HTMLDivElement} el
* @param {*} binding
* @param {VNode} vNode
* @param {VNode} oldVNode
*/
beforeMount
(
el
:
HTMLDivElement
,
binding
:
any
,
vNode
:
VNode
,
oldVNode
:
VNode
)
{
bc
.
init
(
el
,
binding
);
},
/**
* 指令更新
*
* @param {HTMLDivElement} el
* @param {*} binding
* @param {VNode} vNode
* @param {VNode} oldVNode
*/
updated
(
el
:
HTMLDivElement
,
binding
:
any
,
vNode
:
VNode
,
oldVNode
:
VNode
)
{
bc
.
update
(
el
,
binding
);
},
};
/**
* 微标控制器
*
* @export
* @class BadgeController
*/
export
class
BadgeController
{
/**
* 唯一实例
*
* @private
* @static
* @memberof BadgeControllerController
*/
private
static
readonly
instance
=
new
BadgeController
();
/**
* 容器
*
* @protected
* @type {HTMLDivElement}
* @memberof NotificationSignalController
*/
protected
el
!
:
HTMLElement
;
/**
* Creates an instance of BadgeControllerController.
* @memberof BadgeControllerController
*/
private
constructor
()
{
if
(
BadgeController
.
instance
)
{
return
BadgeController
.
instance
;
}
}
/**
* 初始化
*
* @param {HTMLDivElement}
* @param {any}
* @memberof BadgeController
*/
public
init
(
el
:
HTMLDivElement
,
binding
:
any
):
void
{
const
item
:
any
=
binding
.
value
;
if
(
Object
.
keys
(
item
).
length
>
0
&&
isExistAndNotEmpty
(
item
.
count
))
{
if
(
!
item
.
showZero
&&
item
.
count
==
0
)
{
return
;
}
const
badge
:
HTMLElement
=
document
.
createElement
(
'sup'
);
badge
.
innerHTML
=
String
(
item
.
count
);
badge
.
classList
.
add
(
'ibiz-badge'
);
this
.
el
=
badge
;
el
.
append
(
badge
);
this
.
setBadgeclass
(
item
.
type
);
this
.
setBadgeclass
(
item
.
size
);
this
.
setBadgeclass
(
item
.
className
);
this
.
setBadgeOffset
(
item
.
offset
);
}
}
/**
* 更新
*
* @param {HTMLDivElement}
* @param {any}
* @memberof BadgeController
*/
public
update
(
el
:
HTMLDivElement
,
binding
:
any
):
void
{
const
item
:
any
=
binding
.
value
;
if
(
Object
.
keys
(
item
).
length
>
0
&&
isExistAndNotEmpty
(
item
.
count
))
{
if
(
!
item
.
showZero
&&
item
.
count
==
0
)
{
return
;
}
this
.
el
.
innerHTML
=
String
(
item
.
count
);
}
}
/**
* 设置徽标类型样式
*
* @param {string}
* @memberof BadgeController
*/
public
setBadgeclass
(
type
:
string
)
{
if
(
!
type
)
{
return
;
}
this
.
el
.
classList
.
add
(
type
);
}
/**
* 设置徽标偏移量
*
* @param {string}
* @memberof BadgeController
*/
public
setBadgeOffset
(
offset
:
Array
<
number
>
)
{
if
(
offset
&&
offset
.
length
==
2
)
{
this
.
el
.
style
.
transform
=
`translate(
${
offset
[
0
]
/
50
}
rem,
${
offset
[
1
]
/
50
}
rem)`
;
}
}
/**
* 获取唯一实例
*
* @static
* @returns {BadgeController}
* @memberof BadgeController
*/
public
static
getInstance
():
BadgeController
{
return
BadgeController
.
instance
;
}
}
// 导出服务
export
const
bc
:
BadgeController
=
BadgeController
.
getInstance
();
modules/ibizlab-generator-core/src/main/resources/templ/r7/app_{{apps}}/src/directives/directives.ts
0 → 100644
浏览文件 @
894e2457
import
{
Badge
}
from
'./badge/badge'
;
import
{
Format
}
from
'./format/format'
;
export
default
(
Vue
:
any
)
=>
{
Vue
.
directive
(
'badge'
,
Badge
);
Vue
.
directive
(
'format'
,
Format
);
}
modules/ibizlab-generator-core/src/main/resources/templ/r7/app_{{apps}}/src/directives/format/format.scss
0 → 100644
浏览文件 @
894e2457
.vue-format-single
{
display
:
flex
;
width
:
100%
;
height
:
100%
;
}
.vue-format-single
>
*
{
flex-grow
:
0
;
flex-shrink
:
0
;
}
.vue-format-single-color-red
{
color
:
red
;
}
.vue-format-single-color-black
{
color
:
black
;
}
.vue-format-single-color-yellow
{
color
:
yellow
;
}
.vue-format-single-color-green
{
color
:
green
;
}
.vue-format-single-color-white
{
color
:
white
;
}
.vue-format-single-color-blue
{
color
:
blue
;
}
.vue-format-single-color-cyan
{
color
:
cyan
;
}
.vue-format-single-color-magenta
{
color
:
rmagentaed
;
}
.vue-format-single-fill
{
flex-grow
:
1
;
flex-shrink
:
1
;
overflow
:
hidden
;
white-space
:
nowrap
;
}
modules/ibizlab-generator-core/src/main/resources/templ/r7/app_{{apps}}/src/directives/format/format.ts
0 → 100644
浏览文件 @
894e2457
import
{
VNode
}
from
'vue'
;
import
moment
from
'moment'
;
/**
* 格式化指令
*
*/
export
const
Format
:
any
=
{
/**
* @description 指令初始化
* @param {HTMLDivElement} el 元素
* @param {*} binding 指令
* @param {VNode} vNode 节点
* @param {VNode} oldVNode 旧节点
*/
beforeMount
(
el
:
HTMLDivElement
,
binding
:
any
,
vNode
:
VNode
,
oldVNode
:
VNode
)
{
format
.
init
(
el
,
binding
,
vNode
);
},
/**
* @description 指令更新
* @param {HTMLDivElement} el
* @param {*} binding
* @param {VNode} vNode
* @param {VNode} oldVNode
*/
updated
(
el
:
HTMLDivElement
,
binding
:
any
,
vNode
:
VNode
,
oldVNode
:
VNode
)
{
format
.
init
(
el
,
binding
,
vNode
);
},
};
/**
* @description 格式化控制器
* @export
* @class FormatController
*/
export
class
FormatController
{
/**
* @description 唯一实例
* @private
* @static
* @memberof FormatController
*/
private
static
readonly
instance
=
new
FormatController
();
/**
* @description 容器
* @protected
* @type {HTMLElement}
* @memberof FormatController
*/
protected
el
!
:
HTMLElement
;
/**
* Creates an instance of FormatController.
* @memberof FormatController
*/
private
constructor
()
{
if
(
FormatController
.
instance
)
{
return
FormatController
.
instance
;
}
}
/**
* @description 获取唯一实例
* @static
* @return {*} {FormatController}
* @memberof FormatController
*/
public
static
getInstance
():
FormatController
{
return
FormatController
.
instance
;
}
/**
* @description 初始化
* @param {HTMLDivElement} el 元素
* @param {*} binding 绑定值
* @param {*} vnode 节点
* @memberof FormatController
*/
public
init
(
el
:
HTMLDivElement
,
binding
:
any
,
vNode
:
any
)
{
const
value
=
el
.
innerText
;
const
formatRule
=
binding
.
value
;
if
(
value
&&
formatRule
)
{
const
returnValue
=
this
.
formatData
(
value
,
formatRule
);
el
.
innerHTML
=
this
.
encodeHtml
(
returnValue
);
}
}
/**
* @description 格式化时间
* @private
* @param {*} newValue 新值
* @param {*} oldValue 原始值
* @param {string} dateFormat 日期格式化
* @return {*}
* @memberof FormatController
*/
private
formatDate
(
newValue
:
any
,
oldValue
:
any
,
dateFormat
:
string
)
{
if
(
isNaN
(
oldValue
)
&&
!
isNaN
(
Date
.
parse
(
oldValue
)))
{
return
moment
(
oldValue
).
format
(
dateFormat
);
}
else
{
return
newValue
;
}
}
/**
* @description 格式化数据
* @private
* @param {string} value 值
* @param {string} formatRule 格式化规则
* @return {*}
* @memberof FormatController
*/
private
formatData
(
value
:
any
,
formatRule
:
string
)
{
const
oldValue
=
value
;
let
usedCalc
:
boolean
=
false
;
const
formatRules
=
formatRule
.
split
(
';'
);
if
(
formatRules
.
length
<
4
&&
formatRules
[
0
].
match
(
/^
\[(
>|<|=|>=|<=|<>
)\d
+
\]
/
))
{
usedCalc
=
true
;
}
let
newFormatRule
=
this
.
handleFormatRules
(
value
,
formatRules
);
// 遇到 % 乘以 100
if
(
newFormatRule
.
match
(
/
[^
*|
\\
|_
]
%/
)
!==
null
&&
value
.
toString
().
match
(
/^-
?\d
+
(\.\d
+
)?
$/
))
{
value
=
value
*
100
;
}
let
codeZhengshuNumCount
=
0
;
let
codeXiaoshuNumCount
=
0
;
let
allEffectivePlaceholder
=
true
;
let
isQianfenwei
=
false
;
let
isFenShuwei
=
false
;
// 处理自定义格式中整数部分数字占位符个数
if
(
newFormatRule
.
match
(
/
(([
#|0|
\?](\\\.
|
[^
#|0|
\.])
*
)
+
)\.?
/
)
!==
null
)
{
const
temp
=
newFormatRule
.
replace
(
/
[
*|
\\
|_
]{2}
/g
,
''
)
.
replace
(
/
[
*|
\\
|_
]([
#|0|
\?])
/g
,
''
)
.
match
(
/
(([
#|0|
\?](\\\.
|
[^
#|0|
\.])
*
)
+
)\.?
/
);
if
(
temp
)
{
codeZhengshuNumCount
=
temp
[
1
].
match
(
/
([
#|0|
\?])
/g
)?.
length
||
0
;
}
}
// 处理千分位
if
(
newFormatRule
.
match
(
/
[^
*|
\\
|_
]
,/
)
!==
null
)
{
isQianfenwei
=
true
;
const
endQianfenwei
=
(
newFormatRule
+
' '
).
match
(
/
[^
*|
\\
|_
](
,+
)[^
#|0|
\?]
/
);
if
(
endQianfenwei
!==
null
)
{
// 是否有末尾千分位
value
=
value
/
Math
.
pow
(
1000
,
endQianfenwei
[
1
].
length
);
}
}
// 处理小数
if
(
newFormatRule
.
match
(
/
\.(([
#|0|
\?]?(\\\.
|
[^
#|0|
\.])
*
)
+
)
/
)
!==
null
)
{
const
xiaoshuCode
=
(
newFormatRule
.
replace
(
/
[
*|
\\
|_
]{2}
/g
,
''
)
?.
replace
(
/
[
*|
\\
|_
]([
#|0|
\?])
/g
,
''
)
?.
match
(
/
\.(([
#|0|
\?]?(\\\.
|
[^
#|0|
\.])
*
)
+
)
/
)
as
any
)[
1
];
const
xiaoshuNumSlot
=
xiaoshuCode
?.
match
(
/
([
#|0|
\?])
/g
);
if
(
xiaoshuCode
.
match
(
/^#+%
?
$/
)
===
null
)
{
allEffectivePlaceholder
=
false
;
}
if
(
xiaoshuNumSlot
===
null
)
{
codeXiaoshuNumCount
=
0
;
}
else
{
codeXiaoshuNumCount
=
xiaoshuNumSlot
.
length
;
}
}
else
{
// rule没有小数部分,直接四舍五入
if
(
typeof
value
===
'number'
)
{
value
=
Math
.
round
(
value
);
}
}
// 处理分数
const
tempFenshuMatch
=
newFormatRule
.
replace
(
/
[
*|
\\
|_
]{2}
/g
,
''
)
.
replace
(
/
[
*|
\\
|_
]([
#|0|
\?])
/g
,
''
)
.
match
(
/
(
.*
[^
*|
\\
|_
])\/[^\d
|#|0|
\?]
*
?([\d
|#|0|
\?]
+
)
/
);
let
fenmu
:
any
;
if
(
tempFenshuMatch
)
{
//如果是分数表达式
value
=
oldValue
;
const
isHasZhengshu
:
any
=
tempFenshuMatch
[
1
].
match
(
/
([
#|0
\?]
+
[^
#|0
\?]
*
)
/g
);
fenmu
=
tempFenshuMatch
[
2
];
if
(
tempFenshuMatch
.
length
>=
2
)
{
isFenShuwei
=
true
;
}
if
(
fenmu
===
'?'
)
{
const
temp
=
this
.
parseNumber
(
parseFloat
(
value
),
1
);
fenmu
=
temp
[
1
];
}
else
if
(
fenmu
===
'??'
)
{
const
temp
=
this
.
parseNumber
(
parseFloat
(
value
),
2
);
fenmu
=
temp
[
1
];
}
else
if
(
fenmu
===
'???'
)
{
const
temp
=
this
.
parseNumber
(
parseFloat
(
value
),
3
);
fenmu
=
temp
[
1
];
}
const
runValue
=
parseInt
(((
parseInt
((
value
*
fenmu
*
2
).
toString
())
+
1
)
/
2
).
toString
());
if
(
isHasZhengshu
.
length
>=
2
)
{
value
=
[
parseInt
((
runValue
/
fenmu
).
toString
()),
runValue
%
fenmu
];
}
if
(
isHasZhengshu
.
length
>=
2
)
{
codeZhengshuNumCount
=
isHasZhengshu
[
0
].
match
(
/
([
#|0
\?])[^
#|0
\?]
*/g
).
length
;
codeXiaoshuNumCount
=
isHasZhengshu
[
1
].
match
(
/
([
#|0
\?])[^
#|0
\?]
*/g
).
length
;
}
else
{
codeZhengshuNumCount
=
0
;
codeXiaoshuNumCount
=
isHasZhengshu
[
0
].
length
;
value
=
[
0
,
runValue
];
}
}
else
{
// 如果是一个极小的数字,例如9.568181142949328e-7
const
e
=
value
.
toString
().
match
(
/e
([
+|-
])(\d
+
)
$/
);
value
=
value
.
toString
().
split
(
'.'
);
if
(
e
)
{
if
(
e
[
1
]
===
'-'
)
{
if
(
e
[
2
]
>
0
)
{
value
=
[
0
,
Array
(
e
[
2
]
-
1
)
.
fill
(
0
)
.
join
(
''
)
+
value
[
0
]
+
value
[
1
].
replace
(
/e-
(\d
+
)
$/
,
''
),
];
}
}
}
}
value
[
0
]
=
Math
.
abs
(
value
[
0
]).
toString
();
let
temp
=
''
;
const
returnValue
=
[
''
,
''
,
''
];
let
returnHtml
=
''
;
// 已经跑完的数字位置
let
finishedNumCount
=
0
;
let
styleColor
=
''
;
while
(
newFormatRule
.
length
>
0
)
{
temp
=
newFormatRule
[
0
];
if
(
temp
===
'_'
)
{
returnHtml
+=
'<span style="opacity: 0">'
+
newFormatRule
[
1
]
+
'</span>'
;
newFormatRule
=
newFormatRule
.
slice
(
2
);
}
else
if
(
temp
===
'*'
)
{
returnValue
[
0
]
=
returnHtml
;
if
(
newFormatRule
[
1
]
!==
'='
)
{
returnValue
[
1
]
+=
newFormatRule
[
1
];
}
returnHtml
=
''
;
newFormatRule
=
newFormatRule
.
slice
(
2
);
}
else
if
(
temp
===
'['
)
{
newFormatRule
=
newFormatRule
.
slice
(
1
);
const
type
:
any
=
newFormatRule
.
match
(
/^
([^\]]
+
)\]
/
);
const
styleColorList
:
any
=
{
红色
:
'red'
,
黑色
:
'black'
,
黄色
:
'yellow'
,
绿色
:
'green'
,
白色
:
'white'
,
蓝色
:
'blue'
,
青色
:
'cyan'
,
洋红
:
'magenta'
,
};
const
findStr
=
newFormatRule
.
match
(
/^
\[\$(\S)
-804
\]
/
);
if
(
Object
.
keys
(
styleColorList
).
includes
(
type
[
1
]))
{
styleColor
=
styleColorList
[
type
[
1
]];
returnHtml
+=
''
;
}
else
if
(
findStr
)
{
newFormatRule
=
newFormatRule
.
replace
(
/^
\[\$(\S)
-804
\]
/
,
''
);
returnHtml
+=
findStr
[
1
];
}
newFormatRule
=
newFormatRule
.
slice
(
type
.
length
+
1
);
}
else
if
(
temp
===
'#'
||
temp
===
'0'
||
temp
===
'?'
)
{
const
match
=
newFormatRule
.
match
(
/^
([
#|0
]
+
)\.([
#|0
]
+
)
E
\+([
#|0
]
+
)
/
);
if
(
match
)
{
// 科学计数法
let
match1Length
=
match
[
1
].
length
;
const
match2Length
=
match
[
2
].
length
;
const
match3Length
=
match
[
3
].
length
;
let
firstWeishu
=
value
[
0
].
length
;
//整数位数
let
chengshu
=
0
;
if
(
value
.
length
>
1
)
{
//有小数部分
if
(
value
[
0
]
===
0
)
{
//数字是小于1的
value
[
0
]
=
''
;
let
ppp
=
0
;
while
(
ppp
++
<
100
)
{
if
(
value
[
1
][
0
]
!==
'0'
)
{
value
[
0
]
+=
value
[
1
][
0
];
}
value
[
1
]
=
value
[
1
].
slice
(
1
);
chengshu
--
;
if
(
value
[
1
].
length
===
0
)
{
//if(value[0]=='0'){
value
=
[
value
[
0
]];
firstWeishu
=
value
[
0
].
length
;
break
;
}
}
//小于1的,表达式整数无论多少位,只进步到一位有效数字,在excel尝试得到,不知道原因
if
(
match1Length
>
1
)
{
for
(
let
i
=
0
;
i
<
match1Length
-
1
;
i
++
)
{
returnHtml
+=
'0'
;
}
}
match1Length
=
1
;
}
else
{
value
=
[
value
[
0
]
+
value
[
1
]];
}
}
returnHtml
+=
value
[
0
].
toString
().
slice
(
0
,
match1Length
)
+
'.'
;
//整数位
//小数部分
let
xiaoshuValue
=
''
;
for
(
let
i
=
match2Length
+
match1Length
;
i
>=
match1Length
+
1
;
i
--
)
{
if
(
newFormatRule
[
i
]
===
'#'
&&
xiaoshuValue
===
''
&&
value
[
0
][
i
-
1
]
===
'0'
)
{
return
;
}
else
if
(
value
[
0
][
i
-
1
]
!==
undefined
)
{
xiaoshuValue
=
value
[
0
][
i
-
1
]
+
xiaoshuValue
;
}
else
if
(
newFormatRule
[
i
]
===
'0'
)
{
xiaoshuValue
=
'0'
+
xiaoshuValue
;
}
}
returnHtml
+=
xiaoshuValue
+
'E'
;
returnHtml
+=
firstWeishu
>
match1Length
-
chengshu
?
'+'
:
'-'
;
//指数部分
const
valueTemp
=
Math
.
abs
(
firstWeishu
-
match1Length
+
chengshu
);
if
(
valueTemp
.
toString
().
length
<
match3Length
)
{
for
(
let
i
=
0
;
i
<
match3Length
-
valueTemp
.
toString
().
length
;
i
++
)
{
returnHtml
+=
'0'
;
}
}
returnHtml
+=
valueTemp
;
newFormatRule
=
newFormatRule
.
replace
(
/^
([
#|0
]
+
)\.([
#|0
]
+
)
E
\+([
#|0
]
+
)
/
,
''
);
}
else
{
if
(
finishedNumCount
>=
codeZhengshuNumCount
)
{
//进入小数区间,或者分数区间
if
(
isFenShuwei
===
true
)
{
if
(
finishedNumCount
>
codeZhengshuNumCount
+
codeXiaoshuNumCount
-
1
)
{
//进入分母区间了
const
oldReturnHtml
=
returnHtml
;
if
(
fenmu
.
toString
()[
finishedNumCount
-
codeZhengshuNumCount
-
codeXiaoshuNumCount
])
{
returnHtml
+=
fenmu
.
toString
();
//[finishedNumCount - codeZhengshuNumCount - codeXiaoshuNumCount];
}
else
if
(
temp
===
'0'
)
{
returnHtml
+=
'0'
;
}
else
if
(
temp
===
'?'
)
{
returnHtml
+=
' '
;
}
newFormatRule
=
newFormatRule
.
slice
(
returnHtml
.
length
-
oldReturnHtml
.
length
);
}
else
{
if
(
value
.
length
===
2
&&
value
[
1
].
length
>
codeXiaoshuNumCount
)
{
returnHtml
+=
value
[
1
];
newFormatRule
=
newFormatRule
.
slice
(
codeXiaoshuNumCount
);
}
else
{
if
(
value
.
length
===
2
&&
finishedNumCount
-
codeZhengshuNumCount
>
codeXiaoshuNumCount
-
value
[
1
].
length
-
1
)
{
returnHtml
+=
value
[
1
][
value
[
1
].
length
-
codeXiaoshuNumCount
+
finishedNumCount
-
codeZhengshuNumCount
];
}
else
if
(
temp
===
'0'
)
{
returnHtml
+=
'0'
;
}
else
if
(
temp
===
'?'
)
{
returnHtml
+=
' '
;
}
newFormatRule
=
newFormatRule
.
slice
(
1
);
}
}
}
else
{
if
(
value
.
length
===
2
&&
value
[
1
].
length
>
finishedNumCount
-
codeZhengshuNumCount
)
{
returnHtml
+=
value
[
1
][
finishedNumCount
-
codeZhengshuNumCount
];
}
else
if
(
temp
===
'0'
)
{
returnHtml
+=
'0'
;
}
else
if
(
temp
===
'?'
)
{
returnHtml
+=
' '
;
}
newFormatRule
=
newFormatRule
.
slice
(
1
);
}
}
else
if
(
codeZhengshuNumCount
-
finishedNumCount
<=
value
[
0
].
length
)
{
// 整数部分 code 3个 value 2个, finishedNumCount应该1就进入
if
(
finishedNumCount
===
0
)
{
// 整数之前的部分(code位少)
// 整数部分 虽然code的位数不够,则都显示
for
(
let
i
=
0
;
i
<
value
[
0
].
length
-
codeZhengshuNumCount
;
i
++
)
{
returnHtml
+=
value
[
0
][
i
];
if
(
isQianfenwei
&&
(
value
[
0
].
length
-
i
)
%
3
===
1
)
{
returnHtml
+=
','
;
}
}
}
if
(
value
[
0
]
===
'0'
)
{
if
(
temp
===
'0'
)
{
returnHtml
+=
'0'
;
}
else
if
(
temp
===
'?'
)
{
returnHtml
+=
' '
;
}
}
else
{
returnHtml
+=
value
[
0
][
value
[
0
].
length
+
finishedNumCount
-
codeZhengshuNumCount
];
}
if
(
!
(
isFenShuwei
&&
value
[
0
]
===
'0'
))
{
if
(
isQianfenwei
&&
(
codeZhengshuNumCount
-
finishedNumCount
)
%
3
===
1
&&
codeZhengshuNumCount
-
finishedNumCount
!==
1
)
{
returnHtml
+=
','
;
}
}
newFormatRule
=
newFormatRule
.
slice
(
1
);
}
else
{
if
(
temp
===
'0'
)
{
returnHtml
+=
'0'
;
}
else
if
(
temp
===
'?'
)
{
returnHtml
+=
' '
;
}
if
(
isQianfenwei
&&
(
codeZhengshuNumCount
-
finishedNumCount
)
%
3
===
1
&&
codeZhengshuNumCount
-
finishedNumCount
!==
1
)
{
returnHtml
+=
','
;
}
newFormatRule
=
newFormatRule
.
slice
(
1
);
}
finishedNumCount
++
;
}
}
else
if
(
temp
===
'@'
)
{
returnHtml
+=
oldValue
;
newFormatRule
=
newFormatRule
.
slice
(
1
);
}
else
if
(
temp
===
'"'
)
{
const
findStr
:
any
=
newFormatRule
.
match
(
/^"
([^
"
]
*
)
"/
);
returnHtml
+=
findStr
[
1
];
newFormatRule
=
newFormatRule
.
replace
(
/^"
([^
"
]
*
)
"/
,
''
);
}
else
if
(
temp
===
'
\
\'
|| temp === '
!
') {
returnHtml += newFormatRule[1];
newFormatRule = newFormatRule.slice(2);
} else if (temp === '
,
') {
newFormatRule = newFormatRule.slice(1);
} else if (temp === '
.
') {
//真实数字精度大于格式小数精度,则进行四舍五入
if (finishedNumCount === codeZhengshuNumCount && value.length === 2 && value[1].length > codeXiaoshuNumCount) {
// 前面添加一个1,后面再删除,是为了防止第一位是0,造成的省略
const fixed = Math.round(
parseFloat('
1
' + value[1].slice(0, codeXiaoshuNumCount) + '
.
' + value[1].slice(codeXiaoshuNumCount)),
)
.toString()
.slice(1);
value[1] = parseFloat('
0
.
' + fixed)
.toFixed(codeXiaoshuNumCount)
.split('
.
')[1]
.replace(/0+$/, '');
if (value[1].match(/^0+$/) !== null) {
value = [value[0]];
}
}
if (allEffectivePlaceholder) {
// 如果小数点后面都是#,而且遇到了整数,则判断小数点是无效的
// ##.## 遇到【3】,最终显示【 3 】,而不是【 3. 】
if (value[1]) {
returnHtml += temp;
}
} else {
returnHtml += temp;
}
newFormatRule = newFormatRule.slice(1);
} else {
returnHtml += temp;
newFormatRule = newFormatRule.slice(1);
}
}
returnHtml = this.formatDate(returnHtml, oldValue, formatRule);
returnValue[2] = returnHtml;
// 如果只配置了规则或者颜色,等于默认填充了值
if ((usedCalc || styleColor) && returnHtml === '') {
returnValue[2] = oldValue;
}
if (styleColor !== '') {
returnValue[3] = styleColor;
}
return returnValue;
}
/**
* @description 处理格式化规则
* 根据格式化规则对 正 负 零 区分显示规则处理
* @private
* @param {*} value 值
* @param {string} formatRule 格式化规则
* @return {*} {string}
* @memberof FormatController
*/
private handleFormatRules(value: any, formatRules: string[]): string {
let matchFunc = [
// 正数
function (value: any) {
return parseFloat(value).toString() === value.toString() && parseFloat(value) > 0;
},
// 负数
function (value: any) {
return parseFloat(value).toString() === value.toString() && parseFloat(value) < 0;
},
// 0
function (value: any) {
return value === 0 || value === '
0
' || value === '
-
0
';
},
// 文本
function () {
return true;
},
];
// 是否匹配
const isMatch = function (value: any, temp1: any, temp2: any) {
if (temp1 === '
=
') {
temp1 = '
==
';
}
switch (temp1) {
case '
>
':
return parseFloat(value) > parseFloat(temp2);
case '
<
':
return parseFloat(value) < parseFloat(temp2);
case '
>=
':
return parseFloat(value) >= parseFloat(temp2);
case '
<=
':
return parseFloat(value) <= parseFloat(temp2);
case '
<>
':
return parseFloat(value) !== parseFloat(temp2);
case '
==
':
return parseFloat(value) === parseFloat(temp2);
}
};
if (formatRules.length < 4 && formatRules[0].match(/^
\
[(>|<|=|>=|<=|<>)
\
d+
\
]/)) {
// 使用了条件表达式
matchFunc = [
function (value: any) {
const temp: any = formatRules[0].match(/^
\
[(>|<|=|>=|<=|<>)(
\
d+)
\
]/);
return isMatch(value, temp[1], temp[2]) || true;
},
function (value: any) {
const temp: any = formatRules[1].match(/^
\
[(>|<|=|>=|<=|<>)(
\
d+)
\
]/);
return isMatch(value, temp[1], temp[2]) || true;
},
function () {
return true;
},
];
}
if (formatRules.length === 3) {
formatRules[3] = '
@
';
} else if (formatRules.length === 2) {
formatRules[3] = '
@
';
formatRules[2] = formatRules[0];
} else if (formatRules.length === 1) {
if (formatRules[0].includes('
@
')) {
formatRules[3] = formatRules[0];
} else {
formatRules[3] = '
@
';
}
formatRules[2] = formatRules[0];
formatRules[1] = '
-
' + formatRules[0];
}
let newFormatRule: string = '';
for (const i in matchFunc) {
if (matchFunc[i](value)) {
newFormatRule = formatRules[i];
break;
}
}
return newFormatRule;
}
/**
* @description 解析数字
* @param {number} num 值
* @param {number} placeholder 占位数
* @return {*}
* @memberof FormatController
*/
private parseNumber(num: number, placeholder: number) {
const numList = num.toString().split('
.
');
num = parseFloat('
0
.
' + numList[1]);
let nearHalf = [0, 1];
for (let fenmu = 1; fenmu < Math.pow(10, placeholder); fenmu++) {
let begin = 1;
let end = fenmu - 1;
let half = 0;
let tag: boolean = true;
while (tag) {
half = begin + parseInt(((end - begin) / 2).toString());
if (half / fenmu === num) {
begin = half;
end = half;
tag = false;
}
if (half / fenmu > num) {
end = half;
} else {
begin = half;
}
if (end - begin <= 1) {
tag = false;
}
}
if (half / fenmu === num) {
nearHalf = [half, fenmu];
tag = false;
}
if (begin / fenmu === num) {
nearHalf = [begin, fenmu];
tag = false;
}
if (end / fenmu === num) {
nearHalf = [end, fenmu];
tag = false;
}
if (placeholder === 1 || (placeholder === 2 && fenmu >= 10) || (placeholder === 3 && fenmu >= 100)) {
if (Math.abs(end / fenmu - num) < Math.abs(nearHalf[0] / nearHalf[1] - num)) {
nearHalf = [end, fenmu];
}
}
}
nearHalf[0] = parseInt(nearHalf[0].toString()) + parseFloat(numList[0]) * nearHalf[1];
return nearHalf;
}
/**
* @description Html
* @param {*} [value0, value1, value2, style]
* @return {*}
* @memberof FormatController
*/
private encodeHtml([value0, value1, value2, style]: any) {
if (value1) {
const fillValue = value1.repeat(1000);
return (
'
<
span
class
=
"vue-format-single' +
(style ? ' vue-format-single-color-' + style : '') +
'"
>
' +
(value0 ? '
<
span
>
' + value0 + '
<
/span>' : ''
)
+
(
'<span class="vue-format-single-fill">'
+
fillValue
+
'</span>'
)
+
(
value2
?
'<span>'
+
value2
+
'</span>'
:
''
)
+
'</span>'
);
}
else
{
if
(
style
)
{
return
(
'<span class="vue-format-single'
+
(
' vue-format-single-color-'
+
style
)
+
'">'
+
[
value0
,
value1
,
value2
].
join
(
''
)
+
'</span>'
);
}
else
{
return
[
value0
,
value1
,
value2
].
join
(
''
);
}
}
}
}
// 导出服务
export
const
format
:
FormatController
=
FormatController
.
getInstance
();
modules/ibizlab-generator-core/src/main/resources/templ/r7/app_{{apps}}/src/main.ts
浏览文件 @
894e2457
...
@@ -3,9 +3,10 @@ import Antd from 'ant-design-vue';
...
@@ -3,9 +3,10 @@ import Antd from 'ant-design-vue';
import
{
Interceptors
}
from
'@core'
;
import
{
Interceptors
}
from
'@core'
;
import
'font-awesome/css/font-awesome.min.css'
;
import
'font-awesome/css/font-awesome.min.css'
;
import
'ant-design-vue/dist/antd.css'
;
import
'ant-design-vue/dist/antd.css'
;
import
'@/style/index.scss'
import
'@/style/index.scss'
;
import
App
from
'./App.vue'
import
App
from
'./App.vue'
;
import
directives
from
'@/directives/directives'
;
// 挂载拦截器
// 挂载拦截器
Interceptors
.
getInstance
();
Interceptors
.
getInstance
();
createApp
(
App
).
use
(
Router
).
use
(
Antd
).
mount
(
'#app'
)
createApp
(
App
).
use
(
Router
).
use
(
Antd
).
use
(
directives
).
mount
(
'#app'
)
编辑
预览
Markdown
格式
0%
请重试
or
添加新附件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录