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

Support for ARB comments #62

Closed
plaa opened this issue Sep 26, 2024 · 9 comments · Fixed by #63
Closed

Support for ARB comments #62

plaa opened this issue Sep 26, 2024 · 9 comments · Fixed by #63
Labels
enhancement New feature or request

Comments

@plaa
Copy link

plaa commented Sep 26, 2024

Expected Behavior

Most places discussing how to organize and add comments to ARB files suggest the following format for comments:

{
    ...
    "@_HOME_SCREEN": {},
    "homeScreenTitle": "",
    ...
    "@_SETTINGS_SCREEN": {},
    "settingsScreenTitle": ""
}

Currently this produces the error "Metadata for an undefined key" in ARB-editor. This warning can be disabled, but that's less than ideal. I propose ARB-editor should accept this @_xyz comment convention and highlight the comment differently from other keys to make it more visible.

Also grouping localization strings with empty lines is useful, but ARB-editor autoformat removes all empty lines. I propose it should retain one empty line (possibly with a configuration option how many to retain). (EDIT: Problem was with Prettier extension, solution below)

Specifications

  • Version: 0.0.12
  • Platform: MacOS
@mosuem
Copy link
Collaborator

mosuem commented Sep 26, 2024

Ok so two issues here:

  1. Adding comments to ARB files

The ARB format already supports arbitrary keys prefixed with @@x-, so @@x-comments could be used for global comments. We could also introduce a @@comment global comment, if there is a use case.
But what you are writing seems to be more targeted as comments for messages - which I would have probably rather written as

{
    "homeScreenTitle": "",
    "@homeScreenTitle": {
      "comment": "Some comment"
    }
}

The comment field is not allowed yet, but we do have description. Could you give an example of a comment which is not a description? I am open to allowing a comment field in there.

  1. Supporting empty lines

ARB files are just JSON files with an added schema. The autoformatter should just be the JSON formatter, and VS Code at least seems to support retaining blank lines.

@mosuem mosuem added the enhancement New feature or request label Sep 26, 2024
@plaa
Copy link
Author

plaa commented Sep 26, 2024

Thank you for the prompt reply!

Adding comments to ARB file

It seems that there is no documented way of adding developer-focused comments / structure to ARB files. When I Googled how to do it, I continuously got suggestions of using @_XYZ syntax, examples: 1 2 3

To avoid confusion with custom x-fields, I could use for example @@x-_XYZ or @@x-____XYZ____ notation for comments. It would be great if some form would be documented for general use.

Whatever the syntax, it would be good it ARB-editor could highlight the comments in a different color so that they would be easier to spot.

Supporting empty lines

Thank you for the pointer. I have Prettier extension installed, and even though it retained one empty line in *.json files, it removed all empty lines in *.arb files. Adding the following .prettierrc file fixed this (including to help others with the same issue). I'll edit my OP to exclude this.

{
  "overrides": [
    {
      "files": "*.arb",
      "options": {
        "parser": "json",
        "proseWrap": "preserve"
      }
    }
  ]
}

@plaa plaa changed the title Support for ARB comments + empty lines Support for ARB comments Sep 26, 2024
@plaa
Copy link
Author

plaa commented Sep 26, 2024

Maybe all keys starting with @@ could be highlighted differently? It would also be useful to distinguish between translation keys and metadata, and would highlight any @@x- form comments as well.

@mosuem
Copy link
Collaborator

mosuem commented Sep 26, 2024

Thanks for collecting those examples, which shows this is an issue which should be solved more generally. I would propose @@comment for a top-level comment and adding a comment field to messages, next to description and type.

One of the examples linked is rather about using comments to separate the ARB file into sections. I can't think of a good solution for that, except splitting up the arb file into several smaller files, or using @@x- messages as a hack. But that goes beyong the scope of this discussion...

@mosuem mosuem mentioned this issue Sep 26, 2024
2 tasks
@plaa
Copy link
Author

plaa commented Sep 26, 2024

My original use case is actually about segmenting the file, so that it's easier for developers to see what is where. I guess @@comment could be used multiple times, but that's bad practice in JSON. 🤔

@plaa
Copy link
Author

plaa commented Sep 26, 2024

To elaborate a bit: I think your suggested comments are a great addition. One of the things I've had pains with other localization formats is the indistinction between descriptions intended for translators and comments intended for developers.

Making the file format easier to structure and edit by developers would also be great, and positioned comments / segmenting would assist in that.

@mosuem
Copy link
Collaborator

mosuem commented Sep 26, 2024

Regarding the structuring, I really think it would be best to have multiple files. The ARB file format, in its current structure, is not made to be structured internally as it consists of top-level messages only.

We could discuss adding some sort of structuring as a new feature, but that would probably be a breaking change in the format, and give two different options of structuring. Both those things don't sound great.

@plaa
Copy link
Author

plaa commented Sep 27, 2024

Yes, I agree it would be a significant change. If the structuring is semantic, it would probably mean nesting the keys, which is a big change.

For larger scopes using several files is probably best. For small scopes desiring some structure, using a @@x-____LOGIN_SCREEN____ format is probably best and pragmatic. It's syntactically correct, doesn't break any tools, is understandable and easily visible to editors. If the IDE highlights @@ with a separate color it's automatically even more visible.

Do you think highlighting @@ annotated keys with a different color would be feasible? I think it would be useful even outside the scope of comments we're discussing, as it points out metadata separately.

@mosuem
Copy link
Collaborator

mosuem commented Sep 27, 2024

I personally think that JSON dictionaries (and ARB files as an extension) should not care about ordering, so it feels weird to use comments to format this. But then again, if it works, why not :)

Do you think highlighting @@ annotated keys with a different color would be feasible? I think it would be useful even outside the scope of comments we're discussing, as it points out metadata separately.

I filed #64.

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

Successfully merging a pull request may close this issue.

2 participants