Changes for page 学校ページ テンプレート
Last modified by Super Admin on 2026/04/05 18:59
From version
36.1
edited by Super Admin
on 2026/03/10 14:40
on 2026/03/10 14:40
Change comment:
There is no comment for this version
To version
26.1
edited by Super Admin
on 2026/03/09 12:38
on 2026/03/09 12:38
Change comment:
There is no comment for this version
Summary
Details
- Page properties
-
- Content
-
... ... @@ -1,29 +1,9 @@ 1 1 {{velocity}} 2 2 ## ===== 学校ページ テンプレート ===== 3 -## ページタイトルを学校名に設定({{html}}ブロックの前で実行する必要あり) 4 -#set($__titleObj = $doc.getObject('SeitokaiCode.SchoolClass')) 5 -#if($__titleObj) 6 - #set($__titleName = $__titleObj.getValue('schoolName')) 7 - #if($__titleName && $__titleName != '') 8 - $doc.setTitle($__titleName) 9 - #end 10 -#end 11 -{{html clean="false"}} 12 -## メンテナンスバナー({{include}}ではなくインラインで記述し、<p>タグ挿入を回避) 13 -#set($bannerDoc = $xwiki.getDocument('SeitokaiAdmin.MaintenanceBanner')) 14 -#set($bannerObj = $bannerDoc.getObject('SeitokaiCode.MaintenanceBannerClass')) 15 -#if($bannerObj && $bannerObj.getValue('enabled') == 1) 16 -#set($bannerMsg = $bannerObj.getValue('message')) 17 -#set($bannerLevel = $bannerObj.getValue('level')) 18 -#if(!$bannerLevel || $bannerLevel == '')#set($bannerLevel = 'warning')#end 19 -<div class="maintenance-banner active maintenance-${bannerLevel}" id="maintenance-banner"> 20 - <div class="maintenance-banner-inner"> 21 - <span class="maintenance-icon">#if($bannerLevel == 'urgent')<svg class="ico-banner" viewBox="0 0 24 24"><path d="M10.29 3.86L1.82 18a2 2 0 001.71 3h16.94a2 2 0 001.71-3L13.71 3.86a2 2 0 00-3.42 0z"/><line x1="12" y1="9" x2="12" y2="13"/><line x1="12" y1="17" x2="12.01" y2="17"/></svg>#elseif($bannerLevel == 'info')<svg class="ico-banner" viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><line x1="12" y1="16" x2="12" y2="12"/><line x1="12" y1="8" x2="12.01" y2="8"/></svg>#else<svg class="ico-banner" viewBox="0 0 24 24"><path d="M14.7 6.3a1 1 0 000 1.4l1.6 1.6a1 1 0 001.4 0l3.77-3.77a6 6 0 01-7.94 7.94l-6.91 6.91a2.12 2.12 0 01-3-3l6.91-6.91a6 6 0 017.94-7.94l-3.76 3.76z"/></svg>#end</span> 22 - <span class="maintenance-text">$!escapetool.xml($bannerMsg)</span> 23 - <button class="maintenance-close" onclick="document.getElementById('maintenance-banner').style.display='none'">×</button> 24 - </div> 25 -</div> 26 -#end 3 +## このテンプレートは学校ページの表示と入力フォームを制御します。 4 + 5 +## メンテナンスバナー 6 +{{include reference="SeitokaiCode.MaintenanceBannerInclude" /}}{{html clean="false"}} 27 27 ## --- 学校基本情報フィールド --- 28 28 #set($schoolCode = $doc.getValue('schoolCode')) 29 29 #set($schoolName = $doc.getValue('schoolName')) ... ... @@ -179,7 +179,7 @@ 179 179 ## --- ユーザー情報取得 --- 180 180 ## displayName: Wiki上の表示名(ニックネーム)。本名(firstName/lastName)は管理者のみ閲覧可能。 181 181 #set($lastAuthor = $doc.author) 182 -#set($lastAuthorDoc = $xwiki.getDocument($lastAuthor)) 162 +#set($lastAuthorDoc = $xwiki.getDocument("XWiki.${lastAuthor}")) 183 183 #set($authorAccountType = '') 184 184 #set($authorUserRole = '') 185 185 #set($authorUserStatus = '') ... ... @@ -232,20 +232,48 @@ 232 232 #end 233 233 #end 234 234 235 -## --- 編集ボタン(権限があるユーザーのみ表示) --- 236 -#set($canEditSchool = false) 237 -#if(!$isGuest && ($isViewerAdmin || $viewerSchoolCode == $schoolCode)) 238 - #set($canEditSchool = true) 239 -#end 240 -#if($canEditSchool) 241 -<div style="text-align:right; margin-bottom:12px;"> 242 - <a href="$doc.getURL('view', 'sheet=SeitokaiCode.SchoolEditForm')" class="btn-school-edit"><svg class="ico" viewBox="0 0 24 24"><path d="M11 4H4a2 2 0 00-2 2v14a2 2 0 002 2h14a2 2 0 002-2v-7"/><path d="M18.5 2.5a2.121 2.121 0 013 3L12 15l-4 1 1-4 9.5-9.5z"/></svg> 基本情報を編集</a> 215 +## --- 信頼性バッジ + ユーザー情報 --- 216 +<div class="seitokai-badge-container"> 217 + ## 承認バッジ 218 + #if($authorAccountType == 'admin') 219 + <span class="badge badge-admin"><svg class="ico" viewBox="0 0 24 24"><path d="M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z"/></svg> 管理者</span> 220 + #elseif($authorAccountType == 'verified') 221 + <span class="badge badge-verified"><svg class="ico" viewBox="0 0 24 24" stroke-width="2.5"><path d="M20 6L9 17l-5-5"/></svg> 承認済み</span> 222 + #elseif($authorAccountType == 'referred') 223 + <span class="badge badge-referred"><svg class="ico" viewBox="0 0 24 24"><path d="M10 13a5 5 0 007.54.54l3-3a5 5 0 00-7.07-7.07l-1.72 1.71"/><path d="M14 11a5 5 0 00-7.54-.54l-3 3a5 5 0 007.07 7.07l1.71-1.71"/></svg> 紹介</span> 224 + #else 225 + <span class="badge badge-general">一般</span> 226 + #end 227 + ## 役割バッジ 228 + #if($authorUserRole == 'student') 229 + <span class="badge badge-role-student"><svg class="ico" viewBox="0 0 24 24"><path d="M22 10l-10-5L2 10l10 5 10-5z"/><path d="M6 12v5c0 1.66 2.69 3 6 3s6-1.34 6-3v-5"/></svg> 生徒</span> 230 + #set($authorIsOfficer = $!lastAuthorDoc.getValue('isOfficer')) 231 + #if($authorIsOfficer == 'true') 232 + <span class="badge badge-role-officer"><svg class="ico" viewBox="0 0 24 24"><path d="M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z"/></svg> 役員</span> 233 + #end 234 + #elseif($authorUserRole == 'teacher') 235 + <span class="badge badge-role-teacher"><svg class="ico" viewBox="0 0 24 24"><path d="M4 19.5A2.5 2.5 0 016.5 17H20"/><path d="M6.5 2H20v20H6.5A2.5 2.5 0 014 19.5v-15A2.5 2.5 0 016.5 2z"/></svg> 教員</span> 236 + #elseif($authorUserRole == 'graduate') 237 + <span class="badge badge-role-graduate"><svg class="ico" viewBox="0 0 24 24"><path d="M22 10l-10-5L2 10l10 5 10-5z"/><path d="M6 12v5c0 1.66 2.69 3 6 3s6-1.34 6-3v-5"/></svg> 卒業生</span> 238 + #end 239 + ## 学年(生徒のみ公開) 240 + #if($authorGrade && $authorGrade != '') 241 + <span class="badge badge-grade">$authorGrade</span> 242 + #end 243 + ## 在籍状態(卒業・休学等の場合のみ表示) 244 + #if($authorUserStatus == 'graduated') 245 + <span class="badge badge-status-graduated"><svg class="ico" viewBox="0 0 24 24"><path d="M22 10l-10-5L2 10l10 5 10-5z"/><path d="M6 12v5c0 1.66 2.69 3 6 3s6-1.34 6-3v-5"/></svg> 卒業済み</span> 246 + #elseif($authorUserStatus == 'on_leave') 247 + <span class="badge badge-status-onleave"><svg class="ico" viewBox="0 0 24 24" fill="currentColor"><rect x="6" y="4" width="4" height="16" rx="1"/><rect x="14" y="4" width="4" height="16" rx="1"/></svg> 休学中</span> 248 + #elseif($authorUserStatus == 'transferred') 249 + <span class="badge badge-status-transferred"><svg class="ico" viewBox="0 0 24 24"><polyline points="23 4 23 10 17 10"/><polyline points="1 20 1 14 7 14"/><path d="M3.51 9a9 9 0 0114.85-3.36L23 10M1 14l4.64 4.36A9 9 0 0020.49 15"/></svg> 転校済み</span> 250 + #end 251 + <span class="badge-info">最終編集: $!escapetool.xml($authorDisplayName) ($xwiki.formatDate($doc.date, "yyyy/MM/dd"))</span> 243 243 </div> 244 -#end 245 245 246 246 ## --- ① 学校基本情報 + 連絡先(左右グリッド・折りたたみ対応) --- 247 247 <div class="school-info-grid"> 248 - <div class="school-info-card collapse d" id="card-basic-info">256 + <div class="school-info-card mobile-collapse" id="card-basic-info"> 249 249 <h2 onclick="toggleInfoCard('card-basic-info')"><span><svg class="ico ico-md" viewBox="0 0 24 24"><path d="M4 19.5A2.5 2.5 0 016.5 17H20"/><path d="M6.5 2H20v20H6.5A2.5 2.5 0 014 19.5v-15A2.5 2.5 0 016.5 2z"/></svg> 学校基本情報</span><span class="collapse-toggle"><span class="collapse-label-open">たたむ</span><span class="collapse-label-closed">開く</span> <span class="collapse-arrow">▼</span></span></h2> 250 250 <table class="wiki-table school-info-table"> 251 251 <tr><th>学校コード</th><td>$!escapetool.xml($!schoolCode)</td></tr> ... ... @@ -265,7 +265,7 @@ 265 265 #end 266 266 </div> 267 267 268 - <div class="school-info-card collapse d" id="card-contact">276 + <div class="school-info-card mobile-collapse" id="card-contact"> 269 269 <h2 onclick="toggleInfoCard('card-contact')"><span><svg class="ico ico-md" viewBox="0 0 24 24"><path d="M22 16.92v3a2 2 0 01-2.18 2 19.79 19.79 0 01-8.63-3.07 19.5 19.5 0 01-6-6 19.79 19.79 0 01-3.07-8.67A2 2 0 014.11 2h3a2 2 0 012 1.72c.127.96.361 1.903.7 2.81a2 2 0 01-.45 2.11L8.09 9.91a16 16 0 006 6l1.27-1.27a2 2 0 012.11-.45c.907.339 1.85.573 2.81.7A2 2 0 0122 16.92z"/></svg> 連絡先・SNS</span><span class="collapse-toggle"><span class="collapse-label-open">たたむ</span><span class="collapse-label-closed">開く</span> <span class="collapse-arrow">▼</span></span></h2> 270 270 <table class="wiki-table school-info-table"> 271 271 <tr><th>問い合わせ先</th><td>#if($contactInfo && $contactInfo != '')$!escapetool.xml($contactInfo)#else<span class="text-placeholder">未登録</span>#end</td></tr> ... ... @@ -1018,11 +1018,16 @@ 1018 1018 } 1019 1019 }); 1020 1020 } 1021 -// ページ読み込み時の 初期化1029 +// ページ読み込み時にデフォルトで現在の年度を表示 1022 1022 document.addEventListener('DOMContentLoaded', function() { 1023 - // デフォルトで現在の年度を表示 1024 1024 var defaultTab = document.querySelector('.activity-fy-tab.active'); 1025 1025 if (defaultTab) { defaultTab.click(); } 1033 + // モバイルでは基本情報・連絡先をデフォルト折りたたみ 1034 + if (window.innerWidth <= 768) { 1035 + document.querySelectorAll('.school-info-card.mobile-collapse').forEach(function(card) { 1036 + card.classList.add('collapsed'); 1037 + }); 1038 + } 1026 1026 // 保存成功時のトースト通知 1027 1027 if (window.location.search.indexOf('archived=1') !== -1) { 1028 1028 showToast('年度アーカイブを作成しました', 'success'); ... ... @@ -1062,6 +1062,7 @@ 1062 1062 var card = document.getElementById(cardId); 1063 1063 if (!card) return; 1064 1064 card.classList.toggle('collapsed'); 1078 + card.classList.remove('mobile-collapse'); 1065 1065 } 1066 1066 1067 1067 // 投稿の編集(インライン編集フォームを開く)