1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- <!-- Thumbnail -->
- <!-- Images, Gifs & Videos -->
- <span class="in-view-indicator" in-view="ctrl.thumbnailInView($inview)"></span>
- <div ng-if="ctrl.uploading">
- <! -- Loading indicator -->
- <div class="circle active center">
- <i class="material-icons md-24">file_upload</i>
- <div class="loading active"></div>
- </div>
- </div>
- <div ng-if="!ctrl.uploading">
- <div ng-if="ctrl.showThumbnail" class="thumbnail {{ctrl.type}}" ng-click="ctrl.download()" ng-style="ctrl.thumbnailStyle">
- <div class="loading-wrapper" ng-class="{active: ctrl.downloading || ctrl.thumbnailDownloading}">
- <div class="loading"></div>
- <div class="loading-text" translate>messenger.DOWNLOADING</div>
- </div>
- <div class="overlay video" ng-if="ctrl.type === 'video' && !ctrl.downloading">
- <i class="material-icons md-light">play_circle_outline</i>
- </div>
- <div class="overlay gif" ng-if="ctrl.type === 'file' && ctrl.message.file.type === 'image/gif' && !ctrl.downloading">
- <i class="material-icons md-light">play_circle_outline</i>
- </div>
- <img ng-if="ctrl.thumbnail !== null" ng-src="{{ctrl.thumbnail}}">
- <div ng-if="ctrl.message.thumbnail != undefined" class="thumbnail-loader">
- <img ng-src="{{ ctrl.message.thumbnail.preview | bufferToUrl: 'image/png' }}">
- </div>
- </div>
- <!-- Location -->
- <location ng-if="ctrl.type === 'location'" location="ctrl.location"></location>
- <!-- Audio file -->
- <div class="file-message" ng-if="ctrl.type === 'audio'">
- <! -- Loading indicator -->
- <div class="circle" ng-click="ctrl.download()"
- ng-class="{active: !ctrl.downloading}"
- ng-if="!ctrl.downloaded">
- <i class="material-icons md-24">file_download</i>
- <div class="loading" ng-class="{active: ctrl.downloading}"></div>
- </div>
- <! -- Play Indicator -->
- <div class="circle" ng-click="ctrl.download()" ng-if="ctrl.downloaded">
- <i class="material-icons md-24">play_arrow</i>
- </div>
- <div class="info" translate>messageTypes.AUDIO_MESSAGE</div>
- </div>
- <!-- Anim GIF -->
- <div class="animgif" ng-if="ctrl.downloaded && ctrl.isAnimGif">
- <img ng-src="{{ ctrl.blobBuffer | bufferToUrl: 'image/gif'}}" />
- </div>
- <!-- Other file messages -->
- <div class="file-message" ng-if="ctrl.type === 'file' && !ctrl.isAnimGif" ng-click="ctrl.download()">
- <! -- Loading indicator -->
- <div class="circle"
- ng-class="{active: !ctrl.downloading}"
- ng-if="!ctrl.downloaded"
- ng-style="{'background-image': 'url({{ctrl.message.thumbnail.preview | bufferToUrl: 'image/png'}})' }">
- <i class="material-icons md-24">file_download</i>
- <div class="loading" ng-class="{active: ctrl.downloading}"></div>
- </div>
- <! -- Open Indicator -->
- <div class="circle"
- ng-if="ctrl.downloaded && ctrl.message.thumbnail.preview !== undefined"
- ng-style="{'background-image': 'url({{ctrl.message.thumbnail.preview | bufferToUrl: 'image/png'}})' }">
- </div>
- <div class="circle"
- ng-if="ctrl.downloaded && ctrl.message.thumbnail.preview == undefined">
- <img ng-src="{{ ctrl.message.file.type | mimeType: false }}"/>
- </div>
- <div class="info">
- <p>{{ctrl.message.file.name}}</p>
- <p>{{ctrl.message.file.type | mimeType: true}}</p>
- <p>{{ctrl.message.file.size | fileSize}}</p>
- </div>
- </div>
- </div>
- <!-- Ballot -->
- <span ng-if="ctrl.type === 'ballot'"><em>Ballot messages are not yet supported.</em></span> <!-- TODO -->
|