项目中,申请者申请某些事项以后,常常需要在申请列表中查看当前申请的记录所在的审批状态,动态美观的显示状态可以使UI更符合客户要求,比如下面这样。

以Goods__c表为例,申请者申请的一些采购以前需要得到批准,申请者列表需要显示所有的申请记录,状态(Status__c)有以下情况:

  直线经理审批;

  部门经理审批;

  总经理审批;

  审批通过。

实现上述方式主要实现思路:首先通过css画出来审批的步骤图,没有到达的灰色显示,经过或者正在步骤绿色显示,比如当前步骤为部门经理审批,则直线经理审批和部门经理审批节点为绿色,总经理审批和审批通过节点为灰色。然后通过jquery对'查看'设置onmouseenter以及onmouseleave事件,当onmouseenter时,显示状态的div,当onmouseleave时,移出状态的div。

代码如下:

1.Controller代码:初始化数据

 public without sharing class GoodsShowStatusController {

     public List<Goods__c> goodsList{get;set;}

     public GoodsShowStatusController() {
initData();
} public void initData() {
goodsList = [select Id,GoodsName__c,GoodsPrice__c,Status__c from Goods__c limit 10];
}
}

2.VF代码:显示数据并且通过jquery和css实现效果

 <apex:page controller="GoodsShowStatusController">

 <style type="text/css">
.steps {
position: relative;
margin-bottom: 30px;
counter-reset: step;
} .steps li {
list-style-type: none;
font-size: 12px;
text-align: center;
width: 15%;
position: relative;
float: left;
} .steps li:before {
display: block;
content: counter(step);
counter-increment: step;
width: 32px;
height: 32px;
background-color: #019875;
line-height: 32px;
border-radius: 32px;
font-size: 16px;
color: #fff;
text-align: center;
font-weight: 700;
margin: 0 auto 8px auto;
} .steps li ~ li:after {
content: '';
width: 100%;
height: 2px;
background-color: #019875;
position: absolute;
left: -50%;
top: 15px;
z-index: -1;
} .steps li.active:after {
background-color: green;
} .steps li.active ~ li:before,.steps li.active ~ li:after {
background-color: gray;
} .goodsStatusShow {
line-height: 18px;
position: relative;
} .goodsStatusShow div {
display: none;
position: absolute;
left: 0px;
top: 0px;
z-index: 1000;
} .goodsStatusShowDetail {
width: 800px;
border: 1px #C3A459 solid;
background-color: #FFFEED;
padding: 5px
}
</style> <apex:includeScript value="{!$Resource.JQuery2}" />
<script type="text/javascript">
$(function(){
$('.goodsStatusShow').mouseenter(function(){
$(this).find('div').slideDown("fast");
});
$('.goodsStatusShow').mouseleave(function(){
$(this).find('div').slideUp("fast");
});
});
</script>
<apex:pageBlock >
<apex:pageBlockTable value="{!goodsList}" var="goods">
<apex:column headervalue="流程图查看">
<apex:facet name="header">当前步骤测试样例</apex:facet>
<div class="goodsStatusShow">
查看
<div class="goodsStatusShowDetail">
<ul class="steps">
<li class="{!IF(goods.Status__c == '直线经理审批','active','')}">直线经理审批</li>
<li class="{!IF(goods.Status__c == '部门经理审批','active','')}">部门经理审批</li>
<li class="{!IF(goods.Status__c == '总经理审批','active','')}">总经理审批</li>
<li class="{!IF(goods.Status__c == '审批通过','active','')}">审批通过</li>
</ul>
</div>
</div>
</apex:column>
<apex:column headervalue="商品名称">
<apex:outputField value="{!goods.GoodsName__c}" />
</apex:column>
<apex:column headervalue="商品价格">
<apex:outputField value="{!goods.GoodsPrice__c}" />
</apex:column>
<apex:column headervalue="商品所处审批流程">
<apex:outputField value="{!goods.Status__c}" />
</apex:column>
</apex:pageBlockTable>
</apex:pageBlock>
</apex:page>

效果展示:

1.流程为部门经理审批的效果图显示

2.流程为总经理审批的效果图显示

总结:此篇主要在业务上描述如何实现更好的UI效果,主要用到的技术其实是css和jquery的居多,篇中显示样式在baidu上copy一些,有需要的可以在此基础上进行更改,有问题的地方欢迎指正,有问题的欢迎留言。

salesforce 零基础学习(四十六)动态美观显示列表中记录的审批状态的更多相关文章

  1. salesforce 零基础学习(十六)Validation Rules & Date/time

    上一篇介绍的内容为Formula,其中的Date/time部分未指出,此篇主要介绍Date/time部分以及Validation rules. 本篇参考PDF: Date/time:https://r ...

  2. salesforce零基础学习(九十六)Platform Event浅谈

    本篇参考:https://developer.salesforce.com/blogs/2018/07/which-streaming-event-do-i-use.html https://trai ...

  3. salesforce零基础学习(九十六)项目中的零碎知识点小总结(四)

    本篇参考: https://developer.salesforce.com/docs/atlas.en-us.216.0.apexcode.meta/apexcode/apex_classes_ke ...

  4. salesforce 零基础学习(十九)Permission sets 讲解及设置

    Permission sets以及Profile是常见的设置访问权限的方式. Profile规则为'who see what'.通过Profile可以将一类的用户设置相同的访问权限.对于有着相同Pro ...

  5. salesforce 零基础学习(十八)WorkFlow介绍及用法

    说起workflow大家肯定都不陌生,这里简单介绍一下salesforce中什么情况下使用workflow. 当你分配许多任务,定期发送电子邮件,记录修改时,可以通过自动配置workflow来完成以上 ...

  6. salesforce零基础学习(一百零五)Change Data Capture

    本篇参考: https://developer.salesforce.com/docs/atlas.en-us.232.0.api_streaming.meta/api_streaming/using ...

  7. salesforce 零基础学习(六十八)http callout test class写法

    此篇可以参考: https://developer.salesforce.com/docs/atlas.en-us.apexcode.meta/apexcode/apex_classes_restfu ...

  8. salesforce零基础学习(八十九)使用 input type=file 以及RemoteAction方式上传附件

    在classic环境中,salesforce提供了<apex:inputFile>标签用来实现附件的上传以及内容获取.salesforce 零基础学习(二十四)解析csv格式内容中有类似的 ...

  9. salesforce 零基础学习(五十二)Trigger使用篇(二)

    第十七篇的Trigger用法为通过Handler方式实现Trigger的封装,此种好处是一个Handler对应一个sObject,使本该在Trigger中写的代码分到Handler中,代码更加清晰. ...

随机推荐

  1. python调用c\c++

    前言 python 这门语言,凭借着其极高的易学易用易读性和丰富的扩展带来的学习友好性和项目友好性,近年来迅速成为了越来越多的人们的首选.然而一旦拿python与传统的编程语言(C/C++)如来比较的 ...

  2. 尽量用goto代替尾递归

    void PrintList(List L) { if(L!=Null) { PrintElement(L->Element); PrintLisr(L->Next); } } 所谓尾递归 ...

  3. Java操作属性文件之工具类

    最近空闲时间整理一下平时常用的一下工具类,重复造轮子实在是浪费时间,如果不正确或者有待改善的地方,欢迎指教... package com.hsuchan.business.utils; import ...

  4. LeetCode 412. Fizz Buzz

    Problem: Write a program that outputs the string representation of numbers from 1 to n. But for mult ...

  5. 北京电子科技学院(BESTI)实验报告4

    北京电子科技学院(BESTI)实验报告4 课程: 信息安全系统设计基础 班级:1452.1453 姓名:(按贡献大小排名)周恩德 .郑凯杰 学号:(按贡献大小排名)20145217 .201453 指 ...

  6. dedecms 采集规则过滤与替换

    过滤与替换常用操作:点击"常用规则",选择要过滤的代码段,再编辑成我们需要的.如果会文章简单采集了,接下来就需要过滤掉采集内容中的广告和链接及其它代码.一般的写法是{dede:tr ...

  7. iOS 图片文件格式判断、圆角图片

    1.圆角图片 // 设置圆形图片(放到分类中使用) - (UIImage *)cutCircleImage { UIGraphicsBeginImageContextWithOptions(self. ...

  8. HttpClient发送Get和Post请求

    package JanGin.httpClient.demo; import java.io.IOException; import java.io.UnsupportedEncodingExcept ...

  9. 【Linux】Linux统计文件夹、文件数量的命令

    # 查看当前目录下的文件数量(不包含子目录中的文件) ls -l|grep "^-"| wc -l # 查看当前目录下的文件数量(包含子目录中的文件) 注意:R,代表子目录 ls ...

  10. Python 键盘记录

    之前写的键盘记录最后一直在纠结弹框与不弹框的问题,代码找不到了,今天重新来一遍 #!/usr/bin/env python# -*-coding:utf-8 -*-from ctypes import ...