- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 primefaces p:schedule 组件来显示事件,如下所示。 p:schedule
These events can be draggable if we set property draggable="true" and with event 'eventMove'.
I have two type of events, which I can differntiate by using their 'title'
我希望 type1 事件可拖动,而 type 2 事件不可拖动。
我怎样才能实现它?因为我们提供了以这种方式成为可拖动事件的语法。
<p:schedule value="#{scheduleController.eventModel}" widgetVar="myschedule" draggable="true">
<p:ajax event="dateSelect" listener="#{scheduleController.onDateSelect}" update="eventDetails" oncomplete="eventDialog.show()" />
<p:ajax event="eventSelect" listener="#{scheduleController.onEventSelect}" update="eventDetails" oncomplete="eventDialog.show()" />
<p:ajax event="eventMove" listener="#{scheduleController.onEventMove}" update="messages" />
</p:schedule>
最佳答案
您必须深入研究 fullcalendar 插件才能实现它。检查这些问题:
FullCalendar: How to stop dragging custom events?
How do I disable drag and drop in fullcalendar
http://code.google.com/p/fullcalendar/issues/detail?id=1243
http://arshaw.com/fullcalendar/docs/event_data/Event_Object/
也许如果您可以在 JSF 服务器的响应发出之前对其进行编辑,请尝试使用过滤器。
当可拖动为 ON 时,事件具有以下一般结构:
注意主 div 的类:
<div style="position: absolute; z-index: 8; top: 83px; left: 359px; width: 133.85px; height: 166px;" class="fc-event fc-event-skin fc-event-vert fc-event-draggable fc-corner-top fc-corner-bottom ui-draggable ui-resizable">
<div class="fc-event-inner fc-event-skin">
<div class="fc-event-head fc-event-skin">
<div class="fc-event-time">19/12 8:00 - 19/12 10:00</div>
</div>
<div class="fc-event-content">
<div class="fc-event-title">Breakfast at Tiffanys</div>
</div>
<div class="fc-event-bg"></div>
</div>
<div class="ui-resizable-handle ui-resizable-s">=</div>
</div>
</div>
<!-- COMMENTED IN ORDER TO KEEP SAME CODE BLOCK -->
<!--When draggable is off, you can see the classes: -->
<div style="position: absolute; z-index: 8; top: 83px; left: 359px; width: 133.85px; height: 166px;" class="fc-event fc-event-skin fc-event-vert fc-corner-top fc-corner-bottom ui-resizable">
<div class="fc-event-inner fc-event-skin">
<div class="fc-event-head fc-event-skin">
<div class="fc-event-time">19/12 8:00 - 19/12 10:00</div>
</div>
<div class="fc-event-content">
<div class="fc-event-title">Breakfast at Tiffanys</div>
</div>
<div class="fc-event-bg"></div>
</div>
<div class="ui-resizable-handle ui-resizable-s">=</div>
</div>
</div>
然后您需要取消注册您想要的预定事件的 DOM 事件,但是...
安排每次重新渲染,并重新注册事件和类。您几乎无法控制这些项目,因为 primefaces 将数据转发到 jQuery 计划插件。
因此,您需要在每次重新渲染时将事件标记为不可拖动。
ajax 代码上的 PF 响应是一个 JavaScript 对象,其中包含插件重新呈现时间表所需的数据,因此我认为服务器端的任何内容都不会帮助您。
这是事件拖动的服务器响应:
<partial-response>
<changes>
<update id="formNotificacao:j_idt72">{"events" : [{"id": "0df04a40-3477-4564-ae2c-340509acd09e","title": "Champions League Match","start": 1355781614894,"end": 1355792414894,"allDay":false,"editable":true},{"id": "3d1e23ec-3a85-488b-aea4-00fa5f2205da","title": "Birthday Party","start": 1355748300000,"end": 1355766300000,"allDay":false,"editable":true},{"id": "35dec60d-0e7a-431d-aef4-b077616908ab","title": "Breakfast at Tiffanys","start": 1355919300000,"end": 1355926500000,"allDay":false,"editable":true},{"id": "4b6c8d2c-bcf1-444c-a92f-d5a0b60499a1","title": "Plant the new garden stuff","start": 1356022814910,"end": 1356195614910,"allDay":false,"editable":true}]}</update>
<update id="javax.faces.ViewState">-8755441948733966113:8810728330896833649</update>
</changes>
</partial-response>
我认为你必须使用一些 JavaScript 来从你想要的元素中取消注册事件。但由于它们是从服务器加载的,仅包含数据,因此您必须通过名称、日期或其他内容来识别它们。
有关如何取消注册事件的信息,请参阅此问题:jquery override event
所以路径是:
作为额外的好处,这是我测试过的源代码:
您必须将 <p:schedule>
的可拖动属性绑定(bind)到托管 bean bool 属性,然后使用控件(在下面的示例中为 selectbooleancheckbox:
<p:schedule value="#{scheduleController.eventModel}" draggable="#{scheduleController.draggable}" (...) />
注意与服务器通信的ajax标签:
<p:selectBooleanCheckbox value="#{scheduleController.draggable}">
<p:ajax update=":formNotificacao:toggleDraggableSchedule"/>
</p:selectBooleanCheckbox>
整个 JSF 代码:
<h:form id="formNotificacao">
<p:growl id="messages" showDetail="true" />
<h:panelGroup id="toggleDraggableSchedule">
<p:schedule value="#{scheduleController.eventModel}" draggable="#{scheduleController.draggable}"
widgetVar="myschedule" view="agendaWeek" allDaySlot="false"
slotMinutes="15" firstHour="7" showWeekends="FALSE"
leftHeaderTemplate="prev,next" rightHeaderTemplate=""
minTime="7am" maxTime="21pm"
timeFormat="dd/MM H:mm{ - dd/MM H:mm}" axisFormat="HH"
timeZone="#{rotulo.timeZone}">
<p:ajax event="dateSelect"
listener="#{scheduleController.onDateSelect}"
update="formNotificacao" oncomplete="eventDialog.show()" />
<p:ajax event="eventSelect"
listener="#{scheduleController.onEventSelect}"
update="formNotificacao" oncomplete="eventDialog.show()" />
<p:ajax event="eventMove"
listener="#{scheduleController.onEventMove}" update="formNotificacao" />
<p:ajax event="eventResize"
listener="#{scheduleController.onEventResize}" update="formNotificacao" />
</p:schedule>
</h:panelGroup>
<p:dialog widgetVar="eventDialog" header="Event Details"
showEffect="clip" hideEffect="clip">
<h:panelGrid id="eventDetails" columns="2">
<h:outputLabel for="title" value="Title:" />
<p:inputText id="title"
value="#{scheduleController.event.title}" required="true" />
<h:outputLabel for="from" value="From:" />
<p:calendar value="#{scheduleController.event.startDate}" pattern="MM/dd/yyyy HH:mm" stepMinute="15" />
<h:outputLabel for="to" value="To:" />
<p:calendar value="#{scheduleController.event.endDate}" pattern="MM/dd/yyyy HH:mm" stepMinute="15" />
<h:outputLabel for="allDay" value="All Day:" />
<h:selectBooleanCheckbox id="allDay"
value="#{scheduleController.event.allDay}" />
<p:commandButton type="reset" value="Reset" />
<p:commandButton value="Save"
actionListener="#{scheduleController.addEvent}"
oncomplete="myschedule.update();eventDialog.hide();" />
</h:panelGrid>
</p:dialog>
<p:selectBooleanCheckbox value="#{scheduleController.draggable}">
<p:ajax update=":formNotificacao:toggleDraggableSchedule"/>
</p:selectBooleanCheckbox>
</h:form>
托管 bean:
import java.text.DateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.TimeZone;
import javax.faces.application.FacesMessage;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ViewScoped;
import javax.faces.context.FacesContext;
import javax.faces.event.ActionEvent;
import org.primefaces.event.DateSelectEvent;
import org.primefaces.event.ScheduleEntryMoveEvent;
import org.primefaces.event.ScheduleEntryResizeEvent;
import org.primefaces.event.ScheduleEntrySelectEvent;
import org.primefaces.model.DefaultScheduleEvent;
import org.primefaces.model.DefaultScheduleModel;
import org.primefaces.model.ScheduleEvent;
import org.primefaces.model.ScheduleModel;
@ManagedBean
@ViewScoped
public class ScheduleController {
private ScheduleModel eventModel;
private ScheduleEvent event = new DefaultScheduleEvent();
private List<ScheduleEvent> eventos;
private String theme;
private boolean draggable;
public ScheduleController() {
eventModel = new DefaultScheduleModel();
eventModel.addEvent(new DefaultScheduleEvent("Champions League Match",
previousDay8Pm(), previousDay11Pm()));
eventModel.addEvent(new DefaultScheduleEvent("Birthday Party",
today1Pm(), today6Pm()));
eventModel.addEvent(new DefaultScheduleEvent("Breakfast at Tiffanys",
nextDay9Am(), nextDay11Am()));
eventModel.addEvent(new DefaultScheduleEvent(
"Plant the new garden stuff", theDayAfter3Pm(),
fourDaysLater3pm()));
setEventos(eventModel.getEvents());
}
private Date fourDaysLater3pm() {
return getDate(4, 15);
}
private Date theDayAfter3Pm() {
return getDate(2, 15);
}
private Date nextDay11Am() {
return getDate(1, 11);
}
private Date nextDay9Am() {
return getDate(+1, 9);
}
private Date today6Pm() {
return getDate(0, 18);
}
private Date today1Pm() {
return getDate(0, 13);
}
private Date previousDay11Pm() {
return getDate(-1, 23);
}
private Date previousDay8Pm() {
return getDate(-1, 20);
}
private Date getDate(int deltaDay, int hour) {
Calendar cal = Calendar.getInstance();
cal.setTime(new Date());
cal.set(Calendar.HOUR_OF_DAY, hour);
cal.set(Calendar.DAY_OF_MONTH, cal.get(Calendar.DAY_OF_MONTH)
+ deltaDay);
return cal.getTime();
}
public void addEvent(ActionEvent actionEvent) {
if (event.getId() == null)
eventModel.addEvent(event);
else
eventModel.updateEvent(event);
event = new DefaultScheduleEvent();
}
public void onEventSelect(ScheduleEntrySelectEvent selectEvent) {
event = selectEvent.getScheduleEvent();
}
public void onDateSelect(DateSelectEvent selectEvent) {
event = new DefaultScheduleEvent(Math.random() + "",
selectEvent.getDate(), selectEvent.getDate());
}
public void onEventMove(ScheduleEntryMoveEvent event) {
snapToFifteen((DefaultScheduleEvent) event.getScheduleEvent());
FacesMessage message = new FacesMessage(FacesMessage.SEVERITY_INFO,
"Event moved", "Day delta:" + event.getDayDelta()
+ ", Minute delta:" + event.getMinuteDelta());
addMessage(message);
}
public void onEventResize(ScheduleEntryResizeEvent event) {
snapToFifteen((DefaultScheduleEvent) event.getScheduleEvent());
FacesMessage message = new FacesMessage(FacesMessage.SEVERITY_INFO,
"Event resized", "Day delta:" + event.getDayDelta()
+ ", Minute delta:" + event.getMinuteDelta());
addMessage(message);
}
private void snapToFifteen(DefaultScheduleEvent ev) {
DateFormat sdf = DateFormat.getDateTimeInstance(DateFormat.FULL,
DateFormat.FULL);
sdf.setTimeZone(TimeZone.getTimeZone("GMT-3"));
System.out.println("CALLING SNAP ON event: Start = "
+ sdf.format(ev.getStartDate()) + " End = "
+ sdf.format(ev.getEndDate()));
Date inicio = fifteenize(ev.getStartDate());
Date fim = fifteenize(ev.getEndDate());
ev.setStartDate(inicio);
ev.setEndDate(fim);
System.out.println("Snapped: Start = " + sdf.format(ev.getStartDate())
+ " End = " + sdf.format(ev.getEndDate()));
}
private Date fifteenize(Date data) {
Calendar cal = Calendar.getInstance();
cal.setTime(data);
int minutos = cal.get(Calendar.MINUTE);
int modQuinze = (minutos + 7) / 15;
cal.set(Calendar.MINUTE, modQuinze * 15);
cal.set(Calendar.HOUR, cal.get(Calendar.HOUR));
cal.set(Calendar.SECOND, 0);
cal.set(Calendar.MILLISECOND, 0);
return cal.getTime();
}
private void addMessage(FacesMessage message) {
FacesContext.getCurrentInstance().addMessage(null, message);
}
public ScheduleModel getEventModel() {
return eventModel;
}
public void setEventModel(ScheduleModel eventModel) {
this.eventModel = eventModel;
}
public ScheduleEvent getEvent() {
return event;
}
public void setEvent(ScheduleEvent event) {
this.event = event;
}
public String getTheme() {
return theme;
}
public void setTheme(String theme) {
this.theme = theme;
}
public void setEventos(List<ScheduleEvent> eventos) {
this.eventos = eventos;
}
public List<ScheduleEvent> getEventos() {
return eventos;
}
public void setDraggable(boolean draggable) {
this.draggable = draggable;
}
public boolean isDraggable() {
return draggable;
}
}
如果您仔细观察托管 bean,它与 primefaces 展示示例相比还有一些其他变化,例如,所有事件都以 15 分钟为间隔,以及其他内容。
关于jquery - 使 Primefaces 计划事件在某些条件下可拖动和不可拖动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13873386/
我的程序有问题。 我有一个比较两个字符串的条件: (if (eq? (exp1) (exp2))) 当 exp1 给我一个字符串,exp2 给我一个字符串。可以肯定的是,当我更改“eq?”时到“=”,
我们有多种主要使用 GWT 开发的产品,目前由我们的最终客户使用。 想知道 GWT 的路线图。我得到了一些非官方的更新,谷歌正在将 GWT 中开发的产品转移到其他一些新技术。这是真的吗? GWT 的长
我希望每 15 分钟定期构建一次。我在网上看过,我正在使用这个时间表:*/15 * * * * Jenkins 告诉我使用 H/15 * * * * 来平均分配负载而不是 */15 * * * * 有
所以我正试图在 Scheme 中找出整个 call/cc 的东西。下面是我正在使用的代码: (+ 1 (call/cc (lambda (k) (if (number? k)
所以我正试图在 Scheme 中找出整个 call/cc 的东西。下面是我正在使用的代码: (+ 1 (call/cc (lambda (k) (if (number? k)
我们有一个 Azure WebJob,计划在 UTC 每天上午 8:00 运行(CRON - 0 00 08 * * *)。大多数时候它都会正确触发,但有时会触发两次(第二次运行)第一次运行后约 10
我是 Terraform 的新手。我正在尝试通过 azure 管道创建一个简单的存储帐户,但是当我运行我的管道时,我收到错误“太多命令行参数”。我很震惊,我不知道自己做错了什么。有人可以帮忙吗。 这是
我想在某些逻辑中间停止芭蕾舞 Actor 程序。如何使用代码停止 ballerina 中正在运行的程序?我正在寻找相当于 java 中的 System.exit(0) 的东西。 最佳答案 我相信您正在
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 8年前关闭。 Improve this qu
我们有一个 Azure WebJob,计划在 UTC 每天上午 8:00 运行(CRON - 0 00 08 * * *)。大多数时候它都会正确触发,但有时会触发两次(第二次运行)第一次运行后约 10
我是 Terraform 的新手。我正在尝试通过 azure 管道创建一个简单的存储帐户,但是当我运行我的管道时,我收到错误“太多命令行参数”。我很震惊,我不知道自己做错了什么。有人可以帮忙吗。 这是
我正在浏览 htdp 并在一开始的某个地方发现了这个:- Explain why the following sentences are illegal definitions: 1. (define
我正在使用 Laravel 开发成员(member)门户。 成员(member)资格有不同的类别,例如1) 单人2) 成人3) 家庭以及不同价格的所有类型。 我有一个 plans 表和 plans_s
我使用 DreamHost 作为我的网站的服务器,并且我尝试每天、每周和每月执行某个 MySQL 查询来更改我的网站的数据库。我开始在本地主机上使用事件调度程序,然后我发现我无法在 DreamHost
这周我的 crontab 作业发生了一个问题。 设置如下,每两周正常运行一次,直到现在。 10 06 * * 1 test $(($(date +\%W)\%2)) -eq 0 && echo 'te
编写了一个简单的脚本,它将在日志文件中写入日期时间戳,并且每次运行该脚本时,它都会附加到该日志文件中。 #!/bin/sh echo $(date) >> log.txt 当我尝试每 1 分钟安排一次
我对 PIPE 的了解是它用于单向通信,它有助于在两个相关进程之间进行通信。我从一本书中得到了下面的 PIPE 编程代码示例。我正在尝试使用 printf 理解代码并在代码的每一行之后打印出所有点。但
代码如下: (define make-simple-sv-num (lambda (delare) (let ((tal (random-from-to 100000 1000000)))
我目前正在使用“How To Design Programs”——使用 Scheme/Racket;我在 Scheme 的 R5RS 版本中遇到了一个非常奇特的功能。 在进行简单的减法时,尽管使用的是
我想确定时间表的详细信息。例如: 我有一个事件的时间表:event.schedule "Every 3 months on the 10th day of the month" 由哈希表示: {
我是一名优秀的程序员,十分优秀!