question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

Extend Image Traits

See original GitHub issue

Hello,

i would like to extend the image type with some options, specially with a redirect option on click. I tried this solution after the editor initialization (i precise that i work in full javascript and non Node.js environment) : editor.DomComponents.addType(‘image’, { isComponent: el => el.tagName == ‘img’, model: { defaults: { traits: [ // Strings are automatically converted to text types ‘alt’, ‘title’, // Same as: { type: ‘text’, name: ‘name’ } { type: ‘url’, name: ‘href’, placeholder:‘https://google.com’, changeProp: 1 } ], // As by default, traits are binded to attributes, so to define // their initial value we can use attributes attributes: { type: ‘title’, required: false }, }, init() { // Also the listener changes from change:attributes:* to change:* this.on(‘change:url’, this.handlePlhChange); }, handlePlhChange() { console.log(‘URL updated’); }, }, });

So, with that code, i saw my URL input but i can’t trigger the update. My point is to intercept the input update and get the input value to use it to put my “img” DOM into a “a href” DOM

Any help would be great 😃

Best regards

Issue Analytics

  • State:closed
  • Created 3 years ago
  • Comments:8 (3 by maintainers)

github_iconTop GitHub Comments

1reaction
Lerdouillecommented, Jul 5, 2020

Hi again,

here is the final solution to create a a href image :

editor.DomComponents.addType('imagelink', {
                model: {
                    defaults: {
                        tagName: 'div',
                        resizable: {keepAutoHeight: true},
                        droppable: false,
                        traits: [
                            { 
                                type: 'href', label: 'Source', name: 'href'
                            },
                            {
                                type: 'select',
                                label: 'Target',
                                name: 'target',
                                options: [
                                  { value: '', name: 'This window' },
                                  { value: '_blank', name: 'New window' }
                                ]
                            }
                        ],
                        components: [
                            {
                                resizable: false,
                                draggable: false,
                                droppable: false,
                                selectable: false,
                                hoverable: false,
                                type: 'link',
                                components: [{
                                    type: 'image',
                                    attributes: {
                                        src: '',
                                        style:'width:100%;'
                                    },
                                    resizable: false,
                                    draggable: false,
                                    droppable: false,
                                    hoverable: false,
                                    selectable: false,
                                }]
                            }
                        ]
                    },
                    init() {
                      this.on('change:attributes:href', this.handleHrefChange);
                      this.on('change:attributes:target', this.handleTargetChange);
                    },
                    handleHrefChange: function ( component, value ) {
                        delete component.attributes.attributes;
                        component.attributes.components.models[0].attributes.attributes.href = value;
                        return false;
                    },
                    handleTargetChange: function ( component, value ) {
                        delete component.attributes.attributes;
                        component.attributes.components.models[0].attributes.attributes.target = value;
                        return false;
                    },
                },
            });

Now i have to found how to check the URL integrity when you want to update the href variable

Best regards

0reactions
Lerdouillecommented, Jun 24, 2020

Here is a solution i found :

editor.DomComponents.addType(‘imagelink’, { // Model definition model: { // Default properties defaults: { tagName: ‘a’, //resizable: true, attributes: { // Default attributes name: ‘Default name’, placeholder: ‘Insert text here’ }, components: ‘’, traits: [ { type: ‘text’, label: ‘Name’, name: ‘name’ }, { type: ‘text’, label: ‘Placeholder’, name: ‘placeholder’ }, { type: ‘href’, label: ‘Source’, name: ‘href’ } ], }, init() { this.on(‘change:attributes’, this.handleAttrChange); }, handleAttrChange() { console.log('Attributes updated: ', this.getAttributes()); }, }, view: { events: { dblclick: ‘innerElDblClick’, click: ‘innerElClick’, }, innerElClick(ev) { ev.stopPropagation(); editor.select( this.model ); return false; }, innerElDblClick(ev) { ev.stopPropagation(); editor.select( this.model ); return false; }, } });

With functions innerElClick and innerElDblClick, when you click throught the editor, it will select the properties of the new type imagelink and allow you to change the source link. By the way, you can also double click on the image to open asset and change the source file image.

I have actually another issue with my new type, i can’t figure out how to resize the component with the mouse drag method… I tried to add the property resizable: true on the model definition (commented in my sample) but it didn’t work…

Could you please tell me if there is a solution to change the size of the whole component (img and href dom) ?

Best regards

Read more comments on GitHub >

github_iconTop Results From Across the Web

How to Extend Backgrounds in Photoshop with Content Aware
Use the Content-Aware Scale tool to stretch your image, paying close attention to the subject. Once you see the subject begin to widen,...
Read more >
Use Snapseed expand tool to add extra space in your image ...
The Snapseed photo editing app has an expand tool that allows you to automatically copy the edges of your images and expand the...
Read more >
How To Stretch Images With Complex Backgrounds Like ...
In this brilliant tutorial, Photoshop instructor Unmesh Dinda from PiXimperfect shows you how to use the Content-Aware Fill tool, the Healing Brush tool,...
Read more >
Adjust and exaggerate facial features - Adobe Support
After opening an image, click Filter > Liquefy. Convert to Smart Object before liquefying. Enlarge the eyes. In the Liquify window, click ...
Read more >
Extending Anthophila research through image and trait ...
2) Create over 1.3M specimen images from which the project will capture detailed functional trait information at the specimen level. It will create...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found