message_icon.ts 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  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. return 'ic_insert_drive_file_24px.svg';
  40. case 'ballot':
  41. return 'ic_poll_24px.svg';
  42. default:
  43. return null;
  44. }
  45. };
  46. this.icon = getIcon(this.message.type);
  47. }],
  48. template: `
  49. <img ng-if="ctrl.icon !== null" ng-src="img/{{ ctrl.icon }}" alt="{{ ctrl.message.type }} icon">
  50. `,
  51. };
  52. },
  53. ];