Edgewall Software
Modify

Opened 20 years ago

Closed 19 years ago

Last modified 19 years ago

#739 closed enhancement (fixed)

Enhance inline image handling

Reported by: daniel+trac@… Owned by: Christian Boos
Priority: normal Milestone: 0.9
Component: wiki system Version: devel
Severity: normal Keywords:
Cc: daniel+trac@… Branch:
Release Notes:
API Changes:
Internal Changes:

Description

It would be nice if the Trac wiki would support ways to:

  • Inline attached images via straightforward syntax
  • Inline images by relative URIs, without leading http:
  • Force the inlining of images with arbitrary URLs, not necessarily beginning with http: and not necessarily ending in .png, .jpg, .gif

without falling back to inline HTML and WikiProcessors magic.

Possible syntax could be:

PageName/attached-image.png or PageName:attached-image.png
image:relative/path/to/image.png
image:/uri/to/image.png
image:http://foo.com/image.bmp
image:/cgi-bin/generated-image.cgi

Also compare with #691 where a similar issue is raised for hyperlinks, with solutions partially covering some of the above cases in a different way.

Attachments (0)

Change History (9)

comment:1 by tstivers@…, 20 years ago

The patches I made for #691 will auto-inline relative links to images but won't handle cgi generated images (it inlines using extensions just like http:// links). I'd like to see some way of doing relative links, including links to images included in the 0.8 release if at all possible. It would also be nice to reference attachments as attachment:filename.ext and [attachment:filename.ext fancyname] with auto image inlining based on extension.

comment:2 by daniel, 20 years ago

Milestone: 0.9

comment:3 by Steven N. Severinghaus <sns@…>, 19 years ago

For what it's worth, I've made a minor change to source:/file/trunk/trac/WikiFormatter.py that allows us to put images inside links, e.g. [http://foo/bar.jpg http://foo/bar_thumb.jpg] could be used to create a thumbnail link. The complete source of the relevant function is below. I can supply a diff if desired, but the change is fairly obvious and localized to the last few lines.

    def _fancylink_formatter(self, match, fullmatch):
        link = fullmatch.group('fancyurl')
        name = fullmatch.group('linkname')

        module_link, t, missing, title = self._expand_module_link(link)
        if module_link and missing:
            return '<a class="missing" href="%s">%s?</a>' % (module_link, name)
        elif module_link:
            return '<a href="%s">%s</a>' % (module_link, name)
        elif name.endswith('.png') or name.endswith('.jpg') or name.endswith('.gif'):
            return '<a href="%s"><img src="%s" alt="%s" /></a>' % (link, name, name)
        else:
            return '<a class="ext-link" title="%s" href="%s">%s</a>' % (link, link, name)

An example of this in action can be found here.

comment:4 by Christian Boos, 19 years ago

Owner: changed from Jonas Borgström to Christian Boos
Status: newassigned

I'll try to integrate the Image macro from Shun-ichi Goto.

comment:5 by Christian Boos, 19 years ago

Resolution: fixed
Status: assignedclosed

Seems to work fine. Fixed in [1872] (source:trunk/wiki-macros/Image.py#latest)

An environment upgrade is needed for installing the new macro (see [1871]).

comment:6 by Christopher Lenz, 19 years ago

cboos, I don't quite understand why you implemented this as a "classic" user macro. Why not put it, together with the other core macros, in trac.wiki.macros? I really think this functionality is important/essential enough to be put in the core.

comment:7 by Christian Boos, 19 years ago

Well, ok, I'll do it tomorrow.

At least it helped me to discover a few issues with user macros :)

comment:8 by Christian Boos, 19 years ago

Hm, I think it would be better to leave this big macro in its own file:

The other default macros source:trunk/trac/wiki/macros.py could then either go in

or be split up:

Besides being default macros, those macros are quite unrelated to each other, so I think splitting them up is better.

comment:9 by Christopher Lenz, 19 years ago

Why? I just don't see the problem here.

Modify Ticket

Change Properties
Set your email in Preferences
Action
as closed The owner will remain Christian Boos.
The resolution will be deleted. Next status will be 'reopened'.
to The owner will be changed from Christian Boos to the specified user.

Add Comment


E-mail address and name can be saved in the Preferences .
 
Note: See TracTickets for help on using tickets.