From 8071e4d6f3a1b1b24f9d3ca06a1d9bea7674f709 Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Sun, 15 Mar 2020 14:53:37 +0530 Subject: [PATCH 01/11] finished longest string in sentance /********************************\ @bhargavmantha finished the 1st question of longest count of string in the sentance \********************************/ The approach followed is mentioned in the comments of the code please refer and fo let me know your viewes --- .directory | 6 + .eslint.js | 116 + .eslintrc | 21 + .eslintrc.json | 3 + .vscode/settings.json | 1903 ++++++++++++++++- js-exercises/.directory | 6 + js-exercises/.eslint.js | 116 + js-exercises/.eslintrc | 12 +- js-exercises/.eslintrc.json | 3 + .../longest-word-in-string/.directory | 6 + js-exercises/longest-word-in-string/README.md | 3 + .../longestWordInString.js | 56 + .../longestWordInString.test.js | 26 + js-exercises/package.json | 19 +- package.json | 14 + 15 files changed, 2302 insertions(+), 8 deletions(-) create mode 100644 .directory create mode 100644 .eslint.js create mode 100644 .eslintrc create mode 100644 .eslintrc.json create mode 100644 js-exercises/.directory create mode 100644 js-exercises/.eslint.js create mode 100644 js-exercises/.eslintrc.json create mode 100644 js-exercises/longest-word-in-string/.directory create mode 100644 js-exercises/longest-word-in-string/README.md create mode 100644 js-exercises/longest-word-in-string/longestWordInString.js create mode 100644 js-exercises/longest-word-in-string/longestWordInString.test.js diff --git a/.directory b/.directory new file mode 100644 index 00000000..8ab8667d --- /dev/null +++ b/.directory @@ -0,0 +1,6 @@ +[Dolphin] +Timestamp=2020,3,15,12,57,31 +Version=4 + +[Settings] +HiddenFilesShown=true diff --git a/.eslint.js b/.eslint.js new file mode 100644 index 00000000..bd8a8f3b --- /dev/null +++ b/.eslint.js @@ -0,0 +1,116 @@ +/** @format */ + +module.exports = { + extends: ["airbnb", "prettier", "prettier/react"], + parser: "babel-eslint", + parserOptions: { + ecmaVersion: 2020, + // Can I remove these now? + ecmaFeatures: { + impliedStrict: true, + classes: true + } + }, + env: { + browser: true, + node: true, + jquery: true, + jest: true + }, + rules: { + "no-debugger": 0, + "no-alert": 0, + "no-await-in-loop": 0, + "no-return-assign": ["error", "except-parens"], + "no-restricted-syntax": [ + 2, + "ForInStatement", + "LabeledStatement", + "WithStatement" + ], + "no-unused-vars": [ + 1, + { + ignoreSiblings: true, + argsIgnorePattern: "res|next|^err" + } + ], + "prefer-const": [ + "error", + { + destructuring: "all" + } + ], + "arrow-body-style": [2, "as-needed"], + "no-unused-expressions": [ + 2, + { + allowTaggedTemplates: true + } + ], + "no-param-reassign": [ + 2, + { + props: false + } + ], + "no-console": 0, + "import/prefer-default-export": 0, + import: 0, + "func-names": 0, + "space-before-function-paren": 0, + "comma-dangle": 0, + "max-len": 0, + "import/extensions": 0, + "no-underscore-dangle": 0, + "consistent-return": 0, + "react/display-name": 1, + "react/no-array-index-key": 0, + "react/react-in-jsx-scope": 0, + "react/prefer-stateless-function": 0, + "react/forbid-prop-types": 0, + "react/no-unescaped-entities": 0, + "jsx-a11y/accessible-emoji": 0, + "react/require-default-props": 0, + "react/jsx-filename-extension": [ + 1, + { + extensions: [".js", ".jsx"] + } + ], + radix: 0, + "no-shadow": [ + 2, + { + hoist: "all", + allow: ["resolve", "reject", "done", "next", "err", "error"] + } + ], + quotes: [ + 2, + "single", + { + avoidEscape: true, + allowTemplateLiterals: true + } + ], + "prettier/prettier": [ + "error", + { + trailingComma: "es5", + singleQuote: true, + printWidth: 80 + } + ], + "jsx-a11y/href-no-hash": "off", + "jsx-a11y/anchor-is-valid": [ + "warn", + { + aspects: ["invalidHref"] + } + ], + "react-hooks/rules-of-hooks": "error", + "react-hooks/exhaustive-deps": "warn" + }, + plugins: ["html", "prettier", "react-hooks"] +}; diff --git a/.eslintrc b/.eslintrc new file mode 100644 index 00000000..0a48840e --- /dev/null +++ b/.eslintrc @@ -0,0 +1,21 @@ +{ + "extends": "airbnb", + "env": { + "jest": true + }, + "rules": { + "no-restricted-syntax": 0, + "arrow-parens": 0, + "import/prefer-default-export": 0, + "no-console": 2, + "prettier/prettier": [ + "error", + { + "trailingComma": "es5", + "singleQuote": true, + "printWidth": 120, + "tabWidth": 8, + } + ] + } +} \ No newline at end of file diff --git a/.eslintrc.json b/.eslintrc.json new file mode 100644 index 00000000..42ac4c87 --- /dev/null +++ b/.eslintrc.json @@ -0,0 +1,3 @@ +{ + "extends": ["wesbos"] +} diff --git a/.vscode/settings.json b/.vscode/settings.json index d402eb44..61e36993 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -1,8 +1,1901 @@ +/* +please keep in mind thet these are my settings these can be ignored +*/ { - "eslint.workingDirectories": [ - { - "mode": "auto" - } + // Optional BUT IMPORTANT: If you have the prettier extension enabled for other languages like CSS and HTML, turn it off for JS since we are doing it through Eslint already + "prettier.disableLanguages": [ + "javascript", + "javascriptreact" ], - "editor.tabSize": 2 + // Editor + // When enabled, the diff editor ignores changes in leading or trailing whitespace. + "diffEditor.ignoreTrimWhitespace": true, + // Timeout in milliseconds after which diff computation is cancelled. Use 0 for no timeout. + "diffEditor.maxComputationTime": 5000, + // Controls whether the diff editor shows +/- indicators for added/removed changes. + "diffEditor.renderIndicators": true, + // Controls whether the diff editor shows the diff side by side or inline. + "diffEditor.renderSideBySide": true, + // Controls whether suggestions should be accepted on commit characters. For example, in JavaScript, the semi-colon (`;`) can be a commit character that accepts a suggestion and types that character. + "editor.acceptSuggestionOnCommitCharacter": true, + // Controls whether suggestions should be accepted on `Enter`, in addition to `Tab`. Helps to avoid ambiguity between inserting new lines or accepting suggestions. + // - on + // - smart: Only accept a suggestion with `Enter` when it makes a textual change. + // - off + "editor.acceptSuggestionOnEnter": "on", + // Controls the number of lines in the editor that can be read out by a screen reader. Warning: this has a performance implication for numbers larger than the default. + "editor.accessibilityPageSize": 10, + // Controls whether the editor should run in a mode where it is optimized for screen readers. + // - auto: The editor will use platform APIs to detect when a Screen Reader is attached. + // - on: The editor will be permanently optimized for usage with a Screen Reader. + // - off: The editor will never be optimized for usage with a Screen Reader. + "editor.accessibilitySupport": "auto", + // Controls whether the editor should automatically close brackets after the user adds an opening bracket. + // - always + // - languageDefined: Use language configurations to determine when to autoclose brackets. + // - beforeWhitespace: Autoclose brackets only when the cursor is to the left of whitespace. + // - never + "editor.autoClosingBrackets": "languageDefined", + // Controls whether the editor should type over closing quotes or brackets. + // - always + // - auto: Type over closing quotes or brackets only if they were automatically inserted. + // - never + "editor.autoClosingOvertype": "auto", + // Controls whether the editor should automatically close quotes after the user adds an opening quote. + // - always + // - languageDefined: Use language configurations to determine when to autoclose quotes. + // - beforeWhitespace: Autoclose quotes only when the cursor is to the left of whitespace. + // - never + "editor.autoClosingQuotes": "languageDefined", + // Controls whether the editor should automatically adjust the indentation when users type, paste, move or indent lines. + // - none: The editor will not insert indentation automatically. + // - keep: The editor will keep the current line's indentation. + // - brackets: The editor will keep the current line's indentation and honor language defined brackets. + // - advanced: The editor will keep the current line's indentation, honor language defined brackets and invoke special onEnterRules defined by languages. + // - full: The editor will keep the current line's indentation, honor language defined brackets, invoke special onEnterRules defined by languages, and honor indentationRules defined by languages. + "editor.autoIndent": "full", + // Controls whether the editor should automatically surround selections. + // - languageDefined: Use language configurations to determine when to automatically surround selections. + // - quotes: Surround with quotes but not brackets. + // - brackets: Surround with brackets but not quotes. + // - never + "editor.autoSurround": "languageDefined", + // Code action kinds to be run on save. + "editor.codeActionsOnSave": { + "source.fixAll": true + }, + // Controls whether the editor shows CodeLens. + "editor.codeLens": true, + // Controls whether the editor should render the inline color decorators and color picker. + "editor.colorDecorators": true, + // Enable that the selection with the mouse and keys is doing column selection. + "editor.columnSelection": false, + // Controls whether a space character is inserted when commenting. + "editor.comments.insertSpace": true, + // Controls whether syntax highlighting should be copied into the clipboard. + "editor.copyWithSyntaxHighlighting": true, + // Control the cursor animation style. + "editor.cursorBlinking": "blink", + // Controls whether the smooth caret animation should be enabled. + "editor.cursorSmoothCaretAnimation": false, + // Controls the cursor style. + "editor.cursorStyle": "line", + // Controls the minimal number of visible leading and trailing lines surrounding the cursor. Known as 'scrollOff' or `scrollOffset` in some other editors. + "editor.cursorSurroundingLines": 0, + // Controls when `cursorSurroundingLines` should be enforced. + // - default: `cursorSurroundingLines` is enforced only when triggered via the keyboard or API. + // - all: `cursorSurroundingLines` is enforced always. + "editor.cursorSurroundingLinesStyle": "default", + // Controls the width of the cursor when `editor.cursorStyle` is set to `line`. + "editor.cursorWidth": 0, + // Defines a default formatter which takes precedence over all other formatter settings. Must be the identifier of an extension contributing a formatter. + "editor.defaultFormatter": null, + // Controls whether the definition link opens element in the peek widget. + "editor.definitionLinkOpensInPeek": false, + // Controls whether `editor.tabSize#` and `#editor.insertSpaces` will be automatically detected when a file is opened based on the file contents. + "editor.detectIndentation": true, + // Controls whether the editor should allow moving selections via drag and drop. + "editor.dragAndDrop": true, + // Controls whether copying without a selection copies the current line. + "editor.emptySelectionClipboard": true, + // Scrolling speed multiplier when pressing `Alt`. + "editor.fastScrollSensitivity": 5, + // Controls whether the Find Widget should add extra lines on top of the editor. When true, you can scroll beyond the first line when the Find Widget is visible. + "editor.find.addExtraSpaceOnTop": true, + // Controls whether the find operation is carried out on selected text or the entire file in the editor. + // - never: Never turn on Find in selection automatically (default) + // - always: Always turn on Find in selection automatically + // - multiline: Turn on Find in selection automatically when multiple lines of content are selected. + "editor.find.autoFindInSelection": "never", + // Controls whether the Find Widget should read or modify the shared find clipboard on macOS. + "editor.find.globalFindClipboard": false, + // Controls whether the search string in the Find Widget is seeded from the editor selection. + "editor.find.seedSearchStringFromSelection": true, + // Controls whether the editor has code folding enabled. + "editor.folding": true, + // Controls whether the editor should highlight folded ranges. + "editor.foldingHighlight": true, + // Controls the strategy for computing folding ranges. + // - auto: Use a language-specific folding strategy if available, else the indentation-based one. + // - indentation: Use the indentation-based folding strategy. + "editor.foldingStrategy": "auto", + // Controls the font family. + "editor.fontFamily": "Consolas, 'Courier New', monospace", + // Configures font ligatures. + "editor.fontLigatures": false, + // Controls the font size in pixels. + "editor.fontSize": 14, + // Controls the font weight. + "editor.fontWeight": "normal", + // Controls whether the editor should automatically format the pasted content. A formatter must be available and the formatter should be able to format a range in a document. + "editor.formatOnPaste": true, + // Format a file on save. A formatter must be available, the file must not be saved after delay, and the editor must not be shutting down. + "editor.formatOnSave": true, + // Controls whether the editor should automatically format the line after typing. + "editor.formatOnType": true, + // Controls whether the editor should render the vertical glyph margin. Glyph margin is mostly used for debugging. + "editor.glyphMargin": true, + // Alternative command id that is being executed when the result of 'Go to Declaration' is the current location. + "editor.gotoLocation.alternativeDeclarationCommand": "editor.action.goToReferences", + // Alternative command id that is being executed when the result of 'Go to Definition' is the current location. + "editor.gotoLocation.alternativeDefinitionCommand": "editor.action.goToReferences", + // Alternative command id that is being executed when the result of 'Go to Implementation' is the current location. + "editor.gotoLocation.alternativeImplementationCommand": "", + // Alternative command id that is being executed when the result of 'Go to Reference' is the current location. + "editor.gotoLocation.alternativeReferenceCommand": "", + // Alternative command id that is being executed when the result of 'Go to Type Definition' is the current location. + "editor.gotoLocation.alternativeTypeDefinitionCommand": "editor.action.goToReferences", + // Controls the behavior the 'Go to Declaration'-command when multiple target locations exist. + // - peek: Show peek view of the results (default) + // - gotoAndPeek: Go to the primary result and show a peek view + // - goto: Go to the primary result and enable peek-less navigation to others + "editor.gotoLocation.multipleDeclarations": "peek", + // Controls the behavior the 'Go to Definition'-command when multiple target locations exist. + // - peek: Show peek view of the results (default) + // - gotoAndPeek: Go to the primary result and show a peek view + // - goto: Go to the primary result and enable peek-less navigation to others + "editor.gotoLocation.multipleDefinitions": "peek", + // Controls the behavior the 'Go to Implementations'-command when multiple target locations exist. + // - peek: Show peek view of the results (default) + // - gotoAndPeek: Go to the primary result and show a peek view + // - goto: Go to the primary result and enable peek-less navigation to others + "editor.gotoLocation.multipleImplementations": "peek", + // Controls the behavior the 'Go to References'-command when multiple target locations exist. + // - peek: Show peek view of the results (default) + // - gotoAndPeek: Go to the primary result and show a peek view + // - goto: Go to the primary result and enable peek-less navigation to others + "editor.gotoLocation.multipleReferences": "peek", + // Controls the behavior the 'Go to Type Definition'-command when multiple target locations exist. + // - peek: Show peek view of the results (default) + // - gotoAndPeek: Go to the primary result and show a peek view + // - goto: Go to the primary result and enable peek-less navigation to others + "editor.gotoLocation.multipleTypeDefinitions": "peek", + // Controls whether the cursor should be hidden in the overview ruler. + "editor.hideCursorInOverviewRuler": false, + // Controls whether the editor should highlight the active indent guide. + "editor.highlightActiveIndentGuide": true, + // Controls the delay in milliseconds after which the hover is shown. + "editor.hover.delay": 300, + // Controls whether the hover is shown. + "editor.hover.enabled": true, + // Controls whether the hover should remain visible when mouse is moved over it. + "editor.hover.sticky": true, + // Insert spaces when pressing `Tab`. This setting is overridden based on the file contents when `editor.detectIndentation` is on. + "editor.insertSpaces": true, + // Controls the letter spacing in pixels. + "editor.letterSpacing": 0, + // Enables the code action lightbulb in the editor. + "editor.lightbulb.enabled": true, + // Controls the line height. Use 0 to compute the line height from the font size. + "editor.lineHeight": 0, + // Controls the display of line numbers. + // - off: Line numbers are not rendered. + // - on: Line numbers are rendered as absolute number. + // - relative: Line numbers are rendered as distance in lines to cursor position. + // - interval: Line numbers are rendered every 10 lines. + "editor.lineNumbers": "on", + // Controls whether the editor should detect links and make them clickable. + "editor.links": true, + // Highlight matching brackets. + "editor.matchBrackets": "always", + // Controls whether the minimap is shown. + "editor.minimap.enabled": true, + // Limit the width of the minimap to render at most a certain number of columns. + "editor.minimap.maxColumn": 120, + // Controls the rendering mode of the minimap. + // - actual: The minimap will be displayed in its original size, so it might be higher than the editor. + // - cover: The minimap will always have the height of the editor and will stretch or shrink as necessary. + // - contain: The minimap will shrink as necessary to never be higher than the editor. + "editor.minimap.mode": "actual", + // Render the actual characters on a line as opposed to color blocks. + "editor.minimap.renderCharacters": true, + // Scale of content drawn in the minimap. + "editor.minimap.scale": 1, + // Controls when the minimap slider is shown. + "editor.minimap.showSlider": "mouseover", + // Controls the side where to render the minimap. + "editor.minimap.side": "right", + // A multiplier to be used on the `deltaX` and `deltaY` of mouse wheel scroll events. + "editor.mouseWheelScrollSensitivity": 1, + // Zoom the font of the editor when using mouse wheel and holding `Ctrl`. + "editor.mouseWheelZoom": false, + // The modifier to be used to add multiple cursors with the mouse. The Go To Definition and Open Link mouse gestures will adapt such that they do not conflict with the multicursor modifier. [Read more](https://code.visualstudio.com/docs/editor/codebasics#_multicursor-modifier). + // - ctrlCmd: Maps to `Control` on Windows and Linux and to `Command` on macOS. + // - alt: Maps to `Alt` on Windows and Linux and to `Option` on macOS. + "editor.multiCursorModifier": "alt", + // Controls pasting when the line count of the pasted text matches the cursor count. + // - spread: Each cursor pastes a single line of the text. + // - full: Each cursor pastes the full text. + "editor.multiCursorPaste": "spread", + // Controls whether the editor should highlight semantic symbol occurrences. + "editor.occurrencesHighlight": true, + // Controls whether a border should be drawn around the overview ruler. + "editor.overviewRulerBorder": true, + // Controls the amount of space between the bottom edge of the editor and the last line. + "editor.padding.bottom": 0, + // Controls the amount of space between the top edge of the editor and the first line. + "editor.padding.top": 0, + // Controls whether the parameter hints menu cycles or closes when reaching the end of the list. + "editor.parameterHints.cycle": false, + // Enables a pop-up that shows parameter documentation and type information as you type. + "editor.parameterHints.enabled": true, + // Controls whether to focus the inline editor or the tree in the peek widget. + // - tree: Focus the tree when opening peek + // - editor: Focus the editor when opening peek + "editor.peekWidgetDefaultFocus": "tree", + // Controls whether suggestions should automatically show up while typing. + "editor.quickSuggestions": { + "other": true, + "comments": false, + "strings": false + }, + // Controls the delay in milliseconds after which quick suggestions will show up. + "editor.quickSuggestionsDelay": 10, + // Enable/disable the ability to preview changes before renaming + "editor.rename.enablePreview": true, + // Controls whether the editor should render control characters. + "editor.renderControlCharacters": false, + // Render last line number when the file ends with a newline. + "editor.renderFinalNewline": true, + // Controls whether the editor should render indent guides. + "editor.renderIndentGuides": true, + // Controls how the editor should render the current line highlight. + // - none + // - gutter + // - line + // - all: Highlights both the gutter and the current line. + "editor.renderLineHighlight": "line", + // Controls how the editor should render whitespace characters. + // - none + // - boundary: Render whitespace characters except for single spaces between words. + // - selection: Render whitespace characters only on selected text. + // - all + "editor.renderWhitespace": "selection", + // Controls whether selections should have rounded corners. + "editor.roundedSelection": true, + // Render vertical rulers after a certain number of monospace characters. Use multiple values for multiple rulers. No rulers are drawn if array is empty. + "editor.rulers": [], + // Controls the number of extra characters beyond which the editor will scroll horizontally. + "editor.scrollBeyondLastColumn": 5, + // Controls whether the editor will scroll beyond the last line. + "editor.scrollBeyondLastLine": true, + // Controls whether the Linux primary clipboard should be supported. + "editor.selectionClipboard": true, + // Controls whether the editor should highlight matches similar to the selection. + "editor.selectionHighlight": true, + // Controls whether the semanticHighlighting is shown for the languages that support it. + "editor.semanticHighlighting.enabled": true, + // Controls when the folding controls on the gutter are shown. + // - always: Always show the folding controls. + // - mouseover: Only show the folding controls when the mouse is over the gutter. + "editor.showFoldingControls": "mouseover", + // Controls fading out of unused code. + "editor.showUnused": true, + // Controls whether the editor will scroll using an animation. + "editor.smoothScrolling": false, + // Controls whether snippets are shown with other suggestions and how they are sorted. + // - top: Show snippet suggestions on top of other suggestions. + // - bottom: Show snippet suggestions below other suggestions. + // - inline: Show snippets suggestions with other suggestions. + // - none: Do not show snippet suggestions. + "editor.snippetSuggestions": "inline", + // Keep peek editors open even when double clicking their content or when hitting `Escape`. + "editor.stablePeek": false, + // Controls whether filtering and sorting suggestions accounts for small typos. + "editor.suggest.filterGraceful": true, + // Controls whether unexpected text modifications while accepting completions should be highlighted, e.g `insertMode` is `replace` but the completion only supports `insert`. + "editor.suggest.insertHighlight": true, + // Controls whether words are overwritten when accepting completions. Note that this depends on extensions opting into this feature. + // - insert: Insert suggestion without overwriting text right of the cursor. + // - replace: Insert suggestion and overwrite text right of the cursor. + "editor.suggest.insertMode": "insert", + // Controls whether sorting favours words that appear close to the cursor. + "editor.suggest.localityBonus": false, + // Controls how many suggestions IntelliSense will show before showing a scrollbar (maximum 15). + "editor.suggest.maxVisibleSuggestions": 12, + // Controls whether remembered suggestion selections are shared between multiple workspaces and windows (needs `editor.suggestSelection`). + "editor.suggest.shareSuggestSelections": false, + // When enabled IntelliSense shows `class`-suggestions. + "editor.suggest.showClasses": true, + // When enabled IntelliSense shows `color`-suggestions. + "editor.suggest.showColors": true, + // When enabled IntelliSense shows `constant`-suggestions. + "editor.suggest.showConstants": true, + // When enabled IntelliSense shows `constructor`-suggestions. + "editor.suggest.showConstructors": true, + // When enabled IntelliSense shows `customcolor`-suggestions. + "editor.suggest.showCustomcolors": true, + // When enabled IntelliSense shows `enumMember`-suggestions. + "editor.suggest.showEnumMembers": true, + // When enabled IntelliSense shows `enum`-suggestions. + "editor.suggest.showEnums": true, + // When enabled IntelliSense shows `event`-suggestions. + "editor.suggest.showEvents": true, + // When enabled IntelliSense shows `field`-suggestions. + "editor.suggest.showFields": true, + // When enabled IntelliSense shows `file`-suggestions. + "editor.suggest.showFiles": true, + // When enabled IntelliSense shows `folder`-suggestions. + "editor.suggest.showFolders": true, + // When enabled IntelliSense shows `function`-suggestions. + "editor.suggest.showFunctions": true, + // Controls whether to show or hide icons in suggestions. + "editor.suggest.showIcons": true, + // When enabled IntelliSense shows `interface`-suggestions. + "editor.suggest.showInterfaces": true, + // When enabled IntelliSense shows `keyword`-suggestions. + "editor.suggest.showKeywords": true, + // When enabled IntelliSense shows `method`-suggestions. + "editor.suggest.showMethods": true, + // When enabled IntelliSense shows `module`-suggestions. + "editor.suggest.showModules": true, + // When enabled IntelliSense shows `operator`-suggestions. + "editor.suggest.showOperators": true, + // When enabled IntelliSense shows `property`-suggestions. + "editor.suggest.showProperties": true, + // When enabled IntelliSense shows `reference`-suggestions. + "editor.suggest.showReferences": true, + // When enabled IntelliSense shows `snippet`-suggestions. + "editor.suggest.showSnippets": true, + // When enabled IntelliSense shows `struct`-suggestions. + "editor.suggest.showStructs": true, + // When enabled IntelliSense shows `typeParameter`-suggestions. + "editor.suggest.showTypeParameters": true, + // When enabled IntelliSense shows `unit`-suggestions. + "editor.suggest.showUnits": true, + // When enabled IntelliSense shows `value`-suggestions. + "editor.suggest.showValues": true, + // When enabled IntelliSense shows `variable`-suggestions. + "editor.suggest.showVariables": true, + // When enabled IntelliSense shows `text`-suggestions. + "editor.suggest.showWords": true, + // Controls whether an active snippet prevents quick suggestions. + "editor.suggest.snippetsPreventQuickSuggestions": true, + // Font size for the suggest widget. When set to `0`, the value of `editor.fontSize` is used. + "editor.suggestFontSize": 0, + // Line height for the suggest widget. When set to `0`, the value of `editor.lineHeight` is used. + "editor.suggestLineHeight": 0, + // Controls whether suggestions should automatically show up when typing trigger characters. + "editor.suggestOnTriggerCharacters": true, + // Controls how suggestions are pre-selected when showing the suggest list. + // - first: Always select the first suggestion. + // - recentlyUsed: Select recent suggestions unless further typing selects one, e.g. `console.| -> console.log` because `log` has been completed recently. + // - recentlyUsedByPrefix: Select suggestions based on previous prefixes that have completed those suggestions, e.g. `co -> console` and `con -> const`. + "editor.suggestSelection": "recentlyUsed", + // Enables tab completions. + // - on: Tab complete will insert the best matching suggestion when pressing tab. + // - off: Disable tab completions. + // - onlySnippets: Tab complete snippets when their prefix match. Works best when 'quickSuggestions' aren't enabled. + "editor.tabCompletion": "off", + // The number of spaces a tab is equal to. This setting is overridden based on the file contents when `editor.detectIndentation` is on. + "editor.tabSize": 4, + // Overrides editor colors and font style from the currently selected color theme. + "editor.tokenColorCustomizations": {}, + // Remove trailing auto inserted whitespace. + "editor.trimAutoWhitespace": true, + // Controls whether clicking on the empty content after a folded line will unfold the line. + "editor.unfoldOnClickInEmptyContent": false, + // Inserting and deleting whitespace follows tab stops. + "editor.useTabStops": true, + // Controls whether completions should be computed based on words in the document. + "editor.wordBasedSuggestions": true, + // Characters that will be used as word separators when doing word related navigations or operations. + "editor.wordSeparators": "`~!@#$%^&*()-=+[{]}\\|;:'\",.<>/?", + // Controls how lines should wrap. + // - off: Lines will never wrap. + // - on: Lines will wrap at the viewport width. + // - wordWrapColumn: Lines will wrap at `editor.wordWrapColumn`. + // - bounded: Lines will wrap at the minimum of viewport and `editor.wordWrapColumn`. + "editor.wordWrap": "off", + // Controls the wrapping column of the editor when `editor.wordWrap` is `wordWrapColumn` or `bounded`. + "editor.wordWrapColumn": 80, + // Controls the indentation of wrapped lines. + // - none: No indentation. Wrapped lines begin at column 1. + // - same: Wrapped lines get the same indentation as the parent. + // - indent: Wrapped lines get +1 indentation toward the parent. + // - deepIndent: Wrapped lines get +2 indentation toward the parent. + "editor.wrappingIndent": "same", + // Controls the algorithm that computes wrapping points. + // - simple: Assumes that all characters are of the same width. This is a fast algorithm that works correctly for monospace fonts and certain scripts (like Latin characters) where glyphs are of equal width. + // - advanced: Delegates wrapping points computation to the browser. This is a slow algorithm, that might cause freezes for large files, but it works correctly in all cases. + "editor.wrappingStrategy": "simple", + // SCM + // Controls whether inline actions are always visible in the Source Control view. + "scm.alwaysShowActions": false, + // Controls whether to show the Source Control Provider section even when there's only one Provider registered. + "scm.alwaysShowProviders": false, + // Controls whether the SCM view should automatically reveal and select files when opening them. + "scm.autoReveal": true, + // Controls the Source Control count badge. + // - all: Show the sum of all Source Control Providers count badges. + // - focused: Show the count badge of the focused Source Control Provider. + // - off: Disable the Source Control count badge. + "scm.countBadge": "all", + // Controls the default Source Control repository view mode. + // - tree: Show the repository changes as a tree. + // - list: Show the repository changes as a list. + "scm.defaultViewMode": "list", + // Controls diff decorations in the editor. + // - all: Show the diff decorations in all available locations. + // - gutter: Show the diff decorations only in the editor gutter. + // - overview: Show the diff decorations only in the overview ruler. + // - minimap: Show the diff decorations only in the minimap. + // - none: Do not show the diff decorations. + "scm.diffDecorations": "all", + // Controls the visibility of the Source Control diff decorator in the gutter. + // - always: Show the diff decorator in the gutter at all times. + // - hover: Show the diff decorator in the gutter only on hover. + "scm.diffDecorationsGutterVisibility": "always", + // Controls the width(px) of diff decorations in gutter (added & modified). + "scm.diffDecorationsGutterWidth": 3, + // Controls how many providers are visible in the Source Control Provider section. Set to `0` to be able to manually resize the view. + "scm.providers.visible": 10, + // If set, automatically switch to the preferred color theme based on the OS appearance. + "window.autoDetectColorScheme": false, + // Workbench + // Controls the visibility of the activity bar in the workbench. + "workbench.activityBar.visible": true, + // Overrides colors from the currently selected color theme. + "workbench.colorCustomizations": {}, + // Specifies the color theme used in the workbench. + "workbench.colorTheme": "Monokai Pro (Filter Machine)", + // Controls the number of recently used commands to keep in history for the command palette. Set to 0 to disable command history. + "workbench.commandPalette.history": 50, + // Controls whether the last typed input to the command palette should be restored when opening it the next time. + "workbench.commandPalette.preserveInput": false, + // Controls if the centered layout should automatically resize to maximum width when more than one group is open. Once only one group is open it will resize back to the original centered width. + "workbench.editor.centeredLayoutAutoResize": true, + // Controls the behavior of empty editor groups when the last tab in the group is closed. When enabled, empty groups will automatically close. When disabled, empty groups will remain part of the grid. + "workbench.editor.closeEmptyGroups": true, + // Controls whether editors showing a file that was opened during the session should close automatically when getting deleted or renamed by some other process. Disabling this will keep the editor open on such an event. Note that deleting from within the application will always close the editor and that dirty files will never close to preserve your data. + "workbench.editor.closeOnFileDelete": false, + // Controls whether opened editors show as preview. Preview editors are reused until they are pinned (e.g. via double click or editing) and show up with an italic font style. + "workbench.editor.enablePreview": true, + // Controls whether editors opened from Quick Open show as preview. Preview editors are reused until they are pinned (e.g. via double click or editing). + "workbench.editor.enablePreviewFromQuickOpen": true, + // Controls whether tabs are closed in most recently used order or from left to right. + "workbench.editor.focusRecentEditorAfterClose": true, + // Controls whether a top border is drawn on modified (dirty) editor tabs or not. + "workbench.editor.highlightModifiedTabs": false, + // Controls the format of the label for an editor. + // - default: Show the name of the file. When tabs are enabled and two files have the same name in one group the distinguishing sections of each file's path are added. When tabs are disabled, the path relative to the workspace folder is shown if the editor is active. + // - short: Show the name of the file followed by its directory name. + // - medium: Show the name of the file followed by its path relative to the workspace folder. + // - long: Show the name of the file followed by its absolute path. + "workbench.editor.labelFormat": "default", + // Controls if the number of opened editors should be limited or not. When enabled, less recently used editors that are not dirty will close to make space for newly opening editors. + "workbench.editor.limit.enabled": false, + // Controls if the limit of maximum opened editors should apply per editor group or across all editor groups. + "workbench.editor.limit.perEditorGroup": false, + // Controls the maximum number of opened editors. Use the `workbench.editor.limit.perEditorGroup` setting to control this limit per editor group or across all groups. + "workbench.editor.limit.value": 10, + // Navigate between open files using mouse buttons four and five if provided. + "workbench.editor.mouseBackForwardToNavigate": true, + // Controls where editors open. Select `left` or `right` to open editors to the left or right of the currently active one. Select `first` or `last` to open editors independently from the currently active one. + "workbench.editor.openPositioning": "right", + // Controls the default direction of editors that are opened side by side (e.g. from the explorer). By default, editors will open on the right hand side of the currently active one. If changed to `down`, the editors will open below the currently active one. + "workbench.editor.openSideBySideDirection": "right", + // Restores the last view state (e.g. scroll position) when re-opening files after they have been closed. + "workbench.editor.restoreViewState": true, + // Controls whether an editor is revealed in any of the visible groups if opened. If disabled, an editor will prefer to open in the currently active editor group. If enabled, an already opened editor will be revealed instead of opened again in the currently active editor group. Note that there are some cases where this setting is ignored, e.g. when forcing an editor to open in a specific group or to the side of the currently active group. + "workbench.editor.revealIfOpen": false, + // Controls whether opened editors should show with an icon or not. This requires an icon theme to be enabled as well. + "workbench.editor.showIcons": true, + // Controls whether opened editors should show in tabs or not. + "workbench.editor.showTabs": true, + // Controls the sizing of editor groups when splitting them. + // - distribute: Splits all the editor groups to equal parts. + // - split: Splits the active editor group to equal parts. + "workbench.editor.splitSizing": "distribute", + // Controls the position of the editor's tabs close buttons, or disables them when set to 'off'. + "workbench.editor.tabCloseButton": "right", + // Controls the sizing of editor tabs. + // - fit: Always keep tabs large enough to show the full editor label. + // - shrink: Allow tabs to get smaller when the available space is not enough to show all tabs at once. + "workbench.editor.tabSizing": "fit", + // Controls font aliasing method in the workbench. + // - default: Sub-pixel font smoothing. On most non-retina displays this will give the sharpest text. + // - antialiased: Smooth the font on the level of the pixel, as opposed to the subpixel. Can make the font appear lighter overall. + // - none: Disables font smoothing. Text will show with jagged sharp edges. + // - auto: Applies `default` or `antialiased` automatically based on the DPI of displays. + "workbench.fontAliasing": "default", + // Controls the format of the label for an untitled editor. + // - content: The name of the untitled file is derived from the contents of its first line unless it has an associated file path. It will fallback to the name in case the line is empty or contains no word characters. + // - name: The name of the untitled file is not derived from the contents of the file. + "workbench.editor.untitled.labelFormat": "content", + // Specifies the icon theme used in the workbench or 'null' to not show any file icons. + // - null: No file icons + // - vs-minimal + // - vs-seti + "workbench.iconTheme": "material-icon-theme", + // Controls whether keyboard navigation in lists and trees is automatically triggered simply by typing. If set to `false`, keyboard navigation is only triggered when executing the `list.toggleKeyboardNavigation` command, for which you can assign a keyboard shortcut. + "workbench.list.automaticKeyboardNavigation": true, + // Controls whether lists and trees support horizontal scrolling in the workbench. + "workbench.list.horizontalScrolling": false, + // Controls the keyboard navigation style for lists and trees in the workbench. Can be simple, highlight and filter. + // - simple: Simple keyboard navigation focuses elements which match the keyboard input. Matching is done only on prefixes. + // - highlight: Highlight keyboard navigation highlights elements which match the keyboard input. Further up and down navigation will traverse only the highlighted elements. + // - filter: Filter keyboard navigation will filter out and hide all the elements which do not match the keyboard input. + "workbench.list.keyboardNavigation": "highlight", + // The modifier to be used to add an item in trees and lists to a multi-selection with the mouse (for example in the explorer, open editors and scm view). The 'Open to Side' mouse gestures - if supported - will adapt such that they do not conflict with the multiselect modifier. + // - ctrlCmd: Maps to `Control` on Windows and Linux and to `Command` on macOS. + // - alt: Maps to `Alt` on Windows and Linux and to `Option` on macOS. + "workbench.list.multiSelectModifier": "ctrlCmd", + // Controls how to open items in trees and lists using the mouse (if supported). For parents with children in trees, this setting will control if a single click expands the parent or a double click. Note that some trees and lists might choose to ignore this setting if it is not applicable. + "workbench.list.openMode": "singleClick", + // Controls the default location of the panel (terminal, debug console, output, problems). It can either show at the bottom, right, or left of the workbench. + "workbench.panel.defaultLocation": "bottom", + // Specifies the preferred color theme for dark OS appearance when 'window.autoDetectColorScheme' is enabled. + "workbench.preferredDarkColorTheme": "Default Dark+", + // Specifies the preferred color theme used in high contrast mode when 'window.autoDetectHighContrast' is enabled. + "workbench.preferredHighContrastColorTheme": "Default High Contrast", + // Specifies the preferred color theme for light OS appearance when 'window.autoDetectColorScheme' is enabled. + "workbench.preferredLightColorTheme": "Default Light+", + // Controls whether Quick Open should close automatically once it loses focus. + "workbench.quickOpen.closeOnFocusLost": true, + // Controls whether the last typed input to Quick Open should be restored when opening it the next time. + "workbench.quickOpen.preserveInput": false, + // Determines which settings editor to use by default. + // - ui: Use the settings UI editor. + // - json: Use the JSON file editor. + "workbench.settings.editor": "ui", + // Controls whether to enable the natural language search mode for settings. The natural language search is provided by a Microsoft online service. + "workbench.settings.enableNaturalLanguageSearch": true, + // Controls whether opening keybinding settings also opens an editor showing all default keybindings. + "workbench.settings.openDefaultKeybindings": false, + // Controls whether opening settings also opens an editor showing all default settings. + "workbench.settings.openDefaultSettings": false, + // Controls the behavior of the settings editor Table of Contents while searching. + // - hide: Hide the Table of Contents while searching. + // - filter: Filter the Table of Contents to just categories that have matching settings. Clicking a category will filter the results to that category. + "workbench.settings.settingsSearchTocBehavior": "filter", + // Controls whether to use the split JSON editor when editing settings as JSON. + "workbench.settings.useSplitJSON": false, + // Controls the location of the sidebar and activity bar. They can either show on the left or right of the workbench. + "workbench.sideBar.location": "left", + // Controls which editor is shown at startup, if none are restored from the previous session. + // - none: Start without an editor. + // - welcomePage: Open the Welcome page (default). + // - readme: Open the README when opening a folder that contains one, fallback to 'welcomePage' otherwise. + // - newUntitledFile: Open a new untitled file (only applies when opening an empty workspace). + // - welcomePageInEmptyWorkbench: Open the Welcome page when opening an empty workbench. + "workbench.startupEditor": "welcomePage", + // Controls the visibility of the status bar at the bottom of the workbench. + "workbench.statusBar.visible": true, + // When enabled, will show the watermark tips when no editor is open. + "workbench.tips.enabled": true, + // Controls tree indentation in pixels. + "workbench.tree.indent": 8, + // Controls whether the tree should render indent guides. + "workbench.tree.renderIndentGuides": "onHover", + // Controls the visibility of view header actions. View header actions may either be always visible, or only visible when that view is focused or hovered over. + "workbench.view.alwaysShowHeaderActions": false, + // Window + // If enabled, will automatically change to high contrast theme if Windows is using a high contrast theme, and to dark theme when switching away from a Windows high contrast theme. + "window.autoDetectHighContrast": true, + // If enabled, clicking on an inactive window will both activate the window and trigger the element under the mouse if it is clickable. If disabled, clicking anywhere on an inactive window will activate it only and a second click is required on the element. + "window.clickThroughInactive": true, + // Controls whether closing the last editor should also close the window. This setting only applies for windows that do not show folders. + "window.closeWhenEmpty": false, + // Controls whether the menu bar will be focused by pressing the Alt-key. This setting has no effect on toggling the menu bar with the Alt-key. + "window.customMenuBarAltFocus": true, + // If enabled, double clicking the application icon in the title bar will close the window and the window cannot be dragged by the icon. This setting only has an effect when `window.titleBarStyle` is set to `custom`. + "window.doubleClickIconToClose": false, + // Controls if native full-screen should be used on macOS. Disable this option to prevent macOS from creating a new space when going full-screen. + "window.nativeFullScreen": true, + // Enables macOS Sierra window tabs. Note that changes require a full restart to apply and that native tabs will disable a custom title bar style if configured. + "window.nativeTabs": false, + // Controls whether the main menus can be opened via Alt-key shortcuts. Disabling mnemonics allows to bind these Alt-key shortcuts to editor commands instead. + "window.enableMenuBarMnemonics": true, + // Control the visibility of the menu bar. A setting of 'toggle' means that the menu bar is hidden and a single press of the Alt key will show it. By default, the menu bar will be visible, unless the window is full screen. + // - default: Menu is only hidden in full screen mode. + // - visible: Menu is always visible even in full screen mode. + // - toggle: Menu is hidden but can be displayed via Alt key. + // - hidden: Menu is always hidden. + // - compact: Menu is displayed as a compact button in the sidebar. This value is ignored when 'window.titleBarStyle' is 'native'. + "window.menuBarVisibility": "default", + // Controls the dimensions of opening a new window when at least one window is already opened. Note that this setting does not have an impact on the first window that is opened. The first window will always restore the size and location as you left it before closing. + // - default: Open new windows in the center of the screen. + // - inherit: Open new windows with same dimension as last active one. + // - offset: Open new windows with same dimension as last active one with an offset position. + // - maximized: Open new windows maximized. + // - fullscreen: Open new windows in full screen mode. + "window.newWindowDimensions": "default", + // Controls whether files should open in a new window. + // Note that there can still be cases where this setting is ignored (e.g. when using the `--new-window` or `--reuse-window` command line option). + // - on: Files will open in a new window. + // - off: Files will open in the window with the files' folder open or the last active window. + // - default: Files will open in a new window unless picked from within the application (e.g. via the File menu). + "window.openFilesInNewWindow": "off", + // Controls whether folders should open in a new window or replace the last active window. + // Note that there can still be cases where this setting is ignored (e.g. when using the `--new-window` or `--reuse-window` command line option). + // - on: Folders will open in a new window. + // - off: Folders will replace the last active window. + // - default: Folders will open in a new window unless a folder is picked from within the application (e.g. via the File menu). + "window.openFoldersInNewWindow": "default", + // Controls whether a new empty window should open when starting a second instance without arguments or if the last running instance should get focus. + // Note that there can still be cases where this setting is ignored (e.g. when using the `--new-window` or `--reuse-window` command line option). + // - on: Open a new empty window. + // - off: Focus the last active running instance. + "window.openWithoutArgumentsInNewWindow": "on", + // Controls whether a window should restore to full screen mode if it was exited in full screen mode. + "window.restoreFullscreen": false, + // Controls how windows are being reopened after a restart. + // - all: Reopen all windows. + // - folders: Reopen all folders. Empty workspaces will not be restored. + // - one: Reopen the last active window. + // - none: Never reopen a window. Always start with an empty one. + "window.restoreWindows": "all", + // Controls the window title based on the active editor. Variables are substituted based on the context: + // - `${activeEditorShort}`: the file name (e.g. myFile.txt). + // - `${activeEditorMedium}`: the path of the file relative to the workspace folder (e.g. myFolder/myFileFolder/myFile.txt). + // - `${activeEditorLong}`: the full path of the file (e.g. /Users/Development/myFolder/myFileFolder/myFile.txt). + // - `${activeFolderShort}`: the name of the folder the file is contained in (e.g. myFileFolder). + // - `${activeFolderMedium}`: the path of the folder the file is contained in, relative to the workspace folder (e.g. myFolder/myFileFolder). + // - `${activeFolderLong}`: the full path of the folder the file is contained in (e.g. /Users/Development/myFolder/myFileFolder). + // - `${folderName}`: name of the workspace folder the file is contained in (e.g. myFolder). + // - `${folderPath}`: file path of the workspace folder the file is contained in (e.g. /Users/Development/myFolder). + // - `${rootName}`: name of the workspace (e.g. myFolder or myWorkspace). + // - `${rootPath}`: file path of the workspace (e.g. /Users/Development/myWorkspace). + // - `${appName}`: e.g. VS Code. + // - `${remoteName}`: e.g. SSH + // - `${dirty}`: a dirty indicator if the active editor is dirty. + // - `${separator}`: a conditional separator (" - ") that only shows when surrounded by variables with values or static text. + "window.title": "${dirty}${activeEditorShort}${separator}${rootName}${separator}${appName}", + // Adjust the appearance of the window title bar. On Linux and Windows, this setting also affects the application and context menu appearances. Changes require a full restart to apply. + "window.titleBarStyle": "custom", + // Adjust the zoom level of the window. The original size is 0 and each increment above (e.g. 1) or below (e.g. -1) represents zooming 20% larger or smaller. You can also enter decimals to adjust the zoom level with a finer granularity. + "window.zoomLevel": 0, + // Files + // Configure file associations to languages (e.g. `"*.extension": "html"`). These have precedence over the default associations of the languages installed. + "files.associations": {}, + // When enabled, the editor will attempt to guess the character set encoding when opening files. This setting can also be configured per language. + "files.autoGuessEncoding": false, + // Controls auto save of dirty editors. Read more about autosave [here](https://code.visualstudio.com/docs/editor/codebasics#_save-auto-save). + // - off: A dirty editor is never automatically saved. + // - afterDelay: A dirty editor is automatically saved after the configured `files.autoSaveDelay`. + // - onFocusChange: A dirty editor is automatically saved when the editor loses focus. + // - onWindowChange: A dirty editor is automatically saved when the window loses focus. + "files.autoSave": "off", + // Controls the delay in ms after which a dirty editor is saved automatically. Only applies when `files.autoSave` is set to `afterDelay`. + "files.autoSaveDelay": 1000, + // The default language mode that is assigned to new files. If configured to `${activeEditorLanguage}`, will use the language mode of the currently active text editor if any. + "files.defaultLanguage": "", + // Moves files/folders to the OS trash (recycle bin on Windows) when deleting. Disabling this will delete files/folders permanently. + "files.enableTrash": true, + // The default character set encoding to use when reading and writing files. This setting can also be configured per language. + "files.encoding": "utf8", + // The default end of line character. + // - \n: LF + // - \r\n: CRLF + // - auto: Uses operating system specific end of line character. + "files.eol": "auto", + // Configure glob patterns for excluding files and folders. For example, the files explorer decides which files and folders to show or hide based on this setting. + "files.exclude": { + "**/.git": true, + "**/.svn": true, + "**/.hg": true, + "**/CVS": true, + "**/.DS_Store": true + }, + // Controls whether unsaved files are remembered between sessions, allowing the save prompt when exiting the editor to be skipped. + // - off: Disable hot exit. + // - onExit: Hot exit will be triggered when the last window is closed on Windows/Linux or when the `workbench.action.quit` command is triggered (command palette, keybinding, menu). All windows with backups will be restored upon next launch. + // - onExitAndWindowClose: Hot exit will be triggered when the last window is closed on Windows/Linux or when the `workbench.action.quit` command is triggered (command palette, keybinding, menu), and also for any window with a folder opened regardless of whether it's the last window. All windows without folders opened will be restored upon next launch. To restore folder windows as they were before shutdown set `window.restoreWindows` to `all`. + "files.hotExit": "onExit", + // When enabled, insert a final new line at the end of the file when saving it. + "files.insertFinalNewline": false, + // Controls the memory available to VS Code after restart when trying to open large files. Same effect as specifying `--max-memory=NEWSIZE` on the command line. + "files.maxMemoryForLargeFilesMB": 4096, + // Timeout in milliseconds after which file participants for create, rename, and delete are cancelled. Use `0` to disable participants. + "files.participants.timeout": 5000, + // A save conflict can occur when a file is saved to disk that was changed by another program in the meantime. To prevent data loss, the user is asked to compare the changes in the editor with the version on disk. This setting should only be changed if you frequently encounter save conflict errors and may result in data loss if used without caution. + // - askUser: Will refuse to save and ask for resolving the save conflict manually. + // - overwriteFileOnDisk: Will resolve the save conflict by overwriting the file on disk with the changes in the editor. + "files.saveConflictResolution": "askUser", + // When enabled, will trim all new lines after the final new line at the end of the file when saving it. + "files.trimFinalNewlines": false, + // When enabled, will trim trailing whitespace when saving a file. + "files.trimTrailingWhitespace": false, + // Configure glob patterns of file paths to exclude from file watching. Patterns must match on absolute paths (i.e. prefix with ** or the full path to match properly). Changing this setting requires a restart. When you experience Code consuming lots of cpu time on startup, you can exclude large folders to reduce the initial load. + "files.watcherExclude": { + "**/.git/objects/**": true, + "**/.git/subtree-cache/**": true, + "**/node_modules/*/**": true + }, + // Screencast Mode + // Only show keyboard shortcuts in Screencast Mode. + "screencastMode.onlyKeyboardShortcuts": false, + // Controls the vertical offset of the screencast mode overlay from the bottom as a percentage of the workbench height. + "screencastMode.verticalOffset": 20, + // Zen Mode + // Controls whether turning on Zen Mode also centers the layout. + "zenMode.centerLayout": true, + // Controls whether turning on Zen Mode also puts the workbench into full screen mode. + "zenMode.fullScreen": true, + // Controls whether turning on Zen Mode also hides the activity bar at the left of the workbench. + "zenMode.hideActivityBar": true, + // Controls whether turning on Zen Mode also hides the editor line numbers. + "zenMode.hideLineNumbers": true, + // Controls whether turning on Zen Mode also hides the status bar at the bottom of the workbench. + "zenMode.hideStatusBar": true, + // Controls whether turning on Zen Mode also hides workbench tabs. + "zenMode.hideTabs": true, + // Controls whether a window should restore to zen mode if it was exited in zen mode. + "zenMode.restore": false, + // Controls whether notifications are shown while in zen mode. If true, only error notifications will pop out. + "zenMode.silentNotifications": true, + // File Explorer + // Controls whether the explorer should automatically reveal and select files when opening them. + "explorer.autoReveal": true, + // Controls whether the explorer should render folders in a compact form. In such a form, single child folders will be compressed in a combined tree element. Useful for Java package structures, for example. + "explorer.compactFolders": true, + // Controls whether the explorer should ask for confirmation when deleting a file via the trash. + "explorer.confirmDelete": true, + // Controls whether the explorer should ask for confirmation to move files and folders via drag and drop. + "explorer.confirmDragAndDrop": true, + // Controls whether file decorations should use badges. + "explorer.decorations.badges": true, + // Controls whether file decorations should use colors. + "explorer.decorations.colors": true, + // Controls whether the explorer should allow to move files and folders via drag and drop. + "explorer.enableDragAndDrop": true, + // Controls what naming strategy to use when a giving a new name to a duplicated explorer item on paste. + // - simple: Appends the word "copy" at the end of the duplicated name potentially followed by a number + // - smart: Adds a number at the end of the duplicated name. If some number is already part of the name, tries to increase that number + "explorer.incrementalNaming": "simple", + // Number of editors shown in the Open Editors pane. + "explorer.openEditors.visible": 9, + // Controls sorting order of files and folders in the explorer. + // - default: Files and folders are sorted by their names, in alphabetical order. Folders are displayed before files. + // - mixed: Files and folders are sorted by their names, in alphabetical order. Files are interwoven with folders. + // - filesFirst: Files and folders are sorted by their names, in alphabetical order. Files are displayed before folders. + // - type: Files and folders are sorted by their extensions, in alphabetical order. Folders are displayed before files. + // - modified: Files and folders are sorted by last modified date, in descending order. Folders are displayed before files. + "explorer.sortOrder": "default", + // Search + // Controls the positioning of the actionbar on rows in the search view. + // - auto: Position the actionbar to the right when the search view is narrow, and immediately after the content when the search view is wide. + // - right: Always position the actionbar to the right. + "search.actionsPosition": "auto", + // Controls whether the search results will be collapsed or expanded. + // - auto: Files with less than 10 results are expanded. Others are collapsed. + // - alwaysCollapse + // - alwaysExpand + "search.collapseResults": "alwaysExpand", + // Configure glob patterns for excluding files and folders in searches. Inherits all glob patterns from the `files.exclude` setting. + "search.exclude": { + "**/node_modules": true, + "**/bower_components": true, + "**/*.code-search": true + }, + // Controls whether to follow symlinks while searching. + "search.followSymlinks": true, + // Controls whether the search view should read or modify the shared find clipboard on macOS. + "search.globalFindClipboard": false, + // Whether to include results from recently opened files in the file results for Quick Open. + "search.quickOpen.includeHistory": true, + // Whether to include results from a global symbol search in the file results for Quick Open. + "search.quickOpen.includeSymbols": false, + // Configure effect of double clicking a result in a search editor. + // - selectWord: Double clicking selects the word under the cursor. + // - goToLocation: Double clicking opens the result in the active editor group. + // - openLocationToSide: Double clicking opens the result in the editor group to the side, creating one if it does not yet exist. + "search.searchEditor.doubleClickBehaviour": "goToLocation", + // Search all files as you type. + "search.searchOnType": true, + // When `search.searchOnType` is enabled, controls the timeout in milliseconds between a character being typed and the search starting. Has no effect when `search.searchOnType` is disabled. + "search.searchOnTypeDebouncePeriod": 300, + // Controls whether to show line numbers for search results. + "search.showLineNumbers": false, + // Search case-insensitively if the pattern is all lowercase, otherwise, search case-sensitively. + "search.smartCase": false, + // Controls sorting order of search results. + // - default: Results are sorted by folder and file names, in alphabetical order. + // - fileNames: Results are sorted by file names ignoring folder order, in alphabetical order. + // - type: Results are sorted by file extensions, in alphabetical order. + // - modified: Results are sorted by file last modified date, in descending order. + // - countDescending: Results are sorted by count per file, in descending order. + // - countAscending: Results are sorted by count per file, in ascending order. + "search.sortOrder": "default", + // Controls whether to use global `.gitignore` and `.ignore` files when searching for files. + "search.useGlobalIgnoreFiles": false, + // Controls whether to use `.gitignore` and `.ignore` files when searching for files. + "search.useIgnoreFiles": true, + // Controls whether to open Replace Preview when selecting or replacing a match. + "search.useReplacePreview": true, + // HTTP + // The proxy setting to use. If not set, will be inherited from the `http_proxy` and `https_proxy` environment variables. + "http.proxy": "", + // The value to send as the `Proxy-Authorization` header for every network request. + "http.proxyAuthorization": null, + // Controls whether the proxy server certificate should be verified against the list of supplied CAs. + "http.proxyStrictSSL": true, + // Use the proxy support for extensions. + // - off: Disable proxy support for extensions. + // - on: Enable proxy support for extensions. + // - override: Enable proxy support for extensions, override request options. + "http.proxySupport": "override", + // Controls whether CA certificates should be loaded from the OS. (On Windows and macOS a reload of the window is required after turning this off.) + "http.systemCertificates": true, + // Keyboard + // Controls the dispatching logic for key presses to use either `code` (recommended) or `keyCode`. + "keyboard.dispatch": "code", + // Enables the macOS touchbar buttons on the keyboard if available. + "keyboard.touchbar.enabled": true, + // A set of identifiers for entries in the touchbar that should not show up (for example `workbench.action.navigateBack`. + "keyboard.touchbar.ignored": [], + // Update + // Enable to download and install new VS Code Versions in the background on Windows + "update.enableWindowsBackgroundUpdates": true, + // Configure whether you receive automatic updates. Requires a restart after change. The updates are fetched from a Microsoft online service. + // - none: Disable updates. + // - manual: Disable automatic background update checks. Updates will be available if you manually check for updates. + // - start: Check for updates only on startup. Disable automatic background update checks. + // - default: Enable automatic update checks. Code will check for updates automatically and periodically. + "update.mode": "default", + // Show Release Notes after an update. The Release Notes are fetched from a Microsoft online service. + "update.showReleaseNotes": true, + // Debug + // Allow setting breakpoints in any file. + "debug.allowBreakpointsEverywhere": false, + // Controls if the debug console should be automatically closed when the debug session ends. + "debug.console.closeOnEnd": false, + // Controls the font family in the debug console. + "debug.console.fontFamily": "default", + // Controls the font size in pixels in the debug console. + "debug.console.fontSize": 14, + // Controls if the debug console should suggest previously typed input. + "debug.console.historySuggestions": true, + // Controls the line height in pixels in the debug console. Use 0 to compute the line height from the font size. + "debug.console.lineHeight": 0, + // Controls if the lines should wrap in the debug console. + "debug.console.wordWrap": true, + // Controls whether the workbench window should be focused when the debugger breaks. + "debug.focusWindowOnBreak": true, + // Show variable values inline in editor while debugging. + "debug.inlineValues": false, + // Controls when the internal debug console should open. + "debug.internalConsoleOptions": "openOnFirstSessionStart", + // Controls what to do when errors are encountered after running a preLaunchTask. + // - debugAnyway: Ignore task errors and start debugging. + // - showErrors: Show the Problems view and do not start debugging. + // - prompt: Prompt user. + // - cancel: Cancel debugging. + "debug.onTaskErrors": "prompt", + // Controls when the debug view should open. + "debug.openDebug": "openOnSessionStart", + // Automatically open the explorer view at the end of a debug session. + "debug.openExplorerOnEnd": false, + // Controls whether breakpoints should be shown in the overview ruler. + "debug.showBreakpointsInOverviewRuler": false, + // Controls whether inline breakpoints candidate decorations should be shown in the editor while debugging. + "debug.showInlineBreakpointCandidates": true, + // Controls when the debug status bar should be visible. + // - never: Never show debug in status bar + // - always: Always show debug in status bar + // - onFirstSessionStart: Show debug in status bar only after debug was started for the first time + "debug.showInStatusBar": "onFirstSessionStart", + // Controls whether the debug sub-sessions are shown in the debug tool bar. When this setting is false the stop command on a sub-session will also stop the parent session. + "debug.showSubSessionsInToolBar": false, + // Controls the location of the debug toolbar. Either `floating` in all views, `docked` in the debug view, or `hidden`. + "debug.toolBarLocation": "floating", + // Global debug launch configuration. Should be used as an alternative to 'launch.json' that is shared across workspaces. + "launch": { + "configurations": [], + "compounds": [] + }, + // HTML + // Enable/disable autoclosing of HTML tags. + "html.autoClosingTags": true, + // A list of relative file paths pointing to JSON files following the custom data format. + // VS Code loads custom data on startup to enhance its HTML support for the custom HTML tags, attributes and attribute values you specify in the JSON files. + // The file paths are relative to workspace and only workspace folder settings are considered. + "html.customData": [], + // List of tags, comma separated, where the content shouldn't be reformatted. `null` defaults to the `pre` tag. + "html.format.contentUnformatted": "pre,code,textarea", + // Enable/disable default HTML formatter. + "html.format.enable": true, + // End with a newline. + "html.format.endWithNewline": false, + // List of tags, comma separated, that should have an extra newline before them. `null` defaults to `"head, body, /html"`. + "html.format.extraLiners": "head, body, /html", + // Format and indent `{{#foo}}` and `{{/foo}}`. + "html.format.indentHandlebars": false, + // Indent `` and `` sections. + "html.format.indentInnerHtml": false, + // Maximum number of line breaks to be preserved in one chunk. Use `null` for unlimited. + "html.format.maxPreserveNewLines": null, + // Controls whether existing line breaks before elements should be preserved. Only works before elements, not inside tags or for text. + "html.format.preserveNewLines": true, + // List of tags, comma separated, that shouldn't be reformatted. `null` defaults to all tags listed at https://www.w3.org/TR/html5/dom.html#phrasing-content. + "html.format.unformatted": "wbr", + // Wrap attributes. + // - auto: Wrap attributes only when line length is exceeded. + // - force: Wrap each attribute except first. + // - force-aligned: Wrap each attribute except first and keep aligned. + // - force-expand-multiline: Wrap each attribute. + // - aligned-multiple: Wrap when line length is exceeded, align attributes vertically. + // - preserve: Preserve wrapping of attributes + // - preserve-aligned: Preserve wrapping of attributes but align. + "html.format.wrapAttributes": "auto", + // Maximum amount of characters per line (0 = disable). + "html.format.wrapLineLength": 120, + // Enable/disable mirroring cursor on matching HTML tag. + "html.mirrorCursorOnMatchingTag": false, + // Controls whether the built-in HTML language support suggests HTML5 tags, properties and values. + "html.suggest.html5": true, + // Traces the communication between VS Code and the HTML language server. + "html.trace.server": "off", + // Controls whether the built-in HTML language support validates embedded scripts. + "html.validate.scripts": true, + // Controls whether the built-in HTML language support validates embedded styles. + "html.validate.styles": true, + // JSON + // Enable/disable default JSON formatter + "json.format.enable": true, + // The maximum number of outline symbols and folding regions computed (limited for performance reasons). + "json.maxItemsComputed": 5000, + // Associate schemas to JSON files in the current project + "json.schemas": [], + // Traces the communication between VS Code and the JSON language server. + "json.trace.server": "off", + // Markdown + // Controls where links in markdown files should be opened. + // - currentGroup: Open links in the active editor group. + // - beside: Open links beside the active editor. + "markdown.links.openLocation": "currentGroup", + // Sets how line-breaks are rendered in the markdown preview. Setting it to 'true' creates a
for every newline. + "markdown.preview.breaks": false, + // Double click in the markdown preview to switch to the editor. + "markdown.preview.doubleClickToSwitchToEditor": true, + // Controls the font family used in the markdown preview. + "markdown.preview.fontFamily": "-apple-system, BlinkMacSystemFont, 'Segoe WPC', 'Segoe UI', 'Ubuntu', 'Droid Sans', sans-serif", + // Controls the font size in pixels used in the markdown preview. + "markdown.preview.fontSize": 14, + // Controls the line height used in the markdown preview. This number is relative to the font size. + "markdown.preview.lineHeight": 1.6, + // Enable or disable conversion of URL-like text to links in the markdown preview. + "markdown.preview.linkify": true, + // Mark the current editor selection in the markdown preview. + "markdown.preview.markEditorSelection": true, + // Controls how links to other markdown files in the markdown preview should be opened. + // - inPreview: Try to open links in the markdown preview + // - inEditor: Try to open links in the editor + "markdown.preview.openMarkdownLinks": "inPreview", + // When a markdown preview is scrolled, update the view of the editor. + "markdown.preview.scrollEditorWithPreview": true, + // When a markdown editor is scrolled, update the view of the preview. + "markdown.preview.scrollPreviewWithEditor": true, + // A list of URLs or local paths to CSS style sheets to use from the markdown preview. Relative paths are interpreted relative to the folder open in the explorer. If there is no open folder, they are interpreted relative to the location of the markdown file. All '\' need to be written as '\\'. + "markdown.styles": [], + // Enable debug logging for the markdown extension. + "markdown.trace": "off", + // PHP + // Controls whether the built-in PHP language suggestions are enabled. The support suggests PHP globals and variables. + "php.suggest.basic": true, + // Enable/disable built-in PHP validation. + "php.validate.enable": true, + // Points to the PHP executable. + "php.validate.executablePath": null, + // Whether the linter is run on save or on type. + "php.validate.run": "onSave", + // TypeScript + // Enable/disable automatic closing of JSX tags. Requires using TypeScript 3.0 or newer in the workspace. + "javascript.autoClosingTags": true, + // Enable/disable default JavaScript formatter. + "javascript.format.enable": true, + // Defines space handling after a comma delimiter. + "javascript.format.insertSpaceAfterCommaDelimiter": true, + // Defines space handling after the constructor keyword. Requires using TypeScript 2.3.0 or newer in the workspace. + "javascript.format.insertSpaceAfterConstructor": false, + // Defines space handling after function keyword for anonymous functions. + "javascript.format.insertSpaceAfterFunctionKeywordForAnonymousFunctions": true, + // Defines space handling after keywords in a control flow statement. + "javascript.format.insertSpaceAfterKeywordsInControlFlowStatements": true, + // Defines space handling after opening and before closing JSX expression braces. + "javascript.format.insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces": false, + // Defines space handling after opening and before closing non-empty braces. Requires using TypeScript 2.3.0 or newer in the workspace. + "javascript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces": true, + // Defines space handling after opening and before closing non-empty brackets. + "javascript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets": false, + // Defines space handling after opening and before closing non-empty parenthesis. + "javascript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis": false, + // Defines space handling after opening and before closing template string braces. + "javascript.format.insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces": false, + // Defines space handling after a semicolon in a for statement. + "javascript.format.insertSpaceAfterSemicolonInForStatements": true, + // Defines space handling after a binary operator. + "javascript.format.insertSpaceBeforeAndAfterBinaryOperators": true, + // Defines space handling before function argument parentheses. + "javascript.format.insertSpaceBeforeFunctionParenthesis": false, + // Defines whether an open brace is put onto a new line for control blocks or not. + "javascript.format.placeOpenBraceOnNewLineForControlBlocks": false, + // Defines whether an open brace is put onto a new line for functions or not. + "javascript.format.placeOpenBraceOnNewLineForFunctions": false, + // Defines handling of optional semicolons. Requires using TypeScript 3.7 or newer in the workspace. + // - ignore: Don't insert or remove any semicolons. + // - insert: Insert semicolons at statement ends. + // - remove: Remove unnecessary semicolons. + "javascript.format.semicolons": "ignore", + // Enable/disable semantic checking of JavaScript files. Existing jsconfig.json or tsconfig.json files override this setting. Requires using TypeScript 2.3.1 or newer in the workspace. + "javascript.implicitProjectConfig.checkJs": false, + // Preferred path style for auto imports. + // - auto: Automatically select import path style. Prefers using a relative import if `baseUrl` is configured and the relative path has fewer segments than the non-relative import. + // - relative: Relative to the file location. + // - non-relative: Based on the `baseUrl` configured in your `jsconfig.json` / `tsconfig.json`. + "javascript.preferences.importModuleSpecifier": "auto", + // Preferred quote style to use for quick fixes: `single` quotes, `double` quotes, or `auto` infer quote type from existing imports. Requires using TypeScript 2.9 or newer in the workspace. + "javascript.preferences.quoteStyle": "auto", + // Enable/disable introducing aliases for object shorthand properties during renames. Requires using TypeScript 3.4 or newer in the workspace. + "javascript.preferences.renameShorthandProperties": true, + // Enable/disable references CodeLens in JavaScript files. + "javascript.referencesCodeLens.enabled": false, + // Enable/disable references CodeLens on all functions in JavaScript files. + "javascript.referencesCodeLens.showOnAllFunctions": false, + // Enable/disable auto import suggestions. Requires using TypeScript 2.6.1 or newer in the workspace. + "javascript.suggest.autoImports": true, + // Complete functions with their parameter signature. + "javascript.suggest.completeFunctionCalls": false, + // Enable/disable suggestion to complete JSDoc comments. + "javascript.suggest.completeJSDocs": true, + // Enabled/disable autocomplete suggestions. + "javascript.suggest.enabled": true, + // Enable/disable showing completions on potentially undefined values that insert an optional chain call. Requires TS 3.7+ and strict null checks to be enabled. + "javascript.suggest.includeAutomaticOptionalChainCompletions": true, + // Enable/disable including unique names from the file in JavaScript suggestions. Note that name suggestions are always disabled in JavaScript code that is semantically checked using `@ts-check` or `checkJs`. + "javascript.suggest.names": true, + // Enable/disable suggestions for paths in import statements and require calls. + "javascript.suggest.paths": true, + // Enable/disable suggestion diagnostics for JavaScript files in the editor. Requires using TypeScript 2.8 or newer in the workspace. + "javascript.suggestionActions.enabled": true, + // Enable/disable automatic updating of import paths when you rename or move a file in VS Code. Requires using TypeScript 2.9 or newer in the workspace. + // - prompt: Prompt on each rename. + // - always: Always update paths automatically. + // - never: Never rename paths and don't prompt. + "javascript.updateImportsOnFileMove.enabled": "prompt", + // Enable/disable JavaScript validation. + "javascript.validate.enable": true, + // Enable/disable automatic closing of JSX tags. Requires using TypeScript 3.0 or newer in the workspace. + "typescript.autoClosingTags": true, + // Check if npm is installed for Automatic Type Acquisition. + "typescript.check.npmIsInstalled": true, + // Disables automatic type acquisition. Automatic type acquisition fetches `@types` packages from npm to improve IntelliSense for external libraries. + "typescript.disableAutomaticTypeAcquisition": false, + // Enable/disable default TypeScript formatter. + "typescript.format.enable": true, + // Defines space handling after a comma delimiter. + "typescript.format.insertSpaceAfterCommaDelimiter": true, + // Defines space handling after the constructor keyword. Requires using TypeScript 2.3.0 or newer in the workspace. + "typescript.format.insertSpaceAfterConstructor": false, + // Defines space handling after function keyword for anonymous functions. + "typescript.format.insertSpaceAfterFunctionKeywordForAnonymousFunctions": true, + // Defines space handling after keywords in a control flow statement. + "typescript.format.insertSpaceAfterKeywordsInControlFlowStatements": true, + // Defines space handling after opening and before closing JSX expression braces. + "typescript.format.insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces": false, + // Defines space handling after opening and before closing non-empty braces. Requires using TypeScript 2.3.0 or newer in the workspace. + "typescript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces": true, + // Defines space handling after opening and before closing non-empty brackets. + "typescript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets": false, + // Defines space handling after opening and before closing non-empty parenthesis. + "typescript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis": false, + // Defines space handling after opening and before closing template string braces. + "typescript.format.insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces": false, + // Defines space handling after a semicolon in a for statement. + "typescript.format.insertSpaceAfterSemicolonInForStatements": true, + // Defines space handling after type assertions in TypeScript. Requires using TypeScript 2.4 or newer in the workspace. + "typescript.format.insertSpaceAfterTypeAssertion": false, + // Defines space handling after a binary operator. + "typescript.format.insertSpaceBeforeAndAfterBinaryOperators": true, + // Defines space handling before function argument parentheses. + "typescript.format.insertSpaceBeforeFunctionParenthesis": false, + // Defines whether an open brace is put onto a new line for control blocks or not. + "typescript.format.placeOpenBraceOnNewLineForControlBlocks": false, + // Defines whether an open brace is put onto a new line for functions or not. + "typescript.format.placeOpenBraceOnNewLineForFunctions": false, + // Defines handling of optional semicolons. Requires using TypeScript 3.7 or newer in the workspace. + // - ignore: Don't insert or remove any semicolons. + // - insert: Insert semicolons at statement ends. + // - remove: Remove unnecessary semicolons. + "typescript.format.semicolons": "ignore", + // Enable/disable implementations CodeLens. This CodeLens shows the implementers of an interface. + "typescript.implementationsCodeLens.enabled": false, + // Sets the locale used to report JavaScript and TypeScript errors. Requires using TypeScript 2.6.0 or newer in the workspace. Default of `null` uses VS Code's locale. + "typescript.locale": null, + // Specifies the path to the npm executable used for Automatic Type Acquisition. Requires using TypeScript 2.3.4 or newer in the workspace. + "typescript.npm": null, + // Preferred path style for auto imports. + // - auto: Automatically select import path style. Prefers using a relative import if `baseUrl` is configured and the relative path has fewer segments than the non-relative import. + // - relative: Relative to the file location. + // - non-relative: Based on the `baseUrl` configured in your `jsconfig.json` / `tsconfig.json`. + "typescript.preferences.importModuleSpecifier": "auto", + // Preferred quote style to use for quick fixes: `single` quotes, `double` quotes, or `auto` infer quote type from existing imports. Requires using TypeScript 2.9 or newer in the workspace. + "typescript.preferences.quoteStyle": "auto", + // Enable/disable introducing aliases for object shorthand properties during renames. Requires using TypeScript 3.4 or newer in the workspace. + "typescript.preferences.renameShorthandProperties": true, + // Enable/disable references CodeLens in TypeScript files. + "typescript.referencesCodeLens.enabled": false, + // Enable/disable references CodeLens on all functions in TypeScript files. + "typescript.referencesCodeLens.showOnAllFunctions": false, + // Report style checks as warnings. + "typescript.reportStyleChecksAsWarnings": true, + // Enable/disable auto import suggestions. Requires using TypeScript 2.6.1 or newer in the workspace. + "typescript.suggest.autoImports": true, + // Complete functions with their parameter signature. + "typescript.suggest.completeFunctionCalls": false, + // Enable/disable suggestion to complete JSDoc comments. + "typescript.suggest.completeJSDocs": true, + // Enabled/disable autocomplete suggestions. + "typescript.suggest.enabled": true, + // Enable/disable showing completions on potentially undefined values that insert an optional chain call. Requires TS 3.7+ and strict null checks to be enabled. + "typescript.suggest.includeAutomaticOptionalChainCompletions": true, + // Enable/disable suggestions for paths in import statements and require calls. + "typescript.suggest.paths": true, + // Enable/disable suggestion diagnostics for TypeScript files in the editor. Requires using TypeScript 2.8 or newer in the workspace. + "typescript.suggestionActions.enabled": true, + // Controls auto detection of tsc tasks. + // - on: Create both build and watch tasks. + // - off: Disable this feature. + // - build: Only create single run compile tasks. + // - watch: Only create compile and watch tasks. + "typescript.tsc.autoDetect": "on", + // Specifies the folder path to the tsserver and lib*.d.ts files under a TypeScript install to use for IntelliSense, for example: `./node_modules/typescript/lib`. + // - When specified as a user setting, the TypeScript version from `typescript.tsdk` automatically replaces the built-in TypeScript version. + // - When specified as a workspace setting, `typescript.tsdk` allows you to switch to use that workspace version of TypeScript for IntelliSense with the `TypeScript: Select TypeScript version` command. + "typescript.tsdk": null, + // Enables logging of the TS server to a file. This log can be used to diagnose TS Server issues. The log may contain file paths, source code, and other potentially sensitive information from your project. + "typescript.tsserver.log": "off", + // Set the maximum amount of memory (in MB) to allocate to the TypeScript server process + "typescript.tsserver.maxTsServerMemory": 3072, + // Additional paths to discover TypeScript Language Service plugins. Requires using TypeScript 2.3.0 or newer in the workspace. + "typescript.tsserver.pluginPaths": [], + // Enables tracing of messages sent to the TS server. This trace can be used to diagnose TS Server issues. The trace may contain file paths, source code, and other potentially sensitive information from your project. + "typescript.tsserver.trace": "off", + // Enable/disable spawning a separate TypeScript server that can more quickly respond to syntax related operations, such as calculating folding or computing document symbols. Requires using TypeScript 3.4.0 or newer in the workspace. + "typescript.tsserver.useSeparateSyntaxServer": true, + // Configure which watching strategies should be used to keep track of files and directories. Requires using TypeScript 3.8+ in the workspace. + "typescript.tsserver.watchOptions": {}, + // Enable/disable automatic updating of import paths when you rename or move a file in VS Code. Requires using TypeScript 2.9 or newer in the workspace. + // - prompt: Prompt on each rename. + // - always: Always update paths automatically. + // - never: Never rename paths and don't prompt. + "typescript.updateImportsOnFileMove.enabled": "prompt", + // Enable/disable TypeScript validation. + "typescript.validate.enable": true, + // CSS + // Insert semicolon at end of line when completing CSS properties + "css.completion.completePropertyWithSemicolon": true, + // By default, VS Code triggers property value completion after selecting a CSS property. Use this setting to disable this behavior. + "css.completion.triggerPropertyValueCompletion": true, + // A list of relative file paths pointing to JSON files following the custom data format. + // VS Code loads custom data on startup to enhance its CSS support for the custom CSS properties, at directives, pseudo classes and pseudo elements you specify in the JSON files. + // The file paths are relative to workspace and only workspace folder settings are considered. + "css.customData": [], + // Invalid number of parameters. + "css.lint.argumentsInColorFunction": "error", + // Do not use `width` or `height` when using `padding` or `border`. + "css.lint.boxModel": "ignore", + // When using a vendor-specific prefix make sure to also include all other vendor-specific properties. + "css.lint.compatibleVendorPrefixes": "ignore", + // Do not use duplicate style definitions. + "css.lint.duplicateProperties": "ignore", + // Do not use empty rulesets. + "css.lint.emptyRules": "warning", + // Avoid using `float`. Floats lead to fragile CSS that is easy to break if one aspect of the layout changes. + "css.lint.float": "ignore", + // `@font-face` rule must define `src` and `font-family` properties. + "css.lint.fontFaceProperties": "warning", + // Hex colors must consist of three or six hex numbers. + "css.lint.hexColorLength": "error", + // Selectors should not contain IDs because these rules are too tightly coupled with the HTML. + "css.lint.idSelector": "ignore", + // IE hacks are only necessary when supporting IE7 and older. + "css.lint.ieHack": "ignore", + // Avoid using `!important`. It is an indication that the specificity of the entire CSS has gotten out of control and needs to be refactored. + "css.lint.important": "ignore", + // Import statements do not load in parallel. + "css.lint.importStatement": "ignore", + // Property is ignored due to the display. E.g. with `display: inline`, the `width`, `height`, `margin-top`, `margin-bottom`, and `float` properties have no effect. + "css.lint.propertyIgnoredDueToDisplay": "warning", + // The universal selector (`*`) is known to be slow. + "css.lint.universalSelector": "ignore", + // Unknown at-rule. + "css.lint.unknownAtRules": "warning", + // Unknown property. + "css.lint.unknownProperties": "warning", + // Unknown vendor specific property. + "css.lint.unknownVendorSpecificProperties": "ignore", + // A list of properties that are not validated against the `unknownProperties` rule. + "css.lint.validProperties": [], + // When using a vendor-specific prefix, also include the standard property. + "css.lint.vendorPrefix": "warning", + // No unit for zero needed. + "css.lint.zeroUnits": "ignore", + // Traces the communication between VS Code and the CSS language server. + "css.trace.server": "off", + // Enables or disables all validations. + "css.validate": true, + // LESS + // Insert semicolon at end of line when completing CSS properties + "less.completion.completePropertyWithSemicolon": true, + // By default, VS Code triggers property value completion after selecting a CSS property. Use this setting to disable this behavior. + "less.completion.triggerPropertyValueCompletion": true, + // Invalid number of parameters. + "less.lint.argumentsInColorFunction": "error", + // Do not use `width` or `height` when using `padding` or `border`. + "less.lint.boxModel": "ignore", + // When using a vendor-specific prefix make sure to also include all other vendor-specific properties. + "less.lint.compatibleVendorPrefixes": "ignore", + // Do not use duplicate style definitions. + "less.lint.duplicateProperties": "ignore", + // Do not use empty rulesets. + "less.lint.emptyRules": "warning", + // Avoid using `float`. Floats lead to fragile CSS that is easy to break if one aspect of the layout changes. + "less.lint.float": "ignore", + // `@font-face` rule must define `src` and `font-family` properties. + "less.lint.fontFaceProperties": "warning", + // Hex colors must consist of three or six hex numbers. + "less.lint.hexColorLength": "error", + // Selectors should not contain IDs because these rules are too tightly coupled with the HTML. + "less.lint.idSelector": "ignore", + // IE hacks are only necessary when supporting IE7 and older. + "less.lint.ieHack": "ignore", + // Avoid using `!important`. It is an indication that the specificity of the entire CSS has gotten out of control and needs to be refactored. + "less.lint.important": "ignore", + // Import statements do not load in parallel. + "less.lint.importStatement": "ignore", + // Property is ignored due to the display. E.g. with `display: inline`, the `width`, `height`, `margin-top`, `margin-bottom`, and `float` properties have no effect. + "less.lint.propertyIgnoredDueToDisplay": "warning", + // The universal selector (`*`) is known to be slow. + "less.lint.universalSelector": "ignore", + // Unknown at-rule. + "less.lint.unknownAtRules": "warning", + // Unknown property. + "less.lint.unknownProperties": "warning", + // Unknown vendor specific property. + "less.lint.unknownVendorSpecificProperties": "ignore", + // A list of properties that are not validated against the `unknownProperties` rule. + "less.lint.validProperties": [], + // When using a vendor-specific prefix, also include the standard property. + "less.lint.vendorPrefix": "warning", + // No unit for zero needed. + "less.lint.zeroUnits": "ignore", + // Enables or disables all validations. + "less.validate": true, + // SCSS (Sass) + // Insert semicolon at end of line when completing CSS properties + "scss.completion.completePropertyWithSemicolon": true, + // By default, VS Code triggers property value completion after selecting a CSS property. Use this setting to disable this behavior. + "scss.completion.triggerPropertyValueCompletion": true, + // Invalid number of parameters. + "scss.lint.argumentsInColorFunction": "error", + // Do not use `width` or `height` when using `padding` or `border`. + "scss.lint.boxModel": "ignore", + // When using a vendor-specific prefix make sure to also include all other vendor-specific properties. + "scss.lint.compatibleVendorPrefixes": "ignore", + // Do not use duplicate style definitions. + "scss.lint.duplicateProperties": "ignore", + // Do not use empty rulesets. + "scss.lint.emptyRules": "warning", + // Avoid using `float`. Floats lead to fragile CSS that is easy to break if one aspect of the layout changes. + "scss.lint.float": "ignore", + // `@font-face` rule must define `src` and `font-family` properties. + "scss.lint.fontFaceProperties": "warning", + // Hex colors must consist of three or six hex numbers. + "scss.lint.hexColorLength": "error", + // Selectors should not contain IDs because these rules are too tightly coupled with the HTML. + "scss.lint.idSelector": "ignore", + // IE hacks are only necessary when supporting IE7 and older. + "scss.lint.ieHack": "ignore", + // Avoid using `!important`. It is an indication that the specificity of the entire CSS has gotten out of control and needs to be refactored. + "scss.lint.important": "ignore", + // Import statements do not load in parallel. + "scss.lint.importStatement": "ignore", + // Property is ignored due to the display. E.g. with `display: inline`, the `width`, `height`, `margin-top`, `margin-bottom`, and `float` properties have no effect. + "scss.lint.propertyIgnoredDueToDisplay": "warning", + // The universal selector (`*`) is known to be slow. + "scss.lint.universalSelector": "ignore", + // Unknown at-rule. + "scss.lint.unknownAtRules": "warning", + // Unknown property. + "scss.lint.unknownProperties": "warning", + // Unknown vendor specific property. + "scss.lint.unknownVendorSpecificProperties": "ignore", + // A list of properties that are not validated against the `unknownProperties` rule. + "scss.lint.validProperties": [], + // When using a vendor-specific prefix, also include the standard property. + "scss.lint.vendorPrefix": "warning", + // No unit for zero needed. + "scss.lint.zeroUnits": "ignore", + // Enables or disables all validations. + "scss.validate": true, + // Extensions + // When enabled, automatically checks extensions for updates. If an extension has an update, it is marked as outdated in the Extensions view. The updates are fetched from a Microsoft online service. + "extensions.autoCheckUpdates": true, + // When enabled, automatically installs updates for extensions. The updates are fetched from a Microsoft online service. + "extensions.autoUpdate": true, + // When enabled, editors with extension details will be automatically closed upon navigating away from the Extensions View. + "extensions.closeExtensionDetailsOnViewChange": false, + // When an extension is listed here, a confirmation prompt will not be shown when that extension handles a URI. + "extensions.confirmedUriHandlerExtensionIds": [], + // When enabled, the notifications for extension recommendations will not be shown. + "extensions.ignoreRecommendations": false, + // When enabled, recommendations will not be fetched or shown unless specifically requested by the user. Some recommendations are fetched from a Microsoft online service. + "extensions.showRecommendationsOnlyOnDemand": false, + // Terminal + // Customizes what kind of terminal to launch. + // - integrated: Use VS Code's integrated terminal. + // - external: Use the configured external terminal. + "terminal.explorerKind": "integrated", + // External Terminal + // Customizes which terminal to run on Linux. + "terminal.external.linuxExec": "xterm", + // Customizes which terminal application to run on macOS. + "terminal.external.osxExec": "Terminal.app", + // Customizes which terminal to run on Windows. + "terminal.external.windowsExec": "C:\\WINDOWS\\System32\\cmd.exe", + // Integrated Terminal + // Whether or not to allow chord keybindings in the terminal. Note that when this is true and the keystroke results in a chord it will bypass `terminal.integrated.commandsToSkipShell`, setting this to false is particularly useful when you want ctrl+k to go to your shell (not VS Code). + "terminal.integrated.allowChords": true, + // A path that when set will override `terminal.integrated.shell.linux` and ignore `shellArgs` values for automation-related terminal usage like tasks and debug. + "terminal.integrated.automationShell.linux": null, + // A path that when set will override `terminal.integrated.shell.osx` and ignore `shellArgs` values for automation-related terminal usage like tasks and debug. + "terminal.integrated.automationShell.osx": null, + // A path that when set will override `terminal.integrated.shell.windows` and ignore `shellArgs` values for automation-related terminal usage like tasks and debug. + "terminal.integrated.automationShell.windows": null, + // A set of command IDs whose keybindings will not be sent to the shell and instead always be handled by Code. This allows the use of keybindings that would normally be consumed by the shell to act the same as when the terminal is not focused, for example ctrl+p to launch Quick Open. + "terminal.integrated.commandsToSkipShell": [], + // Controls whether to confirm on exit if there are active terminal sessions. + "terminal.integrated.confirmOnExit": false, + // Controls whether text selected in the terminal will be copied to the clipboard. + "terminal.integrated.copyOnSelection": false, + // Controls whether the terminal cursor blinks. + "terminal.integrated.cursorBlinking": false, + // Controls the style of terminal cursor. + "terminal.integrated.cursorStyle": "block", + // Controls the width of the cursor when `terminal.integrated.cursorStyle` is set to `line`. + "terminal.integrated.cursorWidth": 1, + // An explicit start path where the terminal will be launched, this is used as the current working directory (cwd) for the shell process. This may be particularly useful in workspace settings if the root directory is not a convenient cwd. + "terminal.integrated.cwd": "", + // Controls whether to detect and set the `$LANG` environment variable to a UTF-8 compliant option since VS Code's terminal only supports UTF-8 encoded data coming from the shell. + // - auto: Set the `$LANG` environment variable if the existing variable does not exist or it does not end in `'.UTF-8'`. + // - off: Do not set the `$LANG` environment variable. + // - on: Always set the `$LANG` environment variable. + "terminal.integrated.detectLocale": "auto", + // Controls whether bold text in the terminal will always use the "bright" ANSI color variant. + "terminal.integrated.drawBoldTextInBrightColors": true, + // Controls whether the terminal bell is enabled. + "terminal.integrated.enableBell": false, + // Whether to enable file links in the terminal. Links can be slow when working on a network drive in particular because each file link is verified against the file system. + "terminal.integrated.enableFileLinks": true, + // Object with environment variables that will be added to the VS Code process to be used by the terminal on Linux. Set to `null` to delete the environment variable. + "terminal.integrated.env.linux": {}, + // Object with environment variables that will be added to the VS Code process to be used by the terminal on macOS. Set to `null` to delete the environment variable. + "terminal.integrated.env.osx": {}, + // Object with environment variables that will be added to the VS Code process to be used by the terminal on Windows. Set to `null` to delete the environment variable. + "terminal.integrated.env.windows": {}, + // Scrolling speed multiplier when pressing `Alt`. + "terminal.integrated.fastScrollSensitivity": 5, + // Controls the font family of the terminal, this defaults to `editor.fontFamily`'s value. + "terminal.integrated.fontFamily": "", + // Controls the font size in pixels of the terminal. + "terminal.integrated.fontSize": 14, + // The font weight to use within the terminal for non-bold text. + "terminal.integrated.fontWeight": "normal", + // The font weight to use within the terminal for bold text. + "terminal.integrated.fontWeightBold": "bold", + // Whether new shells should inherit their environment from VS Code. This is not supported on Windows. + "terminal.integrated.inheritEnv": true, + // Controls the letter spacing of the terminal, this is an integer value which represents the amount of additional pixels to add between characters. + "terminal.integrated.letterSpacing": 0, + // Controls the line height of the terminal, this number is multiplied by the terminal font size to get the actual line-height in pixels. + "terminal.integrated.lineHeight": 1, + // Controls whether to force selection when using Option+click on macOS. This will force a regular (line) selection and disallow the use of column selection mode. This enables copying and pasting using the regular terminal selection, for example, when mouse mode is enabled in tmux. + "terminal.integrated.macOptionClickForcesSelection": false, + // Controls whether to treat the option key as the meta key in the terminal on macOS. + "terminal.integrated.macOptionIsMeta": false, + // When set the foreground color of each cell will change to try meet the contrast ratio specified. Example values: + // + // - 1: The default, do nothing. + // - 4.5: WCAG AA compliance (minimum). + // - 7: WCAG AAA compliance (enhanced). + // - 21: White on black or black on white. + "terminal.integrated.minimumContrastRatio": 1, + // A multiplier to be used on the `deltaY` of mouse wheel scroll events. + "terminal.integrated.mouseWheelScrollSensitivity": 1, + // Controls how the terminal is rendered. + // - auto: Let VS Code guess which renderer to use. + // - canvas: Use the standard GPU/canvas-based renderer. + // - dom: Use the fallback DOM-based renderer. + "terminal.integrated.rendererType": "auto", + // Controls how terminal reacts to right click. + // - default: Show the context menu. + // - copyPaste: Copy when there is a selection, otherwise paste. + // - paste: Paste on right click. + // - selectWord: Select the word under the cursor and show the context menu. + "terminal.integrated.rightClickBehavior": "copyPaste", + // Controls the maximum amount of lines the terminal keeps in its buffer. + "terminal.integrated.scrollback": 1000, + // The path of the shell that the terminal uses on Linux (default: /bin/bash). + "terminal.integrated.shell.linux": null, + // The path of the shell that the terminal uses on macOS (default: /bin/bash). + "terminal.integrated.shell.osx": null, + // The path of the shell that the terminal uses on Windows (default: C:\WINDOWS\System32\WindowsPowerShell\v1.0\powershell.exe). + "terminal.integrated.shell.windows": null, + // The command line arguments to use when on the Linux terminal. + "terminal.integrated.shellArgs.linux": [], + // The command line arguments to use when on the macOS terminal. + "terminal.integrated.shellArgs.osx": [ + "-l" + ], + // The command line arguments to use when on the Windows terminal. + "terminal.integrated.shellArgs.windows": [], + // Controls whether to show the alert "The terminal process terminated with exit code" when exit code is non-zero. + "terminal.integrated.showExitAlert": true, + // Controls the working directory a split terminal starts with. + // - workspaceRoot: A new split terminal will use the workspace root as the working directory. In a multi-root workspace a choice for which root folder to use is offered. + // - initial: A new split terminal will use the working directory that the parent terminal started with. + // - inherited: On macOS and Linux, a new split terminal will use the working directory of the parent terminal. On Windows, this behaves the same as initial. + "terminal.integrated.splitCwd": "inherited", + // Controls what version of unicode to use when evaluating the width of characters in the terminal. If you experience emoji or other wide characters not taking up the right amount of space or backspace either deleting too much or too little then you may want to try tweaking this setting. + // - 6: Version 6 of unicode, this is an older version which should work better on older systems. + // - 11: Version 11 of unicode, this version provides better support on modern systems that use modern versions of unicode. + "terminal.integrated.unicodeVersion": "11", + // Whether to use ConPTY for Windows terminal process communication (requires Windows 10 build number 18309+). Winpty will be used if this is false. + "terminal.integrated.windowsEnableConpty": true, + // Tasks + // Controls enablement of `provideTasks` for all task provider extension. If the Tasks: Run Task command is slow, disabling auto detect for task providers may help. Individual extensions may also provide settings that disable auto detection. + "task.autoDetect": "on", + // Configures whether to show the problem matcher prompt when running a task. Set to `true` to never prompt, or use a dictionary of task types to turn off prompting only for specific task types. + "task.problemMatchers.neverPrompt": false, + // Controls whether to show the task detail for task that have a detail in the Run Task quick pick. + "task.quickOpen.detail": true, + // Controls the number of recent items tracked in task quick open dialog. + "task.quickOpen.history": 30, + // Controls whether the task quick pick is skipped when there is only one task to pick from. + "task.quickOpen.skip": false, + // Configures whether a warning is shown when a provider is slow + "task.slowProviderWarning": true, + // Problems + // Controls whether Problems view should automatically reveal files when opening them. + "problems.autoReveal": true, + // Show Errors & Warnings on files and folder. + "problems.decorations.enabled": true, + // When enabled shows the current problem in the status bar. + "problems.showCurrentInStatus": false, + // Breadcrumb Navigation + // Enable/disable navigation breadcrumbs. + "breadcrumbs.enabled": true, + // Controls whether and how file paths are shown in the breadcrumbs view. + // - on: Show the file path in the breadcrumbs view. + // - off: Do not show the file path in the breadcrumbs view. + // - last: Only show the last element of the file path in the breadcrumbs view. + "breadcrumbs.filePath": "on", + // Render breadcrumb items with icons. + "breadcrumbs.icons": true, + // When enabled breadcrumbs show `array`-symbols. + "breadcrumbs.showArrays": true, + // When enabled breadcrumbs show `boolean`-symbols. + "breadcrumbs.showBooleans": true, + // When enabled breadcrumbs show `class`-symbols. + "breadcrumbs.showClasses": true, + // When enabled breadcrumbs show `constant`-symbols. + "breadcrumbs.showConstants": true, + // When enabled breadcrumbs show `constructor`-symbols. + "breadcrumbs.showConstructors": true, + // When enabled breadcrumbs show `enumMember`-symbols. + "breadcrumbs.showEnumMembers": true, + // When enabled breadcrumbs show `enum`-symbols. + "breadcrumbs.showEnums": true, + // When enabled breadcrumbs show `event`-symbols. + "breadcrumbs.showEvents": true, + // When enabled breadcrumbs show `field`-symbols. + "breadcrumbs.showFields": true, + // When enabled breadcrumbs show `file`-symbols. + "breadcrumbs.showFiles": true, + // When enabled breadcrumbs show `function`-symbols. + "breadcrumbs.showFunctions": true, + // When enabled breadcrumbs show `interface`-symbols. + "breadcrumbs.showInterfaces": true, + // When enabled breadcrumbs show `key`-symbols. + "breadcrumbs.showKeys": true, + // When enabled breadcrumbs show `method`-symbols. + "breadcrumbs.showMethods": true, + // When enabled breadcrumbs show `module`-symbols. + "breadcrumbs.showModules": true, + // When enabled breadcrumbs show `namespace`-symbols. + "breadcrumbs.showNamespaces": true, + // When enabled breadcrumbs show `null`-symbols. + "breadcrumbs.showNull": true, + // When enabled breadcrumbs show `number`-symbols. + "breadcrumbs.showNumbers": true, + // When enabled breadcrumbs show `object`-symbols. + "breadcrumbs.showObjects": true, + // When enabled breadcrumbs show `operator`-symbols. + "breadcrumbs.showOperators": true, + // When enabled breadcrumbs show `package`-symbols. + "breadcrumbs.showPackages": true, + // When enabled breadcrumbs show `property`-symbols. + "breadcrumbs.showProperties": true, + // When enabled breadcrumbs show `string`-symbols. + "breadcrumbs.showStrings": true, + // When enabled breadcrumbs show `struct`-symbols. + "breadcrumbs.showStructs": true, + // When enabled breadcrumbs show `typeParameter`-symbols. + "breadcrumbs.showTypeParameters": true, + // When enabled breadcrumbs show `variable`-symbols. + "breadcrumbs.showVariables": true, + // Controls whether and how symbols are shown in the breadcrumbs view. + // - on: Show all symbols in the breadcrumbs view. + // - off: Do not show symbols in the breadcrumbs view. + // - last: Only show the current symbol in the breadcrumbs view. + "breadcrumbs.symbolPath": "on", + // Controls how symbols are sorted in the breadcrumbs outline view. + // - position: Show symbol outline in file position order. + // - name: Show symbol outline in alphabetical order. + // - type: Show symbol outline in symbol type order. + "breadcrumbs.symbolSortOrder": "position", + // Telemetry + // Enable crash reports to be sent to a Microsoft online service. + // This option requires restart to take effect. + "telemetry.enableCrashReporter": true, + // Enable usage data and errors to be sent to a Microsoft online service. + "telemetry.enableTelemetry": true, + // Outline + // Render Outline Elements with Icons. + "outline.icons": true, + // Use badges for Errors & Warnings. + "outline.problems.badges": true, + // Use colors for Errors & Warnings. + "outline.problems.colors": true, + // Show Errors & Warnings on Outline Elements. + "outline.problems.enabled": true, + // When enabled outline shows `array`-symbols. + "outline.showArrays": true, + // When enabled outline shows `boolean`-symbols. + "outline.showBooleans": true, + // When enabled outline shows `class`-symbols. + "outline.showClasses": true, + // When enabled outline shows `constant`-symbols. + "outline.showConstants": true, + // When enabled outline shows `constructor`-symbols. + "outline.showConstructors": true, + // When enabled outline shows `enumMember`-symbols. + "outline.showEnumMembers": true, + // When enabled outline shows `enum`-symbols. + "outline.showEnums": true, + // When enabled outline shows `event`-symbols. + "outline.showEvents": true, + // When enabled outline shows `field`-symbols. + "outline.showFields": true, + // When enabled outline shows `file`-symbols. + "outline.showFiles": true, + // When enabled outline shows `function`-symbols. + "outline.showFunctions": true, + // When enabled outline shows `interface`-symbols. + "outline.showInterfaces": true, + // When enabled outline shows `key`-symbols. + "outline.showKeys": true, + // When enabled outline shows `method`-symbols. + "outline.showMethods": true, + // When enabled outline shows `module`-symbols. + "outline.showModules": true, + // When enabled outline shows `namespace`-symbols. + "outline.showNamespaces": true, + // When enabled outline shows `null`-symbols. + "outline.showNull": true, + // When enabled outline shows `number`-symbols. + "outline.showNumbers": true, + // When enabled outline shows `object`-symbols. + "outline.showObjects": true, + // When enabled outline shows `operator`-symbols. + "outline.showOperators": true, + // When enabled outline shows `package`-symbols. + "outline.showPackages": true, + // When enabled outline shows `property`-symbols. + "outline.showProperties": true, + // When enabled outline shows `string`-symbols. + "outline.showStrings": true, + // When enabled outline shows `struct`-symbols. + "outline.showStructs": true, + // When enabled outline shows `typeParameter`-symbols. + "outline.showTypeParameters": true, + // When enabled outline shows `variable`-symbols. + "outline.showVariables": true, + // Default Configuration Overrides + // Configure editor settings to be overridden for [css] language. + "[css]": { + "editor.suggest.insertMode": "replace" + }, + // Configure editor settings to be overridden for [git-commit] language. + "[git-commit]": { + "editor.rulers": [ + 72 + ] + }, + // Configure editor settings to be overridden for [go] language. + "[go]": { + "editor.insertSpaces": false + }, + // Configure editor settings to be overridden for [handlebars] language. + "[handlebars]": { + "editor.suggest.insertMode": "replace" + }, + // Configure editor settings to be overridden for [html] language. + "[html]": { + "editor.suggest.insertMode": "replace" + }, + // Configure editor settings to be overridden for [json] language. + "[json]": { + "editor.quickSuggestions": { + "strings": true + }, + "editor.suggest.insertMode": "replace" + }, + // Configure editor settings to be overridden for [jsonc] language. + "[jsonc]": { + "editor.quickSuggestions": { + "strings": true + }, + "editor.suggest.insertMode": "replace" + }, + // Configure editor settings to be overridden for [less] language. + "[less]": { + "editor.suggest.insertMode": "replace" + }, + // Configure editor settings to be overridden for [makefile] language. + "[makefile]": { + "editor.insertSpaces": false + }, + // Configure editor settings to be overridden for [markdown] language. + "[markdown]": { + "editor.wordWrap": "on", + "editor.quickSuggestions": false + }, + // Configure editor settings to be overridden for [scss] language. + "[scss]": { + "editor.suggest.insertMode": "replace" + }, + // Configure editor settings to be overridden for [search-result] language. + "[search-result]": { + "editor.lineNumbers": "off" + }, + // Configure editor settings to be overridden for [shellscript] language. + "[shellscript]": { + "files.eol": "\n" + }, + // Configure editor settings to be overridden for [yaml] language. + "[yaml]": { + "editor.insertSpaces": true, + "editor.tabSize": 2, + "editor.autoIndent": "advanced" + }, + // Remote + // When enabled extensions are downloaded locally and installed on remote. + "remote.downloadExtensionsLocally": false, + // Override the kind of an extension. `ui` extensions are installed and run on the local machine while `workspace` extensions are run on the remote. By overriding an extension's default kind using this setting, you specify if that extension should be installed and enabled locally or remotely. + "remote.extensionKind": { + "pub.name": [ + "ui" + ] + }, + // Restores the ports you forwarded in a workspace. + "remote.restoreForwardedPorts": false, + // Node debug + // Automatically attach node debugger when node.js was launched in debug mode from integrated terminal. + // - disabled: Auto attach is disabled and not shown in status bar. + // - on: Auto attach is active. + // - off: Auto attach is inactive. + "debug.node.autoAttach": "disabled", + // Controls whether to show a warning when the 'useWSL' attribute is used. + "debug.node.showUseWslIsDeprecatedWarning": true, + //Emmet + // An array of languages where Emmet abbreviations should not be expanded. + "emmet.excludeLanguages": [ + "markdown" + ], + // Path to a folder containing Emmet profiles and snippets. + "emmet.extensionsPath": null, + // Enable Emmet abbreviations in languages that are not supported by default. Add a mapping here between the language and emmet supported language. + // E.g.: `{"vue-html": "html", "javascript": "javascriptreact"}` + "emmet.includeLanguages": {}, + // When set to `false`, the whole file is parsed to determine if current position is valid for expanding Emmet abbreviations. When set to `true`, only the content around the current position in css/scss/less files is parsed. + "emmet.optimizeStylesheetParsing": true, + // Preferences used to modify behavior of some actions and resolvers of Emmet. + "emmet.preferences": {}, + // Shows possible Emmet abbreviations as suggestions. Not applicable in stylesheets or when emmet.showExpandedAbbreviation is set to `"never"`. + "emmet.showAbbreviationSuggestions": true, + // Shows expanded Emmet abbreviations as suggestions. + // The option `"inMarkupAndStylesheetFilesOnly"` applies to html, haml, pug, slim, xml, xsl, css, scss, sass, less and stylus. + // The option `"always"` applies to all parts of the file regardless of markup/css. + "emmet.showExpandedAbbreviation": "always", + // If `true`, then Emmet suggestions will show up as snippets allowing you to order them as per `editor.snippetSuggestions` setting. + "emmet.showSuggestionsAsSnippets": false, + // Define profile for specified syntax or use your own profile with specific rules. + "emmet.syntaxProfiles": {}, + // When enabled, Emmet abbreviations are expanded when pressing TAB. + "emmet.triggerExpansionOnTab": false, + // Variables to be used in Emmet snippets + "emmet.variables": {}, + // Git + // Controls whether force push (with or without lease) is enabled. + "git.allowForcePush": false, + // Always show the Staged Changes resource group. + "git.alwaysShowStagedChangesResourceGroup": false, + // Controls the signoff flag for all commits. + "git.alwaysSignOff": false, + // When enabled, commits will automatically be fetched from the default remote of the current Git repository. + "git.autofetch": false, + // Duration in seconds between each automatic git fetch, when `git.autofetch` is enabled. + "git.autofetchPeriod": 180, + // Whether auto refreshing is enabled. + "git.autorefresh": true, + // Configures when repositories should be automatically detected. + // - true: Scan for both subfolders of the current opened folder and parent folders of open files. + // - false: Disable automatic repository scanning. + // - subFolders: Scan for subfolders of the currently opened folder. + // - openEditors: Scan for parent folders of open files. + "git.autoRepositoryDetection": true, + // Stash any changes before pulling and restore them after successful pull. + "git.autoStash": false, + // Controls the sort order for branches. + "git.branchSortOrder": "committerdate", + // A regular expression to validate new branch names. + "git.branchValidationRegex": "", + // The character to replace whitespace in new branch names. + "git.branchWhitespaceChar": "-", + // Controls what type of branches are listed when running `Checkout to...`. + // - all: Show all references. + // - local: Show only local branches. + // - tags: Show only tags. + // - remote: Show only remote branches. + "git.checkoutType": "all", + // Always confirm the creation of empty commits for the 'Git: Commit Empty' command. + "git.confirmEmptyCommits": true, + // Controls whether to ask for confirmation before force-pushing. + "git.confirmForcePush": true, + // Confirm before synchronizing git repositories. + "git.confirmSync": true, + // Controls the Git count badge. + // - all: Count all changes. + // - tracked: Count only tracked changes. + // - off: Turn off counter. + "git.countBadge": "all", + // Controls whether Git contributes colors and badges to the explorer and the open editors view. + "git.decorations.enabled": true, + // The default location to clone a git repository. + "git.defaultCloneDirectory": null, + // Controls whether to automatically detect git submodules. + "git.detectSubmodules": true, + // Controls the limit of git submodules detected. + "git.detectSubmodulesLimit": 10, + // Enables commit signing with GPG. + "git.enableCommitSigning": false, + // Whether git is enabled. + "git.enabled": true, + // Commit all changes when there are no staged changes. + "git.enableSmartCommit": false, + // Controls whether the Git Sync command appears in the status bar. + "git.enableStatusBarSync": true, + // When enabled, fetch all branches when pulling. Otherwise, fetch just the current one. + "git.fetchOnPull": false, + // List of git repositories to ignore. + "git.ignoredRepositories": [], + // Ignores the legacy Git warning. + "git.ignoreLegacyWarning": false, + // Ignores the warning when there are too many changes in a repository. + "git.ignoreLimitWarning": false, + // Ignores the warning when Git is missing. + "git.ignoreMissingGitWarning": false, + // Controls when to show commit message input validation. + "git.inputValidation": "warn", + // Controls the commit message length threshold for showing a warning. + "git.inputValidationLength": 72, + // Controls the commit message subject length threshold for showing a warning. Unset it to inherit the value of `config.inputValidationLength`. + "git.inputValidationSubjectLength": 50, + // Controls whether the diff editor should be opened when clicking a change. Otherwise the regular editor will be opened. + "git.openDiffOnClick": true, + // Path and filename of the git executable, e.g. `C:\Program Files\Git\bin\git.exe` (Windows). + "git.path": null, + // Runs a git command after a successful commit. + // - none: Don't run any command after a commit. + // - push: Run 'Git Push' after a successful commit. + // - sync: Run 'Git Sync' after a successful commit. + "git.postCommitCommand": "none", + // Controls whether Git should check for unsaved files before committing. + // - always: Check for any unsaved files. + // - staged: Check only for unsaved staged files. + // - never: Disable this check. + "git.promptToSaveFilesBeforeCommit": "always", + // Fetch all tags when pulling. + "git.pullTags": true, + // Force git to use rebase when running the sync command. + "git.rebaseWhenSync": false, + // List of paths to search for git repositories in. + "git.scanRepositories": [], + // Controls whether to show an inline Open File action in the Git changes view. + "git.showInlineOpenFileAction": true, + // Controls whether git actions should show progress. + "git.showProgress": true, + // Controls whether to show a notification when a push is successful. + "git.showPushSuccessNotification": false, + // Control which changes are automatically staged by Smart Commit. + // - all: Automatically stage all changes. + // - tracked: Automatically staged tracked changes only. + "git.smartCommitChanges": "all", + // Suggests to enable smart commit (commit all changes when there are no staged changes). + "git.suggestSmartCommit": true, + // Controls whether a notification comes up when running the Sync action, which allows the user to cancel the operation. + "git.supportCancellation": false, + // Controls how untracked changes behave. + // - mixed: All changes, tracked and untracked, appear together and behave equally. + // - separate: Untracked changes appear separately in the Source Control view. They are also excluded from several actions. + // - hidden: Untracked changes are hidden and excluded from several actions. + "git.untrackedChanges": "mixed", + // Controls whether force pushing uses the safer force-with-lease variant. + "git.useForcePushWithLease": true, + // Grunt + // Controls whether auto detection of Grunt tasks is on or off. Default is on. + "grunt.autoDetect": "on", + // Gulp + // Controls whether auto detection of Gulp tasks is on or off. Default is on. + "gulp.autoDetect": "on", + // Jake + // Controls whether auto detection of Jake tasks is on or off. Default is on. + "jake.autoDetect": "on", + // Merge Conflict + // Whether to automatically navigate to the next merge conflict after resolving a merge conflict. + "merge-conflict.autoNavigateNextConflict.enabled": false, + // Create a Code Lens for merge conflict blocks within editor. + "merge-conflict.codeLens.enabled": true, + // Create decorators for merge conflict blocks within editor. + "merge-conflict.decorators.enabled": true, + // Controls where the diff view should be opened when comparing changes in merge conflicts. + // - Current: Open the diff view in the current editor group. + // - Beside: Open the diff view next to the current editor group. + // - Below: Open the diff view below the current editor group. + "merge-conflict.diffViewPosition": "Current", + // References Search View + // Controls whether 'Peek References' or 'Find References' is invoked when selecting code lens references + // - peek: Show references in peek editor. + // - view: Show references in separate view. + "references.preferredLocation": "peek", + // Npm + // Controls whether npm scripts should be automatically detected. + "npm.autoDetect": "on", + // Enable running npm scripts contained in a folder from the Explorer context menu. + "npm.enableRunFromFolder": false, + // Enable an explorer view for npm scripts when there is no top-level 'package.json' file. + "npm.enableScriptExplorer": false, + // Configure glob patterns for folders that should be excluded from automatic script detection. + "npm.exclude": "", + // Fetch data from https://registry.npmjs.org and https://registry.bower.io to provide auto-completion and information on hover features on npm dependencies. + "npm.fetchOnlinePackageInfo": true, + // The package manager used to run scripts. + "npm.packageManager": "npm", + // Run npm commands with the `--silent` option. + "npm.runSilent": false, + // The default click action used in the npm scripts explorer: `open` or `run`, the default is `open`. + "npm.scriptExplorerAction": "open" } \ No newline at end of file diff --git a/js-exercises/.directory b/js-exercises/.directory new file mode 100644 index 00000000..9e2f3fd1 --- /dev/null +++ b/js-exercises/.directory @@ -0,0 +1,6 @@ +[Dolphin] +Timestamp=2020,3,15,12,44,55 +Version=4 + +[Settings] +HiddenFilesShown=true diff --git a/js-exercises/.eslint.js b/js-exercises/.eslint.js new file mode 100644 index 00000000..bd8a8f3b --- /dev/null +++ b/js-exercises/.eslint.js @@ -0,0 +1,116 @@ +/** @format */ + +module.exports = { + extends: ["airbnb", "prettier", "prettier/react"], + parser: "babel-eslint", + parserOptions: { + ecmaVersion: 2020, + // Can I remove these now? + ecmaFeatures: { + impliedStrict: true, + classes: true + } + }, + env: { + browser: true, + node: true, + jquery: true, + jest: true + }, + rules: { + "no-debugger": 0, + "no-alert": 0, + "no-await-in-loop": 0, + "no-return-assign": ["error", "except-parens"], + "no-restricted-syntax": [ + 2, + "ForInStatement", + "LabeledStatement", + "WithStatement" + ], + "no-unused-vars": [ + 1, + { + ignoreSiblings: true, + argsIgnorePattern: "res|next|^err" + } + ], + "prefer-const": [ + "error", + { + destructuring: "all" + } + ], + "arrow-body-style": [2, "as-needed"], + "no-unused-expressions": [ + 2, + { + allowTaggedTemplates: true + } + ], + "no-param-reassign": [ + 2, + { + props: false + } + ], + "no-console": 0, + "import/prefer-default-export": 0, + import: 0, + "func-names": 0, + "space-before-function-paren": 0, + "comma-dangle": 0, + "max-len": 0, + "import/extensions": 0, + "no-underscore-dangle": 0, + "consistent-return": 0, + "react/display-name": 1, + "react/no-array-index-key": 0, + "react/react-in-jsx-scope": 0, + "react/prefer-stateless-function": 0, + "react/forbid-prop-types": 0, + "react/no-unescaped-entities": 0, + "jsx-a11y/accessible-emoji": 0, + "react/require-default-props": 0, + "react/jsx-filename-extension": [ + 1, + { + extensions: [".js", ".jsx"] + } + ], + radix: 0, + "no-shadow": [ + 2, + { + hoist: "all", + allow: ["resolve", "reject", "done", "next", "err", "error"] + } + ], + quotes: [ + 2, + "single", + { + avoidEscape: true, + allowTemplateLiterals: true + } + ], + "prettier/prettier": [ + "error", + { + trailingComma: "es5", + singleQuote: true, + printWidth: 80 + } + ], + "jsx-a11y/href-no-hash": "off", + "jsx-a11y/anchor-is-valid": [ + "warn", + { + aspects: ["invalidHref"] + } + ], + "react-hooks/rules-of-hooks": "error", + "react-hooks/exhaustive-deps": "warn" + }, + plugins: ["html", "prettier", "react-hooks"] +}; diff --git a/js-exercises/.eslintrc b/js-exercises/.eslintrc index 076e10cc..0a48840e 100644 --- a/js-exercises/.eslintrc +++ b/js-exercises/.eslintrc @@ -6,6 +6,16 @@ "rules": { "no-restricted-syntax": 0, "arrow-parens": 0, - "import/prefer-default-export": 0 + "import/prefer-default-export": 0, + "no-console": 2, + "prettier/prettier": [ + "error", + { + "trailingComma": "es5", + "singleQuote": true, + "printWidth": 120, + "tabWidth": 8, + } + ] } } \ No newline at end of file diff --git a/js-exercises/.eslintrc.json b/js-exercises/.eslintrc.json new file mode 100644 index 00000000..42ac4c87 --- /dev/null +++ b/js-exercises/.eslintrc.json @@ -0,0 +1,3 @@ +{ + "extends": ["wesbos"] +} diff --git a/js-exercises/longest-word-in-string/.directory b/js-exercises/longest-word-in-string/.directory new file mode 100644 index 00000000..f750f1cc --- /dev/null +++ b/js-exercises/longest-word-in-string/.directory @@ -0,0 +1,6 @@ +[Dolphin] +Timestamp=2020,3,15,12,57,17 +Version=4 + +[Settings] +HiddenFilesShown=true diff --git a/js-exercises/longest-word-in-string/README.md b/js-exercises/longest-word-in-string/README.md new file mode 100644 index 00000000..5be4f25c --- /dev/null +++ b/js-exercises/longest-word-in-string/README.md @@ -0,0 +1,3 @@ +# Instructions + +Write a function which returns the longest word in a string diff --git a/js-exercises/longest-word-in-string/longestWordInString.js b/js-exercises/longest-word-in-string/longestWordInString.js new file mode 100644 index 00000000..9b740107 --- /dev/null +++ b/js-exercises/longest-word-in-string/longestWordInString.js @@ -0,0 +1,56 @@ +/** + * Please be sincear and let me know about all the mistakes i have made + * please be a little kind as i am still a novoice and am still learning + * @Bhargav Mantha + * + * Procedure/Approach/psudo code i am following + * 1.LongestWordInString is a function which takes input as a parameter + * 2.I am not taking into account that the sentance can have letters of same length + * even if the do the last occuring word is replaced or an array of words is pushed + * into the key of the respective Json + * 3.After this the function is called to return the respective sorted keys of array + * using Object.keys + * @param {String} inputString + */ +/** + * this function is rresponsable for splitting the sentance into a word of array and + * returning the same + * @param {String} inputString + */ +const getwordsFromString = inputString => { + const wordArray = inputString.split(' '); + return wordArray; +}; +/** + * takes the input as array of an object + * @param {array-Object} arrayOfWords + */ +const getlongestWordLength = arrayOfWords => { + const JSONOfWordLength = {}; + for (let i = 0; i < arrayOfWords.length; i += 1) { + const lengthOfWord = arrayOfWords[i].length; + const words = JSONOfWordLength[`${lengthOfWord}`]; + const wordOrArrayOfCommonLengthWords = + words === undefined ? arrayOfWords[i] : [...words, arrayOfWords[i]]; + JSONOfWordLength[lengthOfWord] = wordOrArrayOfCommonLengthWords; + } + const arrayOfKeysOfWordJsonLength = Object.keys(JSONOfWordLength); + const sortedKeys = arrayOfKeysOfWordJsonLength.sort( + (previousNumber, nextNumber) => previousNumber - nextNumber + ); + const longestWordlength = sortedKeys[sortedKeys.length - 1]; + return longestWordlength; +}; +function longestWordInString(inputString) { + const wordsInString = getwordsFromString(inputString); + const longestWord = parseInt(getlongestWordLength(wordsInString)); + console.log(longestWord); + return longestWord; +} +longestWordInString( + 'What if we try a super-long word such as otorhinolaryngology' +); +export { longestWordInString }; +/** + * regards Bhargav Mantha-Awaiting Response + */ diff --git a/js-exercises/longest-word-in-string/longestWordInString.test.js b/js-exercises/longest-word-in-string/longestWordInString.test.js new file mode 100644 index 00000000..590edd1b --- /dev/null +++ b/js-exercises/longest-word-in-string/longestWordInString.test.js @@ -0,0 +1,26 @@ +import { longestWordInString } from './longestWordInString'; + +describe('longestWordInString', () => { + test('should return a number', () => { + expect(typeof longestWordInString('some hello')).toBe('number'); + }); + test('should return the correct solution', () => { + expect( + longestWordInString('The quick brown fox jumped over the lazy dog') + ).toBe(6); + expect(longestWordInString('May the force be with you')).toBe(5); + expect( + longestWordInString( + 'What if we try a super-long word such as otorhinolaryngology' + ) + ).toBe(19); + expect( + longestWordInString( + 'What if we try a super-long word such as otorhinolaryngology' + ) + ).toBe(19); + expect(longestWordInString(' ')).toBe(0); + expect(longestWordInString('123 456 ')).toBe(3); + expect(longestWordInString('aaa bbb ccc ddd eee fff ggg hhh')).toBe(3); + }); +}); diff --git a/js-exercises/package.json b/js-exercises/package.json index 65ee3a9c..d36e1c7d 100644 --- a/js-exercises/package.json +++ b/js-exercises/package.json @@ -4,12 +4,27 @@ "main": "index.js", "license": "MIT", "scripts": { - "test": "jest" + "test": "jest", + "lint": "eslint .", + "lint:fix": "eslint --fix" }, "devDependencies": { "babel-jest": "^25.1.0", "jest": "^25.1.0" }, + "peerDependencies": { + "babel-eslint": "^9.0.0", + "eslint": "^6.1.0", + "eslint-config-airbnb": "^18.0.0", + "eslint-config-prettier": "^4.1.0", + "eslint-plugin-html": "^5.0.3", + "eslint-plugin-import": "^2.18.0", + "eslint-plugin-jsx-a11y": "^6.2.3", + "eslint-plugin-prettier": "^3.0.1", + "eslint-plugin-react": "^7.14.2", + "eslint-plugin-react-hooks": "^1.4.0", + "prettier": "^1.16.4" + }, "dependencies": { "@babel/cli": "^7.8.4", "@babel/core": "^7.8.4", @@ -33,4 +48,4 @@ "eslint" ] } -} +} \ No newline at end of file diff --git a/package.json b/package.json index 126fdb5a..ceef6b2e 100644 --- a/package.json +++ b/package.json @@ -20,5 +20,19 @@ "node-cmd": "^3.0.0", "node-fetch": "^2.6.0", "url-join": "^4.0.1" + }, + "devDependencies": { + "babel-eslint": "^9.0.0", + "eslint": "^5.16.0", + "eslint-config-airbnb": "^17.1.1", + "eslint-config-prettier": "^4.3.0", + "eslint-config-wesbos": "0.0.19", + "eslint-plugin-html": "^5.0.5", + "eslint-plugin-import": "^2.20.1", + "eslint-plugin-jsx-a11y": "^6.2.3", + "eslint-plugin-prettier": "^3.1.2", + "eslint-plugin-react": "^7.19.0", + "eslint-plugin-react-hooks": "^1.7.0", + "prettier": "^1.19.1" } } From bd9058d0095a8fb68d80c876c95cc46674498291 Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Sun, 15 Mar 2020 14:54:45 +0530 Subject: [PATCH 02/11] :fix remove function call Function call has been removed which was accndently put --- js-exercises/longest-word-in-string/longestWordInString.js | 3 --- 1 file changed, 3 deletions(-) diff --git a/js-exercises/longest-word-in-string/longestWordInString.js b/js-exercises/longest-word-in-string/longestWordInString.js index 9b740107..a4d1c630 100644 --- a/js-exercises/longest-word-in-string/longestWordInString.js +++ b/js-exercises/longest-word-in-string/longestWordInString.js @@ -47,9 +47,6 @@ function longestWordInString(inputString) { console.log(longestWord); return longestWord; } -longestWordInString( - 'What if we try a super-long word such as otorhinolaryngology' -); export { longestWordInString }; /** * regards Bhargav Mantha-Awaiting Response From f88e0e91653758c71503ddf5e163edf99f80346b Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Sun, 15 Mar 2020 14:59:06 +0530 Subject: [PATCH 03/11] Update package.json --- js-exercises/package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/js-exercises/package.json b/js-exercises/package.json index d36e1c7d..c6df52b4 100644 --- a/js-exercises/package.json +++ b/js-exercises/package.json @@ -48,4 +48,4 @@ "eslint" ] } -} \ No newline at end of file +} From c93d1a702487874f35ec6aba71e27a8586071767 Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Sun, 15 Mar 2020 15:28:04 +0530 Subject: [PATCH 04/11] comple second exercise the second question rotated string or not check was also done --- .vscode/settings.json | 6 ++--- js-exercises/rotated-string/README.md | 3 +++ js-exercises/rotated-string/rotatedString.js | 22 +++++++++++++++++++ .../rotated-string/rotatedString.test.js | 11 ++++++++++ 4 files changed, 39 insertions(+), 3 deletions(-) create mode 100644 js-exercises/rotated-string/README.md create mode 100644 js-exercises/rotated-string/rotatedString.js create mode 100644 js-exercises/rotated-string/rotatedString.test.js diff --git a/.vscode/settings.json b/.vscode/settings.json index 61e36993..a73ee218 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -89,7 +89,7 @@ please keep in mind thet these are my settings these can be ignored // Controls the width of the cursor when `editor.cursorStyle` is set to `line`. "editor.cursorWidth": 0, // Defines a default formatter which takes precedence over all other formatter settings. Must be the identifier of an extension contributing a formatter. - "editor.defaultFormatter": null, + "editor.defaultFormatter": "rvest.vs-code-prettier-eslint", // Controls whether the definition link opens element in the peek widget. "editor.definitionLinkOpensInPeek": false, // Controls whether `editor.tabSize#` and `#editor.insertSpaces` will be automatically detected when a file is opened based on the file contents. @@ -128,9 +128,9 @@ please keep in mind thet these are my settings these can be ignored // Controls the font weight. "editor.fontWeight": "normal", // Controls whether the editor should automatically format the pasted content. A formatter must be available and the formatter should be able to format a range in a document. - "editor.formatOnPaste": true, + "editor.formatOnPaste": false, // Format a file on save. A formatter must be available, the file must not be saved after delay, and the editor must not be shutting down. - "editor.formatOnSave": true, + "editor.formatOnSave": false, // Controls whether the editor should automatically format the line after typing. "editor.formatOnType": true, // Controls whether the editor should render the vertical glyph margin. Glyph margin is mostly used for debugging. diff --git a/js-exercises/rotated-string/README.md b/js-exercises/rotated-string/README.md new file mode 100644 index 00000000..4b64a9eb --- /dev/null +++ b/js-exercises/rotated-string/README.md @@ -0,0 +1,3 @@ +# Instructions + +Write a function `rotatedString` which returns true if the string is a rotated version of the given string diff --git a/js-exercises/rotated-string/rotatedString.js b/js-exercises/rotated-string/rotatedString.js new file mode 100644 index 00000000..2dc6cd49 --- /dev/null +++ b/js-exercises/rotated-string/rotatedString.js @@ -0,0 +1,22 @@ +/** + * Please be sincear and let me know about all the mistakes i have made + * please be a little kind as i am still a novoice and am still learning + * @Bhargav Mantha + * + * Procedure/Approach/psudo code i am following + * 1.check if string 2 is a substring of string 1 + string 1 and + * 2.string1 is not equal to string 2 + * @param {String,String} stringToCompare1,stringToCompare2 + */ + +const rotatedString = (stringToCompare1, stringToCompare2) => { + const stringAgainstWhichToTest = stringToCompare1 + stringToCompare1; + if ( + stringAgainstWhichToTest.includes(stringToCompare2) === true && + stringToCompare1 !== stringToCompare2 + ) + return true; + return false; +}; + +export { rotatedString }; diff --git a/js-exercises/rotated-string/rotatedString.test.js b/js-exercises/rotated-string/rotatedString.test.js new file mode 100644 index 00000000..1ff417f0 --- /dev/null +++ b/js-exercises/rotated-string/rotatedString.test.js @@ -0,0 +1,11 @@ +import { rotatedString } from './rotatedString'; + +describe('rotatedString', () => { + it('rotatedString returns true for the given strings', () => { + expect(rotatedString('abcde', 'cdeab')).toBeTruthy(); + }); + + it('rotatedString returns false for the given strings', () => { + expect(rotatedString('abcde', 'abcde')).toBeFalsy(); + }); +}); From a57370476f5aac3da18188f51b299056ca8073c3 Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Sun, 15 Mar 2020 21:07:10 +0530 Subject: [PATCH 05/11] complete us-phone-validator compleated the us phone validator 1.used a regx that tests the validity of the phone number 2.the following is the url for the same <---------------url----------------> https://regex101.com/r/iZ2vL4/65 <--------------url----------------> You can play around with the tool for working of the same :arrow_forward: :yum: felling lucky --- js-exercises/args-string/README.md | 5 +++++ js-exercises/args-string/argsString.js | 3 +++ js-exercises/args-string/argsString.test.js | 15 +++++++++++++ js-exercises/telephone-check/README.md | 16 ++++++++++++++ .../telephone-check/telephoneCheck.js | 22 +++++++++++++++++++ .../telephone-check/telephoneCheck.test.js | 14 ++++++++++++ 6 files changed, 75 insertions(+) create mode 100644 js-exercises/args-string/README.md create mode 100644 js-exercises/args-string/argsString.js create mode 100644 js-exercises/args-string/argsString.test.js create mode 100644 js-exercises/telephone-check/README.md create mode 100644 js-exercises/telephone-check/telephoneCheck.js create mode 100644 js-exercises/telephone-check/telephoneCheck.test.js diff --git a/js-exercises/args-string/README.md b/js-exercises/args-string/README.md new file mode 100644 index 00000000..1bca6eba --- /dev/null +++ b/js-exercises/args-string/README.md @@ -0,0 +1,5 @@ +# Instructions + +Write your own version of Template literals (String interpolation) + +**You are NOT allowed to use existing array utilities.** diff --git a/js-exercises/args-string/argsString.js b/js-exercises/args-string/argsString.js new file mode 100644 index 00000000..e0699ce8 --- /dev/null +++ b/js-exercises/args-string/argsString.js @@ -0,0 +1,3 @@ +const argsString = (message, args) => {}; + +export { argsString }; diff --git a/js-exercises/args-string/argsString.test.js b/js-exercises/args-string/argsString.test.js new file mode 100644 index 00000000..4f966cf3 --- /dev/null +++ b/js-exercises/args-string/argsString.test.js @@ -0,0 +1,15 @@ +import { argsString } from "./argsString"; + +describe("argsString", () => { + it("argsString does this thing...", () => { + expect(argsString("{} {}", ["Hello", "World!"])).toBe("Hello World!"); + }); + + it("argsString does that other thing...", () => { + expect(argsString("{}! How are you?", ["Hey"])).toBe("Hey! How are you?"); + }); + + it("argsString does a very cool thing...", () => { + expect(argsString("How are you?", ["Hey", "what"])).toBe("How are you?"); + }); +}); diff --git a/js-exercises/telephone-check/README.md b/js-exercises/telephone-check/README.md new file mode 100644 index 00000000..736c8ceb --- /dev/null +++ b/js-exercises/telephone-check/README.md @@ -0,0 +1,16 @@ +# Instructions + +Return true if the passed string is a valid US phone number. + +The user may fill out the form field any way they choose as long as it is a valid US number. The following are examples of valid formats for US numbers (refer to the tests below for other variants): + +555-555-5555 +(555)555-5555 +(555) 555-5555 +555 555 5555 +5555555555 +1 555 555 5555 + +For this challenge you will be presented with a string such as 800-692-7753 or 8oo-six427676;laskdjf. Your job is to validate or reject the US phone number based on any combination of the formats provided above. The area code is required. If the country code is provided, you must confirm that the country code is 1. + +Return true if the string is a valid US phone number; otherwise return false. diff --git a/js-exercises/telephone-check/telephoneCheck.js b/js-exercises/telephone-check/telephoneCheck.js new file mode 100644 index 00000000..db098887 --- /dev/null +++ b/js-exercises/telephone-check/telephoneCheck.js @@ -0,0 +1,22 @@ +/** + * Please be sincear and let me know about all the mistakes i have made + * please be a little kind as i am still a novoice and am still learning + * @Bhargav Mantha + * + * Procedure/Approach/psudo code i am following + * 1.cI constructed a regex to check if the given phone number is + * actually in the format of US Phone Number + * 2. If the phone number is iun the US phone number format return true else false + * @param {String} (Phonenumber) + */ +const regExMatcher = inputPhoneNumber => { + const regex = /^(1\s)?\(?\d{3}(\))?(-|\s)?\d{3}(-|\s)?\d{4}$/; + const pattern = new RegExp(regex); + const resultOfRegx = pattern.test(inputPhoneNumber); + return resultOfRegx; +}; +function telephoneCheck(inputPhoneNumber) { + const resultOfReplacement = regExMatcher(inputPhoneNumber); + return resultOfReplacement; +} +export { telephoneCheck }; diff --git a/js-exercises/telephone-check/telephoneCheck.test.js b/js-exercises/telephone-check/telephoneCheck.test.js new file mode 100644 index 00000000..c2f89e33 --- /dev/null +++ b/js-exercises/telephone-check/telephoneCheck.test.js @@ -0,0 +1,14 @@ +import { telephoneCheck } from './telephoneCheck'; + +describe('telephoneCheck', () => { + test('should return correct boolean', () => { + expect(telephoneCheck('1 (555) 555-5555')).toBe(true); + expect(telephoneCheck('(555)555-5555')).toBe(true); + expect(telephoneCheck('555-5555')).toBe(false); + expect(telephoneCheck('1 555)555-5555')).toBe(false); + expect(telephoneCheck('123**&!!asdf#')).toBe(false); + expect(telephoneCheck('0 (757) 622-7382')).toBe(false); + expect(telephoneCheck('-1 (757) 622-7382')).toBe(false); + expect(telephoneCheck('(555)5(55?)-5555')).toBe(false); + }); +}); From e7fc987470e8fad11a28a2747ae49ae0e1d290a5 Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Sun, 15 Mar 2020 21:11:58 +0530 Subject: [PATCH 06/11] add the rot-13 question Added the Rot 13 question . A small/atomic update for teliphone as well --- js-exercises/rot-13/README.md | 7 +++++++ js-exercises/rot-13/rot13.js | 7 +++++++ js-exercises/rot-13/rot13.test.js | 10 ++++++++++ js-exercises/telephone-check/telephoneCheck.js | 6 ++++++ 4 files changed, 30 insertions(+) create mode 100644 js-exercises/rot-13/README.md create mode 100644 js-exercises/rot-13/rot13.js create mode 100644 js-exercises/rot-13/rot13.test.js diff --git a/js-exercises/rot-13/README.md b/js-exercises/rot-13/README.md new file mode 100644 index 00000000..229970b3 --- /dev/null +++ b/js-exercises/rot-13/README.md @@ -0,0 +1,7 @@ +One of the simplest and most widely known ciphers is a Caesar cipher, also known as a shift cipher. In a shift cipher the meanings of the letters are shifted by some set amount. + +A common modern use is the ROT13 cipher, where the values of the letters are shifted by 13 places. Thus 'A' ↔ 'N', 'B' ↔ 'O' and so on. + +Write a function which takes a ROT13 encoded string as input and returns a decoded string. + +All letters will be uppercase. Do not transform any non-alphabetic character (i.e. spaces, punctuation), but do pass them on. diff --git a/js-exercises/rot-13/rot13.js b/js-exercises/rot-13/rot13.js new file mode 100644 index 00000000..fe456a67 --- /dev/null +++ b/js-exercises/rot-13/rot13.js @@ -0,0 +1,7 @@ +function rot13(...args) { + return args; +} + +export { + rot13, +}; diff --git a/js-exercises/rot-13/rot13.test.js b/js-exercises/rot-13/rot13.test.js new file mode 100644 index 00000000..f1d14721 --- /dev/null +++ b/js-exercises/rot-13/rot13.test.js @@ -0,0 +1,10 @@ +import { rot13 } from './rot13'; + +describe('rot13', () => { + test('should correctly decipher the input', () => { + expect(rot13('SERR PBQR PNZC')).toEqual('FREE CODE CAMP'); + expect(rot13('SERR CVMMN!')).toEqual('FREE PIZZA!'); + expect(rot13('SERR YBIR?')).toEqual('FREE LOVE?'); + expect(rot13('GUR DHVPX OEBJA QBT WHZCRQ BIRE GUR YNML SBK.')).toEqual('THE QUICK BROWN DOG JUMPED OVER THE LAZY FOX.'); + }); +}); diff --git a/js-exercises/telephone-check/telephoneCheck.js b/js-exercises/telephone-check/telephoneCheck.js index db098887..9fd0cf66 100644 --- a/js-exercises/telephone-check/telephoneCheck.js +++ b/js-exercises/telephone-check/telephoneCheck.js @@ -9,6 +9,12 @@ * 2. If the phone number is iun the US phone number format return true else false * @param {String} (Phonenumber) */ + +/** + * this function is responsable for checking if the phone number is valied or not + * i have used a regex to perform the same please let me know ur openion + * @param {String} inputPhoneNumber + */ const regExMatcher = inputPhoneNumber => { const regex = /^(1\s)?\(?\d{3}(\))?(-|\s)?\d{3}(-|\s)?\d{4}$/; const pattern = new RegExp(regex); From 81124e82ceceb9f1a2982fc4d902a7b8263fa09d Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Sun, 15 Mar 2020 23:05:30 +0530 Subject: [PATCH 07/11] complete rot-13 Compleated the code to convert plain text to cipher text --- js-exercises/rot-13/rot13.js | 64 +++++++++++++++++++++++++++++++++--- 1 file changed, 59 insertions(+), 5 deletions(-) diff --git a/js-exercises/rot-13/rot13.js b/js-exercises/rot-13/rot13.js index fe456a67..1dfaf8c4 100644 --- a/js-exercises/rot-13/rot13.js +++ b/js-exercises/rot-13/rot13.js @@ -1,7 +1,61 @@ -function rot13(...args) { - return args; -} +/** + * Please be sincear and let me know about all the mistakes i have made + * please be a little kind as i am still a novoice and am still learning + * @Bhargav Mantha + * + * Procedure/Approach/psudo code i am following + * 1.convert the character to its respective ASCII Value. + * 2.once converted add 13 to it and convert it back to the character and join it. + * 3.And Ofcourse ignore the special characters + */ + +/** + *converts character to ASCII value + * @param {String} of length 1 character + */ +const getASCIIValuesOfCharacter = character => character.charCodeAt(); +/** + * COnverts ASCII Number Back to character + * @param {Number} number + */ +const convertBackToLetter = number => String.fromCharCode(number); -export { - rot13, +/** + *Determines The Value TO be added to the ASCII VALUE and convert it to Cipher text + * @param {Number} SHIFTNUMBERBY + * @param {Number} ASCIIValue + */ +const cipherCharacterASCIIValue = (SHIFTNUMBERBY, ASCIIValue) => { + if (ASCIIValue + SHIFTNUMBERBY > 90) { + return 64 + (SHIFTNUMBERBY - (90 - ASCIIValue)); + } + return ASCIIValue + SHIFTNUMBERBY; }; + +/** + *Main Function + * @param {String} inptString + */ +function rot13(inputString) { + const arrayOfLetters = inputString.split(''); + const SHIFTNUMBERBY = 13; + const cipheredArray = []; + + for (let i = 0; i < arrayOfLetters.length; i += 1) { + const character = arrayOfLetters[i]; + const ASCIIValue = getASCIIValuesOfCharacter(character); + if (ASCIIValue > 64) { + const getcipherCharacterASCIIValue = cipherCharacterASCIIValue( + SHIFTNUMBERBY, + ASCIIValue + ); + const cipheredCharacter = convertBackToLetter( + getcipherCharacterASCIIValue + ); + cipheredArray.push(cipheredCharacter); + } else cipheredArray.push(character); + } + + return cipheredArray.join(''); +} +export { rot13 }; From 51ca29d0861fbfd9216891bf9f59f70e2a47d9d1 Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Mon, 16 Mar 2020 00:24:42 +0530 Subject: [PATCH 08/11] complete abbrivatestring problem Abbrivate String problem completed @bhargavmantha the psudo code is written in the comments --- js-exercises/abbreviate-string/README.md | 7 +++++ .../abbreviate-string/abbreviateString.js | 31 +++++++++++++++++++ .../abbreviateString.test.js | 16 ++++++++++ js-exercises/rot-13/rot13.test.js | 4 ++- 4 files changed, 57 insertions(+), 1 deletion(-) create mode 100644 js-exercises/abbreviate-string/README.md create mode 100644 js-exercises/abbreviate-string/abbreviateString.js create mode 100644 js-exercises/abbreviate-string/abbreviateString.test.js diff --git a/js-exercises/abbreviate-string/README.md b/js-exercises/abbreviate-string/README.md new file mode 100644 index 00000000..51112bc2 --- /dev/null +++ b/js-exercises/abbreviate-string/README.md @@ -0,0 +1,7 @@ +# Instructions + +- Given a string return the abbreviated version of the string + +For example - + +Given `Hacktober Fest` as the input the function should return `Hacktober F.` diff --git a/js-exercises/abbreviate-string/abbreviateString.js b/js-exercises/abbreviate-string/abbreviateString.js new file mode 100644 index 00000000..8bc2faa1 --- /dev/null +++ b/js-exercises/abbreviate-string/abbreviateString.js @@ -0,0 +1,31 @@ +/** + * Please be sincear and let me know about all the mistakes i have made + * please be a little kind as i am still a novoice and am still learning + * @Bhargav Mantha + * + * Procedure/Approach/psudo code i am following + * 1.now check if the input is a string or else return an error + * 2.split the input string into words + * 3.make the abbrivation return it + */ +const util = require('util'); + +const getWordsFromString = string => string.split(' '); +const checkIfString = string => util.isString(string); +function abbreviateString(string) { + const stringCondition = checkIfString(string); + let abbrivatedString = ''; + if (stringCondition) { + const wordsArray = getWordsFromString(string); + abbrivatedString = `${wordsArray[0]} ${[ + ...wordsArray[wordsArray.length - 1], + ][0].toUpperCase()}.`; + return abbrivatedString; + } + const error = new Error( + `Sorry. Could not eveluate the input.Reason the input was not a sting.expected string got <${typeof string}>` + ); + throw error; +} +// console.log(abbreviateString('Leeroy Fitzgerald Jenkins')); +export { abbreviateString }; diff --git a/js-exercises/abbreviate-string/abbreviateString.test.js b/js-exercises/abbreviate-string/abbreviateString.test.js new file mode 100644 index 00000000..18716e04 --- /dev/null +++ b/js-exercises/abbreviate-string/abbreviateString.test.js @@ -0,0 +1,16 @@ +import { abbreviateString } from './abbreviateString'; + +describe('abbreviateString', () => { + it('abbreviates the following strings', () => { + expect(abbreviateString('Hacktober Fest')).toEqual('Hacktober F.'); + expect(abbreviateString('Leeroy Fitzgerald Jenkins')).toEqual('Leeroy J.'); + expect(abbreviateString('Some arbitrary string length here.')).toEqual('Some H.'); + }); + + it('throws error on invalid parameters', () => { + expect(() => abbreviateString(123)).toThrow(); + expect(() => abbreviateString([])).toThrow(); + expect(() => abbreviateString({})).toThrow(); + expect(() => abbreviateString(null)).toThrow(); + }); +}); diff --git a/js-exercises/rot-13/rot13.test.js b/js-exercises/rot-13/rot13.test.js index f1d14721..7e4f3f16 100644 --- a/js-exercises/rot-13/rot13.test.js +++ b/js-exercises/rot-13/rot13.test.js @@ -5,6 +5,8 @@ describe('rot13', () => { expect(rot13('SERR PBQR PNZC')).toEqual('FREE CODE CAMP'); expect(rot13('SERR CVMMN!')).toEqual('FREE PIZZA!'); expect(rot13('SERR YBIR?')).toEqual('FREE LOVE?'); - expect(rot13('GUR DHVPX OEBJA QBT WHZCRQ BIRE GUR YNML SBK.')).toEqual('THE QUICK BROWN DOG JUMPED OVER THE LAZY FOX.'); + expect(rot13('GUR DHVPX OEBJA QBT WHZCRQ BIRE GUR YNML SBK.')).toEqual( + 'THE QUICK BROWN DOG JUMPED OVER THE LAZY FOX.' + ); }); }); From 52429297d8fb659f14b8214bb0968c37345b13c0 Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Mon, 16 Mar 2020 00:28:40 +0530 Subject: [PATCH 09/11] fetch question add-big-integer get the questions add big integers --- .../abbreviateString.test.js | 4 ++- js-exercises/add-big-integers/README.md | 17 +++++++++ .../add-big-integers/addBigIntegers.js | 3 ++ .../add-big-integers/addBigIntegers.test.js | 35 +++++++++++++++++++ 4 files changed, 58 insertions(+), 1 deletion(-) create mode 100644 js-exercises/add-big-integers/README.md create mode 100644 js-exercises/add-big-integers/addBigIntegers.js create mode 100644 js-exercises/add-big-integers/addBigIntegers.test.js diff --git a/js-exercises/abbreviate-string/abbreviateString.test.js b/js-exercises/abbreviate-string/abbreviateString.test.js index 18716e04..fb07857a 100644 --- a/js-exercises/abbreviate-string/abbreviateString.test.js +++ b/js-exercises/abbreviate-string/abbreviateString.test.js @@ -4,7 +4,9 @@ describe('abbreviateString', () => { it('abbreviates the following strings', () => { expect(abbreviateString('Hacktober Fest')).toEqual('Hacktober F.'); expect(abbreviateString('Leeroy Fitzgerald Jenkins')).toEqual('Leeroy J.'); - expect(abbreviateString('Some arbitrary string length here.')).toEqual('Some H.'); + expect(abbreviateString('Some arbitrary string length here.')).toEqual( + 'Some H.' + ); }); it('throws error on invalid parameters', () => { diff --git a/js-exercises/add-big-integers/README.md b/js-exercises/add-big-integers/README.md new file mode 100644 index 00000000..8b633faa --- /dev/null +++ b/js-exercises/add-big-integers/README.md @@ -0,0 +1,17 @@ +# Instructions + +- Given a string with numbers separated by `\n`, return the sum of these numbers + +For example - + +```js +`539 +8 +201`; +``` + +// Add the numbers 539, 8 and 201 + +# Restrictions + +- Don't use `BigInt` implementation of JavaScript. diff --git a/js-exercises/add-big-integers/addBigIntegers.js b/js-exercises/add-big-integers/addBigIntegers.js new file mode 100644 index 00000000..cf809e9f --- /dev/null +++ b/js-exercises/add-big-integers/addBigIntegers.js @@ -0,0 +1,3 @@ +function addBigIntegers(intString) {} + +export { addBigIntegers }; diff --git a/js-exercises/add-big-integers/addBigIntegers.test.js b/js-exercises/add-big-integers/addBigIntegers.test.js new file mode 100644 index 00000000..fa9fcad0 --- /dev/null +++ b/js-exercises/add-big-integers/addBigIntegers.test.js @@ -0,0 +1,35 @@ +import { addBigIntegers } from "./addBigIntegers"; + +describe("addBigIntegers", () => { + it("Adds a series of large integers", () => { + expect( + addBigIntegers(`539 +8 +201`) + ).toEqual("748"); + expect( + addBigIntegers(`8284089949645109317773 +5840714128396983596239 +12946447842028638908267 +79798868618779259038022`) + ).toEqual("106870120538849990860301"); + expect( + addBigIntegers(`8756499060735809031881837100717640 +70934460872207922801951375249700 +8977770975897338226131985886684681 +91454061215320969515432196409002 +651196844487299640943680194655725 +6961749288159882186283784162262 +9036094416288347680296039655938060 +939687434873009984637644098803640 +79366258890858900774075693801787 +14118147069715140307096132393279 +934555969025599810767196778088364 +7551918592800103991210533406382642`) + ).toEqual("37110557971443771181453756303286782"); + expect( + addBigIntegers(`437720396187259475835238781865656019744046796313512520697126 +984916770573810944707747942410200944569369114644474457801304`) + ).toEqual("1422637166761070420542986724275856964313415910957986978498430"); + }); +}); From 0fea65e0a86b5b3b03811dbb6efd2f23893977e9 Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Mon, 16 Mar 2020 10:28:36 +0530 Subject: [PATCH 10/11] complete BigInteger sum The sum of Big integer promlem compleated @bhargavmantha the how and when is describes in the comments --- .../add-big-integers/addBigIntegers.js | 161 +++++++++++++++++- 1 file changed, 160 insertions(+), 1 deletion(-) diff --git a/js-exercises/add-big-integers/addBigIntegers.js b/js-exercises/add-big-integers/addBigIntegers.js index cf809e9f..dc378e7d 100644 --- a/js-exercises/add-big-integers/addBigIntegers.js +++ b/js-exercises/add-big-integers/addBigIntegers.js @@ -1,3 +1,162 @@ -function addBigIntegers(intString) {} +/** + * Please be sincear and let me know about all the mistakes i have made + * please be a little kind as i am still a novoice and am still learning + * @Bhargav Mantha + * + * consider the example [ '539', '8', '201' ] in string literal format on convertion we get + * Procedure/Approach/psudo code i am following + * 1.Step one Split the string into specific numbers Strings based on \n =>[ '539', '8', '201' ] + * 2.now get the greatest length in the above array array => in the abpove case its 3 + * 3. now add zeros to the places without the same for missing positions + * ex---[ '539', '008', '201' ] + * 4.now we generate a big number JSON with key as the units(0),once(1),tens(2) and so onn=> + * { + '0': [ '2', '0', '5' ], + '1': [ '0', '0', '3' ], + '2': [ '1', '8', '9' ] + } + * + * + * + * 5.now calculate the sume of each array + * 6.pass On the carry + * 7.reverse the array + * VOOOLAA we have the sum of big integers + * */ + +/** + *function to split the string by \n + * @param {String} intString + */ +const splitStringBasedOnNewLine = intString => intString.split('\n'); + +/** + * returns the length of trhe greatest array number + * @param {Array Object} bigNumbersArray + */ +const getLargestLengthInArray = bigNumbersArray => { + let largestLength = 0; + + for (let i = 0; i < bigNumbersArray.length; i += 1) { + if (bigNumbersArray[i].length > largestLength) { + largestLength = bigNumbersArray[i].length; + } + } + return largestLength; +}; +/** + *returns the JSON OF THE BIGNUMBER + * @param {Array Object} bigNumbersArray + */ +const bigNumberJSONGenerator = bigNumbersArray => { + const bigNumbersJSON = {}; + + // eslint-disable-next-line no-unused-vars + for (const key of bigNumbersArray.keys()) { + bigNumbersJSON[`${key}`] = bigNumbersArray[`${key}`]; + } + return bigNumbersJSON; +}; +/** + * returns the mapped position array object + * @param {number} bignumber + * @param {Obj} OBJECT + */ +const positionMapperJSONGenerator = (bignumber, OBJECT) => { + const bigNumberArray = [...bignumber]; + // eslint-disable-next-line no-unused-vars + for (let i = 0; i < OBJECT.largestLength; i += 1) { + const number = OBJECT.bigNumbersPositionMapperJSON[`${i}`]; + OBJECT.bigNumbersPositionMapperJSON[`${i}`] = + number === undefined + ? bigNumberArray[`${i}`] + : [bigNumberArray[`${i}`], ...number]; + // console.log(bigNumberArray[`${i}`]); + } + + return OBJECT.bigNumbersPositionMapperJSON; +}; + +const positionTrackerJsonGenerator = (bigNumbersJSON, largestLength) => { + const bigNumbersPositionMapperJSON = {}; + + const OBJECT = { + largestLength, + bigNumbersPositionMapperJSON, + }; + Object.keys(bigNumbersJSON).forEach(function(key) { + positionMapperJSONGenerator(bigNumbersJSON[`${key}`], OBJECT); + }); + return bigNumbersPositionMapperJSON; +}; +/** + *returns the string with length of the largest big integer with + replaced missing 0 + * @param {Array Object} bigNumbersArray + * @param {Number} largestLength + */ +const recursive0Adder = (bigNumbersArray, largestLength) => { + const finalArray = []; + bigNumbersArray.forEach(element => { + let i = 0; + while (element.length < largestLength) { + i += 1; + // eslint-disable-next-line no-param-reassign + element = `0${element}`; + } + finalArray.push(element); + }); + return finalArray; +}; +/** + * returns Sum of the array + * @param {Array Object} array + */ +const sumOfAnArray = array => + array.reduce( + (previousElement, nextElement) => + parseInt(previousElement) + parseInt(nextElement), + 0 + ); +/** + * returns The actual sum of the Big integer + * @param {JSON object} positionTrackerJSON + */ +const bigIntegerSumCalculator = positionTrackerJSON => { + let sumArray = []; + let sum = 0; + let carry = 0; + for (let i = Object.keys(positionTrackerJSON).length - 1; i >= 0; i -= 1) { + let temp = sumOfAnArray(positionTrackerJSON[`${i}`]); + + temp = `${temp}`; + sum = (parseInt(temp) % 10) + parseInt(carry); + + carry = Math.trunc(parseInt(temp) / 10); + + sumArray.push(`${sum}`); + } + sumArray = sumArray.reverse().join(''); + + return sumArray; +}; +/** + * the actual function call + * @param {String literal} intString + */ +function addBigIntegers(intString) { + let bigNumbersArray = splitStringBasedOnNewLine(intString); + + const largestLength = getLargestLengthInArray(bigNumbersArray); + bigNumbersArray = recursive0Adder(bigNumbersArray, largestLength); + + const bigNumbersJSON = bigNumberJSONGenerator(bigNumbersArray); + const positionTrackerJSON = positionTrackerJsonGenerator( + bigNumbersJSON, + largestLength + ); + const sumOfBigintegers = bigIntegerSumCalculator(positionTrackerJSON); + return sumOfBigintegers; +} export { addBigIntegers }; From 0737ece5ceab4c08b9ec261fcb3697a311f49f6f Mon Sep 17 00:00:00 2001 From: BhargavMantha Date: Mon, 16 Mar 2020 10:37:15 +0530 Subject: [PATCH 11/11] Add trim functionality added trim functionality --- .../add-big-integers/addBigIntegers.js | 24 +++++++++++++++---- .../add-big-integers/addBigIntegers.test.js | 14 +++++------ 2 files changed, 26 insertions(+), 12 deletions(-) diff --git a/js-exercises/add-big-integers/addBigIntegers.js b/js-exercises/add-big-integers/addBigIntegers.js index dc378e7d..01b4bbff 100644 --- a/js-exercises/add-big-integers/addBigIntegers.js +++ b/js-exercises/add-big-integers/addBigIntegers.js @@ -137,7 +137,7 @@ const bigIntegerSumCalculator = positionTrackerJSON => { sumArray.push(`${sum}`); } sumArray = sumArray.reverse().join(''); - + console.log(sumArray); return sumArray; }; /** @@ -146,17 +146,31 @@ const bigIntegerSumCalculator = positionTrackerJSON => { */ function addBigIntegers(intString) { let bigNumbersArray = splitStringBasedOnNewLine(intString); - + bigNumbersArray = bigNumbersArray.map(element => element.trim()); + /* console.log(bigNumbersArray); */ const largestLength = getLargestLengthInArray(bigNumbersArray); bigNumbersArray = recursive0Adder(bigNumbersArray, largestLength); - + /* console.log(bigNumbersArray); */ const bigNumbersJSON = bigNumberJSONGenerator(bigNumbersArray); const positionTrackerJSON = positionTrackerJsonGenerator( bigNumbersJSON, largestLength ); + // console.log(positionTrackerJSON); const sumOfBigintegers = bigIntegerSumCalculator(positionTrackerJSON); - return sumOfBigintegers; + /* console.log(sumOfBigintegers); */ } - +/* addBigIntegers(`8756499060735809031881837100717640 +70934460872207922801951375249700 +8977770975897338226131985886684681 +91454061215320969515432196409002 +651196844487299640943680194655725 +6961749288159882186283784162262 +9036094416288347680296039655938060 +939687434873009984637644098803640 +79366258890858900774075693801787 +14118147069715140307096132393279 +934555969025599810767196778088364 +7551918592800103991210533406382642`); + */ export { addBigIntegers }; diff --git a/js-exercises/add-big-integers/addBigIntegers.test.js b/js-exercises/add-big-integers/addBigIntegers.test.js index fa9fcad0..fe02e5e1 100644 --- a/js-exercises/add-big-integers/addBigIntegers.test.js +++ b/js-exercises/add-big-integers/addBigIntegers.test.js @@ -1,18 +1,18 @@ -import { addBigIntegers } from "./addBigIntegers"; +import { addBigIntegers } from './addBigIntegers'; -describe("addBigIntegers", () => { - it("Adds a series of large integers", () => { +describe('addBigIntegers', () => { + it('Adds a series of large integers', () => { expect( addBigIntegers(`539 8 201`) - ).toEqual("748"); + ).toEqual('748'); expect( addBigIntegers(`8284089949645109317773 5840714128396983596239 12946447842028638908267 79798868618779259038022`) - ).toEqual("106870120538849990860301"); + ).toEqual('106870120538849990860301'); expect( addBigIntegers(`8756499060735809031881837100717640 70934460872207922801951375249700 @@ -26,10 +26,10 @@ describe("addBigIntegers", () => { 14118147069715140307096132393279 934555969025599810767196778088364 7551918592800103991210533406382642`) - ).toEqual("37110557971443771181453756303286782"); + ).toEqual('37110557971443771181453756303286782'); expect( addBigIntegers(`437720396187259475835238781865656019744046796313512520697126 984916770573810944707747942410200944569369114644474457801304`) - ).toEqual("1422637166761070420542986724275856964313415910957986978498430"); + ).toEqual('1422637166761070420542986724275856964313415910957986978498430'); }); });