1001 Freelance Projects
Latest Projects from Freelance Marketplaces
Today is: 06-May-2024 16:48 GMT
View Project
View this project in detail (Note: you will be redirected to external marketplace)
Project title: Enabling Autolinking in Slate.js editor
Posted by: External project from PeoplePerHour
Started: 02-May-2021 08:35 GMT
Description: - Slatejs is a rich texteditor using the "contenteditable" param - very similar to any other text editor like TinyMCE.
- Slatejs is extremely extensible - adding your own ability of items to do.
- In the slatejs demo - [https://www.slatejs.org/examples/richtext](https://www.slatejs.org/examples/richtext) you can see how it works.
- Pretty much like a free text editor - any bold. italic.
- It also supports markdown shortcuts - [https://www.slatejs.org/examples/markdown-shortcuts](https://www.slatejs.org/examples/markdown-shortcuts)
- If you type ">", "-", or "#"s., it automatically expands to those shortcuts. ([see code](https://github.com/ianstormtaylor/slate/blob/main/site/examples/markdown-shortcuts.tsx))

Problem Statement:

- Slatejs doesn't support autolinking by default.
- There is manual linking - [https://www.slatejs.org/examples/links](https://www.slatejs.org/examples/links) , you can select a text and make it a link.
- All modern editors, when you type a link, it autolinks. If you type google.com and type space, it makes it a link. But slatejs doesn't out of box.
- This is exactly what we want to do. When someone types a valid link and presses space, it should automatically make it a clickable link. i.e when i type [www.google.com](http://www.google.com)
- You can use this code to find out whether it is a valid url - [https://gist.github.com/alagu/b5355685aace148607bcda84264a9ff2](https://gist.github.com/alagu/b5355685aace148607bcda84264a9ff2)
- Pointers:
- Read through the markdown shortcuts code, you'll find a lot of similarities in how you want to add your linking as well.
- But it will not exactly work, because markdown uses shortcuts, here you want evaluate whether it is a valid link after a space and convert it into space.
- Slatejs has a data representation format in json (scroll to bottom of the code in this [markdown shortcuts](https://github.com/ianstormtaylor/slate/blob/main/site/examples/markdown-shortcuts.tsx)), there is a initialvalue that is set that gets rendered.
-



- So to update the content, you have to update the json and each type item in json has a corresponding rendering function called "Element"
-

- As bonus,
- if you are able to understand how Slatejs Transforms are working, it would help you to understand better.

### Output

- Share a codesandbox link with a working code of the autolinking.
- How to test:
- Try typing `[google.com](http://google.com)` and hit space, [google.com](http://google.com) should have become a link. `[www.twitter.com](http://www.twitter.com)` and hit a space, [www.twitter.com](http://www.twitter.com) should become a link.
Project ID: 3166102
Project category:
Project budget:
View this project in detail (Note: you will be redirected to external marketplace)
Last Projects / Browse Projects
  Project Started
Honest Review of Self-Help Book Needed
Category: Book Review, Copywriting, Creative Writing
Budget: €8 - €30 EUR
06-May-2024
16:04 GMT
Looking for a Video Creator for iPhone Mockup Ads
Category: Animated Video Development, Video Production, Video Services, Videography
Budget: $30 - $250 USD
06-May-2024
16:04 GMT
Renovacion de Pagina web Wordpress(Only Spanish Speaking)
Category: Graphic Design, PHP, SEO, Web Design, WordPress
Budget: $30 - $250 USD
06-May-2024
16:03 GMT
Professional PowerPoint Cleanup & Enhancement
Category: Excel, Graphic Design, Powerpoint, Presentations, Word
Budget: £20 - £250 GBP
06-May-2024
16:03 GMT
Minimalistic Logo for Brand Identification
Category: 3D Design, Graphic Design, Illustration, Logo Design, Photoshop
Budget: ₹600 - ₹1500 INR
06-May-2024
16:03 GMT
Multi-Media Personnel for Branding Agency
Category: 3D Animation, After Effects, Animation, Video Editing, Video Services
Budget: ₹1500 - ₹12500 INR
06-May-2024
16:03 GMT
Information Sharing Website DevelopmentC:\Users\pr073\OneDrive\Pictures\jayadharshini.png
Category: Graphic Design, HTML, PHP, User Interface / IA, Web Design
Budget: ₹12500 - ₹37500 INR
06-May-2024
16:00 GMT
Migración de proyecto en Angular, NodeJs, express, MongoDB
Category: AngularJS, HTML5, JavaScript, Node.js, NoSQL Couch & Mongo
Budget: €30 - €250 EUR
06-May-2024
16:00 GMT
High-Impact Informational Website Design
Category: Graphic Design, HTML, PHP, User Interface / IA, Web Design
Budget: ₹1500 - ₹12500 INR
06-May-2024
15:59 GMT
Racket Scripting & Grammar Developer
Category: Coding, Lisp, Racket
Budget: $30 - $250 USD
06-May-2024
15:59 GMT
Contact details for founders/CEOs of SMEs 06-May-2024
15:59 GMT
Desmos Network DApp Developer
Category: Mobile App Development, Node.js, React Native, Typescript
Budget: €250 - €750 EUR
06-May-2024
15:59 GMT
C[sharp] DLL Integration into C++ UI
Category: .NET, C, Programming, C#, C++, Software Architecture
Budget: ₹1500 - ₹12500 INR
06-May-2024
15:59 GMT
Farewell Themed Wristband Design
Category: Graphic Design, Logo Design, Photoshop, Photoshop Design, T Shirts
Budget: ₹600 - ₹1500 INR
06-May-2024
15:59 GMT
German SEO pro needed for ongoing B2B website optimisation 06-May-2024
15:58 GMT
Browse All Projects
Projects by Skills ...
Projects for 'android'
Projects for 'ajax'
Projects for 'asp'
Projects for 'aspnet'
Projects for 'cms'
Projects for 'cpp'
Projects for 'csharp'
Projects for 'css'
Projects for 'delphi'
Projects for 'design'
Projects for 'drupal'
Projects for 'excel'
Projects for 'facebook'
Projects for 'flash'
Projects for 'html'
Projects for 'java'
Projects for 'javascript'
Projects for 'joomla'
Projects for 'iphone'
Projects for 'mysql'
Projects for 'photoshop'
Projects for 'php'
Projects for 'python'
Projects for 'ruby'
Projects for 'seo'
Projects for 'sql'
Projects for 'sysadm'
Projects for 'translate'
Projects for 'typing'
Projects for 'twitter'
Projects for 'vbnet'
Projects for 'xml'
Projects for 'wordpress'
Projects for 'writing'
Read RSS feeds ... New!
RSS feed for 'android'
RSS feed for 'ajax'
RSS feed for 'asp'
RSS feed for 'aspnet'
RSS feed for 'cms'
RSS feed for 'cpp'
RSS feed for 'csharp'
RSS feed for 'css'
RSS feed for 'delphi'
RSS feed for 'design'
RSS feed for 'drupal'
RSS feed for 'excel'
RSS feed for 'facebook'
RSS feed for 'flash'
RSS feed for 'html'
RSS feed for 'java'
RSS feed for 'javascript'
RSS feed for 'joomla'
RSS feed for 'iphone'
RSS feed for 'mysql'
RSS feed for 'photoshop'
RSS feed for 'php'
RSS feed for 'python'
RSS feed for 'ruby'
RSS feed for 'seo'
RSS feed for 'sql'
RSS feed for 'sysadm'
RSS feed for 'translate'
RSS feed for 'typing'
RSS feed for 'twitter'
RSS feed for 'vbnet'
RSS feed for 'xml'
RSS feed for 'wordpress'
RSS feed for 'writing'
New!
Проекты на русском
(Projects in Russian)

Short URL:
1001fp.com
Mobile version:
m.1001freelanceprojects.com
Copyright © 2005-2022 1001 Freelance Projects