Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Cannot Read Properties of null (reading 'from') #42

Open
PeteMichaud opened this issue Apr 17, 2022 · 5 comments
Open

Cannot Read Properties of null (reading 'from') #42

PeteMichaud opened this issue Apr 17, 2022 · 5 comments

Comments

@PeteMichaud
Copy link
Collaborator

When I try to use a snippet like so:

<< : «

It fails, and throws the exception: Uncaught TypeError: Cannot read properties of null (reading 'from')

Coming from this line:

var wordStart = word.from.ch;

Looks like editor.wordAt doesn't like the bracket characters?

@PeteMichaud
Copy link
Collaborator Author

Investigating further, CodeMirror's wordAt function is used to capture the potential snippet name, but it only finds words made of "word characters." The function itself:

function wordAt(cm, pos) {
    var start = pos.ch, end = start, line = cm.getLine(pos.line);
    while (start && CodeMirror.isWordChar(line.charAt(start - 1))) --start;
    while (end < line.length && CodeMirror.isWordChar(line.charAt(end))) ++end;
    return {from: Pos(pos.line, start), to: Pos(pos.line, end), word: line.slice(start, end)};
  }

The relevant call here is isWordChar.

There are 2 options that I can see:

  1. Use a custom implementation of wordAt that removes the call to isWordChar and replaces it with something like isNotWhiteSpaceChar. This would let us use snippets with any characters we wanted, and is my preferred method.
  2. Insert a null check at the offending line linked in the original message of this thread, and potentially do some error checking on the settings screen, alerting the user to a snippet that cannot be processed because it's not made of word characters.

A third option which is not available to us at this time: isWordChar takes an optional parameter of a custom helper to inject logic about what counts as a word character, but wordAt doesn't support passing that through. If it did support passing through we could pass our own logic in without making a custom function at all. I'll go make a feature request in the CodeMirror repo, because I think that would actually be ideal.

@rickalex21
Copy link

I'm getting something similar.

VM361:61 Uncaught (in promise) TypeError: Cannot read properties of null (reading 'view')
    at TextSnippets.eval (eval at <anonymous> (app.js:1:1494667), <anonymous>:61:60)
    at Generator.next (<anonymous>)
    at fulfilled (eval at <anonymous> (app.js:1:1494667), <anonymous>:28:58)

The problem is in the line that contains let editor...

if (this.settings.isWYSISWYG) {
                let editor = this.app.workspace.activeLeaf.view.sourceMode.cmEditor;
                this.settings.isWYSISWYG = (typeof editor.wordAt === 'function');
                this.registerDomEvent(document, 'keydown', (event) => this.handleKeyDown(editor, event));

I can't use 'Tab' , I have it enabled . It automatically inserts an indent. Not sure if I have to unmap it and remap it some how in obsidian.vimrc or something else I have to do?

My plugin does not show up, I think it's cause of this error. I usually just edit the data.json since I can't see the plugin settings.

@ArianaKhit
Copy link
Owner

  1. Use a custom implementation of wordAt

I preferred this option, now in 0.1.0 "word" is sequence of characters except whitespaces and delimiters.

@ArianaKhit
Copy link
Owner

I can't use 'Tab'

For some reasons Tab or Space are not working in LivePreview mode.

@jeansordes
Copy link

About the "Tab and Space" issue, we found a temporary fix in issue #47

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants