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_track_quiz/views/event_leaderboard_templates.xml | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/website_event_track_quiz/views/event_leaderboard_templates.xml')
| -rw-r--r-- | addons/website_event_track_quiz/views/event_leaderboard_templates.xml | 135 |
1 files changed, 135 insertions, 0 deletions
diff --git a/addons/website_event_track_quiz/views/event_leaderboard_templates.xml b/addons/website_event_track_quiz/views/event_leaderboard_templates.xml new file mode 100644 index 00000000..8a2e4eb6 --- /dev/null +++ b/addons/website_event_track_quiz/views/event_leaderboard_templates.xml @@ -0,0 +1,135 @@ +<?xml version="1.0" encoding="UTF-8"?> +<odoo> + +<template id="event_leaderboard" name="Leaderboard"> + <t t-call="website_event.layout"> + <div t-if="visitors" class="bg-light pt32 pb32 o_wevent_quiz_leaderboard"> + <t t-call="website_event_track_quiz.leaderboard_search_bar"/> + <div class="container mt32"> + <div t-if="not search" class="row mb-3"> + <div class="col-md-4 d-flex flex-grow-1" t-foreach="top3_visitors" t-as="visitor"> + <t t-call="website_event_track_quiz.top3_visitor_card"></t> + </div> + </div> + <table class="table table-sm"> + <tr t-foreach="visitors" t-as="visitor" + t-attf-class="#{'alert-info' if visitor['visitor'] == current_visitor else 'bg-white'} #{'o_wevent_quiz_scroll_to' if scroll_to_position and visitor['visitor'] == current_visitor else ''}"> + <t t-call="website_event_track_quiz.all_visitor_card"/> + </tr> + </table> + <div class="form-inline justify-content-center"> + <t t-call="website_event_track_quiz.pager_nobox"/> + </div> + </div> + </div> + <div t-if="not visitors and search" class="container mt32"> + <t t-call="website_event_track_quiz.leaderboard_search_bar"/> + <div class='alert alert-warning mt32'>No user found for <strong><t t-esc="search"/></strong>. Try another search.</div> + </div> + <div t-if="not visitors and not search" class="vh-100 bg-light d-flex justify-content-center align-items-center"> + <h4 class="text-muted font-weight-bold">There is currently no leaderboard available</h4> + </div> + </t> +</template> + +<template id="pager_nobox" name="Pager (not box display)"> + <ul t-if="pager['page_count'] > 1" t-attf-class="o_wprofile_pager font-weight-bold pagination m-0"> + <li t-attf-class="page-item o_wprofile_pager_arrow #{'disabled' if pager['page']['num'] == 1 else ''}"> + <a t-att-href=" pager['page_first']['url'] if pager['page']['num'] != 1 else None" class="page-link"><i class="fa fa-step-backward"/></a> + </li> + <li t-attf-class="page-item o_wprofile_pager_arrow #{'disabled' if pager['page']['num'] == 1 else ''}"> + <a t-att-href=" pager['page_previous']['url'] if pager['page']['num'] != 1 else None" class="page-link"><i class="fa fa-caret-left"/></a> + </li> + <t t-foreach="pager['pages']" t-as="page"> + <li t-attf-class="page-item #{'active disabled bg-primary rounded-circle' if page['num'] == pager['page']['num'] else ''}"> <a t-att-href="page['url']" class="page-link" t-raw="page['num']"></a></li> + </t> + <li t-attf-class="page-item o_wprofile_pager_arrow #{'disabled' if pager['page']['num'] == pager['page_count'] else ''}"> + <a t-att-href="pager['page_next']['url'] if pager['page']['num'] != pager['page_count'] else None" class="page-link"><i class="fa fa-caret-right"/></a> + </li> + <li t-attf-class="page-item o_wprofile_pager_arrow #{'disabled' if pager['page']['num'] == pager['page_count'] else ''}"> + <a t-att-href=" pager['page_last']['url'] if pager['page']['num'] != pager['page_count'] else None" class="page-link"><i class="fa fa-step-forward"/></a> + </li> + </ul> +</template> + +<template id="top3_visitor_card" name="Top 3 Visitor Card"> + <div class="card w-100 text-center mb-2 border-bottom-0"> + <div class="card-body"> + <div class="d-inline-block position-relative"> + <img class="rounded-circle img-fluid" + style="width: 128px; height: 128px; object-fit: cover;" + t-att-src="image_data_uri(visitor['visitor'].partner_image) if visitor['visitor'].partner_image else '/web/static/src/img/user_placeholder.jpg'"/> + <img class="position-absolute" t-attf-src="/website_profile/static/src/img/rank_#{visitor['position']}.svg" alt="User rank" style="bottom: 0; right: -10px"/> + </div> + <h3 t-if="visitor['visitor'] == current_visitor and not visitor['visitor'].name" class="mt-2 mb-0">You</h3> + <h3 t-else="" class="mt-2 mb-0" t-esc="visitor['visitor'].display_name"/> + </div> + <div class="row mx-0 o_wprofile_top3_card_footer text-nowrap"> + <div class="col py-3"><b t-esc="visitor['points']"/> <span class="text-muted">Points</span></div> + </div> + </div> +</template> + +<template id="all_visitor_card" name="All VIsitor Card"> + <td class="align-middle text-right text-muted" style="width: 0"> + <span t-esc="visitor['position']"/> + </td> + <td class="align-middle d-none d-sm-table-cell"> + <img class="o_object_fit_cover rounded-circle o_wprofile_img_small" + width="30" + height="30" + t-att-src="image_data_uri(visitor['visitor'].partner_image) if visitor['visitor'].partner_image else '/web/static/src/img/user_placeholder.jpg'"/> + </td> + <td class="align-middle w-md-75"> + <span t-if="visitor['visitor'] == current_visitor and not visitor['visitor'].name" class="font-weight-bold">You</span> + <span t-else="" class="font-weight-bold" t-esc="visitor['visitor'].display_name"/><br/> + </td> + <td class="align-middle font-weight-bold text-right text-nowrap"> + <b t-esc="visitor['points']"/> <span class="text-muted small font-weight-bold">Points</span> + </td> +</template> + +<!-- Sub nav --> +<template id="leaderboard_search_bar" name="Leaderboard search bar"> + <div class="container"> + <div class="row align-items-center justify-content-between"> + <!-- Desktop Mode --> + <div class="col d-none d-md-flex flex-row align-items-center justify-content-end"> + <!-- search --> + <form t-attf-action="#{'/event/%s/community/leaderboard/results' % (slug(event))}" role="search" method="get"> + <div class="input-group ml-1 position-relative"> + <span class="input-group-prepend"> + <button class="btn btn-link text-white rounded-0 pr-1" type="submit" aria-label="Search" title="Search"> + <i class="fa fa-search"></i> + </button> + </span> + <input type="text" class="form-control rounded-0" name="search" placeholder="Search Attendees" t-att-value="searched_name or ''"/> + </div> + </form> + </div> + + <!-- Mobile Mode --> + <div class="col d-md-none py-1 o_wprofile_user_profile_sub_nav_mobile_col"> + <div class="btn-group w-100 position-relative" role="group" aria-label="Mobile sub-nav"> + + <div class="btn-group ml-1 position-static mr-2"> + <a class="btn bg-black-25 text-white dropdown-toggle" href="#" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"><i class="fa fa-search"></i></a> + <div class="dropdown-menu dropdown-menu-right w-100" style="right: 10px;"> + <form class="px-3" t-attf-action="#{'/event/%s/community/leaderboard' % (slug(event))}" role="search" method="get"> + <div class="input-group"> + <input type="text" class="form-control" name="search" placeholder="Search courses"/> + <span class="input-group-append"> + <button class="btn btn-primary" type="submit" aria-label="Search" title="Search"> + <i class="fa fa-search"/> + </button> + </span> + </div> + </form> + </div> + </div> + </div> + </div> + </div> + </div> +</template> +</odoo> |
