-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathinversify.code-snippets
43 lines (43 loc) · 1.71 KB
/
inversify.code-snippets
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
{
// Place your martini-ide workspace snippets here. Each snippet is defined under a snippet name and has a scope, prefix, body and
// description. Add comma separated ids of the languages where the snippet is applicable in the scope field. If scope
// is left empty or omitted, the snippet gets applied to all languages. The prefix is what is
// used to trigger the snippet and the body will be expanded and inserted. Possible variables are:
// $1, $2 for tab stops, $0 for the final cursor position, and ${1:label}, ${2:another} for placeholders.
// Placeholders with the same ids are connected.
// Example:
// "Print to console": {
// "scope": "javascript,typescript",
// "prefix": "log",
// "body": [
// "console.log('$1');",
// "$2"
// ],
// "description": "Log output to console"
// }
"inversify import": {
"prefix": "inversify",
"body": ["import { injectable, inject } from \"inversify\";"],
"description": "Imports inversify."
},
"inject": {
"prefix": "inject",
"body": ["@inject(${1:type})", "private readonly ${2:name}: ${1:type};"],
"description": "Inject a service."
},
"inject_factory": {
"prefix": "inject factory",
"body": ["@inject(\"Factory<${1:type}>\")", "private readonly ${2:name}: ($3) => ${1:type};"],
"description": "Inject a factory."
},
"bind factory": {
"prefix": "bind factory",
"body": [
"bind(\"Factory<${1:type}>\").toFactory(ctx => ($2) => {",
" const object = ctx.container.get(${1:type});",
" return object;",
"});"
],
"description": "Bind a factory."
}
}