Wiki source code of ExternalApps
Hide last authors
| author | version | line-number | content |
|---|---|---|---|
| |
1.5 | 1 | {{velocity}} |
| |
2.196 | 2 | {{html clean="false"}} |
| 3 | ## space: $spaceDoc <br /> | ||
| 4 | ## children: $spaceDoc.getChildren() | ||
| 5 | |||
| |
2.112 | 6 | #set($query = 'select doc from Document doc, doc.object(ExternalApps.Code.ExternalAppsClass) as app') |
| |
2.114 | 7 | #set($applications = $services.query.xwql($query).addFilter('hidden').execute()) |
| |
2.50 | 8 | |
| |
2.121 | 9 | <style> |
| |
2.179 | 10 | .applications { |
| 11 | display: grid; | ||
| |
2.196 | 12 | grid-gap: 10px; |
| |
2.179 | 13 | } |
| 14 | |||
| |
2.182 | 15 | @media screen and (min-width: 640px) { |
| |
2.183 | 16 | .applications { |
| 17 | grid-template-columns: 1fr 1fr; | ||
| 18 | } | ||
| |
2.182 | 19 | } |
| |
2.184 | 20 | /* |
| |
2.182 | 21 | @media screen and (min-width: 900px) { |
| |
2.183 | 22 | .applications { |
| 23 | grid-template-columns: 1fr 1fr 1fr; | ||
| 24 | } | ||
| |
2.182 | 25 | } |
| |
2.184 | 26 | */ |
| |
2.182 | 27 | |
| 28 | @media screen and (min-width: 1200px) { | ||
| |
2.183 | 29 | .applications { |
| |
2.185 | 30 | grid-template-columns: 1fr 1fr 1fr; |
| |
2.183 | 31 | } |
| |
2.182 | 32 | } |
| 33 | |||
| 34 | @media screen and (min-width: 1800px) { | ||
| |
2.183 | 35 | .applications { |
| |
2.185 | 36 | grid-template-columns: 1fr 1fr 1fr 1fr; |
| |
2.183 | 37 | } |
| |
2.182 | 38 | } |
| |
2.196 | 39 | |
| |
2.195 | 40 | .application { |
| |
2.121 | 41 | border: 1px solid var(--color-support-light); |
| |
2.125 | 42 | padding: 1rem; |
| |
2.181 | 43 | height: 100%; |
| |
2.121 | 44 | } |
| |
2.146 | 45 | |
| 46 | .application img { | ||
| |
2.148 | 47 | display: block; |
| |
2.170 | 48 | margin: 0 auto 1.5rem auto; |
| |
2.146 | 49 | } |
| |
2.149 | 50 | |
| 51 | .application .title { | ||
| 52 | text-align: center; | ||
| |
2.153 | 53 | height: 3em; |
| |
2.149 | 54 | } |
| |
2.160 | 55 | |
| |
2.167 | 56 | .application .tags { |
| 57 | display: flex; | ||
| |
2.169 | 58 | justify-content: space-around; |
| |
2.171 | 59 | margin-bottom: 1.5rem; |
| |
2.167 | 60 | } |
| 61 | |||
| 62 | .application .tags span { | ||
| |
2.160 | 63 | font-size: .8rem; |
| |
2.174 | 64 | border: 1px solid var(--color-support-dark); |
| |
2.175 | 65 | padding: .2rem .3rem; |
| |
2.163 | 66 | border-radius: var(--border-radius-default); |
| |
2.160 | 67 | } |
| |
2.177 | 68 | |
| 69 | .application .description { | ||
| 70 | text-align: center; | ||
| 71 | } | ||
| |
2.121 | 72 | </style> |
| 73 | |||
| 74 | |||
| |
2.196 | 75 | <div class="applications"> |
| 76 | #foreach($application in $applications) | ||
| 77 | #set($app = $xwiki.getDocument($application)) | ||
| 78 | #set($URL = $app.display('url')) | ||
| 79 | #set($title = $app.display('title')) | ||
| 80 | #set($category = $app.display('category')) | ||
| 81 | <div> | ||
| 82 | <div class="application"> | ||
| 83 | #if($app.getAttachment('logo.png').isImage()) | ||
| 84 | <img src="$app.getAttachmentURL('logo.png')" width="75" height="75" alt="$title.replace('"', '\"')"> | ||
| 85 | #else | ||
| 86 | <img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mN89x8AAuEB74Y0o2cAAAAASUVORK5CYII=" width="75" height="75" alt=""> | ||
| 87 | #end | ||
| 88 | <div class="tags"><span>$category</span></div> | ||
| 89 | <h3 class="title">$title</h3> | ||
| 90 | ##<a href="$URL">$URL</a> | ||
| 91 | <p class="description">$!app.getValue('description')</p> | ||
| 92 | ##<input id="$application.concat('-visibility')" type="checkbox" #if($app.getValue('private') == 1)checked#end disabled /><label for="$application.concat('-visibility')">Private</label> | ||
| |
2.187 | 93 | |
| |
2.196 | 94 | <div> |
| 95 | ##$app.getValue('maintainers') | ||
| 96 | ##$app.display('maintainers') | ||
| 97 | </div> | ||
| |
2.187 | 98 | |
| |
2.196 | 99 | </div> |
| |
2.120 | 100 | </div> |
| |
2.196 | 101 | #end |
| |
2.120 | 102 | </div> |
| |
1.5 | 103 | {{/html}} |
| |
2.196 | 104 | {{/velocity}} |
| |
2.195 | 105 |