You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

80 lines
2.6 KiB

7 years ago
  1. # MuK Preview
  2. MuK Preview enables support to preview binary files directly in Odoo. It adds
  3. a button to the binary field, which opens a file preview dialog. The preview can be
  4. easily extended by adding new Handlers to the Preview Generator.
  5. ## Extend MuK Preview
  6. To extend the preview a new "PreviewHandler" has to be created and subsequently added to the "PreviewGenerator".
  7. In the following steps show the implementation of the image preview.
  8. ### PreviewHandler
  9. ```javascript
  10. odoo.define('muk_preview_image.PreviewHandler', function (require) {
  11. "use strict";
  12. var core = require('web.core');
  13. var PreviewHandler = require('muk_preview.PreviewHandler');
  14. var QWeb = core.qweb;
  15. var _t = core._t;
  16. var ImageHandler = PreviewHandler.BaseHandler.extend({
  17. checkExtension: function(extension) {
  18. return ['.cod', '.ras', '.fif', '.gif', '.ief', '.jpeg', '.jpg', '.jpe', '.png', '.tiff',
  19. '.tif', '.mcf', '.wbmp', '.fh4', '.fh5', '.fhc', '.ico', '.pnm', '.pbm', '.pgm',
  20. '.ppm', '.rgb', '.xwd', '.xbm', '.xpm', 'cod', 'ras', 'fif', 'gif', 'ief', 'jpeg',
  21. 'jpg', 'jpe', 'png', 'tiff', '.tif', 'mcf', 'wbmp', 'fh4', 'fh5', 'fhc', 'ico',
  22. 'pnm', 'pbm', 'pgm', '.ppm', 'rgb', 'xwd', 'xbm', 'xpm'].includes(extension);
  23. },
  24. checkType: function(mimetype) {
  25. return ['image/cis-cod', 'image/cmu-raster', 'image/fif', 'image/gif', 'image/ief', 'image/jpeg',
  26. 'image/png', 'image/tiff', 'image/vasa', 'image/vnd.wap.wbmp', 'image/x-freehand', 'image/x-icon',
  27. 'image/x-portable-anymap', 'image/x-portable-bitmap', 'image/x-portable-graymap', 'image/x-portable-pixmap',
  28. 'image/x-rgb', 'image/x-windowdump', 'image/x-xbitmap', 'image/x-xpixmap'].includes(mimetype);
  29. },
  30. createHtml: function(url, mimetype, extension, title) {
  31. var result = $.Deferred();
  32. var $content = $(QWeb.render('ImageHTMLContent', {url: url, alt: title}));
  33. $content.find('img').click(function (e) {
  34. ImageViewer().show(this.src, this.src);
  35. });
  36. result.resolve($content);
  37. return $.when(result);
  38. },
  39. });
  40. return {
  41. ImageHandler: ImageHandler,
  42. }
  43. });
  44. ```
  45. ### PreviewGenerator
  46. ```javascript
  47. odoo.define('muk_preview_image.PreviewGenerator', function (require) {
  48. "use strict";
  49. var core = require('web.core');
  50. var PreviewGenerator = require('muk_preview.PreviewGenerator');
  51. var PreviewHandler = require('muk_preview_image.PreviewHandler');
  52. var QWeb = core.qweb;
  53. var _t = core._t;
  54. PreviewGenerator.include({
  55. init: function(widget, additional_handler) {
  56. this._super(widget, additional_handler);
  57. this.handler = _.extend(this.handler, {
  58. "ImageHandler": new PreviewHandler.ImageHandler(widget),
  59. });
  60. },
  61. });
  62. });
  63. ```