diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/website_event/views/event_templates_page_registration.xml | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/website_event/views/event_templates_page_registration.xml')
| -rw-r--r-- | addons/website_event/views/event_templates_page_registration.xml | 393 |
1 files changed, 393 insertions, 0 deletions
diff --git a/addons/website_event/views/event_templates_page_registration.xml b/addons/website_event/views/event_templates_page_registration.xml new file mode 100644 index 00000000..410dab04 --- /dev/null +++ b/addons/website_event/views/event_templates_page_registration.xml @@ -0,0 +1,393 @@ +<?xml version="1.0" encoding="utf-8"?> +<odoo> + + +<template id="event_details" name="Event Header"> + <t t-call="website_event.layout"> + <div name="event" itemscope="itemscope" itemtype="http://schema.org/Event"> + <t t-call="website.record_cover"> + <t t-set="_record" t-value="event"/> + <t t-set="use_filters" t-value="True"/> + <t t-set="use_size" t-value="True"/> + <t t-set="use_text_align" t-value="True"/> + + <div class="container d-flex flex-column flex-grow-1 justify-content-around"> + <div class="o_wevent_event_title"> + <span t-if="event.is_participating" class="badge badge-success o_wevent_badge"><i class="fa fa-check mr-2"/>Registered</span> + <h1 t-field="event.name" class="o_wevent_event_name" itemprop="name" placeholder="Event Title"/> + <h2 t-field="event.subtitle" class="o_wevent_event_subtitle" placeholder="Event Subtitle"/> + </div> + </div> + <div class="container"> + <t t-call="website_event.registration_template"/> + </div> + </t> + <t t-raw="0"/> + </div> + </t> +</template> + +<!-- Event - Description --> +<template id="event_description_full" name="Event Description" track="1"> + <t t-call="website_event.event_details"> + <section class="bg-200 mt-n5"> + <div class="container overflow-hidden"> + <div class="row no-gutters mt-n4 mb-3"> + <!-- Description --> + <div id="o_wevent_event_main_col" class="col-lg-8 bg-white px-3 pt-5 pb-0 shadow-sm"> + <span t-field="event.description" itemprop="description"/> + </div> + <div class="col-lg-4 bg-light shadow-sm d-print-none"> + <!-- Date & Time --> + <div class="o_wevent_sidebar_block"> + <h6 class="o_wevent_sidebar_title">Date & Time</h6> + <div class="d-flex"> + <h5 t-field="event.with_context(tz=event.date_tz).date_begin" class="my-1 mr-1" t-options="{'date_only': 'true', 'format': 'EEEE'}"/> + <h5 class="my-1" t-field="event.with_context(tz=event.date_tz).date_begin" t-options="{'date_only': 'true', 'format': 'long'}" itemprop="startDate" t-att-datetime="event.date_begin"/> + </div> + <t t-if="not event.is_one_day">Start -</t> + <span t-field="event.with_context(tz=event.date_tz).date_begin" t-options="{'time_only': 'true', 'format': 'short'}"/> + <t t-if="event.is_one_day"> + <i class="fa fa-long-arrow-right mx-1"/> + <span t-field="event.with_context(tz=event.date_tz).date_end" t-options="{'time_only': 'true', 'format': 'short'}"/> + </t> + <t t-else=""> + <i class="fa fa-long-arrow-down d-block text-muted mx-3 my-2" style="font-size: 1.5rem"/> + <div class="d-flex"> + <h5 t-field="event.with_context(tz=event.date_tz).date_end" class="my-1 mr-1" t-options="{'date_only': 'true', 'format': 'EEEE'}"/> + <h5 class="my-1" t-field="event.with_context(tz=event.date_tz).date_end" t-options="{'date_only': 'true', 'format': 'long'}"/> + </div> + <t t-if="not event.is_one_day">End -</t> + <span t-field="event.with_context(tz=event.date_tz).date_end" t-options="{'time_only': 'true', 'format': 'short'}"/> + </t> + <!-- Timezone --> + <small t-esc="event.date_tz" class="d-block my-3 text-muted"/> + + <div class="dropdown"> + <i class="fa fa-calendar mr-1"/> + <a href="#" role="button" data-toggle="dropdown">Add to Calendar</a> + <div class="dropdown-menu"> + <a t-att-href="iCal_url" class="dropdown-item">iCal/Outlook</a> + <a t-att-href="google_url" class="dropdown-item" target="_blank">Google</a> + </div> + </div> + </div> + <!-- Location --> + <div t-if="event.address_id" class="o_wevent_sidebar_block"> + <h6 class="o_wevent_sidebar_title">Location</h6> + <h4 t-field="event.address_id" class="" t-options='{ + "widget": "contact", + "fields": ["name"] + }'/> + <div itemprop="location" class="mb-2" t-field="event.address_id" t-options='{ + "widget": "contact", + "fields": ["address"], + "no_marker": True + }'/> + <div class="mb-3" t-field="event.address_id" t-options='{ + "widget": "contact", + "fields": ["phone", "mobile", "email"] + }'/> + <i class="fa fa-map-marker fa-fw" role="img"/> + <a t-att-href="event._google_map_link()" target="_blank">Get the direction</a> + </div> + <!-- Organizer --> + <div t-if="event.organizer_id" class="o_wevent_sidebar_block"> + <h6 class="o_wevent_sidebar_title">Organizer</h6> + <h4 t-field="event.organizer_id"/> + <div itemprop="location" t-field="event.organizer_id" t-options="{'widget': 'contact', 'fields': ['phone', 'mobile', 'email']}"/> + </div> + <!-- Social --> + <div class="o_wevent_sidebar_block"> + <h6 class="o_wevent_sidebar_title">SHARE</h6> + <p class="mb-2">Find out what people see and say about this event, and join the conversation.</p> + <t t-snippet-call="website.s_share"> + <t t-set="_no_title" t-value="True"/> + <t t-set="_classes" t-valuef="o_wevent_sidebar_social mx-n1"/> + <t t-set="_link_classes" t-valuef="o_wevent_social_link"/> + </t> + </div> + </div> + </div> + </div> + </section> + </t> +</template> + +<!-- Event - Registration --> +<template id="registration_template" name="Registration"> + <div t-if="request.env.user.has_group('event.group_event_manager')" class="alert alert-info rounded-0 o_website_event_configuration o_not_editable" role="status"> + <a t-attf-href="/web#id=#{event.id}&view_type=form&model=event.event"> + <i class="fa fa-pencil mr-2" role="img" aria-label="Edit" title="Edit event registration in backend"/><em>Configure Event Tickets</em> + </a> + </div> + <div t-if="toast_message" class="o_wevent_register_toaster d-none" t-att-data-message="toast_message"/> + <div t-if="not event.event_registrations_open" class="bg-white mb-5"> + <div class="alert alert-info mb-0 d-flex justify-content-between align-items-center" role="status"> + <t t-if="event.start_sale_date and event.start_sale_date > datetime.date.today()"> + <em class="col-md-8">Ticket Sales starting on <t t-esc="event.start_sale_date"/></em> + <button class="btn btn-danger mr-1 ml-3 col-md-4" disabled="1">Registrations not yet open</button> + </t> + <t t-else=""> + <div class="col-md-8"> + <em t-if="event.event_registrations_sold_out">Tickets for this Event are <b>Sold Out</b></em> + <em t-else="">Registrations are <b>closed</b></em> + </div> + <button class="btn btn-danger ml-3 col-md-4 py-2" disabled="1"> + <span t-if="event.event_registrations_sold_out">Sold Out</span> + <span t-else="">Registrations Closed</span> + </button> + </t> + </div> + </div> + <form t-if="event.event_registrations_open and (not event.event_ticket_ids or any(not ticket.is_expired for ticket in event.event_ticket_ids))" + id="registration_form" + class="mb-5" + t-attf-action="/event/#{slug(event)}/registration/new" method="post" + itemscope="itemscope" itemprop="offers" itemtype="http://schema.org/AggregateOffer"> + <input type="hidden" name="csrf_token" t-att-value="request.csrf_token()"/> + <div id="o_wevent_tickets" class="bg-white shadow-sm o_wevent_js_ticket_details" data-folded-by-default="0"> + <t t-set="tickets" t-value="event.event_ticket_ids.filtered(lambda ticket: not ticket.is_expired)"/> + <!-- If some tickets expired and there is only one type left, we keep the same layout --> + <t t-if="len(event.event_ticket_ids) > 1"> + <div class="d-flex justify-content-between align-items-center py-2 pl-3 pr-2 border-bottom"> + <div id="price-range" class="pr-3 d-none"/> + <span t-if="not event.event_registrations_open" class="text-danger"> + <i class="fa fa-ban mr-2"/>Sold Out + </span> + <div t-if="event.is_participating" id="registered" class="ml-auto pr-3 d-none"> + <span class="o_wevent_badge badge badge-success ml-3"> + <i class="fa fa-check mr-2"/>Registered + </span> + </div> + <a href="#" role="button" class="btn o_wevent_registration_btn text-left" data-target="#o_wevent_tickets_collapse"> + <span class="py-2">Tickets</span> + <span class="close d-none">×</span> + </a> + </div> + <div id="o_wevent_tickets_collapse" class="collapse show"> + <div t-foreach="tickets" t-as="ticket" class="row px-3 py-3 mx-0 bg-light border-bottom"> + <div class="col-md-8 col-xs-12 p-0" itemscope="itemscope" itemtype="http://schema.org/Offer"> + <h5 itemprop="name" t-field="ticket.name" class="my-0"/> + <t t-if="ticket.description"> + <small t-field="ticket.description" class="text-muted py-2"/> + <br/> + </t> + <small t-if="ticket.end_sale_date and ticket.sale_available and not ticket.is_expired" class="text-muted mr-3" itemprop="availabilityEnds">Sales end on <span itemprop="priceValidUntil" t-field="ticket.end_sale_date"/></small> + <small t-if="ticket.start_sale_date and not ticket.sale_available and not ticket.is_expired" class="text-muted mr-3" itemprop="availabilityEnds">Sales start on <span itemprop="priceValidUntil" t-field="ticket.start_sale_date"/></small> + </div> + <div class="col-md-4 col-xs-12 p-0 d-flex align-items-center justify-content-between"> + <div class="o_wevent_registration_multi_select"/> + <div class="w-auto ml-auto"> + <select t-if="not ticket.is_expired and ticket.sale_available" + t-attf-name="nb_register-#{ticket.id}" + class="custom-select"> + <t t-set="seats_max_ticket" t-value="(not ticket.seats_limited or ticket.seats_available > 9) and 10 or ticket.seats_available + 1"/> + <t t-set="seats_max_event" t-value="(not event.seats_limited or event.seats_available > 9) and 10 or event.seats_available + 1"/> + <t t-set="seats_max" t-value="min(seats_max_ticket, seats_max_event)"/> + <t t-foreach="range(0, seats_max)" t-as="nb"> + <option t-esc="nb" t-att-selected="len(ticket) == 0 and nb == 0 and 'selected'"/> + </t> + </select> + <div t-else="" class="text-danger"> + <span t-if="not ticket.sale_available and not ticket.is_expired and ticket.is_launched()" >Sold Out</span> + <span t-if="ticket.is_expired">Expired</span> + </div> + </div> + </div> + </div> + <div class="row no-gutters"> + <div class="col-md-4 offset-md-8 py-2 pl-md-0 pr-md-2"> + <button type="submit" class="btn btn-primary o_wait_lazy_js btn-block a-submit" disabled="" t-attf-id="#{event.id}"> + Register + <t t-if="event.seats_limited and event.seats_max and event.seats_available <= (event.seats_max * 0.2)"> + (only <t t-esc="event.seats_available"/> available) + </t> + </button> + </div> + </div> + </div> + </t> + <div t-else="" class="o_wevent_registration_single"> + <div class="row p-2 pl-3"> + <div class="col-lg-8 d-flex flex-columns align-items-center" itemscope="itemscope" itemtype="http://schema.org/Offer"> + <h6 itemprop="name" class="my-0 pr-3 border-right text-dark"> + <span t-if="tickets" t-field="tickets.name"/> + <span t-else="">Registration</span> + </h6> + <small t-if="tickets.end_sale_date and tickets.sale_available and not tickets.is_expired" class="text-muted mr-3" itemprop="availabilityEnds">Sales end on <span itemprop="priceValidUntil" t-field="tickets.end_sale_date"/></small> + <div class="ml-auto o_wevent_nowrap"> + <t t-if="event.event_registrations_open"> + <span class="text-dark font-weight-bold align-middle pr-2">Qty</span> + <link itemprop="availability" content="http://schema.org/InStock"/> + <select t-att-name="'nb_register-%s' % (tickets.id if tickets else 0)" class="w-auto custom-select"> + <t t-set="seats_max_ticket" t-value="(not tickets or not tickets.seats_limited or tickets.seats_available > 9) and 10 or tickets.seats_available + 1"/> + <t t-set="seats_max_event" t-value="(not event.seats_limited or event.seats_available > 9) and 10 or event.seats_available + 1"/> + <t t-set="seats_max" t-value="min(seats_max_ticket, seats_max_event) if tickets else seats_max_event"/> + <t t-foreach="range(0, seats_max)" t-as="nb"> + <option t-esc="nb" t-att-selected="nb == 1 and 'selected'"/> + </t> + </select> + </t> + <t t-else=""> + <span itemprop="availability" content="http://schema.org/SoldOut" class="text-danger"> + <i class="fa fa-ban mr-2"/>Sold Out + </span> + </t> + </div> + </div> + <div class="col-lg-4 pt-3 pt-lg-0 pl-2 pl-lg-0"> + <button type="submit" class="btn btn-primary o_wait_lazy_js btn-block a-submit" t-attf-id="#{event.id}"> + Register + <t t-if="event.seats_limited and event.seats_max and event.seats_available <= (event.seats_max * 0.2)"> + (only <t t-esc="event.seats_available"/> available) + </t> + </button> + </div> + </div> + </div> + </div> + </form> +</template> + +<template id="registration_attendee_details" name="Registration Attendee Details"> + <div id="modal_attendees_registration" class="modal fade" tabindex="-1" role="dialog"> + <div class="modal-dialog modal-lg" role="document"> + <form id="attendee_registration" t-attf-action="/event/#{slug(event)}/registration/confirm" method="post" class="js_website_submit_form"> + <input type="hidden" name="csrf_token" t-att-value="request.csrf_token()"/> + <div class="modal-content"> + <div class="modal-header align-items-center"> + <h4 class="modal-title">Attendees</h4> + <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span>×</span></button> + </div> + <t t-set="counter_type" t-value="1"/> + <t t-set="counter" t-value="0"/> + <t t-foreach="tickets" t-as="ticket" t-if="availability_check"> + <t t-foreach="range(1, ticket['quantity'] + 1)" t-as="att_counter" name="attendee_loop"> + <t t-set="counter" t-value="counter + 1"/> + <div class="modal-body bg-light border-bottom"> + <h5 class="mt-1 pb-2 border-bottom">Ticket #<span t-esc="counter"/> <small class="text-muted">- <span t-esc="ticket['name']"/></small></h5> + <div class="row"> + <div class="col-lg my-2"> + <label>Name</label> + <input class="form-control" type="text" t-attf-name="#{counter}-name" required="This field is required"/> + </div> + <div class="col-lg my-2"> + <label>Email</label> + <input class="form-control" type="email" t-attf-name="#{counter}-email" required="This field is required"/> + </div> + <div class="col-lg my-2"> + <label>Phone <small>(Optional)</small></label> + <input class="form-control" type="tel" t-attf-name="#{counter}-phone"/> + </div> + <input class="d-none" type="text" t-attf-name="#{counter}-event_ticket_id" t-attf-value="#{ticket['id']}"/> + </div> + </div> + </t> + <t t-set="counter_type" t-value="counter_type + 1"/> + </t> + <t t-if="not availability_check"> + <div class="modal-body bg-light border-bottom"> + <strong> You ordered more tickets than available seats</strong> + </div> + </t> + <div class="modal-footer border-0 justify-content-between"> + <button type="button" class="btn btn-secondary js_goto_event" data-dismiss="modal">Cancel</button> + <button type="submit" class="btn btn-primary" t-if="availability_check">Continue</button> + </div> + </div> + </form> + </div> + </div> +</template> + +<template id="registration_complete" name="Registration Completed"> + <t t-call="website_event.layout"> + <div class="container my-5 o_wereg_confirmed"> + <div class="row mb-3"> + <div class="col-12"> + <h3>Registration confirmed!</h3> + <span class="h4 text-muted" t-esc="event.name"/> + </div> + </div> + <div class="row mb-3 o_wereg_confirmed_attendees"> + <div class="col-md-4 col-xs-12 mt-3" t-foreach="attendees" t-as="attendee"> + <div class="d-flex flex-column"> + <span class="font-weight-bold"> + <t t-if="attendee.name" t-esc="attendee.name"/> + <t t-else="">N/A</t> + </span> + <span> + <i class="fa fa-envelope mr-2 "></i> + <t t-if="attendee.email" t-esc="attendee.email"/> + <t t-else="">N/A</t> + </span> + <span> + <i class="fa fa-phone mr-2"></i> + <t t-if="attendee.phone" t-esc="attendee.phone"/> + <t t-else="">N/A</t> + </span> + <span> + <i class="fa fa-ticket mr-2"></i> + <t t-if="attendee.event_ticket_id" t-esc="attendee.event_ticket_id.name"/> + <t t-else="">N/A</t> + (ref: <t t-esc="attendee.id"/>) + </span> + </div> + </div> + </div> + <div class="row mb-3"> + <div class="col"> + <p><b>Start</b> <span itemprop="startDate" t-esc="event.date_begin_located"/><br/> <b>End</b> <span itemprop="endDate" t-esc="event.date_end_located"/></p> + <div class="mt-4"> + <h5 t-field="event.address_id" class="text-secondary font-weight-bold" t-options='{ + "widget": "contact", + "fields": ["name"] + }'/> + <a itemprop="location" t-att-href="event.google_map_link()" target="_BLANK" temprop="location" t-field="event.address_id" t-options='{ + "widget": "contact", + "fields": ["address"] + }'/> + <div itemprop="location" t-field="event.address_id" t-options='{ + "widget": "contact", + "fields": ["phone", "mobile", "email"] + }'/> + </div> + <div id="add_to_calendar" class="mt-4 d-flex flex-column flex-md-row"> + <a role="button" class="btn btn-primary" t-att-href="iCal_url"> + <i class="fa fa-fw fa-calendar"/> Add to iCal/Outlook + </a> + <a role="button" class="btn btn-primary ml-md-2 mt-2 mt-md-0" t-att-href="google_url" target='_blank'> + <i class="fa fa-fw fa-calendar"/> Add to Google Calendar + </a> + </div> + </div> + </div> + </div> + </t> +</template> + +<!-- Edit Options --> +<template id="fold_register_details" inherit_id="website_event.registration_template" active="False" customize_show="True" name="Fold ticket details"> + <xpath expr="//div[@id='o_wevent_tickets']" position="attributes"> + <attribute name="data-folded-by-default">1</attribute> + </xpath> + <xpath expr="//div[@id='registered']" position="attributes"> + <attribute name="class">ml-auto pr-3</attribute> + </xpath> + <xpath expr="//div[@id='price-range']" position="attributes"> + <attribute name="class">ml-0 pr-3</attribute> + </xpath> + <xpath expr="//div[@id='o_wevent_tickets_collapse']" position="attributes"> + <attribute name="class">collapse</attribute> + </xpath> + <xpath expr="//a[hasclass('o_wevent_registration_btn')]" position="attributes"> + <attribute name="class">btn btn-primary o_wevent_registration_btn collapsed</attribute> + <attribute name="data-toggle">collapse</attribute> + </xpath> + <xpath expr="//span[hasclass('close')]" position="attributes"> + <attribute name="class">close d-none</attribute> + </xpath> +</template> + +</odoo> |
