Compare commits
1 Commits
release/20
...
fix/env-se
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ad5accf2a8 |
@@ -1,2 +0,0 @@
|
|||||||
node_modules
|
|
||||||
**/*/node_modules
|
|
||||||
@@ -13,7 +13,6 @@ SESSION_SECRET='add some secret here'
|
|||||||
# Hoppscotch App Domain Config
|
# Hoppscotch App Domain Config
|
||||||
REDIRECT_URL="http://localhost:3000"
|
REDIRECT_URL="http://localhost:3000"
|
||||||
WHITELISTED_ORIGINS = "http://localhost:3170,http://localhost:3000,http://localhost:3100"
|
WHITELISTED_ORIGINS = "http://localhost:3170,http://localhost:3000,http://localhost:3100"
|
||||||
VITE_ALLOWED_AUTH_PROVIDERS = GOOGLE,GITHUB,MICROSOFT,EMAIL
|
|
||||||
|
|
||||||
# Google Auth Config
|
# Google Auth Config
|
||||||
GOOGLE_CLIENT_ID="************************************************"
|
GOOGLE_CLIENT_ID="************************************************"
|
||||||
@@ -32,7 +31,6 @@ MICROSOFT_CLIENT_ID="************************************************"
|
|||||||
MICROSOFT_CLIENT_SECRET="************************************************"
|
MICROSOFT_CLIENT_SECRET="************************************************"
|
||||||
MICROSOFT_CALLBACK_URL="http://localhost:3170/v1/auth/microsoft/callback"
|
MICROSOFT_CALLBACK_URL="http://localhost:3170/v1/auth/microsoft/callback"
|
||||||
MICROSOFT_SCOPE="user.read"
|
MICROSOFT_SCOPE="user.read"
|
||||||
MICROSOFT_TENANT="common"
|
|
||||||
|
|
||||||
# Mailer config
|
# Mailer config
|
||||||
MAILER_SMTP_URL="smtps://user@domain.com:pass@smtp.domain.com"
|
MAILER_SMTP_URL="smtps://user@domain.com:pass@smtp.domain.com"
|
||||||
|
|||||||
81
.github/workflows/release-push-docker.yml
vendored
81
.github/workflows/release-push-docker.yml
vendored
@@ -1,81 +0,0 @@
|
|||||||
name: "Push containers to Docker Hub on release"
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
tags:
|
|
||||||
- '*.*.*'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Setup environment
|
|
||||||
run: cp .env.example .env
|
|
||||||
|
|
||||||
- name: Setup QEMU
|
|
||||||
uses: docker/setup-qemu-action@v3
|
|
||||||
|
|
||||||
- name: Log in to Docker Hub
|
|
||||||
uses: docker/login-action@v2
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKER_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
|
||||||
|
|
||||||
- name: Build and push the backend container
|
|
||||||
uses: docker/build-push-action@v4
|
|
||||||
with:
|
|
||||||
context: .
|
|
||||||
file: ./prod.Dockerfile
|
|
||||||
target: backend
|
|
||||||
push: true
|
|
||||||
platforms: |
|
|
||||||
linux/amd64
|
|
||||||
linux/arm64
|
|
||||||
tags: |
|
|
||||||
${{ secrets.DOCKER_ORG_NAME }}/${{ secrets.DOCKER_BACKEND_CONTAINER_NAME }}:latest
|
|
||||||
${{ secrets.DOCKER_ORG_NAME }}/${{ secrets.DOCKER_BACKEND_CONTAINER_NAME }}:${{ github.ref_name }}
|
|
||||||
|
|
||||||
- name: Build and push the frontend container
|
|
||||||
uses: docker/build-push-action@v4
|
|
||||||
with:
|
|
||||||
context: .
|
|
||||||
file: ./prod.Dockerfile
|
|
||||||
target: app
|
|
||||||
push: true
|
|
||||||
platforms: |
|
|
||||||
linux/amd64
|
|
||||||
linux/arm64
|
|
||||||
tags: |
|
|
||||||
${{ secrets.DOCKER_ORG_NAME }}/${{ secrets.DOCKER_FRONTEND_CONTAINER_NAME }}:latest
|
|
||||||
${{ secrets.DOCKER_ORG_NAME }}/${{ secrets.DOCKER_FRONTEND_CONTAINER_NAME }}:${{ github.ref_name }}
|
|
||||||
|
|
||||||
- name: Build and push the admin dashboard container
|
|
||||||
uses: docker/build-push-action@v4
|
|
||||||
with:
|
|
||||||
context: .
|
|
||||||
file: ./prod.Dockerfile
|
|
||||||
target: sh_admin
|
|
||||||
push: true
|
|
||||||
platforms: |
|
|
||||||
linux/amd64
|
|
||||||
linux/arm64
|
|
||||||
tags: |
|
|
||||||
${{ secrets.DOCKER_ORG_NAME }}/${{ secrets.DOCKER_SH_ADMIN_CONTAINER_NAME }}:latest
|
|
||||||
${{ secrets.DOCKER_ORG_NAME }}/${{ secrets.DOCKER_SH_ADMIN_CONTAINER_NAME }}:${{ github.ref_name }}
|
|
||||||
|
|
||||||
- name: Build and push the AIO container
|
|
||||||
uses: docker/build-push-action@v4
|
|
||||||
with:
|
|
||||||
context: .
|
|
||||||
file: ./prod.Dockerfile
|
|
||||||
target: aio
|
|
||||||
push: true
|
|
||||||
platforms: |
|
|
||||||
linux/amd64
|
|
||||||
linux/arm64
|
|
||||||
tags: |
|
|
||||||
${{ secrets.DOCKER_ORG_NAME }}/${{ secrets.DOCKER_AIO_CONTAINER_NAME }}:latest
|
|
||||||
${{ secrets.DOCKER_ORG_NAME }}/${{ secrets.DOCKER_AIO_CONTAINER_NAME }}:${{ github.ref_name }}
|
|
||||||
4
.github/workflows/tests.yml
vendored
4
.github/workflows/tests.yml
vendored
@@ -2,9 +2,9 @@ name: Node.js CI
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: [main, staging, "release/**"]
|
branches: [main, staging]
|
||||||
pull_request:
|
pull_request:
|
||||||
branches: [main, staging, "release/**"]
|
branches: [main, staging]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
test:
|
test:
|
||||||
|
|||||||
42
.github/workflows/ui.yml
vendored
42
.github/workflows/ui.yml
vendored
@@ -1,42 +0,0 @@
|
|||||||
name: Deploy to Netlify (ui)
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches: [main]
|
|
||||||
# run this workflow only if an update is made to the ui package
|
|
||||||
paths:
|
|
||||||
- "packages/hoppscotch-ui/**"
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy:
|
|
||||||
name: Deploy
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Setup environment
|
|
||||||
run: mv .env.example .env
|
|
||||||
|
|
||||||
- name: Setup pnpm
|
|
||||||
uses: pnpm/action-setup@v2.2.4
|
|
||||||
with:
|
|
||||||
version: 8
|
|
||||||
run_install: true
|
|
||||||
|
|
||||||
- name: Setup node
|
|
||||||
uses: actions/setup-node@v3
|
|
||||||
with:
|
|
||||||
node-version: ${{ matrix.node }}
|
|
||||||
cache: pnpm
|
|
||||||
|
|
||||||
- name: Build site
|
|
||||||
run: pnpm run generate-ui
|
|
||||||
|
|
||||||
# Deploy the ui site with netlify-cli
|
|
||||||
- name: Deploy to Netlify (ui)
|
|
||||||
run: npx netlify-cli deploy --dir=packages/hoppscotch-ui/.histoire/dist --prod
|
|
||||||
env:
|
|
||||||
NETLIFY_SITE_ID: ${{ secrets.NETLIFY_UI_SITE_ID }}
|
|
||||||
NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }}
|
|
||||||
@@ -1,8 +1,3 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
semi: false,
|
semi: false
|
||||||
trailingComma: "es5",
|
|
||||||
singleQuote: false,
|
|
||||||
printWidth: 80,
|
|
||||||
useTabs: false,
|
|
||||||
tabWidth: 2
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,8 +6,8 @@ We as members, contributors, and leaders pledge to make participation in our
|
|||||||
community a harassment-free experience for everyone, regardless of age, body
|
community a harassment-free experience for everyone, regardless of age, body
|
||||||
size, visible or invisible disability, ethnicity, sex characteristics, gender
|
size, visible or invisible disability, ethnicity, sex characteristics, gender
|
||||||
identity and expression, level of experience, education, socio-economic status,
|
identity and expression, level of experience, education, socio-economic status,
|
||||||
nationality, personal appearance, race, caste, color, religion, or sexual
|
nationality, personal appearance, race, religion, or sexual identity
|
||||||
identity and orientation.
|
and orientation.
|
||||||
|
|
||||||
We pledge to act and interact in ways that contribute to an open, welcoming,
|
We pledge to act and interact in ways that contribute to an open, welcoming,
|
||||||
diverse, inclusive, and healthy community.
|
diverse, inclusive, and healthy community.
|
||||||
@@ -22,17 +22,17 @@ community include:
|
|||||||
* Giving and gracefully accepting constructive feedback
|
* Giving and gracefully accepting constructive feedback
|
||||||
* Accepting responsibility and apologizing to those affected by our mistakes,
|
* Accepting responsibility and apologizing to those affected by our mistakes,
|
||||||
and learning from the experience
|
and learning from the experience
|
||||||
* Focusing on what is best not just for us as individuals, but for the overall
|
* Focusing on what is best not just for us as individuals, but for the
|
||||||
community
|
overall community
|
||||||
|
|
||||||
Examples of unacceptable behavior include:
|
Examples of unacceptable behavior include:
|
||||||
|
|
||||||
* The use of sexualized language or imagery, and sexual attention or advances of
|
* The use of sexualized language or imagery, and sexual attention or
|
||||||
any kind
|
advances of any kind
|
||||||
* Trolling, insulting or derogatory comments, and personal or political attacks
|
* Trolling, insulting or derogatory comments, and personal or political attacks
|
||||||
* Public or private harassment
|
* Public or private harassment
|
||||||
* Publishing others' private information, such as a physical or email address,
|
* Publishing others' private information, such as a physical or email
|
||||||
without their explicit permission
|
address, without their explicit permission
|
||||||
* Other conduct which could reasonably be considered inappropriate in a
|
* Other conduct which could reasonably be considered inappropriate in a
|
||||||
professional setting
|
professional setting
|
||||||
|
|
||||||
@@ -82,15 +82,15 @@ behavior was inappropriate. A public apology may be requested.
|
|||||||
|
|
||||||
### 2. Warning
|
### 2. Warning
|
||||||
|
|
||||||
**Community Impact**: A violation through a single incident or series of
|
**Community Impact**: A violation through a single incident or series
|
||||||
actions.
|
of actions.
|
||||||
|
|
||||||
**Consequence**: A warning with consequences for continued behavior. No
|
**Consequence**: A warning with consequences for continued behavior. No
|
||||||
interaction with the people involved, including unsolicited interaction with
|
interaction with the people involved, including unsolicited interaction with
|
||||||
those enforcing the Code of Conduct, for a specified period of time. This
|
those enforcing the Code of Conduct, for a specified period of time. This
|
||||||
includes avoiding interactions in community spaces as well as external channels
|
includes avoiding interactions in community spaces as well as external channels
|
||||||
like social media. Violating these terms may lead to a temporary or permanent
|
like social media. Violating these terms may lead to a temporary or
|
||||||
ban.
|
permanent ban.
|
||||||
|
|
||||||
### 3. Temporary Ban
|
### 3. Temporary Ban
|
||||||
|
|
||||||
@@ -109,24 +109,20 @@ Violating these terms may lead to a permanent ban.
|
|||||||
standards, including sustained inappropriate behavior, harassment of an
|
standards, including sustained inappropriate behavior, harassment of an
|
||||||
individual, or aggression toward or disparagement of classes of individuals.
|
individual, or aggression toward or disparagement of classes of individuals.
|
||||||
|
|
||||||
**Consequence**: A permanent ban from any sort of public interaction within the
|
**Consequence**: A permanent ban from any sort of public interaction within
|
||||||
community.
|
the community.
|
||||||
|
|
||||||
## Attribution
|
## Attribution
|
||||||
|
|
||||||
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
|
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
|
||||||
version 2.1, available at
|
version 2.0, available at
|
||||||
[https://www.contributor-covenant.org/version/2/1/code_of_conduct.html][v2.1].
|
https://www.contributor-covenant.org/version/2/0/code_of_conduct.html.
|
||||||
|
|
||||||
Community Impact Guidelines were inspired by
|
Community Impact Guidelines were inspired by [Mozilla's code of conduct
|
||||||
[Mozilla's code of conduct enforcement ladder][Mozilla CoC].
|
enforcement ladder](https://github.com/mozilla/diversity).
|
||||||
|
|
||||||
For answers to common questions about this code of conduct, see the FAQ at
|
|
||||||
[https://www.contributor-covenant.org/faq][FAQ]. Translations are available at
|
|
||||||
[https://www.contributor-covenant.org/translations][translations].
|
|
||||||
|
|
||||||
[homepage]: https://www.contributor-covenant.org
|
[homepage]: https://www.contributor-covenant.org
|
||||||
[v2.1]: https://www.contributor-covenant.org/version/2/1/code_of_conduct.html
|
|
||||||
[Mozilla CoC]: https://github.com/mozilla/diversity
|
For answers to common questions about this code of conduct, see the FAQ at
|
||||||
[FAQ]: https://www.contributor-covenant.org/faq
|
https://www.contributor-covenant.org/faq. Translations are available at
|
||||||
[translations]: https://www.contributor-covenant.org/translations
|
https://www.contributor-covenant.org/translations.
|
||||||
|
|||||||
180
README.md
180
README.md
@@ -2,18 +2,23 @@
|
|||||||
<a href="https://hoppscotch.io">
|
<a href="https://hoppscotch.io">
|
||||||
<img
|
<img
|
||||||
src="https://avatars.githubusercontent.com/u/56705483"
|
src="https://avatars.githubusercontent.com/u/56705483"
|
||||||
alt="Hoppscotch"
|
alt="Hoppscotch Logo"
|
||||||
height="64"
|
height="64"
|
||||||
/>
|
/>
|
||||||
</a>
|
</a>
|
||||||
|
<br />
|
||||||
|
<p>
|
||||||
<h3>
|
<h3>
|
||||||
<b>
|
<b>
|
||||||
Hoppscotch
|
Hoppscotch
|
||||||
</b>
|
</b>
|
||||||
</h3>
|
</h3>
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
<b>
|
<b>
|
||||||
Open Source API Development Ecosystem
|
Open source API development ecosystem
|
||||||
</b>
|
</b>
|
||||||
|
</p>
|
||||||
<p>
|
<p>
|
||||||
|
|
||||||
[](CODE_OF_CONDUCT.md) [](https://hoppscotch.io) [](https://github.com/hoppscotch/hoppscotch/actions) [](https://twitter.com/share?text=%F0%9F%91%BD%20Hoppscotch%20%E2%80%A2%20Open%20source%20API%20development%20ecosystem%20-%20Helps%20you%20create%20requests%20faster,%20saving%20precious%20time%20on%20development.&url=https://hoppscotch.io&hashtags=hoppscotch&via=hoppscotch_io)
|
[](CODE_OF_CONDUCT.md) [](https://hoppscotch.io) [](https://github.com/hoppscotch/hoppscotch/actions) [](https://twitter.com/share?text=%F0%9F%91%BD%20Hoppscotch%20%E2%80%A2%20Open%20source%20API%20development%20ecosystem%20-%20Helps%20you%20create%20requests%20faster,%20saving%20precious%20time%20on%20development.&url=https://hoppscotch.io&hashtags=hoppscotch&via=hoppscotch_io)
|
||||||
@@ -29,18 +34,23 @@
|
|||||||
</p>
|
</p>
|
||||||
<br />
|
<br />
|
||||||
<p>
|
<p>
|
||||||
<a href="https://hoppscotch.io">
|
<a href="https://hoppscotch.io/#gh-light-mode-only" target="_blank">
|
||||||
<picture>
|
<img
|
||||||
<source media="(prefers-color-scheme: dark)" srcset="./packages/hoppscotch-common/public/images/banner-dark.png">
|
src="./packages/hoppscotch-common/public/images/banner-light.png"
|
||||||
<source media="(prefers-color-scheme: light)" srcset="./packages/hoppscotch-common/public/images/banner-light.png">
|
alt="Hoppscotch"
|
||||||
<img alt="Hoppscotch" src="./packages/hoppscotch-common/public/images/banner-dark.png">
|
width="100%"
|
||||||
</picture>
|
/>
|
||||||
|
</a>
|
||||||
|
<a href="https://hoppscotch.io/#gh-dark-mode-only" target="_blank">
|
||||||
|
<img
|
||||||
|
src="./packages/hoppscotch-common/public/images/banner-dark.png"
|
||||||
|
alt="Hoppscotch"
|
||||||
|
width="100%"
|
||||||
|
/>
|
||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
_We highly recommend you take a look at the [**Hoppscotch Documentation**](https://docs.hoppscotch.io) to learn more about the app._
|
|
||||||
|
|
||||||
#### **Support**
|
#### **Support**
|
||||||
|
|
||||||
[](https://hoppscotch.io/discord) [](https://hoppscotch.io/telegram) [](https://github.com/hoppscotch/hoppscotch/discussions)
|
[](https://hoppscotch.io/discord) [](https://hoppscotch.io/telegram) [](https://github.com/hoppscotch/hoppscotch/discussions)
|
||||||
@@ -49,9 +59,9 @@ _We highly recommend you take a look at the [**Hoppscotch Documentation**](https
|
|||||||
|
|
||||||
❤️ **Lightweight:** Crafted with minimalistic UI design.
|
❤️ **Lightweight:** Crafted with minimalistic UI design.
|
||||||
|
|
||||||
⚡️ **Fast:** Send requests and get responses in real time.
|
⚡️ **Fast:** Send requests and get/copy responses in real-time.
|
||||||
|
|
||||||
🗄️ **HTTP Methods:** Request methods define the type of action you are requesting to be performed.
|
**HTTP Methods**
|
||||||
|
|
||||||
- `GET` - Requests retrieve resource information
|
- `GET` - Requests retrieve resource information
|
||||||
- `POST` - The server creates a new entry in a database
|
- `POST` - The server creates a new entry in a database
|
||||||
@@ -64,15 +74,17 @@ _We highly recommend you take a look at the [**Hoppscotch Documentation**](https
|
|||||||
- `TRACE` - Performs a message loop-back test along the path to the target resource
|
- `TRACE` - Performs a message loop-back test along the path to the target resource
|
||||||
- `<custom>` - Some APIs use custom request methods such as `LIST`. Type in your custom methods.
|
- `<custom>` - Some APIs use custom request methods such as `LIST`. Type in your custom methods.
|
||||||
|
|
||||||
🌈 **Theming:** Customizable combinations for background, foreground, and accent colors — [customize now](https://hoppscotch.io/settings).
|
🌈 **Make it yours:** Customizable combinations for background, foreground, and accent colors — [customize now](https://hoppscotch.io/settings).
|
||||||
|
|
||||||
- Choose a theme: System preference, Light, Dark, and Black
|
**Theming**
|
||||||
- Choose accent colors: Green, Teal, Blue, Indigo, Purple, Yellow, Orange, Red, and Pink
|
|
||||||
|
- Choose a theme: System (default), Light, Dark, and Black
|
||||||
|
- Choose accent color: Green (default), Teal, Blue, Indigo, Purple, Yellow, Orange, Red, and Pink
|
||||||
- Distraction-free Zen mode
|
- Distraction-free Zen mode
|
||||||
|
|
||||||
_Customized themes are synced with your cloud/local session._
|
_Customized themes are synced with cloud / local session_
|
||||||
|
|
||||||
🔥 **PWA:** Install as a [Progressive Web App](https://web.dev/progressive-web-apps) on your device.
|
🔥 **PWA:** Install as a [PWA](https://web.dev/what-are-pwas/) on your device.
|
||||||
|
|
||||||
- Instant loading with Service Workers
|
- Instant loading with Service Workers
|
||||||
- Offline support
|
- Offline support
|
||||||
@@ -95,7 +107,7 @@ _Customized themes are synced with your cloud/local session._
|
|||||||
|
|
||||||
📡 **Server-Sent Events:** Receive a stream of updates from a server over an HTTP connection without resorting to polling.
|
📡 **Server-Sent Events:** Receive a stream of updates from a server over an HTTP connection without resorting to polling.
|
||||||
|
|
||||||
🌩 **Socket.IO:** Send and Receive data with the SocketIO server.
|
🌩 **Socket.IO:** Send and Receive data with SocketIO server.
|
||||||
|
|
||||||
🦟 **MQTT:** Subscribe and Publish to topics of an MQTT Broker.
|
🦟 **MQTT:** Subscribe and Publish to topics of an MQTT Broker.
|
||||||
|
|
||||||
@@ -115,7 +127,7 @@ _Customized themes are synced with your cloud/local session._
|
|||||||
- OAuth 2.0
|
- OAuth 2.0
|
||||||
- OIDC Access Token/PKCE
|
- OIDC Access Token/PKCE
|
||||||
|
|
||||||
📢 **Headers:** Describes the format the body of your request is being sent in.
|
📢 **Headers:** Describes the format the body of your request is being sent as.
|
||||||
|
|
||||||
📫 **Parameters:** Use request parameters to set varying parts in simulated requests.
|
📫 **Parameters:** Use request parameters to set varying parts in simulated requests.
|
||||||
|
|
||||||
@@ -125,14 +137,14 @@ _Customized themes are synced with your cloud/local session._
|
|||||||
- FormData, JSON, and many more
|
- FormData, JSON, and many more
|
||||||
- Toggle between key-value and RAW input parameter list
|
- Toggle between key-value and RAW input parameter list
|
||||||
|
|
||||||
📮 **Response:** Contains the status line, headers, and the message/response body.
|
👋 **Response:** Contains the status line, headers, and the message/response body.
|
||||||
|
|
||||||
- Copy the response to the clipboard
|
- Copy response to clipboard
|
||||||
- Download the response as a file
|
- Download response as a file
|
||||||
- View response headers
|
- View response headers
|
||||||
- View raw and preview HTML, image, JSON, and XML responses
|
- View raw and preview of HTML, image, JSON, XML responses
|
||||||
|
|
||||||
⏰ **History:** Request entries are synced with your cloud/local session storage.
|
⏰ **History:** Request entries are synced with cloud / local session storage to restore with a single click.
|
||||||
|
|
||||||
📁 **Collections:** Keep your API requests organized with collections and folders. Reuse them with a single click.
|
📁 **Collections:** Keep your API requests organized with collections and folders. Reuse them with a single click.
|
||||||
|
|
||||||
@@ -140,32 +152,7 @@ _Customized themes are synced with your cloud/local session._
|
|||||||
- Nested folders
|
- Nested folders
|
||||||
- Export and import as a file or GitHub gist
|
- Export and import as a file or GitHub gist
|
||||||
|
|
||||||
_Collections are synced with your cloud/local session storage._
|
_Collections are synced with cloud / local session storage_
|
||||||
|
|
||||||
📜 **Pre-Request Scripts:** Snippets of code associated with a request that is executed before the request is sent.
|
|
||||||
|
|
||||||
- Set environment variables
|
|
||||||
- Include timestamp in the request headers
|
|
||||||
- Send a random alphanumeric string in the URL parameters
|
|
||||||
- Any JavaScript functions
|
|
||||||
|
|
||||||
👨👩👧👦 **Teams:** Helps you collaborate across your teams to design, develop, and test APIs faster.
|
|
||||||
|
|
||||||
- Create unlimited teams
|
|
||||||
- Create unlimited shared collections
|
|
||||||
- Create unlimited team members
|
|
||||||
- Role-based access control
|
|
||||||
- Cloud sync
|
|
||||||
- Multiple devices
|
|
||||||
|
|
||||||
👥 **Workspaces:** Organize your personal and team collections environments into workspaces. Easily switch between workspaces to manage multiple projects.
|
|
||||||
|
|
||||||
- Create unlimited workspaces
|
|
||||||
- Switch between personal and team workspaces
|
|
||||||
|
|
||||||
⌨️ **Keyboard Shortcuts:** Optimized for efficiency.
|
|
||||||
|
|
||||||
> **[Read our documentation on Keyboard Shortcuts](https://docs.hoppscotch.io/documentation/features/shortcuts)**
|
|
||||||
|
|
||||||
🌐 **Proxy:** Enable Proxy Mode from Settings to access blocked APIs.
|
🌐 **Proxy:** Enable Proxy Mode from Settings to access blocked APIs.
|
||||||
|
|
||||||
@@ -174,31 +161,60 @@ _Collections are synced with your cloud/local session storage._
|
|||||||
- Access APIs served in non-HTTPS (`http://`) endpoints
|
- Access APIs served in non-HTTPS (`http://`) endpoints
|
||||||
- Use your Proxy URL
|
- Use your Proxy URL
|
||||||
|
|
||||||
_Official proxy server is hosted by Hoppscotch - **[GitHub](https://github.com/hoppscotch/proxyscotch)** - **[Privacy Policy](https://docs.hoppscotch.io/support/privacy)**._
|
_Official proxy server is hosted by Hoppscotch - **[GitHub](https://github.com/hoppscotch/proxyscotch)** - **[Privacy Policy](https://docs.hoppscotch.io/support/privacy)**_
|
||||||
|
|
||||||
|
📜 **Pre-Request Scripts β:** Snippets of code associated with a request that is executed before the request is sent.
|
||||||
|
|
||||||
|
- Set environment variables
|
||||||
|
- Include timestamp in the request headers
|
||||||
|
- Send a random alphanumeric string in the URL parameters
|
||||||
|
- Any JavaScript functions
|
||||||
|
|
||||||
|
📄 **API Documentation:** Create and share dynamic API documentation easily, quickly.
|
||||||
|
|
||||||
|
1. Add your requests to Collections and Folders
|
||||||
|
2. Export Collections and easily share your APIs with the rest of your team
|
||||||
|
3. Import Collections and Generate Documentation on-the-go
|
||||||
|
|
||||||
|
⌨️ **Keyboard Shortcuts:** Optimized for efficiency.
|
||||||
|
|
||||||
|
> **[Read our documentation on Keyboard Shortcuts](https://docs.hoppscotch.io/documentation/features/shortcuts)**
|
||||||
|
|
||||||
🌎 **i18n:** Experience the app in your language.
|
🌎 **i18n:** Experience the app in your language.
|
||||||
|
|
||||||
Help us to translate Hoppscotch. Please read [`TRANSLATIONS`](TRANSLATIONS.md) for details on our [`CODE OF CONDUCT`](CODE_OF_CONDUCT.md) and the process for submitting pull requests to us.
|
Help us to translate Hoppscotch. Please read [`TRANSLATIONS`](TRANSLATIONS.md) for details on our [`CODE OF CONDUCT`](CODE_OF_CONDUCT.md), and the process for submitting pull requests to us.
|
||||||
|
|
||||||
☁️ **Auth + Sync:** Sign in and sync your data in real-time across all your devices.
|
📦 **Add-ons:** Official add-ons for hoppscotch.
|
||||||
|
|
||||||
**Sign in with:**
|
- **[Proxy](https://github.com/hoppscotch/proxyscotch)** - A simple proxy server created for Hoppscotch
|
||||||
|
- **[CLI β](https://github.com/hoppscotch/hopp-cli)** - A CLI solution for Hoppscotch
|
||||||
|
- **[Browser Extensions](https://github.com/hoppscotch/hoppscotch-extension)** - Browser extensions that simplifies access to Hoppscotch
|
||||||
|
|
||||||
|
[ **Firefox**](https://addons.mozilla.org/en-US/firefox/addon/hoppscotch) | [ **Chrome**](https://chrome.google.com/webstore/detail/hoppscotch-extension-for-c/amknoiejhlmhancpahfcfcfhllgkpbld)
|
||||||
|
|
||||||
|
> **Extensions fixes `CORS` issues.**
|
||||||
|
|
||||||
|
- **[Hopp-Doc-Gen](https://github.com/hoppscotch/hopp-doc-gen)** - An API doc generator CLI for Hoppscotch
|
||||||
|
|
||||||
|
_Add-ons are developed and maintained under **[Hoppscotch Organization](https://github.com/hoppscotch)**._
|
||||||
|
|
||||||
|
☁️ **Auth + Sync:** Sign in and sync your data in real-time.
|
||||||
|
|
||||||
|
**Sign in with**
|
||||||
|
|
||||||
- GitHub
|
- GitHub
|
||||||
- Google
|
- Google
|
||||||
- Microsoft
|
- Microsoft
|
||||||
- Email
|
- Email
|
||||||
- SSO (Single Sign-On)[^EE]
|
|
||||||
|
|
||||||
**🔄 Synchronize your data:** Handoff to continue tasks on your other devices.
|
**Synchronize your data**
|
||||||
|
|
||||||
- Workspaces
|
|
||||||
- History
|
- History
|
||||||
- Collections
|
- Collections
|
||||||
- Environments
|
- Environments
|
||||||
- Settings
|
- Settings
|
||||||
|
|
||||||
✅ **Post-Request Tests:** Write tests associated with a request that is executed after the request's response.
|
✅ **Post-Request Tests β:** Write tests associated with a request that is executed after the request's response.
|
||||||
|
|
||||||
- Check the status code as an integer
|
- Check the status code as an integer
|
||||||
- Filter response headers
|
- Filter response headers
|
||||||
@@ -206,7 +222,7 @@ Help us to translate Hoppscotch. Please read [`TRANSLATIONS`](TRANSLATIONS.md) f
|
|||||||
- Set environment variables
|
- Set environment variables
|
||||||
- Write JavaScript code
|
- Write JavaScript code
|
||||||
|
|
||||||
🌱 **Environments:** Environment variables allow you to store and reuse values in your requests and scripts.
|
🌱 **Environments** : Environment variables allow you to store and reuse values in your requests and scripts.
|
||||||
|
|
||||||
- Unlimited environments and variables
|
- Unlimited environments and variables
|
||||||
- Initialize through the pre-request script
|
- Initialize through the pre-request script
|
||||||
@@ -225,31 +241,22 @@ Help us to translate Hoppscotch. Please read [`TRANSLATIONS`](TRANSLATIONS.md) f
|
|||||||
|
|
||||||
</details>
|
</details>
|
||||||
|
|
||||||
|
👨👩👧👦 **Teams β:** Helps you collaborate across your team to design, develop, and test APIs faster.
|
||||||
|
|
||||||
|
- Unlimited teams
|
||||||
|
- Unlimited shared collections
|
||||||
|
- Unlimited team members
|
||||||
|
- Role-based access control
|
||||||
|
- Cloud sync
|
||||||
|
- Multiple devices
|
||||||
|
|
||||||
🚚 **Bulk Edit:** Edit key-value pairs in bulk.
|
🚚 **Bulk Edit:** Edit key-value pairs in bulk.
|
||||||
|
|
||||||
- Entries are separated by newline
|
- Entries are separated by newline
|
||||||
- Keys and values are separated by `:`
|
- Keys and values are separated by `:`
|
||||||
- Prepend `#` to any row you want to add but keep disabled
|
- Prepend `#` to any row you want to add but keep disabled
|
||||||
|
|
||||||
🎛️ **Admin dashboard:** Manage your team and invite members.
|
**For more features, please read our [documentation](https://docs.hoppscotch.io).**
|
||||||
|
|
||||||
- Insights
|
|
||||||
- Manage users
|
|
||||||
- Manage teams
|
|
||||||
|
|
||||||
📦 **Add-ons:** Official add-ons for hoppscotch.
|
|
||||||
|
|
||||||
- **[Hoppscotch CLI](https://github.com/hoppscotch/hopp-cli)** - Command-line interface for Hoppscotch.
|
|
||||||
- **[Proxy](https://github.com/hoppscotch/proxyscotch)** - A simple proxy server created for Hoppscotch.
|
|
||||||
- **[Browser Extensions](https://github.com/hoppscotch/hoppscotch-extension)** - Browser extensions that enhance your Hoppscotch experience.
|
|
||||||
|
|
||||||
[ **Firefox**](https://addons.mozilla.org/en-US/firefox/addon/hoppscotch) | [ **Chrome**](https://chrome.google.com/webstore/detail/hoppscotch-extension-for-c/amknoiejhlmhancpahfcfcfhllgkpbld)
|
|
||||||
|
|
||||||
> **Extensions fix `CORS` issues.**
|
|
||||||
|
|
||||||
_Add-ons are developed and maintained under **[Hoppscotch Organization](https://github.com/hoppscotch)**._
|
|
||||||
|
|
||||||
**For a complete list of features, please read our [documentation](https://docs.hoppscotch.io).**
|
|
||||||
|
|
||||||
## **Demo**
|
## **Demo**
|
||||||
|
|
||||||
@@ -261,9 +268,18 @@ _Add-ons are developed and maintained under **[Hoppscotch Organization](https://
|
|||||||
2. Click "Send" to simulate the request
|
2. Click "Send" to simulate the request
|
||||||
3. View the response
|
3. View the response
|
||||||
|
|
||||||
|
## **Built with**
|
||||||
|
|
||||||
|
- [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML)
|
||||||
|
- [CSS](https://developer.mozilla.org/en-US/docs/Web/CSS), [SCSS](https://sass-lang.com), [Windi CSS](https://windicss.org)
|
||||||
|
- [JavaScript](https://developer.mozilla.org/en-US/docs/Web/JavaScript)
|
||||||
|
- [TypeScript](https://www.typescriptlang.org)
|
||||||
|
- [Vue](https://vuejs.org)
|
||||||
|
- [Vite](https://vitejs.dev)
|
||||||
|
|
||||||
## **Developing**
|
## **Developing**
|
||||||
|
|
||||||
Follow our [self-hosting documentation](https://docs.hoppscotch.io/documentation/self-host/getting-started) to get started with the development environment.
|
Follow our [self-hosting guide](https://docs.hoppscotch.io/documentation/self-host/getting-started) to get started with the development environment.
|
||||||
|
|
||||||
## **Contributing**
|
## **Contributing**
|
||||||
|
|
||||||
@@ -281,7 +297,7 @@ See the [`CHANGELOG`](CHANGELOG.md) file for details.
|
|||||||
|
|
||||||
## **Authors**
|
## **Authors**
|
||||||
|
|
||||||
This project owes its existence to the collective efforts of all those who contribute — [contribute now](CONTRIBUTING.md).
|
This project exists thanks to all the people who contribute — [contribute](CONTRIBUTING.md).
|
||||||
|
|
||||||
<div align="center">
|
<div align="center">
|
||||||
<a href="https://github.com/hoppscotch/hoppscotch/graphs/contributors">
|
<a href="https://github.com/hoppscotch/hoppscotch/graphs/contributors">
|
||||||
@@ -293,6 +309,4 @@ This project owes its existence to the collective efforts of all those who contr
|
|||||||
|
|
||||||
## **License**
|
## **License**
|
||||||
|
|
||||||
This project is licensed under the [MIT License](https://opensource.org/licenses/MIT) — see the [`LICENSE`](LICENSE) file for details.
|
This project is licensed under the [MIT License](https://opensource.org/licenses/MIT) - see the [`LICENSE`](LICENSE) file for details.
|
||||||
|
|
||||||
[^EE]: Enterprise edition feature. [Learn more](https://docs.hoppscotch.io/documentation/self-host/getting-started).
|
|
||||||
|
|||||||
@@ -2,9 +2,8 @@
|
|||||||
|
|
||||||
This document outlines security procedures and general policies for the Hoppscotch project.
|
This document outlines security procedures and general policies for the Hoppscotch project.
|
||||||
|
|
||||||
- [Security Policy](#security-policy)
|
1. [Reporting a security vulnerability](#reporting-a-security-vulnerability)
|
||||||
- [Reporting a security vulnerability](#reporting-a-security-vulnerability)
|
3. [Incident response process](#incident-response-process)
|
||||||
- [Incident response process](#incident-response-process)
|
|
||||||
|
|
||||||
## Reporting a security vulnerability
|
## Reporting a security vulnerability
|
||||||
|
|
||||||
|
|||||||
@@ -9,24 +9,26 @@ Before you start working on a new language, please look through the [open pull r
|
|||||||
if there is no existing translation, you can create a new one by following these steps:
|
if there is no existing translation, you can create a new one by following these steps:
|
||||||
|
|
||||||
1. **[Fork the repository](https://github.com/hoppscotch/hoppscotch/fork).**
|
1. **[Fork the repository](https://github.com/hoppscotch/hoppscotch/fork).**
|
||||||
2. **Checkout the `main` branch for latest translations.**
|
2. **Checkout the `i18n` branch for latest translations.**
|
||||||
3. **Create a new branch for your translation with base branch `main`.**
|
3. **Create a new branch for your translation with base branch `i18n`.**
|
||||||
4. **Create target language file in the [`/packages/hoppscotch-common/locales`](https://github.com/hoppscotch/hoppscotch/tree/main/packages/hoppscotch-common/locales) directory.**
|
4. **Create target language file in the [`/packages/hoppscotch-common/locales`](https://github.com/hoppscotch/hoppscotch/tree/main/packages/hoppscotch-common/locales) directory.**
|
||||||
5. **Copy the contents of the source file [`/packages/hoppscotch-common/locales/en.json`](https://github.com/hoppscotch/hoppscotch/blob/main/packages/hoppscotch-common/locales/en.json) to the target language file.**
|
5. **Copy the contents of the source file [`/packages/hoppscotch-common/locales/en.json`](https://github.com/hoppscotch/hoppscotch/blob/main/packages/hoppscotch-common/locales/en.json) to the target language file.**
|
||||||
6. **Translate the strings in the target language file.**
|
6. **Translate the strings in the target language file.**
|
||||||
7. **Add your language entry to [`/packages/hoppscotch-common/languages.json`](https://github.com/hoppscotch/hoppscotch/blob/main/packages/hoppscotch-common/languages.json).**
|
7. **Add your language entry to [`/packages/hoppscotch-common/languages.json`](https://github.com/hoppscotch/hoppscotch/blob/main/packages/hoppscotch-common/languages.json).**
|
||||||
8. **Save and commit changes.**
|
8. **Save & commit changes.**
|
||||||
9. **Send a pull request.**
|
9. **Send a pull request.**
|
||||||
|
|
||||||
_You may send a pull request before all steps above are complete: e.g., you may want to ask for help with translations, or getting tests to pass. However, your pull request will not be merged until all steps above are complete._
|
_You may send a pull request before all steps above are complete: e.g., you may want to ask for help with translations, or getting tests to pass. However, your pull request will not be merged until all steps above are complete._
|
||||||
|
|
||||||
|
`i18n` branch will be merged into `main` branch once every week.
|
||||||
|
|
||||||
Completing an initial translation of the whole site is a fairly large task. One way to break that task up is to work with other translators through pull requests on your fork. You can also [add collaborators to your fork](https://help.github.com/en/github/setting-up-and-managing-your-github-user-account/inviting-collaborators-to-a-personal-repository) if you'd like to invite other translators to commit directly to your fork and share responsibility for merging pull requests.
|
Completing an initial translation of the whole site is a fairly large task. One way to break that task up is to work with other translators through pull requests on your fork. You can also [add collaborators to your fork](https://help.github.com/en/github/setting-up-and-managing-your-github-user-account/inviting-collaborators-to-a-personal-repository) if you'd like to invite other translators to commit directly to your fork and share responsibility for merging pull requests.
|
||||||
|
|
||||||
## Updating a translation
|
## Updating a translation
|
||||||
|
|
||||||
### Corrections
|
### Corrections
|
||||||
|
|
||||||
If you notice spelling or grammar errors, typos, or opportunities for better phrasing, open a pull request with your suggested fix. If you see a problem that you aren't sure of or don't have time to fix, [open an issue](https://github.com/hoppscotch/hoppscotch/issues/new/choose).
|
If you notice spelling or grammar errors, typos, or opportunities for better phrasing, open a pull request with your suggested fix. If you see a problem that you aren't sure of or don't have time to fix, open an issue.
|
||||||
|
|
||||||
### Broken links
|
### Broken links
|
||||||
|
|
||||||
|
|||||||
@@ -1,11 +0,0 @@
|
|||||||
:3000 {
|
|
||||||
try_files {path} /
|
|
||||||
root * /site/selfhost-web
|
|
||||||
file_server
|
|
||||||
}
|
|
||||||
|
|
||||||
:3100 {
|
|
||||||
try_files {path} /
|
|
||||||
root * /site/sh-admin
|
|
||||||
file_server
|
|
||||||
}
|
|
||||||
72
aio_run.mjs
72
aio_run.mjs
@@ -1,72 +0,0 @@
|
|||||||
#!/usr/local/bin/node
|
|
||||||
// @ts-check
|
|
||||||
|
|
||||||
import { execSync, spawn } from "child_process"
|
|
||||||
import fs from "fs"
|
|
||||||
import process from "process"
|
|
||||||
|
|
||||||
function runChildProcessWithPrefix(command, args, prefix) {
|
|
||||||
const childProcess = spawn(command, args);
|
|
||||||
|
|
||||||
childProcess.stdout.on('data', (data) => {
|
|
||||||
const output = data.toString().trim().split('\n');
|
|
||||||
output.forEach((line) => {
|
|
||||||
console.log(`${prefix} | ${line}`);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
childProcess.stderr.on('data', (data) => {
|
|
||||||
const error = data.toString().trim().split('\n');
|
|
||||||
error.forEach((line) => {
|
|
||||||
console.error(`${prefix} | ${line}`);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
childProcess.on('close', (code) => {
|
|
||||||
console.log(`${prefix} Child process exited with code ${code}`);
|
|
||||||
});
|
|
||||||
|
|
||||||
childProcess.on('error', (stuff) => {
|
|
||||||
console.log("error")
|
|
||||||
console.log(stuff)
|
|
||||||
})
|
|
||||||
|
|
||||||
return childProcess
|
|
||||||
}
|
|
||||||
|
|
||||||
const envFileContent = Object.entries(process.env)
|
|
||||||
.filter(([env]) => env.startsWith("VITE_"))
|
|
||||||
.map(([env, val]) => `${env}=${
|
|
||||||
(val.startsWith("\"") && val.endsWith("\""))
|
|
||||||
? val
|
|
||||||
: `"${val}"`
|
|
||||||
}`)
|
|
||||||
.join("\n")
|
|
||||||
|
|
||||||
fs.writeFileSync("build.env", envFileContent)
|
|
||||||
|
|
||||||
execSync(`npx import-meta-env -x build.env -e build.env -p "/site/**/*"`)
|
|
||||||
|
|
||||||
fs.rmSync("build.env")
|
|
||||||
|
|
||||||
const caddyProcess = runChildProcessWithPrefix("caddy", ["run", "--config", "/etc/caddy/Caddyfile", "--adapter", "caddyfile"], "App/Admin Dashboard Caddy")
|
|
||||||
const backendProcess = runChildProcessWithPrefix("pnpm", ["run", "start:prod"], "Backend Server")
|
|
||||||
|
|
||||||
caddyProcess.on("exit", (code) => {
|
|
||||||
console.log(`Exiting process because Caddy Server exited with code ${code}`)
|
|
||||||
process.exit(code)
|
|
||||||
})
|
|
||||||
|
|
||||||
backendProcess.on("exit", (code) => {
|
|
||||||
console.log(`Exiting process because Backend Server exited with code ${code}`)
|
|
||||||
process.exit(code)
|
|
||||||
})
|
|
||||||
|
|
||||||
process.on('SIGINT', () => {
|
|
||||||
console.log("SIGINT received, exiting...")
|
|
||||||
|
|
||||||
caddyProcess.kill("SIGINT")
|
|
||||||
backendProcess.kill("SIGINT")
|
|
||||||
|
|
||||||
process.exit(0)
|
|
||||||
})
|
|
||||||
@@ -8,25 +8,23 @@ services:
|
|||||||
hoppscotch-backend:
|
hoppscotch-backend:
|
||||||
container_name: hoppscotch-backend
|
container_name: hoppscotch-backend
|
||||||
build:
|
build:
|
||||||
dockerfile: prod.Dockerfile
|
dockerfile: packages/hoppscotch-backend/Dockerfile
|
||||||
context: .
|
context: .
|
||||||
target: backend
|
target: prod
|
||||||
env_file:
|
env_file:
|
||||||
- ./.env
|
- ./.env
|
||||||
restart: always
|
restart: always
|
||||||
environment:
|
environment:
|
||||||
# Edit the below line to match your PostgresDB URL if you have an outside DB (make sure to update the .env file as well)
|
# Edit the below line to match your PostgresDB URL if you have an outside DB (make sure to update the .env file as well)
|
||||||
- DATABASE_URL=postgresql://postgres:testpass@hoppscotch-db:5432/hoppscotch?connect_timeout=300
|
- DATABASE_URL=postgresql://postgres:testpass@hoppscotch-db:5432/hoppscotch?connect_timeout=300
|
||||||
- PORT=3170
|
- PORT=3000
|
||||||
volumes:
|
volumes:
|
||||||
# Uncomment the line below when modifying code. Only applicable when using the "dev" target.
|
- ./packages/hoppscotch-backend/:/usr/src/app
|
||||||
# - ./packages/hoppscotch-backend/:/usr/src/app
|
|
||||||
- /usr/src/app/node_modules/
|
- /usr/src/app/node_modules/
|
||||||
depends_on:
|
depends_on:
|
||||||
hoppscotch-db:
|
- hoppscotch-db
|
||||||
condition: service_healthy
|
|
||||||
ports:
|
ports:
|
||||||
- "3170:3170"
|
- "3170:3000"
|
||||||
|
|
||||||
# The main hoppscotch app. This will be hosted at port 3000
|
# The main hoppscotch app. This will be hosted at port 3000
|
||||||
# NOTE: To do TLS or play around with how the app is hosted, you can look into the Caddyfile for
|
# NOTE: To do TLS or play around with how the app is hosted, you can look into the Caddyfile for
|
||||||
@@ -34,9 +32,8 @@ services:
|
|||||||
hoppscotch-app:
|
hoppscotch-app:
|
||||||
container_name: hoppscotch-app
|
container_name: hoppscotch-app
|
||||||
build:
|
build:
|
||||||
dockerfile: prod.Dockerfile
|
dockerfile: packages/hoppscotch-selfhost-web/Dockerfile
|
||||||
context: .
|
context: .
|
||||||
target: app
|
|
||||||
env_file:
|
env_file:
|
||||||
- ./.env
|
- ./.env
|
||||||
depends_on:
|
depends_on:
|
||||||
@@ -50,9 +47,8 @@ services:
|
|||||||
hoppscotch-sh-admin:
|
hoppscotch-sh-admin:
|
||||||
container_name: hoppscotch-sh-admin
|
container_name: hoppscotch-sh-admin
|
||||||
build:
|
build:
|
||||||
dockerfile: prod.Dockerfile
|
dockerfile: packages/hoppscotch-sh-admin/Dockerfile
|
||||||
context: .
|
context: .
|
||||||
target: sh_admin
|
|
||||||
env_file:
|
env_file:
|
||||||
- ./.env
|
- ./.env
|
||||||
depends_on:
|
depends_on:
|
||||||
@@ -60,91 +56,16 @@ services:
|
|||||||
ports:
|
ports:
|
||||||
- "3100:8080"
|
- "3100:8080"
|
||||||
|
|
||||||
# The service that spins up all 3 services at once in one container
|
|
||||||
hoppscotch-aio:
|
|
||||||
container_name: hoppscotch-aio
|
|
||||||
build:
|
|
||||||
dockerfile: prod.Dockerfile
|
|
||||||
context: .
|
|
||||||
target: aio
|
|
||||||
env_file:
|
|
||||||
- ./.env
|
|
||||||
depends_on:
|
|
||||||
hoppscotch-db:
|
|
||||||
condition: service_healthy
|
|
||||||
ports:
|
|
||||||
- "3000:3000"
|
|
||||||
- "3100:3100"
|
|
||||||
- "3170:3170"
|
|
||||||
|
|
||||||
# The preset DB service, you can delete/comment the below lines if
|
# The preset DB service, you can delete/comment the below lines if
|
||||||
# you are using an external postgres instance
|
# you are using an external postgres instance
|
||||||
# This will be exposed at port 5432
|
# This will be exposed at port 5432
|
||||||
hoppscotch-db:
|
hoppscotch-db:
|
||||||
image: postgres:15
|
image: postgres
|
||||||
ports:
|
ports:
|
||||||
- "5432:5432"
|
- "5432:5432"
|
||||||
user: postgres
|
|
||||||
environment:
|
environment:
|
||||||
# The default user defined by the docker image
|
|
||||||
POSTGRES_USER: postgres
|
|
||||||
# NOTE: Please UPDATE THIS PASSWORD!
|
# NOTE: Please UPDATE THIS PASSWORD!
|
||||||
POSTGRES_PASSWORD: testpass
|
POSTGRES_PASSWORD: testpass
|
||||||
POSTGRES_DB: hoppscotch
|
POSTGRES_DB: hoppscotch
|
||||||
healthcheck:
|
|
||||||
test:
|
|
||||||
[
|
|
||||||
"CMD-SHELL",
|
|
||||||
"sh -c 'pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}'"
|
|
||||||
]
|
|
||||||
interval: 5s
|
|
||||||
timeout: 5s
|
|
||||||
retries: 10
|
|
||||||
|
|
||||||
# All the services listed below are deprececated
|
|
||||||
hoppscotch-old-backend:
|
|
||||||
container_name: hoppscotch-old-backend
|
|
||||||
build:
|
|
||||||
dockerfile: packages/hoppscotch-backend/Dockerfile
|
|
||||||
context: .
|
|
||||||
target: prod
|
|
||||||
env_file:
|
|
||||||
- ./.env
|
|
||||||
restart: always
|
|
||||||
environment:
|
|
||||||
# Edit the below line to match your PostgresDB URL if you have an outside DB (make sure to update the .env file as well)
|
|
||||||
- DATABASE_URL=postgresql://postgres:testpass@hoppscotch-db:5432/hoppscotch?connect_timeout=300
|
|
||||||
- PORT=3000
|
|
||||||
volumes:
|
|
||||||
# Uncomment the line below when modifying code. Only applicable when using the "dev" target.
|
|
||||||
# - ./packages/hoppscotch-backend/:/usr/src/app
|
|
||||||
- /usr/src/app/node_modules/
|
|
||||||
depends_on:
|
|
||||||
hoppscotch-db:
|
|
||||||
condition: service_healthy
|
|
||||||
ports:
|
|
||||||
- "3170:3000"
|
|
||||||
|
|
||||||
hoppscotch-old-app:
|
|
||||||
container_name: hoppscotch-old-app
|
|
||||||
build:
|
|
||||||
dockerfile: packages/hoppscotch-selfhost-web/Dockerfile
|
|
||||||
context: .
|
|
||||||
env_file:
|
|
||||||
- ./.env
|
|
||||||
depends_on:
|
|
||||||
- hoppscotch-old-backend
|
|
||||||
ports:
|
|
||||||
- "3000:8080"
|
|
||||||
|
|
||||||
hoppscotch-old-sh-admin:
|
|
||||||
container_name: hoppscotch-old-sh-admin
|
|
||||||
build:
|
|
||||||
dockerfile: packages/hoppscotch-sh-admin/Dockerfile
|
|
||||||
context: .
|
|
||||||
env_file:
|
|
||||||
- ./.env
|
|
||||||
depends_on:
|
|
||||||
- hoppscotch-old-backend
|
|
||||||
ports:
|
|
||||||
- "3100:8080"
|
|
||||||
|
|||||||
@@ -1,14 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
curlCheck() {
|
|
||||||
if ! curl -s --head "$1" | head -n 1 | grep -q "HTTP/1.[01] [23].."; then
|
|
||||||
echo "URL request failed!"
|
|
||||||
exit 1
|
|
||||||
else
|
|
||||||
echo "URL request succeeded!"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
curlCheck "http://localhost:3000"
|
|
||||||
curlCheck "http://localhost:3100"
|
|
||||||
curlCheck "http://localhost:3170/ping"
|
|
||||||
@@ -32,14 +32,5 @@
|
|||||||
"@types/node": "^17.0.24",
|
"@types/node": "^17.0.24",
|
||||||
"cross-env": "^7.0.3",
|
"cross-env": "^7.0.3",
|
||||||
"http-server": "^14.1.1"
|
"http-server": "^14.1.1"
|
||||||
},
|
|
||||||
"pnpm": {
|
|
||||||
"packageExtensions": {
|
|
||||||
"httpsnippet@^3.0.1": {
|
|
||||||
"peerDependencies": {
|
|
||||||
"ajv": "6.12.3"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,12 +17,12 @@
|
|||||||
"types": "dist/index.d.ts",
|
"types": "dist/index.d.ts",
|
||||||
"sideEffects": false,
|
"sideEffects": false,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@codemirror/language": "^6.9.0",
|
"@codemirror/language": "^6.2.0",
|
||||||
"@lezer/highlight": "^1.1.6",
|
"@lezer/highlight": "^1.0.0",
|
||||||
"@lezer/lr": "^1.3.10"
|
"@lezer/lr": "^1.2.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@lezer/generator": "^1.5.0",
|
"@lezer/generator": "^1.1.0",
|
||||||
"mocha": "^9.2.2",
|
"mocha": "^9.2.2",
|
||||||
"rollup": "^2.70.2",
|
"rollup": "^2.70.2",
|
||||||
"rollup-plugin-dts": "^4.2.1",
|
"rollup-plugin-dts": "^4.2.1",
|
||||||
|
|||||||
24
packages/dioc/.gitignore
vendored
24
packages/dioc/.gitignore
vendored
@@ -1,24 +0,0 @@
|
|||||||
# Logs
|
|
||||||
logs
|
|
||||||
*.log
|
|
||||||
npm-debug.log*
|
|
||||||
yarn-debug.log*
|
|
||||||
yarn-error.log*
|
|
||||||
pnpm-debug.log*
|
|
||||||
lerna-debug.log*
|
|
||||||
|
|
||||||
node_modules
|
|
||||||
dist
|
|
||||||
dist-ssr
|
|
||||||
*.local
|
|
||||||
|
|
||||||
# Editor directories and files
|
|
||||||
.vscode/*
|
|
||||||
!.vscode/extensions.json
|
|
||||||
.idea
|
|
||||||
.DS_Store
|
|
||||||
*.suo
|
|
||||||
*.ntvs*
|
|
||||||
*.njsproj
|
|
||||||
*.sln
|
|
||||||
*.sw?
|
|
||||||
@@ -1,141 +0,0 @@
|
|||||||
# dioc
|
|
||||||
|
|
||||||
A small and lightweight dependency injection / inversion of control system.
|
|
||||||
|
|
||||||
### About
|
|
||||||
|
|
||||||
`dioc` is a really simple **DI/IOC** system where you write services (which are singletons per container) that can depend on each other and emit events that can be listened upon.
|
|
||||||
|
|
||||||
### Demo
|
|
||||||
|
|
||||||
```ts
|
|
||||||
import { Service, Container } from "dioc"
|
|
||||||
|
|
||||||
// Here is a simple service, which you can define by extending the Service class
|
|
||||||
// and providing an ID static field (of type string)
|
|
||||||
export class PersistenceService extends Service {
|
|
||||||
// This should be unique for each container
|
|
||||||
public static ID = "PERSISTENCE_SERVICE"
|
|
||||||
|
|
||||||
public read(key: string): string | undefined {
|
|
||||||
// ...
|
|
||||||
}
|
|
||||||
|
|
||||||
public write(key: string, value: string) {
|
|
||||||
// ...
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
type TodoServiceEvent =
|
|
||||||
| { type: "TODO_CREATED"; index: number }
|
|
||||||
| { type: "TODO_DELETED"; index: number }
|
|
||||||
|
|
||||||
// Services have a built in event system
|
|
||||||
// Define the generic argument to say what are the possible emitted values
|
|
||||||
export class TodoService extends Service<TodoServiceEvent> {
|
|
||||||
public static ID = "TODO_SERVICE"
|
|
||||||
|
|
||||||
// Inject persistence service into this service
|
|
||||||
private readonly persistence = this.bind(PersistenceService)
|
|
||||||
|
|
||||||
public todos = []
|
|
||||||
|
|
||||||
// Service constructors cannot have arguments
|
|
||||||
constructor() {
|
|
||||||
super()
|
|
||||||
|
|
||||||
this.todos = JSON.parse(this.persistence.read("todos") ?? "[]")
|
|
||||||
}
|
|
||||||
|
|
||||||
public addTodo(text: string) {
|
|
||||||
// ...
|
|
||||||
|
|
||||||
// You can access services via the bound fields
|
|
||||||
this.persistence.write("todos", JSON.stringify(this.todos))
|
|
||||||
|
|
||||||
// This is how you emit an event
|
|
||||||
this.emit({
|
|
||||||
type: "TODO_CREATED",
|
|
||||||
index,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
public removeTodo(index: number) {
|
|
||||||
// ...
|
|
||||||
|
|
||||||
this.emit({
|
|
||||||
type: "TODO_DELETED",
|
|
||||||
index,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Services need a container to run in
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
// You can initialize and get services using Container#bind
|
|
||||||
// It will automatically initialize the service (and its dependencies)
|
|
||||||
const todoService = container.bind(TodoService) // Returns an instance of TodoService
|
|
||||||
```
|
|
||||||
|
|
||||||
### Demo (Unit Test)
|
|
||||||
|
|
||||||
`dioc/testing` contains `TestContainer` which lets you bind mocked services to the container.
|
|
||||||
|
|
||||||
```ts
|
|
||||||
import { TestContainer } from "dioc/testing"
|
|
||||||
import { TodoService, PersistenceService } from "./demo.ts" // The above demo code snippet
|
|
||||||
import { describe, it, expect, vi } from "vitest"
|
|
||||||
|
|
||||||
describe("TodoService", () => {
|
|
||||||
it("addTodo writes to persistence", () => {
|
|
||||||
const container = new TestContainer()
|
|
||||||
|
|
||||||
const writeFn = vi.fn()
|
|
||||||
|
|
||||||
// The first parameter is the service to mock and the second parameter
|
|
||||||
// is the mocked service fields and functions
|
|
||||||
container.bindMock(PersistenceService, {
|
|
||||||
read: () => undefined, // Not really important for this test
|
|
||||||
write: writeFn,
|
|
||||||
})
|
|
||||||
|
|
||||||
// the peristence service bind in TodoService will now use the
|
|
||||||
// above defined mocked implementation
|
|
||||||
const todoService = container.bind(TodoService)
|
|
||||||
|
|
||||||
todoService.addTodo("sup")
|
|
||||||
|
|
||||||
expect(writeFn).toHaveBeenCalledOnce()
|
|
||||||
expect(writeFn).toHaveBeenCalledWith("todos", JSON.stringify(["sup"]))
|
|
||||||
})
|
|
||||||
})
|
|
||||||
```
|
|
||||||
|
|
||||||
### Demo (Vue)
|
|
||||||
|
|
||||||
`dioc/vue` contains a Vue Plugin and a `useService` composable that allows Vue components to use the defined services.
|
|
||||||
|
|
||||||
In the app entry point:
|
|
||||||
|
|
||||||
```ts
|
|
||||||
import { createApp } from "vue"
|
|
||||||
import { diocPlugin } from "dioc/vue"
|
|
||||||
|
|
||||||
const app = createApp()
|
|
||||||
|
|
||||||
app.use(diocPlugin, {
|
|
||||||
container: new Container(), // You can pass in the container you want to provide to the components here
|
|
||||||
})
|
|
||||||
```
|
|
||||||
|
|
||||||
In your Vue components:
|
|
||||||
|
|
||||||
```vue
|
|
||||||
<script setup>
|
|
||||||
import { TodoService } from "./demo.ts" // The above demo
|
|
||||||
import { useService } from "dioc/vue"
|
|
||||||
|
|
||||||
const todoService = useService(TodoService) // Returns an instance of the TodoService class
|
|
||||||
</script>
|
|
||||||
```
|
|
||||||
2
packages/dioc/index.d.ts
vendored
2
packages/dioc/index.d.ts
vendored
@@ -1,2 +0,0 @@
|
|||||||
export { default } from "./dist/main.d.ts"
|
|
||||||
export * from "./dist/main.d.ts"
|
|
||||||
@@ -1,147 +0,0 @@
|
|||||||
import { Service } from "./service"
|
|
||||||
import { Observable, Subject } from 'rxjs'
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Stores the current container instance in the current operating context.
|
|
||||||
*
|
|
||||||
* NOTE: This should not be used outside of dioc library code
|
|
||||||
*/
|
|
||||||
export let currentContainer: Container | null = null
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The events emitted by the container
|
|
||||||
*
|
|
||||||
* `SERVICE_BIND` - emitted when a service is bound to the container directly or as a dependency to another service
|
|
||||||
* `SERVICE_INIT` - emitted when a service is initialized
|
|
||||||
*/
|
|
||||||
export type ContainerEvent =
|
|
||||||
| {
|
|
||||||
type: 'SERVICE_BIND';
|
|
||||||
|
|
||||||
/** The Service ID of the service being bounded (the dependency) */
|
|
||||||
boundeeID: string;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Service ID of the bounder that is binding the boundee (the dependent)
|
|
||||||
*
|
|
||||||
* NOTE: This will be undefined if the service is bound directly to the container
|
|
||||||
*/
|
|
||||||
bounderID: string | undefined
|
|
||||||
}
|
|
||||||
| {
|
|
||||||
type: 'SERVICE_INIT';
|
|
||||||
|
|
||||||
/** The Service ID of the service being initialized */
|
|
||||||
serviceID: string
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The dependency injection container, allows for services to be initialized and maintains the dependency trees.
|
|
||||||
*/
|
|
||||||
export class Container {
|
|
||||||
/** Used during the `bind` operation to detect circular dependencies */
|
|
||||||
private bindStack: string[] = []
|
|
||||||
|
|
||||||
/** The map of bound services to their IDs */
|
|
||||||
protected boundMap = new Map<string, Service<unknown>>()
|
|
||||||
|
|
||||||
/** The RxJS observable representing the event stream */
|
|
||||||
protected event$ = new Subject<ContainerEvent>()
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns whether a container has the given service bound
|
|
||||||
* @param service The service to check for
|
|
||||||
*/
|
|
||||||
public hasBound<
|
|
||||||
T extends typeof Service<any> & { ID: string }
|
|
||||||
>(service: T): boolean {
|
|
||||||
return this.boundMap.has(service.ID)
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the service bound to the container with the given ID or if not found, undefined.
|
|
||||||
*
|
|
||||||
* NOTE: This is an advanced method and should not be used as much as possible.
|
|
||||||
*
|
|
||||||
* @param serviceID The ID of the service to get
|
|
||||||
*/
|
|
||||||
public getBoundServiceWithID(serviceID: string): Service<unknown> | undefined {
|
|
||||||
return this.boundMap.get(serviceID)
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Binds a service to the container. This is equivalent to marking a service as a dependency.
|
|
||||||
* @param service The class reference of a service to bind
|
|
||||||
* @param bounder The class reference of the service that is binding the service (if bound directly to the container, this should be undefined)
|
|
||||||
*/
|
|
||||||
public bind<T extends typeof Service<any> & { ID: string }>(
|
|
||||||
service: T,
|
|
||||||
bounder: ((typeof Service<T>) & { ID: string }) | undefined = undefined
|
|
||||||
): InstanceType<T> {
|
|
||||||
// We need to store the current container in a variable so that we can restore it after the bind operation
|
|
||||||
const oldCurrentContainer = currentContainer;
|
|
||||||
currentContainer = this;
|
|
||||||
|
|
||||||
// If the service is already bound, return the existing instance
|
|
||||||
if (this.hasBound(service)) {
|
|
||||||
this.event$.next({
|
|
||||||
type: 'SERVICE_BIND',
|
|
||||||
boundeeID: service.ID,
|
|
||||||
bounderID: bounder?.ID // Return the bounder ID if it is defined, else assume its the container
|
|
||||||
})
|
|
||||||
|
|
||||||
return this.boundMap.get(service.ID) as InstanceType<T> // Casted as InstanceType<T> because service IDs and types are expected to match
|
|
||||||
}
|
|
||||||
|
|
||||||
// Detect circular dependency and throw error
|
|
||||||
if (this.bindStack.findIndex((serviceID) => serviceID === service.ID) !== -1) {
|
|
||||||
const circularServices = `${this.bindStack.join(' -> ')} -> ${service.ID}`
|
|
||||||
|
|
||||||
throw new Error(`Circular dependency detected.\nChain: ${circularServices}`)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Push the service ID onto the bind stack to detect circular dependencies
|
|
||||||
this.bindStack.push(service.ID)
|
|
||||||
|
|
||||||
// Initialize the service and emit events
|
|
||||||
|
|
||||||
// NOTE: We need to cast the service to any as TypeScript thinks that the service is abstract
|
|
||||||
const instance: Service<any> = new (service as any)()
|
|
||||||
|
|
||||||
this.boundMap.set(service.ID, instance)
|
|
||||||
|
|
||||||
this.bindStack.pop()
|
|
||||||
|
|
||||||
this.event$.next({
|
|
||||||
type: 'SERVICE_INIT',
|
|
||||||
serviceID: service.ID,
|
|
||||||
})
|
|
||||||
|
|
||||||
this.event$.next({
|
|
||||||
type: 'SERVICE_BIND',
|
|
||||||
boundeeID: service.ID,
|
|
||||||
bounderID: bounder?.ID
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
// Restore the current container
|
|
||||||
currentContainer = oldCurrentContainer;
|
|
||||||
|
|
||||||
// We expect the return type to match the service definition
|
|
||||||
return instance as InstanceType<T>
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns an iterator of the currently bound service IDs and their instances
|
|
||||||
*/
|
|
||||||
public getBoundServices(): IterableIterator<[string, Service<any>]> {
|
|
||||||
return this.boundMap.entries()
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the public container event stream
|
|
||||||
*/
|
|
||||||
public getEventStream(): Observable<ContainerEvent> {
|
|
||||||
return this.event$.asObservable()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,2 +0,0 @@
|
|||||||
export * from "./container"
|
|
||||||
export * from "./service"
|
|
||||||
@@ -1,65 +0,0 @@
|
|||||||
import { Observable, Subject } from 'rxjs'
|
|
||||||
import { Container, currentContainer } from './container'
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A Dioc service that can bound to a container and can bind dependency services.
|
|
||||||
*
|
|
||||||
* NOTE: Services cannot have a constructor that takes arguments.
|
|
||||||
*
|
|
||||||
* @template EventDef The type of events that can be emitted by the service. These will be accessible by event streams
|
|
||||||
*/
|
|
||||||
export abstract class Service<EventDef = {}> {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The internal event stream of the service
|
|
||||||
*/
|
|
||||||
private event$ = new Subject<EventDef>()
|
|
||||||
|
|
||||||
/** The container the service is bound to */
|
|
||||||
#container: Container
|
|
||||||
|
|
||||||
constructor() {
|
|
||||||
if (!currentContainer) {
|
|
||||||
throw new Error(
|
|
||||||
`Tried to initialize service with no container (ID: ${ (this.constructor as any).ID })`
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
this.#container = currentContainer
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Binds a dependency service into this service.
|
|
||||||
* @param service The class reference of the service to bind
|
|
||||||
*/
|
|
||||||
protected bind<T extends typeof Service<any> & { ID: string }>(service: T): InstanceType<T> {
|
|
||||||
if (!currentContainer) {
|
|
||||||
throw new Error('No currentContainer defined.')
|
|
||||||
}
|
|
||||||
|
|
||||||
return currentContainer.bind(service, this.constructor as typeof Service<any> & { ID: string })
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the container the service is bound to
|
|
||||||
*/
|
|
||||||
protected getContainer(): Container {
|
|
||||||
return this.#container
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Emits an event on the service's event stream
|
|
||||||
* @param event The event to emit
|
|
||||||
*/
|
|
||||||
protected emit(event: EventDef) {
|
|
||||||
this.event$.next(event)
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the event stream of the service
|
|
||||||
*/
|
|
||||||
public getEventStream(): Observable<EventDef> {
|
|
||||||
|
|
||||||
return this.event$.asObservable()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
import { Container, Service } from "./main";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A container that can be used for writing tests, contains additional methods
|
|
||||||
* for binding suitable for writing tests. (see `bindMock`).
|
|
||||||
*/
|
|
||||||
export class TestContainer extends Container {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Binds a mock service to the container.
|
|
||||||
*
|
|
||||||
* @param service
|
|
||||||
* @param mock
|
|
||||||
*/
|
|
||||||
public bindMock<
|
|
||||||
T extends typeof Service<any> & { ID: string },
|
|
||||||
U extends Partial<InstanceType<T>>
|
|
||||||
>(service: T, mock: U): U {
|
|
||||||
if (this.boundMap.has(service.ID)) {
|
|
||||||
throw new Error(`Service '${service.ID}' already bound to container. Did you already call bindMock on this ?`)
|
|
||||||
}
|
|
||||||
|
|
||||||
this.boundMap.set(service.ID, mock as any)
|
|
||||||
|
|
||||||
this.event$.next({
|
|
||||||
type: "SERVICE_BIND",
|
|
||||||
boundeeID: service.ID,
|
|
||||||
bounderID: undefined,
|
|
||||||
})
|
|
||||||
|
|
||||||
return mock
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,34 +0,0 @@
|
|||||||
import { Plugin, inject } from "vue"
|
|
||||||
import { Container } from "./container"
|
|
||||||
import { Service } from "./service"
|
|
||||||
|
|
||||||
const VUE_CONTAINER_KEY = Symbol()
|
|
||||||
|
|
||||||
// TODO: Some Vue version issue with plugin generics is breaking type checking
|
|
||||||
/**
|
|
||||||
* The Vue Dioc Plugin, this allows the composables to work and access the container
|
|
||||||
*
|
|
||||||
* NOTE: Make sure you add `vue` as dependency to be able to use this plugin (duh)
|
|
||||||
*/
|
|
||||||
export const diocPlugin: Plugin = {
|
|
||||||
install(app, { container }) {
|
|
||||||
app.provide(VUE_CONTAINER_KEY, container)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A composable that binds a service to a Vue Component
|
|
||||||
*
|
|
||||||
* @param service The class reference of the service to bind
|
|
||||||
*/
|
|
||||||
export function useService<
|
|
||||||
T extends typeof Service<any> & { ID: string }
|
|
||||||
>(service: T): InstanceType<T> {
|
|
||||||
const container = inject(VUE_CONTAINER_KEY) as Container | undefined | null
|
|
||||||
|
|
||||||
if (!container) {
|
|
||||||
throw new Error("Container not found, did you forget to install the dioc plugin?")
|
|
||||||
}
|
|
||||||
|
|
||||||
return container.bind(service)
|
|
||||||
}
|
|
||||||
@@ -1,54 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "dioc",
|
|
||||||
"private": true,
|
|
||||||
"version": "0.1.0",
|
|
||||||
"type": "module",
|
|
||||||
"files": [
|
|
||||||
"dist",
|
|
||||||
"index.d.ts"
|
|
||||||
],
|
|
||||||
"main": "./dist/counter.umd.cjs",
|
|
||||||
"module": "./dist/counter.js",
|
|
||||||
"types": "./index.d.ts",
|
|
||||||
"exports": {
|
|
||||||
".": {
|
|
||||||
"types": "./dist/main.d.ts",
|
|
||||||
"require": "./dist/index.cjs",
|
|
||||||
"import": "./dist/index.js"
|
|
||||||
},
|
|
||||||
"./vue": {
|
|
||||||
"types": "./dist/vue.d.ts",
|
|
||||||
"require": "./dist/vue.cjs",
|
|
||||||
"import": "./dist/vue.js"
|
|
||||||
},
|
|
||||||
"./testing": {
|
|
||||||
"types": "./dist/testing.d.ts",
|
|
||||||
"require": "./dist/testing.cjs",
|
|
||||||
"import": "./dist/testing.js"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"scripts": {
|
|
||||||
"dev": "vite",
|
|
||||||
"build": "vite build && tsc --emitDeclarationOnly",
|
|
||||||
"prepare": "pnpm run build",
|
|
||||||
"test": "vitest run",
|
|
||||||
"do-test": "pnpm run test",
|
|
||||||
"test:watch": "vitest"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"typescript": "^4.9.4",
|
|
||||||
"vite": "^4.0.4",
|
|
||||||
"vitest": "^0.29.3"
|
|
||||||
},
|
|
||||||
"dependencies": {
|
|
||||||
"rxjs": "^7.8.1"
|
|
||||||
},
|
|
||||||
"peerDependencies": {
|
|
||||||
"vue": "^3.2.25"
|
|
||||||
},
|
|
||||||
"peerDependenciesMeta": {
|
|
||||||
"vue": {
|
|
||||||
"optional": true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,262 +0,0 @@
|
|||||||
import { it, expect, describe, vi } from "vitest"
|
|
||||||
import { Service } from "../lib/service"
|
|
||||||
import { Container, currentContainer, ContainerEvent } from "../lib/container"
|
|
||||||
|
|
||||||
class TestServiceA extends Service {
|
|
||||||
public static ID = "TestServiceA"
|
|
||||||
}
|
|
||||||
|
|
||||||
class TestServiceB extends Service {
|
|
||||||
public static ID = "TestServiceB"
|
|
||||||
|
|
||||||
// Marked public to allow for testing
|
|
||||||
public readonly serviceA = this.bind(TestServiceA)
|
|
||||||
}
|
|
||||||
|
|
||||||
describe("Container", () => {
|
|
||||||
describe("getBoundServiceWithID", () => {
|
|
||||||
it("returns the service instance if it is bound to the container", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const service = container.bind(TestServiceA)
|
|
||||||
|
|
||||||
expect(container.getBoundServiceWithID(TestServiceA.ID)).toBe(service)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("returns undefined if the service is not bound to the container", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
expect(container.getBoundServiceWithID(TestServiceA.ID)).toBeUndefined()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe("bind", () => {
|
|
||||||
it("correctly binds the service to it", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const service = container.bind(TestServiceA)
|
|
||||||
|
|
||||||
// @ts-expect-error getContainer is defined as a protected property, but we are leveraging it here to check
|
|
||||||
expect(service.getContainer()).toBe(container)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("after bind, the current container is set back to its previous value", () => {
|
|
||||||
const originalValue = currentContainer
|
|
||||||
|
|
||||||
const container = new Container()
|
|
||||||
container.bind(TestServiceA)
|
|
||||||
|
|
||||||
expect(currentContainer).toBe(originalValue)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("dependent services are registered in the same container", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceB = container.bind(TestServiceB)
|
|
||||||
|
|
||||||
// @ts-expect-error getContainer is defined as a protected property, but we are leveraging it here to check
|
|
||||||
expect(serviceB.serviceA.getContainer()).toBe(container)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("binding an already initialized service returns the initialized instance (services are singletons)", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceA = container.bind(TestServiceA)
|
|
||||||
const serviceA2 = container.bind(TestServiceA)
|
|
||||||
|
|
||||||
expect(serviceA).toBe(serviceA2)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("binding a service which is a dependency of another service returns the same instance created from the dependency resolution (services are singletons)", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceB = container.bind(TestServiceB)
|
|
||||||
const serviceA = container.bind(TestServiceA)
|
|
||||||
|
|
||||||
expect(serviceB.serviceA).toBe(serviceA)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("binding an initialized service as a dependency returns the same instance", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceA = container.bind(TestServiceA)
|
|
||||||
const serviceB = container.bind(TestServiceB)
|
|
||||||
|
|
||||||
expect(serviceB.serviceA).toBe(serviceA)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("container emits an init event when an uninitialized service is initialized via bind and event only called once", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceFunc = vi.fn<
|
|
||||||
[ContainerEvent & { type: "SERVICE_INIT" }],
|
|
||||||
void
|
|
||||||
>()
|
|
||||||
|
|
||||||
container.getEventStream().subscribe((ev) => {
|
|
||||||
if (ev.type === "SERVICE_INIT") {
|
|
||||||
serviceFunc(ev)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
const instance = container.bind(TestServiceA)
|
|
||||||
|
|
||||||
expect(serviceFunc).toHaveBeenCalledOnce()
|
|
||||||
expect(serviceFunc).toHaveBeenCalledWith(<ContainerEvent>{
|
|
||||||
type: "SERVICE_INIT",
|
|
||||||
serviceID: TestServiceA.ID,
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it("the bind event emitted has an undefined bounderID when the service is bound directly to the container", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceFunc = vi.fn<
|
|
||||||
[ContainerEvent & { type: "SERVICE_BIND" }],
|
|
||||||
void
|
|
||||||
>()
|
|
||||||
|
|
||||||
container.getEventStream().subscribe((ev) => {
|
|
||||||
if (ev.type === "SERVICE_BIND") {
|
|
||||||
serviceFunc(ev)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
container.bind(TestServiceA)
|
|
||||||
|
|
||||||
expect(serviceFunc).toHaveBeenCalledOnce()
|
|
||||||
expect(serviceFunc).toHaveBeenCalledWith(<ContainerEvent>{
|
|
||||||
type: "SERVICE_BIND",
|
|
||||||
boundeeID: TestServiceA.ID,
|
|
||||||
bounderID: undefined,
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it("the bind event emitted has the correct bounderID when the service is bound to another service", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceFunc = vi.fn<
|
|
||||||
[ContainerEvent & { type: "SERVICE_BIND" }],
|
|
||||||
void
|
|
||||||
>()
|
|
||||||
|
|
||||||
container.getEventStream().subscribe((ev) => {
|
|
||||||
// We only care about the bind event of TestServiceA
|
|
||||||
if (ev.type === "SERVICE_BIND" && ev.boundeeID === TestServiceA.ID) {
|
|
||||||
serviceFunc(ev)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
container.bind(TestServiceB)
|
|
||||||
|
|
||||||
expect(serviceFunc).toHaveBeenCalledOnce()
|
|
||||||
expect(serviceFunc).toHaveBeenCalledWith(<ContainerEvent>{
|
|
||||||
type: "SERVICE_BIND",
|
|
||||||
boundeeID: TestServiceA.ID,
|
|
||||||
bounderID: TestServiceB.ID,
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe("hasBound", () => {
|
|
||||||
it("returns true if the given service is bound to the container", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
container.bind(TestServiceA)
|
|
||||||
|
|
||||||
expect(container.hasBound(TestServiceA)).toEqual(true)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("returns false if the given service is not bound to the container", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
expect(container.hasBound(TestServiceA)).toEqual(false)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("returns true when the service is bound because it is a dependency of another service", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
container.bind(TestServiceB)
|
|
||||||
|
|
||||||
expect(container.hasBound(TestServiceA)).toEqual(true)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe("getEventStream", () => {
|
|
||||||
it("returns an observable which emits events correctly when services are initialized", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceFunc = vi.fn<
|
|
||||||
[ContainerEvent & { type: "SERVICE_INIT" }],
|
|
||||||
void
|
|
||||||
>()
|
|
||||||
|
|
||||||
container.getEventStream().subscribe((ev) => {
|
|
||||||
if (ev.type === "SERVICE_INIT") {
|
|
||||||
serviceFunc(ev)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
container.bind(TestServiceB)
|
|
||||||
|
|
||||||
expect(serviceFunc).toHaveBeenCalledTimes(2)
|
|
||||||
expect(serviceFunc).toHaveBeenNthCalledWith(1, <ContainerEvent>{
|
|
||||||
type: "SERVICE_INIT",
|
|
||||||
serviceID: TestServiceA.ID,
|
|
||||||
})
|
|
||||||
expect(serviceFunc).toHaveBeenNthCalledWith(2, <ContainerEvent>{
|
|
||||||
type: "SERVICE_INIT",
|
|
||||||
serviceID: TestServiceB.ID,
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it("returns an observable which emits events correctly when services are bound", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceFunc = vi.fn<
|
|
||||||
[ContainerEvent & { type: "SERVICE_BIND" }],
|
|
||||||
void
|
|
||||||
>()
|
|
||||||
|
|
||||||
container.getEventStream().subscribe((ev) => {
|
|
||||||
if (ev.type === "SERVICE_BIND") {
|
|
||||||
serviceFunc(ev)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
container.bind(TestServiceB)
|
|
||||||
|
|
||||||
expect(serviceFunc).toHaveBeenCalledTimes(2)
|
|
||||||
expect(serviceFunc).toHaveBeenNthCalledWith(1, <ContainerEvent>{
|
|
||||||
type: "SERVICE_BIND",
|
|
||||||
boundeeID: TestServiceA.ID,
|
|
||||||
bounderID: TestServiceB.ID,
|
|
||||||
})
|
|
||||||
expect(serviceFunc).toHaveBeenNthCalledWith(2, <ContainerEvent>{
|
|
||||||
type: "SERVICE_BIND",
|
|
||||||
boundeeID: TestServiceB.ID,
|
|
||||||
bounderID: undefined,
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe("getBoundServices", () => {
|
|
||||||
it("returns an iterator over all services bound to the container in the format [service id, service instance]", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const instanceB = container.bind(TestServiceB)
|
|
||||||
const instanceA = instanceB.serviceA
|
|
||||||
|
|
||||||
expect(Array.from(container.getBoundServices())).toEqual([
|
|
||||||
[TestServiceA.ID, instanceA],
|
|
||||||
[TestServiceB.ID, instanceB],
|
|
||||||
])
|
|
||||||
})
|
|
||||||
|
|
||||||
it("returns an empty iterator if no services are bound", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
expect(Array.from(container.getBoundServices())).toEqual([])
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
@@ -1,66 +0,0 @@
|
|||||||
import { describe, expect, it, vi } from "vitest"
|
|
||||||
import { Service, Container } from "../lib/main"
|
|
||||||
|
|
||||||
class TestServiceA extends Service {
|
|
||||||
public static ID = "TestServiceA"
|
|
||||||
}
|
|
||||||
|
|
||||||
class TestServiceB extends Service<"test"> {
|
|
||||||
public static ID = "TestServiceB"
|
|
||||||
|
|
||||||
// Marked public to allow for testing
|
|
||||||
public readonly serviceA = this.bind(TestServiceA)
|
|
||||||
|
|
||||||
public emitTestEvent() {
|
|
||||||
this.emit("test")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
describe("Service", () => {
|
|
||||||
describe("constructor", () => {
|
|
||||||
it("throws an error if the service is initialized without a container", () => {
|
|
||||||
expect(() => new TestServiceA()).toThrowError(
|
|
||||||
"Tried to initialize service with no container (ID: TestServiceA)"
|
|
||||||
)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe("bind", () => {
|
|
||||||
it("correctly binds the dependency service using the container", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceA = container.bind(TestServiceA)
|
|
||||||
|
|
||||||
const serviceB = container.bind(TestServiceB)
|
|
||||||
expect(serviceB.serviceA).toBe(serviceA)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe("getContainer", () => {
|
|
||||||
it("returns the container the service is bound to", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceA = container.bind(TestServiceA)
|
|
||||||
|
|
||||||
// @ts-expect-error getContainer is a protected member, we are just using it to help with testing
|
|
||||||
expect(serviceA.getContainer()).toBe(container)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe("getEventStream", () => {
|
|
||||||
it("returns the valid event stream of the service", () => {
|
|
||||||
const container = new Container()
|
|
||||||
|
|
||||||
const serviceB = container.bind(TestServiceB)
|
|
||||||
|
|
||||||
const serviceFunc = vi.fn()
|
|
||||||
|
|
||||||
serviceB.getEventStream().subscribe(serviceFunc)
|
|
||||||
|
|
||||||
serviceB.emitTestEvent()
|
|
||||||
|
|
||||||
expect(serviceFunc).toHaveBeenCalledOnce()
|
|
||||||
expect(serviceFunc).toHaveBeenCalledWith("test")
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
@@ -1,92 +0,0 @@
|
|||||||
import { describe, expect, it, vi } from "vitest"
|
|
||||||
import { TestContainer } from "../lib/testing"
|
|
||||||
import { Service } from "../lib/service"
|
|
||||||
import { ContainerEvent } from "../lib/container"
|
|
||||||
|
|
||||||
class TestServiceA extends Service {
|
|
||||||
public static ID = "TestServiceA"
|
|
||||||
|
|
||||||
public test() {
|
|
||||||
return "real"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class TestServiceB extends Service {
|
|
||||||
public static ID = "TestServiceB"
|
|
||||||
|
|
||||||
// declared public to help with testing
|
|
||||||
public readonly serviceA = this.bind(TestServiceA)
|
|
||||||
|
|
||||||
public test() {
|
|
||||||
return this.serviceA.test()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
describe("TestContainer", () => {
|
|
||||||
describe("bindMock", () => {
|
|
||||||
it("returns the fake service defined", () => {
|
|
||||||
const container = new TestContainer()
|
|
||||||
|
|
||||||
const fakeService = {
|
|
||||||
test: () => "fake",
|
|
||||||
}
|
|
||||||
|
|
||||||
const result = container.bindMock(TestServiceA, fakeService)
|
|
||||||
|
|
||||||
expect(result).toBe(fakeService)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("new services bound to the container get the mock service", () => {
|
|
||||||
const container = new TestContainer()
|
|
||||||
|
|
||||||
const fakeServiceA = {
|
|
||||||
test: () => "fake",
|
|
||||||
}
|
|
||||||
|
|
||||||
container.bindMock(TestServiceA, fakeServiceA)
|
|
||||||
|
|
||||||
const serviceB = container.bind(TestServiceB)
|
|
||||||
|
|
||||||
expect(serviceB.serviceA).toBe(fakeServiceA)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("container emits SERVICE_BIND event", () => {
|
|
||||||
const container = new TestContainer()
|
|
||||||
|
|
||||||
const fakeServiceA = {
|
|
||||||
test: () => "fake",
|
|
||||||
}
|
|
||||||
|
|
||||||
const serviceFunc = vi.fn<[ContainerEvent, void]>()
|
|
||||||
|
|
||||||
container.getEventStream().subscribe((ev) => {
|
|
||||||
serviceFunc(ev)
|
|
||||||
})
|
|
||||||
|
|
||||||
container.bindMock(TestServiceA, fakeServiceA)
|
|
||||||
|
|
||||||
expect(serviceFunc).toHaveBeenCalledOnce()
|
|
||||||
expect(serviceFunc).toHaveBeenCalledWith(<ContainerEvent>{
|
|
||||||
type: "SERVICE_BIND",
|
|
||||||
boundeeID: TestServiceA.ID,
|
|
||||||
bounderID: undefined,
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it("throws if service already bound", () => {
|
|
||||||
const container = new TestContainer()
|
|
||||||
|
|
||||||
const fakeServiceA = {
|
|
||||||
test: () => "fake",
|
|
||||||
}
|
|
||||||
|
|
||||||
container.bindMock(TestServiceA, fakeServiceA)
|
|
||||||
|
|
||||||
expect(() => {
|
|
||||||
container.bindMock(TestServiceA, fakeServiceA)
|
|
||||||
}).toThrowError(
|
|
||||||
"Service 'TestServiceA' already bound to container. Did you already call bindMock on this ?"
|
|
||||||
)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
2
packages/dioc/testing.d.ts
vendored
2
packages/dioc/testing.d.ts
vendored
@@ -1,2 +0,0 @@
|
|||||||
export { default } from "./dist/testing.d.ts"
|
|
||||||
export * from "./dist/testing.d.ts"
|
|
||||||
@@ -1,21 +0,0 @@
|
|||||||
{
|
|
||||||
"compilerOptions": {
|
|
||||||
"target": "ESNext",
|
|
||||||
"useDefineForClassFields": true,
|
|
||||||
"module": "ESNext",
|
|
||||||
"lib": ["ESNext", "DOM"],
|
|
||||||
"moduleResolution": "Node",
|
|
||||||
"strict": true,
|
|
||||||
"declaration": true,
|
|
||||||
"sourceMap": true,
|
|
||||||
"outDir": "dist",
|
|
||||||
"resolveJsonModule": true,
|
|
||||||
"isolatedModules": true,
|
|
||||||
"esModuleInterop": true,
|
|
||||||
"noUnusedLocals": true,
|
|
||||||
"noUnusedParameters": true,
|
|
||||||
"noImplicitReturns": true,
|
|
||||||
"skipLibCheck": true
|
|
||||||
},
|
|
||||||
"include": ["lib"]
|
|
||||||
}
|
|
||||||
@@ -1,16 +0,0 @@
|
|||||||
import { defineConfig } from 'vite'
|
|
||||||
|
|
||||||
export default defineConfig({
|
|
||||||
build: {
|
|
||||||
lib: {
|
|
||||||
entry: {
|
|
||||||
index: './lib/main.ts',
|
|
||||||
vue: './lib/vue.ts',
|
|
||||||
testing: './lib/testing.ts',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
rollupOptions: {
|
|
||||||
external: ['vue'],
|
|
||||||
}
|
|
||||||
},
|
|
||||||
})
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
import { defineConfig } from "vitest/config"
|
|
||||||
|
|
||||||
export default defineConfig({
|
|
||||||
test: {
|
|
||||||
|
|
||||||
}
|
|
||||||
})
|
|
||||||
2
packages/dioc/vue.d.ts
vendored
2
packages/dioc/vue.d.ts
vendored
@@ -1,2 +0,0 @@
|
|||||||
export { default } from "./dist/vue.d.ts"
|
|
||||||
export * from "./dist/vue.d.ts"
|
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "hoppscotch-backend",
|
"name": "hoppscotch-backend",
|
||||||
"version": "2023.8.1",
|
"version": "2023.4.5",
|
||||||
"description": "",
|
"description": "",
|
||||||
"author": "",
|
"author": "",
|
||||||
"private": true,
|
"private": true,
|
||||||
@@ -33,7 +33,7 @@
|
|||||||
"@nestjs/passport": "^9.0.0",
|
"@nestjs/passport": "^9.0.0",
|
||||||
"@nestjs/platform-express": "^9.2.1",
|
"@nestjs/platform-express": "^9.2.1",
|
||||||
"@nestjs/throttler": "^4.0.0",
|
"@nestjs/throttler": "^4.0.0",
|
||||||
"@prisma/client": "^4.16.2",
|
"@prisma/client": "^4.7.1",
|
||||||
"apollo-server-express": "^3.11.1",
|
"apollo-server-express": "^3.11.1",
|
||||||
"apollo-server-plugin-base": "^3.7.1",
|
"apollo-server-plugin-base": "^3.7.1",
|
||||||
"argon2": "^0.30.3",
|
"argon2": "^0.30.3",
|
||||||
@@ -57,7 +57,7 @@
|
|||||||
"passport-jwt": "^4.0.1",
|
"passport-jwt": "^4.0.1",
|
||||||
"passport-local": "^1.0.0",
|
"passport-local": "^1.0.0",
|
||||||
"passport-microsoft": "^1.0.0",
|
"passport-microsoft": "^1.0.0",
|
||||||
"prisma": "^4.16.2",
|
"prisma": "^4.7.1",
|
||||||
"reflect-metadata": "^0.1.13",
|
"reflect-metadata": "^0.1.13",
|
||||||
"rimraf": "^3.0.2",
|
"rimraf": "^3.0.2",
|
||||||
"rxjs": "^7.6.0"
|
"rxjs": "^7.6.0"
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ datasource db {
|
|||||||
|
|
||||||
generator client {
|
generator client {
|
||||||
provider = "prisma-client-js"
|
provider = "prisma-client-js"
|
||||||
binaryTargets = ["native", "debian-openssl-1.1.x", "debian-openssl-3.0.x"]
|
binaryTargets = ["native", "debian-openssl-1.1.x"]
|
||||||
}
|
}
|
||||||
|
|
||||||
model Team {
|
model Team {
|
||||||
|
|||||||
@@ -411,23 +411,6 @@ export class AdminResolver {
|
|||||||
return deletedTeam.right;
|
return deletedTeam.right;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Mutation(() => Boolean, {
|
|
||||||
description: 'Revoke a team Invite by Invite ID',
|
|
||||||
})
|
|
||||||
@UseGuards(GqlAuthGuard, GqlAdminGuard)
|
|
||||||
async revokeTeamInviteByAdmin(
|
|
||||||
@Args({
|
|
||||||
name: 'inviteID',
|
|
||||||
description: 'Team Invite ID',
|
|
||||||
type: () => ID,
|
|
||||||
})
|
|
||||||
inviteID: string,
|
|
||||||
): Promise<boolean> {
|
|
||||||
const invite = await this.adminService.revokeTeamInviteByID(inviteID);
|
|
||||||
if (E.isLeft(invite)) throwErr(invite.left);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Subscriptions */
|
/* Subscriptions */
|
||||||
|
|
||||||
@Subscription(() => InvitedUser, {
|
@Subscription(() => InvitedUser, {
|
||||||
|
|||||||
@@ -11,7 +11,6 @@ import {
|
|||||||
INVALID_EMAIL,
|
INVALID_EMAIL,
|
||||||
ONLY_ONE_ADMIN_ACCOUNT,
|
ONLY_ONE_ADMIN_ACCOUNT,
|
||||||
TEAM_INVITE_ALREADY_MEMBER,
|
TEAM_INVITE_ALREADY_MEMBER,
|
||||||
TEAM_INVITE_NO_INVITE_FOUND,
|
|
||||||
USER_ALREADY_INVITED,
|
USER_ALREADY_INVITED,
|
||||||
USER_IS_ADMIN,
|
USER_IS_ADMIN,
|
||||||
USER_NOT_FOUND,
|
USER_NOT_FOUND,
|
||||||
@@ -182,7 +181,7 @@ export class AdminService {
|
|||||||
* @returns an array team invitations
|
* @returns an array team invitations
|
||||||
*/
|
*/
|
||||||
async pendingInvitationCountInTeam(teamID: string) {
|
async pendingInvitationCountInTeam(teamID: string) {
|
||||||
const invitations = await this.teamInvitationService.getTeamInvitations(
|
const invitations = await this.teamInvitationService.getAllTeamInvitations(
|
||||||
teamID,
|
teamID,
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -237,11 +236,11 @@ export class AdminService {
|
|||||||
const user = await this.userService.findUserByEmail(userEmail);
|
const user = await this.userService.findUserByEmail(userEmail);
|
||||||
if (O.isNone(user)) return E.left(USER_NOT_FOUND);
|
if (O.isNone(user)) return E.left(USER_NOT_FOUND);
|
||||||
|
|
||||||
const teamMember = await this.teamService.getTeamMemberTE(
|
const isUserAlreadyMember = await this.teamService.getTeamMemberTE(
|
||||||
teamID,
|
teamID,
|
||||||
user.value.uid,
|
user.value.uid,
|
||||||
)();
|
)();
|
||||||
if (E.isLeft(teamMember)) {
|
if (E.left(isUserAlreadyMember)) {
|
||||||
const addedUser = await this.teamService.addMemberToTeamWithEmail(
|
const addedUser = await this.teamService.addMemberToTeamWithEmail(
|
||||||
teamID,
|
teamID,
|
||||||
userEmail,
|
userEmail,
|
||||||
@@ -249,18 +248,6 @@ export class AdminService {
|
|||||||
);
|
);
|
||||||
if (E.isLeft(addedUser)) return E.left(addedUser.left);
|
if (E.isLeft(addedUser)) return E.left(addedUser.left);
|
||||||
|
|
||||||
const userInvitation =
|
|
||||||
await this.teamInvitationService.getTeamInviteByEmailAndTeamID(
|
|
||||||
userEmail,
|
|
||||||
teamID,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (E.isRight(userInvitation)) {
|
|
||||||
await this.teamInvitationService.revokeInvitation(
|
|
||||||
userInvitation.right.id,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return E.right(addedUser.right);
|
return E.right(addedUser.right);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -417,19 +404,4 @@ export class AdminService {
|
|||||||
if (E.isLeft(team)) return E.left(team.left);
|
if (E.isLeft(team)) return E.left(team.left);
|
||||||
return E.right(team.right);
|
return E.right(team.right);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Revoke a team invite by ID
|
|
||||||
* @param inviteID Team Invite ID
|
|
||||||
* @returns an Either of boolean or error
|
|
||||||
*/
|
|
||||||
async revokeTeamInviteByID(inviteID: string) {
|
|
||||||
const teamInvite = await this.teamInvitationService.revokeInvitation(
|
|
||||||
inviteID,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (E.isLeft(teamInvite)) return E.left(teamInvite.left);
|
|
||||||
|
|
||||||
return E.right(teamInvite.right);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +0,0 @@
|
|||||||
import { Controller, Get } from '@nestjs/common';
|
|
||||||
|
|
||||||
@Controller('ping')
|
|
||||||
export class AppController {
|
|
||||||
@Get()
|
|
||||||
ping(): string {
|
|
||||||
return 'Success';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -19,7 +19,6 @@ import { UserCollectionModule } from './user-collection/user-collection.module';
|
|||||||
import { ShortcodeModule } from './shortcode/shortcode.module';
|
import { ShortcodeModule } from './shortcode/shortcode.module';
|
||||||
import { COOKIES_NOT_FOUND } from './errors';
|
import { COOKIES_NOT_FOUND } from './errors';
|
||||||
import { ThrottlerModule } from '@nestjs/throttler';
|
import { ThrottlerModule } from '@nestjs/throttler';
|
||||||
import { AppController } from './app.controller';
|
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
@@ -82,6 +81,5 @@ import { AppController } from './app.controller';
|
|||||||
ShortcodeModule,
|
ShortcodeModule,
|
||||||
],
|
],
|
||||||
providers: [GQLComplexityPlugin],
|
providers: [GQLComplexityPlugin],
|
||||||
controllers: [AppController],
|
|
||||||
})
|
})
|
||||||
export class AppModule {}
|
export class AppModule {}
|
||||||
|
|||||||
@@ -2,9 +2,9 @@ import {
|
|||||||
Body,
|
Body,
|
||||||
Controller,
|
Controller,
|
||||||
Get,
|
Get,
|
||||||
InternalServerErrorException,
|
|
||||||
Post,
|
Post,
|
||||||
Query,
|
Query,
|
||||||
|
Req,
|
||||||
Request,
|
Request,
|
||||||
Res,
|
Res,
|
||||||
UseGuards,
|
UseGuards,
|
||||||
@@ -19,18 +19,12 @@ import { JwtAuthGuard } from './guards/jwt-auth.guard';
|
|||||||
import { GqlUser } from 'src/decorators/gql-user.decorator';
|
import { GqlUser } from 'src/decorators/gql-user.decorator';
|
||||||
import { AuthUser } from 'src/types/AuthUser';
|
import { AuthUser } from 'src/types/AuthUser';
|
||||||
import { RTCookie } from 'src/decorators/rt-cookie.decorator';
|
import { RTCookie } from 'src/decorators/rt-cookie.decorator';
|
||||||
import {
|
import { authCookieHandler, throwHTTPErr } from './helper';
|
||||||
AuthProvider,
|
|
||||||
authCookieHandler,
|
|
||||||
authProviderCheck,
|
|
||||||
throwHTTPErr,
|
|
||||||
} from './helper';
|
|
||||||
import { GoogleSSOGuard } from './guards/google-sso.guard';
|
import { GoogleSSOGuard } from './guards/google-sso.guard';
|
||||||
import { GithubSSOGuard } from './guards/github-sso.guard';
|
import { GithubSSOGuard } from './guards/github-sso.guard';
|
||||||
import { MicrosoftSSOGuard } from './guards/microsoft-sso-.guard';
|
import { MicrosoftSSOGuard } from './guards/microsoft-sso-.guard';
|
||||||
import { ThrottlerBehindProxyGuard } from 'src/guards/throttler-behind-proxy.guard';
|
import { ThrottlerBehindProxyGuard } from 'src/guards/throttler-behind-proxy.guard';
|
||||||
import { SkipThrottle } from '@nestjs/throttler';
|
import { SkipThrottle } from '@nestjs/throttler';
|
||||||
import { AUTH_PROVIDER_NOT_SPECIFIED } from 'src/errors';
|
|
||||||
|
|
||||||
@UseGuards(ThrottlerBehindProxyGuard)
|
@UseGuards(ThrottlerBehindProxyGuard)
|
||||||
@Controller({ path: 'auth', version: '1' })
|
@Controller({ path: 'auth', version: '1' })
|
||||||
@@ -45,9 +39,6 @@ export class AuthController {
|
|||||||
@Body() authData: SignInMagicDto,
|
@Body() authData: SignInMagicDto,
|
||||||
@Query('origin') origin: string,
|
@Query('origin') origin: string,
|
||||||
) {
|
) {
|
||||||
if (!authProviderCheck(AuthProvider.EMAIL))
|
|
||||||
throwHTTPErr({ message: AUTH_PROVIDER_NOT_SPECIFIED, statusCode: 404 });
|
|
||||||
|
|
||||||
const deviceIdToken = await this.authService.signInMagicLink(
|
const deviceIdToken = await this.authService.signInMagicLink(
|
||||||
authData.email,
|
authData.email,
|
||||||
origin,
|
origin,
|
||||||
|
|||||||
@@ -11,7 +11,6 @@ import { RTJwtStrategy } from './strategies/rt-jwt.strategy';
|
|||||||
import { GoogleStrategy } from './strategies/google.strategy';
|
import { GoogleStrategy } from './strategies/google.strategy';
|
||||||
import { GithubStrategy } from './strategies/github.strategy';
|
import { GithubStrategy } from './strategies/github.strategy';
|
||||||
import { MicrosoftStrategy } from './strategies/microsoft.strategy';
|
import { MicrosoftStrategy } from './strategies/microsoft.strategy';
|
||||||
import { AuthProvider, authProviderCheck } from './helper';
|
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
@@ -27,9 +26,9 @@ import { AuthProvider, authProviderCheck } from './helper';
|
|||||||
AuthService,
|
AuthService,
|
||||||
JwtStrategy,
|
JwtStrategy,
|
||||||
RTJwtStrategy,
|
RTJwtStrategy,
|
||||||
...(authProviderCheck(AuthProvider.GOOGLE) ? [GoogleStrategy] : []),
|
GoogleStrategy,
|
||||||
...(authProviderCheck(AuthProvider.GITHUB) ? [GithubStrategy] : []),
|
GithubStrategy,
|
||||||
...(authProviderCheck(AuthProvider.MICROSOFT) ? [MicrosoftStrategy] : []),
|
MicrosoftStrategy,
|
||||||
],
|
],
|
||||||
controllers: [AuthController],
|
controllers: [AuthController],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -228,7 +228,7 @@ export class AuthService {
|
|||||||
url = process.env.VITE_BASE_URL;
|
url = process.env.VITE_BASE_URL;
|
||||||
}
|
}
|
||||||
|
|
||||||
await this.mailerService.sendEmail(email, {
|
await this.mailerService.sendAuthEmail(email, {
|
||||||
template: 'code-your-own',
|
template: 'code-your-own',
|
||||||
variables: {
|
variables: {
|
||||||
inviteeEmail: email,
|
inviteeEmail: email,
|
||||||
|
|||||||
@@ -1,20 +1,8 @@
|
|||||||
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
import { ExecutionContext, Injectable } from '@nestjs/common';
|
||||||
import { AuthGuard } from '@nestjs/passport';
|
import { AuthGuard } from '@nestjs/passport';
|
||||||
import { AuthProvider, authProviderCheck, throwHTTPErr } from '../helper';
|
|
||||||
import { Observable } from 'rxjs';
|
|
||||||
import { AUTH_PROVIDER_NOT_SPECIFIED } from 'src/errors';
|
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class GithubSSOGuard extends AuthGuard('github') implements CanActivate {
|
export class GithubSSOGuard extends AuthGuard('github') {
|
||||||
canActivate(
|
|
||||||
context: ExecutionContext,
|
|
||||||
): boolean | Promise<boolean> | Observable<boolean> {
|
|
||||||
if (!authProviderCheck(AuthProvider.GITHUB))
|
|
||||||
throwHTTPErr({ message: AUTH_PROVIDER_NOT_SPECIFIED, statusCode: 404 });
|
|
||||||
|
|
||||||
return super.canActivate(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
getAuthenticateOptions(context: ExecutionContext) {
|
getAuthenticateOptions(context: ExecutionContext) {
|
||||||
const req = context.switchToHttp().getRequest();
|
const req = context.switchToHttp().getRequest();
|
||||||
|
|
||||||
|
|||||||
@@ -1,20 +1,8 @@
|
|||||||
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
import { ExecutionContext, Injectable } from '@nestjs/common';
|
||||||
import { AuthGuard } from '@nestjs/passport';
|
import { AuthGuard } from '@nestjs/passport';
|
||||||
import { AuthProvider, authProviderCheck, throwHTTPErr } from '../helper';
|
|
||||||
import { Observable } from 'rxjs';
|
|
||||||
import { AUTH_PROVIDER_NOT_SPECIFIED } from 'src/errors';
|
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class GoogleSSOGuard extends AuthGuard('google') implements CanActivate {
|
export class GoogleSSOGuard extends AuthGuard('google') {
|
||||||
canActivate(
|
|
||||||
context: ExecutionContext,
|
|
||||||
): boolean | Promise<boolean> | Observable<boolean> {
|
|
||||||
if (!authProviderCheck(AuthProvider.GOOGLE))
|
|
||||||
throwHTTPErr({ message: AUTH_PROVIDER_NOT_SPECIFIED, statusCode: 404 });
|
|
||||||
|
|
||||||
return super.canActivate(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
getAuthenticateOptions(context: ExecutionContext) {
|
getAuthenticateOptions(context: ExecutionContext) {
|
||||||
const req = context.switchToHttp().getRequest();
|
const req = context.switchToHttp().getRequest();
|
||||||
|
|
||||||
|
|||||||
@@ -1,26 +1,8 @@
|
|||||||
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
import { ExecutionContext, Injectable } from '@nestjs/common';
|
||||||
import { AuthGuard } from '@nestjs/passport';
|
import { AuthGuard } from '@nestjs/passport';
|
||||||
import { AuthProvider, authProviderCheck, throwHTTPErr } from '../helper';
|
|
||||||
import { Observable } from 'rxjs';
|
|
||||||
import { AUTH_PROVIDER_NOT_SPECIFIED } from 'src/errors';
|
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class MicrosoftSSOGuard
|
export class MicrosoftSSOGuard extends AuthGuard('microsoft') {
|
||||||
extends AuthGuard('microsoft')
|
|
||||||
implements CanActivate
|
|
||||||
{
|
|
||||||
canActivate(
|
|
||||||
context: ExecutionContext,
|
|
||||||
): boolean | Promise<boolean> | Observable<boolean> {
|
|
||||||
if (!authProviderCheck(AuthProvider.MICROSOFT))
|
|
||||||
throwHTTPErr({
|
|
||||||
message: AUTH_PROVIDER_NOT_SPECIFIED,
|
|
||||||
statusCode: 404,
|
|
||||||
});
|
|
||||||
|
|
||||||
return super.canActivate(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
getAuthenticateOptions(context: ExecutionContext) {
|
getAuthenticateOptions(context: ExecutionContext) {
|
||||||
const req = context.switchToHttp().getRequest();
|
const req = context.switchToHttp().getRequest();
|
||||||
|
|
||||||
|
|||||||
@@ -1,11 +1,10 @@
|
|||||||
import { HttpException, HttpStatus } from '@nestjs/common';
|
import { ForbiddenException, HttpException, HttpStatus } from '@nestjs/common';
|
||||||
import { DateTime } from 'luxon';
|
import { DateTime } from 'luxon';
|
||||||
import { AuthError } from 'src/types/AuthError';
|
import { AuthError } from 'src/types/AuthError';
|
||||||
import { AuthTokens } from 'src/types/AuthTokens';
|
import { AuthTokens } from 'src/types/AuthTokens';
|
||||||
import { Response } from 'express';
|
import { Response } from 'express';
|
||||||
import * as cookie from 'cookie';
|
import * as cookie from 'cookie';
|
||||||
import { AUTH_PROVIDER_NOT_SPECIFIED, COOKIES_NOT_FOUND } from 'src/errors';
|
import { COOKIES_NOT_FOUND } from 'src/errors';
|
||||||
import { throwErr } from 'src/utils';
|
|
||||||
|
|
||||||
enum AuthTokenType {
|
enum AuthTokenType {
|
||||||
ACCESS_TOKEN = 'access_token',
|
ACCESS_TOKEN = 'access_token',
|
||||||
@@ -17,13 +16,6 @@ export enum Origin {
|
|||||||
APP = 'app',
|
APP = 'app',
|
||||||
}
|
}
|
||||||
|
|
||||||
export enum AuthProvider {
|
|
||||||
GOOGLE = 'GOOGLE',
|
|
||||||
GITHUB = 'GITHUB',
|
|
||||||
MICROSOFT = 'MICROSOFT',
|
|
||||||
EMAIL = 'EMAIL',
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This function allows throw to be used as an expression
|
* This function allows throw to be used as an expression
|
||||||
* @param errMessage Message present in the error message
|
* @param errMessage Message present in the error message
|
||||||
@@ -105,25 +97,3 @@ export const subscriptionContextCookieParser = (rawCookies: string) => {
|
|||||||
refresh_token: cookies[AuthTokenType.REFRESH_TOKEN],
|
refresh_token: cookies[AuthTokenType.REFRESH_TOKEN],
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* Check to see if given auth provider is present in the VITE_ALLOWED_AUTH_PROVIDERS env variable
|
|
||||||
*
|
|
||||||
* @param provider Provider we want to check the presence of
|
|
||||||
* @returns Boolean if provider specified is present or not
|
|
||||||
*/
|
|
||||||
export function authProviderCheck(provider: string) {
|
|
||||||
if (!provider) {
|
|
||||||
throwErr(AUTH_PROVIDER_NOT_SPECIFIED);
|
|
||||||
}
|
|
||||||
|
|
||||||
const envVariables = process.env.VITE_ALLOWED_AUTH_PROVIDERS
|
|
||||||
? process.env.VITE_ALLOWED_AUTH_PROVIDERS.split(',').map((provider) =>
|
|
||||||
provider.trim().toUpperCase(),
|
|
||||||
)
|
|
||||||
: [];
|
|
||||||
|
|
||||||
if (!envVariables.includes(provider.toUpperCase())) return false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ export class MicrosoftStrategy extends PassportStrategy(Strategy) {
|
|||||||
clientSecret: process.env.MICROSOFT_CLIENT_SECRET,
|
clientSecret: process.env.MICROSOFT_CLIENT_SECRET,
|
||||||
callbackURL: process.env.MICROSOFT_CALLBACK_URL,
|
callbackURL: process.env.MICROSOFT_CALLBACK_URL,
|
||||||
scope: [process.env.MICROSOFT_SCOPE],
|
scope: [process.env.MICROSOFT_SCOPE],
|
||||||
tenant: process.env.MICROSOFT_TENANT,
|
passReqToCallback: true,
|
||||||
store: true,
|
store: true,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,31 +23,7 @@ export const AUTH_FAIL = 'auth/fail';
|
|||||||
export const JSON_INVALID = 'json_invalid';
|
export const JSON_INVALID = 'json_invalid';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Auth Provider not specified
|
* Tried to delete an user data document from fb firestore but failed.
|
||||||
* (Auth)
|
|
||||||
*/
|
|
||||||
export const AUTH_PROVIDER_NOT_SPECIFIED = 'auth/provider_not_specified';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Environment variable "VITE_ALLOWED_AUTH_PROVIDERS" is not present in .env file
|
|
||||||
*/
|
|
||||||
export const ENV_NOT_FOUND_KEY_AUTH_PROVIDERS =
|
|
||||||
'"VITE_ALLOWED_AUTH_PROVIDERS" is not present in .env file';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Environment variable "VITE_ALLOWED_AUTH_PROVIDERS" is empty in .env file
|
|
||||||
*/
|
|
||||||
export const ENV_EMPTY_AUTH_PROVIDERS =
|
|
||||||
'"VITE_ALLOWED_AUTH_PROVIDERS" is empty in .env file';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Environment variable "VITE_ALLOWED_AUTH_PROVIDERS" contains unsupported provider in .env file
|
|
||||||
*/
|
|
||||||
export const ENV_NOT_SUPPORT_AUTH_PROVIDERS =
|
|
||||||
'"VITE_ALLOWED_AUTH_PROVIDERS" contains an unsupported auth provider in .env file';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Tried to delete a user data document from fb firestore but failed.
|
|
||||||
* (FirebaseService)
|
* (FirebaseService)
|
||||||
*/
|
*/
|
||||||
export const USER_FB_DOCUMENT_DELETION_FAILED =
|
export const USER_FB_DOCUMENT_DELETION_FAILED =
|
||||||
@@ -255,7 +231,7 @@ export const TEAM_COLL_INVALID_JSON = 'team_coll/invalid_json';
|
|||||||
export const TEAM_NOT_OWNER = 'team_coll/team_not_owner' as const;
|
export const TEAM_NOT_OWNER = 'team_coll/team_not_owner' as const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tried to perform an action on a request that doesn't accept their member role level
|
* Tried to perform action on a request that doesn't accept their member role level
|
||||||
* (GqlRequestTeamMemberGuard)
|
* (GqlRequestTeamMemberGuard)
|
||||||
*/
|
*/
|
||||||
export const TEAM_REQ_NOT_REQUIRED_ROLE = 'team_req/not_required_role';
|
export const TEAM_REQ_NOT_REQUIRED_ROLE = 'team_req/not_required_role';
|
||||||
@@ -286,7 +262,7 @@ export const TEAM_REQ_REORDERING_FAILED = 'team_req/reordering_failed' as const;
|
|||||||
export const SENDER_EMAIL_INVALID = 'mailer/sender_email_invalid' as const;
|
export const SENDER_EMAIL_INVALID = 'mailer/sender_email_invalid' as const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tried to perform an action on a request when the user is not even a member of the team
|
* Tried to perform action on a request when the user is not even member of the team
|
||||||
* (GqlRequestTeamMemberGuard, GqlCollectionTeamMemberGuard)
|
* (GqlRequestTeamMemberGuard, GqlCollectionTeamMemberGuard)
|
||||||
*/
|
*/
|
||||||
export const TEAM_REQ_NOT_MEMBER = 'team_req/not_member';
|
export const TEAM_REQ_NOT_MEMBER = 'team_req/not_member';
|
||||||
@@ -331,18 +307,11 @@ export const SHORTCODE_INVALID_JSON = 'shortcode/invalid_json' as const;
|
|||||||
export const SHORTCODE_ALREADY_EXISTS = 'shortcode/already_exists' as const;
|
export const SHORTCODE_ALREADY_EXISTS = 'shortcode/already_exists' as const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Invalid or non-existent TEAM ENVIRONMENT ID
|
* Invalid or non-existent TEAM ENVIRONMMENT ID
|
||||||
* (TeamEnvironmentsService)
|
* (TeamEnvironmentsService)
|
||||||
*/
|
*/
|
||||||
export const TEAM_ENVIRONMENT_NOT_FOUND = 'team_environment/not_found' as const;
|
export const TEAM_ENVIRONMENT_NOT_FOUND = 'team_environment/not_found' as const;
|
||||||
|
|
||||||
/**
|
|
||||||
* Invalid TEAM ENVIRONMENT name
|
|
||||||
* (TeamEnvironmentsService)
|
|
||||||
*/
|
|
||||||
export const TEAM_ENVIRONMENT_SHORT_NAME =
|
|
||||||
'team_environment/short_name' as const;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The user is not a member of the team of the given environment
|
* The user is not a member of the team of the given environment
|
||||||
* (GqlTeamEnvTeamGuard)
|
* (GqlTeamEnvTeamGuard)
|
||||||
@@ -371,7 +340,7 @@ export const USER_SETTINGS_NULL_SETTINGS =
|
|||||||
'user_settings/null_settings' as const;
|
'user_settings/null_settings' as const;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Global environment doesn't exist for the user
|
* Global environment doesnt exists for the user
|
||||||
* (UserEnvironmentsService)
|
* (UserEnvironmentsService)
|
||||||
*/
|
*/
|
||||||
export const USER_ENVIRONMENT_GLOBAL_ENV_DOES_NOT_EXISTS =
|
export const USER_ENVIRONMENT_GLOBAL_ENV_DOES_NOT_EXISTS =
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ import {
|
|||||||
UserMagicLinkMailDescription,
|
UserMagicLinkMailDescription,
|
||||||
} from './MailDescriptions';
|
} from './MailDescriptions';
|
||||||
import { throwErr } from 'src/utils';
|
import { throwErr } from 'src/utils';
|
||||||
|
import * as TE from 'fp-ts/TaskEither';
|
||||||
import { EMAIL_FAILED } from 'src/errors';
|
import { EMAIL_FAILED } from 'src/errors';
|
||||||
import { MailerService as NestMailerService } from '@nestjs-modules/mailer';
|
import { MailerService as NestMailerService } from '@nestjs-modules/mailer';
|
||||||
|
|
||||||
@@ -34,14 +35,33 @@ export class MailerService {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Sends an email to the given email address given a mail description
|
* Sends an email to the given email address given a mail description
|
||||||
* @param to Receiver's email id
|
* @param to The email address to be sent to (NOTE: this is not validated)
|
||||||
* @param mailDesc Definition of what email to be sent
|
* @param mailDesc Definition of what email to be sent
|
||||||
* @returns Response if email was send successfully or not
|
|
||||||
*/
|
*/
|
||||||
async sendEmail(
|
sendMail(
|
||||||
to: string,
|
to: string,
|
||||||
mailDesc: MailDescription | UserMagicLinkMailDescription,
|
mailDesc: MailDescription | UserMagicLinkMailDescription,
|
||||||
) {
|
) {
|
||||||
|
return TE.tryCatch(
|
||||||
|
async () => {
|
||||||
|
await this.nestMailerService.sendMail({
|
||||||
|
to,
|
||||||
|
template: mailDesc.template,
|
||||||
|
subject: this.resolveSubjectForMailDesc(mailDesc),
|
||||||
|
context: mailDesc.variables,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
() => EMAIL_FAILED,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param to Receiver's email id
|
||||||
|
* @param mailDesc Details of email to be sent for Magic-Link auth
|
||||||
|
* @returns Response if email was send successfully or not
|
||||||
|
*/
|
||||||
|
async sendAuthEmail(to: string, mailDesc: UserMagicLinkMailDescription) {
|
||||||
try {
|
try {
|
||||||
await this.nestMailerService.sendMail({
|
await this.nestMailerService.sendMail({
|
||||||
to,
|
to,
|
||||||
|
|||||||
@@ -5,14 +5,11 @@ import * as cookieParser from 'cookie-parser';
|
|||||||
import { VersioningType } from '@nestjs/common';
|
import { VersioningType } from '@nestjs/common';
|
||||||
import * as session from 'express-session';
|
import * as session from 'express-session';
|
||||||
import { emitGQLSchemaFile } from './gql-schema';
|
import { emitGQLSchemaFile } from './gql-schema';
|
||||||
import { checkEnvironmentAuthProvider } from './utils';
|
|
||||||
|
|
||||||
async function bootstrap() {
|
async function bootstrap() {
|
||||||
console.log(`Running in production: ${process.env.PRODUCTION}`);
|
console.log(`Running in production: ${process.env.PRODUCTION}`);
|
||||||
console.log(`Port: ${process.env.PORT}`);
|
console.log(`Port: ${process.env.PORT}`);
|
||||||
|
|
||||||
checkEnvironmentAuthProvider();
|
|
||||||
|
|
||||||
const app = await NestFactory.create(AppModule);
|
const app = await NestFactory.create(AppModule);
|
||||||
|
|
||||||
app.use(
|
app.use(
|
||||||
|
|||||||
@@ -150,7 +150,7 @@ export class ShortcodeService implements UserDataHandler, OnModuleInit {
|
|||||||
orderBy: {
|
orderBy: {
|
||||||
createdOn: 'desc',
|
createdOn: 'desc',
|
||||||
},
|
},
|
||||||
skip: args.cursor ? 1 : 0,
|
skip: 1,
|
||||||
take: args.take,
|
take: args.take,
|
||||||
cursor: args.cursor ? { id: args.cursor } : undefined,
|
cursor: args.cursor ? { id: args.cursor } : undefined,
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,5 +1,15 @@
|
|||||||
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
||||||
import { Reflector } from '@nestjs/core';
|
import { Reflector } from '@nestjs/core';
|
||||||
|
import * as TE from 'fp-ts/TaskEither';
|
||||||
|
import * as O from 'fp-ts/Option';
|
||||||
|
import * as S from 'fp-ts/string';
|
||||||
|
import { pipe } from 'fp-ts/function';
|
||||||
|
import {
|
||||||
|
getAnnotatedRequiredRoles,
|
||||||
|
getGqlArg,
|
||||||
|
getUserFromGQLContext,
|
||||||
|
throwErr,
|
||||||
|
} from 'src/utils';
|
||||||
import { TeamEnvironmentsService } from './team-environments.service';
|
import { TeamEnvironmentsService } from './team-environments.service';
|
||||||
import {
|
import {
|
||||||
BUG_AUTH_NO_USER_CTX,
|
BUG_AUTH_NO_USER_CTX,
|
||||||
@@ -9,10 +19,6 @@ import {
|
|||||||
TEAM_ENVIRONMENT_NOT_FOUND,
|
TEAM_ENVIRONMENT_NOT_FOUND,
|
||||||
} from 'src/errors';
|
} from 'src/errors';
|
||||||
import { TeamService } from 'src/team/team.service';
|
import { TeamService } from 'src/team/team.service';
|
||||||
import { GqlExecutionContext } from '@nestjs/graphql';
|
|
||||||
import * as E from 'fp-ts/Either';
|
|
||||||
import { TeamMemberRole } from '@prisma/client';
|
|
||||||
import { throwErr } from 'src/utils';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A guard which checks whether the caller of a GQL Operation
|
* A guard which checks whether the caller of a GQL Operation
|
||||||
@@ -27,31 +33,50 @@ export class GqlTeamEnvTeamGuard implements CanActivate {
|
|||||||
private readonly teamService: TeamService,
|
private readonly teamService: TeamService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
async canActivate(context: ExecutionContext): Promise<boolean> {
|
canActivate(context: ExecutionContext): Promise<boolean> {
|
||||||
const requireRoles = this.reflector.get<TeamMemberRole[]>(
|
return pipe(
|
||||||
'requiresTeamRole',
|
TE.Do,
|
||||||
context.getHandler(),
|
|
||||||
);
|
|
||||||
if (!requireRoles) throw new Error(BUG_TEAM_ENV_GUARD_NO_REQUIRE_ROLES);
|
|
||||||
|
|
||||||
const gqlExecCtx = GqlExecutionContext.create(context);
|
TE.bindW('requiredRoles', () =>
|
||||||
|
pipe(
|
||||||
|
getAnnotatedRequiredRoles(this.reflector, context),
|
||||||
|
TE.fromOption(() => BUG_TEAM_ENV_GUARD_NO_REQUIRE_ROLES),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
const { user } = gqlExecCtx.getContext().req;
|
TE.bindW('user', () =>
|
||||||
if (user == undefined) throw new Error(BUG_AUTH_NO_USER_CTX);
|
pipe(
|
||||||
|
getUserFromGQLContext(context),
|
||||||
|
TE.fromOption(() => BUG_AUTH_NO_USER_CTX),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
const { id } = gqlExecCtx.getArgs<{ id: string }>();
|
TE.bindW('envID', () =>
|
||||||
if (!id) throwErr(BUG_TEAM_ENV_GUARD_NO_ENV_ID);
|
pipe(
|
||||||
|
getGqlArg('id', context),
|
||||||
|
O.fromPredicate(S.isString),
|
||||||
|
TE.fromOption(() => BUG_TEAM_ENV_GUARD_NO_ENV_ID),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
const teamEnvironment =
|
TE.bindW('membership', ({ envID, user }) =>
|
||||||
await this.teamEnvironmentService.getTeamEnvironment(id);
|
pipe(
|
||||||
if (E.isLeft(teamEnvironment)) throwErr(TEAM_ENVIRONMENT_NOT_FOUND);
|
this.teamEnvironmentService.getTeamEnvironment(envID),
|
||||||
|
TE.fromTaskOption(() => TEAM_ENVIRONMENT_NOT_FOUND),
|
||||||
|
TE.chainW((env) =>
|
||||||
|
pipe(
|
||||||
|
this.teamService.getTeamMemberTE(env.teamID, user.uid),
|
||||||
|
TE.mapLeft(() => TEAM_ENVIRONMENT_NOT_TEAM_MEMBER),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
const member = await this.teamService.getTeamMember(
|
TE.map(({ membership, requiredRoles }) =>
|
||||||
teamEnvironment.right.teamID,
|
requiredRoles.includes(membership.role),
|
||||||
user.uid,
|
),
|
||||||
);
|
|
||||||
if (!member) throwErr(TEAM_ENVIRONMENT_NOT_TEAM_MEMBER);
|
|
||||||
|
|
||||||
return requireRoles.includes(member.role);
|
TE.getOrElse(throwErr),
|
||||||
|
)();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,41 +0,0 @@
|
|||||||
import { ArgsType, Field, ID } from '@nestjs/graphql';
|
|
||||||
|
|
||||||
@ArgsType()
|
|
||||||
export class CreateTeamEnvironmentArgs {
|
|
||||||
@Field({
|
|
||||||
name: 'name',
|
|
||||||
description: 'Name of the Team Environment',
|
|
||||||
})
|
|
||||||
name: string;
|
|
||||||
|
|
||||||
@Field(() => ID, {
|
|
||||||
name: 'teamID',
|
|
||||||
description: 'ID of the Team',
|
|
||||||
})
|
|
||||||
teamID: string;
|
|
||||||
|
|
||||||
@Field({
|
|
||||||
name: 'variables',
|
|
||||||
description: 'JSON string of the variables object',
|
|
||||||
})
|
|
||||||
variables: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
@ArgsType()
|
|
||||||
export class UpdateTeamEnvironmentArgs {
|
|
||||||
@Field(() => ID, {
|
|
||||||
name: 'id',
|
|
||||||
description: 'ID of the Team Environment',
|
|
||||||
})
|
|
||||||
id: string;
|
|
||||||
@Field({
|
|
||||||
name: 'name',
|
|
||||||
description: 'Name of the Team Environment',
|
|
||||||
})
|
|
||||||
name: string;
|
|
||||||
@Field({
|
|
||||||
name: 'variables',
|
|
||||||
description: 'JSON string of the variables object',
|
|
||||||
})
|
|
||||||
variables: string;
|
|
||||||
}
|
|
||||||
@@ -13,11 +13,6 @@ import { throwErr } from 'src/utils';
|
|||||||
import { GqlTeamEnvTeamGuard } from './gql-team-env-team.guard';
|
import { GqlTeamEnvTeamGuard } from './gql-team-env-team.guard';
|
||||||
import { TeamEnvironment } from './team-environments.model';
|
import { TeamEnvironment } from './team-environments.model';
|
||||||
import { TeamEnvironmentsService } from './team-environments.service';
|
import { TeamEnvironmentsService } from './team-environments.service';
|
||||||
import * as E from 'fp-ts/Either';
|
|
||||||
import {
|
|
||||||
CreateTeamEnvironmentArgs,
|
|
||||||
UpdateTeamEnvironmentArgs,
|
|
||||||
} from './input-type.args';
|
|
||||||
|
|
||||||
@UseGuards(GqlThrottlerGuard)
|
@UseGuards(GqlThrottlerGuard)
|
||||||
@Resolver(() => 'TeamEnvironment')
|
@Resolver(() => 'TeamEnvironment')
|
||||||
@@ -34,18 +29,29 @@ export class TeamEnvironmentsResolver {
|
|||||||
})
|
})
|
||||||
@UseGuards(GqlAuthGuard, GqlTeamMemberGuard)
|
@UseGuards(GqlAuthGuard, GqlTeamMemberGuard)
|
||||||
@RequiresTeamRole(TeamMemberRole.OWNER, TeamMemberRole.EDITOR)
|
@RequiresTeamRole(TeamMemberRole.OWNER, TeamMemberRole.EDITOR)
|
||||||
async createTeamEnvironment(
|
createTeamEnvironment(
|
||||||
@Args() args: CreateTeamEnvironmentArgs,
|
@Args({
|
||||||
|
name: 'name',
|
||||||
|
description: 'Name of the Team Environment',
|
||||||
|
})
|
||||||
|
name: string,
|
||||||
|
@Args({
|
||||||
|
name: 'teamID',
|
||||||
|
description: 'ID of the Team',
|
||||||
|
type: () => ID,
|
||||||
|
})
|
||||||
|
teamID: string,
|
||||||
|
@Args({
|
||||||
|
name: 'variables',
|
||||||
|
description: 'JSON string of the variables object',
|
||||||
|
})
|
||||||
|
variables: string,
|
||||||
): Promise<TeamEnvironment> {
|
): Promise<TeamEnvironment> {
|
||||||
const teamEnvironment =
|
return this.teamEnvironmentsService.createTeamEnvironment(
|
||||||
await this.teamEnvironmentsService.createTeamEnvironment(
|
name,
|
||||||
args.name,
|
teamID,
|
||||||
args.teamID,
|
variables,
|
||||||
args.variables,
|
)();
|
||||||
);
|
|
||||||
|
|
||||||
if (E.isLeft(teamEnvironment)) throwErr(teamEnvironment.left);
|
|
||||||
return teamEnvironment.right;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Mutation(() => Boolean, {
|
@Mutation(() => Boolean, {
|
||||||
@@ -53,7 +59,7 @@ export class TeamEnvironmentsResolver {
|
|||||||
})
|
})
|
||||||
@UseGuards(GqlAuthGuard, GqlTeamEnvTeamGuard)
|
@UseGuards(GqlAuthGuard, GqlTeamEnvTeamGuard)
|
||||||
@RequiresTeamRole(TeamMemberRole.OWNER, TeamMemberRole.EDITOR)
|
@RequiresTeamRole(TeamMemberRole.OWNER, TeamMemberRole.EDITOR)
|
||||||
async deleteTeamEnvironment(
|
deleteTeamEnvironment(
|
||||||
@Args({
|
@Args({
|
||||||
name: 'id',
|
name: 'id',
|
||||||
description: 'ID of the Team Environment',
|
description: 'ID of the Team Environment',
|
||||||
@@ -61,12 +67,10 @@ export class TeamEnvironmentsResolver {
|
|||||||
})
|
})
|
||||||
id: string,
|
id: string,
|
||||||
): Promise<boolean> {
|
): Promise<boolean> {
|
||||||
const isDeleted = await this.teamEnvironmentsService.deleteTeamEnvironment(
|
return pipe(
|
||||||
id,
|
this.teamEnvironmentsService.deleteTeamEnvironment(id),
|
||||||
);
|
TE.getOrElse(throwErr),
|
||||||
|
)();
|
||||||
if (E.isLeft(isDeleted)) throwErr(isDeleted.left);
|
|
||||||
return isDeleted.right;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Mutation(() => TeamEnvironment, {
|
@Mutation(() => TeamEnvironment, {
|
||||||
@@ -75,19 +79,28 @@ export class TeamEnvironmentsResolver {
|
|||||||
})
|
})
|
||||||
@UseGuards(GqlAuthGuard, GqlTeamEnvTeamGuard)
|
@UseGuards(GqlAuthGuard, GqlTeamEnvTeamGuard)
|
||||||
@RequiresTeamRole(TeamMemberRole.OWNER, TeamMemberRole.EDITOR)
|
@RequiresTeamRole(TeamMemberRole.OWNER, TeamMemberRole.EDITOR)
|
||||||
async updateTeamEnvironment(
|
updateTeamEnvironment(
|
||||||
@Args()
|
@Args({
|
||||||
args: UpdateTeamEnvironmentArgs,
|
name: 'id',
|
||||||
|
description: 'ID of the Team Environment',
|
||||||
|
type: () => ID,
|
||||||
|
})
|
||||||
|
id: string,
|
||||||
|
@Args({
|
||||||
|
name: 'name',
|
||||||
|
description: 'Name of the Team Environment',
|
||||||
|
})
|
||||||
|
name: string,
|
||||||
|
@Args({
|
||||||
|
name: 'variables',
|
||||||
|
description: 'JSON string of the variables object',
|
||||||
|
})
|
||||||
|
variables: string,
|
||||||
): Promise<TeamEnvironment> {
|
): Promise<TeamEnvironment> {
|
||||||
const updatedTeamEnvironment =
|
return pipe(
|
||||||
await this.teamEnvironmentsService.updateTeamEnvironment(
|
this.teamEnvironmentsService.updateTeamEnvironment(id, name, variables),
|
||||||
args.id,
|
TE.getOrElse(throwErr),
|
||||||
args.name,
|
)();
|
||||||
args.variables,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (E.isLeft(updatedTeamEnvironment)) throwErr(updatedTeamEnvironment.left);
|
|
||||||
return updatedTeamEnvironment.right;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Mutation(() => TeamEnvironment, {
|
@Mutation(() => TeamEnvironment, {
|
||||||
@@ -95,7 +108,7 @@ export class TeamEnvironmentsResolver {
|
|||||||
})
|
})
|
||||||
@UseGuards(GqlAuthGuard, GqlTeamEnvTeamGuard)
|
@UseGuards(GqlAuthGuard, GqlTeamEnvTeamGuard)
|
||||||
@RequiresTeamRole(TeamMemberRole.OWNER, TeamMemberRole.EDITOR)
|
@RequiresTeamRole(TeamMemberRole.OWNER, TeamMemberRole.EDITOR)
|
||||||
async deleteAllVariablesFromTeamEnvironment(
|
deleteAllVariablesFromTeamEnvironment(
|
||||||
@Args({
|
@Args({
|
||||||
name: 'id',
|
name: 'id',
|
||||||
description: 'ID of the Team Environment',
|
description: 'ID of the Team Environment',
|
||||||
@@ -103,13 +116,10 @@ export class TeamEnvironmentsResolver {
|
|||||||
})
|
})
|
||||||
id: string,
|
id: string,
|
||||||
): Promise<TeamEnvironment> {
|
): Promise<TeamEnvironment> {
|
||||||
const teamEnvironment =
|
return pipe(
|
||||||
await this.teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(
|
this.teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(id),
|
||||||
id,
|
TE.getOrElse(throwErr),
|
||||||
);
|
)();
|
||||||
|
|
||||||
if (E.isLeft(teamEnvironment)) throwErr(teamEnvironment.left);
|
|
||||||
return teamEnvironment.right;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Mutation(() => TeamEnvironment, {
|
@Mutation(() => TeamEnvironment, {
|
||||||
@@ -117,7 +127,7 @@ export class TeamEnvironmentsResolver {
|
|||||||
})
|
})
|
||||||
@UseGuards(GqlAuthGuard, GqlTeamEnvTeamGuard)
|
@UseGuards(GqlAuthGuard, GqlTeamEnvTeamGuard)
|
||||||
@RequiresTeamRole(TeamMemberRole.OWNER, TeamMemberRole.EDITOR)
|
@RequiresTeamRole(TeamMemberRole.OWNER, TeamMemberRole.EDITOR)
|
||||||
async createDuplicateEnvironment(
|
createDuplicateEnvironment(
|
||||||
@Args({
|
@Args({
|
||||||
name: 'id',
|
name: 'id',
|
||||||
description: 'ID of the Team Environment',
|
description: 'ID of the Team Environment',
|
||||||
@@ -125,12 +135,10 @@ export class TeamEnvironmentsResolver {
|
|||||||
})
|
})
|
||||||
id: string,
|
id: string,
|
||||||
): Promise<TeamEnvironment> {
|
): Promise<TeamEnvironment> {
|
||||||
const res = await this.teamEnvironmentsService.createDuplicateEnvironment(
|
return pipe(
|
||||||
id,
|
this.teamEnvironmentsService.createDuplicateEnvironment(id),
|
||||||
);
|
TE.getOrElse(throwErr),
|
||||||
|
)();
|
||||||
if (E.isLeft(res)) throwErr(res.left);
|
|
||||||
return res.right;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Subscriptions */
|
/* Subscriptions */
|
||||||
|
|||||||
@@ -2,11 +2,7 @@ import { mockDeep, mockReset } from 'jest-mock-extended';
|
|||||||
import { PrismaService } from 'src/prisma/prisma.service';
|
import { PrismaService } from 'src/prisma/prisma.service';
|
||||||
import { TeamEnvironment } from './team-environments.model';
|
import { TeamEnvironment } from './team-environments.model';
|
||||||
import { TeamEnvironmentsService } from './team-environments.service';
|
import { TeamEnvironmentsService } from './team-environments.service';
|
||||||
import {
|
import { TEAM_ENVIRONMENT_NOT_FOUND } from 'src/errors';
|
||||||
JSON_INVALID,
|
|
||||||
TEAM_ENVIRONMENT_NOT_FOUND,
|
|
||||||
TEAM_ENVIRONMENT_SHORT_NAME,
|
|
||||||
} from 'src/errors';
|
|
||||||
|
|
||||||
const mockPrisma = mockDeep<PrismaService>();
|
const mockPrisma = mockDeep<PrismaService>();
|
||||||
|
|
||||||
@@ -35,81 +31,125 @@ beforeEach(() => {
|
|||||||
|
|
||||||
describe('TeamEnvironmentsService', () => {
|
describe('TeamEnvironmentsService', () => {
|
||||||
describe('getTeamEnvironment', () => {
|
describe('getTeamEnvironment', () => {
|
||||||
test('should successfully return a TeamEnvironment with valid ID', async () => {
|
test('queries the db with the id', async () => {
|
||||||
mockPrisma.teamEnvironment.findFirstOrThrow.mockResolvedValueOnce(
|
mockPrisma.teamEnvironment.findFirst.mockResolvedValue(teamEnvironment);
|
||||||
teamEnvironment,
|
|
||||||
);
|
|
||||||
|
|
||||||
const result = await teamEnvironmentsService.getTeamEnvironment(
|
await teamEnvironmentsService.getTeamEnvironment('123')();
|
||||||
teamEnvironment.id,
|
|
||||||
|
expect(mockPrisma.teamEnvironment.findFirst).toHaveBeenCalledWith(
|
||||||
|
expect.objectContaining({
|
||||||
|
where: {
|
||||||
|
id: '123',
|
||||||
|
},
|
||||||
|
}),
|
||||||
);
|
);
|
||||||
expect(result).toEqualRight(teamEnvironment);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should throw TEAM_ENVIRONMENT_NOT_FOUND with invalid ID', async () => {
|
test('requests prisma to reject the query promise if not found', async () => {
|
||||||
mockPrisma.teamEnvironment.findFirstOrThrow.mockRejectedValueOnce(
|
mockPrisma.teamEnvironment.findFirst.mockResolvedValue(teamEnvironment);
|
||||||
'RejectOnNotFound',
|
|
||||||
);
|
|
||||||
|
|
||||||
const result = await teamEnvironmentsService.getTeamEnvironment(
|
await teamEnvironmentsService.getTeamEnvironment('123')();
|
||||||
teamEnvironment.id,
|
|
||||||
|
expect(mockPrisma.teamEnvironment.findFirst).toHaveBeenCalledWith(
|
||||||
|
expect.objectContaining({
|
||||||
|
rejectOnNotFound: true,
|
||||||
|
}),
|
||||||
);
|
);
|
||||||
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('should return a Some of the correct environment if exists', async () => {
|
||||||
|
mockPrisma.teamEnvironment.findFirst.mockResolvedValue(teamEnvironment);
|
||||||
|
|
||||||
|
const result = await teamEnvironmentsService.getTeamEnvironment('123')();
|
||||||
|
|
||||||
|
expect(result).toEqualSome(teamEnvironment);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should return a None if the environment does not exist', async () => {
|
||||||
|
mockPrisma.teamEnvironment.findFirst.mockRejectedValue('NotFoundError');
|
||||||
|
|
||||||
|
const result = await teamEnvironmentsService.getTeamEnvironment('123')();
|
||||||
|
|
||||||
|
expect(result).toBeNone();
|
||||||
|
});
|
||||||
|
});
|
||||||
describe('createTeamEnvironment', () => {
|
describe('createTeamEnvironment', () => {
|
||||||
test('should successfully create and return a new team environment given valid inputs', async () => {
|
test('should create and return a new team environment given a valid name,variable and team ID', async () => {
|
||||||
mockPrisma.teamEnvironment.create.mockResolvedValue(teamEnvironment);
|
mockPrisma.teamEnvironment.create.mockResolvedValue(teamEnvironment);
|
||||||
|
|
||||||
const result = await teamEnvironmentsService.createTeamEnvironment(
|
const result = await teamEnvironmentsService.createTeamEnvironment(
|
||||||
teamEnvironment.name,
|
teamEnvironment.name,
|
||||||
teamEnvironment.teamID,
|
teamEnvironment.teamID,
|
||||||
JSON.stringify(teamEnvironment.variables),
|
JSON.stringify(teamEnvironment.variables),
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualRight({
|
expect(result).toEqual(<TeamEnvironment>{
|
||||||
...teamEnvironment,
|
id: teamEnvironment.id,
|
||||||
|
name: teamEnvironment.name,
|
||||||
|
teamID: teamEnvironment.teamID,
|
||||||
variables: JSON.stringify(teamEnvironment.variables),
|
variables: JSON.stringify(teamEnvironment.variables),
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should throw TEAM_ENVIRONMENT_SHORT_NAME if input TeamEnvironment name is invalid', async () => {
|
test('should reject if given team ID is invalid', async () => {
|
||||||
const result = await teamEnvironmentsService.createTeamEnvironment(
|
mockPrisma.teamEnvironment.create.mockRejectedValue(null as any);
|
||||||
'12',
|
|
||||||
|
await expect(
|
||||||
|
teamEnvironmentsService.createTeamEnvironment(
|
||||||
|
teamEnvironment.name,
|
||||||
|
'invalidteamid',
|
||||||
|
JSON.stringify(teamEnvironment.variables),
|
||||||
|
),
|
||||||
|
).rejects.toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should reject if provided team environment name is not a string', async () => {
|
||||||
|
mockPrisma.teamEnvironment.create.mockRejectedValue(null as any);
|
||||||
|
|
||||||
|
await expect(
|
||||||
|
teamEnvironmentsService.createTeamEnvironment(
|
||||||
|
null as any,
|
||||||
teamEnvironment.teamID,
|
teamEnvironment.teamID,
|
||||||
JSON.stringify(teamEnvironment.variables),
|
JSON.stringify(teamEnvironment.variables),
|
||||||
);
|
),
|
||||||
|
).rejects.toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
expect(result).toEqualLeft(TEAM_ENVIRONMENT_SHORT_NAME);
|
test('should reject if provided variable is not a string', async () => {
|
||||||
|
mockPrisma.teamEnvironment.create.mockRejectedValue(null as any);
|
||||||
|
|
||||||
|
await expect(
|
||||||
|
teamEnvironmentsService.createTeamEnvironment(
|
||||||
|
teamEnvironment.name,
|
||||||
|
teamEnvironment.teamID,
|
||||||
|
null as any,
|
||||||
|
),
|
||||||
|
).rejects.toBeDefined();
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should send pubsub message to "team_environment/<teamID>/created" if team environment is created successfully', async () => {
|
test('should send pubsub message to "team_environment/<teamID>/created" if team environment is created successfully', async () => {
|
||||||
mockPrisma.teamEnvironment.create.mockResolvedValue(teamEnvironment);
|
mockPrisma.teamEnvironment.create.mockResolvedValueOnce(teamEnvironment);
|
||||||
|
|
||||||
const result = await teamEnvironmentsService.createTeamEnvironment(
|
const result = await teamEnvironmentsService.createTeamEnvironment(
|
||||||
teamEnvironment.name,
|
teamEnvironment.name,
|
||||||
teamEnvironment.teamID,
|
teamEnvironment.teamID,
|
||||||
JSON.stringify(teamEnvironment.variables),
|
JSON.stringify(teamEnvironment.variables),
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
||||||
`team_environment/${teamEnvironment.teamID}/created`,
|
`team_environment/${teamEnvironment.teamID}/created`,
|
||||||
{
|
result,
|
||||||
...teamEnvironment,
|
|
||||||
variables: JSON.stringify(teamEnvironment.variables),
|
|
||||||
},
|
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('deleteTeamEnvironment', () => {
|
describe('deleteTeamEnvironment', () => {
|
||||||
test('should successfully delete a TeamEnvironment with a valid ID', async () => {
|
test('should resolve to true given a valid team environment ID', async () => {
|
||||||
mockPrisma.teamEnvironment.delete.mockResolvedValueOnce(teamEnvironment);
|
mockPrisma.teamEnvironment.delete.mockResolvedValueOnce(teamEnvironment);
|
||||||
|
|
||||||
const result = await teamEnvironmentsService.deleteTeamEnvironment(
|
const result = await teamEnvironmentsService.deleteTeamEnvironment(
|
||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualRight(true);
|
expect(result).toEqualRight(true);
|
||||||
});
|
});
|
||||||
@@ -119,7 +159,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
|
|
||||||
const result = await teamEnvironmentsService.deleteTeamEnvironment(
|
const result = await teamEnvironmentsService.deleteTeamEnvironment(
|
||||||
'invalidid',
|
'invalidid',
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
||||||
});
|
});
|
||||||
@@ -129,7 +169,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
|
|
||||||
const result = await teamEnvironmentsService.deleteTeamEnvironment(
|
const result = await teamEnvironmentsService.deleteTeamEnvironment(
|
||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
||||||
`team_environment/${teamEnvironment.teamID}/deleted`,
|
`team_environment/${teamEnvironment.teamID}/deleted`,
|
||||||
@@ -142,7 +182,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe('updateVariablesInTeamEnvironment', () => {
|
describe('updateVariablesInTeamEnvironment', () => {
|
||||||
test('should successfully add new variable to a team environment', async () => {
|
test('should add new variable to a team environment', async () => {
|
||||||
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
variables: [{ key: 'value' }],
|
variables: [{ key: 'value' }],
|
||||||
@@ -152,7 +192,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
teamEnvironment.name,
|
teamEnvironment.name,
|
||||||
JSON.stringify([{ key: 'value' }]),
|
JSON.stringify([{ key: 'value' }]),
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualRight(<TeamEnvironment>{
|
expect(result).toEqualRight(<TeamEnvironment>{
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
@@ -160,7 +200,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should successfully add new variable to already existing list of variables in a team environment', async () => {
|
test('should add new variable to already existing list of variables in a team environment', async () => {
|
||||||
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
variables: [{ key: 'value' }, { key_2: 'value_2' }],
|
variables: [{ key: 'value' }, { key_2: 'value_2' }],
|
||||||
@@ -170,7 +210,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
teamEnvironment.name,
|
teamEnvironment.name,
|
||||||
JSON.stringify([{ key: 'value' }, { key_2: 'value_2' }]),
|
JSON.stringify([{ key: 'value' }, { key_2: 'value_2' }]),
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualRight(<TeamEnvironment>{
|
expect(result).toEqualRight(<TeamEnvironment>{
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
@@ -178,7 +218,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should successfully edit existing variables in a team environment', async () => {
|
test('should edit existing variables in a team environment', async () => {
|
||||||
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
variables: [{ key: '1234' }],
|
variables: [{ key: '1234' }],
|
||||||
@@ -188,7 +228,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
teamEnvironment.name,
|
teamEnvironment.name,
|
||||||
JSON.stringify([{ key: '1234' }]),
|
JSON.stringify([{ key: '1234' }]),
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualRight(<TeamEnvironment>{
|
expect(result).toEqualRight(<TeamEnvironment>{
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
@@ -196,7 +236,22 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should successfully edit name of an existing team environment', async () => {
|
test('should delete existing variable in a team environment', async () => {
|
||||||
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce(teamEnvironment);
|
||||||
|
|
||||||
|
const result = await teamEnvironmentsService.updateTeamEnvironment(
|
||||||
|
teamEnvironment.id,
|
||||||
|
teamEnvironment.name,
|
||||||
|
JSON.stringify([{}]),
|
||||||
|
)();
|
||||||
|
|
||||||
|
expect(result).toEqualRight(<TeamEnvironment>{
|
||||||
|
...teamEnvironment,
|
||||||
|
variables: JSON.stringify([{}]),
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should edit name of an existing team environment', async () => {
|
||||||
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
variables: [{ key: '123' }],
|
variables: [{ key: '123' }],
|
||||||
@@ -206,7 +261,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
teamEnvironment.name,
|
teamEnvironment.name,
|
||||||
JSON.stringify([{ key: '123' }]),
|
JSON.stringify([{ key: '123' }]),
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualRight(<TeamEnvironment>{
|
expect(result).toEqualRight(<TeamEnvironment>{
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
@@ -214,24 +269,14 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should throw TEAM_ENVIRONMENT_SHORT_NAME if input TeamEnvironment name is invalid', async () => {
|
test('should reject to TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
||||||
const result = await teamEnvironmentsService.updateTeamEnvironment(
|
|
||||||
teamEnvironment.id,
|
|
||||||
'12',
|
|
||||||
JSON.stringify([{ key: 'value' }]),
|
|
||||||
);
|
|
||||||
|
|
||||||
expect(result).toEqualLeft(TEAM_ENVIRONMENT_SHORT_NAME);
|
|
||||||
});
|
|
||||||
|
|
||||||
test('should throw TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
|
||||||
mockPrisma.teamEnvironment.update.mockRejectedValue('RecordNotFound');
|
mockPrisma.teamEnvironment.update.mockRejectedValue('RecordNotFound');
|
||||||
|
|
||||||
const result = await teamEnvironmentsService.updateTeamEnvironment(
|
const result = await teamEnvironmentsService.updateTeamEnvironment(
|
||||||
'invalidid',
|
'invalidid',
|
||||||
teamEnvironment.name,
|
teamEnvironment.name,
|
||||||
JSON.stringify(teamEnvironment.variables),
|
JSON.stringify(teamEnvironment.variables),
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
||||||
});
|
});
|
||||||
@@ -243,7 +288,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
teamEnvironment.name,
|
teamEnvironment.name,
|
||||||
JSON.stringify([{ key: 'value' }]),
|
JSON.stringify([{ key: 'value' }]),
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
||||||
`team_environment/${teamEnvironment.teamID}/updated`,
|
`team_environment/${teamEnvironment.teamID}/updated`,
|
||||||
@@ -256,13 +301,13 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe('deleteAllVariablesFromTeamEnvironment', () => {
|
describe('deleteAllVariablesFromTeamEnvironment', () => {
|
||||||
test('should successfully delete all variables in a team environment', async () => {
|
test('should delete all variables in a team environment', async () => {
|
||||||
mockPrisma.teamEnvironment.update.mockResolvedValueOnce(teamEnvironment);
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce(teamEnvironment);
|
||||||
|
|
||||||
const result =
|
const result =
|
||||||
await teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(
|
await teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(
|
||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualRight(<TeamEnvironment>{
|
expect(result).toEqualRight(<TeamEnvironment>{
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
@@ -270,13 +315,13 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should throw TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
test('should reject to TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
||||||
mockPrisma.teamEnvironment.update.mockRejectedValue('RecordNotFound');
|
mockPrisma.teamEnvironment.update.mockRejectedValue('RecordNotFound');
|
||||||
|
|
||||||
const result =
|
const result =
|
||||||
await teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(
|
await teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(
|
||||||
'invalidid',
|
'invalidid',
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
||||||
});
|
});
|
||||||
@@ -287,7 +332,7 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
const result =
|
const result =
|
||||||
await teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(
|
await teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(
|
||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
||||||
`team_environment/${teamEnvironment.teamID}/updated`,
|
`team_environment/${teamEnvironment.teamID}/updated`,
|
||||||
@@ -300,33 +345,33 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe('createDuplicateEnvironment', () => {
|
describe('createDuplicateEnvironment', () => {
|
||||||
test('should successfully duplicate an existing team environment', async () => {
|
test('should duplicate an existing team environment', async () => {
|
||||||
mockPrisma.teamEnvironment.findFirst.mockResolvedValueOnce(
|
mockPrisma.teamEnvironment.findFirst.mockResolvedValueOnce(
|
||||||
teamEnvironment,
|
teamEnvironment,
|
||||||
);
|
);
|
||||||
|
|
||||||
mockPrisma.teamEnvironment.create.mockResolvedValueOnce({
|
mockPrisma.teamEnvironment.create.mockResolvedValueOnce({
|
||||||
id: 'newid',
|
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
|
id: 'newid',
|
||||||
});
|
});
|
||||||
|
|
||||||
const result = await teamEnvironmentsService.createDuplicateEnvironment(
|
const result = await teamEnvironmentsService.createDuplicateEnvironment(
|
||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualRight(<TeamEnvironment>{
|
expect(result).toEqualRight(<TeamEnvironment>{
|
||||||
id: 'newid',
|
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
|
id: 'newid',
|
||||||
variables: JSON.stringify(teamEnvironment.variables),
|
variables: JSON.stringify(teamEnvironment.variables),
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should throw TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
test('should reject to TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
||||||
mockPrisma.teamEnvironment.findFirst.mockRejectedValue('NotFoundError');
|
mockPrisma.teamEnvironment.findFirst.mockRejectedValue('NotFoundError');
|
||||||
|
|
||||||
const result = await teamEnvironmentsService.createDuplicateEnvironment(
|
const result = await teamEnvironmentsService.createDuplicateEnvironment(
|
||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
||||||
});
|
});
|
||||||
@@ -337,19 +382,19 @@ describe('TeamEnvironmentsService', () => {
|
|||||||
);
|
);
|
||||||
|
|
||||||
mockPrisma.teamEnvironment.create.mockResolvedValueOnce({
|
mockPrisma.teamEnvironment.create.mockResolvedValueOnce({
|
||||||
id: 'newid',
|
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
|
id: 'newid',
|
||||||
});
|
});
|
||||||
|
|
||||||
const result = await teamEnvironmentsService.createDuplicateEnvironment(
|
const result = await teamEnvironmentsService.createDuplicateEnvironment(
|
||||||
teamEnvironment.id,
|
teamEnvironment.id,
|
||||||
);
|
)();
|
||||||
|
|
||||||
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
||||||
`team_environment/${teamEnvironment.teamID}/created`,
|
`team_environment/${teamEnvironment.teamID}/created`,
|
||||||
{
|
{
|
||||||
id: 'newid',
|
|
||||||
...teamEnvironment,
|
...teamEnvironment,
|
||||||
|
id: 'newid',
|
||||||
variables: JSON.stringify([{}]),
|
variables: JSON.stringify([{}]),
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1,14 +1,15 @@
|
|||||||
import { Injectable } from '@nestjs/common';
|
import { Injectable } from '@nestjs/common';
|
||||||
import { TeamEnvironment as DBTeamEnvironment, Prisma } from '@prisma/client';
|
import { pipe } from 'fp-ts/function';
|
||||||
|
import * as T from 'fp-ts/Task';
|
||||||
|
import * as TO from 'fp-ts/TaskOption';
|
||||||
|
import * as TE from 'fp-ts/TaskEither';
|
||||||
|
import * as A from 'fp-ts/Array';
|
||||||
|
import { Prisma } from '@prisma/client';
|
||||||
import { PrismaService } from 'src/prisma/prisma.service';
|
import { PrismaService } from 'src/prisma/prisma.service';
|
||||||
import { PubSubService } from 'src/pubsub/pubsub.service';
|
import { PubSubService } from 'src/pubsub/pubsub.service';
|
||||||
import { TeamEnvironment } from './team-environments.model';
|
import { TeamEnvironment } from './team-environments.model';
|
||||||
import {
|
import { TEAM_ENVIRONMENT_NOT_FOUND } from 'src/errors';
|
||||||
TEAM_ENVIRONMENT_NOT_FOUND,
|
|
||||||
TEAM_ENVIRONMENT_SHORT_NAME,
|
|
||||||
} from 'src/errors';
|
|
||||||
import * as E from 'fp-ts/Either';
|
|
||||||
import { isValidLength } from 'src/utils';
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class TeamEnvironmentsService {
|
export class TeamEnvironmentsService {
|
||||||
constructor(
|
constructor(
|
||||||
@@ -16,218 +17,219 @@ export class TeamEnvironmentsService {
|
|||||||
private readonly pubsub: PubSubService,
|
private readonly pubsub: PubSubService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
TITLE_LENGTH = 3;
|
getTeamEnvironment(id: string) {
|
||||||
|
return TO.tryCatch(() =>
|
||||||
/**
|
this.prisma.teamEnvironment.findFirst({
|
||||||
* TeamEnvironments are saved in the DB in the following way
|
|
||||||
* [{ key: value }, { key: value },....]
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Typecast a database TeamEnvironment to a TeamEnvironment model
|
|
||||||
* @param teamEnvironment database TeamEnvironment
|
|
||||||
* @returns TeamEnvironment model
|
|
||||||
*/
|
|
||||||
private cast(teamEnvironment: DBTeamEnvironment): TeamEnvironment {
|
|
||||||
return {
|
|
||||||
id: teamEnvironment.id,
|
|
||||||
name: teamEnvironment.name,
|
|
||||||
teamID: teamEnvironment.teamID,
|
|
||||||
variables: JSON.stringify(teamEnvironment.variables),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get details of a TeamEnvironment.
|
|
||||||
*
|
|
||||||
* @param id TeamEnvironment ID
|
|
||||||
* @returns Either of a TeamEnvironment or error message
|
|
||||||
*/
|
|
||||||
async getTeamEnvironment(id: string) {
|
|
||||||
try {
|
|
||||||
const teamEnvironment =
|
|
||||||
await this.prisma.teamEnvironment.findFirstOrThrow({
|
|
||||||
where: { id },
|
where: { id },
|
||||||
});
|
rejectOnNotFound: true,
|
||||||
return E.right(teamEnvironment);
|
}),
|
||||||
} catch (error) {
|
);
|
||||||
return E.left(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
createTeamEnvironment(name: string, teamID: string, variables: string) {
|
||||||
* Create a new TeamEnvironment.
|
return pipe(
|
||||||
*
|
() =>
|
||||||
* @param name name of new TeamEnvironment
|
this.prisma.teamEnvironment.create({
|
||||||
* @param teamID teamID of new TeamEnvironment
|
|
||||||
* @param variables JSONified string of contents of new TeamEnvironment
|
|
||||||
* @returns Either of a TeamEnvironment or error message
|
|
||||||
*/
|
|
||||||
async createTeamEnvironment(name: string, teamID: string, variables: string) {
|
|
||||||
const isTitleValid = isValidLength(name, this.TITLE_LENGTH);
|
|
||||||
if (!isTitleValid) return E.left(TEAM_ENVIRONMENT_SHORT_NAME);
|
|
||||||
|
|
||||||
const result = await this.prisma.teamEnvironment.create({
|
|
||||||
data: {
|
data: {
|
||||||
name: name,
|
name: name,
|
||||||
teamID: teamID,
|
teamID: teamID,
|
||||||
variables: JSON.parse(variables),
|
variables: JSON.parse(variables),
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
|
T.chainFirst(
|
||||||
const createdTeamEnvironment = this.cast(result);
|
(environment) => () =>
|
||||||
|
|
||||||
this.pubsub.publish(
|
this.pubsub.publish(
|
||||||
`team_environment/${createdTeamEnvironment.teamID}/created`,
|
`team_environment/${environment.teamID}/created`,
|
||||||
createdTeamEnvironment,
|
<TeamEnvironment>{
|
||||||
|
id: environment.id,
|
||||||
|
name: environment.name,
|
||||||
|
teamID: environment.teamID,
|
||||||
|
variables: JSON.stringify(environment.variables),
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
T.map((data) => {
|
||||||
|
return <TeamEnvironment>{
|
||||||
|
id: data.id,
|
||||||
|
name: data.name,
|
||||||
|
teamID: data.teamID,
|
||||||
|
variables: JSON.stringify(data.variables),
|
||||||
|
};
|
||||||
|
}),
|
||||||
);
|
);
|
||||||
|
|
||||||
return E.right(createdTeamEnvironment);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
deleteTeamEnvironment(id: string) {
|
||||||
* Delete a TeamEnvironment.
|
return pipe(
|
||||||
*
|
TE.tryCatch(
|
||||||
* @param id TeamEnvironment ID
|
() =>
|
||||||
* @returns Either of boolean or error message
|
this.prisma.teamEnvironment.delete({
|
||||||
*/
|
|
||||||
async deleteTeamEnvironment(id: string) {
|
|
||||||
try {
|
|
||||||
const result = await this.prisma.teamEnvironment.delete({
|
|
||||||
where: {
|
where: {
|
||||||
id: id,
|
id: id,
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
|
() => TEAM_ENVIRONMENT_NOT_FOUND,
|
||||||
const deletedTeamEnvironment = this.cast(result);
|
),
|
||||||
|
TE.chainFirst((environment) =>
|
||||||
|
TE.fromTask(() =>
|
||||||
this.pubsub.publish(
|
this.pubsub.publish(
|
||||||
`team_environment/${deletedTeamEnvironment.teamID}/deleted`,
|
`team_environment/${environment.teamID}/deleted`,
|
||||||
deletedTeamEnvironment,
|
<TeamEnvironment>{
|
||||||
|
id: environment.id,
|
||||||
|
name: environment.name,
|
||||||
|
teamID: environment.teamID,
|
||||||
|
variables: JSON.stringify(environment.variables),
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
TE.map((data) => true),
|
||||||
);
|
);
|
||||||
|
|
||||||
return E.right(true);
|
|
||||||
} catch (error) {
|
|
||||||
return E.left(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
updateTeamEnvironment(id: string, name: string, variables: string) {
|
||||||
* Update a TeamEnvironment.
|
return pipe(
|
||||||
*
|
TE.tryCatch(
|
||||||
* @param id TeamEnvironment ID
|
() =>
|
||||||
* @param name TeamEnvironment name
|
this.prisma.teamEnvironment.update({
|
||||||
* @param variables JSONified string of contents of new TeamEnvironment
|
|
||||||
* @returns Either of a TeamEnvironment or error message
|
|
||||||
*/
|
|
||||||
async updateTeamEnvironment(id: string, name: string, variables: string) {
|
|
||||||
try {
|
|
||||||
const isTitleValid = isValidLength(name, this.TITLE_LENGTH);
|
|
||||||
if (!isTitleValid) return E.left(TEAM_ENVIRONMENT_SHORT_NAME);
|
|
||||||
|
|
||||||
const result = await this.prisma.teamEnvironment.update({
|
|
||||||
where: { id: id },
|
where: { id: id },
|
||||||
data: {
|
data: {
|
||||||
name,
|
name,
|
||||||
variables: JSON.parse(variables),
|
variables: JSON.parse(variables),
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
|
() => TEAM_ENVIRONMENT_NOT_FOUND,
|
||||||
const updatedTeamEnvironment = this.cast(result);
|
),
|
||||||
|
TE.chainFirst((environment) =>
|
||||||
|
TE.fromTask(() =>
|
||||||
this.pubsub.publish(
|
this.pubsub.publish(
|
||||||
`team_environment/${updatedTeamEnvironment.teamID}/updated`,
|
`team_environment/${environment.teamID}/updated`,
|
||||||
updatedTeamEnvironment,
|
<TeamEnvironment>{
|
||||||
|
id: environment.id,
|
||||||
|
name: environment.name,
|
||||||
|
teamID: environment.teamID,
|
||||||
|
variables: JSON.stringify(environment.variables),
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
TE.map(
|
||||||
|
(environment) =>
|
||||||
|
<TeamEnvironment>{
|
||||||
|
id: environment.id,
|
||||||
|
name: environment.name,
|
||||||
|
teamID: environment.teamID,
|
||||||
|
variables: JSON.stringify(environment.variables),
|
||||||
|
},
|
||||||
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
return E.right(updatedTeamEnvironment);
|
|
||||||
} catch (error) {
|
|
||||||
return E.left(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
deleteAllVariablesFromTeamEnvironment(id: string) {
|
||||||
* Clear contents of a TeamEnvironment.
|
return pipe(
|
||||||
*
|
TE.tryCatch(
|
||||||
* @param id TeamEnvironment ID
|
() =>
|
||||||
* @returns Either of a TeamEnvironment or error message
|
this.prisma.teamEnvironment.update({
|
||||||
*/
|
|
||||||
async deleteAllVariablesFromTeamEnvironment(id: string) {
|
|
||||||
try {
|
|
||||||
const result = await this.prisma.teamEnvironment.update({
|
|
||||||
where: { id: id },
|
where: { id: id },
|
||||||
data: {
|
data: {
|
||||||
variables: [],
|
variables: [],
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
|
() => TEAM_ENVIRONMENT_NOT_FOUND,
|
||||||
const teamEnvironment = this.cast(result);
|
),
|
||||||
|
TE.chainFirst((environment) =>
|
||||||
|
TE.fromTask(() =>
|
||||||
this.pubsub.publish(
|
this.pubsub.publish(
|
||||||
`team_environment/${teamEnvironment.teamID}/updated`,
|
`team_environment/${environment.teamID}/updated`,
|
||||||
teamEnvironment,
|
<TeamEnvironment>{
|
||||||
|
id: environment.id,
|
||||||
|
name: environment.name,
|
||||||
|
teamID: environment.teamID,
|
||||||
|
variables: JSON.stringify(environment.variables),
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
TE.map(
|
||||||
|
(environment) =>
|
||||||
|
<TeamEnvironment>{
|
||||||
|
id: environment.id,
|
||||||
|
name: environment.name,
|
||||||
|
teamID: environment.teamID,
|
||||||
|
variables: JSON.stringify(environment.variables),
|
||||||
|
},
|
||||||
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
return E.right(teamEnvironment);
|
|
||||||
} catch (error) {
|
|
||||||
return E.left(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
createDuplicateEnvironment(id: string) {
|
||||||
* Create a duplicate of a existing TeamEnvironment.
|
return pipe(
|
||||||
*
|
TE.tryCatch(
|
||||||
* @param id TeamEnvironment ID
|
() =>
|
||||||
* @returns Either of a TeamEnvironment or error message
|
this.prisma.teamEnvironment.findFirst({
|
||||||
*/
|
|
||||||
async createDuplicateEnvironment(id: string) {
|
|
||||||
try {
|
|
||||||
const environment = await this.prisma.teamEnvironment.findFirst({
|
|
||||||
where: {
|
where: {
|
||||||
id: id,
|
id: id,
|
||||||
},
|
},
|
||||||
rejectOnNotFound: true,
|
rejectOnNotFound: true,
|
||||||
});
|
}),
|
||||||
|
() => TEAM_ENVIRONMENT_NOT_FOUND,
|
||||||
const result = await this.prisma.teamEnvironment.create({
|
),
|
||||||
|
TE.chain((environment) =>
|
||||||
|
TE.fromTask(() =>
|
||||||
|
this.prisma.teamEnvironment.create({
|
||||||
data: {
|
data: {
|
||||||
name: environment.name,
|
name: environment.name,
|
||||||
teamID: environment.teamID,
|
teamID: environment.teamID,
|
||||||
variables: environment.variables as Prisma.JsonArray,
|
variables: environment.variables as Prisma.JsonArray,
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
|
),
|
||||||
const duplicatedTeamEnvironment = this.cast(result);
|
),
|
||||||
|
TE.chainFirst((environment) =>
|
||||||
|
TE.fromTask(() =>
|
||||||
this.pubsub.publish(
|
this.pubsub.publish(
|
||||||
`team_environment/${duplicatedTeamEnvironment.teamID}/created`,
|
`team_environment/${environment.teamID}/created`,
|
||||||
duplicatedTeamEnvironment,
|
<TeamEnvironment>{
|
||||||
|
id: environment.id,
|
||||||
|
name: environment.name,
|
||||||
|
teamID: environment.teamID,
|
||||||
|
variables: JSON.stringify(environment.variables),
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
TE.map(
|
||||||
|
(environment) =>
|
||||||
|
<TeamEnvironment>{
|
||||||
|
id: environment.id,
|
||||||
|
name: environment.name,
|
||||||
|
teamID: environment.teamID,
|
||||||
|
variables: JSON.stringify(environment.variables),
|
||||||
|
},
|
||||||
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
return E.right(duplicatedTeamEnvironment);
|
|
||||||
} catch (error) {
|
|
||||||
return E.left(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
fetchAllTeamEnvironments(teamID: string) {
|
||||||
* Fetch all TeamEnvironments of a team.
|
return pipe(
|
||||||
*
|
() =>
|
||||||
* @param teamID teamID of new TeamEnvironment
|
this.prisma.teamEnvironment.findMany({
|
||||||
* @returns List of TeamEnvironments
|
|
||||||
*/
|
|
||||||
async fetchAllTeamEnvironments(teamID: string) {
|
|
||||||
const result = await this.prisma.teamEnvironment.findMany({
|
|
||||||
where: {
|
where: {
|
||||||
teamID: teamID,
|
teamID: teamID,
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
const teamEnvironments = result.map((item) => {
|
T.map(
|
||||||
return this.cast(item);
|
A.map(
|
||||||
});
|
(environment) =>
|
||||||
|
<TeamEnvironment>{
|
||||||
return teamEnvironments;
|
id: environment.id,
|
||||||
|
name: environment.name,
|
||||||
|
teamID: environment.teamID,
|
||||||
|
variables: JSON.stringify(environment.variables),
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -11,6 +11,6 @@ export class TeamEnvsTeamResolver {
|
|||||||
description: 'Returns all Team Environments for the given Team',
|
description: 'Returns all Team Environments for the given Team',
|
||||||
})
|
})
|
||||||
teamEnvironments(@Parent() team: Team): Promise<TeamEnvironment[]> {
|
teamEnvironments(@Parent() team: Team): Promise<TeamEnvironment[]> {
|
||||||
return this.teamEnvironmentService.fetchAllTeamEnvironments(team.id);
|
return this.teamEnvironmentService.fetchAllTeamEnvironments(team.id)();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,20 +0,0 @@
|
|||||||
import { ArgsType, Field, ID } from '@nestjs/graphql';
|
|
||||||
import { TeamMemberRole } from 'src/team/team.model';
|
|
||||||
|
|
||||||
@ArgsType()
|
|
||||||
export class CreateTeamInvitationArgs {
|
|
||||||
@Field(() => ID, {
|
|
||||||
name: 'teamID',
|
|
||||||
description: 'ID of the Team ID to invite from',
|
|
||||||
})
|
|
||||||
teamID: string;
|
|
||||||
|
|
||||||
@Field({ name: 'inviteeEmail', description: 'Email of the user to invite' })
|
|
||||||
inviteeEmail: string;
|
|
||||||
|
|
||||||
@Field(() => TeamMemberRole, {
|
|
||||||
name: 'inviteeRole',
|
|
||||||
description: 'Role to be given to the user',
|
|
||||||
})
|
|
||||||
inviteeRole: TeamMemberRole;
|
|
||||||
}
|
|
||||||
@@ -12,10 +12,15 @@ import { TeamInvitation } from './team-invitation.model';
|
|||||||
import { TeamInvitationService } from './team-invitation.service';
|
import { TeamInvitationService } from './team-invitation.service';
|
||||||
import { pipe } from 'fp-ts/function';
|
import { pipe } from 'fp-ts/function';
|
||||||
import * as TE from 'fp-ts/TaskEither';
|
import * as TE from 'fp-ts/TaskEither';
|
||||||
import * as E from 'fp-ts/Either';
|
|
||||||
import * as O from 'fp-ts/Option';
|
import * as O from 'fp-ts/Option';
|
||||||
import { Team, TeamMember, TeamMemberRole } from 'src/team/team.model';
|
import { Team, TeamMember, TeamMemberRole } from 'src/team/team.model';
|
||||||
import { TEAM_INVITE_NO_INVITE_FOUND, USER_NOT_FOUND } from 'src/errors';
|
import { EmailCodec } from 'src/types/Email';
|
||||||
|
import {
|
||||||
|
INVALID_EMAIL,
|
||||||
|
TEAM_INVITE_EMAIL_DO_NOT_MATCH,
|
||||||
|
TEAM_INVITE_NO_INVITE_FOUND,
|
||||||
|
USER_NOT_FOUND,
|
||||||
|
} from 'src/errors';
|
||||||
import { GqlUser } from 'src/decorators/gql-user.decorator';
|
import { GqlUser } from 'src/decorators/gql-user.decorator';
|
||||||
import { User } from 'src/user/user.model';
|
import { User } from 'src/user/user.model';
|
||||||
import { UseGuards } from '@nestjs/common';
|
import { UseGuards } from '@nestjs/common';
|
||||||
@@ -31,8 +36,6 @@ import { UserService } from 'src/user/user.service';
|
|||||||
import { PubSubService } from 'src/pubsub/pubsub.service';
|
import { PubSubService } from 'src/pubsub/pubsub.service';
|
||||||
import { GqlThrottlerGuard } from 'src/guards/gql-throttler.guard';
|
import { GqlThrottlerGuard } from 'src/guards/gql-throttler.guard';
|
||||||
import { SkipThrottle } from '@nestjs/throttler';
|
import { SkipThrottle } from '@nestjs/throttler';
|
||||||
import { AuthUser } from 'src/types/AuthUser';
|
|
||||||
import { CreateTeamInvitationArgs } from './input-type.args';
|
|
||||||
|
|
||||||
@UseGuards(GqlThrottlerGuard)
|
@UseGuards(GqlThrottlerGuard)
|
||||||
@Resolver(() => TeamInvitation)
|
@Resolver(() => TeamInvitation)
|
||||||
@@ -76,8 +79,8 @@ export class TeamInvitationResolver {
|
|||||||
'Gets the Team Invitation with the given ID, or null if not exists',
|
'Gets the Team Invitation with the given ID, or null if not exists',
|
||||||
})
|
})
|
||||||
@UseGuards(GqlAuthGuard, TeamInviteViewerGuard)
|
@UseGuards(GqlAuthGuard, TeamInviteViewerGuard)
|
||||||
async teamInvitation(
|
teamInvitation(
|
||||||
@GqlUser() user: AuthUser,
|
@GqlUser() user: User,
|
||||||
@Args({
|
@Args({
|
||||||
name: 'inviteID',
|
name: 'inviteID',
|
||||||
description: 'ID of the Team Invitation to lookup',
|
description: 'ID of the Team Invitation to lookup',
|
||||||
@@ -85,11 +88,17 @@ export class TeamInvitationResolver {
|
|||||||
})
|
})
|
||||||
inviteID: string,
|
inviteID: string,
|
||||||
): Promise<TeamInvitation> {
|
): Promise<TeamInvitation> {
|
||||||
const teamInvitation = await this.teamInvitationService.getInvitation(
|
return pipe(
|
||||||
inviteID,
|
this.teamInvitationService.getInvitation(inviteID),
|
||||||
);
|
TE.fromTaskOption(() => TEAM_INVITE_NO_INVITE_FOUND),
|
||||||
if (O.isNone(teamInvitation)) throwErr(TEAM_INVITE_NO_INVITE_FOUND);
|
TE.chainW(
|
||||||
return teamInvitation.value;
|
TE.fromPredicate(
|
||||||
|
(a) => a.inviteeEmail.toLowerCase() === user.email?.toLowerCase(),
|
||||||
|
() => TEAM_INVITE_EMAIL_DO_NOT_MATCH,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
TE.getOrElse(throwErr),
|
||||||
|
)();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Mutation(() => TeamInvitation, {
|
@Mutation(() => TeamInvitation, {
|
||||||
@@ -97,19 +106,56 @@ export class TeamInvitationResolver {
|
|||||||
})
|
})
|
||||||
@UseGuards(GqlAuthGuard, GqlTeamMemberGuard)
|
@UseGuards(GqlAuthGuard, GqlTeamMemberGuard)
|
||||||
@RequiresTeamRole(TeamMemberRole.OWNER)
|
@RequiresTeamRole(TeamMemberRole.OWNER)
|
||||||
async createTeamInvitation(
|
createTeamInvitation(
|
||||||
@GqlUser() user: AuthUser,
|
@GqlUser()
|
||||||
@Args() args: CreateTeamInvitationArgs,
|
user: User,
|
||||||
): Promise<TeamInvitation> {
|
|
||||||
const teamInvitation = await this.teamInvitationService.createInvitation(
|
|
||||||
user,
|
|
||||||
args.teamID,
|
|
||||||
args.inviteeEmail,
|
|
||||||
args.inviteeRole,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (E.isLeft(teamInvitation)) throwErr(teamInvitation.left);
|
@Args({
|
||||||
return teamInvitation.right;
|
name: 'teamID',
|
||||||
|
description: 'ID of the Team ID to invite from',
|
||||||
|
type: () => ID,
|
||||||
|
})
|
||||||
|
teamID: string,
|
||||||
|
@Args({
|
||||||
|
name: 'inviteeEmail',
|
||||||
|
description: 'Email of the user to invite',
|
||||||
|
})
|
||||||
|
inviteeEmail: string,
|
||||||
|
@Args({
|
||||||
|
name: 'inviteeRole',
|
||||||
|
type: () => TeamMemberRole,
|
||||||
|
description: 'Role to be given to the user',
|
||||||
|
})
|
||||||
|
inviteeRole: TeamMemberRole,
|
||||||
|
): Promise<TeamInvitation> {
|
||||||
|
return pipe(
|
||||||
|
TE.Do,
|
||||||
|
|
||||||
|
// Validate email
|
||||||
|
TE.bindW('email', () =>
|
||||||
|
pipe(
|
||||||
|
EmailCodec.decode(inviteeEmail),
|
||||||
|
TE.fromEither,
|
||||||
|
TE.mapLeft(() => INVALID_EMAIL),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
// Validate and get Team
|
||||||
|
TE.bindW('team', () => this.teamService.getTeamWithIDTE(teamID)),
|
||||||
|
|
||||||
|
// Create team
|
||||||
|
TE.chainW(({ email, team }) =>
|
||||||
|
this.teamInvitationService.createInvitation(
|
||||||
|
user,
|
||||||
|
team,
|
||||||
|
email,
|
||||||
|
inviteeRole,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
// If failed, throw err (so the message is passed) else return value
|
||||||
|
TE.getOrElse(throwErr),
|
||||||
|
)();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Mutation(() => Boolean, {
|
@Mutation(() => Boolean, {
|
||||||
@@ -117,7 +163,7 @@ export class TeamInvitationResolver {
|
|||||||
})
|
})
|
||||||
@UseGuards(GqlAuthGuard, TeamInviteTeamOwnerGuard)
|
@UseGuards(GqlAuthGuard, TeamInviteTeamOwnerGuard)
|
||||||
@RequiresTeamRole(TeamMemberRole.OWNER)
|
@RequiresTeamRole(TeamMemberRole.OWNER)
|
||||||
async revokeTeamInvitation(
|
revokeTeamInvitation(
|
||||||
@Args({
|
@Args({
|
||||||
name: 'inviteID',
|
name: 'inviteID',
|
||||||
type: () => ID,
|
type: () => ID,
|
||||||
@@ -125,19 +171,19 @@ export class TeamInvitationResolver {
|
|||||||
})
|
})
|
||||||
inviteID: string,
|
inviteID: string,
|
||||||
): Promise<true> {
|
): Promise<true> {
|
||||||
const isRevoked = await this.teamInvitationService.revokeInvitation(
|
return pipe(
|
||||||
inviteID,
|
this.teamInvitationService.revokeInvitation(inviteID),
|
||||||
);
|
TE.map(() => true as const),
|
||||||
if (E.isLeft(isRevoked)) throwErr(isRevoked.left);
|
TE.getOrElse(throwErr),
|
||||||
return true;
|
)();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Mutation(() => TeamMember, {
|
@Mutation(() => TeamMember, {
|
||||||
description: 'Accept an Invitation',
|
description: 'Accept an Invitation',
|
||||||
})
|
})
|
||||||
@UseGuards(GqlAuthGuard, TeamInviteeGuard)
|
@UseGuards(GqlAuthGuard, TeamInviteeGuard)
|
||||||
async acceptTeamInvitation(
|
acceptTeamInvitation(
|
||||||
@GqlUser() user: AuthUser,
|
@GqlUser() user: User,
|
||||||
@Args({
|
@Args({
|
||||||
name: 'inviteID',
|
name: 'inviteID',
|
||||||
type: () => ID,
|
type: () => ID,
|
||||||
@@ -145,12 +191,10 @@ export class TeamInvitationResolver {
|
|||||||
})
|
})
|
||||||
inviteID: string,
|
inviteID: string,
|
||||||
): Promise<TeamMember> {
|
): Promise<TeamMember> {
|
||||||
const teamMember = await this.teamInvitationService.acceptInvitation(
|
return pipe(
|
||||||
inviteID,
|
this.teamInvitationService.acceptInvitation(inviteID, user),
|
||||||
user,
|
TE.getOrElse(throwErr),
|
||||||
);
|
)();
|
||||||
if (E.isLeft(teamMember)) throwErr(teamMember.left);
|
|
||||||
return teamMember.right;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Subscriptions
|
// Subscriptions
|
||||||
|
|||||||
@@ -1,25 +1,24 @@
|
|||||||
import { Injectable } from '@nestjs/common';
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import * as T from 'fp-ts/Task';
|
||||||
import * as O from 'fp-ts/Option';
|
import * as O from 'fp-ts/Option';
|
||||||
import * as E from 'fp-ts/Either';
|
import * as TO from 'fp-ts/TaskOption';
|
||||||
|
import * as TE from 'fp-ts/TaskEither';
|
||||||
|
import { pipe, flow, constVoid } from 'fp-ts/function';
|
||||||
import { PrismaService } from 'src/prisma/prisma.service';
|
import { PrismaService } from 'src/prisma/prisma.service';
|
||||||
import { TeamInvitation as DBTeamInvitation } from '@prisma/client';
|
import { Team, TeamMemberRole } from 'src/team/team.model';
|
||||||
import { TeamMember, TeamMemberRole } from 'src/team/team.model';
|
import { Email } from 'src/types/Email';
|
||||||
|
import { User } from 'src/user/user.model';
|
||||||
import { TeamService } from 'src/team/team.service';
|
import { TeamService } from 'src/team/team.service';
|
||||||
import {
|
import {
|
||||||
INVALID_EMAIL,
|
|
||||||
TEAM_INVALID_ID,
|
|
||||||
TEAM_INVITE_ALREADY_MEMBER,
|
TEAM_INVITE_ALREADY_MEMBER,
|
||||||
TEAM_INVITE_EMAIL_DO_NOT_MATCH,
|
TEAM_INVITE_EMAIL_DO_NOT_MATCH,
|
||||||
TEAM_INVITE_MEMBER_HAS_INVITE,
|
TEAM_INVITE_MEMBER_HAS_INVITE,
|
||||||
TEAM_INVITE_NO_INVITE_FOUND,
|
TEAM_INVITE_NO_INVITE_FOUND,
|
||||||
TEAM_MEMBER_NOT_FOUND,
|
|
||||||
} from 'src/errors';
|
} from 'src/errors';
|
||||||
import { TeamInvitation } from './team-invitation.model';
|
import { TeamInvitation } from './team-invitation.model';
|
||||||
import { MailerService } from 'src/mailer/mailer.service';
|
import { MailerService } from 'src/mailer/mailer.service';
|
||||||
import { UserService } from 'src/user/user.service';
|
import { UserService } from 'src/user/user.service';
|
||||||
import { PubSubService } from 'src/pubsub/pubsub.service';
|
import { PubSubService } from 'src/pubsub/pubsub.service';
|
||||||
import { validateEmail } from '../utils';
|
|
||||||
import { AuthUser } from 'src/types/AuthUser';
|
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class TeamInvitationService {
|
export class TeamInvitationService {
|
||||||
@@ -30,221 +29,245 @@ export class TeamInvitationService {
|
|||||||
private readonly mailerService: MailerService,
|
private readonly mailerService: MailerService,
|
||||||
|
|
||||||
private readonly pubsub: PubSubService,
|
private readonly pubsub: PubSubService,
|
||||||
) {}
|
) {
|
||||||
|
this.getInvitation = this.getInvitation.bind(this);
|
||||||
/**
|
|
||||||
* Cast a DBTeamInvitation to a TeamInvitation
|
|
||||||
* @param dbTeamInvitation database TeamInvitation
|
|
||||||
* @returns TeamInvitation model
|
|
||||||
*/
|
|
||||||
cast(dbTeamInvitation: DBTeamInvitation): TeamInvitation {
|
|
||||||
return {
|
|
||||||
...dbTeamInvitation,
|
|
||||||
inviteeRole: TeamMemberRole[dbTeamInvitation.inviteeRole],
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
getInvitation(inviteID: string): TO.TaskOption<TeamInvitation> {
|
||||||
* Get the team invite
|
return pipe(
|
||||||
* @param inviteID invite id
|
() =>
|
||||||
* @returns an Option of team invitation or none
|
this.prisma.teamInvitation.findUnique({
|
||||||
*/
|
|
||||||
async getInvitation(inviteID: string) {
|
|
||||||
try {
|
|
||||||
const dbInvitation = await this.prisma.teamInvitation.findUniqueOrThrow({
|
|
||||||
where: {
|
where: {
|
||||||
id: inviteID,
|
id: inviteID,
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
|
TO.fromTask,
|
||||||
return O.some(this.cast(dbInvitation));
|
TO.chain(flow(O.fromNullable, TO.fromOption)),
|
||||||
} catch (e) {
|
TO.map((x) => x as TeamInvitation),
|
||||||
return O.none;
|
);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
getInvitationWithEmail(email: Email, team: Team) {
|
||||||
* Get the team invite for an invitee with email and teamID.
|
return pipe(
|
||||||
* @param inviteeEmail invitee email
|
() =>
|
||||||
* @param teamID team id
|
this.prisma.teamInvitation.findUnique({
|
||||||
* @returns an Either of team invitation for the invitee or error
|
|
||||||
*/
|
|
||||||
async getTeamInviteByEmailAndTeamID(inviteeEmail: string, teamID: string) {
|
|
||||||
const isEmailValid = validateEmail(inviteeEmail);
|
|
||||||
if (!isEmailValid) return E.left(INVALID_EMAIL);
|
|
||||||
|
|
||||||
try {
|
|
||||||
const teamInvite = await this.prisma.teamInvitation.findUniqueOrThrow({
|
|
||||||
where: {
|
where: {
|
||||||
teamID_inviteeEmail: {
|
teamID_inviteeEmail: {
|
||||||
inviteeEmail: inviteeEmail,
|
inviteeEmail: email,
|
||||||
teamID: teamID,
|
teamID: team.id,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
|
TO.fromTask,
|
||||||
return E.right(teamInvite);
|
TO.chain(flow(O.fromNullable, TO.fromOption)),
|
||||||
} catch (e) {
|
);
|
||||||
return E.left(TEAM_INVITE_NO_INVITE_FOUND);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
createInvitation(
|
||||||
* Create a team invitation
|
creator: User,
|
||||||
* @param creator creator of the invitation
|
team: Team,
|
||||||
* @param teamID team id
|
inviteeEmail: Email,
|
||||||
* @param inviteeEmail invitee email
|
|
||||||
* @param inviteeRole invitee role
|
|
||||||
* @returns an Either of team invitation or error message
|
|
||||||
*/
|
|
||||||
async createInvitation(
|
|
||||||
creator: AuthUser,
|
|
||||||
teamID: string,
|
|
||||||
inviteeEmail: string,
|
|
||||||
inviteeRole: TeamMemberRole,
|
inviteeRole: TeamMemberRole,
|
||||||
) {
|
) {
|
||||||
// validate email
|
return pipe(
|
||||||
const isEmailValid = validateEmail(inviteeEmail);
|
// Perform all validation checks
|
||||||
if (!isEmailValid) return E.left(INVALID_EMAIL);
|
TE.sequenceArray([
|
||||||
|
// creator should be a TeamMember
|
||||||
|
pipe(
|
||||||
|
this.teamService.getTeamMemberTE(team.id, creator.uid),
|
||||||
|
TE.map(constVoid),
|
||||||
|
),
|
||||||
|
|
||||||
// team ID should valid
|
// Invitee should not be a team member
|
||||||
const team = await this.teamService.getTeamWithID(teamID);
|
pipe(
|
||||||
if (!team) return E.left(TEAM_INVALID_ID);
|
async () => await this.userService.findUserByEmail(inviteeEmail),
|
||||||
|
TO.foldW(
|
||||||
|
() => TE.right(undefined), // If no user, short circuit to completion
|
||||||
|
(user) =>
|
||||||
|
pipe(
|
||||||
|
// If user is found, check if team member
|
||||||
|
this.teamService.getTeamMemberTE(team.id, user.uid),
|
||||||
|
TE.foldW(
|
||||||
|
() => TE.right(undefined), // Not team-member, this is good
|
||||||
|
() => TE.left(TEAM_INVITE_ALREADY_MEMBER), // Is team member, not good
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
TE.map(constVoid),
|
||||||
|
),
|
||||||
|
|
||||||
// invitation creator should be a TeamMember
|
// Should not have an existing invite
|
||||||
const isTeamMember = await this.teamService.getTeamMember(
|
pipe(
|
||||||
team.id,
|
this.getInvitationWithEmail(inviteeEmail, team),
|
||||||
creator.uid,
|
TE.fromTaskOption(() => null),
|
||||||
);
|
TE.swap,
|
||||||
if (!isTeamMember) return E.left(TEAM_MEMBER_NOT_FOUND);
|
TE.map(constVoid),
|
||||||
|
TE.mapLeft(() => TEAM_INVITE_MEMBER_HAS_INVITE),
|
||||||
|
),
|
||||||
|
]),
|
||||||
|
|
||||||
// Checking to see if the invitee is already part of the team or not
|
// Create the invitation
|
||||||
const inviteeUser = await this.userService.findUserByEmail(inviteeEmail);
|
TE.chainTaskK(
|
||||||
if (O.isSome(inviteeUser)) {
|
() => () =>
|
||||||
// invitee should not already a member
|
this.prisma.teamInvitation.create({
|
||||||
const isTeamMember = await this.teamService.getTeamMember(
|
|
||||||
team.id,
|
|
||||||
inviteeUser.value.uid,
|
|
||||||
);
|
|
||||||
if (isTeamMember) return E.left(TEAM_INVITE_ALREADY_MEMBER);
|
|
||||||
}
|
|
||||||
|
|
||||||
// check invitee already invited earlier or not
|
|
||||||
const teamInvitation = await this.getTeamInviteByEmailAndTeamID(
|
|
||||||
inviteeEmail,
|
|
||||||
team.id,
|
|
||||||
);
|
|
||||||
if (E.isRight(teamInvitation)) return E.left(TEAM_INVITE_MEMBER_HAS_INVITE);
|
|
||||||
|
|
||||||
// create the invitation
|
|
||||||
const dbInvitation = await this.prisma.teamInvitation.create({
|
|
||||||
data: {
|
data: {
|
||||||
teamID: team.id,
|
teamID: team.id,
|
||||||
inviteeEmail,
|
inviteeEmail,
|
||||||
inviteeRole,
|
inviteeRole,
|
||||||
creatorUid: creator.uid,
|
creatorUid: creator.uid,
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
|
),
|
||||||
|
|
||||||
await this.mailerService.sendEmail(inviteeEmail, {
|
// Send email, this is a side effect
|
||||||
|
TE.chainFirstTaskK((invitation) =>
|
||||||
|
pipe(
|
||||||
|
this.mailerService.sendMail(inviteeEmail, {
|
||||||
template: 'team-invitation',
|
template: 'team-invitation',
|
||||||
variables: {
|
variables: {
|
||||||
invitee: creator.displayName ?? 'A Hoppscotch User',
|
invitee: creator.displayName ?? 'A Hoppscotch User',
|
||||||
action_url: `${process.env.VITE_BASE_URL}/join-team?id=${dbInvitation.id}`,
|
action_url: `${process.env.VITE_BASE_URL}/join-team?id=${invitation.id}`,
|
||||||
invite_team_name: team.name,
|
invite_team_name: team.name,
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
|
|
||||||
const invitation = this.cast(dbInvitation);
|
TE.getOrElseW(() => T.of(undefined)), // This value doesn't matter as we don't mind the return value (chainFirst) as long as the task completes
|
||||||
this.pubsub.publish(`team/${invitation.teamID}/invite_added`, invitation);
|
),
|
||||||
|
),
|
||||||
|
|
||||||
return E.right(invitation);
|
// Send PubSub topic
|
||||||
|
TE.chainFirstTaskK((invitation) =>
|
||||||
|
TE.fromTask(async () => {
|
||||||
|
const inv: TeamInvitation = {
|
||||||
|
id: invitation.id,
|
||||||
|
teamID: invitation.teamID,
|
||||||
|
creatorUid: invitation.creatorUid,
|
||||||
|
inviteeEmail: invitation.inviteeEmail,
|
||||||
|
inviteeRole: TeamMemberRole[invitation.inviteeRole],
|
||||||
|
};
|
||||||
|
|
||||||
|
this.pubsub.publish(`team/${inv.teamID}/invite_added`, inv);
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
|
||||||
|
// Map to model type
|
||||||
|
TE.map((x) => x as TeamInvitation),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
revokeInvitation(inviteID: string) {
|
||||||
* Revoke a team invitation
|
return pipe(
|
||||||
* @param inviteID invite id
|
// Make sure invite exists
|
||||||
* @returns an Either of true or error message
|
this.getInvitation(inviteID),
|
||||||
*/
|
TE.fromTaskOption(() => TEAM_INVITE_NO_INVITE_FOUND),
|
||||||
async revokeInvitation(inviteID: string) {
|
|
||||||
// check if the invite exists
|
|
||||||
const invitation = await this.getInvitation(inviteID);
|
|
||||||
if (O.isNone(invitation)) return E.left(TEAM_INVITE_NO_INVITE_FOUND);
|
|
||||||
|
|
||||||
// delete the invite
|
// Delete team invitation
|
||||||
await this.prisma.teamInvitation.delete({
|
TE.chainTaskK(
|
||||||
|
() => () =>
|
||||||
|
this.prisma.teamInvitation.delete({
|
||||||
where: {
|
where: {
|
||||||
id: inviteID,
|
id: inviteID,
|
||||||
},
|
},
|
||||||
});
|
}),
|
||||||
|
),
|
||||||
|
|
||||||
|
// Emit Pubsub Event
|
||||||
|
TE.chainFirst((invitation) =>
|
||||||
|
TE.fromTask(() =>
|
||||||
this.pubsub.publish(
|
this.pubsub.publish(
|
||||||
`team/${invitation.value.teamID}/invite_removed`,
|
`team/${invitation.teamID}/invite_removed`,
|
||||||
invitation.value.id,
|
invitation.id,
|
||||||
);
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
return E.right(true);
|
// We are not returning anything
|
||||||
|
TE.map(constVoid),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
getAllInvitationsInTeam(team: Team) {
|
||||||
|
return pipe(
|
||||||
|
() =>
|
||||||
|
this.prisma.teamInvitation.findMany({
|
||||||
|
where: {
|
||||||
|
teamID: team.id,
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
T.map((x) => x as TeamInvitation[]),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
acceptInvitation(inviteID: string, acceptedBy: User) {
|
||||||
|
return pipe(
|
||||||
|
TE.Do,
|
||||||
|
|
||||||
|
// First get the invitation
|
||||||
|
TE.bindW('invitation', () =>
|
||||||
|
pipe(
|
||||||
|
this.getInvitation(inviteID),
|
||||||
|
TE.fromTaskOption(() => TEAM_INVITE_NO_INVITE_FOUND),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
// Validation checks
|
||||||
|
TE.chainFirstW(({ invitation }) =>
|
||||||
|
TE.sequenceArray([
|
||||||
|
// Make sure the invited user is not part of the team
|
||||||
|
pipe(
|
||||||
|
this.teamService.getTeamMemberTE(invitation.teamID, acceptedBy.uid),
|
||||||
|
TE.swap,
|
||||||
|
TE.bimap(
|
||||||
|
() => TEAM_INVITE_ALREADY_MEMBER,
|
||||||
|
constVoid, // The return type is ignored
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
// Make sure the invited user and accepting user has the same email
|
||||||
|
pipe(
|
||||||
|
undefined,
|
||||||
|
TE.fromPredicate(
|
||||||
|
(a) => acceptedBy.email === invitation.inviteeEmail,
|
||||||
|
() => TEAM_INVITE_EMAIL_DO_NOT_MATCH,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
]),
|
||||||
|
),
|
||||||
|
|
||||||
|
// Add the team member
|
||||||
|
// TODO: Somehow bring subscriptions to this ?
|
||||||
|
TE.bindW('teamMember', ({ invitation }) =>
|
||||||
|
pipe(
|
||||||
|
TE.tryCatch(
|
||||||
|
() =>
|
||||||
|
this.teamService.addMemberToTeam(
|
||||||
|
invitation.teamID,
|
||||||
|
acceptedBy.uid,
|
||||||
|
invitation.inviteeRole,
|
||||||
|
),
|
||||||
|
() => TEAM_INVITE_ALREADY_MEMBER, // Can only fail if Team Member already exists, which we checked, but due to async lets assert that here too
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
TE.chainFirstW(({ invitation }) => this.revokeInvitation(invitation.id)),
|
||||||
|
|
||||||
|
TE.map(({ teamMember }) => teamMember),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Accept a team invitation
|
* Fetch the count invitations for a given team.
|
||||||
* @param inviteID invite id
|
|
||||||
* @param acceptedBy user who accepted the invitation
|
|
||||||
* @returns an Either of team member or error message
|
|
||||||
*/
|
|
||||||
async acceptInvitation(inviteID: string, acceptedBy: AuthUser) {
|
|
||||||
// check if the invite exists
|
|
||||||
const invitation = await this.getInvitation(inviteID);
|
|
||||||
if (O.isNone(invitation)) return E.left(TEAM_INVITE_NO_INVITE_FOUND);
|
|
||||||
|
|
||||||
// make sure the user is not already a member of the team
|
|
||||||
const teamMemberInvitee = await this.teamService.getTeamMember(
|
|
||||||
invitation.value.teamID,
|
|
||||||
acceptedBy.uid,
|
|
||||||
);
|
|
||||||
if (teamMemberInvitee) return E.left(TEAM_INVITE_ALREADY_MEMBER);
|
|
||||||
|
|
||||||
// make sure the user is the same as the invitee
|
|
||||||
if (
|
|
||||||
acceptedBy.email.toLowerCase() !==
|
|
||||||
invitation.value.inviteeEmail.toLowerCase()
|
|
||||||
)
|
|
||||||
return E.left(TEAM_INVITE_EMAIL_DO_NOT_MATCH);
|
|
||||||
|
|
||||||
// add the user to the team
|
|
||||||
let teamMember: TeamMember;
|
|
||||||
try {
|
|
||||||
teamMember = await this.teamService.addMemberToTeam(
|
|
||||||
invitation.value.teamID,
|
|
||||||
acceptedBy.uid,
|
|
||||||
invitation.value.inviteeRole,
|
|
||||||
);
|
|
||||||
} catch (e) {
|
|
||||||
return E.left(TEAM_INVITE_ALREADY_MEMBER);
|
|
||||||
}
|
|
||||||
|
|
||||||
// delete the invite
|
|
||||||
await this.revokeInvitation(inviteID);
|
|
||||||
|
|
||||||
return E.right(teamMember);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Fetch all team invitations for a given team.
|
|
||||||
* @param teamID team id
|
* @param teamID team id
|
||||||
* @returns array of team invitations for a team
|
* @returns a count team invitations for a team
|
||||||
*/
|
*/
|
||||||
async getTeamInvitations(teamID: string) {
|
async getAllTeamInvitations(teamID: string) {
|
||||||
const dbInvitations = await this.prisma.teamInvitation.findMany({
|
const invitations = await this.prisma.teamInvitation.findMany({
|
||||||
where: {
|
where: {
|
||||||
teamID: teamID,
|
teamID: teamID,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
const invitations: TeamInvitation[] = dbInvitations.map((dbInvitation) =>
|
|
||||||
this.cast(dbInvitation),
|
|
||||||
);
|
|
||||||
|
|
||||||
return invitations;
|
return invitations;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,21 +1,21 @@
|
|||||||
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
||||||
|
import { pipe } from 'fp-ts/function';
|
||||||
import { TeamService } from 'src/team/team.service';
|
import { TeamService } from 'src/team/team.service';
|
||||||
import { TeamInvitationService } from './team-invitation.service';
|
import { TeamInvitationService } from './team-invitation.service';
|
||||||
import * as O from 'fp-ts/Option';
|
import * as O from 'fp-ts/Option';
|
||||||
|
import * as T from 'fp-ts/Task';
|
||||||
|
import * as TE from 'fp-ts/TaskEither';
|
||||||
import { GqlExecutionContext } from '@nestjs/graphql';
|
import { GqlExecutionContext } from '@nestjs/graphql';
|
||||||
import {
|
import {
|
||||||
BUG_AUTH_NO_USER_CTX,
|
BUG_AUTH_NO_USER_CTX,
|
||||||
BUG_TEAM_INVITE_NO_INVITE_ID,
|
BUG_TEAM_INVITE_NO_INVITE_ID,
|
||||||
TEAM_INVITE_NO_INVITE_FOUND,
|
TEAM_INVITE_NO_INVITE_FOUND,
|
||||||
TEAM_MEMBER_NOT_FOUND,
|
|
||||||
TEAM_NOT_REQUIRED_ROLE,
|
TEAM_NOT_REQUIRED_ROLE,
|
||||||
} from 'src/errors';
|
} from 'src/errors';
|
||||||
|
import { User } from 'src/user/user.model';
|
||||||
import { throwErr } from 'src/utils';
|
import { throwErr } from 'src/utils';
|
||||||
import { TeamMemberRole } from 'src/team/team.model';
|
import { TeamMemberRole } from 'src/team/team.model';
|
||||||
|
|
||||||
/**
|
|
||||||
* This guard only allows team owner to execute the resolver
|
|
||||||
*/
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class TeamInviteTeamOwnerGuard implements CanActivate {
|
export class TeamInviteTeamOwnerGuard implements CanActivate {
|
||||||
constructor(
|
constructor(
|
||||||
@@ -24,30 +24,48 @@ export class TeamInviteTeamOwnerGuard implements CanActivate {
|
|||||||
) {}
|
) {}
|
||||||
|
|
||||||
async canActivate(context: ExecutionContext): Promise<boolean> {
|
async canActivate(context: ExecutionContext): Promise<boolean> {
|
||||||
// Get GQL context
|
return pipe(
|
||||||
const gqlExecCtx = GqlExecutionContext.create(context);
|
TE.Do,
|
||||||
|
|
||||||
// Get user
|
TE.bindW('gqlCtx', () => TE.of(GqlExecutionContext.create(context))),
|
||||||
const { user } = gqlExecCtx.getContext().req;
|
|
||||||
if (!user) throwErr(BUG_AUTH_NO_USER_CTX);
|
|
||||||
|
|
||||||
// Get the invite
|
// Get the invite
|
||||||
const { inviteID } = gqlExecCtx.getArgs<{ inviteID: string }>();
|
TE.bindW('invite', ({ gqlCtx }) =>
|
||||||
if (!inviteID) throwErr(BUG_TEAM_INVITE_NO_INVITE_ID);
|
pipe(
|
||||||
|
O.fromNullable(gqlCtx.getArgs<{ inviteID?: string }>().inviteID),
|
||||||
|
TE.fromOption(() => BUG_TEAM_INVITE_NO_INVITE_ID),
|
||||||
|
TE.chainW((inviteID) =>
|
||||||
|
pipe(
|
||||||
|
this.teamInviteService.getInvitation(inviteID),
|
||||||
|
TE.fromTaskOption(() => TEAM_INVITE_NO_INVITE_FOUND),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
const invitation = await this.teamInviteService.getInvitation(inviteID);
|
TE.bindW('user', ({ gqlCtx }) =>
|
||||||
if (O.isNone(invitation)) throwErr(TEAM_INVITE_NO_INVITE_FOUND);
|
pipe(
|
||||||
|
gqlCtx.getContext().req.user,
|
||||||
|
O.fromNullable,
|
||||||
|
TE.fromOption(() => BUG_AUTH_NO_USER_CTX),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
// Fetch team member details of this user
|
TE.bindW('userMember', ({ invite, user }) =>
|
||||||
const teamMember = await this.teamService.getTeamMember(
|
this.teamService.getTeamMemberTE(invite.teamID, user.uid),
|
||||||
invitation.value.teamID,
|
),
|
||||||
user.uid,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!teamMember) throwErr(TEAM_MEMBER_NOT_FOUND);
|
TE.chainW(
|
||||||
if (teamMember.role !== TeamMemberRole.OWNER)
|
TE.fromPredicate(
|
||||||
throwErr(TEAM_NOT_REQUIRED_ROLE);
|
({ userMember }) => userMember.role === TeamMemberRole.OWNER,
|
||||||
|
() => TEAM_NOT_REQUIRED_ROLE,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
return true;
|
TE.fold(
|
||||||
|
(err) => throwErr(err),
|
||||||
|
() => T.of(true),
|
||||||
|
),
|
||||||
|
)();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,23 +1,20 @@
|
|||||||
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
||||||
import { TeamInvitationService } from './team-invitation.service';
|
import { TeamInvitationService } from './team-invitation.service';
|
||||||
|
import { pipe, flow } from 'fp-ts/function';
|
||||||
|
import * as TE from 'fp-ts/TaskEither';
|
||||||
|
import * as T from 'fp-ts/Task';
|
||||||
import * as O from 'fp-ts/Option';
|
import * as O from 'fp-ts/Option';
|
||||||
import { GqlExecutionContext } from '@nestjs/graphql';
|
import { GqlExecutionContext } from '@nestjs/graphql';
|
||||||
import {
|
import {
|
||||||
BUG_AUTH_NO_USER_CTX,
|
BUG_AUTH_NO_USER_CTX,
|
||||||
BUG_TEAM_INVITE_NO_INVITE_ID,
|
BUG_TEAM_INVITE_NO_INVITE_ID,
|
||||||
|
TEAM_INVITE_NOT_VALID_VIEWER,
|
||||||
TEAM_INVITE_NO_INVITE_FOUND,
|
TEAM_INVITE_NO_INVITE_FOUND,
|
||||||
TEAM_MEMBER_NOT_FOUND,
|
|
||||||
} from 'src/errors';
|
} from 'src/errors';
|
||||||
|
import { User } from 'src/user/user.model';
|
||||||
import { throwErr } from 'src/utils';
|
import { throwErr } from 'src/utils';
|
||||||
import { TeamService } from 'src/team/team.service';
|
import { TeamService } from 'src/team/team.service';
|
||||||
|
|
||||||
/**
|
|
||||||
* This guard only allows user to execute the resolver
|
|
||||||
* 1. If user is invitee, allow
|
|
||||||
* 2. Or else, if user is team member, allow
|
|
||||||
*
|
|
||||||
* TLDR: Allow if user is invitee or team member
|
|
||||||
*/
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class TeamInviteViewerGuard implements CanActivate {
|
export class TeamInviteViewerGuard implements CanActivate {
|
||||||
constructor(
|
constructor(
|
||||||
@@ -26,32 +23,50 @@ export class TeamInviteViewerGuard implements CanActivate {
|
|||||||
) {}
|
) {}
|
||||||
|
|
||||||
async canActivate(context: ExecutionContext): Promise<boolean> {
|
async canActivate(context: ExecutionContext): Promise<boolean> {
|
||||||
// Get GQL context
|
return pipe(
|
||||||
const gqlExecCtx = GqlExecutionContext.create(context);
|
TE.Do,
|
||||||
|
|
||||||
|
// Get GQL Context
|
||||||
|
TE.bindW('gqlCtx', () => TE.of(GqlExecutionContext.create(context))),
|
||||||
|
|
||||||
// Get user
|
// Get user
|
||||||
const { user } = gqlExecCtx.getContext().req;
|
TE.bindW('user', ({ gqlCtx }) =>
|
||||||
if (!user) throwErr(BUG_AUTH_NO_USER_CTX);
|
pipe(
|
||||||
|
O.fromNullable(gqlCtx.getContext<{ user?: User }>().user),
|
||||||
|
TE.fromOption(() => BUG_AUTH_NO_USER_CTX),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
// Get the invite
|
// Get the invite
|
||||||
const { inviteID } = gqlExecCtx.getArgs<{ inviteID: string }>();
|
TE.bindW('invite', ({ gqlCtx }) =>
|
||||||
if (!inviteID) throwErr(BUG_TEAM_INVITE_NO_INVITE_ID);
|
pipe(
|
||||||
|
O.fromNullable(gqlCtx.getArgs<{ inviteID?: string }>().inviteID),
|
||||||
|
TE.fromOption(() => BUG_TEAM_INVITE_NO_INVITE_ID),
|
||||||
|
TE.chainW(
|
||||||
|
flow(
|
||||||
|
this.teamInviteService.getInvitation,
|
||||||
|
TE.fromTaskOption(() => TEAM_INVITE_NO_INVITE_FOUND),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
const invitation = await this.teamInviteService.getInvitation(inviteID);
|
// Check if the user and the invite email match, else if we can resolver the user as a team member
|
||||||
if (O.isNone(invitation)) throwErr(TEAM_INVITE_NO_INVITE_FOUND);
|
// any better solution ?
|
||||||
|
TE.chainW(({ user, invite }) =>
|
||||||
|
user.email?.toLowerCase() === invite.inviteeEmail.toLowerCase()
|
||||||
|
? TE.of(true)
|
||||||
|
: pipe(
|
||||||
|
this.teamService.getTeamMemberTE(invite.teamID, user.uid),
|
||||||
|
TE.map(() => true),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
// Check if the user and the invite email match, else if user is a team member
|
TE.mapLeft((e) =>
|
||||||
if (
|
e === 'team/member_not_found' ? TEAM_INVITE_NOT_VALID_VIEWER : e,
|
||||||
user.email?.toLowerCase() !== invitation.value.inviteeEmail.toLowerCase()
|
),
|
||||||
) {
|
|
||||||
const teamMember = await this.teamService.getTeamMember(
|
|
||||||
invitation.value.teamID,
|
|
||||||
user.uid,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!teamMember) throwErr(TEAM_MEMBER_NOT_FOUND);
|
TE.fold(throwErr, () => T.of(true)),
|
||||||
}
|
)();
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,11 @@
|
|||||||
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
||||||
import { TeamInvitationService } from './team-invitation.service';
|
import { TeamInvitationService } from './team-invitation.service';
|
||||||
|
import { pipe, flow } from 'fp-ts/function';
|
||||||
import * as O from 'fp-ts/Option';
|
import * as O from 'fp-ts/Option';
|
||||||
|
import * as T from 'fp-ts/Task';
|
||||||
|
import * as TE from 'fp-ts/TaskEither';
|
||||||
import { GqlExecutionContext } from '@nestjs/graphql';
|
import { GqlExecutionContext } from '@nestjs/graphql';
|
||||||
|
import { User } from 'src/user/user.model';
|
||||||
import {
|
import {
|
||||||
BUG_AUTH_NO_USER_CTX,
|
BUG_AUTH_NO_USER_CTX,
|
||||||
BUG_TEAM_INVITE_NO_INVITE_ID,
|
BUG_TEAM_INVITE_NO_INVITE_ID,
|
||||||
@@ -20,26 +24,44 @@ export class TeamInviteeGuard implements CanActivate {
|
|||||||
constructor(private readonly teamInviteService: TeamInvitationService) {}
|
constructor(private readonly teamInviteService: TeamInvitationService) {}
|
||||||
|
|
||||||
async canActivate(context: ExecutionContext): Promise<boolean> {
|
async canActivate(context: ExecutionContext): Promise<boolean> {
|
||||||
// Get GQL Context
|
return pipe(
|
||||||
const gqlExecCtx = GqlExecutionContext.create(context);
|
TE.Do,
|
||||||
|
|
||||||
|
// Get execution context
|
||||||
|
TE.bindW('gqlCtx', () => TE.of(GqlExecutionContext.create(context))),
|
||||||
|
|
||||||
// Get user
|
// Get user
|
||||||
const { user } = gqlExecCtx.getContext().req;
|
TE.bindW('user', ({ gqlCtx }) =>
|
||||||
if (!user) throwErr(BUG_AUTH_NO_USER_CTX);
|
pipe(
|
||||||
|
O.fromNullable(gqlCtx.getContext<{ user?: User }>().user),
|
||||||
|
TE.fromOption(() => BUG_AUTH_NO_USER_CTX),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
// Get the invite
|
// Get invite
|
||||||
const { inviteID } = gqlExecCtx.getArgs<{ inviteID: string }>();
|
TE.bindW('invite', ({ gqlCtx }) =>
|
||||||
if (!inviteID) throwErr(BUG_TEAM_INVITE_NO_INVITE_ID);
|
pipe(
|
||||||
|
O.fromNullable(gqlCtx.getArgs<{ inviteID?: string }>().inviteID),
|
||||||
|
TE.fromOption(() => BUG_TEAM_INVITE_NO_INVITE_ID),
|
||||||
|
TE.chainW(
|
||||||
|
flow(
|
||||||
|
this.teamInviteService.getInvitation,
|
||||||
|
TE.fromTaskOption(() => TEAM_INVITE_NO_INVITE_FOUND),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
const invitation = await this.teamInviteService.getInvitation(inviteID);
|
// Check if the emails match
|
||||||
if (O.isNone(invitation)) throwErr(TEAM_INVITE_NO_INVITE_FOUND);
|
TE.chainW(
|
||||||
|
TE.fromPredicate(
|
||||||
|
({ user, invite }) => user.email === invite.inviteeEmail,
|
||||||
|
() => TEAM_INVITE_EMAIL_DO_NOT_MATCH,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
if (
|
// Fold it to a promise
|
||||||
user.email.toLowerCase() !== invitation.value.inviteeEmail.toLowerCase()
|
TE.fold(throwErr, () => T.of(true)),
|
||||||
) {
|
)();
|
||||||
throwErr(TEAM_INVITE_EMAIL_DO_NOT_MATCH);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,6 +12,6 @@ export class TeamTeamInviteExtResolver {
|
|||||||
complexity: 10,
|
complexity: 10,
|
||||||
})
|
})
|
||||||
teamInvitations(@Parent() team: Team): Promise<TeamInvitation[]> {
|
teamInvitations(@Parent() team: Team): Promise<TeamInvitation[]> {
|
||||||
return this.teamInviteService.getTeamInvitations(team.id);
|
return this.teamInviteService.getAllInvitationsInTeam(team)();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ import { HttpStatus } from '@nestjs/common';
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
** Custom interface to handle errors specific to Auth module
|
** Custom interface to handle errors specific to Auth module
|
||||||
** Since its REST we need to return the HTTP status code along with the error message
|
** Since its REST we need to return HTTP status code along with error message
|
||||||
*/
|
*/
|
||||||
export type AuthError = {
|
export type AuthError = {
|
||||||
message: string;
|
message: string;
|
||||||
|
|||||||
@@ -24,8 +24,6 @@ beforeEach(() => {
|
|||||||
mockPubSub.publish.mockClear();
|
mockPubSub.publish.mockClear();
|
||||||
});
|
});
|
||||||
|
|
||||||
const date = new Date();
|
|
||||||
|
|
||||||
describe('UserHistoryService', () => {
|
describe('UserHistoryService', () => {
|
||||||
describe('fetchUserHistory', () => {
|
describe('fetchUserHistory', () => {
|
||||||
test('Should return a list of users REST history if exists', async () => {
|
test('Should return a list of users REST history if exists', async () => {
|
||||||
@@ -402,7 +400,7 @@ describe('UserHistoryService', () => {
|
|||||||
request: [{}],
|
request: [{}],
|
||||||
responseMetadata: [{}],
|
responseMetadata: [{}],
|
||||||
reqType: ReqType.REST,
|
reqType: ReqType.REST,
|
||||||
executedOn: date,
|
executedOn: new Date(),
|
||||||
isStarred: false,
|
isStarred: false,
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -412,7 +410,7 @@ describe('UserHistoryService', () => {
|
|||||||
request: JSON.stringify([{}]),
|
request: JSON.stringify([{}]),
|
||||||
responseMetadata: JSON.stringify([{}]),
|
responseMetadata: JSON.stringify([{}]),
|
||||||
reqType: ReqType.REST,
|
reqType: ReqType.REST,
|
||||||
executedOn: date,
|
executedOn: new Date(),
|
||||||
isStarred: false,
|
isStarred: false,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -9,13 +9,7 @@ import * as E from 'fp-ts/Either';
|
|||||||
import * as A from 'fp-ts/Array';
|
import * as A from 'fp-ts/Array';
|
||||||
import { TeamMemberRole } from './team/team.model';
|
import { TeamMemberRole } from './team/team.model';
|
||||||
import { User } from './user/user.model';
|
import { User } from './user/user.model';
|
||||||
import {
|
import { JSON_INVALID } from './errors';
|
||||||
ENV_EMPTY_AUTH_PROVIDERS,
|
|
||||||
ENV_NOT_FOUND_KEY_AUTH_PROVIDERS,
|
|
||||||
ENV_NOT_SUPPORT_AUTH_PROVIDERS,
|
|
||||||
JSON_INVALID,
|
|
||||||
} from './errors';
|
|
||||||
import { AuthProvider } from './auth/helper';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A workaround to throw an exception in an expression.
|
* A workaround to throw an exception in an expression.
|
||||||
@@ -158,31 +152,3 @@ export function isValidLength(title: string, length: number) {
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* This function is called by bootstrap() in main.ts
|
|
||||||
* It checks if the "VITE_ALLOWED_AUTH_PROVIDERS" environment variable is properly set or not.
|
|
||||||
* If not, it throws an error.
|
|
||||||
*/
|
|
||||||
export function checkEnvironmentAuthProvider() {
|
|
||||||
if (!process.env.hasOwnProperty('VITE_ALLOWED_AUTH_PROVIDERS')) {
|
|
||||||
throw new Error(ENV_NOT_FOUND_KEY_AUTH_PROVIDERS);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (process.env.VITE_ALLOWED_AUTH_PROVIDERS === '') {
|
|
||||||
throw new Error(ENV_EMPTY_AUTH_PROVIDERS);
|
|
||||||
}
|
|
||||||
|
|
||||||
const givenAuthProviders = process.env.VITE_ALLOWED_AUTH_PROVIDERS.split(
|
|
||||||
',',
|
|
||||||
).map((provider) => provider.toLocaleUpperCase());
|
|
||||||
const supportedAuthProviders = Object.values(AuthProvider).map(
|
|
||||||
(provider: string) => provider.toLocaleUpperCase(),
|
|
||||||
);
|
|
||||||
|
|
||||||
for (const givenAuthProvider of givenAuthProviders) {
|
|
||||||
if (!supportedAuthProviders.includes(givenAuthProvider)) {
|
|
||||||
throw new Error(ENV_NOT_SUPPORT_AUTH_PROVIDERS);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
128
packages/hoppscotch-cli/CODE_OF_CONDUCT.md
Normal file
128
packages/hoppscotch-cli/CODE_OF_CONDUCT.md
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
# Contributor Covenant Code of Conduct
|
||||||
|
|
||||||
|
## Our Pledge
|
||||||
|
|
||||||
|
We as members, contributors, and leaders pledge to make participation in our
|
||||||
|
community a harassment-free experience for everyone, regardless of age, body
|
||||||
|
size, visible or invisible disability, ethnicity, sex characteristics, gender
|
||||||
|
identity and expression, level of experience, education, socio-economic status,
|
||||||
|
nationality, personal appearance, race, religion, or sexual identity
|
||||||
|
and orientation.
|
||||||
|
|
||||||
|
We pledge to act and interact in ways that contribute to an open, welcoming,
|
||||||
|
diverse, inclusive, and healthy community.
|
||||||
|
|
||||||
|
## Our Standards
|
||||||
|
|
||||||
|
Examples of behavior that contributes to a positive environment for our
|
||||||
|
community include:
|
||||||
|
|
||||||
|
- Demonstrating empathy and kindness toward other people
|
||||||
|
- Being respectful of differing opinions, viewpoints, and experiences
|
||||||
|
- Giving and gracefully accepting constructive feedback
|
||||||
|
- Accepting responsibility and apologizing to those affected by our mistakes,
|
||||||
|
and learning from the experience
|
||||||
|
- Focusing on what is best not just for us as individuals, but for the
|
||||||
|
overall community
|
||||||
|
|
||||||
|
Examples of unacceptable behavior include:
|
||||||
|
|
||||||
|
- The use of sexualized language or imagery, and sexual attention or
|
||||||
|
advances of any kind
|
||||||
|
- Trolling, insulting or derogatory comments, and personal or political attacks
|
||||||
|
- Public or private harassment
|
||||||
|
- Publishing others' private information, such as a physical or email
|
||||||
|
address, without their explicit permission
|
||||||
|
- Other conduct which could reasonably be considered inappropriate in a
|
||||||
|
professional setting
|
||||||
|
|
||||||
|
## Enforcement Responsibilities
|
||||||
|
|
||||||
|
Community leaders are responsible for clarifying and enforcing our standards of
|
||||||
|
acceptable behavior and will take appropriate and fair corrective action in
|
||||||
|
response to any behavior that they deem inappropriate, threatening, offensive,
|
||||||
|
or harmful.
|
||||||
|
|
||||||
|
Community leaders have the right and responsibility to remove, edit, or reject
|
||||||
|
comments, commits, code, wiki edits, issues, and other contributions that are
|
||||||
|
not aligned to this Code of Conduct, and will communicate reasons for moderation
|
||||||
|
decisions when appropriate.
|
||||||
|
|
||||||
|
## Scope
|
||||||
|
|
||||||
|
This Code of Conduct applies within all community spaces, and also applies when
|
||||||
|
an individual is officially representing the community in public spaces.
|
||||||
|
Examples of representing our community include using an official e-mail address,
|
||||||
|
posting via an official social media account, or acting as an appointed
|
||||||
|
representative at an online or offline event.
|
||||||
|
|
||||||
|
## Enforcement
|
||||||
|
|
||||||
|
Instances of abusive, harassing, or otherwise unacceptable behavior may be
|
||||||
|
reported to the community leaders responsible for enforcement at
|
||||||
|
support@hoppscotch.io.
|
||||||
|
All complaints will be reviewed and investigated promptly and fairly.
|
||||||
|
|
||||||
|
All community leaders are obligated to respect the privacy and security of the
|
||||||
|
reporter of any incident.
|
||||||
|
|
||||||
|
## Enforcement Guidelines
|
||||||
|
|
||||||
|
Community leaders will follow these Community Impact Guidelines in determining
|
||||||
|
the consequences for any action they deem in violation of this Code of Conduct:
|
||||||
|
|
||||||
|
### 1. Correction
|
||||||
|
|
||||||
|
**Community Impact**: Use of inappropriate language or other behavior deemed
|
||||||
|
unprofessional or unwelcome in the community.
|
||||||
|
|
||||||
|
**Consequence**: A private, written warning from community leaders, providing
|
||||||
|
clarity around the nature of the violation and an explanation of why the
|
||||||
|
behavior was inappropriate. A public apology may be requested.
|
||||||
|
|
||||||
|
### 2. Warning
|
||||||
|
|
||||||
|
**Community Impact**: A violation through a single incident or series
|
||||||
|
of actions.
|
||||||
|
|
||||||
|
**Consequence**: A warning with consequences for continued behavior. No
|
||||||
|
interaction with the people involved, including unsolicited interaction with
|
||||||
|
those enforcing the Code of Conduct, for a specified period of time. This
|
||||||
|
includes avoiding interactions in community spaces as well as external channels
|
||||||
|
like social media. Violating these terms may lead to a temporary or
|
||||||
|
permanent ban.
|
||||||
|
|
||||||
|
### 3. Temporary Ban
|
||||||
|
|
||||||
|
**Community Impact**: A serious violation of community standards, including
|
||||||
|
sustained inappropriate behavior.
|
||||||
|
|
||||||
|
**Consequence**: A temporary ban from any sort of interaction or public
|
||||||
|
communication with the community for a specified period of time. No public or
|
||||||
|
private interaction with the people involved, including unsolicited interaction
|
||||||
|
with those enforcing the Code of Conduct, is allowed during this period.
|
||||||
|
Violating these terms may lead to a permanent ban.
|
||||||
|
|
||||||
|
### 4. Permanent Ban
|
||||||
|
|
||||||
|
**Community Impact**: Demonstrating a pattern of violation of community
|
||||||
|
standards, including sustained inappropriate behavior, harassment of an
|
||||||
|
individual, or aggression toward or disparagement of classes of individuals.
|
||||||
|
|
||||||
|
**Consequence**: A permanent ban from any sort of public interaction within
|
||||||
|
the community.
|
||||||
|
|
||||||
|
## Attribution
|
||||||
|
|
||||||
|
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
|
||||||
|
version 2.0, available at
|
||||||
|
https://www.contributor-covenant.org/version/2/0/code_of_conduct.html.
|
||||||
|
|
||||||
|
Community Impact Guidelines were inspired by [Mozilla's code of conduct
|
||||||
|
enforcement ladder](https://github.com/mozilla/diversity).
|
||||||
|
|
||||||
|
[homepage]: https://www.contributor-covenant.org
|
||||||
|
|
||||||
|
For answers to common questions about this code of conduct, see the FAQ at
|
||||||
|
https://www.contributor-covenant.org/faq. Translations are available at
|
||||||
|
https://www.contributor-covenant.org/translations.
|
||||||
21
packages/hoppscotch-cli/LICENSE
Normal file
21
packages/hoppscotch-cli/LICENSE
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
MIT License
|
||||||
|
|
||||||
|
Copyright (c) 2022
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
@@ -1,19 +1,29 @@
|
|||||||
|
<div align="center">
|
||||||
|
<a href="https://hoppscotch.io">
|
||||||
|
<img
|
||||||
|
src="https://avatars.githubusercontent.com/u/56705483"
|
||||||
|
alt="Hoppscotch Logo"
|
||||||
|
height="64"
|
||||||
|
/>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div align="center">
|
||||||
|
|
||||||
# Hoppscotch CLI <font size=2><sup>ALPHA</sup></font>
|
# Hoppscotch CLI <font size=2><sup>ALPHA</sup></font>
|
||||||
|
|
||||||
A CLI to run Hoppscotch Test Scripts in CI environments.
|
</div>
|
||||||
|
|
||||||
|
A CLI to run Hoppscotch test scripts in CI environments.
|
||||||
|
|
||||||
### **Commands:**
|
### **Commands:**
|
||||||
|
|
||||||
- `hopp test [options] [file]`: testing hoppscotch collection.json file
|
- `hopp test [options] [file]`: testing hoppscotch collection.json file
|
||||||
|
|
||||||
### **Usage:**
|
### **Usage:**
|
||||||
|
```
|
||||||
```bash
|
|
||||||
hopp [options or commands] arguments
|
hopp [options or commands] arguments
|
||||||
```
|
```
|
||||||
|
|
||||||
### **Options:**
|
### **Options:**
|
||||||
|
|
||||||
- `-v`, `--ver`: see the current version of the CLI
|
- `-v`, `--ver`: see the current version of the CLI
|
||||||
- `-h`, `--help`: display help for command
|
- `-h`, `--help`: display help for command
|
||||||
|
|
||||||
@@ -35,18 +45,14 @@ hopp [options or commands] arguments
|
|||||||
- Executes and outputs test-script response.
|
- Executes and outputs test-script response.
|
||||||
|
|
||||||
#### Options:
|
#### Options:
|
||||||
|
|
||||||
##### `-e <file_path>` / `--env <file_path>`
|
##### `-e <file_path>` / `--env <file_path>`
|
||||||
|
|
||||||
- Accepts path to env.json with contents in below format:
|
- Accepts path to env.json with contents in below format:
|
||||||
|
|
||||||
```json
|
```json
|
||||||
{
|
{
|
||||||
"ENV1":"value1",
|
"ENV1":"value1",
|
||||||
"ENV2":"value2"
|
"ENV2":"value2"
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
- You can now access those variables using `pw.env.get('<var_name>')`
|
- You can now access those variables using `pw.env.get('<var_name>')`
|
||||||
|
|
||||||
Taking the above example, `pw.env.get("ENV1")` will return `"value1"`
|
Taking the above example, `pw.env.get("ENV1")` will return `"value1"`
|
||||||
@@ -69,59 +75,4 @@ npm i -g @hoppscotch/cli
|
|||||||
|
|
||||||
## **Contributing:**
|
## **Contributing:**
|
||||||
|
|
||||||
When contributing to this repository, please first discuss the change you wish to make via issue,
|
To get started contributing to the repository, please read **[CONTRIBUTING.md](./CONTRIBUTING.md)**
|
||||||
email, or any other method with the owners of this repository before making a change.
|
|
||||||
|
|
||||||
Please note we have a code of conduct, please follow it in all your interactions with the project.
|
|
||||||
|
|
||||||
## Pull Request Process
|
|
||||||
|
|
||||||
1. Ensure any install or build dependencies are removed before the end of the layer when doing a
|
|
||||||
build.
|
|
||||||
2. Update the README.md with details of changes to the interface, this includes new environment
|
|
||||||
variables, exposed ports, useful file locations and container parameters.
|
|
||||||
3. Increase the version numbers in any examples files and the README.md to the new version that this
|
|
||||||
Pull Request would represent. The versioning scheme we use is [SemVer](https://semver.org).
|
|
||||||
4. You may merge the Pull Request once you have the sign-off of two other developers, or if you
|
|
||||||
do not have permission to do that, you may request the second reviewer merge it for you.
|
|
||||||
|
|
||||||
## Set Up The Development Environment
|
|
||||||
|
|
||||||
1. After cloning the repository, execute the following commands:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
pnpm install
|
|
||||||
pnpm run build
|
|
||||||
```
|
|
||||||
|
|
||||||
2. In order to test locally, you can use two types of package linking:
|
|
||||||
|
|
||||||
1. The 'pnpm exec' way (preferred since it does not hamper your original installation of the CLI):
|
|
||||||
|
|
||||||
```bash
|
|
||||||
pnpm link @hoppscotch/cli
|
|
||||||
|
|
||||||
// Then to use or test the CLI:
|
|
||||||
pnpm exec hopp
|
|
||||||
|
|
||||||
// After testing, to remove the package linking:
|
|
||||||
pnpm rm @hoppscotch/cli
|
|
||||||
```
|
|
||||||
|
|
||||||
2. The 'global' way (warning: this might override the globally installed CLI, if exists):
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo pnpm link --global
|
|
||||||
|
|
||||||
// Then to use or test the CLI:
|
|
||||||
hopp
|
|
||||||
|
|
||||||
// After testing, to remove the package linking:
|
|
||||||
sudo pnpm rm --global @hoppscotch/cli
|
|
||||||
```
|
|
||||||
|
|
||||||
3. To use the Typescript watch scripts:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
pnpm run dev
|
|
||||||
```
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@hoppscotch/cli",
|
"name": "@hoppscotch/cli",
|
||||||
"version": "0.3.2",
|
"version": "0.3.1",
|
||||||
"description": "A CLI to run Hoppscotch test scripts in CI environments.",
|
"description": "A CLI to run Hoppscotch test scripts in CI environments.",
|
||||||
"homepage": "https://hoppscotch.io",
|
"homepage": "https://hoppscotch.io",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
|
|||||||
@@ -42,7 +42,7 @@ export const handleError = <T extends HoppErrorCode>(error: HoppError<T>) => {
|
|||||||
|
|
||||||
switch (error.code) {
|
switch (error.code) {
|
||||||
case "FILE_NOT_FOUND":
|
case "FILE_NOT_FOUND":
|
||||||
ERROR_MSG = `File doesn't exist: ${error.path}`;
|
ERROR_MSG = `File doesn't exists: ${error.path}`;
|
||||||
break;
|
break;
|
||||||
case "UNKNOWN_COMMAND":
|
case "UNKNOWN_COMMAND":
|
||||||
ERROR_MSG = `Unavailable command: ${error.command}`;
|
ERROR_MSG = `Unavailable command: ${error.command}`;
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ module.exports = {
|
|||||||
env: {
|
env: {
|
||||||
browser: true,
|
browser: true,
|
||||||
node: true,
|
node: true,
|
||||||
|
jest: true,
|
||||||
},
|
},
|
||||||
parserOptions: {
|
parserOptions: {
|
||||||
sourceType: "module",
|
sourceType: "module",
|
||||||
@@ -29,18 +30,8 @@ module.exports = {
|
|||||||
"import/named": "off", // because, named import issue with typescript see: https://github.com/typescript-eslint/typescript-eslint/issues/154
|
"import/named": "off", // because, named import issue with typescript see: https://github.com/typescript-eslint/typescript-eslint/issues/154
|
||||||
"no-console": "off",
|
"no-console": "off",
|
||||||
"no-debugger": process.env.HOPP_LINT_FOR_PROD === "true" ? "error" : "warn",
|
"no-debugger": process.env.HOPP_LINT_FOR_PROD === "true" ? "error" : "warn",
|
||||||
"prettier/prettier": [
|
"prettier/prettier":
|
||||||
process.env.HOPP_LINT_FOR_PROD === "true" ? "error" : "warn",
|
process.env.HOPP_LINT_FOR_PROD === "true" ? "error" : "warn",
|
||||||
{},
|
|
||||||
{
|
|
||||||
semi: false,
|
|
||||||
trailingComma: "es5",
|
|
||||||
singleQuote: false,
|
|
||||||
printWidth: 80,
|
|
||||||
useTabs: false,
|
|
||||||
tabWidth: 2,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"vue/multi-word-component-names": "off",
|
"vue/multi-word-component-names": "off",
|
||||||
"vue/no-side-effects-in-computed-properties": "off",
|
"vue/no-side-effects-in-computed-properties": "off",
|
||||||
"import/no-named-as-default": "off",
|
"import/no-named-as-default": "off",
|
||||||
|
|||||||
@@ -1,8 +1,3 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
semi: false,
|
semi: false
|
||||||
trailingComma: "es5",
|
|
||||||
singleQuote: false,
|
|
||||||
printWidth: 80,
|
|
||||||
useTabs: false,
|
|
||||||
tabWidth: 2
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1 +0,0 @@
|
|||||||
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="currentColor" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-star"><polygon points="12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2"/></svg>
|
|
||||||
|
Before Width: | Height: | Size: 337 B |
@@ -4,7 +4,6 @@
|
|||||||
@apply after:backface-hidden;
|
@apply after:backface-hidden;
|
||||||
@apply selection:bg-accentDark;
|
@apply selection:bg-accentDark;
|
||||||
@apply selection:text-accentContrast;
|
@apply selection:text-accentContrast;
|
||||||
@apply overscroll-none;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
:root {
|
:root {
|
||||||
@@ -31,10 +30,6 @@
|
|||||||
@apply h-0;
|
@apply h-0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.no-scrollbar {
|
|
||||||
scrollbar-width: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
input::placeholder,
|
input::placeholder,
|
||||||
textarea::placeholder,
|
textarea::placeholder,
|
||||||
.cm-placeholder {
|
.cm-placeholder {
|
||||||
@@ -170,6 +165,12 @@ a {
|
|||||||
@apply truncate;
|
@apply truncate;
|
||||||
@apply sm:inline-flex;
|
@apply sm:inline-flex;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.env-icon {
|
||||||
|
@apply transition;
|
||||||
|
@apply inline-flex;
|
||||||
|
@apply items-center;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.tippy-svg-arrow {
|
.tippy-svg-arrow {
|
||||||
@@ -188,11 +189,10 @@ a {
|
|||||||
@apply border-solid border-dividerDark;
|
@apply border-solid border-dividerDark;
|
||||||
@apply rounded;
|
@apply rounded;
|
||||||
@apply shadow-lg;
|
@apply shadow-lg;
|
||||||
@apply max-w-[45vw] #{!important};
|
|
||||||
|
|
||||||
.tippy-content {
|
.tippy-content {
|
||||||
@apply flex flex-col;
|
@apply flex flex-col;
|
||||||
@apply max-h-[45vh];
|
@apply max-h-56;
|
||||||
@apply items-stretch;
|
@apply items-stretch;
|
||||||
@apply overflow-y-auto;
|
@apply overflow-y-auto;
|
||||||
@apply text-secondary text-body;
|
@apply text-secondary text-body;
|
||||||
@@ -200,10 +200,6 @@ a {
|
|||||||
@apply leading-normal;
|
@apply leading-normal;
|
||||||
@apply focus:outline-none;
|
@apply focus:outline-none;
|
||||||
scroll-behavior: smooth;
|
scroll-behavior: smooth;
|
||||||
|
|
||||||
& > span {
|
|
||||||
@apply block #{!important};
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.tippy-svg-arrow {
|
.tippy-svg-arrow {
|
||||||
@@ -219,7 +215,6 @@ a {
|
|||||||
|
|
||||||
[data-v-tippy] {
|
[data-v-tippy] {
|
||||||
@apply flex flex-1;
|
@apply flex flex-1;
|
||||||
@apply truncate;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[interactive] > div {
|
[interactive] > div {
|
||||||
@@ -330,7 +325,7 @@ pre.ace_editor {
|
|||||||
@apply after:font-icon;
|
@apply after:font-icon;
|
||||||
@apply after:text-current;
|
@apply after:text-current;
|
||||||
@apply after:right-3;
|
@apply after:right-3;
|
||||||
@apply after:content-["\e5cf"];
|
@apply after:content-["\e313"];
|
||||||
@apply after:text-lg;
|
@apply after:text-lg;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -485,10 +480,6 @@ pre.ace_editor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.cm-scroller {
|
|
||||||
@apply overscroll-y-auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.cm-editor {
|
.cm-editor {
|
||||||
.cm-line::selection {
|
.cm-line::selection {
|
||||||
@apply bg-accentDark #{!important};
|
@apply bg-accentDark #{!important};
|
||||||
@@ -501,22 +492,6 @@ pre.ace_editor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.cm-panel.cm-search [name="close"] {
|
|
||||||
@apply flex;
|
|
||||||
@apply items-center;
|
|
||||||
@apply justify-center;
|
|
||||||
@apply min-h-5;
|
|
||||||
@apply min-w-5;
|
|
||||||
@apply bg-primaryDark #{!important};
|
|
||||||
@apply sticky #{!important};
|
|
||||||
@apply right-0 #{!important};
|
|
||||||
@apply ml-auto #{!important};
|
|
||||||
@apply my-auto #{!important};
|
|
||||||
@apply rounded #{!important};
|
|
||||||
@apply outline #{!important};
|
|
||||||
@apply outline-divider #{!important};
|
|
||||||
}
|
|
||||||
|
|
||||||
.shortcut-key {
|
.shortcut-key {
|
||||||
@apply inline-flex;
|
@apply inline-flex;
|
||||||
@apply font-sans;
|
@apply font-sans;
|
||||||
@@ -592,11 +567,3 @@ details[open] summary .indicator {
|
|||||||
@apply rounded;
|
@apply rounded;
|
||||||
@apply border-0;
|
@apply border-0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.gql-operation-not-highlight {
|
|
||||||
@apply opacity-50;
|
|
||||||
}
|
|
||||||
|
|
||||||
.gql-operation-highlight {
|
|
||||||
@apply opacity-100;
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -1,23 +1,8 @@
|
|||||||
@mixin base-theme {
|
@mixin base-theme {
|
||||||
--font-sans: "Inter Variable", sans-serif;
|
--font-sans: "Inter", sans-serif;
|
||||||
--font-icon: "Material Symbols Rounded Variable";
|
--font-mono: "Roboto Mono", monospace;
|
||||||
--font-mono: "Roboto Mono Variable", monospace;
|
--font-icon: "Material Icons";
|
||||||
--font-size-body: 0.75rem;
|
--font-size-tiny: calc(var(--font-size-body) - 0.062rem);
|
||||||
--font-size-tiny: 0.688rem;
|
|
||||||
--line-height-body: 1rem;
|
|
||||||
--upper-primary-sticky-fold: 4.125rem;
|
|
||||||
--upper-secondary-sticky-fold: 6.188rem;
|
|
||||||
--upper-tertiary-sticky-fold: 8.25rem;
|
|
||||||
--upper-fourth-sticky-fold: 10.2rem;
|
|
||||||
--upper-mobile-primary-sticky-fold: 6.625rem;
|
|
||||||
--upper-mobile-secondary-sticky-fold: 8.688rem;
|
|
||||||
--upper-mobile-sticky-fold: 10.75rem;
|
|
||||||
--upper-mobile-tertiary-sticky-fold: 8.25rem;
|
|
||||||
--lower-primary-sticky-fold: 3rem;
|
|
||||||
--lower-secondary-sticky-fold: 5.063rem;
|
|
||||||
--lower-tertiary-sticky-fold: 7.125rem;
|
|
||||||
--lower-fourth-sticky-fold: 9.188rem;
|
|
||||||
--sidebar-primary-sticky-fold: 2rem;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@mixin dark-theme {
|
@mixin dark-theme {
|
||||||
@@ -215,8 +200,8 @@
|
|||||||
:root {
|
:root {
|
||||||
@include base-theme;
|
@include base-theme;
|
||||||
@include dark-theme;
|
@include dark-theme;
|
||||||
@include dark-editor-theme;
|
|
||||||
@include green-theme;
|
@include green-theme;
|
||||||
|
@include dark-editor-theme;
|
||||||
}
|
}
|
||||||
|
|
||||||
:root.light {
|
:root.light {
|
||||||
@@ -272,3 +257,63 @@
|
|||||||
:root[data-accent="yellow"] {
|
:root[data-accent="yellow"] {
|
||||||
@include yellow-theme;
|
@include yellow-theme;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@mixin font-small {
|
||||||
|
--font-size-body: 0.75rem;
|
||||||
|
--line-height-body: 1rem;
|
||||||
|
--upper-primary-sticky-fold: 4.125rem;
|
||||||
|
--upper-secondary-sticky-fold: 6.188rem;
|
||||||
|
--upper-tertiary-sticky-fold: 8.25rem;
|
||||||
|
--upper-mobile-primary-sticky-fold: 6.625rem;
|
||||||
|
--upper-mobile-secondary-sticky-fold: 8.688rem;
|
||||||
|
--upper-mobile-sticky-fold: 10.75rem;
|
||||||
|
--upper-mobile-tertiary-sticky-fold: 8.25rem;
|
||||||
|
--lower-primary-sticky-fold: 3rem;
|
||||||
|
--lower-secondary-sticky-fold: 5.063rem;
|
||||||
|
--lower-tertiary-sticky-fold: 7.125rem;
|
||||||
|
--sidebar-primary-sticky-fold: 2rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
@mixin font-medium {
|
||||||
|
--font-size-body: 0.875rem;
|
||||||
|
--line-height-body: 1.25rem;
|
||||||
|
--upper-primary-sticky-fold: 4.375rem;
|
||||||
|
--upper-secondary-sticky-fold: 6.688rem;
|
||||||
|
--upper-tertiary-sticky-fold: 9rem;
|
||||||
|
--upper-mobile-primary-sticky-fold: 7.125rem;
|
||||||
|
--upper-mobile-secondary-sticky-fold: 9.438rem;
|
||||||
|
--upper-mobile-sticky-fold: 11.75rem;
|
||||||
|
--upper-mobile-tertiary-sticky-fold: 9rem;
|
||||||
|
--lower-primary-sticky-fold: 3.25rem;
|
||||||
|
--lower-secondary-sticky-fold: 5.563rem;
|
||||||
|
--lower-tertiary-sticky-fold: 7.875rem;
|
||||||
|
--sidebar-primary-sticky-fold: 2.25rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
@mixin font-large {
|
||||||
|
--font-size-body: 1rem;
|
||||||
|
--line-height-body: 1.5rem;
|
||||||
|
--upper-primary-sticky-fold: 4.625rem;
|
||||||
|
--upper-secondary-sticky-fold: 7.188rem;
|
||||||
|
--upper-tertiary-sticky-fold: 9.75rem;
|
||||||
|
--upper-mobile-primary-sticky-fold: 7.625rem;
|
||||||
|
--upper-mobile-secondary-sticky-fold: 10.188rem;
|
||||||
|
--upper-mobile-sticky-fold: 12.75rem;
|
||||||
|
--upper-mobile-tertiary-sticky-fold: 9.75rem;
|
||||||
|
--lower-primary-sticky-fold: 3.5rem;
|
||||||
|
--lower-secondary-sticky-fold: 6.063rem;
|
||||||
|
--lower-tertiary-sticky-fold: 8.625rem;
|
||||||
|
--sidebar-primary-sticky-fold: 2.5rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
:root[data-font-size="small"] {
|
||||||
|
@include font-small;
|
||||||
|
}
|
||||||
|
|
||||||
|
:root[data-font-size="medium"] {
|
||||||
|
@include font-medium;
|
||||||
|
}
|
||||||
|
|
||||||
|
:root[data-font-size="large"] {
|
||||||
|
@include font-large;
|
||||||
|
}
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Kies 'n lêer",
|
"choose_file": "Kies 'n lêer",
|
||||||
"clear": "Duidelik",
|
"clear": "Duidelik",
|
||||||
"clear_all": "Maak alles skoon",
|
"clear_all": "Maak alles skoon",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Koppel",
|
"connect": "Koppel",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "Prettify",
|
"prettify": "Prettify",
|
||||||
"remove": "Verwyder",
|
"remove": "Verwyder",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Herstel",
|
"restore": "Herstel",
|
||||||
"save": "Stoor",
|
"save": "Stoor",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Soek",
|
"search": "Soek",
|
||||||
"share": "Deel",
|
"share": "Deel",
|
||||||
"shortcuts": "Kortpaaie",
|
"shortcuts": "Kortpaaie",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Kollig",
|
"spotlight": "Kollig",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Versameling hernoem",
|
"renamed": "Versameling hernoem",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Stoor as",
|
"save_as": "Stoor as",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Kies 'n versameling",
|
"select": "Kies 'n versameling",
|
||||||
"select_location": "Kies ligging",
|
"select_location": "Kies ligging",
|
||||||
"select_team": "Kies 'n span",
|
"select_team": "Kies 'n span",
|
||||||
"team_collections": "Spanversamelings"
|
"team_collections": "Spanversamelings"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Weet u seker dat u wil afmeld?",
|
"logout": "Weet u seker dat u wil afmeld?",
|
||||||
"remove_collection": "Weet u seker dat u hierdie versameling permanent wil uitvee?",
|
"remove_collection": "Weet u seker dat u hierdie versameling permanent wil uitvee?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Is u seker dat u hierdie werkruimte wil sinkroniseer?"
|
"sync": "Is u seker dat u hierdie werkruimte wil sinkroniseer?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Koptekst {count}",
|
"header": "Koptekst {count}",
|
||||||
"message": "Boodskap {count}",
|
"message": "Boodskap {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Skep nuwe omgewing",
|
"create_new": "Skep nuwe omgewing",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Bewerk omgewing",
|
"edit": "Bewerk omgewing",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Gee 'n geldige naam vir die omgewing",
|
"invalid_name": "Gee 'n geldige naam vir die omgewing",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "Nuwe omgewing",
|
"new": "Nuwe omgewing",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Geen omgewing nie",
|
"no_environment": "Geen omgewing nie",
|
||||||
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Kies omgewing",
|
"select": "Kies omgewing",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Omgewings",
|
"title": "Omgewings",
|
||||||
"updated": "Environment updation",
|
"updated": "Environment updation",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Veranderlike lys"
|
"variable_list": "Veranderlike lys"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Geen duur nie",
|
"no_duration": "Geen duur nie",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Kon nie voorafversoekskrip uitvoer nie",
|
"script_fail": "Kon nie voorafversoekskrip uitvoer nie",
|
||||||
"something_went_wrong": "Iets het verkeerd geloop",
|
"something_went_wrong": "Iets het verkeerd geloop",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Vouer hernoem"
|
"renamed": "Vouer hernoem"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutasies",
|
"mutations": "Mutasies",
|
||||||
"schema": "Skema",
|
"schema": "Skema",
|
||||||
"subscriptions": "Inskrywings",
|
"subscriptions": "Inskrywings"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
||||||
"title": "Invoer"
|
"title": "Invoer"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "Vertical layout",
|
"column": "Vertical layout",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Horizontal layout"
|
"row": "Horizontal layout",
|
||||||
|
"zen_mode": "Zen -modus"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Nuttingslading",
|
"payload": "Nuttingslading",
|
||||||
"query": "Navraag",
|
"query": "Navraag",
|
||||||
"raw_body": "Rou versoeksliggaam",
|
"raw_body": "Rou versoeksliggaam",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Versoek hernoem",
|
"renamed": "Versoek hernoem",
|
||||||
"run": "Hardloop",
|
"run": "Hardloop",
|
||||||
"save": "Stoor",
|
"save": "Stoor",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Versoek gestoor",
|
"saved": "Versoek gestoor",
|
||||||
"share": "Deel",
|
"share": "Deel",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Versoek",
|
"title": "Versoek",
|
||||||
"type": "Soort versoek",
|
"type": "Soort versoek",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Reaksie liggaam",
|
"body": "Reaksie liggaam",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Opskrifte",
|
"headers": "Opskrifte",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Status",
|
"status": "Status",
|
||||||
"time": "Tyd",
|
"time": "Tyd",
|
||||||
"title": "Reaksie",
|
"title": "Reaksie",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "wag vir verbinding",
|
"waiting_for_connection": "wag vir verbinding",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Dit is u vertoonnaam.",
|
"account_name_description": "Dit is u vertoonnaam.",
|
||||||
"background": "Agtergrond",
|
"background": "Agtergrond",
|
||||||
"black_mode": "Swart",
|
"black_mode": "Swart",
|
||||||
|
"change_font_size": "Verander lettergrootte",
|
||||||
"choose_language": "Kies taal",
|
"choose_language": "Kies taal",
|
||||||
"dark_mode": "Donker",
|
"dark_mode": "Donker",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Uitbreidings",
|
"extensions": "Uitbreidings",
|
||||||
"extensions_use_toggle": "Gebruik die blaaieruitbreiding om versoeke te stuur (indien teenwoordig)",
|
"extensions_use_toggle": "Gebruik die blaaieruitbreiding om versoeke te stuur (indien teenwoordig)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "Skrifgrootte",
|
||||||
|
"font_size_large": "Groot",
|
||||||
|
"font_size_medium": "Medium",
|
||||||
|
"font_size_small": "Klein",
|
||||||
"interceptor": "Onderskepper",
|
"interceptor": "Onderskepper",
|
||||||
"interceptor_description": "Middelware tussen toepassing en API's.",
|
"interceptor_description": "Middelware tussen toepassing en API's.",
|
||||||
"language": "Taal",
|
"language": "Taal",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Gaan na die instellingsbladsy",
|
"settings": "Gaan na die instellingsbladsy",
|
||||||
"title": "Navigasie"
|
"title": "Navigasie"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Kopieer versoekskakel",
|
"copy_request_link": "Kopieer versoekskakel",
|
||||||
"delete_method": "Kies DELETE metode",
|
"delete_method": "Kies DELETE metode",
|
||||||
"get_method": "Kies GET -metode",
|
"get_method": "Kies GET -metode",
|
||||||
"head_method": "Kies HOOF metode",
|
"head_method": "Kies HOOF metode",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Metode",
|
"method": "Metode",
|
||||||
"next_method": "Kies Volgende metode",
|
"next_method": "Kies Volgende metode",
|
||||||
"post_method": "Kies POST -metode",
|
"post_method": "Kies POST -metode",
|
||||||
"previous_method": "Kies Vorige metode",
|
"previous_method": "Kies Vorige metode",
|
||||||
"put_method": "Kies PUT -metode",
|
"put_method": "Kies PUT -metode",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Herstel versoek",
|
"reset_request": "Herstel versoek",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Stoor in versamelings",
|
"save_to_collections": "Stoor in versamelings",
|
||||||
"send_request": "Stuur versoek",
|
"send_request": "Stuur versoek",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Versoek"
|
"title": "Versoek"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Meld",
|
"log": "Meld",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Soort gebeurtenis",
|
"event_type": "Soort gebeurtenis",
|
||||||
"log": "Meld",
|
"log": "Meld",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Magtiging",
|
"authorization": "Magtiging",
|
||||||
"body": "Liggaam",
|
"body": "Liggaam",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Versamelings",
|
"collections": "Versamelings",
|
||||||
"documentation": "Dokumentasie",
|
"documentation": "Dokumentasie",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Opskrifte",
|
"headers": "Opskrifte",
|
||||||
"history": "Geskiedenis",
|
"history": "Geskiedenis",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "اختيار ملف",
|
"choose_file": "اختيار ملف",
|
||||||
"clear": "امسح",
|
"clear": "امسح",
|
||||||
"clear_all": "امسح الكل",
|
"clear_all": "امسح الكل",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "الاتصال",
|
"connect": "الاتصال",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "لصق",
|
"paste": "لصق",
|
||||||
"prettify": "جمال",
|
"prettify": "جمال",
|
||||||
"remove": "ازالة",
|
"remove": "ازالة",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "اعادة",
|
"restore": "اعادة",
|
||||||
"save": "حفظ",
|
"save": "حفظ",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "بحث",
|
"search": "بحث",
|
||||||
"share": "يشارك",
|
"share": "يشارك",
|
||||||
"shortcuts": "الاختصارات",
|
"shortcuts": "الاختصارات",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "أضواء كاشفة",
|
"spotlight": "أضواء كاشفة",
|
||||||
"status": "حالة",
|
"status": "حالة",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "تمت إعادة تسمية المجموعة",
|
"renamed": "تمت إعادة تسمية المجموعة",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "حفظ باسم",
|
"save_as": "حفظ باسم",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "حدد مجموعة",
|
"select": "حدد مجموعة",
|
||||||
"select_location": "اختر موقعا",
|
"select_location": "اختر موقعا",
|
||||||
"select_team": "اختر فريقًا",
|
"select_team": "اختر فريقًا",
|
||||||
"team_collections": "مجموعات الفريق"
|
"team_collections": "مجموعات الفريق"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "هل أنت متأكد أنك تريد مغادرة هذا الفريق؟",
|
"exit_team": "هل أنت متأكد أنك تريد مغادرة هذا الفريق؟",
|
||||||
"logout": "هل أنت متأكد أنك تريد تسجيل الخروج؟",
|
"logout": "هل أنت متأكد أنك تريد تسجيل الخروج؟",
|
||||||
"remove_collection": "هل أنت متأكد أنك تريد حذف هذه المجموعة نهائيًا؟",
|
"remove_collection": "هل أنت متأكد أنك تريد حذف هذه المجموعة نهائيًا؟",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "هل أنت متأكد أنك تريد مزامنة مساحة العمل هذه؟"
|
"sync": "هل أنت متأكد أنك تريد مزامنة مساحة العمل هذه؟"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "رأس {count}",
|
"header": "رأس {count}",
|
||||||
"message": "الرسالة {count}",
|
"message": "الرسالة {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "انشاء بيئة جديدة",
|
"create_new": "انشاء بيئة جديدة",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "حذف بيئة العمل",
|
"deleted": "حذف بيئة العمل",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "تحرير البيئة",
|
"edit": "تحرير البيئة",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "الرجاء تقديم اسم صالح للبيئة",
|
"invalid_name": "الرجاء تقديم اسم صالح للبيئة",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "بيئة جديدة",
|
"new": "بيئة جديدة",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "لا بيئة",
|
"no_environment": "لا بيئة",
|
||||||
"no_environment_description": "لم يتم اختيار أي بيئة عمل. اختر ما تريد فعله بالمتغيرات التالية.",
|
"no_environment_description": "لم يتم اختيار أي بيئة عمل. اختر ما تريد فعله بالمتغيرات التالية.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "حدد البيئة",
|
"select": "حدد البيئة",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "البيئات",
|
"title": "البيئات",
|
||||||
"updated": "تحديث بيئة العمل",
|
"updated": "تحديث بيئة العمل",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "قائمة متغيرة"
|
"variable_list": "قائمة متغيرة"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "لا مدة",
|
"no_duration": "لا مدة",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "تعذر تنفيذ نص الطلب المسبق",
|
"script_fail": "تعذر تنفيذ نص الطلب المسبق",
|
||||||
"something_went_wrong": "هناك خطأ ما",
|
"something_went_wrong": "هناك خطأ ما",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "تمت إعادة تسمية المجلد"
|
"renamed": "تمت إعادة تسمية المجلد"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "الطفرات",
|
"mutations": "الطفرات",
|
||||||
"schema": "مخطط",
|
"schema": "مخطط",
|
||||||
"subscriptions": "الاشتراكات",
|
"subscriptions": "الاشتراكات"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "استيراد مجموعة من ملفHoppscotch Collections JSON file",
|
"json_description": "استيراد مجموعة من ملفHoppscotch Collections JSON file",
|
||||||
"title": "يستورد"
|
"title": "يستورد"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "تصيم عمودي",
|
"column": "تصيم عمودي",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "تصميم افقي"
|
"row": "تصميم افقي",
|
||||||
|
"zen_mode": "وضع Zen"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "الحمولة",
|
"payload": "الحمولة",
|
||||||
"query": "استفسار",
|
"query": "استفسار",
|
||||||
"raw_body": "نص طلب خام",
|
"raw_body": "نص طلب خام",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "تمت إعادة تسمية الطلب",
|
"renamed": "تمت إعادة تسمية الطلب",
|
||||||
"run": "يركض",
|
"run": "يركض",
|
||||||
"save": "يحفظ",
|
"save": "يحفظ",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "تم حفظ الطلب",
|
"saved": "تم حفظ الطلب",
|
||||||
"share": "يشارك",
|
"share": "يشارك",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "طلب",
|
"title": "طلب",
|
||||||
"type": "نوع الطلب",
|
"type": "نوع الطلب",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "هيئة الاستجابة",
|
"body": "هيئة الاستجابة",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "الرؤوس",
|
"headers": "الرؤوس",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "حالة",
|
"status": "حالة",
|
||||||
"time": "وقت",
|
"time": "وقت",
|
||||||
"title": "إجابة",
|
"title": "إجابة",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "في انتظار الاتصال",
|
"waiting_for_connection": "في انتظار الاتصال",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "هذا هو اسم العرض الخاص بك.",
|
"account_name_description": "هذا هو اسم العرض الخاص بك.",
|
||||||
"background": "خلفية",
|
"background": "خلفية",
|
||||||
"black_mode": "أسود",
|
"black_mode": "أسود",
|
||||||
|
"change_font_size": "تغيير حجم الخط",
|
||||||
"choose_language": "اختر اللغة",
|
"choose_language": "اختر اللغة",
|
||||||
"dark_mode": "داكن",
|
"dark_mode": "داكن",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "ملحقات",
|
"extensions": "ملحقات",
|
||||||
"extensions_use_toggle": "استخدم امتداد المتصفح لإرسال الطلبات (إن وجدت)",
|
"extensions_use_toggle": "استخدم امتداد المتصفح لإرسال الطلبات (إن وجدت)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "حجم الخط",
|
||||||
|
"font_size_large": "كبير",
|
||||||
|
"font_size_medium": "متوسط",
|
||||||
|
"font_size_small": "صغير",
|
||||||
"interceptor": "المعترض",
|
"interceptor": "المعترض",
|
||||||
"interceptor_description": "البرامج الوسيطة بين التطبيق وواجهات برمجة التطبيقات.",
|
"interceptor_description": "البرامج الوسيطة بين التطبيق وواجهات برمجة التطبيقات.",
|
||||||
"language": "لغة",
|
"language": "لغة",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "انتقل إلى صفحة الإعدادات",
|
"settings": "انتقل إلى صفحة الإعدادات",
|
||||||
"title": "التنقل"
|
"title": "التنقل"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "نسخ ارتباط الطلب",
|
"copy_request_link": "نسخ ارتباط الطلب",
|
||||||
"delete_method": "حدد طريقة الحذف",
|
"delete_method": "حدد طريقة الحذف",
|
||||||
"get_method": "حدد طريقة GET",
|
"get_method": "حدد طريقة GET",
|
||||||
"head_method": "حدد طريقة HEAD",
|
"head_method": "حدد طريقة HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "طريقة",
|
"method": "طريقة",
|
||||||
"next_method": "حدد الطريقة التالية",
|
"next_method": "حدد الطريقة التالية",
|
||||||
"post_method": "حدد طريقة POST",
|
"post_method": "حدد طريقة POST",
|
||||||
"previous_method": "حدد الطريقة السابقة",
|
"previous_method": "حدد الطريقة السابقة",
|
||||||
"put_method": "حدد طريقة PUT",
|
"put_method": "حدد طريقة PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "طلب إعادة التعيين",
|
"reset_request": "طلب إعادة التعيين",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "حفظ في المجموعات",
|
"save_to_collections": "حفظ في المجموعات",
|
||||||
"send_request": "ارسل طلب",
|
"send_request": "ارسل طلب",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "طلب"
|
"title": "طلب"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "سجل",
|
"log": "سجل",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "نوع الحدث",
|
"event_type": "نوع الحدث",
|
||||||
"log": "سجل",
|
"log": "سجل",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "تفويض",
|
"authorization": "تفويض",
|
||||||
"body": "الجسم",
|
"body": "الجسم",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "المجموعات",
|
"collections": "المجموعات",
|
||||||
"documentation": "توثيق",
|
"documentation": "توثيق",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "الرؤوس",
|
"headers": "الرؤوس",
|
||||||
"history": "تاريخ",
|
"history": "تاريخ",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Triar un fitxer",
|
"choose_file": "Triar un fitxer",
|
||||||
"clear": "Netejar",
|
"clear": "Netejar",
|
||||||
"clear_all": "Neteja-ho tot",
|
"clear_all": "Neteja-ho tot",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Connectar",
|
"connect": "Connectar",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Enganxar",
|
"paste": "Enganxar",
|
||||||
"prettify": "Fes-ho bonic",
|
"prettify": "Fes-ho bonic",
|
||||||
"remove": "Eliminar",
|
"remove": "Eliminar",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Restaurar",
|
"restore": "Restaurar",
|
||||||
"save": "Guardar",
|
"save": "Guardar",
|
||||||
"scroll_to_bottom": "Desplaceu-vos cap avall",
|
"scroll_to_bottom": "Desplaceu-vos cap avall",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Cercar",
|
"search": "Cercar",
|
||||||
"share": "Compartir",
|
"share": "Compartir",
|
||||||
"shortcuts": "Dreceres",
|
"shortcuts": "Dreceres",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Destacar",
|
"spotlight": "Destacar",
|
||||||
"status": "Estat",
|
"status": "Estat",
|
||||||
"status_description": "Comproveu l'estat de la web",
|
"status_description": "Comproveu l'estat de la web",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "S'ha canviat el nom de la col·lecció",
|
"renamed": "S'ha canviat el nom de la col·lecció",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Guardar com",
|
"save_as": "Guardar com",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Seleccionar una col·lecció",
|
"select": "Seleccionar una col·lecció",
|
||||||
"select_location": "Seleccionar la ubicació",
|
"select_location": "Seleccionar la ubicació",
|
||||||
"select_team": "Seleccionar un equip",
|
"select_team": "Seleccionar un equip",
|
||||||
"team_collections": "Col·leccions per equips"
|
"team_collections": "Col·leccions per equips"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Està segur que vol deixar aquest equip?",
|
"exit_team": "Està segur que vol deixar aquest equip?",
|
||||||
"logout": "Està segur que vol tancar la sessió?",
|
"logout": "Està segur que vol tancar la sessió?",
|
||||||
"remove_collection": "Està segur que vol suprimir permanentment aquesta col·lecció?",
|
"remove_collection": "Està segur que vol suprimir permanentment aquesta col·lecció?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Està segur que vol sincronitzar aquest espai de treball?"
|
"sync": "Està segur que vol sincronitzar aquest espai de treball?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Capçalera {count}",
|
"header": "Capçalera {count}",
|
||||||
"message": "Missatges {count}",
|
"message": "Missatges {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Crea un entorn nou",
|
"create_new": "Crea un entorn nou",
|
||||||
"created": "Etorn creat",
|
"created": "Etorn creat",
|
||||||
"deleted": "Entorn eliminat",
|
"deleted": "Entorn eliminat",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Editar l'entorn",
|
"edit": "Editar l'entorn",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Proporcioneu un nom vàlid per a l'entorn",
|
"invalid_name": "Proporcioneu un nom vàlid per a l'entorn",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "Les variables d'entorn niuades estan limitades a 10 nivells",
|
"nested_overflow": "Les variables d'entorn niuades estan limitades a 10 nivells",
|
||||||
"new": "Nou entorn",
|
"new": "Nou entorn",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Sense entorn",
|
"no_environment": "Sense entorn",
|
||||||
"no_environment_description": "No s'ha seleccionat cap entorn. Trieu què voleu fer amb les variables següents.",
|
"no_environment_description": "No s'ha seleccionat cap entorn. Trieu què voleu fer amb les variables següents.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Seleccioneu un entorn",
|
"select": "Seleccioneu un entorn",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Entorns",
|
"title": "Entorns",
|
||||||
"updated": "Entorn actualitzat",
|
"updated": "Entorn actualitzat",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Llista de variables"
|
"variable_list": "Llista de variables"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Sense durada",
|
"no_duration": "Sense durada",
|
||||||
"no_results_found": "No s'ha trobat cap coincidència",
|
"no_results_found": "No s'ha trobat cap coincidència",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "No s'ha pogut executar l'script de sol·licitud prèvia",
|
"script_fail": "No s'ha pogut executar l'script de sol·licitud prèvia",
|
||||||
"something_went_wrong": "Alguna cosa ha anat malament",
|
"something_went_wrong": "Alguna cosa ha anat malament",
|
||||||
"test_script_fail": "No s'ha pogut executar l'script posterior a la sol·licitud"
|
"test_script_fail": "No s'ha pogut executar l'script posterior a la sol·licitud"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "S'ha canviat el nom de la carpeta"
|
"renamed": "S'ha canviat el nom de la carpeta"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutacions",
|
"mutations": "Mutacions",
|
||||||
"schema": "Esquema",
|
"schema": "Esquema",
|
||||||
"subscriptions": "Subscripcions",
|
"subscriptions": "Subscripcions"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Importar col·leccions des d'un fitxer JSON de col·leccions Hoppscotch",
|
"json_description": "Importar col·leccions des d'un fitxer JSON de col·leccions Hoppscotch",
|
||||||
"title": "Importació"
|
"title": "Importació"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Amagar o Ampliar Col·leccions",
|
"collapse_collection": "Amagar o Ampliar Col·leccions",
|
||||||
"collapse_sidebar": "Amagar o Ampliar la barra lateral",
|
"collapse_sidebar": "Amagar o Ampliar la barra lateral",
|
||||||
"column": "Distribució vertical",
|
"column": "Distribució vertical",
|
||||||
"name": "Distribució",
|
"name": "Distribució",
|
||||||
"row": "Distribució horitzontal"
|
"row": "Distribució horitzontal",
|
||||||
|
"zen_mode": "Mode Zen"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Payload",
|
"payload": "Payload",
|
||||||
"query": "Consulta",
|
"query": "Consulta",
|
||||||
"raw_body": "Cos de sol·licitud sense processar",
|
"raw_body": "Cos de sol·licitud sense processar",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "S'ha canviat el nom de la sol·licitud",
|
"renamed": "S'ha canviat el nom de la sol·licitud",
|
||||||
"run": "Executar",
|
"run": "Executar",
|
||||||
"save": "Guardar",
|
"save": "Guardar",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "S'ha desat la sol·licitud",
|
"saved": "S'ha desat la sol·licitud",
|
||||||
"share": "Compartir",
|
"share": "Compartir",
|
||||||
"share_description": "Comparteix Hoppscotch amb els teus amics",
|
"share_description": "Comparteix Hoppscotch amb els teus amics",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Sol·licitud",
|
"title": "Sol·licitud",
|
||||||
"type": "Tipus de sol·licitud",
|
"type": "Tipus de sol·licitud",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "Visualitzar els meus enllaços"
|
"view_my_links": "Visualitzar els meus enllaços"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Cos de resposta",
|
"body": "Cos de resposta",
|
||||||
"filter_response_body": "Filtrar el cos de la resposta JSON (utilitza la sintaxi JSONPath)",
|
"filter_response_body": "Filtrar el cos de la resposta JSON (utilitza la sintaxi JSONPath)",
|
||||||
"headers": "Capçaleres",
|
"headers": "Capçaleres",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Estat",
|
"status": "Estat",
|
||||||
"time": "Temps",
|
"time": "Temps",
|
||||||
"title": "Resposta",
|
"title": "Resposta",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "esperant la connexió",
|
"waiting_for_connection": "esperant la connexió",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Aquest és el vostre nom d'exposició",
|
"account_name_description": "Aquest és el vostre nom d'exposició",
|
||||||
"background": "Fons",
|
"background": "Fons",
|
||||||
"black_mode": "Negre",
|
"black_mode": "Negre",
|
||||||
|
"change_font_size": "Canvia la mida de la lletra",
|
||||||
"choose_language": "Tria l'idioma",
|
"choose_language": "Tria l'idioma",
|
||||||
"dark_mode": "Fosc",
|
"dark_mode": "Fosc",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Extensions",
|
"extensions": "Extensions",
|
||||||
"extensions_use_toggle": "Utilitzeu l'extensió del navegador per enviar sol·licituds (si n'hi ha)",
|
"extensions_use_toggle": "Utilitzeu l'extensió del navegador per enviar sol·licituds (si n'hi ha)",
|
||||||
"follow": "Segueix-nos",
|
"follow": "Segueix-nos",
|
||||||
|
"font_size": "Mida de la font",
|
||||||
|
"font_size_large": "Gran",
|
||||||
|
"font_size_medium": "Mitjà",
|
||||||
|
"font_size_small": "Petit",
|
||||||
"interceptor": "Interceptor",
|
"interceptor": "Interceptor",
|
||||||
"interceptor_description": "Middleware entre aplicació i APIs.",
|
"interceptor_description": "Middleware entre aplicació i APIs.",
|
||||||
"language": "Llenguatge",
|
"language": "Llenguatge",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Anar a la pàgina de Configuració",
|
"settings": "Anar a la pàgina de Configuració",
|
||||||
"title": "Navegació"
|
"title": "Navegació"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Copiar l'enllaç de la sol·licitud",
|
"copy_request_link": "Copiar l'enllaç de la sol·licitud",
|
||||||
"delete_method": "Seleccionar el mètode DELETE",
|
"delete_method": "Seleccionar el mètode DELETE",
|
||||||
"get_method": "Seleccionar el mètode GET",
|
"get_method": "Seleccionar el mètode GET",
|
||||||
"head_method": "Seleccionar el mètode HEAD",
|
"head_method": "Seleccionar el mètode HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Mètode",
|
"method": "Mètode",
|
||||||
"next_method": "Seleccionar mètode Següent",
|
"next_method": "Seleccionar mètode Següent",
|
||||||
"post_method": "Seleccionar mètode POST",
|
"post_method": "Seleccionar mètode POST",
|
||||||
"previous_method": "Seleccionar mètode Anterior",
|
"previous_method": "Seleccionar mètode Anterior",
|
||||||
"put_method": "Seleccionar mètode PUT",
|
"put_method": "Seleccionar mètode PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Sol·licitud de restabliment",
|
"reset_request": "Sol·licitud de restabliment",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Guardar a les col·leccions",
|
"save_to_collections": "Guardar a les col·leccions",
|
||||||
"send_request": "Enviar sol.licitud",
|
"send_request": "Enviar sol.licitud",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Sol·licitud"
|
"title": "Sol·licitud"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Registre",
|
"log": "Registre",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Tipus d'esdeveniment",
|
"event_type": "Tipus d'esdeveniment",
|
||||||
"log": "Registre",
|
"log": "Registre",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Autorització",
|
"authorization": "Autorització",
|
||||||
"body": "Cos",
|
"body": "Cos",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Col·leccions",
|
"collections": "Col·leccions",
|
||||||
"documentation": "Documentació",
|
"documentation": "Documentació",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Capçaleres",
|
"headers": "Capçaleres",
|
||||||
"history": "Historial",
|
"history": "Historial",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "选择文件",
|
"choose_file": "选择文件",
|
||||||
"clear": "清除",
|
"clear": "清除",
|
||||||
"clear_all": "全部清除",
|
"clear_all": "全部清除",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "关闭",
|
"close": "关闭",
|
||||||
"connect": "连接",
|
"connect": "连接",
|
||||||
"connecting": "连接中",
|
"connecting": "连接中",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "粘贴",
|
"paste": "粘贴",
|
||||||
"prettify": "美化",
|
"prettify": "美化",
|
||||||
"remove": "移除",
|
"remove": "移除",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "恢复",
|
"restore": "恢复",
|
||||||
"save": "保存",
|
"save": "保存",
|
||||||
"scroll_to_bottom": "滚动至底部",
|
"scroll_to_bottom": "滚动至底部",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "搜索",
|
"search": "搜索",
|
||||||
"share": "分享",
|
"share": "分享",
|
||||||
"shortcuts": "快捷方式",
|
"shortcuts": "快捷方式",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "聚光灯",
|
"spotlight": "聚光灯",
|
||||||
"status": "状态",
|
"status": "状态",
|
||||||
"status_description": "检查网站状态",
|
"status_description": "检查网站状态",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "集合已更名",
|
"renamed": "集合已更名",
|
||||||
"request_in_use": "请求正在使用中",
|
"request_in_use": "请求正在使用中",
|
||||||
"save_as": "另存为",
|
"save_as": "另存为",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "选择一个集合",
|
"select": "选择一个集合",
|
||||||
"select_location": "选择位置",
|
"select_location": "选择位置",
|
||||||
"select_team": "选择一个团队",
|
"select_team": "选择一个团队",
|
||||||
"team_collections": "团队集合"
|
"team_collections": "团队集合"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "你确定要离开此团队吗?",
|
"exit_team": "你确定要离开此团队吗?",
|
||||||
"logout": "你确定要登出吗?",
|
"logout": "你确定要登出吗?",
|
||||||
"remove_collection": "你确定要永久删除该集合吗?",
|
"remove_collection": "你确定要永久删除该集合吗?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "你想保存在此标签页中所作的修改吗?",
|
"save_unsaved_tab": "你想保存在此标签页中所作的修改吗?",
|
||||||
"sync": "您确定要同步该工作区吗?"
|
"sync": "您确定要同步该工作区吗?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "请求头 {count}",
|
"header": "请求头 {count}",
|
||||||
"message": "消息 {count}",
|
"message": "消息 {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "创建新环境",
|
"create_new": "创建新环境",
|
||||||
"created": "环境已创建",
|
"created": "环境已创建",
|
||||||
"deleted": "环境已删除",
|
"deleted": "环境已删除",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "编辑环境",
|
"edit": "编辑环境",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "请提供有效的环境名称",
|
"invalid_name": "请提供有效的环境名称",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "我的环境",
|
"my_environments": "我的环境",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "环境嵌套深度超过限制(10层)",
|
"nested_overflow": "环境嵌套深度超过限制(10层)",
|
||||||
"new": "新建环境",
|
"new": "新建环境",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "无环境",
|
"no_environment": "无环境",
|
||||||
"no_environment_description": "没有选择环境。选择如何处理以下变量。",
|
"no_environment_description": "没有选择环境。选择如何处理以下变量。",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "选择环境",
|
"select": "选择环境",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "团队环境",
|
"team_environments": "团队环境",
|
||||||
"title": "环境",
|
"title": "环境",
|
||||||
"updated": "环境已更新",
|
"updated": "环境已更新",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "变量列表"
|
"variable_list": "变量列表"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "无持续时间",
|
"no_duration": "无持续时间",
|
||||||
"no_results_found": "找不到结果",
|
"no_results_found": "找不到结果",
|
||||||
"page_not_found": "找不到此頁面",
|
"page_not_found": "找不到此頁面",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "无法执行预请求脚本",
|
"script_fail": "无法执行预请求脚本",
|
||||||
"something_went_wrong": "发生了一些错误",
|
"something_went_wrong": "发生了一些错误",
|
||||||
"test_script_fail": "无法执行请求脚本"
|
"test_script_fail": "无法执行请求脚本"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "文件夹已更名"
|
"renamed": "文件夹已更名"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "变更",
|
"mutations": "变更",
|
||||||
"schema": "模式",
|
"schema": "模式",
|
||||||
"subscriptions": "订阅",
|
"subscriptions": "订阅"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "时间",
|
"time": "时间",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "从 Hoppscotch 的集合文件导入(JSON)",
|
"json_description": "从 Hoppscotch 的集合文件导入(JSON)",
|
||||||
"title": "导入"
|
"title": "导入"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "折叠/展开集合",
|
"collapse_collection": "折叠/展开集合",
|
||||||
"collapse_sidebar": "折叠/展开边栏",
|
"collapse_sidebar": "折叠/展开边栏",
|
||||||
"column": "垂直布局",
|
"column": "垂直布局",
|
||||||
"name": "布局",
|
"name": "布局",
|
||||||
"row": "水平布局"
|
"row": "水平布局",
|
||||||
|
"zen_mode": "ZEN 模式"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "有未保存的变更",
|
"close_unsaved_tab": "有未保存的变更",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "负载",
|
"payload": "负载",
|
||||||
"query": "查询",
|
"query": "查询",
|
||||||
"raw_body": "原始请求体",
|
"raw_body": "原始请求体",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "请求重命名",
|
"renamed": "请求重命名",
|
||||||
"run": "运行",
|
"run": "运行",
|
||||||
"save": "保存",
|
"save": "保存",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "请求已保存",
|
"saved": "请求已保存",
|
||||||
"share": "分享",
|
"share": "分享",
|
||||||
"share_description": "分享 Hoppscotch 给你的朋友",
|
"share_description": "分享 Hoppscotch 给你的朋友",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "请求",
|
"title": "请求",
|
||||||
"type": "请求类型",
|
"type": "请求类型",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "查看我的链接"
|
"view_my_links": "查看我的链接"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "响应体",
|
"body": "响应体",
|
||||||
"filter_response_body": "筛选JSON响应本体(使用JSONPath语法)",
|
"filter_response_body": "筛选JSON响应本体(使用JSONPath语法)",
|
||||||
"headers": "响应头",
|
"headers": "响应头",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "状态",
|
"status": "状态",
|
||||||
"time": "时间",
|
"time": "时间",
|
||||||
"title": "响应",
|
"title": "响应",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "等待连接",
|
"waiting_for_connection": "等待连接",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "这是您的显示名称。",
|
"account_name_description": "这是您的显示名称。",
|
||||||
"background": "背景",
|
"background": "背景",
|
||||||
"black_mode": "黑色",
|
"black_mode": "黑色",
|
||||||
|
"change_font_size": "更改字体大小",
|
||||||
"choose_language": "选择语言",
|
"choose_language": "选择语言",
|
||||||
"dark_mode": "暗色",
|
"dark_mode": "暗色",
|
||||||
"delete_account": "刪除账号",
|
"delete_account": "刪除账号",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "扩展",
|
"extensions": "扩展",
|
||||||
"extensions_use_toggle": "使用浏览器扩展发送请求(如果存在)",
|
"extensions_use_toggle": "使用浏览器扩展发送请求(如果存在)",
|
||||||
"follow": "关注我们",
|
"follow": "关注我们",
|
||||||
|
"font_size": "字体大小",
|
||||||
|
"font_size_large": "大",
|
||||||
|
"font_size_medium": "中",
|
||||||
|
"font_size_small": "小",
|
||||||
"interceptor": "拦截器",
|
"interceptor": "拦截器",
|
||||||
"interceptor_description": "应用程序和 API 之间的中间件。",
|
"interceptor_description": "应用程序和 API 之间的中间件。",
|
||||||
"language": "语言",
|
"language": "语言",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "前往设置页面",
|
"settings": "前往设置页面",
|
||||||
"title": "导航"
|
"title": "导航"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "复制请求链接",
|
"copy_request_link": "复制请求链接",
|
||||||
"delete_method": "选择 DELETE 方法",
|
"delete_method": "选择 DELETE 方法",
|
||||||
"get_method": "选择 GET 方法",
|
"get_method": "选择 GET 方法",
|
||||||
"head_method": "选择 HEAD 方法",
|
"head_method": "选择 HEAD 方法",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "方法",
|
"method": "方法",
|
||||||
"next_method": "选择下一个方法",
|
"next_method": "选择下一个方法",
|
||||||
"post_method": "选择 POST 方法",
|
"post_method": "选择 POST 方法",
|
||||||
"previous_method": "选择上一个方法",
|
"previous_method": "选择上一个方法",
|
||||||
"put_method": "选择 PUT 方法",
|
"put_method": "选择 PUT 方法",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "重置请求",
|
"reset_request": "重置请求",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "保存到集合",
|
"save_to_collections": "保存到集合",
|
||||||
"send_request": "发送请求",
|
"send_request": "发送请求",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "请求"
|
"title": "请求"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "日志",
|
"log": "日志",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "事件类型",
|
"event_type": "事件类型",
|
||||||
"log": "日志",
|
"log": "日志",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "授权",
|
"authorization": "授权",
|
||||||
"body": "请求体",
|
"body": "请求体",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "集合",
|
"collections": "集合",
|
||||||
"documentation": "帮助文档",
|
"documentation": "帮助文档",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "环境",
|
"environments": "环境",
|
||||||
"headers": "请求头",
|
"headers": "请求头",
|
||||||
"history": "历史记录",
|
"history": "历史记录",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Vyberte soubor",
|
"choose_file": "Vyberte soubor",
|
||||||
"clear": "Průhledná",
|
"clear": "Průhledná",
|
||||||
"clear_all": "Vymazat vše",
|
"clear_all": "Vymazat vše",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Připojit",
|
"connect": "Připojit",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "Prettify",
|
"prettify": "Prettify",
|
||||||
"remove": "Odstranit",
|
"remove": "Odstranit",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Obnovit",
|
"restore": "Obnovit",
|
||||||
"save": "Uložit",
|
"save": "Uložit",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Vyhledávání",
|
"search": "Vyhledávání",
|
||||||
"share": "Podíl",
|
"share": "Podíl",
|
||||||
"shortcuts": "Klávesové zkratky",
|
"shortcuts": "Klávesové zkratky",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Reflektor",
|
"spotlight": "Reflektor",
|
||||||
"status": "Postavení",
|
"status": "Postavení",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Sbírka přejmenována",
|
"renamed": "Sbírka přejmenována",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Uložit jako",
|
"save_as": "Uložit jako",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Vyberte sbírku",
|
"select": "Vyberte sbírku",
|
||||||
"select_location": "Vyberte umístění",
|
"select_location": "Vyberte umístění",
|
||||||
"select_team": "Vyberte tým",
|
"select_team": "Vyberte tým",
|
||||||
"team_collections": "Týmové sbírky"
|
"team_collections": "Týmové sbírky"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Opravdu se chcete odhlásit?",
|
"logout": "Opravdu se chcete odhlásit?",
|
||||||
"remove_collection": "Opravdu chcete tuto sbírku trvale smazat?",
|
"remove_collection": "Opravdu chcete tuto sbírku trvale smazat?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Opravdu chcete synchronizovat tento pracovní prostor?"
|
"sync": "Opravdu chcete synchronizovat tento pracovní prostor?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Záhlaví {count}",
|
"header": "Záhlaví {count}",
|
||||||
"message": "Zpráva {count}",
|
"message": "Zpráva {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Vytvořit nové prostředí",
|
"create_new": "Vytvořit nové prostředí",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Upravit prostředí",
|
"edit": "Upravit prostředí",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Zadejte platný název prostředí",
|
"invalid_name": "Zadejte platný název prostředí",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "Nové prostředí",
|
"new": "Nové prostředí",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Žádné prostředí",
|
"no_environment": "Žádné prostředí",
|
||||||
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Vyberte prostředí",
|
"select": "Vyberte prostředí",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Prostředí",
|
"title": "Prostředí",
|
||||||
"updated": "Environment updation",
|
"updated": "Environment updation",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Seznam proměnných"
|
"variable_list": "Seznam proměnných"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Žádné trvání",
|
"no_duration": "Žádné trvání",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Skript předběžného požadavku nelze spustit",
|
"script_fail": "Skript předběžného požadavku nelze spustit",
|
||||||
"something_went_wrong": "Něco se pokazilo",
|
"something_went_wrong": "Něco se pokazilo",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Složka přejmenována"
|
"renamed": "Složka přejmenována"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutace",
|
"mutations": "Mutace",
|
||||||
"schema": "Schéma",
|
"schema": "Schéma",
|
||||||
"subscriptions": "Předplatné",
|
"subscriptions": "Předplatné"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
||||||
"title": "Import"
|
"title": "Import"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "Vertical layout",
|
"column": "Vertical layout",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Horizontal layout"
|
"row": "Horizontal layout",
|
||||||
|
"zen_mode": "Zenový režim"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Užitečné zatížení",
|
"payload": "Užitečné zatížení",
|
||||||
"query": "Dotaz",
|
"query": "Dotaz",
|
||||||
"raw_body": "Raw Request Body",
|
"raw_body": "Raw Request Body",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Žádost přejmenována",
|
"renamed": "Žádost přejmenována",
|
||||||
"run": "Běh",
|
"run": "Běh",
|
||||||
"save": "Uložit",
|
"save": "Uložit",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Žádost uložena",
|
"saved": "Žádost uložena",
|
||||||
"share": "Podíl",
|
"share": "Podíl",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Žádost",
|
"title": "Žádost",
|
||||||
"type": "Typ požadavku",
|
"type": "Typ požadavku",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Odpovědní orgán",
|
"body": "Odpovědní orgán",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Záhlaví",
|
"headers": "Záhlaví",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Postavení",
|
"status": "Postavení",
|
||||||
"time": "Čas",
|
"time": "Čas",
|
||||||
"title": "Odezva",
|
"title": "Odezva",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "čekání na připojení",
|
"waiting_for_connection": "čekání na připojení",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Toto je vaše zobrazované jméno.",
|
"account_name_description": "Toto je vaše zobrazované jméno.",
|
||||||
"background": "Pozadí",
|
"background": "Pozadí",
|
||||||
"black_mode": "Černá",
|
"black_mode": "Černá",
|
||||||
|
"change_font_size": "Změnit velikost písma",
|
||||||
"choose_language": "Vyber jazyk",
|
"choose_language": "Vyber jazyk",
|
||||||
"dark_mode": "Temný",
|
"dark_mode": "Temný",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Rozšíření",
|
"extensions": "Rozšíření",
|
||||||
"extensions_use_toggle": "K odeslání požadavků použijte rozšíření prohlížeče (je -li k dispozici)",
|
"extensions_use_toggle": "K odeslání požadavků použijte rozšíření prohlížeče (je -li k dispozici)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "Velikost písma",
|
||||||
|
"font_size_large": "Velký",
|
||||||
|
"font_size_medium": "Střední",
|
||||||
|
"font_size_small": "Malý",
|
||||||
"interceptor": "Interceptor",
|
"interceptor": "Interceptor",
|
||||||
"interceptor_description": "Middleware mezi aplikací a API.",
|
"interceptor_description": "Middleware mezi aplikací a API.",
|
||||||
"language": "Jazyk",
|
"language": "Jazyk",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Přejděte na stránku Nastavení",
|
"settings": "Přejděte na stránku Nastavení",
|
||||||
"title": "Navigace"
|
"title": "Navigace"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Kopírovat požadavek na odkaz",
|
"copy_request_link": "Kopírovat požadavek na odkaz",
|
||||||
"delete_method": "Vyberte metodu ODSTRANIT",
|
"delete_method": "Vyberte metodu ODSTRANIT",
|
||||||
"get_method": "Vyberte metodu ZÍSKAT",
|
"get_method": "Vyberte metodu ZÍSKAT",
|
||||||
"head_method": "Vyberte metodu HEAD",
|
"head_method": "Vyberte metodu HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Metoda",
|
"method": "Metoda",
|
||||||
"next_method": "Vyberte Další metoda",
|
"next_method": "Vyberte Další metoda",
|
||||||
"post_method": "Vyberte metodu POST",
|
"post_method": "Vyberte metodu POST",
|
||||||
"previous_method": "Vyberte předchozí metodu",
|
"previous_method": "Vyberte předchozí metodu",
|
||||||
"put_method": "Vyberte metodu PUT",
|
"put_method": "Vyberte metodu PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Resetovat požadavek",
|
"reset_request": "Resetovat požadavek",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Uložit do sbírek",
|
"save_to_collections": "Uložit do sbírek",
|
||||||
"send_request": "Poslat žádost",
|
"send_request": "Poslat žádost",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Žádost"
|
"title": "Žádost"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Záznam",
|
"log": "Záznam",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Typ události",
|
"event_type": "Typ události",
|
||||||
"log": "Záznam",
|
"log": "Záznam",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Povolení",
|
"authorization": "Povolení",
|
||||||
"body": "Tělo",
|
"body": "Tělo",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Sbírky",
|
"collections": "Sbírky",
|
||||||
"documentation": "Dokumentace",
|
"documentation": "Dokumentace",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Záhlaví",
|
"headers": "Záhlaví",
|
||||||
"history": "Dějiny",
|
"history": "Dějiny",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Vælg en fil",
|
"choose_file": "Vælg en fil",
|
||||||
"clear": "Klar",
|
"clear": "Klar",
|
||||||
"clear_all": "Slet alt",
|
"clear_all": "Slet alt",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Opret forbindelse",
|
"connect": "Opret forbindelse",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "Prettify",
|
"prettify": "Prettify",
|
||||||
"remove": "Fjerne",
|
"remove": "Fjerne",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Gendan",
|
"restore": "Gendan",
|
||||||
"save": "Gemme",
|
"save": "Gemme",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Søg",
|
"search": "Søg",
|
||||||
"share": "Del",
|
"share": "Del",
|
||||||
"shortcuts": "Genveje",
|
"shortcuts": "Genveje",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Spotlight",
|
"spotlight": "Spotlight",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Samling omdøbt",
|
"renamed": "Samling omdøbt",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Gem som",
|
"save_as": "Gem som",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Vælg en samling",
|
"select": "Vælg en samling",
|
||||||
"select_location": "Vælg placering",
|
"select_location": "Vælg placering",
|
||||||
"select_team": "Vælg et hold",
|
"select_team": "Vælg et hold",
|
||||||
"team_collections": "Teamsamlinger"
|
"team_collections": "Teamsamlinger"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Er du sikker på, at du vil logge af?",
|
"logout": "Er du sikker på, at du vil logge af?",
|
||||||
"remove_collection": "Er du sikker på, at du vil slette denne samling permanent?",
|
"remove_collection": "Er du sikker på, at du vil slette denne samling permanent?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Er du sikker på, at du vil synkronisere dette arbejdsområde?"
|
"sync": "Er du sikker på, at du vil synkronisere dette arbejdsområde?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Overskrift {count}",
|
"header": "Overskrift {count}",
|
||||||
"message": "Besked {count}",
|
"message": "Besked {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Skab nyt miljø",
|
"create_new": "Skab nyt miljø",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Rediger miljø",
|
"edit": "Rediger miljø",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Angiv et gyldigt navn på miljøet",
|
"invalid_name": "Angiv et gyldigt navn på miljøet",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "Nyt miljø",
|
"new": "Nyt miljø",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Intet miljø",
|
"no_environment": "Intet miljø",
|
||||||
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Vælg miljø",
|
"select": "Vælg miljø",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Miljøer",
|
"title": "Miljøer",
|
||||||
"updated": "Environment updation",
|
"updated": "Environment updation",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Variabel liste"
|
"variable_list": "Variabel liste"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Ingen varighed",
|
"no_duration": "Ingen varighed",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Kunne ikke udføre pre-request script",
|
"script_fail": "Kunne ikke udføre pre-request script",
|
||||||
"something_went_wrong": "Noget gik galt",
|
"something_went_wrong": "Noget gik galt",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Mappen omdøbt"
|
"renamed": "Mappen omdøbt"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutationer",
|
"mutations": "Mutationer",
|
||||||
"schema": "Skema",
|
"schema": "Skema",
|
||||||
"subscriptions": "Abonnementer",
|
"subscriptions": "Abonnementer"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
||||||
"title": "Importere"
|
"title": "Importere"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "Vertical layout",
|
"column": "Vertical layout",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Horizontal layout"
|
"row": "Horizontal layout",
|
||||||
|
"zen_mode": "Zen -tilstand"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Nyttelast",
|
"payload": "Nyttelast",
|
||||||
"query": "Forespørgsel",
|
"query": "Forespørgsel",
|
||||||
"raw_body": "Raw Request Body",
|
"raw_body": "Raw Request Body",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Anmodning omdøbt",
|
"renamed": "Anmodning omdøbt",
|
||||||
"run": "Løb",
|
"run": "Løb",
|
||||||
"save": "Gemme",
|
"save": "Gemme",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Anmodning gemt",
|
"saved": "Anmodning gemt",
|
||||||
"share": "Del",
|
"share": "Del",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Anmodning",
|
"title": "Anmodning",
|
||||||
"type": "Anmodningstype",
|
"type": "Anmodningstype",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Svarorgan",
|
"body": "Svarorgan",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Overskrifter",
|
"headers": "Overskrifter",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Status",
|
"status": "Status",
|
||||||
"time": "Tid",
|
"time": "Tid",
|
||||||
"title": "Respons",
|
"title": "Respons",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "venter på forbindelse",
|
"waiting_for_connection": "venter på forbindelse",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Dette er dit visningsnavn.",
|
"account_name_description": "Dette er dit visningsnavn.",
|
||||||
"background": "Baggrund",
|
"background": "Baggrund",
|
||||||
"black_mode": "Sort",
|
"black_mode": "Sort",
|
||||||
|
"change_font_size": "Skift skriftstørrelse",
|
||||||
"choose_language": "Vælg sprog",
|
"choose_language": "Vælg sprog",
|
||||||
"dark_mode": "Mørk",
|
"dark_mode": "Mørk",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Udvidelser",
|
"extensions": "Udvidelser",
|
||||||
"extensions_use_toggle": "Brug browserudvidelsen til at sende anmodninger (hvis de findes)",
|
"extensions_use_toggle": "Brug browserudvidelsen til at sende anmodninger (hvis de findes)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "Skriftstørrelse",
|
||||||
|
"font_size_large": "Stor",
|
||||||
|
"font_size_medium": "Medium",
|
||||||
|
"font_size_small": "Lille",
|
||||||
"interceptor": "Aflytter",
|
"interceptor": "Aflytter",
|
||||||
"interceptor_description": "Middleware mellem applikation og API'er.",
|
"interceptor_description": "Middleware mellem applikation og API'er.",
|
||||||
"language": "Sprog",
|
"language": "Sprog",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Gå til siden Indstillinger",
|
"settings": "Gå til siden Indstillinger",
|
||||||
"title": "Navigation"
|
"title": "Navigation"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Kopiér anmodningslink",
|
"copy_request_link": "Kopiér anmodningslink",
|
||||||
"delete_method": "Vælg SLET metode",
|
"delete_method": "Vælg SLET metode",
|
||||||
"get_method": "Vælg GET -metode",
|
"get_method": "Vælg GET -metode",
|
||||||
"head_method": "Vælg HEAD -metode",
|
"head_method": "Vælg HEAD -metode",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Metode",
|
"method": "Metode",
|
||||||
"next_method": "Vælg Næste metode",
|
"next_method": "Vælg Næste metode",
|
||||||
"post_method": "Vælg POST -metode",
|
"post_method": "Vælg POST -metode",
|
||||||
"previous_method": "Vælg Forrige metode",
|
"previous_method": "Vælg Forrige metode",
|
||||||
"put_method": "Vælg PUT -metode",
|
"put_method": "Vælg PUT -metode",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Nulstil anmodning",
|
"reset_request": "Nulstil anmodning",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Gem i samlinger",
|
"save_to_collections": "Gem i samlinger",
|
||||||
"send_request": "Send anmodning",
|
"send_request": "Send anmodning",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Anmodning"
|
"title": "Anmodning"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Log",
|
"log": "Log",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Begivenhedstype",
|
"event_type": "Begivenhedstype",
|
||||||
"log": "Log",
|
"log": "Log",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Bemyndigelse",
|
"authorization": "Bemyndigelse",
|
||||||
"body": "Legeme",
|
"body": "Legeme",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Samlinger",
|
"collections": "Samlinger",
|
||||||
"documentation": "Dokumentation",
|
"documentation": "Dokumentation",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Overskrifter",
|
"headers": "Overskrifter",
|
||||||
"history": "Historie",
|
"history": "Historie",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Datei auswählen",
|
"choose_file": "Datei auswählen",
|
||||||
"clear": "Zurücksetzen",
|
"clear": "Zurücksetzen",
|
||||||
"clear_all": "Alles zurücksetzen",
|
"clear_all": "Alles zurücksetzen",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Verbinden",
|
"connect": "Verbinden",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Einfügen",
|
"paste": "Einfügen",
|
||||||
"prettify": "Verschönern",
|
"prettify": "Verschönern",
|
||||||
"remove": "Entfernen",
|
"remove": "Entfernen",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Wiederherstellen",
|
"restore": "Wiederherstellen",
|
||||||
"save": "Speichern",
|
"save": "Speichern",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Suche",
|
"search": "Suche",
|
||||||
"share": "Teilen",
|
"share": "Teilen",
|
||||||
"shortcuts": "Verknüpfungen",
|
"shortcuts": "Verknüpfungen",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Scheinwerfer",
|
"spotlight": "Scheinwerfer",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"status_description": "Überprüfe den Status der Webseite",
|
"status_description": "Überprüfe den Status der Webseite",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Sammlung umbenannt",
|
"renamed": "Sammlung umbenannt",
|
||||||
"request_in_use": "Anfrage wird ausgeführt",
|
"request_in_use": "Anfrage wird ausgeführt",
|
||||||
"save_as": "Speichern als",
|
"save_as": "Speichern als",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Wähle eine Sammlung",
|
"select": "Wähle eine Sammlung",
|
||||||
"select_location": "Ort auswählen",
|
"select_location": "Ort auswählen",
|
||||||
"select_team": "Wähle ein Team",
|
"select_team": "Wähle ein Team",
|
||||||
"team_collections": "Teamsammlungen"
|
"team_collections": "Teamsammlungen"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Möchtest Du dieses Team wirklich verlassen?",
|
"exit_team": "Möchtest Du dieses Team wirklich verlassen?",
|
||||||
"logout": "Möchtest Du Dich wirklich abmelden?",
|
"logout": "Möchtest Du Dich wirklich abmelden?",
|
||||||
"remove_collection": "Möchtest Du diese Sammlung wirklich endgültig löschen?",
|
"remove_collection": "Möchtest Du diese Sammlung wirklich endgültig löschen?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Möchtest Du diesen Arbeitsbereich wirklich synchronisieren?"
|
"sync": "Möchtest Du diesen Arbeitsbereich wirklich synchronisieren?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Header {count}",
|
"header": "Header {count}",
|
||||||
"message": "Nachricht {count}",
|
"message": "Nachricht {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Neue Umgebung erstellen",
|
"create_new": "Neue Umgebung erstellen",
|
||||||
"created": "Umgebung erzeugt",
|
"created": "Umgebung erzeugt",
|
||||||
"deleted": "Umgebung löschen",
|
"deleted": "Umgebung löschen",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Umgebung bearbeiten",
|
"edit": "Umgebung bearbeiten",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Bitte gib einen gültigen Namen für die Umgebung an",
|
"invalid_name": "Bitte gib einen gültigen Namen für die Umgebung an",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "Verschachtelte Umgebungsvariablen sind limitert auf 10 Unterebenen",
|
"nested_overflow": "Verschachtelte Umgebungsvariablen sind limitert auf 10 Unterebenen",
|
||||||
"new": "Neue Umgebung",
|
"new": "Neue Umgebung",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Keine Umgebung",
|
"no_environment": "Keine Umgebung",
|
||||||
"no_environment_description": "Es wurden keine Umgebungen ausgewählt. Wähle aus, was mit den untenstehenden Variablen geschehen soll.",
|
"no_environment_description": "Es wurden keine Umgebungen ausgewählt. Wähle aus, was mit den untenstehenden Variablen geschehen soll.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Umgebung auswählen",
|
"select": "Umgebung auswählen",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Umgebungen",
|
"title": "Umgebungen",
|
||||||
"updated": "Umgebung aktualisiert",
|
"updated": "Umgebung aktualisiert",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Variablenliste"
|
"variable_list": "Variablenliste"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Keine Dauer",
|
"no_duration": "Keine Dauer",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Pre-Request-Skripte konnte nicht ausgeführt werden",
|
"script_fail": "Pre-Request-Skripte konnte nicht ausgeführt werden",
|
||||||
"something_went_wrong": "Etwas ist schief gelaufen",
|
"something_went_wrong": "Etwas ist schief gelaufen",
|
||||||
"test_script_fail": "Testskripts konnten nicht ausgeführt werden"
|
"test_script_fail": "Testskripts konnten nicht ausgeführt werden"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Ordner umbenannt"
|
"renamed": "Ordner umbenannt"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutationen",
|
"mutations": "Mutationen",
|
||||||
"schema": "Schema",
|
"schema": "Schema",
|
||||||
"subscriptions": "Abonnements",
|
"subscriptions": "Abonnements"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Hoppscotch Sammlungsdatei (JSON) importieren",
|
"json_description": "Hoppscotch Sammlungsdatei (JSON) importieren",
|
||||||
"title": "Importieren"
|
"title": "Importieren"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Sammlungen ein- oder ausklappen",
|
"collapse_collection": "Sammlungen ein- oder ausklappen",
|
||||||
"collapse_sidebar": "Seitenleiste ein- oder ausklappen",
|
"collapse_sidebar": "Seitenleiste ein- oder ausklappen",
|
||||||
"column": "Vertikales Layout",
|
"column": "Vertikales Layout",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Horizontales Layout"
|
"row": "Horizontales Layout",
|
||||||
|
"zen_mode": "Zen-Modus"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Nutzlast",
|
"payload": "Nutzlast",
|
||||||
"query": "Anfrage",
|
"query": "Anfrage",
|
||||||
"raw_body": "Roher Anfragetext",
|
"raw_body": "Roher Anfragetext",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Anfrage umbenannt",
|
"renamed": "Anfrage umbenannt",
|
||||||
"run": "Ausführen",
|
"run": "Ausführen",
|
||||||
"save": "Speichern",
|
"save": "Speichern",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Anfrage gespeichert",
|
"saved": "Anfrage gespeichert",
|
||||||
"share": "Teilen",
|
"share": "Teilen",
|
||||||
"share_description": "Teile Hoppscotch mit Deinen Freunden",
|
"share_description": "Teile Hoppscotch mit Deinen Freunden",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Anfrage",
|
"title": "Anfrage",
|
||||||
"type": "Anfragetyp",
|
"type": "Anfragetyp",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Antworttext",
|
"body": "Antworttext",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Header",
|
"headers": "Header",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Status",
|
"status": "Status",
|
||||||
"time": "Zeit",
|
"time": "Zeit",
|
||||||
"title": "Antwort",
|
"title": "Antwort",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "auf Verbindung warten",
|
"waiting_for_connection": "auf Verbindung warten",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Dies ist Dein Anzeigename.",
|
"account_name_description": "Dies ist Dein Anzeigename.",
|
||||||
"background": "Hintergrund",
|
"background": "Hintergrund",
|
||||||
"black_mode": "Schwarz",
|
"black_mode": "Schwarz",
|
||||||
|
"change_font_size": "Schriftgröße ändern",
|
||||||
"choose_language": "Sprache wählen",
|
"choose_language": "Sprache wählen",
|
||||||
"dark_mode": "Dunkel",
|
"dark_mode": "Dunkel",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Erweiterungen",
|
"extensions": "Erweiterungen",
|
||||||
"extensions_use_toggle": "Verwende die Browsererweiterung, um Anfragen zu senden (falls vorhanden)",
|
"extensions_use_toggle": "Verwende die Browsererweiterung, um Anfragen zu senden (falls vorhanden)",
|
||||||
"follow": "Folge uns",
|
"follow": "Folge uns",
|
||||||
|
"font_size": "Schriftgröße",
|
||||||
|
"font_size_large": "Groß",
|
||||||
|
"font_size_medium": "Mittel",
|
||||||
|
"font_size_small": "Klein",
|
||||||
"interceptor": "Interceptor",
|
"interceptor": "Interceptor",
|
||||||
"interceptor_description": "Middleware zwischen Anwendung und APIs.",
|
"interceptor_description": "Middleware zwischen Anwendung und APIs.",
|
||||||
"language": "Sprache",
|
"language": "Sprache",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Einstellungen öffnen",
|
"settings": "Einstellungen öffnen",
|
||||||
"title": "Navigation"
|
"title": "Navigation"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Anfragelink kopieren",
|
"copy_request_link": "Anfragelink kopieren",
|
||||||
"delete_method": "DELETE-Methode auswählen",
|
"delete_method": "DELETE-Methode auswählen",
|
||||||
"get_method": "GET-Methode auswählen",
|
"get_method": "GET-Methode auswählen",
|
||||||
"head_method": "HEAD-Methode auswählen",
|
"head_method": "HEAD-Methode auswählen",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Methode",
|
"method": "Methode",
|
||||||
"next_method": "Nächste Methode auswählen",
|
"next_method": "Nächste Methode auswählen",
|
||||||
"post_method": "POST-Methode auswählen",
|
"post_method": "POST-Methode auswählen",
|
||||||
"previous_method": "Vorherige Methode auswählen",
|
"previous_method": "Vorherige Methode auswählen",
|
||||||
"put_method": "PUT-Methode auswählen",
|
"put_method": "PUT-Methode auswählen",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Anfrage zurücksetzen",
|
"reset_request": "Anfrage zurücksetzen",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "In Sammlungen speichern",
|
"save_to_collections": "In Sammlungen speichern",
|
||||||
"send_request": "Anfrage senden",
|
"send_request": "Anfrage senden",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Anfrage"
|
"title": "Anfrage"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Protokoll",
|
"log": "Protokoll",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Ereignistyp",
|
"event_type": "Ereignistyp",
|
||||||
"log": "Protokoll",
|
"log": "Protokoll",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Autorisierung",
|
"authorization": "Autorisierung",
|
||||||
"body": "Anfragekörper",
|
"body": "Anfragekörper",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Sammlungen",
|
"collections": "Sammlungen",
|
||||||
"documentation": "Dokumentation",
|
"documentation": "Dokumentation",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Header",
|
"headers": "Header",
|
||||||
"history": "Verlauf",
|
"history": "Verlauf",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Επιλέξτε ένα αρχείο",
|
"choose_file": "Επιλέξτε ένα αρχείο",
|
||||||
"clear": "Σαφή",
|
"clear": "Σαφή",
|
||||||
"clear_all": "Τα καθαρίζω όλα",
|
"clear_all": "Τα καθαρίζω όλα",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Συνδέω-συωδεομαι",
|
"connect": "Συνδέω-συωδεομαι",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "Ωραιοποιώ",
|
"prettify": "Ωραιοποιώ",
|
||||||
"remove": "Αφαιρώ",
|
"remove": "Αφαιρώ",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Επαναφέρω",
|
"restore": "Επαναφέρω",
|
||||||
"save": "Αποθηκεύσετε",
|
"save": "Αποθηκεύσετε",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Αναζήτηση",
|
"search": "Αναζήτηση",
|
||||||
"share": "Μερίδιο",
|
"share": "Μερίδιο",
|
||||||
"shortcuts": "Συντομεύσεις",
|
"shortcuts": "Συντομεύσεις",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Προβολέας θέατρου",
|
"spotlight": "Προβολέας θέατρου",
|
||||||
"status": "Κατάσταση",
|
"status": "Κατάσταση",
|
||||||
"status_description": "Ελέγξτε το status της Ιστοσελίδας",
|
"status_description": "Ελέγξτε το status της Ιστοσελίδας",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Η συλλογή μετονομάστηκε",
|
"renamed": "Η συλλογή μετονομάστηκε",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Αποθήκευση ως",
|
"save_as": "Αποθήκευση ως",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Επιλέξτε μια Συλλογή",
|
"select": "Επιλέξτε μια Συλλογή",
|
||||||
"select_location": "Επιλέξτε τοποθεσία",
|
"select_location": "Επιλέξτε τοποθεσία",
|
||||||
"select_team": "Επιλέξτε μια ομάδα",
|
"select_team": "Επιλέξτε μια ομάδα",
|
||||||
"team_collections": "Συλλογές ομάδων"
|
"team_collections": "Συλλογές ομάδων"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Είστε βέβαιοι ότι θέλετε να αποσυνδεθείτε?",
|
"logout": "Είστε βέβαιοι ότι θέλετε να αποσυνδεθείτε?",
|
||||||
"remove_collection": "Είστε βέβαιοι ότι θέλετε να διαγράψετε οριστικά αυτήν τη συλλογή;",
|
"remove_collection": "Είστε βέβαιοι ότι θέλετε να διαγράψετε οριστικά αυτήν τη συλλογή;",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Είστε βέβαιοι ότι θέλετε να συγχρονίσετε αυτόν τον χώρο εργασίας;"
|
"sync": "Είστε βέβαιοι ότι θέλετε να συγχρονίσετε αυτόν τον χώρο εργασίας;"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Κεφαλίδα {count}",
|
"header": "Κεφαλίδα {count}",
|
||||||
"message": "Μήνυμα {count}",
|
"message": "Μήνυμα {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Δημιουργήστε νέο περιβάλλον",
|
"create_new": "Δημιουργήστε νέο περιβάλλον",
|
||||||
"created": "Το Περιβάλλον δημιουργήθηκε",
|
"created": "Το Περιβάλλον δημιουργήθηκε",
|
||||||
"deleted": "Διαγραφή Περιβάλλοντος",
|
"deleted": "Διαγραφή Περιβάλλοντος",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Επεξεργασία Περιβάλλοντος",
|
"edit": "Επεξεργασία Περιβάλλοντος",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Καταχωρίστε ένα έγκυρο όνομα για το περιβάλλον",
|
"invalid_name": "Καταχωρίστε ένα έγκυρο όνομα για το περιβάλλον",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "Τα Περιβάλλοντα μου",
|
"my_environments": "Τα Περιβάλλοντα μου",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "Οι 'φωλιασμένες' μεταβλητές περιβάλλοντος είναι περιορισμένες σε 10 επίπεδα",
|
"nested_overflow": "Οι 'φωλιασμένες' μεταβλητές περιβάλλοντος είναι περιορισμένες σε 10 επίπεδα",
|
||||||
"new": "Νέο Περιβάλλον",
|
"new": "Νέο Περιβάλλον",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Χωρίς περιβάλλον",
|
"no_environment": "Χωρίς περιβάλλον",
|
||||||
"no_environment_description": "Δέν επιλέχθηκε κάποιο περιβάλλον. Διαλέξτε τι θέλετε να κάνετε με τις παρακάτω μεταβλητές.",
|
"no_environment_description": "Δέν επιλέχθηκε κάποιο περιβάλλον. Διαλέξτε τι θέλετε να κάνετε με τις παρακάτω μεταβλητές.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Επιλέξτε περιβάλλον",
|
"select": "Επιλέξτε περιβάλλον",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Περιβάλλοντα Ομάδας",
|
"team_environments": "Περιβάλλοντα Ομάδας",
|
||||||
"title": "Περιβάλλοντα",
|
"title": "Περιβάλλοντα",
|
||||||
"updated": "Αναβάθμιση Περιβάλλοντος",
|
"updated": "Αναβάθμιση Περιβάλλοντος",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Λίστα μεταβλητών"
|
"variable_list": "Λίστα μεταβλητών"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Χωρίς διάρκεια",
|
"no_duration": "Χωρίς διάρκεια",
|
||||||
"no_results_found": "Δεν βρέθηκαν αντιστοιχίες",
|
"no_results_found": "Δεν βρέθηκαν αντιστοιχίες",
|
||||||
"page_not_found": "Αυτή η σελίδα δεν βρέθηκε",
|
"page_not_found": "Αυτή η σελίδα δεν βρέθηκε",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Δεν ήταν δυνατή η εκτέλεση του σεναρίου πριν από το αίτημα",
|
"script_fail": "Δεν ήταν δυνατή η εκτέλεση του σεναρίου πριν από το αίτημα",
|
||||||
"something_went_wrong": "Κάτι πήγε στραβά",
|
"something_went_wrong": "Κάτι πήγε στραβά",
|
||||||
"test_script_fail": "Δεν μπορεσε να εκτελεστεί το post-request script"
|
"test_script_fail": "Δεν μπορεσε να εκτελεστεί το post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Ο φάκελος μετονομάστηκε"
|
"renamed": "Ο φάκελος μετονομάστηκε"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Μεταλλάξεις",
|
"mutations": "Μεταλλάξεις",
|
||||||
"schema": "Σχήμα",
|
"schema": "Σχήμα",
|
||||||
"subscriptions": "Συνδρομές",
|
"subscriptions": "Συνδρομές"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Εισαγωγή συλλογών αρχείο JSON Hoppscotch Collections",
|
"json_description": "Εισαγωγή συλλογών αρχείο JSON Hoppscotch Collections",
|
||||||
"title": "Εισαγωγή"
|
"title": "Εισαγωγή"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Σύμπτυξη ή επέκταση Συλλογών",
|
"collapse_collection": "Σύμπτυξη ή επέκταση Συλλογών",
|
||||||
"collapse_sidebar": "Σύμπτυξη ή επέκταση του sidebar",
|
"collapse_sidebar": "Σύμπτυξη ή επέκταση του sidebar",
|
||||||
"column": "Κατακόρυφη Διάταξη",
|
"column": "Κατακόρυφη Διάταξη",
|
||||||
"name": "Διάταξη",
|
"name": "Διάταξη",
|
||||||
"row": "Οριζόντια Διάταξη"
|
"row": "Οριζόντια Διάταξη",
|
||||||
|
"zen_mode": "Λειτουργία Zen"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Φορτίο επί πληρωμή",
|
"payload": "Φορτίο επί πληρωμή",
|
||||||
"query": "Ερώτηση",
|
"query": "Ερώτηση",
|
||||||
"raw_body": "Σώμα Ακατέργαστου Αιτήματος",
|
"raw_body": "Σώμα Ακατέργαστου Αιτήματος",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Το αίτημα μετονομάστηκε",
|
"renamed": "Το αίτημα μετονομάστηκε",
|
||||||
"run": "Τρέξιμο",
|
"run": "Τρέξιμο",
|
||||||
"save": "Σώσει",
|
"save": "Σώσει",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Το αίτημα αποθηκεύτηκε",
|
"saved": "Το αίτημα αποθηκεύτηκε",
|
||||||
"share": "Μερίδιο",
|
"share": "Μερίδιο",
|
||||||
"share_description": "Κοινοποίηση Hoppscotch στους φίλους σου",
|
"share_description": "Κοινοποίηση Hoppscotch στους φίλους σου",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Αίτηση",
|
"title": "Αίτηση",
|
||||||
"type": "Τύπος αιτήματος",
|
"type": "Τύπος αιτήματος",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "Προβολή των links μου"
|
"view_my_links": "Προβολή των links μου"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Σώμα απόκρισης",
|
"body": "Σώμα απόκρισης",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Κεφαλίδες",
|
"headers": "Κεφαλίδες",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Κατάσταση",
|
"status": "Κατάσταση",
|
||||||
"time": "χρόνος",
|
"time": "χρόνος",
|
||||||
"title": "Απάντηση",
|
"title": "Απάντηση",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "περιμένοντας τη σύνδεση",
|
"waiting_for_connection": "περιμένοντας τη σύνδεση",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Αυτό είναι το εμφανιζόμενο όνομά σας.",
|
"account_name_description": "Αυτό είναι το εμφανιζόμενο όνομά σας.",
|
||||||
"background": "Ιστορικό",
|
"background": "Ιστορικό",
|
||||||
"black_mode": "Μαύρος",
|
"black_mode": "Μαύρος",
|
||||||
|
"change_font_size": "Αλλαγή μεγέθους γραμματοσειράς",
|
||||||
"choose_language": "Διάλεξε γλώσσα",
|
"choose_language": "Διάλεξε γλώσσα",
|
||||||
"dark_mode": "Σκοτάδι",
|
"dark_mode": "Σκοτάδι",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Επεκτάσεις",
|
"extensions": "Επεκτάσεις",
|
||||||
"extensions_use_toggle": "Χρησιμοποιήστε την επέκταση του προγράμματος περιήγησης για να στείλετε αιτήματα (εάν υπάρχουν)",
|
"extensions_use_toggle": "Χρησιμοποιήστε την επέκταση του προγράμματος περιήγησης για να στείλετε αιτήματα (εάν υπάρχουν)",
|
||||||
"follow": "Ακολούθησε Μας",
|
"follow": "Ακολούθησε Μας",
|
||||||
|
"font_size": "Μέγεθος γραμματοσειράς",
|
||||||
|
"font_size_large": "Μεγάλο",
|
||||||
|
"font_size_medium": "Μεσαίο",
|
||||||
|
"font_size_small": "Μικρό",
|
||||||
"interceptor": "Αναχαιτιστής",
|
"interceptor": "Αναχαιτιστής",
|
||||||
"interceptor_description": "Middleware μεταξύ εφαρμογής και API.",
|
"interceptor_description": "Middleware μεταξύ εφαρμογής και API.",
|
||||||
"language": "Γλώσσα",
|
"language": "Γλώσσα",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Μεταβείτε στη σελίδα Ρυθμίσεις",
|
"settings": "Μεταβείτε στη σελίδα Ρυθμίσεις",
|
||||||
"title": "Πλοήγηση"
|
"title": "Πλοήγηση"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Αντιγραφή συνδέσμου αιτήματος",
|
"copy_request_link": "Αντιγραφή συνδέσμου αιτήματος",
|
||||||
"delete_method": "Επιλέξτε ΔΙΑΓΡΑΦΗ μεθόδου",
|
"delete_method": "Επιλέξτε ΔΙΑΓΡΑΦΗ μεθόδου",
|
||||||
"get_method": "Επιλέξτε μέθοδο GET",
|
"get_method": "Επιλέξτε μέθοδο GET",
|
||||||
"head_method": "Επιλέξτε μέθοδο HEAD",
|
"head_method": "Επιλέξτε μέθοδο HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Μέθοδος",
|
"method": "Μέθοδος",
|
||||||
"next_method": "Επιλέξτε Επόμενη μέθοδος",
|
"next_method": "Επιλέξτε Επόμενη μέθοδος",
|
||||||
"post_method": "Επιλέξτε μέθοδο POST",
|
"post_method": "Επιλέξτε μέθοδο POST",
|
||||||
"previous_method": "Επιλέξτε Προηγούμενη μέθοδος",
|
"previous_method": "Επιλέξτε Προηγούμενη μέθοδος",
|
||||||
"put_method": "Επιλέξτε μέθοδο PUT",
|
"put_method": "Επιλέξτε μέθοδο PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Επαναφορά αιτήματος",
|
"reset_request": "Επαναφορά αιτήματος",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Αποθήκευση στις Συλλογές",
|
"save_to_collections": "Αποθήκευση στις Συλλογές",
|
||||||
"send_request": "Στείλε αίτημα",
|
"send_request": "Στείλε αίτημα",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Αίτηση"
|
"title": "Αίτηση"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Logs",
|
"log": "Logs",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Τύπος συμβάντος",
|
"event_type": "Τύπος συμβάντος",
|
||||||
"log": "Logs",
|
"log": "Logs",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Εξουσιοδότηση",
|
"authorization": "Εξουσιοδότηση",
|
||||||
"body": "Σώμα",
|
"body": "Σώμα",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Συλλογές",
|
"collections": "Συλλογές",
|
||||||
"documentation": "Τεκμηρίωση",
|
"documentation": "Τεκμηρίωση",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Κεφαλίδες",
|
"headers": "Κεφαλίδες",
|
||||||
"history": "Ιστορία",
|
"history": "Ιστορία",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Choose a file",
|
"choose_file": "Choose a file",
|
||||||
"clear": "Clear",
|
"clear": "Clear",
|
||||||
"clear_all": "Clear all",
|
"clear_all": "Clear all",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Connect",
|
"connect": "Connect",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "Prettify",
|
"prettify": "Prettify",
|
||||||
"remove": "Remove",
|
"remove": "Remove",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Restore",
|
"restore": "Restore",
|
||||||
"save": "Save",
|
"save": "Save",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Search",
|
"search": "Search",
|
||||||
"share": "Share",
|
"share": "Share",
|
||||||
"shortcuts": "Shortcuts",
|
"shortcuts": "Shortcuts",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Spotlight",
|
"spotlight": "Spotlight",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Collection renamed",
|
"renamed": "Collection renamed",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Save as",
|
"save_as": "Save as",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Select a Collection",
|
"select": "Select a Collection",
|
||||||
"select_location": "Select location",
|
"select_location": "Select location",
|
||||||
"select_team": "Select a team",
|
"select_team": "Select a team",
|
||||||
"team_collections": "Team Collections"
|
"team_collections": "Team Collections"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Are you sure you want to logout?",
|
"logout": "Are you sure you want to logout?",
|
||||||
"remove_collection": "Are you sure you want to permanently delete this collection?",
|
"remove_collection": "Are you sure you want to permanently delete this collection?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Would you like to restore your workspace from cloud? This will discard your local progress."
|
"sync": "Would you like to restore your workspace from cloud? This will discard your local progress."
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Header {count}",
|
"header": "Header {count}",
|
||||||
"message": "Message {count}",
|
"message": "Message {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Create new environment",
|
"create_new": "Create new environment",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Edit Environment",
|
"edit": "Edit Environment",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Please provide a name for the environment",
|
"invalid_name": "Please provide a name for the environment",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "New Environment",
|
"new": "New Environment",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "No environment",
|
"no_environment": "No environment",
|
||||||
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Select environment",
|
"select": "Select environment",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Environments",
|
"title": "Environments",
|
||||||
"updated": "Environment updated",
|
"updated": "Environment updated",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Variable List"
|
"variable_list": "Variable List"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "No duration",
|
"no_duration": "No duration",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Could not execute pre-request script",
|
"script_fail": "Could not execute pre-request script",
|
||||||
"something_went_wrong": "Something went wrong",
|
"something_went_wrong": "Something went wrong",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Folder renamed"
|
"renamed": "Folder renamed"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutations",
|
"mutations": "Mutations",
|
||||||
"schema": "Schema",
|
"schema": "Schema",
|
||||||
"subscriptions": "Subscriptions",
|
"subscriptions": "Subscriptions"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
||||||
"title": "Import"
|
"title": "Import"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "Vertical layout",
|
"column": "Vertical layout",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Horizontal layout"
|
"row": "Horizontal layout",
|
||||||
|
"zen_mode": "Zen mode"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Payload",
|
"payload": "Payload",
|
||||||
"query": "Query",
|
"query": "Query",
|
||||||
"raw_body": "Raw Request Body",
|
"raw_body": "Raw Request Body",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Request renamed",
|
"renamed": "Request renamed",
|
||||||
"run": "Run",
|
"run": "Run",
|
||||||
"save": "Save",
|
"save": "Save",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Request saved",
|
"saved": "Request saved",
|
||||||
"share": "Share",
|
"share": "Share",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Request",
|
"title": "Request",
|
||||||
"type": "Request type",
|
"type": "Request type",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -515,6 +459,7 @@
|
|||||||
"account_name_description": "This is your display name.",
|
"account_name_description": "This is your display name.",
|
||||||
"background": "Background",
|
"background": "Background",
|
||||||
"black_mode": "Black",
|
"black_mode": "Black",
|
||||||
|
"change_font_size": "Change font size",
|
||||||
"choose_language": "Choose language",
|
"choose_language": "Choose language",
|
||||||
"dark_mode": "Dark",
|
"dark_mode": "Dark",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +472,10 @@
|
|||||||
"extensions": "Browser extension",
|
"extensions": "Browser extension",
|
||||||
"extensions_use_toggle": "Use the browser extension to send requests (if present)",
|
"extensions_use_toggle": "Use the browser extension to send requests (if present)",
|
||||||
"follow": "Follow us",
|
"follow": "Follow us",
|
||||||
|
"font_size": "Font size",
|
||||||
|
"font_size_large": "Large",
|
||||||
|
"font_size_medium": "Medium",
|
||||||
|
"font_size_small": "Small",
|
||||||
"interceptor": "Interceptor",
|
"interceptor": "Interceptor",
|
||||||
"interceptor_description": "Middleware between application and APIs.",
|
"interceptor_description": "Middleware between application and APIs.",
|
||||||
"language": "Language",
|
"language": "Language",
|
||||||
@@ -591,27 +540,19 @@
|
|||||||
"settings": "Go to Settings page",
|
"settings": "Go to Settings page",
|
||||||
"title": "Navigation"
|
"title": "Navigation"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Copy Request Link",
|
"copy_request_link": "Copy Request Link",
|
||||||
"delete_method": "Select DELETE method",
|
"delete_method": "Select DELETE method",
|
||||||
"get_method": "Select GET method",
|
"get_method": "Select GET method",
|
||||||
"head_method": "Select HEAD method",
|
"head_method": "Select HEAD method",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Method",
|
"method": "Method",
|
||||||
"next_method": "Select Next method",
|
"next_method": "Select Next method",
|
||||||
"post_method": "Select POST method",
|
"post_method": "Select POST method",
|
||||||
"previous_method": "Select Previous method",
|
"previous_method": "Select Previous method",
|
||||||
"put_method": "Select PUT method",
|
"put_method": "Select PUT method",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Reset Request",
|
"reset_request": "Reset Request",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Save to Collections",
|
"save_to_collections": "Save to Collections",
|
||||||
"send_request": "Send Request",
|
"send_request": "Send Request",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Request"
|
"title": "Request"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -620,10 +561,10 @@
|
|||||||
"title": "Response"
|
"title": "Response"
|
||||||
},
|
},
|
||||||
"theme": {
|
"theme": {
|
||||||
"black": "Switch theme to Black Mode",
|
"black": "Switch theme to black mode",
|
||||||
"dark": "Switch theme to Dark Mode",
|
"dark": "Switch theme to dark mode",
|
||||||
"light": "Switch theme to Light Mode",
|
"light": "Switch theme to light mode",
|
||||||
"system": "Switch theme to System Mode",
|
"system": "Switch theme to system mode",
|
||||||
"title": "Theme"
|
"title": "Theme"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -641,85 +582,6 @@
|
|||||||
"log": "Log",
|
"log": "Log",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Event type",
|
"event_type": "Event type",
|
||||||
"log": "Log",
|
"log": "Log",
|
||||||
@@ -765,7 +627,7 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"changelog": "Read more about latest releases",
|
"changelog": "Read more about latest releases",
|
||||||
"chat": "Questions? Chat with us!",
|
"chat": "Questions? Chat with us!",
|
||||||
"community": "Ask questions and help others",
|
"community": "Ask questions and help others",
|
||||||
"documentation": "Read more about Hoppscotch",
|
"documentation": "Read more about Hoppscotch",
|
||||||
"forum": "Ask questions and get answers",
|
"forum": "Ask questions and get answers",
|
||||||
"github": "Follow us on Github",
|
"github": "Follow us on Github",
|
||||||
@@ -777,11 +639,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Authorization",
|
"authorization": "Authorization",
|
||||||
"body": "Body",
|
"body": "Body",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Collections",
|
"collections": "Collections",
|
||||||
"documentation": "Documentation",
|
"documentation": "Documentation",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Headers",
|
"headers": "Headers",
|
||||||
"history": "History",
|
"history": "History",
|
||||||
@@ -843,8 +702,6 @@
|
|||||||
"not_found": "Team not found. Contact your team owner.",
|
"not_found": "Team not found. Contact your team owner.",
|
||||||
"not_valid_viewer": "You are not a valid viewer. Contact your team owner.",
|
"not_valid_viewer": "You are not a valid viewer. Contact your team owner.",
|
||||||
"parent_coll_move": "Cannot move collection to a child collection",
|
"parent_coll_move": "Cannot move collection to a child collection",
|
||||||
"success_invites": "Success invites",
|
|
||||||
"failed_invites": "Failed invites",
|
|
||||||
"pending_invites": "Pending invites",
|
"pending_invites": "Pending invites",
|
||||||
"permissions": "Permissions",
|
"permissions": "Permissions",
|
||||||
"same_target_destination": "Same target and destination",
|
"same_target_destination": "Same target and destination",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Seleccionar archivo",
|
"choose_file": "Seleccionar archivo",
|
||||||
"clear": "Limpiar",
|
"clear": "Limpiar",
|
||||||
"clear_all": "Limpiar todo",
|
"clear_all": "Limpiar todo",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Cerrar",
|
"close": "Cerrar",
|
||||||
"connect": "Conectar",
|
"connect": "Conectar",
|
||||||
"connecting": "Conectando",
|
"connecting": "Conectando",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Pegar",
|
"paste": "Pegar",
|
||||||
"prettify": "Embellecer",
|
"prettify": "Embellecer",
|
||||||
"remove": "Eliminar",
|
"remove": "Eliminar",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Restaurar",
|
"restore": "Restaurar",
|
||||||
"save": "Guardar",
|
"save": "Guardar",
|
||||||
"scroll_to_bottom": "Desplazar hacia abajo",
|
"scroll_to_bottom": "Desplazar hacia abajo",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Buscar",
|
"search": "Buscar",
|
||||||
"share": "Compartir",
|
"share": "Compartir",
|
||||||
"shortcuts": "Atajos",
|
"shortcuts": "Atajos",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Destacar",
|
"spotlight": "Destacar",
|
||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
"status_description": "Comprobar el estado del sitio web",
|
"status_description": "Comprobar el estado del sitio web",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Colección renombrada",
|
"renamed": "Colección renombrada",
|
||||||
"request_in_use": "Solicitud en uso",
|
"request_in_use": "Solicitud en uso",
|
||||||
"save_as": "Guardar como",
|
"save_as": "Guardar como",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Seleccionar colección",
|
"select": "Seleccionar colección",
|
||||||
"select_location": "Seleccionar ubicación",
|
"select_location": "Seleccionar ubicación",
|
||||||
"select_team": "Seleccionar equipo",
|
"select_team": "Seleccionar equipo",
|
||||||
"team_collections": "Colecciones de equipos"
|
"team_collections": "Colecciones de equipos"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "¿Estás seguro de que quieres dejar este equipo?",
|
"exit_team": "¿Estás seguro de que quieres dejar este equipo?",
|
||||||
"logout": "¿Estás seguro de que deseas cerrar la sesión?",
|
"logout": "¿Estás seguro de que deseas cerrar la sesión?",
|
||||||
"remove_collection": "¿Estás seguro de que deseas eliminar esta colección de forma permanente?",
|
"remove_collection": "¿Estás seguro de que deseas eliminar esta colección de forma permanente?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "¿Deseas guardar los cambios realizados en esta pestaña?",
|
"save_unsaved_tab": "¿Deseas guardar los cambios realizados en esta pestaña?",
|
||||||
"sync": "¿Estás seguro de que deseas sincronizar este espacio de trabajo?"
|
"sync": "¿Estás seguro de que deseas sincronizar este espacio de trabajo?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Encabezado {count}",
|
"header": "Encabezado {count}",
|
||||||
"message": "Mensaje {count}",
|
"message": "Mensaje {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Crear un nuevo entorno",
|
"create_new": "Crear un nuevo entorno",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Eliminar el entorno",
|
"deleted": "Eliminar el entorno",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Editar entorno",
|
"edit": "Editar entorno",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Proporciona un nombre válido para el entorno.",
|
"invalid_name": "Proporciona un nombre válido para el entorno.",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "Mis entornos",
|
"my_environments": "Mis entornos",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "las variables de entorno anidadas están limitadas a 10 niveles",
|
"nested_overflow": "las variables de entorno anidadas están limitadas a 10 niveles",
|
||||||
"new": "Nuevo entorno",
|
"new": "Nuevo entorno",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Sin entorno",
|
"no_environment": "Sin entorno",
|
||||||
"no_environment_description": "No se ha seleccionado ningún entorno. Elije qué hacer con las siguientes variables.",
|
"no_environment_description": "No se ha seleccionado ningún entorno. Elije qué hacer con las siguientes variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Seleccionar entorno",
|
"select": "Seleccionar entorno",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Entornos de trabajo en equipo",
|
"team_environments": "Entornos de trabajo en equipo",
|
||||||
"title": "Entornos",
|
"title": "Entornos",
|
||||||
"updated": "Entorno actualizado",
|
"updated": "Entorno actualizado",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Lista de variables"
|
"variable_list": "Lista de variables"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Sin duración",
|
"no_duration": "Sin duración",
|
||||||
"no_results_found": "No se han encontrado coincidencias",
|
"no_results_found": "No se han encontrado coincidencias",
|
||||||
"page_not_found": "No se ha podido encontrar esta página",
|
"page_not_found": "No se ha podido encontrar esta página",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "No se pudo ejecutar el script de solicitud previa",
|
"script_fail": "No se pudo ejecutar el script de solicitud previa",
|
||||||
"something_went_wrong": "Algo salió mal",
|
"something_went_wrong": "Algo salió mal",
|
||||||
"test_script_fail": "No se ha podido ejecutar la secuencia de comandos posterior a la solicitud"
|
"test_script_fail": "No se ha podido ejecutar la secuencia de comandos posterior a la solicitud"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Carpeta renombrada"
|
"renamed": "Carpeta renombrada"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutaciones",
|
"mutations": "Mutaciones",
|
||||||
"schema": "Esquema",
|
"schema": "Esquema",
|
||||||
"subscriptions": "Suscripciones",
|
"subscriptions": "Suscripciones"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Tiempo",
|
"time": "Tiempo",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Importar colecciones desde un archivo JSON de colecciones de Hoppscotch",
|
"json_description": "Importar colecciones desde un archivo JSON de colecciones de Hoppscotch",
|
||||||
"title": "Importar"
|
"title": "Importar"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Contraer o expandir colecciones",
|
"collapse_collection": "Contraer o expandir colecciones",
|
||||||
"collapse_sidebar": "Contraer o expandir la barra lateral",
|
"collapse_sidebar": "Contraer o expandir la barra lateral",
|
||||||
"column": "Disposición vertical",
|
"column": "Disposición vertical",
|
||||||
"name": "Diseño",
|
"name": "Diseño",
|
||||||
"row": "Disposición horizontal"
|
"row": "Disposición horizontal",
|
||||||
|
"zen_mode": "Modo zen"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "Tienes cambios sin guardar",
|
"close_unsaved_tab": "Tienes cambios sin guardar",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Carga útil",
|
"payload": "Carga útil",
|
||||||
"query": "Consulta",
|
"query": "Consulta",
|
||||||
"raw_body": "Cuerpo de solicitud sin procesar",
|
"raw_body": "Cuerpo de solicitud sin procesar",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Solicitud renombrada",
|
"renamed": "Solicitud renombrada",
|
||||||
"run": "Ejecutar",
|
"run": "Ejecutar",
|
||||||
"save": "Guardar",
|
"save": "Guardar",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Solicitud guardada",
|
"saved": "Solicitud guardada",
|
||||||
"share": "Compartir",
|
"share": "Compartir",
|
||||||
"share_description": "Comparte Hoppscotch con tus amigos",
|
"share_description": "Comparte Hoppscotch con tus amigos",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Solicitud",
|
"title": "Solicitud",
|
||||||
"type": "Tipo de solicitud",
|
"type": "Tipo de solicitud",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "Ver mis enlaces"
|
"view_my_links": "Ver mis enlaces"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Cuerpo de respuesta",
|
"body": "Cuerpo de respuesta",
|
||||||
"filter_response_body": "Filtrar el cuerpo de la respuesta JSON (utiliza la sintaxis JSONPath)",
|
"filter_response_body": "Filtrar el cuerpo de la respuesta JSON (utiliza la sintaxis JSONPath)",
|
||||||
"headers": "Encabezados",
|
"headers": "Encabezados",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
"time": "Tiempo",
|
"time": "Tiempo",
|
||||||
"title": "Respuesta",
|
"title": "Respuesta",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "esperando la conexión",
|
"waiting_for_connection": "esperando la conexión",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Este es tu nombre para mostrar.",
|
"account_name_description": "Este es tu nombre para mostrar.",
|
||||||
"background": "Fondo",
|
"background": "Fondo",
|
||||||
"black_mode": "Negro",
|
"black_mode": "Negro",
|
||||||
|
"change_font_size": "Cambiar tamaño de fuente",
|
||||||
"choose_language": "Elegir idioma",
|
"choose_language": "Elegir idioma",
|
||||||
"dark_mode": "Oscuro",
|
"dark_mode": "Oscuro",
|
||||||
"delete_account": "Eliminar cuenta",
|
"delete_account": "Eliminar cuenta",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Extensiones",
|
"extensions": "Extensiones",
|
||||||
"extensions_use_toggle": "Utilizar la extensión del navegador para enviar peticiones (si está presente)",
|
"extensions_use_toggle": "Utilizar la extensión del navegador para enviar peticiones (si está presente)",
|
||||||
"follow": "Síguenos",
|
"follow": "Síguenos",
|
||||||
|
"font_size": "Tamaño de fuente",
|
||||||
|
"font_size_large": "Grande",
|
||||||
|
"font_size_medium": "Mediano",
|
||||||
|
"font_size_small": "Pequeño",
|
||||||
"interceptor": "Interceptador",
|
"interceptor": "Interceptador",
|
||||||
"interceptor_description": "Middleware entre la aplicación y las APIs.",
|
"interceptor_description": "Middleware entre la aplicación y las APIs.",
|
||||||
"language": "Idioma",
|
"language": "Idioma",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Ir a la página de configuración",
|
"settings": "Ir a la página de configuración",
|
||||||
"title": "Navegación"
|
"title": "Navegación"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Copiar enlace de solicitud",
|
"copy_request_link": "Copiar enlace de solicitud",
|
||||||
"delete_method": "Seleccionar método DELETE",
|
"delete_method": "Seleccionar método DELETE",
|
||||||
"get_method": "Seleccionar método GET",
|
"get_method": "Seleccionar método GET",
|
||||||
"head_method": "Seleccionar método HEAD",
|
"head_method": "Seleccionar método HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Método",
|
"method": "Método",
|
||||||
"next_method": "Seleccionar método siguiente",
|
"next_method": "Seleccionar método siguiente",
|
||||||
"post_method": "Seleccionar método POST",
|
"post_method": "Seleccionar método POST",
|
||||||
"previous_method": "Seleccionar método anterior",
|
"previous_method": "Seleccionar método anterior",
|
||||||
"put_method": "Seleccionar método PUT",
|
"put_method": "Seleccionar método PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Solicitud de reinicio",
|
"reset_request": "Solicitud de reinicio",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Guardar en colecciones",
|
"save_to_collections": "Guardar en colecciones",
|
||||||
"send_request": "Enviar solicitud",
|
"send_request": "Enviar solicitud",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Solicitud"
|
"title": "Solicitud"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Registro",
|
"log": "Registro",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Tipo de evento",
|
"event_type": "Tipo de evento",
|
||||||
"log": "Registro",
|
"log": "Registro",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Autorización",
|
"authorization": "Autorización",
|
||||||
"body": "Cuerpo",
|
"body": "Cuerpo",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Colecciones",
|
"collections": "Colecciones",
|
||||||
"documentation": "Documentación",
|
"documentation": "Documentación",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Encabezados",
|
"headers": "Encabezados",
|
||||||
"history": "Historial",
|
"history": "Historial",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Valitse tiedosto",
|
"choose_file": "Valitse tiedosto",
|
||||||
"clear": "Asia selvä",
|
"clear": "Asia selvä",
|
||||||
"clear_all": "Tyhjennä",
|
"clear_all": "Tyhjennä",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Kytkeä",
|
"connect": "Kytkeä",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "Koristella",
|
"prettify": "Koristella",
|
||||||
"remove": "Poista",
|
"remove": "Poista",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Palauttaa",
|
"restore": "Palauttaa",
|
||||||
"save": "Tallentaa",
|
"save": "Tallentaa",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Hae",
|
"search": "Hae",
|
||||||
"share": "Jaa",
|
"share": "Jaa",
|
||||||
"shortcuts": "Pikanäppäimet",
|
"shortcuts": "Pikanäppäimet",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Valokeila",
|
"spotlight": "Valokeila",
|
||||||
"status": "Tila",
|
"status": "Tila",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Kokoelma nimetty uudelleen",
|
"renamed": "Kokoelma nimetty uudelleen",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Tallenna nimellä",
|
"save_as": "Tallenna nimellä",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Valitse kokoelma",
|
"select": "Valitse kokoelma",
|
||||||
"select_location": "Valitse sijainti",
|
"select_location": "Valitse sijainti",
|
||||||
"select_team": "Valitse joukkue",
|
"select_team": "Valitse joukkue",
|
||||||
"team_collections": "Joukkuekokoelmat"
|
"team_collections": "Joukkuekokoelmat"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Haluatko varmasti kirjautua ulos?",
|
"logout": "Haluatko varmasti kirjautua ulos?",
|
||||||
"remove_collection": "Haluatko varmasti poistaa tämän kokoelman pysyvästi?",
|
"remove_collection": "Haluatko varmasti poistaa tämän kokoelman pysyvästi?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Haluatko varmasti synkronoida tämän työtilan?"
|
"sync": "Haluatko varmasti synkronoida tämän työtilan?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Otsikko {count}",
|
"header": "Otsikko {count}",
|
||||||
"message": "Viesti {count}",
|
"message": "Viesti {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Luo uusi ympäristö",
|
"create_new": "Luo uusi ympäristö",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Muokkaa ympäristöä",
|
"edit": "Muokkaa ympäristöä",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Anna ympäristölle kelvollinen nimi",
|
"invalid_name": "Anna ympäristölle kelvollinen nimi",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "Uusi ympäristö",
|
"new": "Uusi ympäristö",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Ei ympäristöä",
|
"no_environment": "Ei ympäristöä",
|
||||||
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Valitse ympäristö",
|
"select": "Valitse ympäristö",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Ympäristöt",
|
"title": "Ympäristöt",
|
||||||
"updated": "Environment updation",
|
"updated": "Environment updation",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Muuttujien luettelo"
|
"variable_list": "Muuttujien luettelo"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Ei kestoa",
|
"no_duration": "Ei kestoa",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Ennakkopyyntöskriptiä ei voitu suorittaa",
|
"script_fail": "Ennakkopyyntöskriptiä ei voitu suorittaa",
|
||||||
"something_went_wrong": "Jotain meni pieleen",
|
"something_went_wrong": "Jotain meni pieleen",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Kansio nimettiin uudelleen"
|
"renamed": "Kansio nimettiin uudelleen"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutaatiot",
|
"mutations": "Mutaatiot",
|
||||||
"schema": "Kaavio",
|
"schema": "Kaavio",
|
||||||
"subscriptions": "Tilaukset",
|
"subscriptions": "Tilaukset"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
||||||
"title": "Tuonti"
|
"title": "Tuonti"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "Vertical layout",
|
"column": "Vertical layout",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Horizontal layout"
|
"row": "Horizontal layout",
|
||||||
|
"zen_mode": "Zen -tila"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Hyötykuorma",
|
"payload": "Hyötykuorma",
|
||||||
"query": "Kysely",
|
"query": "Kysely",
|
||||||
"raw_body": "Raaka pyynnön runko",
|
"raw_body": "Raaka pyynnön runko",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Pyyntö nimettiin uudelleen",
|
"renamed": "Pyyntö nimettiin uudelleen",
|
||||||
"run": "Juosta",
|
"run": "Juosta",
|
||||||
"save": "Tallentaa",
|
"save": "Tallentaa",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Pyyntö tallennettu",
|
"saved": "Pyyntö tallennettu",
|
||||||
"share": "Jaa",
|
"share": "Jaa",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Pyyntö",
|
"title": "Pyyntö",
|
||||||
"type": "Pyynnön tyyppi",
|
"type": "Pyynnön tyyppi",
|
||||||
"url": "URL -osoite",
|
"url": "URL -osoite",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Vastauselin",
|
"body": "Vastauselin",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Otsikot",
|
"headers": "Otsikot",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Tila",
|
"status": "Tila",
|
||||||
"time": "Aika",
|
"time": "Aika",
|
||||||
"title": "Vastaus",
|
"title": "Vastaus",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "yhteyttä odotellessa",
|
"waiting_for_connection": "yhteyttä odotellessa",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Tämä on näyttönimesi.",
|
"account_name_description": "Tämä on näyttönimesi.",
|
||||||
"background": "Tausta",
|
"background": "Tausta",
|
||||||
"black_mode": "Musta",
|
"black_mode": "Musta",
|
||||||
|
"change_font_size": "Vaihda fontin kokoa",
|
||||||
"choose_language": "Valitse kieli",
|
"choose_language": "Valitse kieli",
|
||||||
"dark_mode": "Tumma",
|
"dark_mode": "Tumma",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Laajennukset",
|
"extensions": "Laajennukset",
|
||||||
"extensions_use_toggle": "Käytä pyyntöjen lähettämiseen selainlaajennusta (jos sellainen on)",
|
"extensions_use_toggle": "Käytä pyyntöjen lähettämiseen selainlaajennusta (jos sellainen on)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "Fonttikoko",
|
||||||
|
"font_size_large": "Suuri",
|
||||||
|
"font_size_medium": "Keskikokoinen",
|
||||||
|
"font_size_small": "Pieni",
|
||||||
"interceptor": "Torjuntahävittäjä",
|
"interceptor": "Torjuntahävittäjä",
|
||||||
"interceptor_description": "Sovellusliittymien ja sovellusliittymien välinen väliohjelmisto.",
|
"interceptor_description": "Sovellusliittymien ja sovellusliittymien välinen väliohjelmisto.",
|
||||||
"language": "Kieli",
|
"language": "Kieli",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Siirry Asetukset -sivulle",
|
"settings": "Siirry Asetukset -sivulle",
|
||||||
"title": "Navigointi"
|
"title": "Navigointi"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Kopioi pyyntölinkki",
|
"copy_request_link": "Kopioi pyyntölinkki",
|
||||||
"delete_method": "Valitse POISTA menetelmä",
|
"delete_method": "Valitse POISTA menetelmä",
|
||||||
"get_method": "Valitse GET -menetelmä",
|
"get_method": "Valitse GET -menetelmä",
|
||||||
"head_method": "Valitse HEAD -menetelmä",
|
"head_method": "Valitse HEAD -menetelmä",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Menetelmä",
|
"method": "Menetelmä",
|
||||||
"next_method": "Valitse Seuraava menetelmä",
|
"next_method": "Valitse Seuraava menetelmä",
|
||||||
"post_method": "Valitse POST -menetelmä",
|
"post_method": "Valitse POST -menetelmä",
|
||||||
"previous_method": "Valitse Edellinen menetelmä",
|
"previous_method": "Valitse Edellinen menetelmä",
|
||||||
"put_method": "Valitse PUT -menetelmä",
|
"put_method": "Valitse PUT -menetelmä",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Nollaa pyyntö",
|
"reset_request": "Nollaa pyyntö",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Tallenna kokoelmiin",
|
"save_to_collections": "Tallenna kokoelmiin",
|
||||||
"send_request": "Lähetä pyyntö",
|
"send_request": "Lähetä pyyntö",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Pyyntö"
|
"title": "Pyyntö"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Hirsi",
|
"log": "Hirsi",
|
||||||
"url": "URL -osoite"
|
"url": "URL -osoite"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Tapahtumatyyppi",
|
"event_type": "Tapahtumatyyppi",
|
||||||
"log": "Hirsi",
|
"log": "Hirsi",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Valtuutus",
|
"authorization": "Valtuutus",
|
||||||
"body": "Runko",
|
"body": "Runko",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Kokoelmat",
|
"collections": "Kokoelmat",
|
||||||
"documentation": "Dokumentointi",
|
"documentation": "Dokumentointi",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Otsikot",
|
"headers": "Otsikot",
|
||||||
"history": "Historia",
|
"history": "Historia",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Choisir un fichier",
|
"choose_file": "Choisir un fichier",
|
||||||
"clear": "Effacer",
|
"clear": "Effacer",
|
||||||
"clear_all": "Tout effacer",
|
"clear_all": "Tout effacer",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Connecter",
|
"connect": "Connecter",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Coller",
|
"paste": "Coller",
|
||||||
"prettify": "Formater",
|
"prettify": "Formater",
|
||||||
"remove": "Supprimer",
|
"remove": "Supprimer",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Restaurer",
|
"restore": "Restaurer",
|
||||||
"save": "Sauvegarder",
|
"save": "Sauvegarder",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Chercher",
|
"search": "Chercher",
|
||||||
"share": "Partager",
|
"share": "Partager",
|
||||||
"shortcuts": "Raccourcis",
|
"shortcuts": "Raccourcis",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Projecteur",
|
"spotlight": "Projecteur",
|
||||||
"status": "Statut",
|
"status": "Statut",
|
||||||
"status_description": "Vérifier l'état du site web",
|
"status_description": "Vérifier l'état du site web",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Collection renommée",
|
"renamed": "Collection renommée",
|
||||||
"request_in_use": "Demande en cours d'utilisation",
|
"request_in_use": "Demande en cours d'utilisation",
|
||||||
"save_as": "Enregistrer sous",
|
"save_as": "Enregistrer sous",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Sélectionnez une collection",
|
"select": "Sélectionnez une collection",
|
||||||
"select_location": "Sélectionnez l'emplacement",
|
"select_location": "Sélectionnez l'emplacement",
|
||||||
"select_team": "Sélectionnez une équipe",
|
"select_team": "Sélectionnez une équipe",
|
||||||
"team_collections": "Collections de l'équipe"
|
"team_collections": "Collections de l'équipe"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Êtes-vous sûr de vouloir vous déconnecter?",
|
"logout": "Êtes-vous sûr de vouloir vous déconnecter?",
|
||||||
"remove_collection": "Voulez-vous vraiment supprimer définitivement cette collection ?",
|
"remove_collection": "Voulez-vous vraiment supprimer définitivement cette collection ?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Voulez-vous vraiment synchroniser cet espace de travail ?"
|
"sync": "Voulez-vous vraiment synchroniser cet espace de travail ?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "En-tête {count}",
|
"header": "En-tête {count}",
|
||||||
"message": "Message {compte}",
|
"message": "Message {compte}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Créer un nouvel environnement",
|
"create_new": "Créer un nouvel environnement",
|
||||||
"created": "Environnement créé",
|
"created": "Environnement créé",
|
||||||
"deleted": "Environnement supprimé",
|
"deleted": "Environnement supprimé",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Modifier l'environnement",
|
"edit": "Modifier l'environnement",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Veuillez fournir un nom valide pour l'environnement",
|
"invalid_name": "Veuillez fournir un nom valide pour l'environnement",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "les variables d'environnement imbriquées sont limitées à 10 niveaux",
|
"nested_overflow": "les variables d'environnement imbriquées sont limitées à 10 niveaux",
|
||||||
"new": "Nouvel environnement",
|
"new": "Nouvel environnement",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Pas d'environnement",
|
"no_environment": "Pas d'environnement",
|
||||||
"no_environment_description": "Aucun environnement n'a été sélectionné. Choisissez ce qu'il faut faire avec les variables suivantes.",
|
"no_environment_description": "Aucun environnement n'a été sélectionné. Choisissez ce qu'il faut faire avec les variables suivantes.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Sélectionnez l'environnement",
|
"select": "Sélectionnez l'environnement",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Environnements",
|
"title": "Environnements",
|
||||||
"updated": "Mise à jour de l'environnement",
|
"updated": "Mise à jour de l'environnement",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Liste des variables"
|
"variable_list": "Liste des variables"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Pas de durée",
|
"no_duration": "Pas de durée",
|
||||||
"no_results_found": "Aucune correspondance trouvée",
|
"no_results_found": "Aucune correspondance trouvée",
|
||||||
"page_not_found": "Cette page n'a pas pu être trouvée",
|
"page_not_found": "Cette page n'a pas pu être trouvée",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Impossible d'exécuter le script de pré-requête",
|
"script_fail": "Impossible d'exécuter le script de pré-requête",
|
||||||
"something_went_wrong": "Quelque chose s'est mal passé",
|
"something_went_wrong": "Quelque chose s'est mal passé",
|
||||||
"test_script_fail": "Impossible d'exécuter le script post-requête"
|
"test_script_fail": "Impossible d'exécuter le script post-requête"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Dossier renommé"
|
"renamed": "Dossier renommé"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutations",
|
"mutations": "Mutations",
|
||||||
"schema": "Schéma",
|
"schema": "Schéma",
|
||||||
"subscriptions": "Abonnements",
|
"subscriptions": "Abonnements"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Importer des collections depuis un fichier JSON Hoppscotch",
|
"json_description": "Importer des collections depuis un fichier JSON Hoppscotch",
|
||||||
"title": "Importer"
|
"title": "Importer"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Réduire ou développer les collections",
|
"collapse_collection": "Réduire ou développer les collections",
|
||||||
"collapse_sidebar": "Réduire ou développer la barre latérale",
|
"collapse_sidebar": "Réduire ou développer la barre latérale",
|
||||||
"column": "Disposition verticale",
|
"column": "Disposition verticale",
|
||||||
"name": "Disposition",
|
"name": "Disposition",
|
||||||
"row": "Disposition horizontale"
|
"row": "Disposition horizontale",
|
||||||
|
"zen_mode": "Mode Zen"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Charge utile",
|
"payload": "Charge utile",
|
||||||
"query": "Requête",
|
"query": "Requête",
|
||||||
"raw_body": "Corps de requête brut",
|
"raw_body": "Corps de requête brut",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Requête renommée",
|
"renamed": "Requête renommée",
|
||||||
"run": "Lancer",
|
"run": "Lancer",
|
||||||
"save": "Sauvegarder",
|
"save": "Sauvegarder",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Requête enregistrée",
|
"saved": "Requête enregistrée",
|
||||||
"share": "Partager",
|
"share": "Partager",
|
||||||
"share_description": "Partagez Hoppscotch avec vos amis",
|
"share_description": "Partagez Hoppscotch avec vos amis",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Requête",
|
"title": "Requête",
|
||||||
"type": "Type de requête",
|
"type": "Type de requête",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "Voir mes liens"
|
"view_my_links": "Voir mes liens"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Corps de réponse",
|
"body": "Corps de réponse",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "En-têtes",
|
"headers": "En-têtes",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Statut",
|
"status": "Statut",
|
||||||
"time": "Temps",
|
"time": "Temps",
|
||||||
"title": "Réponse",
|
"title": "Réponse",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "En attente de connexion",
|
"waiting_for_connection": "En attente de connexion",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Ceci est votre nom d'affichage.",
|
"account_name_description": "Ceci est votre nom d'affichage.",
|
||||||
"background": "Fond",
|
"background": "Fond",
|
||||||
"black_mode": "Noir",
|
"black_mode": "Noir",
|
||||||
|
"change_font_size": "Changer la taille de la police",
|
||||||
"choose_language": "Choisissez la langue",
|
"choose_language": "Choisissez la langue",
|
||||||
"dark_mode": "Sombre",
|
"dark_mode": "Sombre",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Extensions",
|
"extensions": "Extensions",
|
||||||
"extensions_use_toggle": "Utilisez l'extension de navigateur pour envoyer des requêtes (le cas échéant)",
|
"extensions_use_toggle": "Utilisez l'extension de navigateur pour envoyer des requêtes (le cas échéant)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "Taille de police",
|
||||||
|
"font_size_large": "Grande",
|
||||||
|
"font_size_medium": "Moyenne",
|
||||||
|
"font_size_small": "Petite",
|
||||||
"interceptor": "Intercepteur",
|
"interceptor": "Intercepteur",
|
||||||
"interceptor_description": "Middleware entre l'application et les API.",
|
"interceptor_description": "Middleware entre l'application et les API.",
|
||||||
"language": "Langue",
|
"language": "Langue",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Aller à la page Paramètres",
|
"settings": "Aller à la page Paramètres",
|
||||||
"title": "Navigation"
|
"title": "Navigation"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Copier le lien de requête",
|
"copy_request_link": "Copier le lien de requête",
|
||||||
"delete_method": "Sélectionnez la méthode DELETE",
|
"delete_method": "Sélectionnez la méthode DELETE",
|
||||||
"get_method": "Sélectionnez la méthode GET",
|
"get_method": "Sélectionnez la méthode GET",
|
||||||
"head_method": "Sélectionnez la méthode HEAD",
|
"head_method": "Sélectionnez la méthode HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Méthode",
|
"method": "Méthode",
|
||||||
"next_method": "Sélectionnez la méthode suivante",
|
"next_method": "Sélectionnez la méthode suivante",
|
||||||
"post_method": "Sélectionnez la méthode POST",
|
"post_method": "Sélectionnez la méthode POST",
|
||||||
"previous_method": "Sélectionnez la méthode précédente",
|
"previous_method": "Sélectionnez la méthode précédente",
|
||||||
"put_method": "Sélectionnez la méthode PUT",
|
"put_method": "Sélectionnez la méthode PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Réinitialiser la requête",
|
"reset_request": "Réinitialiser la requête",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Enregistrer dans les collections",
|
"save_to_collections": "Enregistrer dans les collections",
|
||||||
"send_request": "Envoyer la requête",
|
"send_request": "Envoyer la requête",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Requête"
|
"title": "Requête"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Infos",
|
"log": "Infos",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Type d'événement",
|
"event_type": "Type d'événement",
|
||||||
"log": "Infos",
|
"log": "Infos",
|
||||||
@@ -727,7 +587,7 @@
|
|||||||
},
|
},
|
||||||
"state": {
|
"state": {
|
||||||
"bulk_mode": "Modification groupée",
|
"bulk_mode": "Modification groupée",
|
||||||
"bulk_mode_placeholder": "Les entrées sont séparées par une nouvelle ligne\nLes clés et les valeurs sont séparées par :\nAjoutez # à n'importe quelle ligne que vous souhaitez ajouter mais garder désactivée",
|
"bulk_mode_placeholder": "Les entrées sont séparées par une nouvelle ligne\nLes clés et les valeurs sont séparées par :\nAjoutez # à n'importe quelle ligne que vous souhaitez ajouter mais garder désactivée",
|
||||||
"cleared": "Effacé",
|
"cleared": "Effacé",
|
||||||
"connected": "Connecté",
|
"connected": "Connecté",
|
||||||
"connected_to": "Connecté à {nom}",
|
"connected_to": "Connecté à {nom}",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Autorisation",
|
"authorization": "Autorisation",
|
||||||
"body": "Corps",
|
"body": "Corps",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Collections",
|
"collections": "Collections",
|
||||||
"documentation": "Documentation",
|
"documentation": "Documentation",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "En-têtes",
|
"headers": "En-têtes",
|
||||||
"history": "Histoire",
|
"history": "Histoire",
|
||||||
@@ -832,7 +689,7 @@
|
|||||||
"member_role_updated": "Rôles des utilisateurs mis à jour",
|
"member_role_updated": "Rôles des utilisateurs mis à jour",
|
||||||
"members": "Membres",
|
"members": "Membres",
|
||||||
"more_members": "+{count} more",
|
"more_members": "+{count} more",
|
||||||
"name_length_insufficient": "Le nom de l'équipe doit comporter au moins 6 caractères",
|
"name_length_insufficient": "Le nom de l'équipe doit comporter au moins 6 caractères",
|
||||||
"name_updated": "Nom de l'équipe mis à jour",
|
"name_updated": "Nom de l'équipe mis à jour",
|
||||||
"new": "Nouvelle équipe",
|
"new": "Nouvelle équipe",
|
||||||
"new_created": "Nouvelle équipe créée",
|
"new_created": "Nouvelle équipe créée",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "בחר קובץ",
|
"choose_file": "בחר קובץ",
|
||||||
"clear": "ברור",
|
"clear": "ברור",
|
||||||
"clear_all": "נקה הכל",
|
"clear_all": "נקה הכל",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "לְחַבֵּר",
|
"connect": "לְחַבֵּר",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "לְיַפּוֹת",
|
"prettify": "לְיַפּוֹת",
|
||||||
"remove": "לְהַסִיר",
|
"remove": "לְהַסִיר",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "לשחזר",
|
"restore": "לשחזר",
|
||||||
"save": "להציל",
|
"save": "להציל",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "לחפש",
|
"search": "לחפש",
|
||||||
"share": "לַחֲלוֹק",
|
"share": "לַחֲלוֹק",
|
||||||
"shortcuts": "קיצורי דרך",
|
"shortcuts": "קיצורי דרך",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "זַרקוֹר",
|
"spotlight": "זַרקוֹר",
|
||||||
"status": "סטָטוּס",
|
"status": "סטָטוּס",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "שם האוסף שונה",
|
"renamed": "שם האוסף שונה",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "שמור כ",
|
"save_as": "שמור כ",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "בחר אוסף",
|
"select": "בחר אוסף",
|
||||||
"select_location": "תבחר מיקום",
|
"select_location": "תבחר מיקום",
|
||||||
"select_team": "בחר צוות",
|
"select_team": "בחר צוות",
|
||||||
"team_collections": "אוספי צוות"
|
"team_collections": "אוספי צוות"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "האם אתה בטוח שאתה רוצה להתנתק?",
|
"logout": "האם אתה בטוח שאתה רוצה להתנתק?",
|
||||||
"remove_collection": "האם אתה בטוח שברצונך למחוק את האוסף הזה לצמיתות?",
|
"remove_collection": "האם אתה בטוח שברצונך למחוק את האוסף הזה לצמיתות?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "האם אתה בטוח שברצונך לסנכרן את סביבת העבודה הזו?"
|
"sync": "האם אתה בטוח שברצונך לסנכרן את סביבת העבודה הזו?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "כותרת {count}",
|
"header": "כותרת {count}",
|
||||||
"message": "הודעה {count}",
|
"message": "הודעה {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "צור סביבה חדשה",
|
"create_new": "צור סביבה חדשה",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "ערוך את הסביבה",
|
"edit": "ערוך את הסביבה",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "אנא ספק שם חוקי לסביבה",
|
"invalid_name": "אנא ספק שם חוקי לסביבה",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "סביבה חדשה",
|
"new": "סביבה חדשה",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "אין סביבה",
|
"no_environment": "אין סביבה",
|
||||||
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "בחר סביבה",
|
"select": "בחר סביבה",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "סביבות",
|
"title": "סביבות",
|
||||||
"updated": "Environment updation",
|
"updated": "Environment updation",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "רשימת משתנים"
|
"variable_list": "רשימת משתנים"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "אין משך זמן",
|
"no_duration": "אין משך זמן",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "לא ניתן להפעיל סקריפט של בקשה מראש",
|
"script_fail": "לא ניתן להפעיל סקריפט של בקשה מראש",
|
||||||
"something_went_wrong": "משהו השתבש",
|
"something_went_wrong": "משהו השתבש",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "שם התיקייה שונה"
|
"renamed": "שם התיקייה שונה"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "מוטציות",
|
"mutations": "מוטציות",
|
||||||
"schema": "סכֵימָה",
|
"schema": "סכֵימָה",
|
||||||
"subscriptions": "מנויים",
|
"subscriptions": "מנויים"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
||||||
"title": "יְבוּא"
|
"title": "יְבוּא"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "Vertical layout",
|
"column": "Vertical layout",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Horizontal layout"
|
"row": "Horizontal layout",
|
||||||
|
"zen_mode": "מצב זן"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "מטען",
|
"payload": "מטען",
|
||||||
"query": "שאילתא",
|
"query": "שאילתא",
|
||||||
"raw_body": "גוף בקשה גולמית",
|
"raw_body": "גוף בקשה גולמית",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "שם הבקשה שונה",
|
"renamed": "שם הבקשה שונה",
|
||||||
"run": "לָרוּץ",
|
"run": "לָרוּץ",
|
||||||
"save": "להציל",
|
"save": "להציל",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "הבקשה נשמרה",
|
"saved": "הבקשה נשמרה",
|
||||||
"share": "לַחֲלוֹק",
|
"share": "לַחֲלוֹק",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "בַּקָשָׁה",
|
"title": "בַּקָשָׁה",
|
||||||
"type": "סוג בקשה",
|
"type": "סוג בקשה",
|
||||||
"url": "כתובת URL",
|
"url": "כתובת URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "גוף תגובה",
|
"body": "גוף תגובה",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "כותרות",
|
"headers": "כותרות",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "סטָטוּס",
|
"status": "סטָטוּס",
|
||||||
"time": "זְמַן",
|
"time": "זְמַן",
|
||||||
"title": "תְגוּבָה",
|
"title": "תְגוּבָה",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "מחכה לחיבור",
|
"waiting_for_connection": "מחכה לחיבור",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "זהו שם התצוגה שלך.",
|
"account_name_description": "זהו שם התצוגה שלך.",
|
||||||
"background": "רקע כללי",
|
"background": "רקע כללי",
|
||||||
"black_mode": "שָׁחוֹר",
|
"black_mode": "שָׁחוֹר",
|
||||||
|
"change_font_size": "שנה גודל פונט",
|
||||||
"choose_language": "בחר שפה",
|
"choose_language": "בחר שפה",
|
||||||
"dark_mode": "אפל",
|
"dark_mode": "אפל",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "הרחבות",
|
"extensions": "הרחבות",
|
||||||
"extensions_use_toggle": "השתמש בתוסף הדפדפן כדי לשלוח בקשות (אם קיימות)",
|
"extensions_use_toggle": "השתמש בתוסף הדפדפן כדי לשלוח בקשות (אם קיימות)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "גודל גופן",
|
||||||
|
"font_size_large": "גָדוֹל",
|
||||||
|
"font_size_medium": "בינוני",
|
||||||
|
"font_size_small": "קָטָן",
|
||||||
"interceptor": "מיירט",
|
"interceptor": "מיירט",
|
||||||
"interceptor_description": "תוכנת ביניים בין יישום לממשקי API.",
|
"interceptor_description": "תוכנת ביניים בין יישום לממשקי API.",
|
||||||
"language": "שפה",
|
"language": "שפה",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "עבור אל דף ההגדרות",
|
"settings": "עבור אל דף ההגדרות",
|
||||||
"title": "ניווט"
|
"title": "ניווט"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "העתק קישור לבקשה",
|
"copy_request_link": "העתק קישור לבקשה",
|
||||||
"delete_method": "בחר שיטת DELETE",
|
"delete_method": "בחר שיטת DELETE",
|
||||||
"get_method": "בחר שיטת GET",
|
"get_method": "בחר שיטת GET",
|
||||||
"head_method": "בחר שיטת HEAD",
|
"head_method": "בחר שיטת HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "שיטה",
|
"method": "שיטה",
|
||||||
"next_method": "בחר בשיטה הבאה",
|
"next_method": "בחר בשיטה הבאה",
|
||||||
"post_method": "בחר שיטת POST",
|
"post_method": "בחר שיטת POST",
|
||||||
"previous_method": "בחר שיטה קודמת",
|
"previous_method": "בחר שיטה קודמת",
|
||||||
"put_method": "בחר שיטת PUT",
|
"put_method": "בחר שיטת PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "איפוס הבקשה",
|
"reset_request": "איפוס הבקשה",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "שמור באוספים",
|
"save_to_collections": "שמור באוספים",
|
||||||
"send_request": "שלח בקשה",
|
"send_request": "שלח בקשה",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "בַּקָשָׁה"
|
"title": "בַּקָשָׁה"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "עֵץ",
|
"log": "עֵץ",
|
||||||
"url": "כתובת URL"
|
"url": "כתובת URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "סוג אירוע",
|
"event_type": "סוג אירוע",
|
||||||
"log": "עֵץ",
|
"log": "עֵץ",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "הרשאה",
|
"authorization": "הרשאה",
|
||||||
"body": "גוּף",
|
"body": "גוּף",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "אוספים",
|
"collections": "אוספים",
|
||||||
"documentation": "תיעוד",
|
"documentation": "תיעוד",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "כותרות",
|
"headers": "כותרות",
|
||||||
"history": "הִיסטוֹרִיָה",
|
"history": "הִיסטוֹרִיָה",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "फ़ाइल चुनें",
|
"choose_file": "फ़ाइल चुनें",
|
||||||
"clear": "साफ़",
|
"clear": "साफ़",
|
||||||
"clear_all": "सभी साफ करें",
|
"clear_all": "सभी साफ करें",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "बंद करे",
|
"close": "बंद करे",
|
||||||
"connect": "कनेक्ट करें",
|
"connect": "कनेक्ट करें",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "पेस्ट",
|
"paste": "पेस्ट",
|
||||||
"prettify": "सुंदर करे",
|
"prettify": "सुंदर करे",
|
||||||
"remove": "हटाओ",
|
"remove": "हटाओ",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "पुनर्स्थापित करें",
|
"restore": "पुनर्स्थापित करें",
|
||||||
"save": "बचाएं",
|
"save": "बचाएं",
|
||||||
"scroll_to_bottom": "नीचे स्क्रॉल करें",
|
"scroll_to_bottom": "नीचे स्क्रॉल करें",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "खोज",
|
"search": "खोज",
|
||||||
"share": "बाँट",
|
"share": "बाँट",
|
||||||
"shortcuts": "शॉर्टकट",
|
"shortcuts": "शॉर्टकट",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "स्पॉटलाइट",
|
"spotlight": "स्पॉटलाइट",
|
||||||
"status": "स्थिति",
|
"status": "स्थिति",
|
||||||
"status_description": "वेबसाइट की स्थिति जांचें",
|
"status_description": "वेबसाइट की स्थिति जांचें",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "संग्रह का नाम बदला गया",
|
"renamed": "संग्रह का नाम बदला गया",
|
||||||
"request_in_use": "रिक्वेस्ट इन यूज़",
|
"request_in_use": "रिक्वेस्ट इन यूज़",
|
||||||
"save_as": "इस रूप में सेव करें",
|
"save_as": "इस रूप में सेव करें",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "एक संग्रह का चयन करें",
|
"select": "एक संग्रह का चयन करें",
|
||||||
"select_location": "स्थान चुनें",
|
"select_location": "स्थान चुनें",
|
||||||
"select_team": "एक टीम चुनें",
|
"select_team": "एक टीम चुनें",
|
||||||
"team_collections": "टीम संग्रह"
|
"team_collections": "टीम संग्रह"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "क्या आप वाकई इस टीम को छोड़ना चाहते हैं?",
|
"exit_team": "क्या आप वाकई इस टीम को छोड़ना चाहते हैं?",
|
||||||
"logout": "क्या आप वाकई लॉगआउट करना चाहते हैं?",
|
"logout": "क्या आप वाकई लॉगआउट करना चाहते हैं?",
|
||||||
"remove_collection": "क्या आप वाकई इस संग्रह को स्थायी रूप से हटाना चाहते हैं?",
|
"remove_collection": "क्या आप वाकई इस संग्रह को स्थायी रूप से हटाना चाहते हैं?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "क्या आप अपने कार्यक्षेत्र को क्लाउड से पुनर्स्थापित करना चाहेंगे? यह आपकी स्थानीय प्रगति को त्याग देगा।"
|
"sync": "क्या आप अपने कार्यक्षेत्र को क्लाउड से पुनर्स्थापित करना चाहेंगे? यह आपकी स्थानीय प्रगति को त्याग देगा।"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "हेडर {count}",
|
"header": "हेडर {count}",
|
||||||
"message": "मैसेज {count}",
|
"message": "मैसेज {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": " नया वातावरण बनाएं",
|
"create_new": " नया वातावरण बनाएं",
|
||||||
"created": " पर्यावरण बनाया",
|
"created": " पर्यावरण बनाया",
|
||||||
"deleted": " पर्यावरण विलोपन",
|
"deleted": " पर्यावरण विलोपन",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": " पर्यावरण संपादित करें",
|
"edit": " पर्यावरण संपादित करें",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": " कृपया पर्यावरण के लिए एक नाम प्रदान करें",
|
"invalid_name": " कृपया पर्यावरण के लिए एक नाम प्रदान करें",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": " नेस्टेड पर्यावरण चर 10 स्तरों तक सीमित हैं",
|
"nested_overflow": " नेस्टेड पर्यावरण चर 10 स्तरों तक सीमित हैं",
|
||||||
"new": " नया वातावरण",
|
"new": " नया वातावरण",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": " कोई वातावरण नहीं",
|
"no_environment": " कोई वातावरण नहीं",
|
||||||
"no_environment_description": " कोई परिवेश नहीं चुना गया था. चुनें कि निम्नलिखित चर के साथ क्या करना है।",
|
"no_environment_description": " कोई परिवेश नहीं चुना गया था. चुनें कि निम्नलिखित चर के साथ क्या करना है।",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": " पर्यावरण का चयन करें",
|
"select": " पर्यावरण का चयन करें",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": " वातावरण",
|
"title": " वातावरण",
|
||||||
"updated": " पर्यावरण अद्यतन",
|
"updated": " पर्यावरण अद्यतन",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": " परिवर्तनीय सूची"
|
"variable_list": " परिवर्तनीय सूची"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": " कोई अवधि नहीं",
|
"no_duration": " कोई अवधि नहीं",
|
||||||
"no_results_found": " कोई मेल नहीं मिले",
|
"no_results_found": " कोई मेल नहीं मिले",
|
||||||
"page_not_found": " यह पृष्ठ नहीं मिल सका",
|
"page_not_found": " यह पृष्ठ नहीं मिल सका",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": " पूर्व-अनुरोध स्क्रिप्ट निष्पादित नहीं कर सका",
|
"script_fail": " पूर्व-अनुरोध स्क्रिप्ट निष्पादित नहीं कर सका",
|
||||||
"something_went_wrong": " कुछ गलत हो गया",
|
"something_went_wrong": " कुछ गलत हो गया",
|
||||||
"test_script_fail": " अनुरोध के बाद स्क्रिप्ट निष्पादित नहीं कर सका"
|
"test_script_fail": " अनुरोध के बाद स्क्रिप्ट निष्पादित नहीं कर सका"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": " फ़ोल्डर का नाम बदला"
|
"renamed": " फ़ोल्डर का नाम बदला"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": " उत्परिवर्तन",
|
"mutations": " उत्परिवर्तन",
|
||||||
"schema": " योजना",
|
"schema": " योजना",
|
||||||
"subscriptions": " सदस्यता",
|
"subscriptions": " सदस्यता"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -305,7 +274,8 @@
|
|||||||
"pre_request_script": " पूर्व-अनुरोध स्क्रिप्ट जावास्क्रिप्ट में लिखी जाती हैं, और अनुरोध भेजे जाने से पहले चलाई जाती हैं।",
|
"pre_request_script": " पूर्व-अनुरोध स्क्रिप्ट जावास्क्रिप्ट में लिखी जाती हैं, और अनुरोध भेजे जाने से पहले चलाई जाती हैं।",
|
||||||
"script_fail": " ऐसा लगता है कि प्री-रिक्वेस्ट स्क्रिप्ट में गड़बड़ है। नीचे दी गई त्रुटि की जाँच करें और उसके अनुसार स्क्रिप्ट को ठीक करें।",
|
"script_fail": " ऐसा लगता है कि प्री-रिक्वेस्ट स्क्रिप्ट में गड़बड़ है। नीचे दी गई त्रुटि की जाँच करें और उसके अनुसार स्क्रिप्ट को ठीक करें।",
|
||||||
"test_script_fail": " ऐसा लगता है कि परीक्षण स्क्रिप्ट में कोई त्रुटि है। कृपया त्रुटियों को ठीक करें और फिर से परीक्षण चलाएं",
|
"test_script_fail": " ऐसा लगता है कि परीक्षण स्क्रिप्ट में कोई त्रुटि है। कृपया त्रुटियों को ठीक करें और फिर से परीक्षण चलाएं",
|
||||||
"tests": "Write a test script to automate debugging."
|
"tests": "Write a test script to automate debugging.",
|
||||||
|
"test": "डिबगिंग को स्वचालित करने के लिए एक परीक्षण स्क्रिप्ट लिखें"
|
||||||
},
|
},
|
||||||
"hide": {
|
"hide": {
|
||||||
"collection": "संग्रह पैनल संक्षिप्त करें",
|
"collection": "संग्रह पैनल संक्षिप्त करें",
|
||||||
@@ -338,36 +308,13 @@
|
|||||||
"json_description": "Hoppscotch Collections JSON फ़ाइल से संग्रह आयात करें",
|
"json_description": "Hoppscotch Collections JSON फ़ाइल से संग्रह आयात करें",
|
||||||
"title": "आयात करें"
|
"title": "आयात करें"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "संग्रह को संक्षिप्त या विस्तृत करें",
|
"collapse_collection": "संग्रह को संक्षिप्त या विस्तृत करें",
|
||||||
"collapse_sidebar": "साइडबार को संक्षिप्त या विस्तृत करें",
|
"collapse_sidebar": "साइडबार को संक्षिप्त या विस्तृत करें",
|
||||||
"column": "लंबवत लेआउट",
|
"column": "लंबवत लेआउट",
|
||||||
"name": "लेआउट",
|
"name": "लेआउट",
|
||||||
"row": "क्षैतिज लेआउट"
|
"row": "क्षैतिज लेआउट",
|
||||||
|
"zen_mode": "ज़ेन मोड"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +419,6 @@
|
|||||||
"payload": "पेलोड",
|
"payload": "पेलोड",
|
||||||
"query": "सवाल",
|
"query": "सवाल",
|
||||||
"raw_body": "कच्चे अनुरोध निकाय",
|
"raw_body": "कच्चे अनुरोध निकाय",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "अनुरोध नाम दिया गया",
|
"renamed": "अनुरोध नाम दिया गया",
|
||||||
"run": "दौड़ना",
|
"run": "दौड़ना",
|
||||||
"save": "बचाना",
|
"save": "बचाना",
|
||||||
@@ -480,7 +426,6 @@
|
|||||||
"saved": "अनुरोध सहेजा गया",
|
"saved": "अनुरोध सहेजा गया",
|
||||||
"share": "शेयर करना",
|
"share": "शेयर करना",
|
||||||
"share_description": "अपने दोस्तों के साथ hoppscotch साझा करें",
|
"share_description": "अपने दोस्तों के साथ hoppscotch साझा करें",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "प्रार्थना",
|
"title": "प्रार्थना",
|
||||||
"type": "अनुरोध का प्रकार",
|
"type": "अनुरोध का प्रकार",
|
||||||
"url": "यूआरएल",
|
"url": "यूआरएल",
|
||||||
@@ -488,7 +433,6 @@
|
|||||||
"view_my_links": "मेरे लिंक देखें"
|
"view_my_links": "मेरे लिंक देखें"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "प्रतिक्रिया निकाय",
|
"body": "प्रतिक्रिया निकाय",
|
||||||
"filter_response_body": "फ़िल्टर JSON रिस्पांस बॉडी (JSONPATH सिंटैक्स का उपयोग करता है)",
|
"filter_response_body": "फ़िल्टर JSON रिस्पांस बॉडी (JSONPATH सिंटैक्स का उपयोग करता है)",
|
||||||
"headers": "हेडर",
|
"headers": "हेडर",
|
||||||
@@ -502,7 +446,6 @@
|
|||||||
"status": "दर्जा",
|
"status": "दर्जा",
|
||||||
"time": "समय",
|
"time": "समय",
|
||||||
"title": "जवाब",
|
"title": "जवाब",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "जुडने के लिए इंतजार",
|
"waiting_for_connection": "जुडने के लिए इंतजार",
|
||||||
"xml": "एक्सएमएल"
|
"xml": "एक्सएमएल"
|
||||||
},
|
},
|
||||||
@@ -515,6 +458,7 @@
|
|||||||
"account_name_description": "यह आपका प्रदर्शन नाम है।",
|
"account_name_description": "यह आपका प्रदर्शन नाम है।",
|
||||||
"background": "पार्श्वभूमि",
|
"background": "पार्श्वभूमि",
|
||||||
"black_mode": "काला",
|
"black_mode": "काला",
|
||||||
|
"change_font_size": "फॉण्ट आकार बदलें",
|
||||||
"choose_language": "भाषा चुनें",
|
"choose_language": "भाषा चुनें",
|
||||||
"dark_mode": "अँधेरा",
|
"dark_mode": "अँधेरा",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +471,10 @@
|
|||||||
"extensions": "ब्राउज़र विस्तार",
|
"extensions": "ब्राउज़र विस्तार",
|
||||||
"extensions_use_toggle": "अनुरोध भेजने के लिए ब्राउज़र एक्सटेंशन का उपयोग करें (यदि मौजूद है)",
|
"extensions_use_toggle": "अनुरोध भेजने के लिए ब्राउज़र एक्सटेंशन का उपयोग करें (यदि मौजूद है)",
|
||||||
"follow": "हमारे पर का पालन करें",
|
"follow": "हमारे पर का पालन करें",
|
||||||
|
"font_size": "फ़ॉन्ट आकार",
|
||||||
|
"font_size_large": "विशाल",
|
||||||
|
"font_size_medium": "मध्यम",
|
||||||
|
"font_size_small": "छोटा",
|
||||||
"interceptor": "इंटरसेप्टर",
|
"interceptor": "इंटरसेप्टर",
|
||||||
"interceptor_description": "एप्लिकेशन और एपीआई के बीच मिडलवेयर।",
|
"interceptor_description": "एप्लिकेशन और एपीआई के बीच मिडलवेयर।",
|
||||||
"language": "भाषा",
|
"language": "भाषा",
|
||||||
@@ -591,27 +539,19 @@
|
|||||||
"settings": "सेटिंग्स पृष्ठ पर जाएं",
|
"settings": "सेटिंग्स पृष्ठ पर जाएं",
|
||||||
"title": "मार्गदर्शन"
|
"title": "मार्गदर्शन"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "कॉपी अनुरोध लिंक",
|
"copy_request_link": "कॉपी अनुरोध लिंक",
|
||||||
"delete_method": "हटाएं विधि का चयन करें",
|
"delete_method": "हटाएं विधि का चयन करें",
|
||||||
"get_method": "गेट विधि का चयन करें",
|
"get_method": "गेट विधि का चयन करें",
|
||||||
"head_method": "हेड विधि का चयन करें",
|
"head_method": "हेड विधि का चयन करें",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "तरीका",
|
"method": "तरीका",
|
||||||
"next_method": "अगली विधि का चयन करें",
|
"next_method": "अगली विधि का चयन करें",
|
||||||
"post_method": "पोस्ट विधि का चयन करें",
|
"post_method": "पोस्ट विधि का चयन करें",
|
||||||
"previous_method": "पिछली विधि का चयन करें",
|
"previous_method": "पिछली विधि का चयन करें",
|
||||||
"put_method": "पुट विधि का चयन करें",
|
"put_method": "पुट विधि का चयन करें",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "रीसेट अनुरोध",
|
"reset_request": "रीसेट अनुरोध",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "संग्रह के लिए सहेजें",
|
"save_to_collections": "संग्रह के लिए सहेजें",
|
||||||
"send_request": "अनुरोध भेजा",
|
"send_request": "अनुरोध भेजा",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "प्रार्थना"
|
"title": "प्रार्थना"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +581,6 @@
|
|||||||
"log": "लकड़ी का लट्ठा",
|
"log": "लकड़ी का लट्ठा",
|
||||||
"url": "यूआरएल"
|
"url": "यूआरएल"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "घटना प्रकार",
|
"event_type": "घटना प्रकार",
|
||||||
"log": "लकड़ी का लट्ठा",
|
"log": "लकड़ी का लट्ठा",
|
||||||
@@ -777,11 +638,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "प्राधिकार",
|
"authorization": "प्राधिकार",
|
||||||
"body": "शरीर",
|
"body": "शरीर",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "संग्रह",
|
"collections": "संग्रह",
|
||||||
"documentation": "प्रलेखन",
|
"documentation": "प्रलेखन",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "हेडर",
|
"headers": "हेडर",
|
||||||
"history": "इतिहास",
|
"history": "इतिहास",
|
||||||
|
|||||||
@@ -5,34 +5,32 @@
|
|||||||
"choose_file": "Válasszon egy fájlt",
|
"choose_file": "Válasszon egy fájlt",
|
||||||
"clear": "Törlés",
|
"clear": "Törlés",
|
||||||
"clear_all": "Összes törlése",
|
"clear_all": "Összes törlése",
|
||||||
"clear_history": "Clear all History",
|
"close": "Close",
|
||||||
"close": "Bezárás",
|
|
||||||
"connect": "Kapcsolódás",
|
"connect": "Kapcsolódás",
|
||||||
"connecting": "Kapcsolódás",
|
"connecting": "Connecting",
|
||||||
"copy": "Másolás",
|
"copy": "Másolás",
|
||||||
"delete": "Törlés",
|
"delete": "Törlés",
|
||||||
"disconnect": "Leválasztás",
|
"disconnect": "Leválasztás",
|
||||||
"dismiss": "Eltüntetés",
|
"dismiss": "Eltüntetés",
|
||||||
"dont_save": "Ne mentse",
|
"dont_save": "Ne mentse",
|
||||||
"download_file": "Fájl letöltése",
|
"download_file": "Fájl letöltése",
|
||||||
"drag_to_reorder": "Húzza az átrendezéshez",
|
"drag_to_reorder": "Drag to reorder",
|
||||||
"duplicate": "Kettőzés",
|
"duplicate": "Kettőzés",
|
||||||
"edit": "Szerkesztés",
|
"edit": "Szerkesztés",
|
||||||
"filter": "Szűrő",
|
"filter": "Filter",
|
||||||
"go_back": "Vissza",
|
"go_back": "Vissza",
|
||||||
"go_forward": "Előre",
|
"go_forward": "Go forward",
|
||||||
"group_by": "Csoportosítás",
|
"group_by": "Group by",
|
||||||
"label": "Címke",
|
"label": "Címke",
|
||||||
"learn_more": "Tudjon meg többet",
|
"learn_more": "Tudjon meg többet",
|
||||||
"less": "Kevesebb",
|
"less": "Kevesebb",
|
||||||
"more": "Több",
|
"more": "Több",
|
||||||
"new": "Új",
|
"new": "Új",
|
||||||
"no": "Nem",
|
"no": "Nem",
|
||||||
"open_workspace": "Munkaterület megnyitása",
|
"open_workspace": "Open workspace",
|
||||||
"paste": "Beillesztés",
|
"paste": "Beillesztés",
|
||||||
"prettify": "Csinosítás",
|
"prettify": "Csinosítás",
|
||||||
"remove": "Eltávolítás",
|
"remove": "Eltávolítás",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Visszaállítás",
|
"restore": "Visszaállítás",
|
||||||
"save": "Mentés",
|
"save": "Mentés",
|
||||||
"scroll_to_bottom": "Görgetés az aljára",
|
"scroll_to_bottom": "Görgetés az aljára",
|
||||||
@@ -40,7 +38,7 @@
|
|||||||
"search": "Keresés",
|
"search": "Keresés",
|
||||||
"send": "Küldés",
|
"send": "Küldés",
|
||||||
"start": "Indítás",
|
"start": "Indítás",
|
||||||
"starting": "Indítás",
|
"starting": "Starting",
|
||||||
"stop": "Leállítás",
|
"stop": "Leállítás",
|
||||||
"to_close": "a bezáráshoz",
|
"to_close": "a bezáráshoz",
|
||||||
"to_navigate": "a navigáláshoz",
|
"to_navigate": "a navigáláshoz",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Keresés",
|
"search": "Keresés",
|
||||||
"share": "Megosztás",
|
"share": "Megosztás",
|
||||||
"shortcuts": "Gyorsbillentyűk",
|
"shortcuts": "Gyorsbillentyűk",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Reflektorfény",
|
"spotlight": "Reflektorfény",
|
||||||
"status": "Állapot",
|
"status": "Állapot",
|
||||||
"status_description": "A weboldal állapotának ellenőrzése",
|
"status_description": "A weboldal állapotának ellenőrzése",
|
||||||
@@ -122,28 +118,25 @@
|
|||||||
},
|
},
|
||||||
"collection": {
|
"collection": {
|
||||||
"created": "Gyűjtemény létrehozva",
|
"created": "Gyűjtemény létrehozva",
|
||||||
"different_parent": "Nem lehet átrendezni a különböző szülővel rendelkező gyűjteményt",
|
"different_parent": "Cannot reorder collection with different parent",
|
||||||
"edit": "Gyűjtemény szerkesztése",
|
"edit": "Gyűjtemény szerkesztése",
|
||||||
"invalid_name": "Adjon nevet a gyűjteménynek",
|
"invalid_name": "Adjon nevet a gyűjteménynek",
|
||||||
"invalid_root_move": "A gyűjtemény már a gyökérben van",
|
"invalid_root_move": "Collection already in the root",
|
||||||
"moved": "Sikeresen áthelyezve",
|
"moved": "Moved Successfully",
|
||||||
"my_collections": "Saját gyűjtemények",
|
"my_collections": "Saját gyűjtemények",
|
||||||
"name": "Saját új gyűjtemény",
|
"name": "Saját új gyűjtemény",
|
||||||
"name_length_insufficient": "A gyűjtemény nevének legalább 3 karakter hosszúságúnak kell lennie",
|
"name_length_insufficient": "A gyűjtemény nevének legalább 3 karakter hosszúságúnak kell lennie",
|
||||||
"new": "Új gyűjtemény",
|
"new": "Új gyűjtemény",
|
||||||
"order_changed": "Gyűjtemény sorrendje frissítve",
|
"order_changed": "Collection Order Updated",
|
||||||
"renamed": "Gyűjtemény átnevezve",
|
"renamed": "Gyűjtemény átnevezve",
|
||||||
"request_in_use": "A kérés használatban",
|
"request_in_use": "A kérés használatban",
|
||||||
"save_as": "Mentés másként",
|
"save_as": "Mentés másként",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Gyűjtemény kiválasztása",
|
"select": "Gyűjtemény kiválasztása",
|
||||||
"select_location": "Hely kiválasztása",
|
"select_location": "Hely kiválasztása",
|
||||||
"select_team": "Csapat kiválasztása",
|
"select_team": "Csapat kiválasztása",
|
||||||
"team_collections": "Csapat gyűjteményei"
|
"team_collections": "Csapat gyűjteményei"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Biztosan el szeretné hagyni ezt a csapatot?",
|
"exit_team": "Biztosan el szeretné hagyni ezt a csapatot?",
|
||||||
"logout": "Biztosan ki szeretne jelentkezni?",
|
"logout": "Biztosan ki szeretne jelentkezni?",
|
||||||
"remove_collection": "Biztosan véglegesen törölni szeretné ezt a gyűjteményt?",
|
"remove_collection": "Biztosan véglegesen törölni szeretné ezt a gyűjteményt?",
|
||||||
@@ -154,14 +147,9 @@
|
|||||||
"remove_team": "Biztosan törölni szeretné ezt a csapatot?",
|
"remove_team": "Biztosan törölni szeretné ezt a csapatot?",
|
||||||
"remove_telemetry": "Biztosan ki szeretné kapcsolni a telemetriát?",
|
"remove_telemetry": "Biztosan ki szeretné kapcsolni a telemetriát?",
|
||||||
"request_change": "Biztosan el szeretné vetni a jelenlegi kérést? Minden mentetlen változtatás el fog veszni.",
|
"request_change": "Biztosan el szeretné vetni a jelenlegi kérést? Minden mentetlen változtatás el fog veszni.",
|
||||||
"save_unsaved_tab": "Szeretné menteni az ezen a lapon elvégzett változtatásokat?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Szeretné visszaállítani a munkaterületét a felhőből? Ez el fogja vetni a helyi folyamatát."
|
"sync": "Szeretné visszaállítani a munkaterületét a felhőből? Ez el fogja vetni a helyi folyamatát."
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "{count}. fejléc",
|
"header": "{count}. fejléc",
|
||||||
"message": "{count}. üzenet",
|
"message": "{count}. üzenet",
|
||||||
@@ -192,8 +180,8 @@
|
|||||||
"profile": "Jelentkezzen be a profilja megtekintéséhez",
|
"profile": "Jelentkezzen be a profilja megtekintéséhez",
|
||||||
"protocols": "A protokollok üresek",
|
"protocols": "A protokollok üresek",
|
||||||
"schema": "Kapcsolódjon egy GraphQL-végponthoz a séma megtekintéséhez",
|
"schema": "Kapcsolódjon egy GraphQL-végponthoz a séma megtekintéséhez",
|
||||||
"shortcodes": "A rövid kódok üresek",
|
"shortcodes": "Shortcodes are empty",
|
||||||
"subscription": "A feliratkozások üresek",
|
"subscription": "Subscriptions are empty",
|
||||||
"team_name": "A csapat neve üres",
|
"team_name": "A csapat neve üres",
|
||||||
"teams": "Ön nem tartozik semmilyen csapathoz",
|
"teams": "Ön nem tartozik semmilyen csapathoz",
|
||||||
"tests": "Nincsenek tesztek ehhez a kéréshez"
|
"tests": "Nincsenek tesztek ehhez a kéréshez"
|
||||||
@@ -204,40 +192,26 @@
|
|||||||
"create_new": "Új környezet létrehozása",
|
"create_new": "Új környezet létrehozása",
|
||||||
"created": "Környezet létrehozva",
|
"created": "Környezet létrehozva",
|
||||||
"deleted": "Környezet törlése",
|
"deleted": "Környezet törlése",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Környezet szerkesztése",
|
"edit": "Környezet szerkesztése",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Adjon nevet a környezetnek",
|
"invalid_name": "Adjon nevet a környezetnek",
|
||||||
"list": "Environment variables",
|
"my_environments": "My Environments",
|
||||||
"my_environments": "Saját környezetek",
|
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "az egymásba ágyazott környezeti változók 10 szintre vannak korlátozva",
|
"nested_overflow": "az egymásba ágyazott környezeti változók 10 szintre vannak korlátozva",
|
||||||
"new": "Új környezet",
|
"new": "Új környezet",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Nincs környezet",
|
"no_environment": "Nincs környezet",
|
||||||
"no_environment_description": "Nem lettek környezetek kiválasztva. Válassza ki, hogy mit kell tenni a következő változókkal.",
|
"no_environment_description": "Nem lettek környezetek kiválasztva. Válassza ki, hogy mit kell tenni a következő változókkal.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Környezet kiválasztása",
|
"select": "Környezet kiválasztása",
|
||||||
"set": "Set environment",
|
"team_environments": "Team Environments",
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Csapatkörnyezetek",
|
|
||||||
"title": "Környezetek",
|
"title": "Környezetek",
|
||||||
"updated": "Környezet frissítve",
|
"updated": "Környezet frissítve",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Változólista"
|
"variable_list": "Változólista"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"browser_support_sse": "Úgy tűnik, hogy ez a böngésző nem támogatja a kiszolgáló által küldött eseményeket.",
|
"browser_support_sse": "Úgy tűnik, hogy ez a böngésző nem támogatja a kiszolgáló által küldött eseményeket.",
|
||||||
"check_console_details": "Nézze meg a konzolnaplót a részletekért.",
|
"check_console_details": "Nézze meg a konzolnaplót a részletekért.",
|
||||||
"curl_invalid_format": "A cURL nincs megfelelően formázva",
|
"curl_invalid_format": "A cURL nincs megfelelően formázva",
|
||||||
"danger_zone": "Veszélyes zóna",
|
"danger_zone": "Danger zone",
|
||||||
"delete_account": "Az Ön fiókja jelenleg tulajdonos ezekben a csapatokban:",
|
"delete_account": "Your account is currently an owner in these teams:",
|
||||||
"delete_account_description": "El kell távolítani magát, át kell adnia a tulajdonjogot vagy törölnie kell ezeket a csapatokat, mielőtt törölhetné a fiókját.",
|
"delete_account_description": "You must either remove yourself, transfer ownership, or delete these teams before you can delete your account.",
|
||||||
"empty_req_name": "Üres kérésnév",
|
"empty_req_name": "Üres kérésnév",
|
||||||
"f12_details": "(F12 a részletekért)",
|
"f12_details": "(F12 a részletekért)",
|
||||||
"gql_prettify_invalid_query": "Nem sikerült csinosítani egy érvénytelen lekérdezést, oldja meg a lekérdezés szintaktikai hibáit, és próbálja újra",
|
"gql_prettify_invalid_query": "Nem sikerült csinosítani egy érvénytelen lekérdezést, oldja meg a lekérdezés szintaktikai hibáit, és próbálja újra",
|
||||||
@@ -245,14 +219,13 @@
|
|||||||
"incorrect_email": "Hibás e-mail",
|
"incorrect_email": "Hibás e-mail",
|
||||||
"invalid_link": "Érvénytelen hivatkozás",
|
"invalid_link": "Érvénytelen hivatkozás",
|
||||||
"invalid_link_description": "A kattintott hivatkozás érvénytelen vagy lejárt.",
|
"invalid_link_description": "A kattintott hivatkozás érvénytelen vagy lejárt.",
|
||||||
"json_parsing_failed": "Érvénytelen JSON",
|
"json_parsing_failed": "Invalid JSON",
|
||||||
"json_prettify_invalid_body": "Nem sikerült csinosítani egy érvénytelen törzset, oldja meg a JSON szintaktikai hibáit, és próbálja újra",
|
"json_prettify_invalid_body": "Nem sikerült csinosítani egy érvénytelen törzset, oldja meg a JSON szintaktikai hibáit, és próbálja újra",
|
||||||
"network_error": "Úgy tűnik, hogy hálózati hiba van. Próbálja újra.",
|
"network_error": "Úgy tűnik, hogy hálózati hiba van. Próbálja újra.",
|
||||||
"network_fail": "Nem sikerült elküldeni a kérést",
|
"network_fail": "Nem sikerült elküldeni a kérést",
|
||||||
"no_duration": "Nincs időtartam",
|
"no_duration": "Nincs időtartam",
|
||||||
"no_results_found": "Nincs találat",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "Ez az oldal nem található",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Nem sikerült végrehajtani a kérés előtti parancsfájlt",
|
"script_fail": "Nem sikerült végrehajtani a kérés előtti parancsfájlt",
|
||||||
"something_went_wrong": "Valami elromlott",
|
"something_went_wrong": "Valami elromlott",
|
||||||
"test_script_fail": "Nem sikerült végrehajtani a kérés utáni parancsfájlt"
|
"test_script_fail": "Nem sikerült végrehajtani a kérés utáni parancsfájlt"
|
||||||
@@ -265,9 +238,9 @@
|
|||||||
"title": "Exportálás"
|
"title": "Exportálás"
|
||||||
},
|
},
|
||||||
"filter": {
|
"filter": {
|
||||||
"all": "Összes",
|
"all": "All",
|
||||||
"none": "Nincs",
|
"none": "None",
|
||||||
"starred": "Csillagozott"
|
"starred": "Starred"
|
||||||
},
|
},
|
||||||
"folder": {
|
"folder": {
|
||||||
"created": "Mappa létrehozva",
|
"created": "Mappa létrehozva",
|
||||||
@@ -278,16 +251,12 @@
|
|||||||
"renamed": "Mappa átnevezve"
|
"renamed": "Mappa átnevezve"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutációk",
|
"mutations": "Mutációk",
|
||||||
"schema": "Séma",
|
"schema": "Séma",
|
||||||
"subscriptions": "Feliratkozások",
|
"subscriptions": "Feliratkozások"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Idő",
|
"time": "Time",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"header": {
|
"header": {
|
||||||
@@ -338,64 +307,41 @@
|
|||||||
"json_description": "Gyűjtemények importálása Hoppscotch-gyűjtemények JSON-fájlból",
|
"json_description": "Gyűjtemények importálása Hoppscotch-gyűjtemények JSON-fájlból",
|
||||||
"title": "Importálás"
|
"title": "Importálás"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Gyűjtemények összecsukása vagy kinyitása",
|
"collapse_collection": "Gyűjtemények összecsukása vagy kinyitása",
|
||||||
"collapse_sidebar": "Az oldalsáv összecsukása vagy kinyitása",
|
"collapse_sidebar": "Az oldalsáv összecsukása vagy kinyitása",
|
||||||
"column": "Függőleges elrendezés",
|
"column": "Függőleges elrendezés",
|
||||||
"name": "Elrendezés",
|
"name": "Elrendezés",
|
||||||
"row": "Vízszintes elrendezés"
|
"row": "Vízszintes elrendezés",
|
||||||
|
"zen_mode": "Zen mód"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "Elmentetlen változtatásai vannak",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
"collections": "Gyűjtemények",
|
"collections": "Gyűjtemények",
|
||||||
"confirm": "Megerősítés",
|
"confirm": "Megerősítés",
|
||||||
"edit_request": "Kérés szerkesztése",
|
"edit_request": "Kérés szerkesztése",
|
||||||
"import_export": "Importálás és exportálás"
|
"import_export": "Importálás és exportálás"
|
||||||
},
|
},
|
||||||
"mqtt": {
|
"mqtt": {
|
||||||
"already_subscribed": "Ön már feliratkozott erre a témára.",
|
"already_subscribed": "You are already subscribed to this topic.",
|
||||||
"clean_session": "Munkamenet törlése",
|
"clean_session": "Clean Session",
|
||||||
"clear_input": "Bevitel törlése",
|
"clear_input": "Clear input",
|
||||||
"clear_input_on_send": "Bevitel törlése küldéskor",
|
"clear_input_on_send": "Clear input on send",
|
||||||
"client_id": "Ügyfél-azonosító",
|
"client_id": "Client ID",
|
||||||
"color": "Válasszon színt",
|
"color": "Pick a color",
|
||||||
"communication": "Kommunikáció",
|
"communication": "Kommunikáció",
|
||||||
"connection_config": "Kapcsolat beállításai",
|
"connection_config": "Connection Config",
|
||||||
"connection_not_authorized": "Ez az MQTT-kapcsolat nem használ semmilyen hitelesítést.",
|
"connection_not_authorized": "This MQTT connection does not use any authentication.",
|
||||||
"invalid_topic": "Adjon témát a feliratkozáshoz",
|
"invalid_topic": "Please provide a topic for the subscription",
|
||||||
"keep_alive": "Életben tartás",
|
"keep_alive": "Keep Alive",
|
||||||
"log": "Napló",
|
"log": "Napló",
|
||||||
"lw_message": "Utolsó kívánság üzenet",
|
"lw_message": "Last-Will Message",
|
||||||
"lw_qos": "Utolsó kívánság QoS",
|
"lw_qos": "Last-Will QoS",
|
||||||
"lw_retain": "Utolsó kívánság megtartás",
|
"lw_retain": "Last-Will Retain",
|
||||||
"lw_topic": "Utolsó kívánság téma",
|
"lw_topic": "Last-Will Topic",
|
||||||
"message": "Üzenet",
|
"message": "Üzenet",
|
||||||
"new": "Új feliratkozás",
|
"new": "New Subscription",
|
||||||
"not_connected": "Először indítson egy MQTT-kapcsolatot.",
|
"not_connected": "Please start a MQTT connection first.",
|
||||||
"publish": "Közzététel",
|
"publish": "Közzététel",
|
||||||
"qos": "QoS",
|
"qos": "QoS",
|
||||||
"ssl": "SSL",
|
"ssl": "SSL",
|
||||||
@@ -422,7 +368,7 @@
|
|||||||
},
|
},
|
||||||
"profile": {
|
"profile": {
|
||||||
"app_settings": "Alkalmazás beállításai",
|
"app_settings": "Alkalmazás beállításai",
|
||||||
"default_hopp_displayname": "Névtelen felhasználó",
|
"default_hopp_displayname": "Unnamed User",
|
||||||
"editor": "Szerkesztő",
|
"editor": "Szerkesztő",
|
||||||
"editor_description": "A szerkesztők hozzáadhatnak, szerkeszthetnek és törölhetnek kéréseket.",
|
"editor_description": "A szerkesztők hozzáadhatnak, szerkeszthetnek és törölhetnek kéréseket.",
|
||||||
"email_verification_mail": "Egy ellenőrző e-mail el lett küldve az e-mail-címére. Kattintson a hivatkozásra az e-mail-címe ellenőrzéséhez.",
|
"email_verification_mail": "Egy ellenőrző e-mail el lett küldve az e-mail-címére. Kattintson a hivatkozásra az e-mail-címe ellenőrzéséhez.",
|
||||||
@@ -445,26 +391,26 @@
|
|||||||
"choose_language": "Nyelv kiválasztása",
|
"choose_language": "Nyelv kiválasztása",
|
||||||
"content_type": "Tartalom típusa",
|
"content_type": "Tartalom típusa",
|
||||||
"content_type_titles": {
|
"content_type_titles": {
|
||||||
"others": "Egyebek",
|
"others": "Others",
|
||||||
"structured": "Szerkesztett",
|
"structured": "Structured",
|
||||||
"text": "Szöveg"
|
"text": "Text"
|
||||||
},
|
},
|
||||||
"copy_link": "Hivatkozás másolása",
|
"copy_link": "Hivatkozás másolása",
|
||||||
"different_collection": "Nem lehet átrendezni a különböző gyűjteményekből érkező kéréseket",
|
"different_collection": "Cannot reorder requests from different collections",
|
||||||
"duplicated": "Kérés megkettőzve",
|
"duplicated": "Request duplicated",
|
||||||
"duration": "Időtartam",
|
"duration": "Időtartam",
|
||||||
"enter_curl": "cURL-parancs megadása",
|
"enter_curl": "cURL megadása",
|
||||||
"generate_code": "Kód előállítása",
|
"generate_code": "Kód előállítása",
|
||||||
"generated_code": "Előállított kód",
|
"generated_code": "Előállított kód",
|
||||||
"header_list": "Fejléclista",
|
"header_list": "Fejléclista",
|
||||||
"invalid_name": "Adjon nevet a kérésnek",
|
"invalid_name": "Adjon nevet a kérésnek",
|
||||||
"method": "Módszer",
|
"method": "Módszer",
|
||||||
"moved": "Kérés áthelyezve",
|
"moved": "Request moved",
|
||||||
"name": "Kérés neve",
|
"name": "Kérés neve",
|
||||||
"new": "Új kérés",
|
"new": "Új kérés",
|
||||||
"order_changed": "Kérés sorrendje frissítve",
|
"order_changed": "Request Order Updated",
|
||||||
"override": "Felülbírálás",
|
"override": "Felülbírálás",
|
||||||
"override_help": "<kbd>Content-Type</kbd> beállítása a fejlécekben",
|
"override_help": "A <kbd>Content-Type</kbd> beállítása a fejlécekben",
|
||||||
"overriden": "Felülbírálva",
|
"overriden": "Felülbírálva",
|
||||||
"parameter_list": "Lekérdezési paraméterek",
|
"parameter_list": "Lekérdezési paraméterek",
|
||||||
"parameters": "Paraméterek",
|
"parameters": "Paraméterek",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Hasznos teher",
|
"payload": "Hasznos teher",
|
||||||
"query": "Lekérdezés",
|
"query": "Lekérdezés",
|
||||||
"raw_body": "Nyers kéréstörzs",
|
"raw_body": "Nyers kéréstörzs",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Kérés átnevezve",
|
"renamed": "Kérés átnevezve",
|
||||||
"run": "Futtatás",
|
"run": "Futtatás",
|
||||||
"save": "Mentés",
|
"save": "Mentés",
|
||||||
@@ -480,17 +425,15 @@
|
|||||||
"saved": "Kérés elmentve",
|
"saved": "Kérés elmentve",
|
||||||
"share": "Megosztás",
|
"share": "Megosztás",
|
||||||
"share_description": "A Hoppscotch megosztása az ismerőseivel",
|
"share_description": "A Hoppscotch megosztása az ismerőseivel",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Kérés",
|
"title": "Kérés",
|
||||||
"type": "Kérés típusa",
|
"type": "Kérés típusa",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
"variables": "Változók",
|
"variables": "Változók",
|
||||||
"view_my_links": "Saját hivatkozások megtekintése"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Hang",
|
|
||||||
"body": "Válasz törzse",
|
"body": "Válasz törzse",
|
||||||
"filter_response_body": "JSON-válasz törzsének szűrése (JSONPath szintaxist használ)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Fejlécek",
|
"headers": "Fejlécek",
|
||||||
"html": "HTML",
|
"html": "HTML",
|
||||||
"image": "Kép",
|
"image": "Kép",
|
||||||
@@ -502,23 +445,23 @@
|
|||||||
"status": "Állapot",
|
"status": "Állapot",
|
||||||
"time": "Idő",
|
"time": "Idő",
|
||||||
"title": "Válasz",
|
"title": "Válasz",
|
||||||
"video": "Videó",
|
|
||||||
"waiting_for_connection": "várakozás kapcsolódásra",
|
"waiting_for_connection": "várakozás kapcsolódásra",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
"settings": {
|
"settings": {
|
||||||
"accent_color": "Kiemelőszín",
|
"accent_color": "Kiemelőszín",
|
||||||
"account": "Fiók",
|
"account": "Fiók",
|
||||||
"account_deleted": "A fiókja törölve lett",
|
"account_deleted": "Your account has been deleted",
|
||||||
"account_description": "A fiókbeállítások személyre szabása.",
|
"account_description": "A fiókbeállítások személyre szabása.",
|
||||||
"account_email_description": "Az Ön elsődleges e-mail-címe.",
|
"account_email_description": "Az Ön elsődleges e-mail-címe.",
|
||||||
"account_name_description": "Ez a megjelenített neve.",
|
"account_name_description": "Ez a megjelenített neve.",
|
||||||
"background": "Háttér",
|
"background": "Háttér",
|
||||||
"black_mode": "Fekete",
|
"black_mode": "Fekete",
|
||||||
|
"change_font_size": "Betűméret megváltoztatása",
|
||||||
"choose_language": "Nyelv kiválasztása",
|
"choose_language": "Nyelv kiválasztása",
|
||||||
"dark_mode": "Sötét",
|
"dark_mode": "Sötét",
|
||||||
"delete_account": "Fiók törlése",
|
"delete_account": "Delete account",
|
||||||
"delete_account_description": "Ha törli a fiókját, akkor az összes adata véglegesen törlésre kerül. Ezt a műveletet nem lehet visszavonni.",
|
"delete_account_description": "Once you delete your account, all your data will be permanently deleted. This action cannot be undone.",
|
||||||
"expand_navigation": "Navigáció kinyitása",
|
"expand_navigation": "Navigáció kinyitása",
|
||||||
"experiments": "Kísérletek",
|
"experiments": "Kísérletek",
|
||||||
"experiments_notice": "Ez olyan kísérletek gyűjteménye, amelyeken dolgozunk, és amelyek hasznosak, szórakoztatóak lehetnek, mindkettő, vagy egyik sem. Ezek nem véglegesek és nem stabilak, ezért ha valami túl furcsa dolog történik, ne essen pánikba. Egyszerűen kapcsolja ki a hibás dolgot. Viccet félretéve, ",
|
"experiments_notice": "Ez olyan kísérletek gyűjteménye, amelyeken dolgozunk, és amelyek hasznosak, szórakoztatóak lehetnek, mindkettő, vagy egyik sem. Ezek nem véglegesek és nem stabilak, ezért ha valami túl furcsa dolog történik, ne essen pánikba. Egyszerűen kapcsolja ki a hibás dolgot. Viccet félretéve, ",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Böngészőkiterjesztés",
|
"extensions": "Böngészőkiterjesztés",
|
||||||
"extensions_use_toggle": "A böngészőkiterjesztés használata a kérések küldéséhez (ha jelen van)",
|
"extensions_use_toggle": "A böngészőkiterjesztés használata a kérések küldéséhez (ha jelen van)",
|
||||||
"follow": "Kövessen minket",
|
"follow": "Kövessen minket",
|
||||||
|
"font_size": "Betűméret",
|
||||||
|
"font_size_large": "Nagy",
|
||||||
|
"font_size_medium": "Közepes",
|
||||||
|
"font_size_small": "Kicsi",
|
||||||
"interceptor": "Elfogó",
|
"interceptor": "Elfogó",
|
||||||
"interceptor_description": "Középprogram az alkalmazás és az API-k között.",
|
"interceptor_description": "Középprogram az alkalmazás és az API-k között.",
|
||||||
"language": "Nyelv",
|
"language": "Nyelv",
|
||||||
@@ -541,8 +488,8 @@
|
|||||||
"proxy_use_toggle": "A proxy középprogram használata a kérések küldéséhez",
|
"proxy_use_toggle": "A proxy középprogram használata a kérések küldéséhez",
|
||||||
"read_the": "Olvassa el:",
|
"read_the": "Olvassa el:",
|
||||||
"reset_default": "Visszaállítás az alapértelmezettre",
|
"reset_default": "Visszaállítás az alapértelmezettre",
|
||||||
"short_codes": "Rövid kódok",
|
"short_codes": "Short codes",
|
||||||
"short_codes_description": "Az Ön által létrehozott rövid kódok.",
|
"short_codes_description": "Short codes which were created by you.",
|
||||||
"sidebar_on_left": "Oldalsáv a bal oldalon",
|
"sidebar_on_left": "Oldalsáv a bal oldalon",
|
||||||
"sync": "Szinkronizálás",
|
"sync": "Szinkronizálás",
|
||||||
"sync_collections": "Gyűjtemények",
|
"sync_collections": "Gyűjtemények",
|
||||||
@@ -556,16 +503,16 @@
|
|||||||
"theme_description": "Az alkalmazás témájának személyre szabása.",
|
"theme_description": "Az alkalmazás témájának személyre szabása.",
|
||||||
"use_experimental_url_bar": "Kísérleti URL-sáv használata a környezet kiemelésével",
|
"use_experimental_url_bar": "Kísérleti URL-sáv használata a környezet kiemelésével",
|
||||||
"user": "Felhasználó",
|
"user": "Felhasználó",
|
||||||
"verified_email": "Ellenőrzött e-mail-cím",
|
"verified_email": "Verified email",
|
||||||
"verify_email": "E-mail-cím ellenőrzése"
|
"verify_email": "E-mail-cím ellenőrzése"
|
||||||
},
|
},
|
||||||
"shortcodes": {
|
"shortcodes": {
|
||||||
"actions": "Műveletek",
|
"actions": "Actions",
|
||||||
"created_on": "Létrehozva",
|
"created_on": "Created on",
|
||||||
"deleted": "Rövid kód törölve",
|
"deleted": "Shortcode deleted",
|
||||||
"method": "Módszer",
|
"method": "Method",
|
||||||
"not_found": "A rövid kód nem található",
|
"not_found": "Shortcode not found",
|
||||||
"short_code": "Rövid kód",
|
"short_code": "Short code",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"shortcut": {
|
"shortcut": {
|
||||||
@@ -591,33 +538,25 @@
|
|||||||
"settings": "Ugrás a beállítások oldalra",
|
"settings": "Ugrás a beállítások oldalra",
|
||||||
"title": "Navigáció"
|
"title": "Navigáció"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Kérés hivatkozásának másolása",
|
"copy_request_link": "Kérés hivatkozásának másolása",
|
||||||
"delete_method": "DELETE módszer kiválasztása",
|
"delete_method": "DELETE módszer kiválasztása",
|
||||||
"get_method": "GET módszer kiválasztása",
|
"get_method": "GET módszer kiválasztása",
|
||||||
"head_method": "HEAD módszer kiválasztása",
|
"head_method": "HEAD módszer kiválasztása",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Módszer",
|
"method": "Módszer",
|
||||||
"next_method": "Következő módszer kiválasztása",
|
"next_method": "Következő módszer kiválasztása",
|
||||||
"post_method": "POST módszer kiválasztása",
|
"post_method": "POST módszer kiválasztása",
|
||||||
"previous_method": "Előző módszer kiválasztása",
|
"previous_method": "Előző módszer kiválasztása",
|
||||||
"put_method": "PUT módszer kiválasztása",
|
"put_method": "PUT módszer kiválasztása",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Kérés visszaállítása",
|
"reset_request": "Kérés visszaállítása",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Mentés a gyűjteményekbe",
|
"save_to_collections": "Mentés a gyűjteményekbe",
|
||||||
"send_request": "Kérés elküldése",
|
"send_request": "Kérés elküldése",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Kérés"
|
"title": "Kérés"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"copy": "Válasz másolása a vágólapra",
|
"copy": "Copy response to clipboard",
|
||||||
"download": "Válasz letöltés fájlként",
|
"download": "Download response as file",
|
||||||
"title": "Válasz"
|
"title": "Response"
|
||||||
},
|
},
|
||||||
"theme": {
|
"theme": {
|
||||||
"black": "Téma átváltása fekete módra",
|
"black": "Téma átváltása fekete módra",
|
||||||
@@ -635,91 +574,12 @@
|
|||||||
},
|
},
|
||||||
"socketio": {
|
"socketio": {
|
||||||
"communication": "Kommunikáció",
|
"communication": "Kommunikáció",
|
||||||
"connection_not_authorized": "Ez a SocketIO-kapcsolat nem használ semmilyen hitelesítést.",
|
"connection_not_authorized": "This SocketIO connection does not use any authentication.",
|
||||||
"event_name": "Esemény vagy téma neve",
|
"event_name": "Esemény neve",
|
||||||
"events": "Események",
|
"events": "Események",
|
||||||
"log": "Napló",
|
"log": "Napló",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Esemény típusa",
|
"event_type": "Esemény típusa",
|
||||||
"log": "Napló",
|
"log": "Napló",
|
||||||
@@ -732,9 +592,9 @@
|
|||||||
"connected": "Kapcsolódva",
|
"connected": "Kapcsolódva",
|
||||||
"connected_to": "Kapcsolódva ehhez: {name}",
|
"connected_to": "Kapcsolódva ehhez: {name}",
|
||||||
"connecting_to": "Kapcsolódás ehhez: {name}…",
|
"connecting_to": "Kapcsolódás ehhez: {name}…",
|
||||||
"connection_error": "Nem sikerült kapcsolódni",
|
"connection_error": "Failed to connect",
|
||||||
"connection_failed": "A kapcsolódás sikertelen",
|
"connection_failed": "Connection failed",
|
||||||
"connection_lost": "A kapcsolat elveszett",
|
"connection_lost": "Connection lost",
|
||||||
"copied_to_clipboard": "Vágólapra másolva",
|
"copied_to_clipboard": "Vágólapra másolva",
|
||||||
"deleted": "Törölve",
|
"deleted": "Törölve",
|
||||||
"deprecated": "ELAVULT",
|
"deprecated": "ELAVULT",
|
||||||
@@ -749,17 +609,17 @@
|
|||||||
"history_deleted": "Előzmények törölve",
|
"history_deleted": "Előzmények törölve",
|
||||||
"linewrap": "Sorok tördelése",
|
"linewrap": "Sorok tördelése",
|
||||||
"loading": "Betöltés…",
|
"loading": "Betöltés…",
|
||||||
"message_received": "Üzenet: {message} érkezett ehhez a témához: {topic}",
|
"message_received": "Message: {message} arrived on topic: {topic}",
|
||||||
"mqtt_subscription_failed": "Valami elromlott a következő témára való feliratkozás során: {topic}",
|
"mqtt_subscription_failed": "Something went wrong while subscribing to topic: {topic}",
|
||||||
"none": "Nincs",
|
"none": "Nincs",
|
||||||
"nothing_found": "Semmi sem található ehhez:",
|
"nothing_found": "Semmi sem található ehhez:",
|
||||||
"published_error": "Valami elromlott a következő üzenet közzététele során: {topic}, ehhez a témához: {message}",
|
"published_error": "Something went wrong while publishing msg: {topic} to topic: {message}",
|
||||||
"published_message": "Közzétett üzenet: {message}, ehhez a témához: {topic}",
|
"published_message": "Published message: {message} to topic: {topic}",
|
||||||
"reconnection_error": "Nem sikerült újrakapcsolódni",
|
"reconnection_error": "Failed to reconnect",
|
||||||
"subscribed_failed": "Nem sikerült feliratkozni erre a témára: {topic}",
|
"subscribed_failed": "Failed to subscribe to topic: {topic}",
|
||||||
"subscribed_success": "Sikeresen feliratkozott erre a témára: {topic}",
|
"subscribed_success": "Successfully subscribed to topic: {topic}",
|
||||||
"unsubscribed_failed": "Nem sikerült leiratkozni erről a témáról: {topic}",
|
"unsubscribed_failed": "Failed to unsubscribe from topic: {topic}",
|
||||||
"unsubscribed_success": "Sikeresen leiratkozott erről a témáról: {topic}",
|
"unsubscribed_success": "Successfully unsubscribed from topic: {topic}",
|
||||||
"waiting_send_request": "Várakozás a kérés elküldésére"
|
"waiting_send_request": "Várakozás a kérés elküldésére"
|
||||||
},
|
},
|
||||||
"support": {
|
"support": {
|
||||||
@@ -777,12 +637,9 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Felhatalmazás",
|
"authorization": "Felhatalmazás",
|
||||||
"body": "Törzs",
|
"body": "Törzs",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Gyűjtemények",
|
"collections": "Gyűjtemények",
|
||||||
"documentation": "Dokumentáció",
|
"documentation": "Dokumentáció",
|
||||||
"duplicate": "Duplicate Tab",
|
"environments": "Environments",
|
||||||
"environments": "Környezetek",
|
|
||||||
"headers": "Fejlécek",
|
"headers": "Fejlécek",
|
||||||
"history": "Előzmények",
|
"history": "Előzmények",
|
||||||
"mqtt": "MQTT",
|
"mqtt": "MQTT",
|
||||||
@@ -807,7 +664,7 @@
|
|||||||
"email_do_not_match": "Az e-mail-cím nem egyezik a fiókja részleteivel. Vegye fel a kapcsolatot a csapat tulajdonosával.",
|
"email_do_not_match": "Az e-mail-cím nem egyezik a fiókja részleteivel. Vegye fel a kapcsolatot a csapat tulajdonosával.",
|
||||||
"exit": "Kilépés a csapatból",
|
"exit": "Kilépés a csapatból",
|
||||||
"exit_disabled": "Csak a tulajdonos nem léphet ki a csapatból",
|
"exit_disabled": "Csak a tulajdonos nem léphet ki a csapatból",
|
||||||
"invalid_coll_id": "Érvénytelen gyűjteményazonosító",
|
"invalid_coll_id": "Invalid collection ID",
|
||||||
"invalid_email_format": "Az e-mail formátuma érvénytelen",
|
"invalid_email_format": "Az e-mail formátuma érvénytelen",
|
||||||
"invalid_id": "Érvénytelen csapatazonosító. Vegye fel a kapcsolatot a csapat tulajdonosával.",
|
"invalid_id": "Érvénytelen csapatazonosító. Vegye fel a kapcsolatot a csapat tulajdonosával.",
|
||||||
"invalid_invite_link": "Érvénytelen meghívási hivatkozás",
|
"invalid_invite_link": "Érvénytelen meghívási hivatkozás",
|
||||||
@@ -831,7 +688,7 @@
|
|||||||
"member_removed": "Felhasználó eltávolítva",
|
"member_removed": "Felhasználó eltávolítva",
|
||||||
"member_role_updated": "Felhasználói szerepek frissítve",
|
"member_role_updated": "Felhasználói szerepek frissítve",
|
||||||
"members": "Tagok",
|
"members": "Tagok",
|
||||||
"more_members": "+{count} további",
|
"more_members": "+{count} more",
|
||||||
"name_length_insufficient": "A csapat nevének legalább 6 karakter hosszúságúnak kell lennie",
|
"name_length_insufficient": "A csapat nevének legalább 6 karakter hosszúságúnak kell lennie",
|
||||||
"name_updated": "Csapatnév frissítve",
|
"name_updated": "Csapatnév frissítve",
|
||||||
"new": "Új csapat",
|
"new": "Új csapat",
|
||||||
@@ -839,13 +696,13 @@
|
|||||||
"new_name": "Saját új csapat",
|
"new_name": "Saját új csapat",
|
||||||
"no_access": "Nincs szerkesztési jogosultsága ezekhez a gyűjteményekhez",
|
"no_access": "Nincs szerkesztési jogosultsága ezekhez a gyűjteményekhez",
|
||||||
"no_invite_found": "A meghívás nem található. Vegye fel a kapcsolatot a csapat tulajdonosával.",
|
"no_invite_found": "A meghívás nem található. Vegye fel a kapcsolatot a csapat tulajdonosával.",
|
||||||
"no_request_found": "A kérés nem található.",
|
"no_request_found": "Request not found.",
|
||||||
"not_found": "A csapat nem található. Vegye fel a kapcsolatot a csapat tulajdonosával.",
|
"not_found": "A csapat nem található. Vegye fel a kapcsolatot a csapat tulajdonosával.",
|
||||||
"not_valid_viewer": "Ön nem érvényes megtekintő. Vegye fel a kapcsolatot a csapat tulajdonosával.",
|
"not_valid_viewer": "Ön nem érvényes megtekintő. Vegye fel a kapcsolatot a csapat tulajdonosával.",
|
||||||
"parent_coll_move": "Nem lehet áthelyezni a gyűjteményt egy gyermekgyűjteménybe",
|
"parent_coll_move": "Cannot move collection to a child collection",
|
||||||
"pending_invites": "Függőben lévő meghívások",
|
"pending_invites": "Függőben lévő meghívások",
|
||||||
"permissions": "Jogosultságok",
|
"permissions": "Jogosultságok",
|
||||||
"same_target_destination": "Ugyanaz a cél és célhely",
|
"same_target_destination": "Same target and destination",
|
||||||
"saved": "Csapat elmentve",
|
"saved": "Csapat elmentve",
|
||||||
"select_a_team": "Csapat kiválasztása",
|
"select_a_team": "Csapat kiválasztása",
|
||||||
"title": "Csapatok",
|
"title": "Csapatok",
|
||||||
@@ -853,9 +710,9 @@
|
|||||||
"we_sent_invite_link_description": "Kérje meg az összes meghívottat, hogy nézzék meg a beérkező leveleiket. Kattintsanak a hivatkozásra a csapathoz való csatlakozáshoz."
|
"we_sent_invite_link_description": "Kérje meg az összes meghívottat, hogy nézzék meg a beérkező leveleiket. Kattintsanak a hivatkozásra a csapathoz való csatlakozáshoz."
|
||||||
},
|
},
|
||||||
"team_environment": {
|
"team_environment": {
|
||||||
"deleted": "Környezet törölve",
|
"deleted": "Environment Deleted",
|
||||||
"duplicate": "Környezet megkettőzve",
|
"duplicate": "Environment Duplicated",
|
||||||
"not_found": "A környezet nem található."
|
"not_found": "Environment not found."
|
||||||
},
|
},
|
||||||
"test": {
|
"test": {
|
||||||
"failed": "teszt sikertelen",
|
"failed": "teszt sikertelen",
|
||||||
@@ -875,9 +732,9 @@
|
|||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"workspace": {
|
"workspace": {
|
||||||
"change": "Munkaterület váltása",
|
"change": "Change workspace",
|
||||||
"personal": "Saját munkaterület",
|
"personal": "My Workspace",
|
||||||
"team": "Csapat-munkaterület",
|
"team": "Team Workspace",
|
||||||
"title": "Munkaterületek"
|
"title": "Workspaces"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Pilih file",
|
"choose_file": "Pilih file",
|
||||||
"clear": "Bersihkan",
|
"clear": "Bersihkan",
|
||||||
"clear_all": "Bersihkan semua",
|
"clear_all": "Bersihkan semua",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Tutup",
|
"close": "Tutup",
|
||||||
"connect": "Sambungkan",
|
"connect": "Sambungkan",
|
||||||
"connecting": "Menyambungkan",
|
"connecting": "Menyambungkan",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Tempel",
|
"paste": "Tempel",
|
||||||
"prettify": "Prettify",
|
"prettify": "Prettify",
|
||||||
"remove": "Hapus",
|
"remove": "Hapus",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Pulihkan",
|
"restore": "Pulihkan",
|
||||||
"save": "Simpan",
|
"save": "Simpan",
|
||||||
"scroll_to_bottom": "Gulir ke bawah",
|
"scroll_to_bottom": "Gulir ke bawah",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Mencari",
|
"search": "Mencari",
|
||||||
"share": "Membagikan",
|
"share": "Membagikan",
|
||||||
"shortcuts": "Jalan pintas",
|
"shortcuts": "Jalan pintas",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Menyoroti",
|
"spotlight": "Menyoroti",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"status_description": "Periksa status situs web",
|
"status_description": "Periksa status situs web",
|
||||||
@@ -122,28 +118,25 @@
|
|||||||
},
|
},
|
||||||
"collection": {
|
"collection": {
|
||||||
"created": "Koleksi dibuat",
|
"created": "Koleksi dibuat",
|
||||||
"different_parent": "Tidak dapat mengubah urutan koleksi dengan induk yang berbeda",
|
"different_parent": "Cannot reorder collection with different parent",
|
||||||
"edit": "Mengubah Koleksi",
|
"edit": "Mengubah Koleksi",
|
||||||
"invalid_name": "Berikan nama untuk Koleksi",
|
"invalid_name": "Berikan nama untuk Koleksi",
|
||||||
"invalid_root_move": "Koleksi sudah berada di akar direktori",
|
"invalid_root_move": "Collection already in the root",
|
||||||
"moved": "Berhasil Dipindahkan",
|
"moved": "Moved Successfully",
|
||||||
"my_collections": "Koleksi Saya",
|
"my_collections": "Koleksi Saya",
|
||||||
"name": "Koleksi Baru Saya",
|
"name": "Koleksi Baru Saya",
|
||||||
"name_length_insufficient": "Nama koleksi harus minimal 3 karakter",
|
"name_length_insufficient": "Nama koleksi harus minimal 3 karakter",
|
||||||
"new": "Koleksi baru",
|
"new": "Koleksi baru",
|
||||||
"order_changed": "Pembaruan Urutan Koleksi",
|
"order_changed": "Collection Order Updated",
|
||||||
"renamed": "Koleksi berganti nama",
|
"renamed": "Koleksi berganti nama",
|
||||||
"request_in_use": "Permintaan sedang digunakan",
|
"request_in_use": "Permintaan sedang digunakan",
|
||||||
"save_as": "Simpan Sebagai",
|
"save_as": "Simpan Sebagai",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Pilih Koleksi",
|
"select": "Pilih Koleksi",
|
||||||
"select_location": "Pilih lokasi",
|
"select_location": "Pilih lokasi",
|
||||||
"select_team": "Pilih tim",
|
"select_team": "Pilih team",
|
||||||
"team_collections": "Koleksi Tim"
|
"team_collections": "Koleksi Tim"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Apakah Anda yakin ingin keluar dari tim ini?",
|
"exit_team": "Apakah Anda yakin ingin keluar dari tim ini?",
|
||||||
"logout": "Apakah Anda yakin ingin keluar?",
|
"logout": "Apakah Anda yakin ingin keluar?",
|
||||||
"remove_collection": "Apakah Anda yakin ingin menghapus koleksi ini secara permanen?",
|
"remove_collection": "Apakah Anda yakin ingin menghapus koleksi ini secara permanen?",
|
||||||
@@ -154,14 +147,9 @@
|
|||||||
"remove_team": "Apakah Anda yakin ingin menghapus tim ini?",
|
"remove_team": "Apakah Anda yakin ingin menghapus tim ini?",
|
||||||
"remove_telemetry": "Apakah Anda yakin ingin menyisih dari Telemetri?",
|
"remove_telemetry": "Apakah Anda yakin ingin menyisih dari Telemetri?",
|
||||||
"request_change": "Apakah Anda yakin ingin membuang permintaan saat ini, perubahan yang belum disimpan akan hilang.",
|
"request_change": "Apakah Anda yakin ingin membuang permintaan saat ini, perubahan yang belum disimpan akan hilang.",
|
||||||
"save_unsaved_tab": "Apakah Anda ingin menyimpan perubahan yang dibuat di tab ini?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Apakah Anda ingin memulihkan ruang kerja Anda dari cloud? Ini akan membuang kemajuan lokal Anda."
|
"sync": "Apakah Anda ingin memulihkan ruang kerja Anda dari cloud? Ini akan membuang kemajuan lokal Anda."
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Header {count}",
|
"header": "Header {count}",
|
||||||
"message": "Pesan {count}",
|
"message": "Pesan {count}",
|
||||||
@@ -192,8 +180,8 @@
|
|||||||
"profile": "Masuk untuk melihat profil Anda",
|
"profile": "Masuk untuk melihat profil Anda",
|
||||||
"protocols": "Protokol kosong",
|
"protocols": "Protokol kosong",
|
||||||
"schema": "Hubungkan ke endpoint GraphQL untuk melihat skema",
|
"schema": "Hubungkan ke endpoint GraphQL untuk melihat skema",
|
||||||
"shortcodes": "Shortcodes kosong",
|
"shortcodes": "Shortcodes are empty",
|
||||||
"subscription": "Langganan kosong",
|
"subscription": "Subscriptions are empty",
|
||||||
"team_name": "Nama team kosong",
|
"team_name": "Nama team kosong",
|
||||||
"teams": "Kamu bukan di team manapun",
|
"teams": "Kamu bukan di team manapun",
|
||||||
"tests": "Tidak ada tes untuk permintaan ini"
|
"tests": "Tidak ada tes untuk permintaan ini"
|
||||||
@@ -201,34 +189,20 @@
|
|||||||
"environment": {
|
"environment": {
|
||||||
"add_to_global": "Tambahkan ke Global",
|
"add_to_global": "Tambahkan ke Global",
|
||||||
"added": "Tambahan Environment",
|
"added": "Tambahan Environment",
|
||||||
"create_new": "Membuat environment baru",
|
"create_new": "Membuat baru environment",
|
||||||
"created": "Environment dibuat",
|
"created": "Environment dibuat",
|
||||||
"deleted": "Environment dihapus",
|
"deleted": "Environment dihapus",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Sunting Environment",
|
"edit": "Sunting Environment",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Tolong beri nama untuk environment",
|
"invalid_name": "Tolong beri nama untuk environment",
|
||||||
"list": "Environment variables",
|
"my_environments": "My Environments",
|
||||||
"my_environments": "Environment Saya",
|
"nested_overflow": "variabel environment bersarang dibatasi hingga 10 level",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "Variabel environment bersarang dibatasi hingga 10 level",
|
|
||||||
"new": "Environment Baru",
|
"new": "Environment Baru",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "No environment",
|
"no_environment": "No environment",
|
||||||
"no_environment_description": "Tidak ada environment yang dipilih. Pilih apa yang harus dilakukan dengan variabel berikut.",
|
"no_environment_description": "Tidak ada environment yang dipilih. Pilih apa yang harus dilakukan dengan variabel berikut.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Pilih environment",
|
"select": "Pilih environment",
|
||||||
"set": "Set environment",
|
"team_environments": "Team Environments",
|
||||||
"set_as_environment": "Set as environment",
|
"title": "Environments",
|
||||||
"team_environments": "Environment Tim",
|
|
||||||
"title": "Environment",
|
|
||||||
"updated": "Environment diperbarui",
|
"updated": "Environment diperbarui",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Daftar Variable"
|
"variable_list": "Daftar Variable"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -236,8 +210,8 @@
|
|||||||
"check_console_details": "Periksa console log untuk detailnya.",
|
"check_console_details": "Periksa console log untuk detailnya.",
|
||||||
"curl_invalid_format": "cURL tidak diformat dengan benar",
|
"curl_invalid_format": "cURL tidak diformat dengan benar",
|
||||||
"danger_zone": "Danger zone",
|
"danger_zone": "Danger zone",
|
||||||
"delete_account": "Akun Anda saat ini merupakan pemilik dalam tim-tim ini:",
|
"delete_account": "Your account is currently an owner in these teams:",
|
||||||
"delete_account_description": "Anda harus menghapus diri Anda dari tim-tim ini, mentransfer kepemilikan, atau menghapus tim-tim ini sebelum Anda dapat menghapus akun Anda.",
|
"delete_account_description": "You must either remove yourself, transfer ownership, or delete these teams before you can delete your account.",
|
||||||
"empty_req_name": "Nama Permintaan Kosong",
|
"empty_req_name": "Nama Permintaan Kosong",
|
||||||
"f12_details": "(F12 untuk detailnya)",
|
"f12_details": "(F12 untuk detailnya)",
|
||||||
"gql_prettify_invalid_query": "Tidak dapat prettify kueri yang tidak valid, menyelesaikan kesalahan sintaksis kueri, dan coba lagi",
|
"gql_prettify_invalid_query": "Tidak dapat prettify kueri yang tidak valid, menyelesaikan kesalahan sintaksis kueri, dan coba lagi",
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Tidak ada durasi",
|
"no_duration": "Tidak ada durasi",
|
||||||
"no_results_found": "Tidak ada kecocokan yang ditemukan",
|
"no_results_found": "Tidak ada kecocokan yang ditemukan",
|
||||||
"page_not_found": "Halaman ini tidak dapat ditemukan",
|
"page_not_found": "Halaman ini tidak dapat ditemukan",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Tidak dapat menjalankan pre-request script",
|
"script_fail": "Tidak dapat menjalankan pre-request script",
|
||||||
"something_went_wrong": "Ada yang salah",
|
"something_went_wrong": "Ada yang salah",
|
||||||
"test_script_fail": "Tidak dapat mengeksekusi post-request script"
|
"test_script_fail": "Tidak dapat mengeksekusi post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Folder berganti nama"
|
"renamed": "Folder berganti nama"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutations",
|
"mutations": "Mutations",
|
||||||
"schema": "Schema",
|
"schema": "Schema",
|
||||||
"subscriptions": "Subscriptions",
|
"subscriptions": "Subscriptions"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -325,7 +294,7 @@
|
|||||||
"from_json_description": "Impor dari Hoppscotch berkas koleksi",
|
"from_json_description": "Impor dari Hoppscotch berkas koleksi",
|
||||||
"from_my_collections": "Impor dari Koleksi Saya",
|
"from_my_collections": "Impor dari Koleksi Saya",
|
||||||
"from_my_collections_description": "Impor dari Berkas Koleksi Saya",
|
"from_my_collections_description": "Impor dari Berkas Koleksi Saya",
|
||||||
"from_openapi": "Impor dari OpenAPI",
|
"from_openapi": "Import dari OpenAPI",
|
||||||
"from_openapi_description": "Impor dari OpenAPI syarat berkas (YML/JSON)",
|
"from_openapi_description": "Impor dari OpenAPI syarat berkas (YML/JSON)",
|
||||||
"from_postman": "Impor dari Postman",
|
"from_postman": "Impor dari Postman",
|
||||||
"from_postman_description": "Impor dari Koleksi Postman",
|
"from_postman_description": "Impor dari Koleksi Postman",
|
||||||
@@ -338,55 +307,32 @@
|
|||||||
"json_description": "Impor Koleksi dari berkas JSON Koleksi Hoppscotch",
|
"json_description": "Impor Koleksi dari berkas JSON Koleksi Hoppscotch",
|
||||||
"title": "Impor"
|
"title": "Impor"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Ciutkan atau Perluas Collections",
|
"collapse_collection": "Ciutkan atau Perluas Collections",
|
||||||
"collapse_sidebar": "Ciutkan atau Perluas sidebar",
|
"collapse_sidebar": "Ciutkan atau Perluas sidebar",
|
||||||
"column": "Vertikal layout",
|
"column": "Vertikal layout",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Horisontal layout"
|
"row": "Horisontal layout",
|
||||||
|
"zen_mode": "Zen mode"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "Anda memiliki perubahan yang belum disimpan",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
"collections": "Koleksi",
|
"collections": "Koleksi",
|
||||||
"confirm": "Mengonfirmasi",
|
"confirm": "Mengonfirmasi",
|
||||||
"edit_request": "Edit Request",
|
"edit_request": "Edit Request",
|
||||||
"import_export": "Impor / Ekspor"
|
"import_export": "Impor / Ekspor"
|
||||||
},
|
},
|
||||||
"mqtt": {
|
"mqtt": {
|
||||||
"already_subscribed": "Anda sudah berlangganan topik ini.",
|
"already_subscribed": "You are already subscribed to this topic.",
|
||||||
"clean_session": "Sesi Bersih",
|
"clean_session": "Clean Session",
|
||||||
"clear_input": "Hapus input",
|
"clear_input": "Clear input",
|
||||||
"clear_input_on_send": "Hapus input saat mengirim",
|
"clear_input_on_send": "Clear input on send",
|
||||||
"client_id": "Client ID",
|
"client_id": "Client ID",
|
||||||
"color": "Pilih warna",
|
"color": "Pick a color",
|
||||||
"communication": "Komunikasi",
|
"communication": "Komunikasi",
|
||||||
"connection_config": "Konfigurasi Koneksi",
|
"connection_config": "Connection Config",
|
||||||
"connection_not_authorized": "Koneksi MQTT ini tidak menggunakan otentikasi",
|
"connection_not_authorized": "This MQTT connection does not use any authentication.",
|
||||||
"invalid_topic": "Harap berikan topik untuk langganan",
|
"invalid_topic": "Please provide a topic for the subscription",
|
||||||
"keep_alive": "Keep Alive",
|
"keep_alive": "Keep Alive",
|
||||||
"log": "Log",
|
"log": "Log",
|
||||||
"lw_message": "Last-Will Message",
|
"lw_message": "Last-Will Message",
|
||||||
@@ -394,8 +340,8 @@
|
|||||||
"lw_retain": "Last-Will Retain",
|
"lw_retain": "Last-Will Retain",
|
||||||
"lw_topic": "Last-Will Topic",
|
"lw_topic": "Last-Will Topic",
|
||||||
"message": "Pesan",
|
"message": "Pesan",
|
||||||
"new": "Langganan Baru",
|
"new": "New Subscription",
|
||||||
"not_connected": "Mulai koneksi MQTT terlebih dahulu",
|
"not_connected": "Please start a MQTT connection first.",
|
||||||
"publish": "Menerbitkan",
|
"publish": "Menerbitkan",
|
||||||
"qos": "QoS",
|
"qos": "QoS",
|
||||||
"ssl": "SSL",
|
"ssl": "SSL",
|
||||||
@@ -450,19 +396,19 @@
|
|||||||
"text": "Text"
|
"text": "Text"
|
||||||
},
|
},
|
||||||
"copy_link": "Salin tautan",
|
"copy_link": "Salin tautan",
|
||||||
"different_collection": "Tidak dapat mengubah urutan permintaan dari koleksi yang berbeda",
|
"different_collection": "Cannot reorder requests from different collections",
|
||||||
"duplicated": "Request duplicated",
|
"duplicated": "Request duplicated",
|
||||||
"duration": "Durasi",
|
"duration": "Durasi",
|
||||||
"enter_curl": "Masukkan cURL",
|
"enter_curl": "Masukkan cURL",
|
||||||
"generate_code": "Hasilkan kode",
|
"generate_code": "Generate code",
|
||||||
"generated_code": "Hasilkan kode",
|
"generated_code": "Generated code",
|
||||||
"header_list": "Daftar Header",
|
"header_list": "Daftar Header",
|
||||||
"invalid_name": "Harap berikan nama untuk request",
|
"invalid_name": "Harap berikan nama untuk request",
|
||||||
"method": "Method",
|
"method": "Method",
|
||||||
"moved": "Request moved",
|
"moved": "Request moved",
|
||||||
"name": "Request nama",
|
"name": "Request nama",
|
||||||
"new": "Request baru",
|
"new": "Request baru",
|
||||||
"order_changed": "Urutan Request Diperbarui",
|
"order_changed": "Request Order Updated",
|
||||||
"override": "Membatalkan",
|
"override": "Membatalkan",
|
||||||
"override_help": "Set <kbd>Content-Type</kbd> in Headers",
|
"override_help": "Set <kbd>Content-Type</kbd> in Headers",
|
||||||
"overriden": "Diganti",
|
"overriden": "Diganti",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Payload",
|
"payload": "Payload",
|
||||||
"query": "Query",
|
"query": "Query",
|
||||||
"raw_body": "Raw Request Body",
|
"raw_body": "Raw Request Body",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Request berganti nama",
|
"renamed": "Request berganti nama",
|
||||||
"run": "Jalankan",
|
"run": "Jalankan",
|
||||||
"save": "Menyimpan",
|
"save": "Menyimpan",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Request disimpan",
|
"saved": "Request disimpan",
|
||||||
"share": "Membagikan",
|
"share": "Membagikan",
|
||||||
"share_description": "Bagikan Hoppscotch dengan teman-teman Anda",
|
"share_description": "Bagikan Hoppscotch dengan teman-teman Anda",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Request",
|
"title": "Request",
|
||||||
"type": "Tipe Request",
|
"type": "Tipe Request",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "Lihat tautan saya"
|
"view_my_links": "Lihat tautan saya"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Response Body",
|
"body": "Response Body",
|
||||||
"filter_response_body": "Filter body respons JSON (menggunakan sintaks JSONPath)",
|
"filter_response_body": "Filter body respons JSON (menggunakan sintaks JSONPath)",
|
||||||
"headers": "Headers",
|
"headers": "Headers",
|
||||||
@@ -502,19 +445,19 @@
|
|||||||
"status": "Status",
|
"status": "Status",
|
||||||
"time": "Waktu",
|
"time": "Waktu",
|
||||||
"title": "Response",
|
"title": "Response",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "Menunggu koneksi",
|
"waiting_for_connection": "Menunggu koneksi",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
"settings": {
|
"settings": {
|
||||||
"accent_color": "Accent color",
|
"accent_color": "Accent color",
|
||||||
"account": "Akun",
|
"account": "Akun",
|
||||||
"account_deleted": "Akun Anda telah dihapus",
|
"account_deleted": "Your account has been deleted",
|
||||||
"account_description": "Sesuaikan pengaturan akun Anda.",
|
"account_description": "Sesuaikan pengaturan akun Anda.",
|
||||||
"account_email_description": "Alamat surel utama Anda.",
|
"account_email_description": "Alamat surel utama Anda.",
|
||||||
"account_name_description": "Ini adalah nama tampilan Anda.",
|
"account_name_description": "Ini adalah nama tampilan Anda.",
|
||||||
"background": "Latar belakang",
|
"background": "Latar belakang",
|
||||||
"black_mode": "Hitam",
|
"black_mode": "Hitam",
|
||||||
|
"change_font_size": "Ubah ukuran font",
|
||||||
"choose_language": "Pilih bahasa",
|
"choose_language": "Pilih bahasa",
|
||||||
"dark_mode": "Gelap",
|
"dark_mode": "Gelap",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Ekstensi Peramban",
|
"extensions": "Ekstensi Peramban",
|
||||||
"extensions_use_toggle": "Gunakan ekstensi peramban untuk mengirim permintaan (jika ada)",
|
"extensions_use_toggle": "Gunakan ekstensi peramban untuk mengirim permintaan (jika ada)",
|
||||||
"follow": "Ikuti kami",
|
"follow": "Ikuti kami",
|
||||||
|
"font_size": "Ukuran huruf",
|
||||||
|
"font_size_large": "Besar",
|
||||||
|
"font_size_medium": "Sedang",
|
||||||
|
"font_size_small": "Kecil",
|
||||||
"interceptor": "Pencegat",
|
"interceptor": "Pencegat",
|
||||||
"interceptor_description": "Middleware antara aplikasi dan API.",
|
"interceptor_description": "Middleware antara aplikasi dan API.",
|
||||||
"language": "Bahasa",
|
"language": "Bahasa",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Pergi ke halaman Pengaturan",
|
"settings": "Pergi ke halaman Pengaturan",
|
||||||
"title": "Navigasi"
|
"title": "Navigasi"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Salin Tautan Permintaan",
|
"copy_request_link": "Salin Tautan Permintaan",
|
||||||
"delete_method": "Pilih metode DELETE",
|
"delete_method": "Pilih metode DELETE",
|
||||||
"get_method": "Pilih metode GET",
|
"get_method": "Pilih metode GET",
|
||||||
"head_method": "Pilih metode HEAD",
|
"head_method": "Pilih metode HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "metode",
|
"method": "metode",
|
||||||
"next_method": "Pilih metode Next",
|
"next_method": "Pilih metode Next",
|
||||||
"post_method": "Pilih metode POST",
|
"post_method": "Pilih metode POST",
|
||||||
"previous_method": "Pilih metode Previous",
|
"previous_method": "Pilih metode Previous",
|
||||||
"put_method": "Pilih metode PUT",
|
"put_method": "Pilih metode PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Mengatur ulang Request",
|
"reset_request": "Mengatur ulang Request",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Menyimpan ke Collections",
|
"save_to_collections": "Menyimpan ke Collections",
|
||||||
"send_request": "Kirim Request",
|
"send_request": "Kirim Request",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Request"
|
"title": "Request"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Log",
|
"log": "Log",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Tipe Event",
|
"event_type": "Tipe Event",
|
||||||
"log": "Log",
|
"log": "Log",
|
||||||
@@ -747,7 +607,7 @@
|
|||||||
"file_imported": "File diimpor",
|
"file_imported": "File diimpor",
|
||||||
"finished_in": "Selesai dalam {duration} ms",
|
"finished_in": "Selesai dalam {duration} ms",
|
||||||
"history_deleted": "Riwayat dihapus",
|
"history_deleted": "Riwayat dihapus",
|
||||||
"linewrap": "Bungkus baris",
|
"linewrap": "Wrap lines",
|
||||||
"loading": "Memuat...",
|
"loading": "Memuat...",
|
||||||
"message_received": "Pesan: {message} tiba di topik: {topic}",
|
"message_received": "Pesan: {message} tiba di topik: {topic}",
|
||||||
"mqtt_subscription_failed": "Terjadi masalah saat berlangganan topik: {topic}",
|
"mqtt_subscription_failed": "Terjadi masalah saat berlangganan topik: {topic}",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Authorization",
|
"authorization": "Authorization",
|
||||||
"body": "Body",
|
"body": "Body",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Collections",
|
"collections": "Collections",
|
||||||
"documentation": "Dokumentasi",
|
"documentation": "Dokumentasi",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Headers",
|
"headers": "Headers",
|
||||||
"history": "Riwayat",
|
"history": "Riwayat",
|
||||||
@@ -807,7 +664,7 @@
|
|||||||
"email_do_not_match": "Surel tidak cocok dengan detail akun Anda. Hubungi pemilik tim Anda.",
|
"email_do_not_match": "Surel tidak cocok dengan detail akun Anda. Hubungi pemilik tim Anda.",
|
||||||
"exit": "Keluar dari Tim",
|
"exit": "Keluar dari Tim",
|
||||||
"exit_disabled": "Hanya pemilik yang tidak dapat keluar dari tim",
|
"exit_disabled": "Hanya pemilik yang tidak dapat keluar dari tim",
|
||||||
"invalid_coll_id": "ID koleksi tidak valid",
|
"invalid_coll_id": "Invalid collection ID",
|
||||||
"invalid_email_format": "Format surel tidak valid",
|
"invalid_email_format": "Format surel tidak valid",
|
||||||
"invalid_id": "ID tim tidak valid. Hubungi pemilik tim Anda.",
|
"invalid_id": "ID tim tidak valid. Hubungi pemilik tim Anda.",
|
||||||
"invalid_invite_link": "Tautan undangan tidak valid",
|
"invalid_invite_link": "Tautan undangan tidak valid",
|
||||||
@@ -831,7 +688,7 @@
|
|||||||
"member_removed": "Pengguna dihapus",
|
"member_removed": "Pengguna dihapus",
|
||||||
"member_role_updated": "Peran pengguna diperbarui",
|
"member_role_updated": "Peran pengguna diperbarui",
|
||||||
"members": "Anggota",
|
"members": "Anggota",
|
||||||
"more_members": "+{count} lebih",
|
"more_members": "+{count} more",
|
||||||
"name_length_insufficient": "Nama tim harus setidaknya 6 karakter",
|
"name_length_insufficient": "Nama tim harus setidaknya 6 karakter",
|
||||||
"name_updated": "Nama tim diperbarui",
|
"name_updated": "Nama tim diperbarui",
|
||||||
"new": "Tim Baru",
|
"new": "Tim Baru",
|
||||||
@@ -839,13 +696,13 @@
|
|||||||
"new_name": "Tim baru saya",
|
"new_name": "Tim baru saya",
|
||||||
"no_access": "Anda tidak memiliki akses edit ke collections ini",
|
"no_access": "Anda tidak memiliki akses edit ke collections ini",
|
||||||
"no_invite_found": "Undangan tidak ditemukan. Hubungi pemilik tim Anda.",
|
"no_invite_found": "Undangan tidak ditemukan. Hubungi pemilik tim Anda.",
|
||||||
"no_request_found": "Request tidak ditemukan.",
|
"no_request_found": "Request not found.",
|
||||||
"not_found": "Tim tidak ditemukan. Hubungi pemilik tim Anda.",
|
"not_found": "Tim tidak ditemukan. Hubungi pemilik tim Anda.",
|
||||||
"not_valid_viewer": "Anda bukan penonton yang valid. Hubungi pemilik tim Anda.",
|
"not_valid_viewer": "Anda bukan penonton yang valid. Hubungi pemilik tim Anda.",
|
||||||
"parent_coll_move": "Tidak dapat memindahkan koleksi ke dalam koleksi anak",
|
"parent_coll_move": "Cannot move collection to a child collection",
|
||||||
"pending_invites": "Undangan tertunda",
|
"pending_invites": "Undangan tertunda",
|
||||||
"permissions": "Izin",
|
"permissions": "Izin",
|
||||||
"same_target_destination": "Sama tujuan dan destinasi",
|
"same_target_destination": "Same target and destination",
|
||||||
"saved": "Tim disimpan",
|
"saved": "Tim disimpan",
|
||||||
"select_a_team": "Pilih tim",
|
"select_a_team": "Pilih tim",
|
||||||
"title": "tim",
|
"title": "tim",
|
||||||
@@ -853,9 +710,9 @@
|
|||||||
"we_sent_invite_link_description": "Minta semua undangan untuk memeriksa kotak masuk mereka. Klik tautan untuk bergabung dengan tim."
|
"we_sent_invite_link_description": "Minta semua undangan untuk memeriksa kotak masuk mereka. Klik tautan untuk bergabung dengan tim."
|
||||||
},
|
},
|
||||||
"team_environment": {
|
"team_environment": {
|
||||||
"deleted": "Environment dihapus",
|
"deleted": "Environment Deleted",
|
||||||
"duplicate": "Environment diduplikasi",
|
"duplicate": "Environment Duplicated",
|
||||||
"not_found": "Environment tidak ditemukan."
|
"not_found": "Environment not found."
|
||||||
},
|
},
|
||||||
"test": {
|
"test": {
|
||||||
"failed": "Tes gagal",
|
"failed": "Tes gagal",
|
||||||
@@ -875,9 +732,9 @@
|
|||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"workspace": {
|
"workspace": {
|
||||||
"change": "Beralih workspace",
|
"change": "Change workspace",
|
||||||
"personal": "Workspace Saya",
|
"personal": "My Workspace",
|
||||||
"team": "Workspace Tim",
|
"team": "Team Workspace",
|
||||||
"title": "Workspaces"
|
"title": "Workspaces"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Scegli un file",
|
"choose_file": "Scegli un file",
|
||||||
"clear": "Cancella",
|
"clear": "Cancella",
|
||||||
"clear_all": "Cancella tutto",
|
"clear_all": "Cancella tutto",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Connetti",
|
"connect": "Connetti",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "Abbellisci",
|
"prettify": "Abbellisci",
|
||||||
"remove": "Rimuovi",
|
"remove": "Rimuovi",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Ripristina",
|
"restore": "Ripristina",
|
||||||
"save": "Salva",
|
"save": "Salva",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Cerca",
|
"search": "Cerca",
|
||||||
"share": "Condividi",
|
"share": "Condividi",
|
||||||
"shortcuts": "Scorciatoie",
|
"shortcuts": "Scorciatoie",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Riflettore",
|
"spotlight": "Riflettore",
|
||||||
"status": "Stato",
|
"status": "Stato",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Raccolta rinominata",
|
"renamed": "Raccolta rinominata",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Salva come",
|
"save_as": "Salva come",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Seleziona una raccolta",
|
"select": "Seleziona una raccolta",
|
||||||
"select_location": "Seleziona la posizione",
|
"select_location": "Seleziona la posizione",
|
||||||
"select_team": "Seleziona un team",
|
"select_team": "Seleziona un team",
|
||||||
"team_collections": "Raccolte di team"
|
"team_collections": "Raccolte di team"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Sei sicuro di voler uscire?",
|
"logout": "Sei sicuro di voler uscire?",
|
||||||
"remove_collection": "Sei sicuro di voler eliminare definitivamente questa raccolta?",
|
"remove_collection": "Sei sicuro di voler eliminare definitivamente questa raccolta?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Vuoi ripristinare il tuo spazio di lavoro con quello del cloud? Questo annullerà le tue modifiche fatte in locale."
|
"sync": "Vuoi ripristinare il tuo spazio di lavoro con quello del cloud? Questo annullerà le tue modifiche fatte in locale."
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Intestazione {count}",
|
"header": "Intestazione {count}",
|
||||||
"message": "Messaggio {count}",
|
"message": "Messaggio {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Crea un nuovo ambiente",
|
"create_new": "Crea un nuovo ambiente",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Modifica ambiente",
|
"edit": "Modifica ambiente",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Si prega di fornire un nome valido per l'ambiente",
|
"invalid_name": "Si prega di fornire un nome valido per l'ambiente",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "Nuovo ambiente",
|
"new": "Nuovo ambiente",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Nessun ambiente",
|
"no_environment": "Nessun ambiente",
|
||||||
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Seleziona ambiente",
|
"select": "Seleziona ambiente",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Ambienti",
|
"title": "Ambienti",
|
||||||
"updated": "Environment updation",
|
"updated": "Environment updation",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Elenco variabili"
|
"variable_list": "Elenco variabili"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Nessuna durata",
|
"no_duration": "Nessuna durata",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Impossibile eseguire lo script di pre-richiesta",
|
"script_fail": "Impossibile eseguire lo script di pre-richiesta",
|
||||||
"something_went_wrong": "Qualcosa è andato storto",
|
"something_went_wrong": "Qualcosa è andato storto",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Cartella rinominata"
|
"renamed": "Cartella rinominata"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutazioni",
|
"mutations": "Mutazioni",
|
||||||
"schema": "Schema",
|
"schema": "Schema",
|
||||||
"subscriptions": "Sottoscrizioni",
|
"subscriptions": "Sottoscrizioni"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
||||||
"title": "Importa"
|
"title": "Importa"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "Disposizione verticale",
|
"column": "Disposizione verticale",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Disposizione orizzontale"
|
"row": "Disposizione orizzontale",
|
||||||
|
"zen_mode": "Modalità zen"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Contenuto (Payload)",
|
"payload": "Contenuto (Payload)",
|
||||||
"query": "Query",
|
"query": "Query",
|
||||||
"raw_body": "Corpo della richiesta non formattato",
|
"raw_body": "Corpo della richiesta non formattato",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Richiesta rinominata",
|
"renamed": "Richiesta rinominata",
|
||||||
"run": "Esegui",
|
"run": "Esegui",
|
||||||
"save": "Salva",
|
"save": "Salva",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Richiesta salvata",
|
"saved": "Richiesta salvata",
|
||||||
"share": "Condividi",
|
"share": "Condividi",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Richiesta",
|
"title": "Richiesta",
|
||||||
"type": "Tipo di richiesta",
|
"type": "Tipo di richiesta",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Corpo della risposta",
|
"body": "Corpo della risposta",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Intestazioni",
|
"headers": "Intestazioni",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Stato",
|
"status": "Stato",
|
||||||
"time": "Tempo impiegato",
|
"time": "Tempo impiegato",
|
||||||
"title": "Risposta",
|
"title": "Risposta",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "In attesa di connessione",
|
"waiting_for_connection": "In attesa di connessione",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Questo è il tuo nome mostrato.",
|
"account_name_description": "Questo è il tuo nome mostrato.",
|
||||||
"background": "Sfondo",
|
"background": "Sfondo",
|
||||||
"black_mode": "Nero",
|
"black_mode": "Nero",
|
||||||
|
"change_font_size": "Cambia la dimensione dei caratteri",
|
||||||
"choose_language": "Scegli la lingua",
|
"choose_language": "Scegli la lingua",
|
||||||
"dark_mode": "Scuro",
|
"dark_mode": "Scuro",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Estensioni",
|
"extensions": "Estensioni",
|
||||||
"extensions_use_toggle": "Utilizza l'estensione del browser per inviare richieste (se presente)",
|
"extensions_use_toggle": "Utilizza l'estensione del browser per inviare richieste (se presente)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "Dimensione dei caratteri",
|
||||||
|
"font_size_large": "Grande",
|
||||||
|
"font_size_medium": "Medio",
|
||||||
|
"font_size_small": "Piccolo",
|
||||||
"interceptor": "Interceptor",
|
"interceptor": "Interceptor",
|
||||||
"interceptor_description": "Middleware tra applicazione e API.",
|
"interceptor_description": "Middleware tra applicazione e API.",
|
||||||
"language": "Lingua",
|
"language": "Lingua",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Vai alla pagina Impostazioni",
|
"settings": "Vai alla pagina Impostazioni",
|
||||||
"title": "Navigazione"
|
"title": "Navigazione"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Copia il link alla richiesta",
|
"copy_request_link": "Copia il link alla richiesta",
|
||||||
"delete_method": "Seleziona il metodo DELETE",
|
"delete_method": "Seleziona il metodo DELETE",
|
||||||
"get_method": "Seleziona il metodo GET",
|
"get_method": "Seleziona il metodo GET",
|
||||||
"head_method": "Seleziona il metodo HEAD",
|
"head_method": "Seleziona il metodo HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Metodo",
|
"method": "Metodo",
|
||||||
"next_method": "Seleziona il metodo successivo",
|
"next_method": "Seleziona il metodo successivo",
|
||||||
"post_method": "Seleziona il metodo POST",
|
"post_method": "Seleziona il metodo POST",
|
||||||
"previous_method": "Seleziona il metodo precedente",
|
"previous_method": "Seleziona il metodo precedente",
|
||||||
"put_method": "Seleziona il metodo PUT",
|
"put_method": "Seleziona il metodo PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Resetta la richiesta",
|
"reset_request": "Resetta la richiesta",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Salva nelle raccolte",
|
"save_to_collections": "Salva nelle raccolte",
|
||||||
"send_request": "Invia richiesta",
|
"send_request": "Invia richiesta",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Richiesta"
|
"title": "Richiesta"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Log",
|
"log": "Log",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Tipo di evento",
|
"event_type": "Tipo di evento",
|
||||||
"log": "Log",
|
"log": "Log",
|
||||||
@@ -765,7 +625,7 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"changelog": "Maggiori informazioni sulle ultime versioni",
|
"changelog": "Maggiori informazioni sulle ultime versioni",
|
||||||
"chat": "Domande? Chatta con noi!",
|
"chat": "Domande? Chatta con noi!",
|
||||||
"community": "Fai domande e aiuta gli altri",
|
"community": "Fai domande e aiuta gli altri",
|
||||||
"documentation": "Maggiori informazioni su Hoppscotch",
|
"documentation": "Maggiori informazioni su Hoppscotch",
|
||||||
"forum": "Fai domande e ottieni risposte",
|
"forum": "Fai domande e ottieni risposte",
|
||||||
"github": "Follow us on Github",
|
"github": "Follow us on Github",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Autorizzazione",
|
"authorization": "Autorizzazione",
|
||||||
"body": "Corpo",
|
"body": "Corpo",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Raccolte",
|
"collections": "Raccolte",
|
||||||
"documentation": "Documentazione",
|
"documentation": "Documentazione",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Intestazioni",
|
"headers": "Intestazioni",
|
||||||
"history": "Cronologia",
|
"history": "Cronologia",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "ファイルを選択してください",
|
"choose_file": "ファイルを選択してください",
|
||||||
"clear": "クリア",
|
"clear": "クリア",
|
||||||
"clear_all": "すべてクリア",
|
"clear_all": "すべてクリア",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "閉じる",
|
"close": "閉じる",
|
||||||
"connect": "接続",
|
"connect": "接続",
|
||||||
"connecting": "接続中",
|
"connecting": "接続中",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "貼り付け",
|
"paste": "貼り付け",
|
||||||
"prettify": "自動整形",
|
"prettify": "自動整形",
|
||||||
"remove": "削除",
|
"remove": "削除",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "戻す",
|
"restore": "戻す",
|
||||||
"save": "保存",
|
"save": "保存",
|
||||||
"scroll_to_bottom": "下にスクロール",
|
"scroll_to_bottom": "下にスクロール",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "検索",
|
"search": "検索",
|
||||||
"share": "共有",
|
"share": "共有",
|
||||||
"shortcuts": "ショートカット",
|
"shortcuts": "ショートカット",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "スポットライト",
|
"spotlight": "スポットライト",
|
||||||
"status": "状態",
|
"status": "状態",
|
||||||
"status_description": "ウェブサイトの状態を確認",
|
"status_description": "ウェブサイトの状態を確認",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "コレクション名が変更されました",
|
"renamed": "コレクション名が変更されました",
|
||||||
"request_in_use": "使用中のリクエスト",
|
"request_in_use": "使用中のリクエスト",
|
||||||
"save_as": "名前を付けて保存",
|
"save_as": "名前を付けて保存",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "コレクションを選択",
|
"select": "コレクションを選択",
|
||||||
"select_location": "場所を選択",
|
"select_location": "場所を選択",
|
||||||
"select_team": "チームを選択",
|
"select_team": "チームを選択",
|
||||||
"team_collections": "チームコレクション"
|
"team_collections": "チームコレクション"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "本当にこのチームから退出しますか?",
|
"exit_team": "本当にこのチームから退出しますか?",
|
||||||
"logout": "ログアウトしてもよろしいですか?",
|
"logout": "ログアウトしてもよろしいですか?",
|
||||||
"remove_collection": "このコレクションを完全に削除してもよろしいですか?",
|
"remove_collection": "このコレクションを完全に削除してもよろしいですか?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "クラウドからワークスペースを復元しますか?この場合、ローカルの進行状況は破棄されます。"
|
"sync": "クラウドからワークスペースを復元しますか?この場合、ローカルの進行状況は破棄されます。"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "ヘッダー {count}",
|
"header": "ヘッダー {count}",
|
||||||
"message": "メッセージ {count}",
|
"message": "メッセージ {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "新しい環境変数を作成",
|
"create_new": "新しい環境変数を作成",
|
||||||
"created": "環境変数を作成しました",
|
"created": "環境変数を作成しました",
|
||||||
"deleted": "環境変数を削除しました",
|
"deleted": "環境変数を削除しました",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "環境変数の編集",
|
"edit": "環境変数の編集",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "環境変数名を入力してください",
|
"invalid_name": "環境変数名を入力してください",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "個人の環境変数",
|
"my_environments": "個人の環境変数",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "環境変数の入れ子は10段階までです",
|
"nested_overflow": "環境変数の入れ子は10段階までです",
|
||||||
"new": "新しい環境変数",
|
"new": "新しい環境変数",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "環境変数が存在しません",
|
"no_environment": "環境変数が存在しません",
|
||||||
"no_environment_description": "環境変数が選択されていません。次の環境変数から選択してください。",
|
"no_environment_description": "環境変数が選択されていません。次の環境変数から選択してください。",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "環境変数を選択",
|
"select": "環境変数を選択",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "チームの環境変数",
|
"team_environments": "チームの環境変数",
|
||||||
"title": "環境変数",
|
"title": "環境変数",
|
||||||
"updated": "環境変数を更新しました",
|
"updated": "環境変数を更新しました",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "環境変数リスト"
|
"variable_list": "環境変数リスト"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "期間なし",
|
"no_duration": "期間なし",
|
||||||
"no_results_found": "該当するものがありませんでした",
|
"no_results_found": "該当するものがありませんでした",
|
||||||
"page_not_found": "このページは見つかりませんでした",
|
"page_not_found": "このページは見つかりませんでした",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "リクエスト前のスクリプトを実行できませんでした",
|
"script_fail": "リクエスト前のスクリプトを実行できませんでした",
|
||||||
"something_went_wrong": "不明なエラーです",
|
"something_went_wrong": "不明なエラーです",
|
||||||
"test_script_fail": "リクエスト後のスクリプトを実行できませんでした"
|
"test_script_fail": "リクエスト後のスクリプトを実行できませんでした"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "フォルダ名が変更されました"
|
"renamed": "フォルダ名が変更されました"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "ミューテーション",
|
"mutations": "ミューテーション",
|
||||||
"schema": "スキーマ",
|
"schema": "スキーマ",
|
||||||
"subscriptions": "サブスクリプション",
|
"subscriptions": "サブスクリプション"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "時間",
|
"time": "時間",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Hoppscotchのコレクション (JSONファイル) からインポート",
|
"json_description": "Hoppscotchのコレクション (JSONファイル) からインポート",
|
||||||
"title": "インポート"
|
"title": "インポート"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "コレクションを表示・非表示",
|
"collapse_collection": "コレクションを表示・非表示",
|
||||||
"collapse_sidebar": "サイドバーを表示・非表示",
|
"collapse_sidebar": "サイドバーを表示・非表示",
|
||||||
"column": "縦型レイアウト",
|
"column": "縦型レイアウト",
|
||||||
"name": "レイアウト",
|
"name": "レイアウト",
|
||||||
"row": "横型レイアウト"
|
"row": "横型レイアウト",
|
||||||
|
"zen_mode": "禅モード"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "ペイロード",
|
"payload": "ペイロード",
|
||||||
"query": "クエリ",
|
"query": "クエリ",
|
||||||
"raw_body": "生のリクエストボディ",
|
"raw_body": "生のリクエストボディ",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "リクエストの名前を変更",
|
"renamed": "リクエストの名前を変更",
|
||||||
"run": "実行",
|
"run": "実行",
|
||||||
"save": "保存",
|
"save": "保存",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "保存されたリクエスト",
|
"saved": "保存されたリクエスト",
|
||||||
"share": "共有",
|
"share": "共有",
|
||||||
"share_description": "Hoppscotchを友人に共有",
|
"share_description": "Hoppscotchを友人に共有",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "リクエスト",
|
"title": "リクエスト",
|
||||||
"type": "リクエストの種類",
|
"type": "リクエストの種類",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "自分のリンクを見る"
|
"view_my_links": "自分のリンクを見る"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "レスポンスボディ",
|
"body": "レスポンスボディ",
|
||||||
"filter_response_body": "JSONレスポンスボディをフィルタ (JSONPathシンタックスを使用)",
|
"filter_response_body": "JSONレスポンスボディをフィルタ (JSONPathシンタックスを使用)",
|
||||||
"headers": "ヘッダー",
|
"headers": "ヘッダー",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "ステータス",
|
"status": "ステータス",
|
||||||
"time": "時間",
|
"time": "時間",
|
||||||
"title": "レスポンス",
|
"title": "レスポンス",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "接続を待っています",
|
"waiting_for_connection": "接続を待っています",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "あなたの表示名",
|
"account_name_description": "あなたの表示名",
|
||||||
"background": "背景",
|
"background": "背景",
|
||||||
"black_mode": "ブラック",
|
"black_mode": "ブラック",
|
||||||
|
"change_font_size": "フォントの大きさを変更",
|
||||||
"choose_language": "言語を選択",
|
"choose_language": "言語を選択",
|
||||||
"dark_mode": "ダーク",
|
"dark_mode": "ダーク",
|
||||||
"delete_account": "アカウントの削除",
|
"delete_account": "アカウントの削除",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "拡張機能",
|
"extensions": "拡張機能",
|
||||||
"extensions_use_toggle": "ブラウザ拡張機能を使用してリクエストを送信する(利用可能な場合)",
|
"extensions_use_toggle": "ブラウザ拡張機能を使用してリクエストを送信する(利用可能な場合)",
|
||||||
"follow": "フォローする",
|
"follow": "フォローする",
|
||||||
|
"font_size": "フォントサイズ",
|
||||||
|
"font_size_large": "大きめ",
|
||||||
|
"font_size_medium": "普通",
|
||||||
|
"font_size_small": "小さめ",
|
||||||
"interceptor": "インターセプタ",
|
"interceptor": "インターセプタ",
|
||||||
"interceptor_description": "アプリケーションとAPIをつなぐミドルウェア",
|
"interceptor_description": "アプリケーションとAPIをつなぐミドルウェア",
|
||||||
"language": "言語",
|
"language": "言語",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "設定ページに移動",
|
"settings": "設定ページに移動",
|
||||||
"title": "ナビゲーション"
|
"title": "ナビゲーション"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "コピーリクエストリンク",
|
"copy_request_link": "コピーリクエストリンク",
|
||||||
"delete_method": "DELETEメソッドを選択",
|
"delete_method": "DELETEメソッドを選択",
|
||||||
"get_method": "GETメソッドを選択",
|
"get_method": "GETメソッドを選択",
|
||||||
"head_method": "HEADメソッドを選択",
|
"head_method": "HEADメソッドを選択",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "メソッド",
|
"method": "メソッド",
|
||||||
"next_method": "次のメソッドを選択",
|
"next_method": "次のメソッドを選択",
|
||||||
"post_method": "POSTメソッドを選択",
|
"post_method": "POSTメソッドを選択",
|
||||||
"previous_method": "前のメソッドを選択",
|
"previous_method": "前のメソッドを選択",
|
||||||
"put_method": "PUTメソッドを選択",
|
"put_method": "PUTメソッドを選択",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "リセットリクエスト",
|
"reset_request": "リセットリクエスト",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "コレクションに保存",
|
"save_to_collections": "コレクションに保存",
|
||||||
"send_request": "リクエストを送信",
|
"send_request": "リクエストを送信",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "リクエスト"
|
"title": "リクエスト"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "ログ",
|
"log": "ログ",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "イベントの種類",
|
"event_type": "イベントの種類",
|
||||||
"log": "ログ",
|
"log": "ログ",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "認証",
|
"authorization": "認証",
|
||||||
"body": "ボディ",
|
"body": "ボディ",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "コレクション",
|
"collections": "コレクション",
|
||||||
"documentation": "ドキュメント",
|
"documentation": "ドキュメント",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "ヘッダー",
|
"headers": "ヘッダー",
|
||||||
"history": "履歴",
|
"history": "履歴",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "파일 선택",
|
"choose_file": "파일 선택",
|
||||||
"clear": "지우기",
|
"clear": "지우기",
|
||||||
"clear_all": "모두 지우기",
|
"clear_all": "모두 지우기",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "닫기",
|
"close": "닫기",
|
||||||
"connect": "연결",
|
"connect": "연결",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "붙여넣기",
|
"paste": "붙여넣기",
|
||||||
"prettify": "구문 강조",
|
"prettify": "구문 강조",
|
||||||
"remove": "제거",
|
"remove": "제거",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "복원",
|
"restore": "복원",
|
||||||
"save": "저장",
|
"save": "저장",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "찾기",
|
"search": "찾기",
|
||||||
"share": "공유하기",
|
"share": "공유하기",
|
||||||
"shortcuts": "바로가기",
|
"shortcuts": "바로가기",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "스포트라이트",
|
"spotlight": "스포트라이트",
|
||||||
"status": "상태",
|
"status": "상태",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "모음집 이름이 변경됨",
|
"renamed": "모음집 이름이 변경됨",
|
||||||
"request_in_use": "사용 중인 요청",
|
"request_in_use": "사용 중인 요청",
|
||||||
"save_as": "다른 이름으로 저장",
|
"save_as": "다른 이름으로 저장",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "모음집 선택",
|
"select": "모음집 선택",
|
||||||
"select_location": "위치 선택",
|
"select_location": "위치 선택",
|
||||||
"select_team": "팀 선택",
|
"select_team": "팀 선택",
|
||||||
"team_collections": "팀 모음집"
|
"team_collections": "팀 모음집"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "이 팀을 떠나겠습니까?",
|
"exit_team": "이 팀을 떠나겠습니까?",
|
||||||
"logout": "로그아웃하겠습니까?",
|
"logout": "로그아웃하겠습니까?",
|
||||||
"remove_collection": "이 모음집을 영구적으로 삭제하겠습니까?",
|
"remove_collection": "이 모음집을 영구적으로 삭제하겠습니까?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "이 작업 공간을 동기화하겠습니까?"
|
"sync": "이 작업 공간을 동기화하겠습니까?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "헤더 {count}",
|
"header": "헤더 {count}",
|
||||||
"message": "메시지 {count}",
|
"message": "메시지 {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "새 환경 만들기",
|
"create_new": "새 환경 만들기",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "환경 편집",
|
"edit": "환경 편집",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "환경 이름을 바르게 입력하세요.",
|
"invalid_name": "환경 이름을 바르게 입력하세요.",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "환경 변수는 열 단계까지만 중첩될 수 있습니다.",
|
"nested_overflow": "환경 변수는 열 단계까지만 중첩될 수 있습니다.",
|
||||||
"new": "새 환경",
|
"new": "새 환경",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "환경 없음",
|
"no_environment": "환경 없음",
|
||||||
"no_environment_description": "선택한 환경이 없습니다. 선택해주세요.",
|
"no_environment_description": "선택한 환경이 없습니다. 선택해주세요.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "환경 선택",
|
"select": "환경 선택",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "환경",
|
"title": "환경",
|
||||||
"updated": "환경 수정됨",
|
"updated": "환경 수정됨",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "변수 목록"
|
"variable_list": "변수 목록"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "소요 시간 없음",
|
"no_duration": "소요 시간 없음",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "해당 페이지를 찾을 수 없습니다.",
|
"page_not_found": "해당 페이지를 찾을 수 없습니다.",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "사전 요청 스크립트를 실행할 수 없습니다.",
|
"script_fail": "사전 요청 스크립트를 실행할 수 없습니다.",
|
||||||
"something_went_wrong": "문제가 발생했습니다.",
|
"something_went_wrong": "문제가 발생했습니다.",
|
||||||
"test_script_fail": "테스트 스크립트를 실행할 수 없습니다."
|
"test_script_fail": "테스트 스크립트를 실행할 수 없습니다."
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "폴더 이름이 변경됨"
|
"renamed": "폴더 이름이 변경됨"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "뮤테이션",
|
"mutations": "뮤테이션",
|
||||||
"schema": "스키마",
|
"schema": "스키마",
|
||||||
"subscriptions": "섭스크립션",
|
"subscriptions": "섭스크립션"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "호프스카치 모음집 JSON 파일을 가져옵니다.",
|
"json_description": "호프스카치 모음집 JSON 파일을 가져옵니다.",
|
||||||
"title": "가져오기"
|
"title": "가져오기"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "가로형 레이아웃",
|
"column": "가로형 레이아웃",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "세로형 레이아웃"
|
"row": "세로형 레이아웃",
|
||||||
|
"zen_mode": "전체화면"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "페이로드",
|
"payload": "페이로드",
|
||||||
"query": "쿼리",
|
"query": "쿼리",
|
||||||
"raw_body": "원시 요청 본문",
|
"raw_body": "원시 요청 본문",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "요청 이름이 변경됨",
|
"renamed": "요청 이름이 변경됨",
|
||||||
"run": "실행",
|
"run": "실행",
|
||||||
"save": "저장",
|
"save": "저장",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "요청이 저장됨",
|
"saved": "요청이 저장됨",
|
||||||
"share": "공유하기",
|
"share": "공유하기",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "제목",
|
"title": "제목",
|
||||||
"type": "요청 유형",
|
"type": "요청 유형",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "내 링크 보기"
|
"view_my_links": "내 링크 보기"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "응답 본문",
|
"body": "응답 본문",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "헤더",
|
"headers": "헤더",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "상태",
|
"status": "상태",
|
||||||
"time": "시간",
|
"time": "시간",
|
||||||
"title": "제목",
|
"title": "제목",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "연결 대기 중",
|
"waiting_for_connection": "연결 대기 중",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "디스플레이 이름입니다.",
|
"account_name_description": "디스플레이 이름입니다.",
|
||||||
"background": "배경",
|
"background": "배경",
|
||||||
"black_mode": "검은 테마",
|
"black_mode": "검은 테마",
|
||||||
|
"change_font_size": "글자 크기 변경",
|
||||||
"choose_language": "언어 선택",
|
"choose_language": "언어 선택",
|
||||||
"dark_mode": "어두운 테마",
|
"dark_mode": "어두운 테마",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "익스텐션",
|
"extensions": "익스텐션",
|
||||||
"extensions_use_toggle": "브라우저 익스텐션을 사용하여 요청 보내기(있는 경우)",
|
"extensions_use_toggle": "브라우저 익스텐션을 사용하여 요청 보내기(있는 경우)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "글꼴 크기",
|
||||||
|
"font_size_large": "크게",
|
||||||
|
"font_size_medium": "중간",
|
||||||
|
"font_size_small": "작게",
|
||||||
"interceptor": "인터셉터",
|
"interceptor": "인터셉터",
|
||||||
"interceptor_description": "애플리케이션과 API 간의 미들웨어.",
|
"interceptor_description": "애플리케이션과 API 간의 미들웨어.",
|
||||||
"language": "언어",
|
"language": "언어",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "설정 페이지로 이동",
|
"settings": "설정 페이지로 이동",
|
||||||
"title": "내비게이션"
|
"title": "내비게이션"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "요청 링크 복사",
|
"copy_request_link": "요청 링크 복사",
|
||||||
"delete_method": "DELETE 메서드 선택",
|
"delete_method": "DELETE 메서드 선택",
|
||||||
"get_method": "GET 메서드 선택",
|
"get_method": "GET 메서드 선택",
|
||||||
"head_method": "HEAD 메서드 선택",
|
"head_method": "HEAD 메서드 선택",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "메서드",
|
"method": "메서드",
|
||||||
"next_method": "다음 메서드 선택",
|
"next_method": "다음 메서드 선택",
|
||||||
"post_method": "POST 메서드 선택",
|
"post_method": "POST 메서드 선택",
|
||||||
"previous_method": "이전 메서드 선택",
|
"previous_method": "이전 메서드 선택",
|
||||||
"put_method": "PUT 메서드 선택",
|
"put_method": "PUT 메서드 선택",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "요청 초기화",
|
"reset_request": "요청 초기화",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "모음집에 저장",
|
"save_to_collections": "모음집에 저장",
|
||||||
"send_request": "요청 보내기",
|
"send_request": "요청 보내기",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "요청"
|
"title": "요청"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "로그",
|
"log": "로그",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "이벤트 유형",
|
"event_type": "이벤트 유형",
|
||||||
"log": "로그",
|
"log": "로그",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "인증",
|
"authorization": "인증",
|
||||||
"body": "본문",
|
"body": "본문",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "모음집",
|
"collections": "모음집",
|
||||||
"documentation": "문서",
|
"documentation": "문서",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "헤더",
|
"headers": "헤더",
|
||||||
"history": "이력",
|
"history": "이력",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Kies een bestand",
|
"choose_file": "Kies een bestand",
|
||||||
"clear": "Wis",
|
"clear": "Wis",
|
||||||
"clear_all": "Wis alles",
|
"clear_all": "Wis alles",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Verbinden",
|
"connect": "Verbinden",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "Netter opmaken",
|
"prettify": "Netter opmaken",
|
||||||
"remove": "Verwijderen",
|
"remove": "Verwijderen",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Herstellen",
|
"restore": "Herstellen",
|
||||||
"save": "Opslaan",
|
"save": "Opslaan",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Zoeken",
|
"search": "Zoeken",
|
||||||
"share": "Deel",
|
"share": "Deel",
|
||||||
"shortcuts": "Sneltoetsen",
|
"shortcuts": "Sneltoetsen",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Spotlight",
|
"spotlight": "Spotlight",
|
||||||
"status": "Toestand",
|
"status": "Toestand",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Collectie hernoemd",
|
"renamed": "Collectie hernoemd",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Opslaan als",
|
"save_as": "Opslaan als",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Selecteer een collectie",
|
"select": "Selecteer een collectie",
|
||||||
"select_location": "Selecteer een locatie",
|
"select_location": "Selecteer een locatie",
|
||||||
"select_team": "Selecteer een team",
|
"select_team": "Selecteer een team",
|
||||||
"team_collections": "Teamcollecties"
|
"team_collections": "Teamcollecties"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Weet u zeker dat u wilt uitloggen?",
|
"logout": "Weet u zeker dat u wilt uitloggen?",
|
||||||
"remove_collection": "Weet je zeker dat je deze collectie definitief wilt verwijderen?",
|
"remove_collection": "Weet je zeker dat je deze collectie definitief wilt verwijderen?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Weet u zeker dat u deze werkruimte wilt synchroniseren?"
|
"sync": "Weet u zeker dat u deze werkruimte wilt synchroniseren?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Kop {count}",
|
"header": "Kop {count}",
|
||||||
"message": "Bericht {count}",
|
"message": "Bericht {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Nieuwe omgeving maken",
|
"create_new": "Nieuwe omgeving maken",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Omgeving bewerken",
|
"edit": "Omgeving bewerken",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Geef een geldige naam op voor de omgeving",
|
"invalid_name": "Geef een geldige naam op voor de omgeving",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "Nieuwe omgeving",
|
"new": "Nieuwe omgeving",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Geen omgeving",
|
"no_environment": "Geen omgeving",
|
||||||
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Selecteer omgeving",
|
"select": "Selecteer omgeving",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "omgevingen",
|
"title": "omgevingen",
|
||||||
"updated": "Environment updation",
|
"updated": "Environment updation",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Variabele lijst"
|
"variable_list": "Variabele lijst"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Geen duur",
|
"no_duration": "Geen duur",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Kon pre-aanvraagscript niet uitvoeren",
|
"script_fail": "Kon pre-aanvraagscript niet uitvoeren",
|
||||||
"something_went_wrong": "Er is iets fout gegaan",
|
"something_went_wrong": "Er is iets fout gegaan",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Map hernoemd"
|
"renamed": "Map hernoemd"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutaties",
|
"mutations": "Mutaties",
|
||||||
"schema": "Schema",
|
"schema": "Schema",
|
||||||
"subscriptions": "Abonnementen",
|
"subscriptions": "Abonnementen"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
||||||
"title": "Importeren"
|
"title": "Importeren"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "Vertical layout",
|
"column": "Vertical layout",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Horizontal layout"
|
"row": "Horizontal layout",
|
||||||
|
"zen_mode": "Zen-modus"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Payload",
|
"payload": "Payload",
|
||||||
"query": "Vraag",
|
"query": "Vraag",
|
||||||
"raw_body": "Ruwe body",
|
"raw_body": "Ruwe body",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Verzoek hernoemd",
|
"renamed": "Verzoek hernoemd",
|
||||||
"run": "Uitvoeren",
|
"run": "Uitvoeren",
|
||||||
"save": "Opslaan",
|
"save": "Opslaan",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Verzoek opgeslagen",
|
"saved": "Verzoek opgeslagen",
|
||||||
"share": "Deel",
|
"share": "Deel",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Verzoek",
|
"title": "Verzoek",
|
||||||
"type": "Aanvraag type",
|
"type": "Aanvraag type",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Reactie inhoud",
|
"body": "Reactie inhoud",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Headers",
|
"headers": "Headers",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Status",
|
"status": "Status",
|
||||||
"time": "Tijd",
|
"time": "Tijd",
|
||||||
"title": "Antwoord",
|
"title": "Antwoord",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "wachten op verbinding",
|
"waiting_for_connection": "wachten op verbinding",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Dit is uw weergavenaam.",
|
"account_name_description": "Dit is uw weergavenaam.",
|
||||||
"background": "Achtergrond",
|
"background": "Achtergrond",
|
||||||
"black_mode": "zwart",
|
"black_mode": "zwart",
|
||||||
|
"change_font_size": "Verander lettergrootte",
|
||||||
"choose_language": "Kies een taal",
|
"choose_language": "Kies een taal",
|
||||||
"dark_mode": "Donker",
|
"dark_mode": "Donker",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Extensies",
|
"extensions": "Extensies",
|
||||||
"extensions_use_toggle": "Gebruik de browserextensie om verzoeken te versturen (indien aanwezig)",
|
"extensions_use_toggle": "Gebruik de browserextensie om verzoeken te versturen (indien aanwezig)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "Lettergrootte",
|
||||||
|
"font_size_large": "Groot",
|
||||||
|
"font_size_medium": "Medium",
|
||||||
|
"font_size_small": "Klein",
|
||||||
"interceptor": "Interceptor",
|
"interceptor": "Interceptor",
|
||||||
"interceptor_description": "Middleware tussen applicatie en API's.",
|
"interceptor_description": "Middleware tussen applicatie en API's.",
|
||||||
"language": "Taal",
|
"language": "Taal",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Ga naar de pagina Instellingen",
|
"settings": "Ga naar de pagina Instellingen",
|
||||||
"title": "Navigatie"
|
"title": "Navigatie"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Kopieer aanvraaglink",
|
"copy_request_link": "Kopieer aanvraaglink",
|
||||||
"delete_method": "Selecteer DELETE-methode",
|
"delete_method": "Selecteer DELETE-methode",
|
||||||
"get_method": "Selecteer GET-methode",
|
"get_method": "Selecteer GET-methode",
|
||||||
"head_method": "Selecteer HEAD-methode:",
|
"head_method": "Selecteer HEAD-methode:",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Methode",
|
"method": "Methode",
|
||||||
"next_method": "Selecteer volgende methode",
|
"next_method": "Selecteer volgende methode",
|
||||||
"post_method": "Selecteer POST-methode",
|
"post_method": "Selecteer POST-methode",
|
||||||
"previous_method": "Selecteer vorige methode",
|
"previous_method": "Selecteer vorige methode",
|
||||||
"put_method": "Selecteer PUT-methode",
|
"put_method": "Selecteer PUT-methode",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Verzoek resetten",
|
"reset_request": "Verzoek resetten",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Opslaan in collecties",
|
"save_to_collections": "Opslaan in collecties",
|
||||||
"send_request": "Verstuur verzoek",
|
"send_request": "Verstuur verzoek",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Verzoek"
|
"title": "Verzoek"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Logboek",
|
"log": "Logboek",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Evenementtype",
|
"event_type": "Evenementtype",
|
||||||
"log": "Logboek",
|
"log": "Logboek",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Autorisatie",
|
"authorization": "Autorisatie",
|
||||||
"body": "Inhoud",
|
"body": "Inhoud",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Collecties",
|
"collections": "Collecties",
|
||||||
"documentation": "Documentatie",
|
"documentation": "Documentatie",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Headers",
|
"headers": "Headers",
|
||||||
"history": "Geschiedenis",
|
"history": "Geschiedenis",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Velg en fil",
|
"choose_file": "Velg en fil",
|
||||||
"clear": "Tøm",
|
"clear": "Tøm",
|
||||||
"clear_all": "Tøm alt",
|
"clear_all": "Tøm alt",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Koble",
|
"connect": "Koble",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "Forskjønn",
|
"prettify": "Forskjønn",
|
||||||
"remove": "Ta bort",
|
"remove": "Ta bort",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Gjenopprett",
|
"restore": "Gjenopprett",
|
||||||
"save": "Lagre",
|
"save": "Lagre",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Søk",
|
"search": "Søk",
|
||||||
"share": "Dele",
|
"share": "Dele",
|
||||||
"shortcuts": "Snarveier",
|
"shortcuts": "Snarveier",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Spotlight",
|
"spotlight": "Spotlight",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Samlingen ble omdøpt",
|
"renamed": "Samlingen ble omdøpt",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Lagre som",
|
"save_as": "Lagre som",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Velg en samling",
|
"select": "Velg en samling",
|
||||||
"select_location": "Velg plassering",
|
"select_location": "Velg plassering",
|
||||||
"select_team": "Velg et lag",
|
"select_team": "Velg et lag",
|
||||||
"team_collections": "Lagsamlinger"
|
"team_collections": "Lagsamlinger"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Er du sikker på at du vil logge deg av?",
|
"logout": "Er du sikker på at du vil logge deg av?",
|
||||||
"remove_collection": "Er du sikker på at du vil slette denne samlingen permanent?",
|
"remove_collection": "Er du sikker på at du vil slette denne samlingen permanent?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Er du sikker på at du vil synkronisere dette arbeidsområdet?"
|
"sync": "Er du sikker på at du vil synkronisere dette arbeidsområdet?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Overskrift {count}",
|
"header": "Overskrift {count}",
|
||||||
"message": "Melding {count}",
|
"message": "Melding {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Skap nytt miljø",
|
"create_new": "Skap nytt miljø",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Rediger miljø",
|
"edit": "Rediger miljø",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Oppgi et gyldig navn på miljøet",
|
"invalid_name": "Oppgi et gyldig navn på miljøet",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "Nytt miljø",
|
"new": "Nytt miljø",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Ingen miljø",
|
"no_environment": "Ingen miljø",
|
||||||
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Velg miljø",
|
"select": "Velg miljø",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Miljøer",
|
"title": "Miljøer",
|
||||||
"updated": "Environment updation",
|
"updated": "Environment updation",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Variabel liste"
|
"variable_list": "Variabel liste"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Ingen varighet",
|
"no_duration": "Ingen varighet",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Kunne ikke kjøre forhåndsforespørselsskript",
|
"script_fail": "Kunne ikke kjøre forhåndsforespørselsskript",
|
||||||
"something_went_wrong": "Noe gikk galt",
|
"something_went_wrong": "Noe gikk galt",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Mappen ble gitt nytt navn"
|
"renamed": "Mappen ble gitt nytt navn"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutasjoner",
|
"mutations": "Mutasjoner",
|
||||||
"schema": "Skjema",
|
"schema": "Skjema",
|
||||||
"subscriptions": "Abonnementer",
|
"subscriptions": "Abonnementer"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
||||||
"title": "Import"
|
"title": "Import"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "Vertical layout",
|
"column": "Vertical layout",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Horizontal layout"
|
"row": "Horizontal layout",
|
||||||
|
"zen_mode": "Zen-modus"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Nyttelast",
|
"payload": "Nyttelast",
|
||||||
"query": "Spørsmål",
|
"query": "Spørsmål",
|
||||||
"raw_body": "Raw Request Body",
|
"raw_body": "Raw Request Body",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Forespørsel omdøpt",
|
"renamed": "Forespørsel omdøpt",
|
||||||
"run": "Løpe",
|
"run": "Løpe",
|
||||||
"save": "Lagre",
|
"save": "Lagre",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Forespørselen er lagret",
|
"saved": "Forespørselen er lagret",
|
||||||
"share": "Dele",
|
"share": "Dele",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Be om",
|
"title": "Be om",
|
||||||
"type": "Type forespørsel",
|
"type": "Type forespørsel",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Svarkropp",
|
"body": "Svarkropp",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Overskrifter",
|
"headers": "Overskrifter",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Status",
|
"status": "Status",
|
||||||
"time": "Tid",
|
"time": "Tid",
|
||||||
"title": "Respons",
|
"title": "Respons",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "venter på tilkobling",
|
"waiting_for_connection": "venter på tilkobling",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Dette er visningsnavnet ditt.",
|
"account_name_description": "Dette er visningsnavnet ditt.",
|
||||||
"background": "Bakgrunn",
|
"background": "Bakgrunn",
|
||||||
"black_mode": "Svart",
|
"black_mode": "Svart",
|
||||||
|
"change_font_size": "Endre skriftstørrelse",
|
||||||
"choose_language": "Velg språk",
|
"choose_language": "Velg språk",
|
||||||
"dark_mode": "Mørk",
|
"dark_mode": "Mørk",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Utvidelser",
|
"extensions": "Utvidelser",
|
||||||
"extensions_use_toggle": "Bruk nettleserutvidelsen til å sende forespørsler (hvis de er tilstede)",
|
"extensions_use_toggle": "Bruk nettleserutvidelsen til å sende forespørsler (hvis de er tilstede)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "Skriftstørrelse",
|
||||||
|
"font_size_large": "Stor",
|
||||||
|
"font_size_medium": "Medium",
|
||||||
|
"font_size_small": "Liten",
|
||||||
"interceptor": "Interceptor",
|
"interceptor": "Interceptor",
|
||||||
"interceptor_description": "Mellomvare mellom applikasjon og API-er.",
|
"interceptor_description": "Mellomvare mellom applikasjon og API-er.",
|
||||||
"language": "Språk",
|
"language": "Språk",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Gå til Innstillinger-siden",
|
"settings": "Gå til Innstillinger-siden",
|
||||||
"title": "Navigasjon"
|
"title": "Navigasjon"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Kopier forespørselskobling",
|
"copy_request_link": "Kopier forespørselskobling",
|
||||||
"delete_method": "Velg SLETT metoden",
|
"delete_method": "Velg SLETT metoden",
|
||||||
"get_method": "Velg GET-metode",
|
"get_method": "Velg GET-metode",
|
||||||
"head_method": "Velg HEAD-metode",
|
"head_method": "Velg HEAD-metode",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Metode",
|
"method": "Metode",
|
||||||
"next_method": "Velg Neste metode",
|
"next_method": "Velg Neste metode",
|
||||||
"post_method": "Velg POST-metode",
|
"post_method": "Velg POST-metode",
|
||||||
"previous_method": "Velg Forrige metode",
|
"previous_method": "Velg Forrige metode",
|
||||||
"put_method": "Velg PUT-metode",
|
"put_method": "Velg PUT-metode",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Tilbakestill forespørsel",
|
"reset_request": "Tilbakestill forespørsel",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Lagre i samlinger",
|
"save_to_collections": "Lagre i samlinger",
|
||||||
"send_request": "Send forespørsel",
|
"send_request": "Send forespørsel",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Be om"
|
"title": "Be om"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Logg",
|
"log": "Logg",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Hendelsestype",
|
"event_type": "Hendelsestype",
|
||||||
"log": "Logg",
|
"log": "Logg",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Autorisasjon",
|
"authorization": "Autorisasjon",
|
||||||
"body": "Kropp",
|
"body": "Kropp",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Samlinger",
|
"collections": "Samlinger",
|
||||||
"documentation": "Dokumentasjon",
|
"documentation": "Dokumentasjon",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Overskrifter",
|
"headers": "Overskrifter",
|
||||||
"history": "Historie",
|
"history": "Historie",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Wybierz plik",
|
"choose_file": "Wybierz plik",
|
||||||
"clear": "Wyczyść",
|
"clear": "Wyczyść",
|
||||||
"clear_all": "Wyczyść wszystko",
|
"clear_all": "Wyczyść wszystko",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Połącz",
|
"connect": "Połącz",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Paste",
|
"paste": "Paste",
|
||||||
"prettify": "Popraw czytelność",
|
"prettify": "Popraw czytelność",
|
||||||
"remove": "Usuń",
|
"remove": "Usuń",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Przywróć",
|
"restore": "Przywróć",
|
||||||
"save": "Zapisz",
|
"save": "Zapisz",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Szukaj",
|
"search": "Szukaj",
|
||||||
"share": "Udostępnij",
|
"share": "Udostępnij",
|
||||||
"shortcuts": "Skróty",
|
"shortcuts": "Skróty",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Reflektor",
|
"spotlight": "Reflektor",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"status_description": "Check the status of the website",
|
"status_description": "Check the status of the website",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Zmieniono nazwę kolekcji",
|
"renamed": "Zmieniono nazwę kolekcji",
|
||||||
"request_in_use": "Request in use",
|
"request_in_use": "Request in use",
|
||||||
"save_as": "Zapisz jako",
|
"save_as": "Zapisz jako",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Wybierz kolekcję",
|
"select": "Wybierz kolekcję",
|
||||||
"select_location": "Wybierz lokalizację",
|
"select_location": "Wybierz lokalizację",
|
||||||
"select_team": "Wybierz zespół",
|
"select_team": "Wybierz zespół",
|
||||||
"team_collections": "Kolekcje zespołowe"
|
"team_collections": "Kolekcje zespołowe"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Are you sure you want to leave this team?",
|
"exit_team": "Are you sure you want to leave this team?",
|
||||||
"logout": "Czy na pewno chcesz się wylogować?",
|
"logout": "Czy na pewno chcesz się wylogować?",
|
||||||
"remove_collection": "Czy na pewno chcesz trwale usunąć tę kolekcję?",
|
"remove_collection": "Czy na pewno chcesz trwale usunąć tę kolekcję?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Czy na pewno chcesz zsynchronizować ten obszar roboczy?"
|
"sync": "Czy na pewno chcesz zsynchronizować ten obszar roboczy?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Nagłówek {count}",
|
"header": "Nagłówek {count}",
|
||||||
"message": "Wiadomość {count}",
|
"message": "Wiadomość {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Stwórz nowe środowisko",
|
"create_new": "Stwórz nowe środowisko",
|
||||||
"created": "Environment created",
|
"created": "Environment created",
|
||||||
"deleted": "Environment deletion",
|
"deleted": "Environment deletion",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Edytuj środowisko",
|
"edit": "Edytuj środowisko",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Podaj prawidłową nazwę środowiska",
|
"invalid_name": "Podaj prawidłową nazwę środowiska",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "nested environment variables are limited to 10 levels",
|
"nested_overflow": "nested environment variables are limited to 10 levels",
|
||||||
"new": "Nowe środowisko",
|
"new": "Nowe środowisko",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Brak środowiska",
|
"no_environment": "Brak środowiska",
|
||||||
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
"no_environment_description": "No environments were selected. Choose what to do with the following variables.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Wybierz środowisko",
|
"select": "Wybierz środowisko",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Środowiska",
|
"title": "Środowiska",
|
||||||
"updated": "Environment updation",
|
"updated": "Environment updation",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Lista zmiennych"
|
"variable_list": "Lista zmiennych"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Brak czasu trwania",
|
"no_duration": "Brak czasu trwania",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Nie można wykonać skryptu żądania wstępnego",
|
"script_fail": "Nie można wykonać skryptu żądania wstępnego",
|
||||||
"something_went_wrong": "Coś poszło nie tak",
|
"something_went_wrong": "Coś poszło nie tak",
|
||||||
"test_script_fail": "Could not execute post-request script"
|
"test_script_fail": "Could not execute post-request script"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Zmieniono nazwę folderu"
|
"renamed": "Zmieniono nazwę folderu"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutacje",
|
"mutations": "Mutacje",
|
||||||
"schema": "Schemat",
|
"schema": "Schemat",
|
||||||
"subscriptions": "Subskrypcje",
|
"subscriptions": "Subskrypcje"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
"json_description": "Import collections from a Hoppscotch Collections JSON file",
|
||||||
"title": "Import"
|
"title": "Import"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Collapse or Expand Collections",
|
"collapse_collection": "Collapse or Expand Collections",
|
||||||
"collapse_sidebar": "Collapse or Expand the sidebar",
|
"collapse_sidebar": "Collapse or Expand the sidebar",
|
||||||
"column": "Pionowy układ",
|
"column": "Pionowy układ",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Poziomy układ"
|
"row": "Poziomy układ",
|
||||||
|
"zen_mode": "Tryb Zen"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Dane żądania",
|
"payload": "Dane żądania",
|
||||||
"query": "Zapytanie",
|
"query": "Zapytanie",
|
||||||
"raw_body": "Surowa treść żądania",
|
"raw_body": "Surowa treść żądania",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Zmieniono nazwę żądania",
|
"renamed": "Zmieniono nazwę żądania",
|
||||||
"run": "Uruchom",
|
"run": "Uruchom",
|
||||||
"save": "Zapisz",
|
"save": "Zapisz",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Żądanie zostało zapisane",
|
"saved": "Żądanie zostało zapisane",
|
||||||
"share": "Udostępnij",
|
"share": "Udostępnij",
|
||||||
"share_description": "Share Hoppscotch with your friends",
|
"share_description": "Share Hoppscotch with your friends",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Żądanie",
|
"title": "Żądanie",
|
||||||
"type": "Typ żądania",
|
"type": "Typ żądania",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Ciało odpowiedzi",
|
"body": "Ciało odpowiedzi",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Nagłówki",
|
"headers": "Nagłówki",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Status",
|
"status": "Status",
|
||||||
"time": "Czas",
|
"time": "Czas",
|
||||||
"title": "Odpowiedź",
|
"title": "Odpowiedź",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "oczekiwanie na połączenie",
|
"waiting_for_connection": "oczekiwanie na połączenie",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "To jest Twoja nazwa wyświetlana.",
|
"account_name_description": "To jest Twoja nazwa wyświetlana.",
|
||||||
"background": "Tło",
|
"background": "Tło",
|
||||||
"black_mode": "Czarny",
|
"black_mode": "Czarny",
|
||||||
|
"change_font_size": "Zmień rozmiar czczionki",
|
||||||
"choose_language": "Wybierz język",
|
"choose_language": "Wybierz język",
|
||||||
"dark_mode": "Ciemny",
|
"dark_mode": "Ciemny",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Rozszerzenia",
|
"extensions": "Rozszerzenia",
|
||||||
"extensions_use_toggle": "Użyj rozszerzenia przeglądarki do wysyłania żądań (jeśli istnieje)",
|
"extensions_use_toggle": "Użyj rozszerzenia przeglądarki do wysyłania żądań (jeśli istnieje)",
|
||||||
"follow": "Follow Us",
|
"follow": "Follow Us",
|
||||||
|
"font_size": "Rozmiar czcionki",
|
||||||
|
"font_size_large": "Wielki",
|
||||||
|
"font_size_medium": "Średni",
|
||||||
|
"font_size_small": "Mały",
|
||||||
"interceptor": "Interceptor",
|
"interceptor": "Interceptor",
|
||||||
"interceptor_description": "Oprogramowanie pośredniczące między aplikacją a interfejsami API.",
|
"interceptor_description": "Oprogramowanie pośredniczące między aplikacją a interfejsami API.",
|
||||||
"language": "Język",
|
"language": "Język",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Przejdź do strony Ustawienia",
|
"settings": "Przejdź do strony Ustawienia",
|
||||||
"title": "Nawigacja"
|
"title": "Nawigacja"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Kopiuj łącze żądania",
|
"copy_request_link": "Kopiuj łącze żądania",
|
||||||
"delete_method": "Wybierz metodę DELETE",
|
"delete_method": "Wybierz metodę DELETE",
|
||||||
"get_method": "Wybierz metodę GET",
|
"get_method": "Wybierz metodę GET",
|
||||||
"head_method": "Wybierz metodę HEAD",
|
"head_method": "Wybierz metodę HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "metoda",
|
"method": "metoda",
|
||||||
"next_method": "Wybierz następną metodę",
|
"next_method": "Wybierz następną metodę",
|
||||||
"post_method": "Wybierz metodę POST",
|
"post_method": "Wybierz metodę POST",
|
||||||
"previous_method": "Wybierz poprzednią metodę",
|
"previous_method": "Wybierz poprzednią metodę",
|
||||||
"put_method": "Wybierz metodę PUT",
|
"put_method": "Wybierz metodę PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Zresetuj żądanie",
|
"reset_request": "Zresetuj żądanie",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Zapisz w kolekcjach",
|
"save_to_collections": "Zapisz w kolekcjach",
|
||||||
"send_request": "Wyślij żądanie",
|
"send_request": "Wyślij żądanie",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Żądania"
|
"title": "Żądania"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Logi",
|
"log": "Logi",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Typ wydarzenia",
|
"event_type": "Typ wydarzenia",
|
||||||
"log": "Logi",
|
"log": "Logi",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Autoryzacja",
|
"authorization": "Autoryzacja",
|
||||||
"body": "Ciało",
|
"body": "Ciało",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Kolekcje",
|
"collections": "Kolekcje",
|
||||||
"documentation": "Dokumentacja",
|
"documentation": "Dokumentacja",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Nagłówki",
|
"headers": "Nagłówki",
|
||||||
"history": "Historia",
|
"history": "Historia",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
"choose_file": "Escolha um arquivo",
|
"choose_file": "Escolha um arquivo",
|
||||||
"clear": "Limpar",
|
"clear": "Limpar",
|
||||||
"clear_all": "Limpar tudo",
|
"clear_all": "Limpar tudo",
|
||||||
"clear_history": "Clear all History",
|
|
||||||
"close": "Close",
|
"close": "Close",
|
||||||
"connect": "Conectar",
|
"connect": "Conectar",
|
||||||
"connecting": "Connecting",
|
"connecting": "Connecting",
|
||||||
@@ -32,7 +31,6 @@
|
|||||||
"paste": "Colar",
|
"paste": "Colar",
|
||||||
"prettify": "Embelezar",
|
"prettify": "Embelezar",
|
||||||
"remove": "Remover",
|
"remove": "Remover",
|
||||||
"rename": "Rename",
|
|
||||||
"restore": "Restaurar",
|
"restore": "Restaurar",
|
||||||
"save": "Salvar",
|
"save": "Salvar",
|
||||||
"scroll_to_bottom": "Scroll to bottom",
|
"scroll_to_bottom": "Scroll to bottom",
|
||||||
@@ -79,8 +77,6 @@
|
|||||||
"search": "Procurar",
|
"search": "Procurar",
|
||||||
"share": "Compartilhado",
|
"share": "Compartilhado",
|
||||||
"shortcuts": "Atalhos",
|
"shortcuts": "Atalhos",
|
||||||
"social_description": "Follow us on social media to stay updated with the latest news, updates and releases.",
|
|
||||||
"social_links": "Social links",
|
|
||||||
"spotlight": "Holofote",
|
"spotlight": "Holofote",
|
||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
"status_description": "Cheque o estado do website.",
|
"status_description": "Cheque o estado do website.",
|
||||||
@@ -135,15 +131,12 @@
|
|||||||
"renamed": "Coleção renomeada",
|
"renamed": "Coleção renomeada",
|
||||||
"request_in_use": "Requisição em uso",
|
"request_in_use": "Requisição em uso",
|
||||||
"save_as": "Salvar como",
|
"save_as": "Salvar como",
|
||||||
"save_to_collection": "Save to Collection",
|
|
||||||
"select": "Selecione uma coleção",
|
"select": "Selecione uma coleção",
|
||||||
"select_location": "Selecione a localização",
|
"select_location": "Selecione a localização",
|
||||||
"select_team": "Selecione uma equipe",
|
"select_team": "Selecione uma equipe",
|
||||||
"team_collections": "Coleções da equipe"
|
"team_collections": "Coleções da equipe"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"close_unsaved_tab": "Are you sure you want to close this tab?",
|
|
||||||
"close_unsaved_tabs": "Are you sure you want to close all tabs? {count} unsaved tabs will be lost.",
|
|
||||||
"exit_team": "Tem certeza que deseja sair desta equipe?",
|
"exit_team": "Tem certeza que deseja sair desta equipe?",
|
||||||
"logout": "Tem certeza que deseja sair?",
|
"logout": "Tem certeza que deseja sair?",
|
||||||
"remove_collection": "Tem certeza de que deseja excluir esta coleção permanentemente?",
|
"remove_collection": "Tem certeza de que deseja excluir esta coleção permanentemente?",
|
||||||
@@ -157,11 +150,6 @@
|
|||||||
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
"save_unsaved_tab": "Do you want to save changes made in this tab?",
|
||||||
"sync": "Tem certeza de que deseja sincronizar este espaço de trabalho?"
|
"sync": "Tem certeza de que deseja sincronizar este espaço de trabalho?"
|
||||||
},
|
},
|
||||||
"context_menu": {
|
|
||||||
"add_parameters": "Add to parameters",
|
|
||||||
"open_request_in_new_tab": "Open request in new tab",
|
|
||||||
"set_environment_variable": "Set as variable"
|
|
||||||
},
|
|
||||||
"count": {
|
"count": {
|
||||||
"header": "Cabeçalho {count}",
|
"header": "Cabeçalho {count}",
|
||||||
"message": "Mensagem {count}",
|
"message": "Mensagem {count}",
|
||||||
@@ -204,31 +192,17 @@
|
|||||||
"create_new": "Crie um novo ambiente",
|
"create_new": "Crie um novo ambiente",
|
||||||
"created": "Ambiente criado",
|
"created": "Ambiente criado",
|
||||||
"deleted": "Deleção de ambiente",
|
"deleted": "Deleção de ambiente",
|
||||||
"duplicated": "Environment duplicated",
|
|
||||||
"edit": "Editar Ambiente",
|
"edit": "Editar Ambiente",
|
||||||
"empty_variables": "No variables",
|
|
||||||
"global": "Global",
|
|
||||||
"global_variables": "Global variables",
|
|
||||||
"invalid_name": "Forneça um nome válido para o ambiente",
|
"invalid_name": "Forneça um nome válido para o ambiente",
|
||||||
"list": "Environment variables",
|
|
||||||
"my_environments": "My Environments",
|
"my_environments": "My Environments",
|
||||||
"name": "Name",
|
|
||||||
"nested_overflow": "Variáveis de ambiente aninhadas são limitadas a 10 níveis",
|
"nested_overflow": "Variáveis de ambiente aninhadas são limitadas a 10 níveis",
|
||||||
"new": "Novo ambiente",
|
"new": "Novo ambiente",
|
||||||
"no_active_environment": "No active environment",
|
|
||||||
"no_environment": "Sem ambiente",
|
"no_environment": "Sem ambiente",
|
||||||
"no_environment_description": "Nenhum ambiente foi selecionado. Escolha o que fazer com as seguintes variáveis.",
|
"no_environment_description": "Nenhum ambiente foi selecionado. Escolha o que fazer com as seguintes variáveis.",
|
||||||
"quick_peek": "Environment Quick Peek",
|
|
||||||
"replace_with_variable": "Replace with variable",
|
|
||||||
"scope": "Scope",
|
|
||||||
"select": "Selecione o ambiente",
|
"select": "Selecione o ambiente",
|
||||||
"set": "Set environment",
|
|
||||||
"set_as_environment": "Set as environment",
|
|
||||||
"team_environments": "Team Environments",
|
"team_environments": "Team Environments",
|
||||||
"title": "Ambientes",
|
"title": "Ambientes",
|
||||||
"updated": "Atualizacao de ambientes",
|
"updated": "Atualizacao de ambientes",
|
||||||
"value": "Value",
|
|
||||||
"variable": "Variable",
|
|
||||||
"variable_list": "Lista de Variáveis"
|
"variable_list": "Lista de Variáveis"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
@@ -252,7 +226,6 @@
|
|||||||
"no_duration": "Sem duração",
|
"no_duration": "Sem duração",
|
||||||
"no_results_found": "No matches found",
|
"no_results_found": "No matches found",
|
||||||
"page_not_found": "This page could not be found",
|
"page_not_found": "This page could not be found",
|
||||||
"proxy_error": "Proxy error",
|
|
||||||
"script_fail": "Não foi possível executar o script pré-requisição",
|
"script_fail": "Não foi possível executar o script pré-requisição",
|
||||||
"something_went_wrong": "Algo deu errado",
|
"something_went_wrong": "Algo deu errado",
|
||||||
"test_script_fail": "Não foi possível executar o script pós-requisição"
|
"test_script_fail": "Não foi possível executar o script pós-requisição"
|
||||||
@@ -278,13 +251,9 @@
|
|||||||
"renamed": "Pasta renomeada"
|
"renamed": "Pasta renomeada"
|
||||||
},
|
},
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"connection_switch_confirm": "Do you want to connect with the latest GraphQL endpoint?",
|
|
||||||
"connection_switch_new_url": "Switching to a tab will disconnected you from the active GraphQL connection. New connection URL is",
|
|
||||||
"connection_switch_url": "You're connected to a GraphQL endpoint the connection URL is",
|
|
||||||
"mutations": "Mutações",
|
"mutations": "Mutações",
|
||||||
"schema": "Esquema",
|
"schema": "Esquema",
|
||||||
"subscriptions": "Assinaturas",
|
"subscriptions": "Assinaturas"
|
||||||
"switch_connection": "Switch connection"
|
|
||||||
},
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"time": "Time",
|
"time": "Time",
|
||||||
@@ -338,36 +307,13 @@
|
|||||||
"json_description": "Importa coleções de um arquivo JSON de Coleções Hoppscotch",
|
"json_description": "Importa coleções de um arquivo JSON de Coleções Hoppscotch",
|
||||||
"title": "Importar"
|
"title": "Importar"
|
||||||
},
|
},
|
||||||
"inspections": {
|
|
||||||
"description": "Inspect possible errors",
|
|
||||||
"environment": {
|
|
||||||
"add_environment": "Add to Environment",
|
|
||||||
"not_found": "Environment variable “{environment}” not found."
|
|
||||||
},
|
|
||||||
"header": {
|
|
||||||
"cookie": "The browser doesn't allow Hoppscotch to set the Cookie Header. While we're working on the Hoppscotch Desktop App (coming soon), please use the Authorization Header instead."
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"401_error": "Please check your authentication credentials.",
|
|
||||||
"404_error": "Please check your request URL and method type.",
|
|
||||||
"cors_error": "Please check your Cross-Origin Resource Sharing configuration.",
|
|
||||||
"default_error": "Please check your request.",
|
|
||||||
"network_error": "Please check your network connection."
|
|
||||||
},
|
|
||||||
"title": "Inspector",
|
|
||||||
"url": {
|
|
||||||
"extension_not_installed": "Extension not installed.",
|
|
||||||
"extension_unknown_origin": "Make sure you've added the API endpoint's origin to the Hoppscotch Browser Extension list.",
|
|
||||||
"extention_enable_action": "Enable Browser Extension",
|
|
||||||
"extention_not_enabled": "Extension not enabled."
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"layout": {
|
"layout": {
|
||||||
"collapse_collection": "Encolher ou expandir coleções",
|
"collapse_collection": "Encolher ou expandir coleções",
|
||||||
"collapse_sidebar": "Encolher ou Expandir a barra lateral",
|
"collapse_sidebar": "Encolher ou Expandir a barra lateral",
|
||||||
"column": "Layout vertical",
|
"column": "Layout vertical",
|
||||||
"name": "Layout",
|
"name": "Layout",
|
||||||
"row": "Layout horizontal"
|
"row": "Layout horizontal",
|
||||||
|
"zen_mode": "Modo zen"
|
||||||
},
|
},
|
||||||
"modal": {
|
"modal": {
|
||||||
"close_unsaved_tab": "You have unsaved changes",
|
"close_unsaved_tab": "You have unsaved changes",
|
||||||
@@ -472,7 +418,6 @@
|
|||||||
"payload": "Payload",
|
"payload": "Payload",
|
||||||
"query": "Enviar",
|
"query": "Enviar",
|
||||||
"raw_body": "Corpo de Requisição Bruta",
|
"raw_body": "Corpo de Requisição Bruta",
|
||||||
"rename": "Rename Request",
|
|
||||||
"renamed": "Requisição renomeada",
|
"renamed": "Requisição renomeada",
|
||||||
"run": "Executar",
|
"run": "Executar",
|
||||||
"save": "Salvar",
|
"save": "Salvar",
|
||||||
@@ -480,7 +425,6 @@
|
|||||||
"saved": "Requisição salva",
|
"saved": "Requisição salva",
|
||||||
"share": "Compartilhadar",
|
"share": "Compartilhadar",
|
||||||
"share_description": "Compartilhe o Hoppscotch com seus amigos",
|
"share_description": "Compartilhe o Hoppscotch com seus amigos",
|
||||||
"stop": "Stop",
|
|
||||||
"title": "Solicitar",
|
"title": "Solicitar",
|
||||||
"type": "Tipo de requisição",
|
"type": "Tipo de requisição",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
@@ -488,7 +432,6 @@
|
|||||||
"view_my_links": "View my links"
|
"view_my_links": "View my links"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
"audio": "Audio",
|
|
||||||
"body": "Corpo de Resposta",
|
"body": "Corpo de Resposta",
|
||||||
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
"filter_response_body": "Filter JSON response body (uses JSONPath syntax)",
|
||||||
"headers": "Cabeçalhos",
|
"headers": "Cabeçalhos",
|
||||||
@@ -502,7 +445,6 @@
|
|||||||
"status": "Status",
|
"status": "Status",
|
||||||
"time": "Tempo",
|
"time": "Tempo",
|
||||||
"title": "Resposta",
|
"title": "Resposta",
|
||||||
"video": "Video",
|
|
||||||
"waiting_for_connection": "aguardando conexão",
|
"waiting_for_connection": "aguardando conexão",
|
||||||
"xml": "XML"
|
"xml": "XML"
|
||||||
},
|
},
|
||||||
@@ -515,6 +457,7 @@
|
|||||||
"account_name_description": "Este é o seu nome de exibição.",
|
"account_name_description": "Este é o seu nome de exibição.",
|
||||||
"background": "Fundo",
|
"background": "Fundo",
|
||||||
"black_mode": "Preto",
|
"black_mode": "Preto",
|
||||||
|
"change_font_size": "Mudar TAMANHO DA FONTE",
|
||||||
"choose_language": "Escolha o seu idioma",
|
"choose_language": "Escolha o seu idioma",
|
||||||
"dark_mode": "Escuro",
|
"dark_mode": "Escuro",
|
||||||
"delete_account": "Delete account",
|
"delete_account": "Delete account",
|
||||||
@@ -527,6 +470,10 @@
|
|||||||
"extensions": "Extensões",
|
"extensions": "Extensões",
|
||||||
"extensions_use_toggle": "Use a extensão do navegador para enviar solicitações (se houver)",
|
"extensions_use_toggle": "Use a extensão do navegador para enviar solicitações (se houver)",
|
||||||
"follow": "Nos siga",
|
"follow": "Nos siga",
|
||||||
|
"font_size": "Tamanho da fonte",
|
||||||
|
"font_size_large": "Grande",
|
||||||
|
"font_size_medium": "Médio",
|
||||||
|
"font_size_small": "Pequeno",
|
||||||
"interceptor": "Interceptor",
|
"interceptor": "Interceptor",
|
||||||
"interceptor_description": "Middleware entre aplicativo e APIs.",
|
"interceptor_description": "Middleware entre aplicativo e APIs.",
|
||||||
"language": "Língua",
|
"language": "Língua",
|
||||||
@@ -591,27 +538,19 @@
|
|||||||
"settings": "Vá para a página de configurações",
|
"settings": "Vá para a página de configurações",
|
||||||
"title": "Navegação"
|
"title": "Navegação"
|
||||||
},
|
},
|
||||||
"others": {
|
|
||||||
"prettify": "Prettify Editor's Content",
|
|
||||||
"title": "Others"
|
|
||||||
},
|
|
||||||
"request": {
|
"request": {
|
||||||
"copy_request_link": "Copiar link de requisição",
|
"copy_request_link": "Copiar link de requisição",
|
||||||
"delete_method": "Selecione o método DELETE",
|
"delete_method": "Selecione o método DELETE",
|
||||||
"get_method": "Selecione o método GET",
|
"get_method": "Selecione o método GET",
|
||||||
"head_method": "Selecione o método HEAD",
|
"head_method": "Selecione o método HEAD",
|
||||||
"import_curl": "Import cURL",
|
|
||||||
"method": "Método",
|
"method": "Método",
|
||||||
"next_method": "Selecione o próximo método",
|
"next_method": "Selecione o próximo método",
|
||||||
"post_method": "Selecione o método POST",
|
"post_method": "Selecione o método POST",
|
||||||
"previous_method": "Selecione o método anterior",
|
"previous_method": "Selecione o método anterior",
|
||||||
"put_method": "Selecione o método PUT",
|
"put_method": "Selecione o método PUT",
|
||||||
"rename": "Rename Request",
|
|
||||||
"reset_request": "Pedido de reinicialização",
|
"reset_request": "Pedido de reinicialização",
|
||||||
"save_request": "Save Request",
|
|
||||||
"save_to_collections": "Salvar em coleções",
|
"save_to_collections": "Salvar em coleções",
|
||||||
"send_request": "Enviar requisição",
|
"send_request": "Enviar requisição",
|
||||||
"show_code": "Generate code snippet",
|
|
||||||
"title": "Solicitar"
|
"title": "Solicitar"
|
||||||
},
|
},
|
||||||
"response": {
|
"response": {
|
||||||
@@ -641,85 +580,6 @@
|
|||||||
"log": "Registro",
|
"log": "Registro",
|
||||||
"url": "URL"
|
"url": "URL"
|
||||||
},
|
},
|
||||||
"spotlight": {
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"environments": {
|
|
||||||
"delete": "Delete current environment",
|
|
||||||
"duplicate": "Duplicate current environment",
|
|
||||||
"duplicate_global": "Duplicate global environment",
|
|
||||||
"edit": "Edit current environment",
|
|
||||||
"edit_global": "Edit global environment",
|
|
||||||
"new": "Create new environment",
|
|
||||||
"new_variable": "Create a new environment variable",
|
|
||||||
"title": "Environments"
|
|
||||||
},
|
|
||||||
"general": {
|
|
||||||
"chat": "Chat with support",
|
|
||||||
"help_menu": "Help and support",
|
|
||||||
"open_docs": "Read Documentation",
|
|
||||||
"open_github": "Open GitHub repository",
|
|
||||||
"open_keybindings": "Keyboard shortcuts",
|
|
||||||
"social": "Social",
|
|
||||||
"title": "General"
|
|
||||||
},
|
|
||||||
"graphql": {
|
|
||||||
"connect": "Connect to server",
|
|
||||||
"disconnect": "Disconnect from server"
|
|
||||||
},
|
|
||||||
"miscellaneous": {
|
|
||||||
"invite": "Invite your friends to Hoppscotch",
|
|
||||||
"title": "Miscellaneous"
|
|
||||||
},
|
|
||||||
"request": {
|
|
||||||
"save_as_new": "Save as new request",
|
|
||||||
"select_method": "Select method",
|
|
||||||
"switch_to": "Switch to",
|
|
||||||
"tab_authorization": "Authorization tab",
|
|
||||||
"tab_body": "Body tab",
|
|
||||||
"tab_headers": "Headers tab",
|
|
||||||
"tab_parameters": "Parameters tab",
|
|
||||||
"tab_pre_request_script": "Pre-request script tab",
|
|
||||||
"tab_query": "Query tab",
|
|
||||||
"tab_tests": "Tests tab",
|
|
||||||
"tab_variables": "Variables tab"
|
|
||||||
},
|
|
||||||
"response": {
|
|
||||||
"copy": "Copy response",
|
|
||||||
"download": "Download response as file",
|
|
||||||
"title": "Response"
|
|
||||||
},
|
|
||||||
"section": {
|
|
||||||
"interceptor": "Interceptor",
|
|
||||||
"interface": "Interface",
|
|
||||||
"theme": "Theme",
|
|
||||||
"user": "User"
|
|
||||||
},
|
|
||||||
"settings": {
|
|
||||||
"change_interceptor": "Change Interceptor",
|
|
||||||
"change_language": "Change Language",
|
|
||||||
"theme": {
|
|
||||||
"black": "Black",
|
|
||||||
"dark": "Dark",
|
|
||||||
"light": "Light",
|
|
||||||
"system": "System preference"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tab": {
|
|
||||||
"close_current": "Close current tab",
|
|
||||||
"close_others": "Close all other tabs",
|
|
||||||
"duplicate": "Duplicate current tab",
|
|
||||||
"new_tab": "Open a new tab",
|
|
||||||
"title": "Tabs"
|
|
||||||
},
|
|
||||||
"workspace": {
|
|
||||||
"delete": "Delete current team",
|
|
||||||
"edit": "Edit current team",
|
|
||||||
"invite": "Invite people to team",
|
|
||||||
"new": "Create new team",
|
|
||||||
"switch_to_personal": "Switch to your personal workspace",
|
|
||||||
"title": "Teams"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"sse": {
|
"sse": {
|
||||||
"event_type": "Tipo de evento",
|
"event_type": "Tipo de evento",
|
||||||
"log": "Registro",
|
"log": "Registro",
|
||||||
@@ -777,11 +637,8 @@
|
|||||||
"tab": {
|
"tab": {
|
||||||
"authorization": "Autorização",
|
"authorization": "Autorização",
|
||||||
"body": "Corpo",
|
"body": "Corpo",
|
||||||
"close": "Close Tab",
|
|
||||||
"close_others": "Close other Tabs",
|
|
||||||
"collections": "Coleções",
|
"collections": "Coleções",
|
||||||
"documentation": "Documentação",
|
"documentation": "Documentação",
|
||||||
"duplicate": "Duplicate Tab",
|
|
||||||
"environments": "Environments",
|
"environments": "Environments",
|
||||||
"headers": "Cabeçalhos",
|
"headers": "Cabeçalhos",
|
||||||
"history": "História",
|
"history": "História",
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user