message_icon.ts 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /**
  2. * This file is part of Threema Web.
  3. *
  4. * Threema Web is free software: you can redistribute it and/or modify it
  5. * under the terms of the GNU Affero General Public License as published by
  6. * the Free Software Foundation, either version 3 of the License, or (at
  7. * your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful, but
  10. * WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero
  12. * General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU Affero General Public License
  15. * along with Threema Web. If not, see <http://www.gnu.org/licenses/>.
  16. */
  17. export default [
  18. function() {
  19. return {
  20. restrict: 'EA',
  21. scope: {},
  22. bindToController: {
  23. message: '=eeeMessage',
  24. },
  25. controllerAs: 'ctrl',
  26. controller: [function() {
  27. // Return icon depending on message type.
  28. const getIcon = (msgType: threema.MessageType) => {
  29. switch (msgType) {
  30. case 'image':
  31. return 'ic_image_24px.svg';
  32. case 'video':
  33. return 'ic_movie_24px.svg';
  34. case 'audio':
  35. return 'ic_mic_24px.svg';
  36. case 'location':
  37. return 'ic_location_on_24px.svg';
  38. case 'file':
  39. if (this.message.file.type === 'image/gif') {
  40. return 'ic_image_24px.svg';
  41. }
  42. return 'ic_insert_drive_file_24px.svg';
  43. case 'ballot':
  44. return 'ic_poll_24px.svg';
  45. default:
  46. return null;
  47. }
  48. };
  49. this.icon = getIcon(this.message.type);
  50. }],
  51. template: `
  52. <img ng-if="ctrl.icon !== null" ng-src="img/{{ ctrl.icon }}" alt="{{ ctrl.message.type }} icon">
  53. `,
  54. };
  55. },
  56. ];