Compare commits

..

134 Commits

Author SHA1 Message Date
ff35a2a95c chore(release): 3.2.1 2022-03-14 09:23:16 +01:00
549363bbe5 feat(i18n): add Chinese (Simplified) language to locales 2022-03-14 09:23:01 +01:00
e6bda688ac fix(client/basics): fix issue with overlapping photo filters on safari/webkit/iOS 2022-03-14 09:19:22 +01:00
64b0c5e7cf Merge pull request #681 from AmruthPillai/i18n_main
New Crowdin updates
2022-03-14 09:09:26 +01:00
57f7edc134 fix(docker): fix docker-compose for production grade deployments 2022-03-14 09:03:47 +01:00
c62a3c2dfd New translations modals.json (Chinese Simplified) 2022-03-14 07:38:30 +01:00
b7f024913c New translations dashboard.json (Chinese Simplified) 2022-03-14 07:38:28 +01:00
488631e6b0 New translations landing.json (Chinese Simplified) 2022-03-14 07:38:25 +01:00
ca5a866249 New translations builder.json (Chinese Simplified) 2022-03-14 07:38:23 +01:00
3a0cd4e150 New translations common.json (Chinese Simplified) 2022-03-14 07:38:19 +01:00
e82e714e41 chore(release): 3.2.0 2022-03-14 06:40:41 +01:00
21931bc324 feat(i18n): add Bengali, Italian and other languages 2022-03-14 06:40:16 +01:00
ed75a85827 fix(client): fix issue with react-query cache 2022-03-14 06:33:14 +01:00
fbb0285d0d Merge pull request #678 from AmruthPillai/i18n_main
New Crowdin updates
2022-03-14 06:10:51 +01:00
b056b002b7 New translations builder.json (Italian) 2022-03-14 02:04:09 +01:00
8b32bfb9f4 New translations modals.json (Italian) 2022-03-13 22:03:59 +01:00
cf3696c976 New translations dashboard.json (Italian) 2022-03-13 22:03:56 +01:00
aa0dc1d7fb New translations landing.json (Italian) 2022-03-13 22:03:54 +01:00
f5bf77cfd0 New translations builder.json (Italian) 2022-03-13 22:03:51 +01:00
9ddbc7cab2 New translations common.json (Italian) 2022-03-13 22:03:49 +01:00
f7d11c5fd2 New translations landing.json (Bengali) 2022-03-13 21:03:51 +01:00
bede07656b New translations dashboard.json (Bengali) 2022-03-13 21:03:48 +01:00
49b56f7a76 New translations modals.json (Bengali) 2022-03-13 20:08:25 +01:00
1421fc5183 New translations common.json (Bengali) 2022-03-13 20:08:20 +01:00
b3da226d24 New translations builder.json (Bengali) 2022-03-13 20:08:19 +01:00
3d7a5b9313 Merge pull request #675 from AmruthPillai/i18n_main
New Crowdin updates
2022-03-13 19:02:01 +01:00
86ca4602fd Merge pull request #667 from chandiwalaaadhar/fix/skillModal-disable-and-beginner-text-clashing
Fixed Near Overlapping of "Disable" & "Beginner" Label Text in Skills Modal for Desktop Screen
2022-03-13 19:01:52 +01:00
3dde7e5772 Merge pull request #669 from chandiwalaaadhar/fix/gengar-theme-masthead-icons-disapper
Fix-Gengar Theme MastHead Icons Disappear on Theme/Primary Color Change
2022-03-13 19:01:45 +01:00
0782c616ea Merge branch 'main' into fix/gengar-theme-masthead-icons-disapper 2022-03-13 18:56:14 +01:00
d1d3f240b4 Merge branch 'main' of github.com:AmruthPillai/Reactive-Resume 2022-03-13 18:54:03 +01:00
b18120b3f7 fix(app): fix issue with external link redirection in android app 2022-03-13 18:53:48 +01:00
b5809ea449 New translations common.json (Vietnamese) 2022-03-13 17:52:24 +01:00
01acec4a51 New translations common.json (Spanish) 2022-03-13 17:52:21 +01:00
9d076d384c Merge branch 'main' into fix/gengar-theme-masthead-icons-disapper 2022-03-13 21:35:16 +05:30
e7a8596456 Fix-Gengar Theme MastHead Icons Disappear on Theme Change 2022-03-13 12:47:57 +05:30
ab4df6193c Fixed Near Overlapping of Disable & Beginner Text in Skills Modal for Desktop 2022-03-13 12:00:25 +05:30
e4a9f269d2 Merge pull request #662 from AmruthPillai/i18n_main
New Crowdin updates
2022-03-13 07:24:36 +01:00
189cc702c2 New translations modals.json (Italian) 2022-03-13 07:13:32 +01:00
c348b6449b New translations landing.json (Italian) 2022-03-13 07:13:29 +01:00
708920df44 New translations landing.json (German) 2022-03-13 07:13:28 +01:00
81733e5855 New translations landing.json (Spanish) 2022-03-13 07:13:27 +01:00
794c7df374 New translations modals.json (German) 2022-03-13 07:13:24 +01:00
267f593ec2 New translations modals.json (Spanish) 2022-03-13 07:13:23 +01:00
048927a163 New translations dashboard.json (Spanish) 2022-03-13 07:13:16 +01:00
f4a65122c6 New translations dashboard.json (German) 2022-03-13 07:13:15 +01:00
6587c76397 New translations dashboard.json (Italian) 2022-03-13 07:13:14 +01:00
80223a240c New translations builder.json (Italian) 2022-03-13 07:13:12 +01:00
50faa5dff3 New translations modals.json (French) 2022-03-12 20:25:37 +01:00
6a4521b057 New translations landing.json (French) 2022-03-12 20:25:33 +01:00
81a4d7291a New translations dashboard.json (French) 2022-03-12 20:25:32 +01:00
381cfcc220 New translations builder.json (French) 2022-03-12 20:25:28 +01:00
0f555e4f88 New translations common.json (French) 2022-03-12 20:25:27 +01:00
ebd9253038 chore(release): 3.1.4 2022-03-12 19:46:45 +01:00
cf670af403 fix(client): exported pdf did not contain "Present" keyword with translations 2022-03-12 19:46:30 +01:00
dfccb3130f fix(client): fix issues raised through lgtm alerts 2022-03-12 18:56:00 +01:00
ef06240935 docs(readme): add localization percentage badge 2022-03-12 18:47:34 +01:00
55e57353a4 New translations modals.json (Italian) 2022-03-12 18:23:47 +01:00
f0144cc6e7 New translations landing.json (Italian) 2022-03-12 18:23:44 +01:00
e5150ab128 New translations common.json (Italian) 2022-03-12 18:23:40 +01:00
d61905db10 chore(release): 3.1.3 2022-03-12 17:41:29 +01:00
6d55f917ea fix(server): reform url for pdf generation and download
fix #661
2022-03-12 17:41:16 +01:00
4371f3b693 New translations dashboard.json (Italian) 2022-03-12 17:28:42 +01:00
c8c5916d02 Update local-build.mdx 2022-03-12 16:09:08 +01:00
3ca27f2326 docs(style): update CHANGELOG.md 2022-03-12 15:59:34 +01:00
f78f24c972 chore(release): 3.1.2 2022-03-12 15:57:28 +01:00
11cb066573 ci(docker): include traefik routing and proxy to ensure server connections pass in local 2022-03-12 15:55:04 +01:00
528ac84d3b chore(release): 3.1.1 2022-03-12 15:20:01 +01:00
b515fc36e7 feat(client): add product hunt announcement banner 2022-03-12 15:19:19 +01:00
d7268423df chore(release): 3.1.0 2022-03-12 13:01:40 +01:00
bf167f81a3 feat(client): add "spanish (es)" language to i18n locales 2022-03-12 13:01:16 +01:00
9e2f22d878 Merge pull request #654 from AmruthPillai/i18n_main
New Crowdin updates
2022-03-12 12:58:17 +01:00
084b909152 New translations common.json (Hindi) 2022-03-12 12:57:47 +01:00
3955afee8d New translations common.json (German) 2022-03-12 12:57:42 +01:00
f2dd2b5fcf New translations common.json (Kannada) 2022-03-12 12:57:37 +01:00
305561955a New translations common.json (Tamil) 2022-03-12 12:57:36 +01:00
cadbd3dfe8 New translations common.json (Spanish) 2022-03-12 12:57:34 +01:00
b5cd6c412b fix(client): show "present" string if end date is not entered, also add to i18n locales
fix #653
2022-03-12 12:49:11 +01:00
799f20823e fix(server): photo uploads not working, fix save location and returned url
fix #658
2022-03-12 12:37:04 +01:00
dda42b4c6b fix(client): remove hard-coded "keywords:" in certain templates
fix #650
2022-03-12 12:32:35 +01:00
f1c260736a New translations builder.json (Spanish) 2022-03-12 12:16:43 +01:00
b5a9b26f34 New translations builder.json (German) 2022-03-12 12:06:43 +01:00
918bd555c1 New translations builder.json (Spanish) 2022-03-12 12:06:42 +01:00
9ea2775790 New translations builder.json (Kannada) 2022-03-12 12:06:38 +01:00
9d83b997f5 New translations builder.json (Hindi) 2022-03-12 12:06:36 +01:00
228fb42ba5 New translations builder.json (Tamil) 2022-03-12 12:06:35 +01:00
01da1a06b8 feat(client): disable "Toggle Page Orientation" when there's only one page on the artboard
fix #655
2022-03-12 11:59:14 +01:00
82bf44daa2 feat(client): add mm/yyyy date option to date format options
fixes #656
2022-03-12 11:48:07 +01:00
2cbc582a12 feat(client): add sitemap generation to next app 2022-03-12 11:44:51 +01:00
2b9f016b95 New translations modals.json (Spanish) 2022-03-12 09:55:25 +01:00
358c97eb71 New translations dashboard.json (Spanish) 2022-03-12 09:55:19 +01:00
76ef513b46 New translations landing.json (Spanish) 2022-03-12 09:55:18 +01:00
497c6e01f1 New translations builder.json (Spanish) 2022-03-12 09:55:14 +01:00
e78c4a9adb New translations common.json (Spanish) 2022-03-12 09:55:12 +01:00
30d0151bdb Merge pull request #646 from AmruthPillai/i18n_main
New Crowdin updates
2022-03-11 20:28:50 +01:00
4dd94c3363 Update CHANGELOG.md 2022-03-11 20:27:25 +01:00
f711b089bc New translations landing.json (German) 2022-03-11 20:25:38 +01:00
01c1125153 New translations modals.json (German) 2022-03-11 20:25:37 +01:00
fa42d82416 New translations dashboard.json (German) 2022-03-11 20:25:32 +01:00
6322d4d105 New translations builder.json (German) 2022-03-11 20:25:28 +01:00
77467929c7 New translations common.json (German) 2022-03-11 20:25:27 +01:00
3a524f9c9c fix(lang): add hi, de to next-i18next 2022-03-11 20:21:35 +01:00
63f900870b chore(release): 3.0.0 2022-03-11 20:03:50 +01:00
32f78e85f7 Merge pull request #645 from AmruthPillai/feat/add-docs-workspace
Add docs powered by Docusaurus v2
2022-03-11 20:03:29 +01:00
1cc2232730 docs(docusaurus): update docs, add languages, ready to build 2022-03-11 20:02:16 +01:00
2ff6761630 Merge branch 'main' into feat/add-docs-workspace 2022-03-11 19:48:35 +01:00
5836e55a36 docs(readme): update readme with languages section, add license badge 2022-03-11 19:42:07 +01:00
ec98c14fbd Create LICENSE 2022-03-11 19:40:38 +01:00
78c1f5a380 Delete feature_request.md 2022-03-11 19:29:10 +01:00
808fa45124 Delete bug_report.md 2022-03-11 19:29:04 +01:00
2625ed4f3d Merge pull request #644 from AmruthPillai/i18n_main
New Crowdin updates
2022-03-11 19:27:42 +01:00
40085f8d78 New translations modals.json (Hindi) 2022-03-11 19:26:50 +01:00
f4e3be178c New translations landing.json (German) 2022-03-11 19:26:48 +01:00
601f61c59a New translations dashboard.json (Hindi) 2022-03-11 19:26:47 +01:00
59049e8f77 New translations modals.json (German) 2022-03-11 19:26:45 +01:00
798e77f693 New translations landing.json (Hindi) 2022-03-11 19:26:44 +01:00
78565079e7 New translations common.json (Hindi) 2022-03-11 19:26:42 +01:00
0bec4cff05 New translations dashboard.json (German) 2022-03-11 19:26:38 +01:00
26dc0069f9 New translations common.json (German) 2022-03-11 19:26:36 +01:00
90bb80b1e2 New translations builder.json (German) 2022-03-11 19:26:35 +01:00
61ed3ff018 New translations modals.json (Kannada) 2022-03-11 19:26:34 +01:00
36a12e82a2 New translations builder.json (Hindi) 2022-03-11 19:26:26 +01:00
a3cf1752cc Merge pull request #643 from AmruthPillai/i18n_main
New Crowdin updates
2022-03-11 19:06:12 +01:00
5b79e23564 Merge branch 'main' into i18n_main 2022-03-11 19:06:05 +01:00
300e4a790d New translations modals.json (Kannada) 2022-03-11 19:04:32 +01:00
ba4666b767 New translations modals.json (Tamil) 2022-03-11 19:04:31 +01:00
b283c6ee8f New translations landing.json (Tamil) 2022-03-11 19:04:29 +01:00
316eca35ef New translations common.json (Kannada) 2022-03-11 19:04:27 +01:00
16c18de964 New translations common.json (Tamil) 2022-03-11 19:04:26 +01:00
0c23af4be8 New translations builder.json (Kannada) 2022-03-11 19:04:25 +01:00
fe1b325fdf New translations builder.json (Tamil) 2022-03-11 19:04:24 +01:00
9395a4d578 docs(style): update CHANGELOG.md 2022-03-11 15:46:49 +01:00
ef3b2c5638 docs(source-code): add docs to build project from source, docker + local build 2022-03-09 14:05:40 +01:00
6c671f2dba Merge branch 'main' into feat/add-docs-workspace 2022-03-09 11:08:17 +01:00
dc4aa0b496 feat(docs): add docusaurus workspace, initial setup of docs 2022-03-08 23:54:00 +01:00
128 changed files with 11448 additions and 670 deletions

View File

@ -11,7 +11,7 @@ POSTGRES_HOST=localhost
POSTGRES_PORT=5432
POSTGRES_USERNAME=postgres
POSTGRES_PASSWORD=postgres
POSTGRES_DATABASE=reactive_resume
POSTGRES_DATABASE=postgres
POSTGRES_SSL_CERT=
# Auth

View File

@ -1,38 +0,0 @@
---
name: Bug report
about: Create a report to help improve
title: "[BUG] "
labels: bug
assignees: ''
---
**Describe the bug**
A clear and concise description of what the bug is.
**To Reproduce**
Steps to reproduce the behavior:
1. Go to '...'
2. Click on '....'
3. Scroll down to '....'
4. See error
**Expected behavior**
A clear and concise description of what you expected to happen.
**Screenshots**
If applicable, add screenshots to help explain your problem.
**Desktop (please complete the following information):**
- OS: [e.g. iOS]
- Browser [e.g. chrome, safari]
- Version [e.g. 22]
**Smartphone (please complete the following information):**
- Device: [e.g. iPhone6]
- OS: [e.g. iOS8.1]
- Browser [e.g. stock browser, safari]
- Version [e.g. 22]
**Additional context**
Add any other context about the problem here.

View File

@ -1,20 +0,0 @@
---
name: Feature request
about: Suggest an idea for this project
title: "[FEATURE] "
labels: enhancement
assignees: AmruthPillai
---
**Is your feature request related to a problem? Please describe.**
A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]
**Describe the solution you'd like**
A clear and concise description of what you want to happen.
**Describe alternatives you've considered**
A clear and concise description of any alternative solutions or features you've considered.
**Additional context**
Add any other context or screenshots about the feature request here.

View File

@ -1,11 +1,18 @@
# Build Artifacts
dist
.next
# Schema
schema/dist
# Server
server/dist
# Client
client/.next
client/public/__ENV.js
# IDEs
.vscode
# Project Metadata
LICENSE
README.md
CHANGELOG.md
@ -18,4 +25,8 @@ Dockerfile
docker-compose.yml
# Android App
/app
/app
# Docs
docs/build
docs/.docusaurus

View File

@ -2,14 +2,92 @@
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
## [3.0.0-beta.6](https://github.com/AmruthPillai/Reactive-Resume/compare/v3.0.0-beta.5...v3.0.0-beta.6) (2022-03-11)
### [3.2.1](https://github.com/AmruthPillai/Reactive-Resume/compare/v3.2.0...v3.2.1) (2022-03-14)
### Features
* **lang:** add language switcher on the landing page, in the footer ([8bc7d25](https://github.com/AmruthPillai/Reactive-Resume/commit/8bc7d2599ef6af7a07bfbe886c43844152b0d9f7))
* **i18n:** add Chinese (Simplified) language to locales ([549363b](https://github.com/AmruthPillai/Reactive-Resume/commit/549363bbe5bdd781699dea9506bd4baedf5740d1))
### Bug Fixes
* **client/basics:** fix issue with overlapping photo filters on safari/webkit/iOS ([e6bda68](https://github.com/AmruthPillai/Reactive-Resume/commit/e6bda688ac3ba1c04e82721add92e755ea5386c3))
* **docker:** fix docker-compose for production grade deployments ([57f7edc](https://github.com/AmruthPillai/Reactive-Resume/commit/57f7edc13432a038c907afc6cb74b5182a9b2333))
## [3.2.0](https://github.com/AmruthPillai/Reactive-Resume/compare/v3.1.4...v3.2.0) (2022-03-14)
### Features
* **i18n:** add Bengali, Italian and other languages ([21931bc](https://github.com/AmruthPillai/Reactive-Resume/commit/21931bc324b5e2440baaaaa2e52a93b4f2c766f8))
### Bug Fixes
* **app:** fix issue with external link redirection in android app ([b18120b](https://github.com/AmruthPillai/Reactive-Resume/commit/b18120b3f7223981e28c0441a6b7725787186edb))
* **client:** fix issue with react-query cache ([ed75a85](https://github.com/AmruthPillai/Reactive-Resume/commit/ed75a858279047dfd43152e041c1a09a625417f5))
### [3.1.4](https://github.com/AmruthPillai/Reactive-Resume/compare/v3.1.3...v3.1.4) (2022-03-12)
### Bug Fixes
* **client:** exported pdf did not contain "Present" keyword with translations ([cf670af](https://github.com/AmruthPillai/Reactive-Resume/commit/cf670af4035dc9b462cf5b1aad06ca089cf1d40c))
* **client:** fix issues raised through lgtm alerts ([dfccb31](https://github.com/AmruthPillai/Reactive-Resume/commit/dfccb3130f889934d31196226be3d33e772f323b))
### [3.1.3](https://github.com/AmruthPillai/Reactive-Resume/compare/v3.1.2...v3.1.3) (2022-03-12)
### Bug Fixes
* **server:** reform url for pdf generation and download ([6d55f91](https://github.com/AmruthPillai/Reactive-Resume/commit/6d55f917eab3cb2f5f3a90c5a18f03b625d60021)), closes [#661](https://github.com/AmruthPillai/Reactive-Resume/issues/661)
### [3.1.2](https://github.com/AmruthPillai/Reactive-Resume/compare/v3.1.1...v3.1.2) (2022-03-12)
### CI
* **docker:**: include traefik routing and proxy to ensure server connections pass in local ([11cb066](https://github.com/AmruthPillai/Reactive-Resume/commit/11cb066573c6917857b79c028b97fcda1acaf90a))
### [3.1.1](https://github.com/AmruthPillai/Reactive-Resume/compare/v3.1.0...v3.1.1) (2022-03-12)
### Features
* **client:** add product hunt announcement banner ([b515fc3](https://github.com/AmruthPillai/Reactive-Resume/commit/b515fc36e7f282db92e8eb509b6c5004a944fa95))
## [3.1.0](https://github.com/AmruthPillai/Reactive-Resume/compare/v3.0.0...v3.1.0) (2022-03-12)
### Features
* **client:** add "spanish (es)" language to i18n locales ([bf167f8](https://github.com/AmruthPillai/Reactive-Resume/commit/bf167f81a3659677dada55856f5eaf0fc469e697))
* **client:** add mm/yyyy date option to date format options ([82bf44d](https://github.com/AmruthPillai/Reactive-Resume/commit/82bf44daa24422156779e9b38d3dc695176eaa09)), closes [#656](https://github.com/AmruthPillai/Reactive-Resume/issues/656)
* **client:** add sitemap generation to next app ([2cbc582](https://github.com/AmruthPillai/Reactive-Resume/commit/2cbc582a12b72b3012246022d4b518ed657d4c08))
* **client:** disable "Toggle Page Orientation" when there's only one page on the artboard ([01da1a0](https://github.com/AmruthPillai/Reactive-Resume/commit/01da1a06b802f1063a41d7a9a682e76b1daf9461)), closes [#655](https://github.com/AmruthPillai/Reactive-Resume/issues/655)
### Bug Fixes
* **client:** remove hard-coded "keywords:" in certain templates ([dda42b4](https://github.com/AmruthPillai/Reactive-Resume/commit/dda42b4c6b3bc359ac4f2bb91ca8118ddc84ec07)), closes [#650](https://github.com/AmruthPillai/Reactive-Resume/issues/650)
* **client:** show "present" string if end date is not entered, also add to i18n locales ([b5cd6c4](https://github.com/AmruthPillai/Reactive-Resume/commit/b5cd6c412b5b6b6ca7bb43c3801762de451f06b4)), closes [#653](https://github.com/AmruthPillai/Reactive-Resume/issues/653)
* **server:** photo uploads not working, fix save location and returned url ([799f208](https://github.com/AmruthPillai/Reactive-Resume/commit/799f20823e6d97a1ff0ba2c45c61d56304d0fa58)), closes [#658](https://github.com/AmruthPillai/Reactive-Resume/issues/658)
## [3.0.0](https://github.com/AmruthPillai/Reactive-Resume/compare/v3.0.0-beta.6...v3.0.0) (2022-03-11)
### Features
* **lang**: add German, Kannada and Tamil languages to the app ([3a524f9](https://github.com/AmruthPillai/Reactive-Resume/commit/3a524f9c9c7a0e446491265b2242ad3dfeae188c))
* **docs:** add docusaurus workspace, initial setup of docs ([dc4aa0b](https://github.com/AmruthPillai/Reactive-Resume/commit/dc4aa0b496096bd59c45426bfcea6ba7db5f5c01))
## [3.0.0-beta.6](https://github.com/AmruthPillai/Reactive-Resume/compare/v3.0.0-beta.5...v3.0.0-beta.6) (2022-03-11)
### Features
* **lang:** add language switcher on the landing page, in the footer ([8bc7d25](https://github.com/AmruthPillai/Reactive-Resume/commit/8bc7d2599ef6af7a07bfbe886c43844152b0d9f7))
### Bug Fixes
* **i18n:** add missing translation keys, update lang/locale logic ([7d8828a](https://github.com/AmruthPillai/Reactive-Resume/commit/7d8828a358d653bb162877a64c75028eb82678cd))

21
LICENSE Normal file
View File

@ -0,0 +1,21 @@
MIT License
Copyright (c) 2022 Amruth Pillai
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.

View File

@ -2,10 +2,13 @@
# Reactive Resume
![Project Version](https://img.shields.io/github/package-json/v/AmruthPillai/Reactive-Resume?style=flat-square)
![Project License](https://img.shields.io/github/license/AmruthPillai/Reactive-Resume?style=flat-square)
[![Crowdin](https://badges.crowdin.net/reactive-resume/localized.svg)](https://translate.rxresu.me)
[![Docker Pulls](https://img.shields.io/docker/pulls/amruthpillai/reactive-resume?style=flat-square)](https://hub.docker.com/r/amruthpillai/reactive-resume)
[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2FAmruthPillai%2FReactive-Resume.svg?type=shield)](https://app.fossa.com/projects/git%2Bgithub.com%2FAmruthPillai%2FReactive-Resume?ref=badge_shield)
## [Go to App](https://beta.rxresu.me/)
## [Go to App](https://rxresu.me) | [Docs](https://docs.rxresu.me)
Reactive Resume is a free and open source resume builder thats built to make the mundane tasks of creating, updating and sharing your resume as easy as 1, 2, 3. With this app, you can create multiple resumes, share them with recruiters through a unique link and print as PDF, all for free, no advertisements, without losing the integrity and privacy of your data.
@ -15,13 +18,13 @@ You have complete control over what goes into your resume, how it looks, what co
- Free, forever
- No Advertising
- No Tracking (no 🍪s too)
- No User Tracking
- Sync your data across devices
- Accessible in multiple languages
- Import data from [LinkedIn](https://www.linkedin.com/), [JSON Resume](https://jsonresume.org/)
- Manage multiple resumes with one account
- Open Source (with large community support)
- Send your resume to others with a unique sharable link
- Accessible in multiple languages, [help translate here](https://translate.rxresu.me/)
- Pick any font from [Google Fonts](https://fonts.google.com/) to use on your resume
- Choose from 6 vibrant templates and more coming soon
- Export your resume to JSON or PDF format with just one click
@ -31,64 +34,32 @@ You have complete control over what goes into your resume, how it looks, what co
- Tailor-made Backend and Database, isolated from Google, Amazon etc.
- **Oh, and did I mention that it's free?**
## Docker Setup
## Languages
You can pull the prebuilt docker images right off the shelf from either [Docker Hub](https://hub.docker.com/repository/docker/amruthpillai/reactive-resume) or [GitHub Container Registry](https://ghcr.io/amruthpillai/reactive-resume). Keep in mind, you would also need a database for this to work as intended.
- Bengali (বাংলা)
- Chinese (中文)
- English
- French (Français)
- German (Deutsch)
- Hindi (हिन्दी)
- Italian (Italiano)
- Kannada (ಕನ್ನಡ)
- Spanish (Español)
- Tamil (தமிழ்)
```sh
# Server
docker run -p 3100:3100 --env-file .env amruthpillai/reactive-resume:server-latest
Help by [translating Reactive Resume](https://translate.rxresu.me) to your language!
# Client
docker run -p 3000:3000 --env-file .env amruthpillai/reactive-resume:client-latest
```
## Tutorial
Or, to make your life easier there's a simple `docker-compose.yml` included to help you get set up for success.
```sh
docker compose up
```
The docs include an extensive [Tutorial](https://docs.rxresu.me/tutorial) section which outline the features of Reactive Resume and help you through building your first resume on the app.
## Build from Source
If you don't want to use Docker, I understand. There's an old-school way to build the app too. This project, and these instructions rely heavily on [pnpm](https://pnpm.io/) so you might want to have that installed on your system before you continue.
1. Clone the repository locally, or use GitHub Codespaces or CodeSandbox
```
git clone https://github.com/AmruthPillai/Reactive-Resume.git
cd Reactive-Resume
```
2. Install dependencies using `pnpm`, but feel free to use any other package manager that supports npm workspaces.
```
pnpm install
```
3. Copy the `.env.example` file to `.env` in the project root and fill it with values according to your setup. You can skip the SendGrid variables if you don't want to set up mail right away.
```
cp .env.example .env
```
1. Use Docker Compose to create a PostgreSQL instance and a `reactive_resume` database, or feel free to use your own and modify the variables used in `.env`
```
docker-compose up -d postgres
```
5. Run the project and start building!
```
pnpm dev
```
For extensive information on how to build the app on your local machine, head over to the docs's [Source Code](https://docs.rxresu.me/source-code) section.
## Contributing
Please refer to the project's style and contribution guidelines for submitting pull requests.
In general, this project follows the "fork-and-pull" Git workflow.
This project makes use of [conventional commits](https://www.conventionalcommits.org/en/v1.0.0/) style and workflow for commit messages to ensure that the CHANGELOG is auto-generated. In general, this project follows the "fork-and-pull" Git workflow.
1. **Fork** the repo on GitHub
2. **Clone** the project to your own machine
@ -106,15 +77,17 @@ Use the [GitHub Issues](https://github.com/AmruthPillai/Reactive-Resume/issues/n
Reactive Resume would be nothing without the folks who supported me and kept the project alive in the beginning, and your cotinued support is what keeps me going. If you found Reactive Resume to be useful, helpful or just insightful and appreciate the effort I took to make the project, please consider donating as little or as much as your can.
[☕️ Buy me a coffee](https://www.buymeacoffee.com/AmruthPillai)
### [☕️ Buy me a coffee](https://www.buymeacoffee.com/AmruthPillai) | [💸 PayPal](https://paypal.me/RajaRajanA)
## Infrastructure
- Next.js, frontend
- NestJS, backend
- PostgreSQL, database
- DigitalOcean, infrastructure provider
- Crowdin, translation management platform
- [Next.js](https://nextjs.org/), frontend
- [NestJS](https://nestjs.com/), backend
- [PostgreSQL](https://www.postgresql.org/), database
- [DigitalOcean](https://www.digitalocean.com/), infrastructure provider
- [Crowdin](https://translate.rxresu.me/), translation management platform
 
<a href="https://pillai.xyz/digitalocean">
<img src="https://opensource.nyc3.cdn.digitaloceanspaces.com/attribution/assets/PoweredByDO/DO_Powered_by_Badge_blue.svg" width="200px" />

View File

@ -10,7 +10,7 @@ android {
applicationId "me.rxresu.app"
minSdk 21
targetSdk 32
versionCode 2
versionCode 3
versionName "1.0"
resConfigs "en"

View File

@ -1,5 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
<manifest
xmlns:android="http://schemas.android.com/apk/res/android"
package="me.rxresu.app">
<uses-permission android:name="android.permission.INTERNET"/>
@ -10,11 +11,11 @@
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.ReactiveResume.NoActionBar">
android:theme="@style/AppTheme">
<activity
android:configChanges="orientation|screenSize"
android:name=".MainActivity"
android:exported="true"
android:theme="@style/Theme.ReactiveResume.NoActionBar">
android:exported="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />

View File

@ -0,0 +1,21 @@
package me.rxresu.app
import android.content.Intent
import android.net.Uri
import android.webkit.WebView
import android.webkit.WebViewClient
internal class CustomWebViewClient : WebViewClient() {
override fun shouldOverrideUrlLoading(view: WebView, url: String): Boolean {
val hostname = "rxresu.me"
val uri = Uri.parse(url)
if (uri.host != null && uri.host!!.endsWith(hostname)) {
return false
}
view.context.startActivity(Intent(Intent.ACTION_VIEW, Uri.parse(url)))
return true
}
}

View File

@ -1,21 +1,15 @@
package me.rxresu.app
import android.annotation.SuppressLint
import android.graphics.Bitmap
import android.os.Bundle
import android.view.KeyEvent
import android.webkit.WebResourceError
import android.webkit.WebResourceRequest
import android.webkit.WebView
import android.webkit.WebViewClient
import androidx.appcompat.app.AppCompatActivity
class MainActivity : AppCompatActivity() {
private lateinit var webView: WebView
private var isLoaded: Boolean = false
private var webURL = "https://rxresu.me"
private var url = "https://rxresu.me"
@SuppressLint("SetJavaScriptEnabled")
override fun onCreate(savedInstanceState: Bundle?) {
@ -24,53 +18,18 @@ class MainActivity : AppCompatActivity() {
webView = findViewById(R.id.webview)
webView.webViewClient = CustomWebViewClient()
webView.settings.javaScriptEnabled = true
webView.settings.userAgentString = "Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/93.0.4577.82 Mobile Safari/537.36"
webView.loadUrl(url)
}
override fun onResume() {
if (!isLoaded) loadWebView()
super.onResume()
}
private fun loadWebView() {
webView.loadUrl(webURL)
webView.webViewClient = object : WebViewClient() {
override fun shouldOverrideUrlLoading(view: WebView?, request: WebResourceRequest?): Boolean {
val url = request?.url.toString()
view?.loadUrl(url)
return super.shouldOverrideUrlLoading(view, request)
}
override fun onPageStarted(view: WebView?, url: String?, favicon: Bitmap?) {
super.onPageStarted(view, url, favicon)
}
override fun onPageFinished(view: WebView?, url: String?) {
isLoaded = true
super.onPageFinished(view, url)
}
override fun onReceivedError(view: WebView, request: WebResourceRequest, error: WebResourceError) {
isLoaded = false
super.onReceivedError(view, request, error)
}
override fun onBackPressed() {
if (webView.canGoBack()) {
webView.goBack()
} else {
super.onBackPressed()
}
}
override fun onKeyDown(keyCode: Int, event: KeyEvent): Boolean {
if (event.action == KeyEvent.ACTION_DOWN) {
if (keyCode == KeyEvent.KEYCODE_BACK) {
if (webView.canGoBack()) {
webView.goBack()
}
return true
}
}
return super.onKeyDown(keyCode, event)
}
}

View File

@ -2,7 +2,6 @@
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">

View File

@ -1,12 +1,6 @@
<resources>
<style name="Theme.ReactiveResume" parent="Theme.MaterialComponents.DayNight.DarkActionBar" />
<style name="Theme.ReactiveResume.NoActionBar">
<style name="AppTheme" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
</style>
<style name="Theme.ReactiveResume.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" />
<style name="Theme.ReactiveResume.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" />
</resources>

View File

@ -33,6 +33,7 @@ const ArtboardController: React.FC<ReactZoomPanPinchRef> = ({ zoomIn, zoomOut, c
const resume = useAppSelector((state) => state.resume);
const isDesktop = useMediaQuery(theme.breakpoints.up('sm'));
const pages = useAppSelector((state) => state.resume.metadata.layout);
const { left, right } = useAppSelector((state) => state.build.sidebar);
const orientation = useAppSelector((state) => state.build.page.orientation);
@ -96,15 +97,17 @@ const ArtboardController: React.FC<ReactZoomPanPinchRef> = ({ zoomIn, zoomOut, c
{isDesktop && (
<>
<Tooltip arrow placement="top" title={t('builder.controller.tooltip.toggle-orientation') as string}>
<ButtonBase onClick={handleTogglePageOrientation}>
{orientation === 'vertical' ? (
<AlignHorizontalCenter fontSize="medium" />
) : (
<AlignVerticalCenter fontSize="medium" />
)}
</ButtonBase>
</Tooltip>
{pages.length > 1 && (
<Tooltip arrow placement="top" title={t('builder.controller.tooltip.toggle-orientation') as string}>
<ButtonBase onClick={handleTogglePageOrientation}>
{orientation === 'vertical' ? (
<AlignHorizontalCenter fontSize="medium" />
) : (
<AlignVerticalCenter fontSize="medium" />
)}
</ButtonBase>
</Tooltip>
)}
<Tooltip arrow placement="top" title={t('builder.controller.tooltip.toggle-page-break-line') as string}>
<ButtonBase onClick={handleTogglePageBreakLine}>

View File

@ -27,10 +27,12 @@ const Basics = () => {
<Heading path="sections.basics" name={t('builder.leftSidebar.sections.basics.heading')} />
<div className="grid grid-cols-1 gap-4 sm:grid-cols-2">
<div className="flex flex-col items-center gap-4 sm:col-span-2 sm:flex-row">
<PhotoUpload />
<div className="grid items-center gap-4 sm:col-span-2 sm:grid-cols-3">
<div className="mx-auto">
<PhotoUpload />
</div>
<div className="flex w-full flex-col-reverse gap-4 sm:flex-col sm:gap-2">
<div className="grid gap-2 w-full sm:col-span-2">
<ResumeInput label={t('builder.leftSidebar.sections.basics.name.label')} path="basics.name" />
<Button variant="outlined" startIcon={<PhotoFilter />} onClick={handleClick}>

View File

@ -38,6 +38,7 @@ const Settings = () => {
const resume = useAppSelector((state) => state.resume);
const theme = useAppSelector((state) => state.build.theme);
const pages = useAppSelector((state) => state.resume.metadata.layout);
const breakLine = useAppSelector((state) => state.build.page.breakLine);
const orientation = useAppSelector((state) => state.build.page.orientation);
@ -65,6 +66,7 @@ const Settings = () => {
const code = value?.code || 'en';
document.cookie = `NEXT_LOCALE=${code}; path=/; expires=2147483647`;
dispatch(setResumeState({ path: 'metadata.locale', value: code }));
push({ pathname, query }, asPath, { locale: code });
};
@ -151,10 +153,15 @@ const Settings = () => {
<ListItem>
<ListItemText
primary={t('builder.rightSidebar.sections.settings.page.orientation.primary')}
secondary={t('builder.rightSidebar.sections.settings.page.orientation.secondary')}
secondary={
pages.length === 1
? t('builder.rightSidebar.sections.settings.page.orientation.disabled')
: t('builder.rightSidebar.sections.settings.page.orientation.secondary')
}
/>
<Switch
color="secondary"
disabled={pages.length === 1}
checked={orientation === 'horizontal'}
onChange={() => dispatch(togglePageOrientation())}
/>

View File

@ -1,4 +1,4 @@
import { Theme } from '@reactive-resume/schema';
import { Theme as ThemeType } from '@reactive-resume/schema';
import get from 'lodash/get';
import { useTranslation } from 'next-i18next';
@ -16,7 +16,7 @@ const Theme = () => {
const dispatch = useAppDispatch();
const { background, text, primary } = useAppSelector<Theme>((state) => get(state.resume, 'metadata.theme'));
const { background, text, primary } = useAppSelector<ThemeType>((state) => get(state.resume, 'metadata.theme'));
const handleChange = (property: string, color: string) => {
dispatch(setResumeState({ path: `metadata.theme.${property}`, value: color }));

View File

@ -1,8 +1,8 @@
import { Testimony } from '@/data/testimonials';
import { Testimony as TestimonyType } from '@/data/testimonials';
import styles from './Testimony.module.scss';
type Props = Testimony;
type Props = TestimonyType;
const Testimony: React.FC<Props> = ({ name, message }) => {
return (

View File

@ -5,6 +5,8 @@ import { useTranslation } from 'next-i18next';
import { MouseEvent, useState } from 'react';
import { languages } from '@/config/languages';
import { useAppDispatch } from '@/store/hooks';
import { setResumeState } from '@/store/resume/resumeSlice';
import styles from './LanguageSwitcher.module.scss';
@ -13,6 +15,8 @@ const LanguageSwitcher = () => {
const { t } = useTranslation();
const dispatch = useAppDispatch();
const [anchorEl, setAnchorEl] = useState<HTMLButtonElement | null>(null);
const handleClick = (event: MouseEvent<HTMLButtonElement>) => setAnchorEl(event.currentTarget);
@ -23,6 +27,8 @@ const LanguageSwitcher = () => {
const { pathname, asPath, query } = router;
document.cookie = `NEXT_LOCALE=${locale}; path=/; expires=2147483647`;
dispatch(setResumeState({ path: 'metadata.locale', value: locale }));
router.push({ pathname, query }, asPath, { locale });
};

View File

@ -5,16 +5,56 @@ export type Language = {
};
export const languages: Language[] = [
{
code: 'bn',
name: 'Bengali',
localName: 'বাংলা',
},
{
code: 'zh',
name: 'Chinese',
localName: '中文',
},
{
code: 'en',
name: 'English',
},
{
code: 'fr',
name: 'French',
localName: 'Français',
},
{
code: 'de',
name: 'German',
localName: 'Deutsch',
},
{
code: 'hi',
name: 'Hindi',
localName: 'हिन्दी',
},
{
code: 'it',
name: 'Italian',
localName: 'Italiano',
},
{
code: 'kn',
name: 'Kannada',
localName: 'ಕನ್ನಡ',
},
];
{
code: 'es',
name: 'Spanish',
localName: 'Español',
},
{
code: 'ta',
name: 'Tamil',
localName: 'தமிழ்',
},
].sort((a, b) => a.name.localeCompare(b.name));
export const languageMap: Record<string, Language> = languages.reduce(
(acc, lang) => ({

View File

@ -3,7 +3,7 @@ export const FONTS_QUERY = 'fonts';
export const RESUMES_QUERY = 'resumes';
// Regular Expressions
export const VALID_URL_REGEX = /[-a-zA-Z0-9@:%._+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_+.~#?&//=]*)/;
export const VALID_URL_REGEX = /[-a-zA-Z0-9@:%._+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_+.~#?&/=]*)/;
// Date Formats
export const FILENAME_TIMESTAMP = 'DDMMYYYYHHmmss';
@ -11,4 +11,5 @@ export const FILENAME_TIMESTAMP = 'DDMMYYYYHHmmss';
// Links
export const DONATION_URL = 'https://www.buymeacoffee.com/AmruthPillai';
export const GITHUB_URL = 'https://github.com/AmruthPillai/Reactive-Resume';
export const PRODUCT_HUNT_URL = 'https://www.producthunt.com/posts/reactive-resume-v3';
export const GITHUB_ISSUES_URL = 'https://github.com/AmruthPillai/Reactive-Resume/issues/new/choose';

View File

@ -125,7 +125,7 @@ const SkillModal: React.FC = () => {
<div className="col-span-2">
<h4 className="mb-3 font-semibold">{t('builder.common.form.levelNum.label')}</h4>
<div className="px-10">
<div className="px-3">
<Slider
{...field}
marks={[

View File

@ -3,7 +3,7 @@ const path = require('path');
const i18nConfig = {
i18n: {
defaultLocale: 'en',
locales: ['en', 'kn'],
locales: ['bn', 'de', 'en', 'es', 'fr', 'hi', 'it', 'kn', 'ta', 'zh'],
},
nsSeparator: '.',
localePath: path.resolve('./public/locales'),

View File

@ -0,0 +1,6 @@
/** @type {import('next-sitemap').IConfig} */
module.exports = {
siteUrl: 'https://rxresu.me',
changefreq: 'monthly',
generateRobotsTxt: true,
};

View File

@ -2,14 +2,15 @@
"name": "@reactive-resume/client",
"scripts": {
"dev": "react-env --prefix PUBLIC -- next dev",
"build": "next build",
"build": "next build && npm run sitemap",
"start": "react-env --prefix PUBLIC -- next start",
"lint": "next lint --fix"
"lint": "next lint --fix",
"sitemap": "next-sitemap --config next-sitemap.config.js"
},
"dependencies": {
"@beam-australia/react-env": "^3.1.1",
"@emotion/css": "^11.7.1",
"@emotion/react": "^11.8.1",
"@emotion/react": "^11.8.2",
"@emotion/styled": "^11.8.1",
"@hookform/resolvers": "2.8.8",
"@monaco-editor/react": "^4.3.1",
@ -24,7 +25,7 @@
"joi": "^17.6.0",
"lodash": "^4.17.21",
"md5-hex": "^4.0.0",
"monaco-editor": "^0.32.1",
"monaco-editor": "^0.33.0",
"nanoid": "^3.3.1",
"next": "12.1.0",
"next-i18next": "^10.5.0",
@ -35,7 +36,7 @@
"react-dnd-html5-backend": "^15.1.2",
"react-dom": ">=17",
"react-google-login": "^5.2.2",
"react-hook-form": "^7.27.1",
"react-hook-form": "^7.28.0",
"react-hot-toast": "2.2.0",
"react-hotkeys-hook": "^3.4.4",
"react-icons": "^4.3.1",
@ -58,15 +59,16 @@
"@types/downloadjs": "^1.4.3",
"@types/lodash": "^4.14.179",
"@types/node": "17.0.21",
"@types/react": "17.0.39",
"@types/react": "17.0.40",
"@types/react-beautiful-dnd": "^13.1.2",
"@types/react-redux": "^7.1.23",
"@types/tailwindcss": "^3.0.9",
"@types/uuid": "^8.3.4",
"@types/webfontloader": "^1.6.34",
"autoprefixer": "^10.4.2",
"eslint": "^8.10.0",
"eslint": "^8.11.0",
"eslint-config-next": "12.1.0",
"next-sitemap": "^2.5.7",
"postcss": "^8.4.8",
"prettier": "^2.5.1",
"sass": "^1.49.9",

View File

@ -42,6 +42,7 @@ const Build: NextPage<Props> = ({ username, slug }) => {
`resume/${username}/${slug}`,
() => fetchResumeByIdentifier({ username, slug }),
{
cacheTime: 0,
refetchOnMount: false,
refetchOnReconnect: false,
refetchOnWindowFocus: false,

View File

@ -3,6 +3,7 @@ import clsx from 'clsx';
import get from 'lodash/get';
import isEmpty from 'lodash/isEmpty';
import { GetServerSideProps, NextPage } from 'next';
import { serverSideTranslations } from 'next-i18next/serverSideTranslations';
import { useEffect } from 'react';
import Page from '@/components/build/Center/Page';
@ -22,15 +23,19 @@ type Props = {
redirect?: any;
};
export const getServerSideProps: GetServerSideProps<Props | Promise<Props>, QueryParams> = async ({ query }) => {
export const getServerSideProps: GetServerSideProps<Props | Promise<Props>, QueryParams> = async ({
query,
locale,
}) => {
const { username, slug, secretKey } = query as QueryParams;
try {
if (isEmpty(secretKey)) throw new Error('There is no secret key!');
const resume = await fetchResumeByIdentifier({ username, slug, options: { secretKey } });
const displayLocale = resume.metadata.locale || locale || 'en';
return { props: { resume } };
return { props: { resume, ...(await serverSideTranslations(displayLocale, ['common'])) } };
} catch (error) {
return {
redirect: {

View File

@ -0,0 +1,358 @@
{
"common": {
"actions": {
"add": "নতুন {{token}} যোগ করুন",
"delete": "{{token}} মুছুন৷",
"edit": "{{token}} সম্পাদনা করুন"
},
"columns": {
"heading": "কলাম",
"tooltip": "কলামের সংখ্যা পরিবর্তন করুন"
},
"form": {
"date": {
"label": "তারিখ"
},
"description": {
"label": "বর্ণনা"
},
"email": {
"label": "ইমেইল ঠিকানা"
},
"end-date": {
"help-text": "এই ক্ষেত্রটি খালি রাখুন, যদি এখনও উপস্থিত থাকে",
"label": "শেষ তারিখ"
},
"keywords": {
"label": "কীওয়ার্ড"
},
"level": {
"label": "স্তর"
},
"levelNum": {
"label": "স্তর (সংখ্যা)"
},
"name": {
"label": "নাম"
},
"phone": {
"label": "ফোন নম্বর"
},
"position": {
"label": "অবস্থান"
},
"start-date": {
"label": "শুরুর তারিখ"
},
"subtitle": {
"label": "সাবটাইটেল"
},
"summary": {
"label": "সারসংক্ষেপ"
},
"title": {
"label": "শিরোনাম"
},
"url": {
"label": "ওয়েবসাইট"
}
},
"glossary": {
"page": "পাতা"
},
"list": {
"actions": {
"delete": "মুছুন",
"duplicate": "প্রতিলিপি",
"edit": "সম্পাদনা করুন"
},
"empty-text": "এই তালিকাটি খালি।"
},
"tooltip": {
"delete-item": "আপনি এই আইটেমটি মুছে ফেলতে চান আপনি কি নিশ্চিত? এটি একটি অপরিবর্তনীয় ক্রিয়া।",
"delete-section": "সেকশন মুছে ফেলুন",
"rename-section": "সেকশনের নাম পরিবর্তন করুন",
"toggle-visibility": "দৃশ্যমানতা টগল করুন"
}
},
"controller": {
"tooltip": {
"center-artboard": "কেন্দ্র আর্টবোর্ড",
"copy-link": "রিজিউমে লিঙ্ক কপি করুন",
"export-pdf": "পিডিএফ আকারে পাঠান",
"toggle-orientation": "পৃষ্ঠা ওরিয়েন্টেশন টগল করুন",
"toggle-page-break-line": "পৃষ্ঠা বিরতি লাইন টগল করুন",
"toggle-sidebars": "সাইডবার টগল করুন",
"zoom-in": "বড় কর",
"zoom-out": "ছোট করা"
}
},
"header": {
"menu": {
"delete": "মুছুন",
"duplicate": "প্রতিলিপি",
"rename": "নাম পরিবর্তন করুন",
"share-link": "লিঙ্ক শেয়ার করুন",
"tooltips": {
"delete": "আপনি কি এই জীবনবৃত্তান্ত মুছতে চান? এটি একটি অপরিবর্তনীয় ক্রিয়া।",
"share-link": "অন্যদের কাছে দৃশ্যমান করার জন্য আপনাকে আপনার জীবনবৃত্তান্তের দৃশ্যমানতা সর্বজনীনভাবে পরিবর্তন করতে হবে।"
}
}
},
"leftSidebar": {
"sections": {
"awards": {
"form": {
"awarder": {
"label": "পুরস্কারদাতা"
}
}
},
"basics": {
"actions": {
"photo-filters": "ফটো ফিল্টার"
},
"heading": "মৌলিক",
"headline": {
"label": "শিরোনাম"
},
"name": {
"label": "পূর্ণ নাম"
},
"photo-filters": {
"effects": {
"border": {
"label": "বর্ডার"
},
"grayscale": {
"label": "গ্রেস্কেল"
},
"heading": "প্রভাব"
},
"shape": {
"heading": "আকৃতি"
},
"size": {
"heading": "আকার (px এ)"
}
},
"photo-upload": {
"tooltip": {
"remove": "ছবি মুছে ফেলুন",
"upload": "ছবি আপলোড করুন"
}
}
},
"certifications": {
"form": {
"issuer": {
"label": "প্রদানকারী"
}
}
},
"education": {
"form": {
"area-study": {
"label": "শিক্ষার বিষয়বস্তু"
},
"courses": {
"label": "কোর্স"
},
"degree": {
"label": "ডিগ্রী"
},
"grade": {
"label": "গ্রেড"
},
"institution": {
"label": "প্রতিষ্ঠান"
}
}
},
"location": {
"address": {
"label": "ঠিকানা"
},
"city": {
"label": "শহর"
},
"country": {
"label": "দেশ"
},
"heading": "অবস্থান",
"postal-code": {
"label": "পোস্ট অফিসের নাম্বার"
},
"region": {
"label": "অঞ্চল"
}
},
"profiles": {
"form": {
"network": {
"label": "নেটওয়ার্ক"
},
"username": {
"label": "ইউজারনেম"
}
},
"heading": "প্রোফাইল",
"heading_one": "প্রোফাইল"
},
"publications": {
"form": {
"publisher": {
"label": "প্রকাশক"
}
}
},
"references": {
"form": {
"relationship": {
"label": "সম্পর্ক"
}
}
},
"section": {
"heading": "অনুচ্ছেদ"
},
"volunteer": {
"form": {
"organization": {
"label": "সংগঠন"
}
}
}
}
},
"rightSidebar": {
"sections": {
"css": {
"heading": "কাস্টম সিএসএস"
},
"export": {
"heading": "এক্সপোর্ট",
"json": {
"primary": "JSON",
"secondary": "আপনার জীবনবৃত্তান্তের একটি JSON সংস্করণ ডাউনলোড করুন যা পুনরায় প্রতিক্রিয়াশীল জীবনবৃত্তান্তে আমদানি করা যেতে পারে।"
},
"pdf": {
"loading": {
"primary": "পিডিএফ তৈরি করা হচ্ছে",
"secondary": "আপনার পিডিএফ তৈরি হওয়ার জন্য অনুগ্রহ করে অপেক্ষা করুন, এতে 15 সেকেন্ড পর্যন্ত সময় লাগতে পারে।"
},
"normal": {
"primary": "পিডিএফ",
"secondary": "আপনার জীবনবৃত্তান্তের একটি পিডিএফ ডাউনলোড করুন যা আপনি প্রিন্ট করে আপনার স্বপ্নের চাকরিতে পাঠাতে পারেন। এই ফাইলটি আরও সম্পাদনার জন্য আবার আমদানি করা যাবে না৷"
}
}
},
"layout": {
"heading": "লেআউট",
"tooltip": {
"reset-layout": "লেআউট রিসেট করুন"
}
},
"links": {
"bugs-features": {
"body": "জীবনবৃত্তান্ত তৈরি করা থেকে কিছু আপনাকে বাধা দিচ্ছে? অথবা আপনি যোগ করার জন্য একটি আশ্চর্যজনক ধারণা আছে? শুরু করতে GitHub-এ একটি সমস্যা উত্থাপন করুন।",
"button": "Github ইস্যু তালিকা",
"heading": "বাগ? বৈশিষ্ট্য অনুরোধ?"
},
"donate": {
"body": "আপনি যদি প্রতিক্রিয়াশীল জীবনবৃত্তান্ত ব্যবহার করতে পছন্দ করেন, অনুগ্রহ করে বিজ্ঞাপন ছাড়া এবং চিরতরে বিনামূল্যে অ্যাপটিকে চালু ও চালু রাখার জন্য যতটা সম্ভব দান করার কথা বিবেচনা করুন।",
"button": "আমাকে একটা কফি কিনে দাও",
"heading": "Reactive Resume -তে দান করুন"
},
"github": "সোর্স কোড",
"heading": "লিঙ্ক"
},
"settings": {
"global": {
"date": {
"primary": "তারিখ",
"secondary": "অ্যাপ জুড়ে ব্যবহার করার জন্য তারিখ বিন্যাস"
},
"heading": "বিশ্বব্যাপী",
"language": {
"primary": "ভাষা",
"secondary": "অ্যাপ জুড়ে ব্যবহার করার জন্য ভাষা প্রদর্শন করুন"
},
"theme": {
"primary": "থিম"
}
},
"heading": "সেটিংস",
"page": {
"break-line": {
"primary": "লাইন ভেঙ্গে ফেলুন",
"secondary": "একটি A4 পৃষ্ঠার উচ্চতা চিহ্নিত করতে সমস্ত পৃষ্ঠায় একটি লাইন দেখান৷"
},
"heading": "পাতা",
"orientation": {
"disabled": "শুধুমাত্র একটি পৃষ্ঠা থাকলে কোন প্রভাব নেই",
"primary": "ওরিয়েন্টেশন",
"secondary": "পৃষ্ঠাগুলি অনুভূমিকভাবে বা উল্লম্বভাবে প্রদর্শন করতে হবে কিনা"
}
},
"resume": {
"heading": "জীবনবৃত্তান্ত",
"reset": {
"primary": "সবকিছু রিসেট করুন",
"secondary": "অনেক ভুল করেছেন? সমস্ত পরিবর্তন পুনরায় সেট করতে এবং স্ক্র্যাচ থেকে শুরু করতে এখানে ক্লিক করুন। সতর্ক থাকুন, এই ক্রিয়াটি উল্টানো যাবে না।"
},
"sample": {
"primary": "নমুনা ডেটা লোড করুন",
"secondary": "কোথায় শুরু করবেন তা নিশ্চিত নন? একটি সম্পূর্ণ জীবনবৃত্তান্ত দেখতে কেমন তা দেখতে কিছু নমুনা ডেটা লোড করতে এখানে ক্লিক করুন৷"
}
}
},
"sharing": {
"heading": "শেয়ারিং",
"short-url": {
"label": "সংক্ষিপ্ত URL পছন্দ করুন"
},
"visibility": {
"subtitle": "লিঙ্ক সহ যে কাউকে আপনার জীবনবৃত্তান্ত দেখার অনুমতি দিন",
"title": "সর্বজনীন"
}
},
"templates": {
"heading": "টেমপ্লেট"
},
"theme": {
"form": {
"background": {
"label": "ব্যাকগ্রাউন্ড"
},
"primary": {
"label": "প্রাথমিক"
},
"text": {
"label": "লেখা"
}
},
"heading": "থিম"
},
"typography": {
"form": {
"font-family": {
"label": "ফন্ট পরিবার"
},
"font-size": {
"label": "অক্ষরের আকার"
}
},
"heading": "টাইপোগ্রাফি",
"widgets": {
"body": {
"label": "বডি"
},
"headings": {
"label": "শিরোনাম"
}
}
}
}
}
}

View File

@ -0,0 +1,32 @@
{
"avatar": {
"menu": {
"greeting": "হ্যালো",
"logout": "লগআউট"
}
},
"footer": {
"credit": "<1>অমরুথ পিল্লাই</1>-এর একটি প্যাশন প্রোজেক্ট",
"language": {
"missing": "আপনার ভাষা অনুপস্থিত?"
},
"license": "সম্প্রদায়ের দ্বারা, সম্প্রদায়ের জন্য।"
},
"markdown": {
"help-text": "এই বিভাগটি <1>মার্কডাউন</1> ফর্ম্যাটিং সমর্থন করে।"
},
"date": {
"present": "বর্তমান"
},
"subtitle": "একটি বিনামূল্যে এবং ওপেন সোর্স জীবনবৃত্তান্ত নির্মাতা।",
"title": "Reactive Resume",
"toast": {
"error": {
"upload-file-size": "অনুগ্রহ করে শুধুমাত্র 2 মেগাবাইটের নিচে ফাইল আপলোড করুন।",
"upload-photo-size": "অনুগ্রহ করে শুধুমাত্র 2 মেগাবাইটের নিচের ছবি আপলোড করুন, বিশেষত বর্গাকার।"
},
"success": {
"resume-link-copied": "আপনার জীবনবৃত্তান্তের একটি লিঙ্ক আপনার ক্লিপবোর্ডে অনুলিপি করা হয়েছে।"
}
}
}

View File

@ -0,0 +1,25 @@
{
"create-resume": {
"subtitle": "শুন্য থেকে শুরু করা",
"title": "নতুন জীবনবৃত্তান্ত তৈরি করুন"
},
"import-external": {
"subtitle": "LinkedIn, JSON জীবনবৃত্তান্ত, প্রতিক্রিয়াশীল জীবনবৃত্তান্ত",
"title": "বহিরাগত উত্স থেকে আমদানি"
},
"resume": {
"menu": {
"delete": "মুছুন",
"duplicate": "প্রতিলিপি",
"open": "খুলুন",
"rename": "নাম পরিবর্তন করুন",
"share-link": "লিঙ্ক শেয়ার করুন",
"tooltips": {
"delete": "আপনি কি এই জীবনবৃত্তান্ত মুছতে চান? এটি একটি অপরিবর্তনীয় ক্রিয়া।",
"share-link": "অন্যদের কাছে দৃশ্যমান করার জন্য আপনাকে আপনার জীবনবৃত্তান্তের দৃশ্যমানতা সর্বজনীনভাবে পরিবর্তন করতে হবে।"
}
},
"timestamp": "সর্বশেষ আপডেট করা হয়েছে {{timestamp}} আগে"
},
"title": "ড্যাশবোর্ড"
}

View File

@ -0,0 +1,41 @@
{
"actions": {
"app": "অ্যাপ্লিকেশন এ যান",
"login": "লগইন",
"logout": "লগআউট",
"register": "নিবন্ধন"
},
"features": {
"heading": "বৈশিষ্ট্যসমূহ",
"list": {
"ads": "বিজ্ঞাপনবিহীন",
"export": "JSON বা PDF ফরম্যাটে আপনার জীবনবৃত্তান্ত রপ্তানি করুন",
"free": "সব সময়ের জন্য ফ্রি",
"import": "LinkedIn, JSON Resume থেকে ডেটা আমদানি করুন",
"languages": "একাধিক ভাষায় অ্যাক্সেসযোগ্য",
"more": "এবং আরও অনেক উত্তেজনাপূর্ণ বৈশিষ্ট্য, <1>এটি সম্পর্কে সমস্ত এখানে পড়ুন</1>৷",
"tracking": "ব্যবাহারকারী ট্রেকারবিহীন"
}
},
"links": {
"heading": "লিঙ্ক",
"links": {
"donate": "দান করুন",
"github": "সোর্স কোড",
"privacy": "গোপনীয়তা নীতি",
"service": "সেবা পাবার শর্ত"
}
},
"screenshots": {
"heading": "স্ক্রিনশট"
},
"testimonials": {
"heading": "প্রশংসাপত্র",
"body": "ভাল বা খারাপ, আমি প্রতিক্রিয়াশীল জীবনবৃত্তান্ত সম্পর্কে আপনার মতামত এবং আপনার জন্য অভিজ্ঞতা কেমন হয়েছে তা জানতে চাই।<br/>এখানে বিশ্বজুড়ে ব্যবহারকারীদের পাঠানো কিছু বার্তা রয়েছে৷",
"contact": "আপনি <1>আমার ইমেল</1> বা <3>আমার ওয়েবসাইট</3>-এ যোগাযোগ ফর্মের মাধ্যমে আমার সাথে যোগাযোগ করতে পারেন।"
},
"summary": {
"body": "Reactive Resume হল একটি বিনামূল্যের এবং ওপেন সোর্স জীবনবৃত্তান্ত নির্মাতা যা আপনার জীবনবৃত্তান্ত তৈরি, আপডেট এবং শেয়ার করার জাগতিক কাজগুলিকে 1, 2, 3 এর মতো সহজ করে তুলতে তৈরি করা হয়েছে৷ এই অ্যাপটির মাধ্যমে, আপনি একাধিক জীবনবৃত্তান্ত তৈরি করতে পারেন, নিয়োগকারীদের বা বন্ধুদের সাথে শেয়ার করতে পারেন৷ একটি অনন্য লিঙ্কের মাধ্যমে এবং আপনার ডেটার অখণ্ডতা এবং গোপনীয়তা হারানো ছাড়াই বিনামূল্যে, কোনও বিজ্ঞাপন, কোনও ট্র্যাকিং ছাড়াই একটি পিডিএফ হিসাবে মুদ্রণ করুন।",
"heading": "সারসংক্ষেপ"
}
}

View File

@ -0,0 +1,135 @@
{
"auth": {
"forgot-password": {
"actions": {
"send-email": "পাসওয়ার্ড রিসেট ইমেল পাঠান"
},
"body": "আপনি যে অ্যাকাউন্টটি পুনরুদ্ধার করতে চান তার সাথে যুক্ত ইমেল ঠিকানাটি লিখুন।",
"form": {
"email": {
"label": "ইমেইল ঠিকানা"
}
},
"heading": "আপনি কি পাসওয়ার্ড ভুলে গেছেন?",
"help-text": "অ্যাকাউন্টটি বিদ্যমান থাকলে, আপনি আপনার পাসওয়ার্ড রিসেট করার জন্য একটি লিঙ্ক সহ একটি ইমেল পাবেন।"
},
"login": {
"actions": {
"login": "লগইন",
"google": "গুগল দিয়ে লগইন করুন"
},
"body": "লগইন এবং অ্যাক্সেস, পরিচালনা এবং আপনার জীবনবৃত্তান্ত শেয়ার করতে আপনার অ্যাকাউন্টের সাথে যুক্ত আপনার ব্যবহারকারীর নাম এবং পাসওয়ার্ড লিখুন।",
"form": {
"password": {
"label": "পাসওয়ার্ড"
},
"username": {
"help-text": "এছাড়াও আপনি আপনার ইমেল ঠিকানা লিখতে পারেন",
"label": "ইউজারনেম"
}
},
"heading": "আপনার অ্যাকাউন্টে লগ ইন করুন",
"recover-text": "আপনি যদি আপনার পাসওয়ার্ড ভুলে গিয়ে থাকেন, আপনি এখানে <1>আপনার অ্যাকাউন্ট পুনরুদ্ধার</1> করতে পারেন৷",
"register-text": "আপনার যদি একটি না থাকে, আপনি এখানে <1>একটি অ্যাকাউন্ট তৈরি করতে</1> পারেন৷"
},
"register": {
"actions": {
"register": "নিবন্ধন",
"google": "Google এর সাথে নিবন্ধন করুন"
},
"body": "একটি অ্যাকাউন্ট তৈরি করতে আপনার ব্যক্তিগত তথ্য লিখুন.",
"form": {
"confirm-password": {
"label": "পাসওয়ার্ড নিশ্চিত করুন"
},
"email": {
"label": "ইমেইল ঠিকানা"
},
"name": {
"label": "পূর্ণ নাম"
},
"password": {
"label": "পাসওয়ার্ড"
},
"username": {
"label": "ইউজারনেম"
}
},
"heading": "একটি অ্যাকাউন্ট তৈরি করুন",
"loginText": "আপনার যদি ইতিমধ্যেই একটি অ্যাকাউন্ট থাকে, আপনি <1>এখানে লগইন করতে পারেন</1>৷"
},
"reset-password": {
"actions": {
"set-password": "নতুন পাসওয়ার্ড সেট করুন"
},
"body": "আপনার অ্যাকাউন্টের জন্য একটি নতুন পাসওয়ার্ড লিখুন।",
"form": {
"confirm-password": {
"label": "পাসওয়ার্ড নিশ্চিত করুন"
},
"password": {
"label": "পাসওয়ার্ড"
}
},
"heading": "আপনার পাসওয়ার্ডটি রিসেট করুন"
}
},
"dashboard": {
"create-resume": {
"actions": {
"create-resume": "জীবনবৃত্তান্ত তৈরি করুন"
},
"body": "এটি একটি নাম দিয়ে আপনার জীবনবৃত্তান্ত নির্মাণ শুরু করুন. এটা হতে পারে আপনি যে ভূমিকার জন্য আবেদন করছেন বা আপনার প্রিয় খাবারের জন্য।",
"form": {
"name": {
"label": "নাম"
},
"public": {
"label": "সর্বজনীনভাবে অ্যাক্সেসযোগ্য?"
},
"slug": {
"label": "স্লাগ"
}
},
"heading": "একটি নতুন জীবনবৃত্তান্ত তৈরি করুন"
},
"import-external": {
"heading": "বহিরাগত উত্স থেকে আমদানি",
"json-resume": {
"actions": {
"upload-json": "JSON আপলোড করুন"
},
"body": "আপনার যদি একটি <1>প্রমাণিত JSON সারসংকলন</1> যাওয়ার জন্য প্রস্তুত থাকে, তাহলে আপনি এটি ব্যবহার করতে পারেন প্রতিক্রিয়াশীল জীবনবৃত্তান্তে আপনার বিকাশ দ্রুত-ট্র্যাক করতে। নীচের বোতামে ক্লিক করুন এবং শুরু করতে একটি বৈধ JSON ফাইল আপলোড করুন৷",
"heading": "JSON রিজিউম থেকে আমদানি করুন"
},
"linkedin": {
"actions": {
"upload-archive": "ZIP সংরক্ষণাগার আপলোড করুন"
},
"body": "আপনি LinkedIn থেকে আপনার ডেটা রপ্তানি করে এবং Reactive Resume-এ ক্ষেত্রগুলি স্বয়ংক্রিয়ভাবে পূরণ করতে ব্যবহার করে সময় বাঁচাতে পারেন। LinkedIn-এর <1>ডেটা গোপনীয়তা</1> বিভাগে যান এবং আপনার ডেটা সংরক্ষণের জন্য অনুরোধ করুন। একবার এটি উপলব্ধ হলে, নীচের জিপ ফাইলটি আপলোড করুন।",
"heading": "LinkedIn থেকে আমদানি করুন"
},
"reactive-resume": {
"actions": {
"upload-json": "JSON আপলোড করুন"
},
"body": "আপনার যদি একটি JSON থাকে যা রিঅ্যাকটিভ রিজিউমের বর্তমান সংস্করণের সাথে রপ্তানি করা হয়েছিল, আপনি আবার সম্পাদনাযোগ্য সংস্করণ পেতে এটিকে এখানে আবার আমদানি করতে পারেন। প্রতিক্রিয়াশীল জীবনবৃত্তান্তের পূর্ববর্তী সংস্করণগুলি দুর্ভাগ্যবশত এই মুহূর্তে সমর্থিত নয়৷",
"heading": "প্রতিক্রিয়াশীল জীবনবৃত্তান্ত থেকে আমদানি করুন"
}
},
"rename-resume": {
"actions": {
"rename-resume": "রিজিউমের নাম পরিবর্তন করুন"
},
"form": {
"name": {
"label": "নাম"
},
"slug": {
"label": "স্লাগ"
}
},
"heading": "আপনার জীবনবৃত্তান্তের নাম পরিবর্তন করুন"
}
}
}

View File

@ -0,0 +1,358 @@
{
"common": {
"actions": {
"add": "Neue {{token}} hinzufügen",
"delete": "Löschen {{token}}",
"edit": "Bearbeiten {{token}}"
},
"columns": {
"heading": "Spalten",
"tooltip": "Anzahl der Spalten ändern"
},
"form": {
"date": {
"label": "Datum"
},
"description": {
"label": "Beschreibung"
},
"email": {
"label": "E-Mail Adresse"
},
"end-date": {
"help-text": "Dieses Feld leer lassen, wenn noch vorhanden",
"label": "Enddatum"
},
"keywords": {
"label": "Stichwörter"
},
"level": {
"label": "Ebene"
},
"levelNum": {
"label": "Ebene (Anzahl)"
},
"name": {
"label": "Name"
},
"phone": {
"label": "Telefonnummer"
},
"position": {
"label": "Position"
},
"start-date": {
"label": "Startdatum"
},
"subtitle": {
"label": "Untertitel"
},
"summary": {
"label": "Zusammenfassung"
},
"title": {
"label": "Titel"
},
"url": {
"label": "Webseite"
}
},
"glossary": {
"page": "Seite"
},
"list": {
"actions": {
"delete": "Löschen",
"duplicate": "Duplizieren",
"edit": "Bearbeiten"
},
"empty-text": "Diese Liste ist leer."
},
"tooltip": {
"delete-item": "Sind Sie sicher, dass Sie dieses Element löschen möchten? Dies ist eine unumkehrbare Aktion.",
"delete-section": "Abschnitt löschen",
"rename-section": "Abschnitt umbenennen",
"toggle-visibility": "Sichtbarkeit umschalten"
}
},
"controller": {
"tooltip": {
"center-artboard": "Artboard zentrieren",
"copy-link": "Link zum Lebenslauf kopieren",
"export-pdf": "PDF exportieren",
"toggle-orientation": "Seitenausrichtung umschalten",
"toggle-page-break-line": "Pausenzeile umschalten",
"toggle-sidebars": "Seitenleisten umschalten",
"zoom-in": "Vergrößern",
"zoom-out": "Verkleinern"
}
},
"header": {
"menu": {
"delete": "Löschen",
"duplicate": "Duplizieren",
"rename": "Umbenennen",
"share-link": "Link teilen",
"tooltips": {
"delete": "Sind Sie sicher, dass Sie diesen Lebenslauf löschen möchten? Dies ist eine unumkehrbare Aktion.",
"share-link": "Du musst die Sichtbarkeit deines Lebenslaufs in die Öffentlichkeit ändern, um ihn für andere sichtbar zu machen."
}
}
},
"leftSidebar": {
"sections": {
"awards": {
"form": {
"awarder": {
"label": "Auszeichnung"
}
}
},
"basics": {
"actions": {
"photo-filters": "Fotofilter"
},
"heading": "Grundlagen",
"headline": {
"label": "Überschrift"
},
"name": {
"label": "Voller Name"
},
"photo-filters": {
"effects": {
"border": {
"label": "Grenze"
},
"grayscale": {
"label": "Graustufen"
},
"heading": "Effekte"
},
"shape": {
"heading": "Form"
},
"size": {
"heading": "Größe (in px)"
}
},
"photo-upload": {
"tooltip": {
"remove": "Foto entfernen",
"upload": "Foto hochladen"
}
}
},
"certifications": {
"form": {
"issuer": {
"label": "Aussteller"
}
}
},
"education": {
"form": {
"area-study": {
"label": "Studienbereich"
},
"courses": {
"label": "Kurse"
},
"degree": {
"label": "Grad"
},
"grade": {
"label": "Note"
},
"institution": {
"label": "Institution"
}
}
},
"location": {
"address": {
"label": "Adresse"
},
"city": {
"label": "Stadt"
},
"country": {
"label": "Land"
},
"heading": "Standort",
"postal-code": {
"label": "Postleitzahl"
},
"region": {
"label": "Region"
}
},
"profiles": {
"form": {
"network": {
"label": "Netzwerk"
},
"username": {
"label": "Benutzername"
}
},
"heading": "Profiles",
"heading_one": "Profil"
},
"publications": {
"form": {
"publisher": {
"label": "Herausgeber"
}
}
},
"references": {
"form": {
"relationship": {
"label": "Beziehung"
}
}
},
"section": {
"heading": "Abschnitt"
},
"volunteer": {
"form": {
"organization": {
"label": "Organisation"
}
}
}
}
},
"rightSidebar": {
"sections": {
"css": {
"heading": "Benutzerdefiniertes CSS"
},
"export": {
"heading": "Exportieren",
"json": {
"primary": "JSON",
"secondary": "Laden Sie eine JSON-Version Ihres Lebenslaufs herunter, die Sie wieder in Reaktives Lebenslauf importieren können."
},
"pdf": {
"loading": {
"primary": "PDF wird erstellt",
"secondary": "Bitte warten Sie, wenn Ihr PDF generiert wird, dies kann bis zu 15 Sekunden dauern."
},
"normal": {
"primary": "PDF",
"secondary": "Laden Sie sich ein PDF Ihres Lebenslaufs herunter, das Sie ausdrucken und an Ihren Traumjob senden können. Diese Datei kann nicht zur weiteren Bearbeitung importiert werden."
}
}
},
"layout": {
"heading": "Layout",
"tooltip": {
"reset-layout": "Layout zurücksetzen"
}
},
"links": {
"bugs-features": {
"body": "Hält Sie etwas davon ab, einen Lebenslauf zu erstellen? Oder haben Sie eine tolle Idee, die Sie hinzufügen möchten? Erhöhen Sie einen Eintrag auf GitHub, um loszulegen.",
"button": "GitHub Themen",
"heading": "Fehler? Feature-Anfragen?"
},
"donate": {
"body": "Wenn Ihnen Reactive Resume gefallen hat, denken Sie bitte darüber nach, so viel wie möglich zu spenden, damit die App für immer kostenlos und werbefrei bleibt.",
"button": "Kaufe mir einen Kaffee",
"heading": "Spenden an Reaktives Lebenslauf"
},
"github": "Quellcode",
"heading": "Links"
},
"settings": {
"global": {
"date": {
"primary": "Datum",
"secondary": "Datumsformat für die gesamte App"
},
"heading": "Globale",
"language": {
"primary": "Sprache",
"secondary": "Sprache anzeigen, die in der gesamten App verwendet wird"
},
"theme": {
"primary": "Thema"
}
},
"heading": "Einstellungen",
"page": {
"break-line": {
"primary": "Linie anhalten",
"secondary": "Zeile auf allen Seiten anzeigen, um die Höhe einer A4-Seite zu markieren"
},
"heading": "Seite",
"orientation": {
"disabled": "Hat keine Auswirkung, wenn nur eine Seite vorhanden ist",
"primary": "Ausrichtung",
"secondary": "Ob Seiten horizontal oder vertikal angezeigt werden sollen"
}
},
"resume": {
"heading": "Lebenslauf",
"reset": {
"primary": "Alles zurücksetzen",
"secondary": "Zu viele Fehler gemacht? Klicken Sie hier, um alle Änderungen zurückzusetzen und bei Null zu beginnen. Sei vorsichtig, diese Aktion kann nicht rückgängig gemacht werden."
},
"sample": {
"primary": "Beispieldaten laden",
"secondary": "Nicht sicher, wo man anfangen soll? Klicken Sie hier, um ein paar Beispieldaten zu laden, um zu sehen, wie ein vollständiger Lebenslauf aussieht."
}
}
},
"sharing": {
"heading": "Teilen",
"short-url": {
"label": "Kurze URL bevorzugen"
},
"visibility": {
"subtitle": "Erlaube jemandem mit einem Link deinen Lebenslauf anzusehen",
"title": "Öffentlich"
}
},
"templates": {
"heading": "Vorlagen"
},
"theme": {
"form": {
"background": {
"label": "Hintergrund"
},
"primary": {
"label": "Primär"
},
"text": {
"label": "Text"
}
},
"heading": "Thema"
},
"typography": {
"form": {
"font-family": {
"label": "Schriftfamilie"
},
"font-size": {
"label": "Schriftgröße"
}
},
"heading": "Typographie",
"widgets": {
"body": {
"label": "Körper"
},
"headings": {
"label": "Überschriften"
}
}
}
}
}
}

View File

@ -0,0 +1,32 @@
{
"avatar": {
"menu": {
"greeting": "Hallo",
"logout": "Abmelden"
}
},
"footer": {
"credit": "Ein Herzensprojekt von <1>Amruth Pillai</1>",
"language": {
"missing": "Ihre Sprache fehlt?"
},
"license": "Von der Gemeinschaft, für die Gemeinschaft."
},
"markdown": {
"help-text": "Dieser Abschnitt unterstützt <1>Markdown</1> Formatierung."
},
"date": {
"present": "Gegenwärtig"
},
"subtitle": "Ein freier und Open-Source-Lebenslauf-Builder.",
"title": "Reaktives Lebenslauf",
"toast": {
"error": {
"upload-file-size": "Bitte laden Sie nur Dateien unter 2 Megabytes hoch.",
"upload-photo-size": "Bitte laden Sie nur Fotos unter 2 Megabytes hoch, vorzugsweise quadratisch."
},
"success": {
"resume-link-copied": "Ein Link zu deinem Lebenslauf wurde in deine Zwischenablage kopiert."
}
}
}

View File

@ -0,0 +1,25 @@
{
"create-resume": {
"subtitle": "Bei Null anfangen",
"title": "Neuen Lebenslauf erstellen"
},
"import-external": {
"subtitle": "LinkedIn, JSON Resume, Reaktives Lebenslauf",
"title": "Aus externen Quellen importieren"
},
"resume": {
"menu": {
"delete": "Löschen",
"duplicate": "Duplikat",
"open": "Öffnen",
"rename": "Umbenennen",
"share-link": "Einen Link teilen",
"tooltips": {
"delete": "Möchten Sie diesen Lebenslauf wirklich löschen? Dies ist eine irreversible Aktion.",
"share-link": "Sie müssen die Sichtbarkeit Ihres Lebenslaufs auf öffentlich ändern, um ihn für andere sichtbar zu machen."
}
},
"timestamp": "Zuletzt vor {{timestamp}} aktualisiert"
},
"title": "Dashboard"
}

View File

@ -0,0 +1,41 @@
{
"actions": {
"app": "Gehe zu App",
"login": "Anmelden",
"logout": "Ausloggen",
"register": "Registrieren"
},
"features": {
"heading": "Eigenschaften",
"list": {
"ads": "Keine Werbung",
"export": "Exportieren Sie Ihren Lebenslauf in JSON oder PDF Format",
"free": "Frei, für immer",
"import": "Importiere Daten von LinkedIn, JSON Lebenslauf",
"languages": "In mehreren Sprachen zugänglich",
"more": "Und viel mehr aufregende Features, <1>lesen Sie alles hier</1>",
"tracking": "Keine Benutzerverfolgung"
}
},
"links": {
"heading": "Verknüpfungen",
"links": {
"donate": "Spenden",
"github": "Quellcode",
"privacy": "Datenschutzerklärung",
"service": "Nutzungsbedingungen"
}
},
"screenshots": {
"heading": "Screenshots"
},
"testimonials": {
"heading": "Referenzen",
"body": "Gut oder schlecht, ich würde gerne Ihre Meinung über Reactive Resume und wie die Erfahrung war für Sie.<br/>Hier sind einige der Nachrichten, die von Benutzern auf der ganzen Welt gesendet werden.",
"contact": "Du kannst mich über <1>meine E-Mail</1> oder über das Kontaktformular auf <3>meiner Website</3>erreichen."
},
"summary": {
"body": "Reaktives Lebenslauf ist ein freier und Open-Source-Lebenslauf-Builder, der gebaut wurde, um die weltlichen Aufgaben zu machen, zu erstellen, Aktualisieren und teilen Sie Ihren Lebenslauf so einfach wie 1, 2, 3. Mit dieser App kannst du mehrere Bewerbungen erstellen, sie mit Recruitern oder Freunden über einen einzigartigen Link teilen und sie als PDF ausdrucken. alle kostenlos, keine Werbung, keine Verfolgung, ohne die Integrität und Privatsphäre Ihrer Daten zu verlieren.",
"heading": "Zusammenfassung"
}
}

View File

@ -0,0 +1,135 @@
{
"auth": {
"forgot-password": {
"actions": {
"send-email": "Passwort zurücksetzen E-Mail senden"
},
"body": "Geben Sie einfach die E-Mail-Adresse ein, die mit dem Konto verknüpft ist, das Sie wiederherstellen möchten.",
"form": {
"email": {
"label": "E-Mail-Addresse"
}
},
"heading": "Passwort vergessen?",
"help-text": "Wenn das Konto existiert, erhalten Sie eine E-Mail mit einem Link zum Zurücksetzen Ihres Passworts."
},
"login": {
"actions": {
"login": "Anmeldung",
"google": "Mit Google anmelden"
},
"body": "Bitte geben Sie Ihren Benutzernamen und Ihr Passwort ein, um sich anzumelden und zuzugreifen, Ihre Bewerbungen zu verwalten und weiterzugeben.",
"form": {
"password": {
"label": "Passwort"
},
"username": {
"help-text": "Sie können auch Ihre E-Mail-Adresse eingeben",
"label": "Nutzername"
}
},
"heading": "Bei Ihrem Konto anmelden",
"recover-text": "Falls Sie Ihr Passwort vergessen haben, können Sie <1>Ihr Konto wiederherstellen</1> hier einrichten.",
"register-text": "Wenn Sie keinen haben, können Sie hier <1>ein Konto erstellen</1> anlegen."
},
"register": {
"actions": {
"register": "Registrieren",
"google": "Mit Google registrieren"
},
"body": "Bitte geben Sie Ihre persönlichen Daten ein, um ein Konto zu erstellen.",
"form": {
"confirm-password": {
"label": "Passwort bestätigen"
},
"email": {
"label": "E-Mail-Addresse"
},
"name": {
"label": "Vollständiger Name"
},
"password": {
"label": "Passwort"
},
"username": {
"label": "Nutzername"
}
},
"heading": "Ein Konto erstellen",
"loginText": "Wenn Sie bereits ein Konto haben, können Sie sich hier <1>anmelden</1>."
},
"reset-password": {
"actions": {
"set-password": "Neues Passwort setzen"
},
"body": "Geben Sie ein neues Passwort für Ihr Konto ein.",
"form": {
"confirm-password": {
"label": "Passwort bestätigen"
},
"password": {
"label": "Passwort"
}
},
"heading": "Passwort zurücksetzen"
}
},
"dashboard": {
"create-resume": {
"actions": {
"create-resume": "Lebenslauf erstellen"
},
"body": "Erstelle deinen Lebenslauf, indem du ihm einen Namen gibst. Er könnte sich auf die Rolle beziehen, die Sie beantragen, oder nur auf Ihren Lieblings-Snack.",
"form": {
"name": {
"label": "Name"
},
"public": {
"label": "Ist öffentlich zugänglich?"
},
"slug": {
"label": "Slug"
}
},
"heading": "Neuen Lebenslauf erstellen"
},
"import-external": {
"heading": "Import aus externen Quellen",
"json-resume": {
"actions": {
"upload-json": "JSON hochladen"
},
"body": "Wenn du einen <1>validierten JSON Resume</1> bereit hast, kannst du damit deine Entwicklung auf reaktiven Resume beschleunigen. Klicken Sie auf den Button unten und laden Sie eine gültige JSON-Datei hoch, um zu beginnen.",
"heading": "Import vom JSON-Lebenslauf"
},
"linkedin": {
"actions": {
"upload-archive": "ZIP-Archiv hochladen"
},
"body": "Sie können Zeit sparen, indem Sie Ihre Daten aus LinkedIn exportieren und sie zum automatischen Ausfüllen von Feldern auf Reaktives Lebenslauf verwenden. Gehen Sie zum Abschnitt <1>Datenschutz </1> auf LinkedIn und fordern Sie ein Archiv Ihrer Daten an. Sobald diese verfügbar sind, laden Sie die ZIP-Datei unten hoch.",
"heading": "Aus LinkedIn importieren"
},
"reactive-resume": {
"actions": {
"upload-json": "JSON hochladen"
},
"body": "Wenn Sie ein JSON haben, das mit der aktuellen Version von Reactive Resume exportiert wurde, Sie können es hier wieder importieren um wieder eine editierbare Version zu erhalten. Vorherige Versionen von Reactive Resume werden derzeit leider nicht unterstützt.",
"heading": "Import vom Reaktives Lebenslauf"
}
},
"rename-resume": {
"actions": {
"rename-resume": "Lebenslauf umbenennen"
},
"form": {
"name": {
"label": "Name"
},
"slug": {
"label": "Slug"
}
},
"heading": "Lebenslauf umbenennen"
}
}
}

View File

@ -61,18 +61,18 @@
"page": "Page"
},
"list": {
"empty-text": "This list is empty.",
"actions": {
"edit": "Edit",
"delete": "Delete",
"duplicate": "Duplicate",
"delete": "Delete"
}
"edit": "Edit"
},
"empty-text": "This list is empty."
},
"tooltip": {
"delete-item": "Are you sure you want to delete this item? This is an irreversible action.",
"delete-section": "Delete Section",
"rename-section": "Rename Section",
"toggle-visibility": "Toggle Visibility",
"delete-item": "Are you sure you want to delete this item? This is an irreversible action."
"toggle-visibility": "Toggle Visibility"
}
},
"controller": {
@ -290,6 +290,7 @@
},
"heading": "Page",
"orientation": {
"disabled": "Has no effect when there is only one page",
"primary": "Orientation",
"secondary": "Whether to display pages horizontally or vertically"
}

View File

@ -15,6 +15,9 @@
"markdown": {
"help-text": "This section supports <1>markdown</1> formatting."
},
"date": {
"present": "Present"
},
"subtitle": "A free and open source resume builder.",
"title": "Reactive Resume",
"toast": {

View File

@ -0,0 +1,358 @@
{
"common": {
"actions": {
"add": "Agregar nuevo {{token}}",
"delete": "Eliminar {{token}}",
"edit": "Editar {{token}}"
},
"columns": {
"heading": "Columnas",
"tooltip": "Cambiar número de columnas"
},
"form": {
"date": {
"label": "Fecha"
},
"description": {
"label": "Descripción"
},
"email": {
"label": "Correo electrónico"
},
"end-date": {
"help-text": "Deje este campo en blanco, si todavía está presente",
"label": "Fecha de finalización"
},
"keywords": {
"label": "Palabras claves"
},
"level": {
"label": "Nivel"
},
"levelNum": {
"label": "Nivel (Número)"
},
"name": {
"label": "Nombre"
},
"phone": {
"label": "Número de teléfono"
},
"position": {
"label": "Puesto de trabajo"
},
"start-date": {
"label": "Fecha de inicio"
},
"subtitle": {
"label": "Subtítulo"
},
"summary": {
"label": "Resumen"
},
"title": {
"label": "Título"
},
"url": {
"label": "Sitio Web"
}
},
"glossary": {
"page": "Página"
},
"list": {
"actions": {
"delete": "Eliminar",
"duplicate": "Duplicar",
"edit": "Editar"
},
"empty-text": "Esta lista esta vacia."
},
"tooltip": {
"delete-item": "¿Estás seguro de que deseas eliminar este elemento? Esta acción es irreversible.",
"delete-section": "Eliminar sección",
"rename-section": "Renombrar sección",
"toggle-visibility": "Cambiar Visibilidad"
}
},
"controller": {
"tooltip": {
"center-artboard": "Centrar Tablero",
"copy-link": "Copiar enlace al currículum",
"export-pdf": "Exportar PDF",
"toggle-orientation": "Cambiar la orientación de la página",
"toggle-page-break-line": "Alternar línea de salto de página",
"toggle-sidebars": "Ocultar/mostrar barra lateral",
"zoom-in": "Acercar",
"zoom-out": "Alejar"
}
},
"header": {
"menu": {
"delete": "Eliminar",
"duplicate": "Duplicar",
"rename": "Renombrar",
"share-link": "Compartir enlace",
"tooltips": {
"delete": "¿Estás seguro de que deseas eliminar este elemento? Esta acción es irreversible.",
"share-link": "Debe cambiar la visibilidad de su currículum a público para que sea visible para los demás."
}
}
},
"leftSidebar": {
"sections": {
"awards": {
"form": {
"awarder": {
"label": "Otorgado por"
}
}
},
"basics": {
"actions": {
"photo-filters": "Filtro de fotos"
},
"heading": "Información básica",
"headline": {
"label": "Titular"
},
"name": {
"label": "Nombre Completo"
},
"photo-filters": {
"effects": {
"border": {
"label": "Borde"
},
"grayscale": {
"label": "Escala de grises"
},
"heading": "Efectos"
},
"shape": {
"heading": "Forma"
},
"size": {
"heading": "Tamaño (en píxeles)"
}
},
"photo-upload": {
"tooltip": {
"remove": "Eliminar foto",
"upload": "Subir foto"
}
}
},
"certifications": {
"form": {
"issuer": {
"label": "Emisor"
}
}
},
"education": {
"form": {
"area-study": {
"label": "Área de estudio"
},
"courses": {
"label": "Cursos"
},
"degree": {
"label": "Grado"
},
"grade": {
"label": "Calificación"
},
"institution": {
"label": "Institución"
}
}
},
"location": {
"address": {
"label": "Dirección"
},
"city": {
"label": "Ciudad"
},
"country": {
"label": "País"
},
"heading": "Ubicación",
"postal-code": {
"label": "Código Postal"
},
"region": {
"label": "Area"
}
},
"profiles": {
"form": {
"network": {
"label": "Red"
},
"username": {
"label": "Nombre de usario"
}
},
"heading": "Perfiles",
"heading_one": "Perfil"
},
"publications": {
"form": {
"publisher": {
"label": "Editor"
}
}
},
"references": {
"form": {
"relationship": {
"label": "Relación"
}
}
},
"section": {
"heading": "Sección"
},
"volunteer": {
"form": {
"organization": {
"label": "Organización"
}
}
}
}
},
"rightSidebar": {
"sections": {
"css": {
"heading": "CSS personalizado"
},
"export": {
"heading": "Exportar",
"json": {
"primary": "JSON",
"secondary": "Descargar una versión JSON de su currículum que se puede volver a importar a Reactive Resume."
},
"pdf": {
"loading": {
"primary": "Generando PDF",
"secondary": "Por favor, espere mientras se genera su PDF, esto puede tardar hasta 15 segundos."
},
"normal": {
"primary": "PDF",
"secondary": "Descargar un PDF de su currículum que puede imprimir y enviar al trabajo de sus sueños. Este archivo no se puede volver a importar para su posterior edición."
}
}
},
"layout": {
"heading": "Diseño",
"tooltip": {
"reset-layout": "Restablecer Diseño"
}
},
"links": {
"bugs-features": {
"body": "¿Algo que te impide hacer un currículum? ¿O tienes una idea increíble para agregar? Plantea una Propuesta en GitHub para comenzar.",
"button": "Propuesta de GitHub",
"heading": "¿Errores? ¿Solicitud de características?"
},
"donate": {
"body": "Si le gustó usar Reactive Resume, considere donar lo que pueda a la causa de mantener la aplicación en funcionamiento, sin anuncios y gratis para siempre.",
"button": "Invítame a un café",
"heading": "Donar a Reactive Resume"
},
"github": "Código Fuente",
"heading": "Enlaces"
},
"settings": {
"global": {
"date": {
"primary": "Fecha",
"secondary": "Formato de fecha para usar en toda la aplicación"
},
"heading": "Global",
"language": {
"primary": "Idioma",
"secondary": "Idioma que se utilizará en toda la aplicación"
},
"theme": {
"primary": "Tema"
}
},
"heading": "Preferencias",
"page": {
"break-line": {
"primary": "Linea de separación",
"secondary": "Mostrar una línea en todas las páginas para marcar la altura de una página A4"
},
"heading": "Página",
"orientation": {
"disabled": "No tiene efecto cuando solo hay una página",
"primary": "Orientación",
"secondary": "Visualización horizontal o vertical de las páginas"
}
},
"resume": {
"heading": "Currículum",
"reset": {
"primary": "Restablecer Todo",
"secondary": "¿Has cometido demasiados errores? Haz clic aquí para restablecer todos los cambios y empezar de cero. Ten cuidado, esta acción no se puede revertir."
},
"sample": {
"primary": "Cargar datos de muestra",
"secondary": "¿No sabe por dónde empezar? Haz clic aquí para cargar algunos datos de muestra y ver cómo es un currículum completo."
}
}
},
"sharing": {
"heading": "Compartir",
"short-url": {
"label": "Preferir URL corta"
},
"visibility": {
"subtitle": "Permitir que cualquier persona con un enlace vea su currículum",
"title": "Público"
}
},
"templates": {
"heading": "Plantillas"
},
"theme": {
"form": {
"background": {
"label": "Fondo"
},
"primary": {
"label": "Principal"
},
"text": {
"label": "Texto"
}
},
"heading": "Tema"
},
"typography": {
"form": {
"font-family": {
"label": "Familia tipográfica"
},
"font-size": {
"label": "Tamaño de fuente"
}
},
"heading": "Tipografía",
"widgets": {
"body": {
"label": "Cuerpo"
},
"headings": {
"label": "Encabezados"
}
}
}
}
}
}

View File

@ -0,0 +1,32 @@
{
"avatar": {
"menu": {
"greeting": "Hola",
"logout": "Cerrar sesión"
}
},
"footer": {
"credit": "Un proyecto apasionante de <1>Amruth Pillai</1>",
"language": {
"missing": "Idioma ausente?"
},
"license": "Por la comunidad, para la comunidad."
},
"markdown": {
"help-text": "Esta sección soporta el formato <1>markdown</1>."
},
"date": {
"present": "Actualidad"
},
"subtitle": "Un generador de currículum gratuito y de código abierto.",
"title": "Reactive Resume",
"toast": {
"error": {
"upload-file-size": "Por favor, suba sólo archivos de menos de 2 megabytes.",
"upload-photo-size": "Por favor, suba sólo fotos de menos de 2 megabytes, preferiblemente cuadradas."
},
"success": {
"resume-link-copied": "Se ha copiado un enlace a su currículum en su portapapeles."
}
}
}

View File

@ -0,0 +1,25 @@
{
"create-resume": {
"subtitle": "Empezar desde cero",
"title": "Crear currículum"
},
"import-external": {
"subtitle": "LinkedIn, JSON Resume, Reactive Resume",
"title": "Importar desde fuentes externas"
},
"resume": {
"menu": {
"delete": "Borrar",
"duplicate": "Duplicar",
"open": "Abrir",
"rename": "Rebautizar",
"share-link": "Compartir enlace",
"tooltips": {
"delete": "¿Está seguro de que desea eliminar este currículum? Esta es una acción irreversible.",
"share-link": "Debe cambiar la visibilidad de su currículum a público para que sea visible para los demás."
}
},
"timestamp": "Última actualización {{timestamp}}"
},
"title": "Panel de Control"
}

View File

@ -0,0 +1,41 @@
{
"actions": {
"app": "Ir a la aplicación",
"login": "Iniciar sesión",
"logout": "Cerrar sesión",
"register": "Registrar"
},
"features": {
"heading": "Características",
"list": {
"ads": "Sin publicidad",
"export": "Exporta tu currículum a formato JSON o PDF",
"free": "Gratis para siempre",
"import": "Importar datos de LinkedIn, JSON Resume",
"languages": "Accesible en varios idiomas",
"more": "Y funciones mucho más emocionantes, <1>lea todo sobre esto aquí</1>",
"tracking": "Sin seguimiento de usuario"
}
},
"links": {
"heading": "Enlaces",
"links": {
"donate": "Donar",
"github": "Código fuente",
"privacy": "Política de Privacidad",
"service": "Términos de Servicio"
}
},
"screenshots": {
"heading": "Capturas de pantalla"
},
"testimonials": {
"heading": "Opiniones",
"body": "Bueno o malo, me encantaría saber tu opinión sobre Reactive Resume y cómo ha sido la experiencia para ti.<br/>Estos son algunos de los mensajes enviados por usuarios de todo el mundo.",
"contact": "Puedes comunicarte conmigo a través de <1>mi correo electrónico</1> o a través del formulario de contacto en <3>mi sitio web</3>."
},
"summary": {
"body": "Reactive Resume es un generador de currículums gratuito y de código abierto que está diseñado para hacer que las tareas mundanas de crear, actualizar y compartir su currículum sean tan fáciles como 1, 2, 3. Con esta aplicación, puede crear múltiples currículums, compartirlos con reclutadores o amigos a través de un enlace único e imprímalo como PDF, todo gratis, sin anuncios, sin seguimiento, sin perder la integridad y privacidad de sus datos.",
"heading": "Resumen"
}
}

View File

@ -0,0 +1,135 @@
{
"auth": {
"forgot-password": {
"actions": {
"send-email": "Enviar correo electrónico para restablecer la contraseña"
},
"body": "Simplemente ingrese la dirección de correo electrónico asociada con la cuenta que desea recuperar.",
"form": {
"email": {
"label": "Dirección de correo electrónico"
}
},
"heading": "¿Olvidó su contraseña?",
"help-text": "Si la cuenta existe, recibirá un correo electrónico con un enlace para restablecer su contraseña."
},
"login": {
"actions": {
"login": "Acceso",
"google": "Iniciar sesión con Google"
},
"body": "Por favor, introduzca su nombre de usuario y contraseña asociados a su cuenta para iniciar sesión y acceder, gestionar y compartir sus currículos.",
"form": {
"password": {
"label": "Contraseña"
},
"username": {
"help-text": "También puede ingresar su dirección de correo electrónico",
"label": "Nombre de usuario"
}
},
"heading": "Ingrese en su cuenta",
"recover-text": "En caso de que hayas olvidado tu contraseña, puedes <1>recuperar tu cuenta</1> aquí.",
"register-text": "Si no tiene una, puede <1>crear una cuenta</1> aquí."
},
"register": {
"actions": {
"register": "Registrarse",
"google": "Regístrese con Google"
},
"body": "Por favor ingrese su información personal para crear una cuenta.",
"form": {
"confirm-password": {
"label": "Confirmar Contraseña"
},
"email": {
"label": "Dirección de correo electrónico"
},
"name": {
"label": "Nombre completo"
},
"password": {
"label": "Clave"
},
"username": {
"label": "Nombre de usuario"
}
},
"heading": "Crear una cuenta",
"loginText": "Si ya tiene una cuenta, puede <1>iniciar sesión aquí</1>."
},
"reset-password": {
"actions": {
"set-password": "Establecer una nueva contraseña"
},
"body": "Introduzca una nueva contraseña para su cuenta.",
"form": {
"confirm-password": {
"label": "Confirmar contraseña"
},
"password": {
"label": "Clave"
}
},
"heading": "Restablecer tu contraseña"
}
},
"dashboard": {
"create-resume": {
"actions": {
"create-resume": "Crear currículum"
},
"body": "Comience a construir su currículum dándole un nombre. Podría ser en referencia al puesto que está solicitando, o simplemente a su refrigerio favorito.",
"form": {
"name": {
"label": "Nombre"
},
"public": {
"label": "¿Es de acceso público?"
},
"slug": {
"label": "Segmento"
}
},
"heading": "Crear un nuevo currículum"
},
"import-external": {
"heading": "Importar desde fuentes externas",
"json-resume": {
"actions": {
"upload-json": "Subir JSON"
},
"body": "Si tiene un <1>JSON Resume validado</1> listo para usar, puede usarlo para acelerar su desarrollo en Reactive Resume. Haga clic en el botón a continuación y cargue un archivo JSON válido para comenzar.",
"heading": "Importar desde JSON Resume"
},
"linkedin": {
"actions": {
"upload-archive": "Subir archivo ZIP"
},
"body": "Puede ahorrar tiempo exportando sus datos de LinkedIn y usándolos para autocompletar campos en Reactive Resume. Dirígete a <1>Privacidad de datos</1> en LinkedIn y solicita un archivo de tus datos. Una vez que esté disponible, cargue el archivo ZIP a continuación.",
"heading": "Importar desde LinkedIn"
},
"reactive-resume": {
"actions": {
"upload-json": "Subir JSON"
},
"body": "Si tiene un JSON que se exportó con la versión actual de Reactive Resume, puede volver a importarlo aquí para obtener una versión editable nuevamente. Desafortunadamente, las versiones anteriores de Reactive Resume no son compatibles en este momento.",
"heading": "Importar desde Reactive Resume"
}
},
"rename-resume": {
"actions": {
"rename-resume": "Renombrar currículum"
},
"form": {
"name": {
"label": "Nombre"
},
"slug": {
"label": "Babosa"
}
},
"heading": "Renombrar tu currículum"
}
}
}

View File

@ -0,0 +1,358 @@
{
"common": {
"actions": {
"add": "Ajouter un/une {{token}}",
"delete": "Supprimer {{token}}",
"edit": "Éditer {{token}}"
},
"columns": {
"heading": "Colonnes",
"tooltip": "Modifier le nombre de colonnes"
},
"form": {
"date": {
"label": "Date"
},
"description": {
"label": "Description"
},
"email": {
"label": "Adresse email"
},
"end-date": {
"help-text": "Si actuel, laisser ce champ vide",
"label": "Date de fin"
},
"keywords": {
"label": "Mots-clés"
},
"level": {
"label": "Niveau"
},
"levelNum": {
"label": "Niveau (nombre)"
},
"name": {
"label": "Nom"
},
"phone": {
"label": "Numéro de téléphone"
},
"position": {
"label": "Poste"
},
"start-date": {
"label": "Date de début"
},
"subtitle": {
"label": "Sous-titre"
},
"summary": {
"label": "Résumé"
},
"title": {
"label": "Titre"
},
"url": {
"label": "Site web"
}
},
"glossary": {
"page": "Page"
},
"list": {
"actions": {
"delete": "Supprimer",
"duplicate": "Dédoubler",
"edit": "Éditer"
},
"empty-text": "Cette liste est vide."
},
"tooltip": {
"delete-item": "Êtes-vous sûr de vouloir supprimer cet objet ? Cette action est irréversible.",
"delete-section": "Supprimer la section",
"rename-section": "Renommer la section",
"toggle-visibility": "Rendre visible/invisible"
}
},
"controller": {
"tooltip": {
"center-artboard": "Centrer l'affichage",
"copy-link": "Copier le lien vers le CV",
"export-pdf": "Exporter en PDF",
"toggle-orientation": "Basculer l'orientation de la page",
"toggle-page-break-line": "Afficher/cacher l'indicateur de saut de page",
"toggle-sidebars": "Afficher/cacher les barres latérales",
"zoom-in": "Zoomer",
"zoom-out": "Dézoomer"
}
},
"header": {
"menu": {
"delete": "Supprimer",
"duplicate": "Dédoubler",
"rename": "Renommer",
"share-link": "Partager un lien",
"tooltips": {
"delete": "Êtes-vous sûr(e) de vouloir supprimer ce CV ? Cette action est irréversible.",
"share-link": "Vous devez changer la visibilité de votre CV en public pour le rendre visible aux autres."
}
}
},
"leftSidebar": {
"sections": {
"awards": {
"form": {
"awarder": {
"label": "Décerné par"
}
}
},
"basics": {
"actions": {
"photo-filters": "Filtres pour la photo"
},
"heading": "Informations de base",
"headline": {
"label": "Titre"
},
"name": {
"label": "Nom complet"
},
"photo-filters": {
"effects": {
"border": {
"label": "Bordure"
},
"grayscale": {
"label": "Noir et blanc"
},
"heading": "Effets"
},
"shape": {
"heading": "Forme"
},
"size": {
"heading": "Taille (en pixels)"
}
},
"photo-upload": {
"tooltip": {
"remove": "Supprimer la photo",
"upload": "Importer une photo"
}
}
},
"certifications": {
"form": {
"issuer": {
"label": "Certifié par"
}
}
},
"education": {
"form": {
"area-study": {
"label": "Domaine d'étude"
},
"courses": {
"label": "Cours"
},
"degree": {
"label": "Diplôme"
},
"grade": {
"label": "Note"
},
"institution": {
"label": "Établissement"
}
}
},
"location": {
"address": {
"label": "Adresse"
},
"city": {
"label": "Commune"
},
"country": {
"label": "Pays"
},
"heading": "Adresse",
"postal-code": {
"label": "Code postal"
},
"region": {
"label": "Région"
}
},
"profiles": {
"form": {
"network": {
"label": "Réseau social"
},
"username": {
"label": "Nom d'utilisateur"
}
},
"heading": "Profils",
"heading_one": "Profil"
},
"publications": {
"form": {
"publisher": {
"label": "Éditeur"
}
}
},
"references": {
"form": {
"relationship": {
"label": "Type de relation"
}
}
},
"section": {
"heading": "Section"
},
"volunteer": {
"form": {
"organization": {
"label": "Association"
}
}
}
}
},
"rightSidebar": {
"sections": {
"css": {
"heading": "CSS personnalisé"
},
"export": {
"heading": "Exporter",
"json": {
"primary": "JSON",
"secondary": "Télécharger une version JSON de votre CV, qui pourra être réimportée dans Reactive Resume."
},
"pdf": {
"loading": {
"primary": "Génération du PDF",
"secondary": "Veuillez patienter pendant que votre PDF est généré, cela peut prendre jusqu'à 15 secondes."
},
"normal": {
"primary": "PDF",
"secondary": "Téléchargez un PDF de votre CV que vous pourrez imprimer et envoyer à l'emploi de vos rêves. Ce fichier ne peut pas être réimporté pour être modifié ultérieurement."
}
}
},
"layout": {
"heading": "Disposition",
"tooltip": {
"reset-layout": "Réinitialiser la disposition"
}
},
"links": {
"bugs-features": {
"body": "Quelque chose vous a empêché de rédiger un CV ? Ou vous avez une idée géniale à ajouter ? Créez une issue sur GitHub pour commencer.",
"button": "Issues GitHub",
"heading": "Bogues ? Demandes de fonctionnalités ?"
},
"donate": {
"body": "Si vous avez aimé utiliser Reactive Resume, pensez à donner comme vous le pouvez pour que l'application reste disponible, gratuite et sans publicité pour toujours.",
"button": "Offrez-moi un café",
"heading": "Faire un don à Reactive Resume"
},
"github": "Code source",
"heading": "Liens"
},
"settings": {
"global": {
"date": {
"primary": "Date",
"secondary": "Format de date à utiliser dans l'application"
},
"heading": "Général",
"language": {
"primary": "Langue",
"secondary": "Langue d'affichage à utiliser dans l'application"
},
"theme": {
"primary": "Thème"
}
},
"heading": "Paramètres",
"page": {
"break-line": {
"primary": "Indicateur de changement de page",
"secondary": "Afficher une ligne sur toutes les pages pour marquer la hauteur d'une feuille A4"
},
"heading": "Page",
"orientation": {
"disabled": "N'a aucun effet lorsqu'il n'y a qu'une seule page",
"primary": "Orientation",
"secondary": "Afficher les pages horizontalement ou verticalement"
}
},
"resume": {
"heading": "CV",
"reset": {
"primary": "Tout remettre à zéro",
"secondary": "Vous avez fait trop d'erreurs ? Cliquez ici pour réinitialiser toutes les modifications et repartir de zéro. Attention, cette action ne peut pas être annulée."
},
"sample": {
"primary": "Charger les données de démo",
"secondary": "Vous ne savez pas par où commencer ? Cliquez ici pour charger quelques exemples de données afin de voir à quoi ressemble un CV complet."
}
}
},
"sharing": {
"heading": "Partage",
"short-url": {
"label": "Préférer une URL courte"
},
"visibility": {
"subtitle": "Permettre à toute personne ayant un lien de consulter votre CV",
"title": "Public"
}
},
"templates": {
"heading": "Modèles"
},
"theme": {
"form": {
"background": {
"label": "Couleur d'arrière plan"
},
"primary": {
"label": "Couleur principale"
},
"text": {
"label": "Couleur de texte"
}
},
"heading": "Thème"
},
"typography": {
"form": {
"font-family": {
"label": "Famille de police"
},
"font-size": {
"label": "Taille de la police"
}
},
"heading": "Typographie",
"widgets": {
"body": {
"label": "Contenu"
},
"headings": {
"label": "Titres"
}
}
}
}
}
}

View File

@ -0,0 +1,32 @@
{
"avatar": {
"menu": {
"greeting": "Bonjour",
"logout": "Déconnexion"
}
},
"footer": {
"credit": "Un projet passionné de <1>Amruth Pillai</1>",
"language": {
"missing": "Il manque votre langue ?"
},
"license": "Par la communauté, pour la communauté."
},
"markdown": {
"help-text": "Cette section prend en charge la mise en forme <1>markdown</1>."
},
"date": {
"present": "Présent"
},
"subtitle": "Un constructeur de CV gratuit et open source.",
"title": "Reactive Resume",
"toast": {
"error": {
"upload-file-size": "Veuillez télécharger uniquement des fichiers de moins de 2 Mo.",
"upload-photo-size": "Veuillez télécharger uniquement des photos de moins de 2 Mo, de préférence carrées."
},
"success": {
"resume-link-copied": "Un lien vers votre CV a été copié dans votre presse-papier."
}
}
}

View File

@ -0,0 +1,25 @@
{
"create-resume": {
"subtitle": "Partir de zéro",
"title": "Créer un nouveau CV"
},
"import-external": {
"subtitle": "LinkedIn, JSON Resume, Reactive Resume",
"title": "Importer de sources externes"
},
"resume": {
"menu": {
"delete": "Supprimer",
"duplicate": "Dédoubler",
"open": "Ouvrir",
"rename": "Renommer",
"share-link": "Partager un lien",
"tooltips": {
"delete": "Êtes-vous sûr(e) de vouloir supprimer ce CV ? Cette action est irréversible.",
"share-link": "Vous devez changer la visibilité de votre CV en public pour le rendre visible aux autres."
}
},
"timestamp": "Dernière mise à jour il y a {{timestamp}}"
},
"title": "Tableau de bord"
}

View File

@ -0,0 +1,41 @@
{
"actions": {
"app": "Accéder à l'app",
"login": "Connexion",
"logout": "Déconnexion",
"register": "Inscription"
},
"features": {
"heading": "Fonctionnalités",
"list": {
"ads": "Pas de publicité",
"export": "Exporter votre CV au format JSON ou PDF",
"free": "Gratuit, pour toujours",
"import": "Importer des données depuis LinkedIn, JSON Resume",
"languages": "Accessible en plusieurs langues",
"more": "Et bien plus de fonctionnalités intéressantes, <1>tout lire ici</1>",
"tracking": "Pas de pistage des utilisateurs"
}
},
"links": {
"heading": "Liens",
"links": {
"donate": "Faire un don",
"github": "Code source",
"privacy": "Politique de confidentialité",
"service": "Conditions d'utilisation"
}
},
"screenshots": {
"heading": "Captures d'écran"
},
"testimonials": {
"heading": "Témoignages",
"body": "Bonne ou mauvaiss, j'aimerais entendre votre opinion sur Reactive Resume et comment l'expérience a été pour vous.<br/>Voici quelques-uns des messages envoyés par des utilisateurs du monde entier.",
"contact": "Vous pouvez me contacter via <1>mon e-mail</1> ou via le formulaire de contact de <3>mon site web</3>."
},
"summary": {
"body": "Reactive Resume est un générateur de CV gratuit et open source, conçu pour rendre les tâches banales de création, de mise à jour et de partage de votre CV aussi faciles que de compter jusqu'à 3. Avec cette application, vous pouvez créer plusieurs CVs, les partager avec des recruteurs ou des amis par le biais d'un lien unique et les imprimer au format PDF, le tout gratuitement, sans publicité, sans pistage, et sans perdre l'intégrité et la confidentialité de vos données.",
"heading": "Résumé"
}
}

View File

@ -0,0 +1,135 @@
{
"auth": {
"forgot-password": {
"actions": {
"send-email": "Envoyer l'email de réinitialisation du mot de passe"
},
"body": "Il suffit de saisir l'adresse email associée au compte que vous souhaitez récupérer.",
"form": {
"email": {
"label": "Adresse e-mail"
}
},
"heading": "Mot de passe oublié ?",
"help-text": "Si le compte existe, vous recevrez un courriel contenant un lien pour réinitialiser votre mot de passe."
},
"login": {
"actions": {
"login": "Connexion",
"google": "Connexion avec Google"
},
"body": "Veuillez entrer votre nom d'utilisateur et votre mot de passe associés à votre compte pour vous connecter et accéder, gérer et partager vos CVs.",
"form": {
"password": {
"label": "Mot de passe"
},
"username": {
"help-text": "Vous pouvez également saisir votre adresse e-mail",
"label": "Nom d'utilisateur"
}
},
"heading": "Connexion à votre compte",
"recover-text": "Si vous avez oublié votre mot de passe, vous pouvez <1>récupérer votre compte</1> ici.",
"register-text": "Si vous n'en avez pas, vous pouvez <1>créer un compte</1> ici."
},
"register": {
"actions": {
"register": "Inscription",
"google": "Inscription avec Google"
},
"body": "Veuillez saisir vos informations personnelles pour créer un compte.",
"form": {
"confirm-password": {
"label": "Confirmez le mot de passe"
},
"email": {
"label": "Adresse e-mail"
},
"name": {
"label": "Nom complet"
},
"password": {
"label": "Mot de passe"
},
"username": {
"label": "Nom d'utilisateur"
}
},
"heading": "Créer un compte",
"loginText": "Si vous avez déjà un compte, vous pouvez <1>vous connecter ici</1>."
},
"reset-password": {
"actions": {
"set-password": "Définir un nouveau mot de passe"
},
"body": "Saisissez un nouveau mot de passe pour votre compte.",
"form": {
"confirm-password": {
"label": "Confirmez le mot de passe"
},
"password": {
"label": "Mot de passe"
}
},
"heading": "Réinitialiser votre mot de passe"
}
},
"dashboard": {
"create-resume": {
"actions": {
"create-resume": "Créer un CV"
},
"body": "Commencez à construire votre CV en lui donnant un nom. Il peut s'agir d'une référence au rôle auquel vous postulez ou simplement de votre repas préféré.",
"form": {
"name": {
"label": "Nom"
},
"public": {
"label": "Est-il accessible au public ?"
},
"slug": {
"label": "Alias"
}
},
"heading": "Créer un nouveau CV"
},
"import-external": {
"heading": "Importer de sources externes",
"json-resume": {
"actions": {
"upload-json": "Mettre en ligne un JSON"
},
"body": "Si vous avez un <1>JSON Resume valide</1> prêt à l'emploi, vous pouvez l'utiliser pour accélérer votre création sur Reactive Resume. Cliquez sur le bouton ci-dessous et mettez en ligne un fichier JSON valide pour commencer.",
"heading": "Importer depuis JSON Resume"
},
"linkedin": {
"actions": {
"upload-archive": "Mettre en ligne une archive ZIP"
},
"body": "Vous pouvez gagner du temps en exportant vos données depuis LinkedIn et en les utilisant pour remplir automatiquement les champs sur Reactive Resume. Rendez-vous dans la section <1>Confidentialité des données</1> sur LinkedIn et demandez une archive de vos données. Une fois disponible, chargez le fichier ZIP ci-dessous.",
"heading": "Import depuis LinkedIn"
},
"reactive-resume": {
"actions": {
"upload-json": "Mettre en ligne un JSON"
},
"body": "Si vous avez un JSON qui a été exporté avec la version actuelle de Reactive Resume, vous pouvez l'importer ici pour récupérer une version modifiable. Les versions précédentes de Reactive Resume ne sont malheureusement pas prises en charge pour le moment.",
"heading": "Importer depuis Reactive Resume"
}
},
"rename-resume": {
"actions": {
"rename-resume": "Renommer le CV"
},
"form": {
"name": {
"label": "Nom"
},
"slug": {
"label": "Alias"
}
},
"heading": "Renommer votre CV"
}
}
}

View File

@ -0,0 +1,358 @@
{
"common": {
"actions": {
"add": "नया जोड़ें {{token}}",
"delete": "हटाएं {{token}}",
"edit": "संपादित करें {{token}}"
},
"columns": {
"heading": "कॉलम",
"tooltip": "स्तंभों की संख्या बदलें"
},
"form": {
"date": {
"label": "तारीख"
},
"description": {
"label": "विवरण"
},
"email": {
"label": "ईमेल पता"
},
"end-date": {
"help-text": "इस फ़ील्ड को खाली छोड़ दें, यदि अभी भी मौजूद है",
"label": "अंतिम तिथि"
},
"keywords": {
"label": "कीवर्ड"
},
"level": {
"label": "स्तर"
},
"levelNum": {
"label": "स्तर (संख्या)"
},
"name": {
"label": "नाम"
},
"phone": {
"label": "फ़ोन नंबर"
},
"position": {
"label": "स्थान"
},
"start-date": {
"label": "आरंभ करने की तिथि"
},
"subtitle": {
"label": "उपशीर्षक"
},
"summary": {
"label": "सारांश"
},
"title": {
"label": "शीर्षक"
},
"url": {
"label": "वेबसाइट"
}
},
"glossary": {
"page": "पृष्ठ"
},
"list": {
"actions": {
"delete": "हटाएं",
"duplicate": "डुप्लिकेट",
"edit": "संपादित करें"
},
"empty-text": "यह सूची खाली है।"
},
"tooltip": {
"delete-item": "क्या आप सुनिश्चित रूप से इस आइटम को मिटाना चाहते हैं? यह एक अपरिवर्तनीय क्रिया है।",
"delete-section": "अनुभाग हटाएं",
"rename-section": "अनुभाग का नाम बदलें",
"toggle-visibility": "दृश्यता टॉगल करें"
}
},
"controller": {
"tooltip": {
"center-artboard": "केंद्र आर्टबोर्ड",
"copy-link": "फिर से शुरू करने के लिए लिंक कॉपी करें",
"export-pdf": "पीडीएफ निर्यात करें",
"toggle-orientation": "टॉगल पेज ओरिएंटेशन",
"toggle-page-break-line": "टॉगल पेज ब्रेक लाइन",
"toggle-sidebars": "साइडबार टॉगल करें",
"zoom-in": "ज़ूम इन",
"zoom-out": "ज़ूम आउट"
}
},
"header": {
"menu": {
"delete": "हटाएं",
"duplicate": "डुप्लिकेट",
"rename": "नाम बदलें",
"share-link": "लिंक शेयर करें",
"tooltips": {
"delete": "क्या आप वाकई इस रेज़्यूमे को हटाना चाहते हैं? यह एक अपरिवर्तनीय क्रिया है।",
"share-link": "आपको अपने रेज़्यूमे की दृश्यता को सार्वजनिक करने की आवश्यकता है ताकि इसे दूसरों को दिखाई दे।"
}
}
},
"leftSidebar": {
"sections": {
"awards": {
"form": {
"awarder": {
"label": "पुरस्कार देने वाला"
}
}
},
"basics": {
"actions": {
"photo-filters": "फोटो फिल्टर"
},
"heading": "मूल बातें",
"headline": {
"label": "शीर्षक"
},
"name": {
"label": "पूरा नाम"
},
"photo-filters": {
"effects": {
"border": {
"label": "बॉर्डर"
},
"grayscale": {
"label": "स्केल"
},
"heading": "प्रभाव"
},
"shape": {
"heading": "आकार"
},
"size": {
"heading": "आकार (पीएक्स में)"
}
},
"photo-upload": {
"tooltip": {
"remove": "फोटो हटाएं",
"upload": "फोटो अपलोड करें"
}
}
},
"certifications": {
"form": {
"issuer": {
"label": "जारीकर्ता"
}
}
},
"education": {
"form": {
"area-study": {
"label": "अध्ययन का क्षेत्र"
},
"courses": {
"label": "पाठ्यक्रम"
},
"degree": {
"label": "डिग्री"
},
"grade": {
"label": "ग्रेड"
},
"institution": {
"label": "संस्थान"
}
}
},
"location": {
"address": {
"label": "पता"
},
"city": {
"label": "शहर"
},
"country": {
"label": "देश"
},
"heading": "स्थान",
"postal-code": {
"label": "डाक कोड"
},
"region": {
"label": "क्षेत्र"
}
},
"profiles": {
"form": {
"network": {
"label": "नेटवर्क"
},
"username": {
"label": "उपयोगकर्ता नाम"
}
},
"heading": "प्रोफाइल",
"heading_one": "प्रोफ़ाइल"
},
"publications": {
"form": {
"publisher": {
"label": "प्रकाशक"
}
}
},
"references": {
"form": {
"relationship": {
"label": "संबंध"
}
}
},
"section": {
"heading": "अनुभाग"
},
"volunteer": {
"form": {
"organization": {
"label": "संगठन"
}
}
}
}
},
"rightSidebar": {
"sections": {
"css": {
"heading": "कस्टम सीएसएस"
},
"export": {
"heading": "निर्यात",
"json": {
"primary": "JSON",
"secondary": "अपने रेज़्यूमे का JSON संस्करण डाउनलोड करें जिसे रिएक्टिव रेज़्यूमे में वापस आयात किया जा सकता है।"
},
"pdf": {
"loading": {
"primary": "पीडीएफ उत्पन्न करना",
"secondary": "कृपया प्रतीक्षा करें क्योंकि आपका PDF जनरेट हो गया है, इसमें 15 सेकंड तक लग सकते हैं।"
},
"normal": {
"primary": "पीडीएफ",
"secondary": "अपने रिज्यूमे का एक पीडीएफ डाउनलोड करें जिसे आप प्रिंट कर सकते हैं और अपने सपनों की नौकरी के लिए भेज सकते हैं। आगे के संपादन के लिए इस फ़ाइल को वापस आयात नहीं किया जा सकता है।"
}
}
},
"layout": {
"heading": "ख़ाका",
"tooltip": {
"reset-layout": "लेआउट रीसेट करें"
}
},
"links": {
"bugs-features": {
"body": "कुछ आपको रिज्यूमे बनाने से रोक रहा है? या क्या आपके पास जोड़ने के लिए एक अद्भुत विचार है? आरंभ करने के लिए गिटहब पर एक मुद्दा उठाएं।",
"button": "गिटहब मुद्दे",
"heading": "कीड़े? सुविधा का अनुरोध?"
},
"donate": {
"body": "यदि आप रिएक्टिव रिज्यूमे का उपयोग करना पसंद करते हैं, तो कृपया ऐप को चालू रखने और विज्ञापनों के बिना और हमेशा के लिए मुक्त रखने के लिए जितना हो सके दान करने पर विचार करें।",
"button": "मेरे लिए एक कॉफी खरीदें",
"heading": "प्रतिक्रियाशील फिर से शुरू करने के लिए दान करें"
},
"github": "सोर्स कोड",
"heading": "लिंक"
},
"settings": {
"global": {
"date": {
"primary": "तारीख",
"secondary": "पूरे ऐप में उपयोग करने के लिए दिनांक प्रारूप"
},
"heading": "वैश्विक",
"language": {
"primary": "भाषा",
"secondary": "पूरे ऐप में उपयोग करने के लिए भाषा प्रदर्शित करें"
},
"theme": {
"primary": "विषय"
}
},
"heading": "समायोजन",
"page": {
"break-line": {
"primary": "अंतराल वाली लकीर",
"secondary": "A4 पृष्ठ की ऊंचाई को चिह्नित करने के लिए सभी पृष्ठों पर एक पंक्ति दिखाएं"
},
"heading": "पृष्ठ",
"orientation": {
"disabled": "केवल एक पृष्ठ होने पर कोई प्रभाव नहीं पड़ता",
"primary": "अभिविन्यास",
"secondary": "पृष्ठों को क्षैतिज या लंबवत रूप से प्रदर्शित करना है या नहीं"
}
},
"resume": {
"heading": "फिर शुरू करना",
"reset": {
"primary": "सब कुछ रीसेट करें",
"secondary": "बहुत सारी गलतियाँ कीं? सभी परिवर्तनों को रीसेट करने और नए सिरे से शुरू करने के लिए यहां क्लिक करें। सावधान रहें, इस क्रिया को उलटा नहीं किया जा सकता है।"
},
"sample": {
"primary": "नमूना डेटा लोड करें",
"secondary": "पता नहीं कहां से शुरू करना है? कुछ नमूना डेटा लोड करने के लिए यहां क्लिक करें यह देखने के लिए कि एक पूरा रिज्यूमे कैसा दिखता है।"
}
}
},
"sharing": {
"heading": "शेयरिंग",
"short-url": {
"label": "लघु URL को प्राथमिकता दें"
},
"visibility": {
"subtitle": "लिंक वाले किसी भी व्यक्ति को अपना बायोडाटा देखने की अनुमति दें",
"title": "जनता"
}
},
"templates": {
"heading": "टेम्पलेट्स"
},
"theme": {
"form": {
"background": {
"label": "पृष्ठभूमि"
},
"primary": {
"label": "मुख्य"
},
"text": {
"label": "मूलपाठ"
}
},
"heading": "विषय"
},
"typography": {
"form": {
"font-family": {
"label": "फ़ॉन्ट परिवार"
},
"font-size": {
"label": "फ़ॉन्ट आकार"
}
},
"heading": "टाइपोग्राफी",
"widgets": {
"body": {
"label": "शरीर"
},
"headings": {
"label": "शीर्षकों"
}
}
}
}
}
}

View File

@ -0,0 +1,32 @@
{
"avatar": {
"menu": {
"greeting": "नमस्ते",
"logout": "लॉग आउट"
}
},
"footer": {
"credit": "<1>अमृत पिल्लै</1> . का एक जुनूनी प्रोजेक्ट",
"language": {
"missing": "आपकी भाषा याद आ रही है?"
},
"license": "समाज के लिए, समाज के लिए।"
},
"markdown": {
"help-text": "यह अनुभाग <1>मार्कडाउन</1> स्वरूपण का समर्थन करता है।"
},
"date": {
"present": "वर्तमान"
},
"subtitle": "एक फ्री और ओपन सोर्स रिज्यूम बिल्डर।",
"title": "रिएक्टिव रिज्यूमे",
"toast": {
"error": {
"upload-file-size": "कृपया केवल 2 मेगाबाइट से कम की फ़ाइलें अपलोड करें।",
"upload-photo-size": "कृपया केवल 2 मेगाबाइट से कम के फ़ोटो अपलोड करें, अधिमानतः वर्गाकार।"
},
"success": {
"resume-link-copied": "आपके रिज्यूमे का लिंक आपके क्लिपबोर्ड पर कॉपी कर दिया गया है।"
}
}
}

View File

@ -0,0 +1,25 @@
{
"create-resume": {
"subtitle": "शून्य से शुरू करें",
"title": "नया रिज्यूमे बनाएं"
},
"import-external": {
"subtitle": "लिंक्डइन, JSON रिज्यूमे, रिएक्टिव रिज्यूमे",
"title": "बाहरी स्रोतों से आयात"
},
"resume": {
"menu": {
"delete": "हटाएं",
"duplicate": "डुप्लिकेट",
"open": "खुला हुआ",
"rename": "नाम बदलें",
"share-link": "लिंक शेयर करें",
"tooltips": {
"delete": "क्या आप वाकई इस रेज़्यूमे को हटाना चाहते हैं? यह एक अपरिवर्तनीय क्रिया है।",
"share-link": "आपको अपने रेज़्यूमे की दृश्यता को सार्वजनिक करने की आवश्यकता है ताकि इसे दूसरों को दिखाई दे।"
}
},
"timestamp": "पिछली बार अपडेट किया गया {{timestamp}} पहले"
},
"title": "डैशबोर्ड"
}

View File

@ -0,0 +1,41 @@
{
"actions": {
"app": "ऐप्स पर जाएं",
"login": "लॉग इन करें",
"logout": "लॉग आउट",
"register": "रजिस्टर करें"
},
"features": {
"heading": "विशेषताएं",
"list": {
"ads": "कोई विज्ञापन नहीं",
"export": "अपने रिज्यूमे को JSON या PDF फॉर्मेट में एक्सपोर्ट करें",
"free": "हमेशा के लिए आज़ाद",
"import": "लिंक्डइन, JSON रिज्यूमे से डेटा आयात करें",
"languages": "कई भाषाओं में सुलभ",
"more": "और भी बहुत कुछ रोमांचक विशेषताएं, <1>इसके बारे में सब कुछ यहां पढ़ें</1>",
"tracking": "कोई उपयोगकर्ता ट्रैकिंग नहीं"
}
},
"links": {
"heading": "लिंक",
"links": {
"donate": "दान करना",
"github": "सोर्स कोड",
"privacy": "गोपनीयता नीति",
"service": "सेवा की शर्तें"
}
},
"screenshots": {
"heading": "स्क्रीनशॉट"
},
"testimonials": {
"heading": "प्रशंसापत्र",
"body": "अच्छा या बुरा, मुझे रिएक्टिव रिज्यूमे पर आपकी राय और आपके लिए अनुभव कैसा रहा, यह जानकर अच्छा लगेगा।<br/>यहां दुनिया भर के उपयोगकर्ताओं द्वारा भेजे गए कुछ संदेश दिए गए हैं।",
"contact": "आप <1>मेरे ईमेल</1> के माध्यम से या <3>मेरी वेबसाइट</3> पर संपर्क फ़ॉर्म के माध्यम से मुझसे संपर्क कर सकते हैं।"
},
"summary": {
"body": "रिएक्टिव रिज्यूमे एक फ्री और ओपन सोर्स रिज्यूमे बिल्डर है जो आपके रिज्यूमे को बनाने, अपडेट करने और साझा करने के सांसारिक कार्यों को 1, 2, 3 जितना आसान बनाने के लिए बनाया गया है। इस ऐप के साथ, आप कई रिज्यूमे बना सकते हैं, उन्हें रिक्रूटर्स या दोस्तों के साथ साझा कर सकते हैं। एक अद्वितीय लिंक के माध्यम से और अपने डेटा की अखंडता और गोपनीयता को खोए बिना इसे एक पीडीएफ के रूप में प्रिंट करें, सब कुछ मुफ्त में, कोई विज्ञापन नहीं, कोई ट्रैकिंग नहीं।",
"heading": "सारांश"
}
}

View File

@ -0,0 +1,135 @@
{
"auth": {
"forgot-password": {
"actions": {
"send-email": "रीसेट पासवर्ड ईमेल भेजें"
},
"body": "बस उस खाते से संबद्ध ईमेल पता दर्ज करें जिसे आप पुनर्प्राप्त करना चाहते हैं।",
"form": {
"email": {
"label": "ईमेल पता"
}
},
"heading": "अपना कूट शब्द भूल गए?",
"help-text": "यदि खाता मौजूद है, तो आपको अपना पासवर्ड रीसेट करने के लिए एक लिंक के साथ एक ईमेल प्राप्त होगा।"
},
"login": {
"actions": {
"login": "लॉग इन करें",
"google": "Google के साथ लॉगिन करें"
},
"body": "लॉग इन करने और अपने रिज्यूमे को एक्सेस करने, प्रबंधित करने और साझा करने के लिए कृपया अपने खाते से संबद्ध अपना उपयोगकर्ता नाम और पासवर्ड दर्ज करें।",
"form": {
"password": {
"label": "कुंजिका"
},
"username": {
"help-text": "आप अपना ईमेल पता भी दर्ज कर सकते हैं",
"label": "उपयोगकर्ता नाम"
}
},
"heading": "अपने अकाउंट में लॉग इन करें",
"recover-text": "यदि आप अपना पासवर्ड भूल गए हैं, तो आप यहां <1>अपना खाता पुनर्प्राप्त</1> कर सकते हैं।",
"register-text": "यदि आपके पास खाता नहीं है, तो आप यहां <1>खाता बना</1> सकते हैं।"
},
"register": {
"actions": {
"register": "रजिस्टर करें",
"google": "Google के साथ रजिस्टर करें"
},
"body": "खाता बनाने के लिए कृपया अपनी व्यक्तिगत जानकारी दर्ज करें।",
"form": {
"confirm-password": {
"label": "पासवर्ड की पुष्टि कीजिये"
},
"email": {
"label": "ईमेल पता"
},
"name": {
"label": "पूरा नाम"
},
"password": {
"label": "कुंजिका"
},
"username": {
"label": "उपयोगकर्ता नाम"
}
},
"heading": "खाता बनाएं",
"loginText": "यदि आपके पास पहले से ही एक खाता है, तो आप <1>यहां लॉगिन</1> कर सकते हैं।"
},
"reset-password": {
"actions": {
"set-password": "नया पासवर्ड सेट करें"
},
"body": "अपने खाते के लिए एक नया पासवर्ड दर्ज करें।",
"form": {
"confirm-password": {
"label": "पासवर्ड की पुष्टि कीजिये"
},
"password": {
"label": "कुंजिका"
}
},
"heading": "अपना पासवर्ड रीसेट करें"
}
},
"dashboard": {
"create-resume": {
"actions": {
"create-resume": "रिज्यूमे बनाएं"
},
"body": "इसे एक नाम देकर अपना रिज्यूमे बनाना शुरू करें। यह उस भूमिका के संदर्भ में हो सकता है जिसके लिए आप आवेदन कर रहे हैं, या सिर्फ आपका पसंदीदा नाश्ता।",
"form": {
"name": {
"label": "नाम"
},
"public": {
"label": "सार्वजनिक रूप से सुलभ है?"
},
"slug": {
"label": "काउंटर"
}
},
"heading": "एक नया बायोडाटा बनाएं"
},
"import-external": {
"heading": "बाहरी स्रोतों से आयात",
"json-resume": {
"actions": {
"upload-json": "JSON अपलोड करें"
},
"body": "यदि आपके पास <1>मान्य JSON रिज्यूमे</1> जाने के लिए तैयार है, तो आप इसका उपयोग रिएक्टिव रिज्यूमे पर अपने विकास को तेजी से ट्रैक करने के लिए कर सकते हैं। शुरू करने के लिए नीचे दिए गए बटन पर क्लिक करें और एक मान्य JSON फ़ाइल अपलोड करें।",
"heading": "JSON रिज्यूमे से आयात करें"
},
"linkedin": {
"actions": {
"upload-archive": "ज़िप संग्रह अपलोड करें"
},
"body": "आप अपने डेटा को लिंक्डइन से निर्यात करके और रिएक्टिव रिज्यूमे पर ऑटो-फिल फ़ील्ड में इसका उपयोग करके समय बचा सकते हैं। लिंक्डइन पर <1>डेटा गोपनीयता</1> अनुभाग पर जाएं और अपने डेटा के संग्रह का अनुरोध करें। एक बार यह उपलब्ध हो जाने पर, नीचे ज़िप फ़ाइल अपलोड करें।",
"heading": "लिंक्डइन से आयात करें"
},
"reactive-resume": {
"actions": {
"upload-json": "JSON अपलोड करें"
},
"body": "यदि आपके पास एक JSON है जिसे रिएक्टिव रिज्यूमे के वर्तमान संस्करण के साथ निर्यात किया गया था, तो आप इसे फिर से एक संपादन योग्य संस्करण प्राप्त करने के लिए यहां वापस आयात कर सकते हैं। रिएक्टिव रिज्यूमे के पिछले संस्करण दुर्भाग्य से इस समय समर्थित नहीं हैं।",
"heading": "रिएक्टिव रिज्यूमे से आयात करें"
}
},
"rename-resume": {
"actions": {
"rename-resume": "रिज्यूमे का नाम बदलें"
},
"form": {
"name": {
"label": "नाम"
},
"slug": {
"label": "काउंटर"
}
},
"heading": "अपने रिज्यूमे का नाम बदलें"
}
}
}

View File

@ -0,0 +1,358 @@
{
"common": {
"actions": {
"add": "Aggiungi {{token}}",
"delete": "Elimina {{token}}",
"edit": "Modifica {{token}}"
},
"columns": {
"heading": "Colonne",
"tooltip": "Modifica numero di colonne"
},
"form": {
"date": {
"label": "Data"
},
"description": {
"label": "Descrizione"
},
"email": {
"label": "Indirizzo e-mail"
},
"end-date": {
"help-text": "Se in corso, lascia questo campo vuoto",
"label": "Data di fine"
},
"keywords": {
"label": "Parole chiave"
},
"level": {
"label": "Livello"
},
"levelNum": {
"label": "Livello (numero)"
},
"name": {
"label": "Nome"
},
"phone": {
"label": "Numero di telefono"
},
"position": {
"label": "Posizione"
},
"start-date": {
"label": "Data di inizio"
},
"subtitle": {
"label": "Sottotitolo"
},
"summary": {
"label": "Profilo personale"
},
"title": {
"label": "Titolo"
},
"url": {
"label": "Sito web"
}
},
"glossary": {
"page": "Pagina"
},
"list": {
"actions": {
"delete": "Elimina",
"duplicate": "Duplica",
"edit": "Modifica"
},
"empty-text": "Questo elenco è vuoto."
},
"tooltip": {
"delete-item": "Vuoi davvero rimuovere questo elemento? Questa operazione è irreversibile.",
"delete-section": "Elimina sezione",
"rename-section": "Rinomina sezione",
"toggle-visibility": "Mostra/Nascondi"
}
},
"controller": {
"tooltip": {
"center-artboard": "Centra tavola da disegno",
"copy-link": "Copia link del curriculum",
"export-pdf": "Esporta in PDF",
"toggle-orientation": "Orientamento verticale/orizzontale",
"toggle-page-break-line": "Mostra/Nascondi linea interruzione pagina",
"toggle-sidebars": "Mostra/Nascondi barre laterali",
"zoom-in": "Ingrandisci",
"zoom-out": "Riduci"
}
},
"header": {
"menu": {
"delete": "Elimina",
"duplicate": "Duplica",
"rename": "Rinomina",
"share-link": "Condividi link",
"tooltips": {
"delete": "Vuoi davvero eliminare questo curriculum? Questa operazione è irreversibile.",
"share-link": "Per rendere il curriculum visibile agli altri, imposta la visibilità su \"Pubblico\"."
}
}
},
"leftSidebar": {
"sections": {
"awards": {
"form": {
"awarder": {
"label": "Conferito da"
}
}
},
"basics": {
"actions": {
"photo-filters": "Filtri per foto"
},
"heading": "Informazioni di base",
"headline": {
"label": "Intestazione"
},
"name": {
"label": "Nome e cognome"
},
"photo-filters": {
"effects": {
"border": {
"label": "Bordo"
},
"grayscale": {
"label": "Scala di grigi"
},
"heading": "Effetti"
},
"shape": {
"heading": "Forma"
},
"size": {
"heading": "Dimensioni (pixel)"
}
},
"photo-upload": {
"tooltip": {
"remove": "Rimuovi foto",
"upload": "Carica foto"
}
}
},
"certifications": {
"form": {
"issuer": {
"label": "Rilasciato da"
}
}
},
"education": {
"form": {
"area-study": {
"label": "Area di studio"
},
"courses": {
"label": "Corsi"
},
"degree": {
"label": "Laurea"
},
"grade": {
"label": "Voto"
},
"institution": {
"label": "Istituto"
}
}
},
"location": {
"address": {
"label": "Indirizzo"
},
"city": {
"label": "Città"
},
"country": {
"label": "Paese"
},
"heading": "Posizione",
"postal-code": {
"label": "CAP"
},
"region": {
"label": "Regione"
}
},
"profiles": {
"form": {
"network": {
"label": "Rete"
},
"username": {
"label": "Nome utente"
}
},
"heading": "Profili",
"heading_one": "Profilo"
},
"publications": {
"form": {
"publisher": {
"label": "Pubblicato da"
}
}
},
"references": {
"form": {
"relationship": {
"label": "Relazione"
}
}
},
"section": {
"heading": "Sezione"
},
"volunteer": {
"form": {
"organization": {
"label": "Organizzazione"
}
}
}
}
},
"rightSidebar": {
"sections": {
"css": {
"heading": "CSS personalizzato"
},
"export": {
"heading": "Esporta",
"json": {
"primary": "JSON",
"secondary": "Scarica una versione JSON del tuo curriculum che puoi importare nuovamente in Reactive Resume."
},
"pdf": {
"loading": {
"primary": "Generazione del PDF in corso...",
"secondary": "Attendi che la generazione del PDF sia completata, l'operazione potrebbe richiedere fino a 15 secondi."
},
"normal": {
"primary": "PDF",
"secondary": "Scarica un PDF del tuo curriculum che puoi stampare e usare per il lavoro dei tuoi sogni. Questo file non può essere importato nuovamente per ulteriori modifiche."
}
}
},
"layout": {
"heading": "Layout",
"tooltip": {
"reset-layout": "Ripristina layout"
}
},
"links": {
"bugs-features": {
"body": "Hai riscontrato un problema nella creazione del tuo curriculum? Hai un'idea fantastica da aggiungere? Usa gli Issue di GitHub per iniziare.",
"button": "Issue di GitHub",
"heading": "Bug? Richieste di funzionalità?"
},
"donate": {
"body": "Se Reactive Resume ti è piaciuto, ti invitiamo a contribuire con una donazione. In questo modo potremo mantenere l'applicazione attiva, gratuita e senza pubblicità.",
"button": "Offrimi un caffè",
"heading": "Donazioni a Reactive Resume"
},
"github": "Codice sorgente",
"heading": "Link"
},
"settings": {
"global": {
"date": {
"primary": "Data",
"secondary": "Formato della data da usare nell'app"
},
"heading": "Globale",
"language": {
"primary": "Lingua",
"secondary": "Lingua di visualizzazione dell'app"
},
"theme": {
"primary": "Tema"
}
},
"heading": "Impostazioni",
"page": {
"break-line": {
"primary": "Linea di interruzione",
"secondary": "Mostra su tutte le pagine una linea che indica l'altezza di un foglio A4"
},
"heading": "Pagina",
"orientation": {
"disabled": "Questa funzione non ha effetto se c'è solo una pagina",
"primary": "Orientamento",
"secondary": "Scegli se visualizzare le pagine in orizzontale o verticale"
}
},
"resume": {
"heading": "Curriculum",
"reset": {
"primary": "Ripristina tutto",
"secondary": "Hai fatto un po' troppi errori? Clicca qui per ripristinare tutte le modifiche e iniziare da zero. Questa operazione non è reversibile."
},
"sample": {
"primary": "Carica dati di esempio",
"secondary": "Non sai da dove cominciare? Clicca qui per caricare alcuni dati di esempio per vedere che aspetto ha un curriculum completo."
}
}
},
"sharing": {
"heading": "Condivisione",
"short-url": {
"label": "Preferisci URL breve"
},
"visibility": {
"subtitle": "Consenti a chiunque abbia il link di vedere il tuo curriculum",
"title": "Pubblico"
}
},
"templates": {
"heading": "Modelli"
},
"theme": {
"form": {
"background": {
"label": "Sfondo"
},
"primary": {
"label": "Principale"
},
"text": {
"label": "Testo"
}
},
"heading": "Tema"
},
"typography": {
"form": {
"font-family": {
"label": "Famiglia di caratteri"
},
"font-size": {
"label": "Dimensioni carattere"
}
},
"heading": "Tipografia",
"widgets": {
"body": {
"label": "Contenuto"
},
"headings": {
"label": "Intestazioni"
}
}
}
}
}
}

View File

@ -0,0 +1,32 @@
{
"avatar": {
"menu": {
"greeting": "Ciao",
"logout": "Esci"
}
},
"footer": {
"credit": "Un progetto nato dalla passione di <1>Amruth Pillai</1>",
"language": {
"missing": "Non trovi la tua lingua?"
},
"license": "Dalla gente, per la gente."
},
"markdown": {
"help-text": "Questa sezione supporta la formattazione <1>Markdown</1> ."
},
"date": {
"present": "In corso"
},
"subtitle": "Un'applicazione di creazione curriculum gratuita e open source.",
"title": "Reactive Resume",
"toast": {
"error": {
"upload-file-size": "Carica solo file inferiori a 2 MB.",
"upload-photo-size": "Carica solo foto inferiori a 2 MB, preferibilmente quadrate."
},
"success": {
"resume-link-copied": "Abbiamo copiato il link del tuo curriculum negli appunti."
}
}
}

View File

@ -0,0 +1,25 @@
{
"create-resume": {
"subtitle": "Inizia da zero",
"title": "Crea nuovo curriculum"
},
"import-external": {
"subtitle": "LinkedIn, JSON Resume, Reactive Resume",
"title": "Importa da fonti esterne"
},
"resume": {
"menu": {
"delete": "Elimina",
"duplicate": "Duplica",
"open": "Apri",
"rename": "Rinomina",
"share-link": "Condividi il link",
"tooltips": {
"delete": "Vuoi davvero eliminare questo curriculum? Questa operazione è irreversibile.",
"share-link": "Per rendere il curriculum visibile agli altri, imposta la visibilità su \"Pubblico\"."
}
},
"timestamp": "Ultimo aggiornamento {{timestamp}} fa"
},
"title": "Dashboard"
}

View File

@ -0,0 +1,41 @@
{
"actions": {
"app": "Vai all'app",
"login": "Accedi",
"logout": "Esci",
"register": "Registrati"
},
"features": {
"heading": "Funzioni",
"list": {
"ads": "Nessuna pubblicità",
"export": "Esporta il tuo curriculum in formato JSON o PDF",
"free": "Gratuita, per sempre",
"import": "Importa dati da LinkedIn, JSON Resume",
"languages": "Accessibile in varie lingue",
"more": "E tante altre funzioni interessanti, <1>scopri di più qui</1>",
"tracking": "Senza rilevamento delle azioni dell'utente"
}
},
"links": {
"heading": "Collegamenti",
"links": {
"donate": "Dona",
"github": "Codice sorgente",
"privacy": "Informativa sulla privacy",
"service": "Condizioni d'uso"
}
},
"screenshots": {
"heading": "Screenshot"
},
"testimonials": {
"heading": "Cosa dicono i nostri utenti",
"body": "Che la tua opinione sia positiva o negativa, mi piacerebbe sapere cosa ne pensi di Reactive Resume.<br/>Ecco alcuni dei messaggi che abbiamo ricevuto dai nostri utenti in tutto il mondo.",
"contact": "Puoi contattarmi al <1>mio indirizzo e-mail</1> oppure usando l'apposito modulo sul <3>mio sito web</3>."
},
"summary": {
"body": "Reactive Resume è un'applicazione di creazione di curriculum gratuita e open source, ideata per semplificare le attività di creazione, aggiornamento e condivisione del tuo curriculum. Con questa applicazione, è possibile creare più curriculum, condividerli con recruiter o amici attraverso un link unico e stamparli in formato PDF, il tutto gratuitamente, senza pubblicità, senza tracciamento e soprattutto preservando l'integrità e la privacy dei tuoi dati.",
"heading": "Profilo personale"
}
}

View File

@ -0,0 +1,135 @@
{
"auth": {
"forgot-password": {
"actions": {
"send-email": "Invia e-mail per reimpostare la password"
},
"body": "Inserisci l'indirizzo e-mail associato all'account da recuperare.",
"form": {
"email": {
"label": "Indirizzo e-mail"
}
},
"heading": "Hai dimenticato la password?",
"help-text": "Se l'account esiste, riceverai un'e-mail con un link per reimpostare la password."
},
"login": {
"actions": {
"login": "Accedi",
"google": "Accedi con Google"
},
"body": "Per accedere e iniziare a lavorare sui tuoi curriculum, inserisci il nome utente e la password associati al tuo account.",
"form": {
"password": {
"label": "Password"
},
"username": {
"help-text": "Puoi anche inserire il tuo indirizzo e-mail",
"label": "Nome utente"
}
},
"heading": "Accedi al tuo account",
"recover-text": "Se hai dimenticato la password, puoi recuperare il tuo account <1>qui</1>.",
"register-text": "Se non hai ancora un account, puoi crearne uno <1>qui</1>."
},
"register": {
"actions": {
"register": "Registrati",
"google": "Registrati con Google"
},
"body": "Inserisci i tuoi dati per creare un account.",
"form": {
"confirm-password": {
"label": "Conferma password"
},
"email": {
"label": "Indirizzo e-mail"
},
"name": {
"label": "Nome e cognome"
},
"password": {
"label": "Password"
},
"username": {
"label": "Nome utente"
}
},
"heading": "Crea un account",
"loginText": "Se hai già un account, puoi accedere <1>qui</1>."
},
"reset-password": {
"actions": {
"set-password": "Imposta nuova password"
},
"body": "Inserisci una nuova password per l'account.",
"form": {
"confirm-password": {
"label": "Conferma password"
},
"password": {
"label": "Password"
}
},
"heading": "Reimposta password"
}
},
"dashboard": {
"create-resume": {
"actions": {
"create-resume": "Crea curriculum"
},
"body": "Inizia a creare un curriculum inserendo un nome, in riferimento alla posizione per cui vuoi candidarti o semplicemente il tuo snack preferito.",
"form": {
"name": {
"label": "Nome"
},
"public": {
"label": "È ad accesso pubblico?"
},
"slug": {
"label": "Slug"
}
},
"heading": "Crea un nuovo curriculum"
},
"import-external": {
"heading": "Importa da fonti esterne",
"json-resume": {
"actions": {
"upload-json": "Carica JSON"
},
"body": "Se hai un <1>JSON Resume valido</1> già pronto, puoi usarlo per velocizzare il lavoro su Reactive Resume. Usa il pulsante qui sotto e carica un file JSON valido per iniziare.",
"heading": "Importa da JSON Resume"
},
"linkedin": {
"actions": {
"upload-archive": "Carica archivio ZIP"
},
"body": "Puoi velocizzare il tuo lavoro esportando i tuoi dati da LinkedIn e usandoli per riempire automaticamente i campi su Reactive Resume. Vai alla sezione <1>Privacy dei dati</1> di LinkedIn, richiedi una copia dei tuoi dati e carica il file ZIP qui sotto.",
"heading": "Importa da LinkedIn"
},
"reactive-resume": {
"actions": {
"upload-json": "Carica JSON"
},
"body": "Se hai un file JSON esportato con la versione attuale di Reactive Resume, puoi importarlo nuovamente qui e continuare ad apportare modifiche. Purtroppo le versioni precedenti di Reactive Resume non sono supportate al momento.",
"heading": "Importa da Reactive Resume"
}
},
"rename-resume": {
"actions": {
"rename-resume": "Rinomina curriculum"
},
"form": {
"name": {
"label": "Nome"
},
"slug": {
"label": "Slug"
}
},
"heading": "Rinomina il tuo curriculum"
}
}
}

View File

@ -61,9 +61,15 @@
"page": "ಪುಟ"
},
"list": {
"actions": {
"delete": "ಅಳಿಸಿ",
"duplicate": "ನಕಲು ಮಾಡಿ",
"edit": "ತಿದ್ದು"
},
"empty-text": "ಈ ಪಟ್ಟಿ ಖಾಲಿಯಾಗಿದೆ."
},
"tooltip": {
"delete-item": "ಈ ಐಟಂ ಅನ್ನು ಅಳಿಸಲು ನೀವು ಖಚಿತವಾಗಿ ಬಯಸುವಿರಾ? ಇದು ಬದಲಾಯಿಸಲಾಗದ ಕ್ರಮ.",
"delete-section": "ವಿಭಾಗವನ್ನು ಅಳಿಸಿ",
"rename-section": "ವಿಭಾಗವನ್ನು ಮರುಹೆಸರಿಸಿ",
"toggle-visibility": "ಗೋಚರತೆಯನ್ನು ಟಾಗಲ್ ಮಾಡಿ"
@ -284,6 +290,7 @@
},
"heading": "ಪುಟ",
"orientation": {
"disabled": "ಒಂದು ಪುಟ ಮಾತ್ರ ಇರುವಾಗ ಯಾವುದೇ ಪರಿಣಾಮ ಬೀರುವುದಿಲ್ಲ",
"primary": "ದೃಷ್ಟಿಕೋನ",
"secondary": "ಪುಟಗಳನ್ನು ಅಡ್ಡಲಾಗಿ ಅಥವಾ ಲಂಬವಾಗಿ ಪ್ರದರ್ಶಿಸಬೇಕೆ"
}

View File

@ -7,11 +7,17 @@
},
"footer": {
"credit": "<1>ಅಮೃತ್ ಪಿಳ್ಳೈ</1> ಅವರು ಉತ್ಸಾಹದಿಂದ ಮಾಡಿರುವ ಪ್ರಾಜೆಕ್ಟ್",
"language": {
"missing": "ನಿಮ್ಮ ಭಾಷೆ ಕಾಣೆಯಾಗಿದೆಯೇ?"
},
"license": "ಸಮುದಾಯದಿಂದ, ಸಮುದಾಯಕ್ಕಾಗಿ."
},
"markdown": {
"help-text": "ಈ ವಿಭಾಗವು <1>ಮಾರ್ಕ್‌ಡೌನ್</1> ಫಾರ್ಮ್ಯಾಟಿಂಗ್ ಅನ್ನು ಬೆಂಬಲಿಸುತ್ತದೆ."
},
"date": {
"present": "ಪ್ರಸ್ತುತ"
},
"subtitle": "ಉಚಿತ ಮತ್ತು ಮುಕ್ತ ಮೂಲ ರೇಸುಮೆ ಬಿಲ್ಡರ್.",
"title": "ರಿಯಾಕ್ಟಿವ್ ರೇಸುಮೆ",
"toast": {

View File

@ -11,7 +11,7 @@
}
},
"heading": "ನಿಮ್ಮ ಪಾಸ್ವರ್ಡ್ ಮರೆತಿರುವಿರಾ?",
"help-text": "ಖಾತೆಯು ಅಸ್ತಿತ್ವದಲ್ಲಿದ್ದರೆ, ನಿಮ್ಮ ಪಾಸ್‌ವರ್ಡ್ ಅನ್ನು ಮರುಹೊಂದಿಸಲು ಲಿಂಕ್‌ನೊಂದಿಗೆ ಇಮೇಲ್ ಅನ್ನು ನೀವು ಸ್ವೀಕರಿಸುತ್ತೀರಿ."
"help-text": "%1 ರ ಜೊತೆ ಜೋಡಣೆಯಾಗಿರುವ ಖಾತೆ ಇದ್ದಲ್ಲಿ, ನೀವು ನಿಮ್ಮ ಗುಪ್ತಪದ ಮರುಹೊಂದಿಕೆ ಕೊಂಡಿಯನ್ನು ಹೊಂದಿರುವ ಮಿಂಚೆಯನ್ನು ಪಡೆಯುವಿರಿ."
},
"login": {
"actions": {
@ -104,16 +104,16 @@
},
"linkedin": {
"actions": {
"upload-archive": "ಜಿಪ್ ಆರ್ಕೈವ್ ಅನ್ನು ಅಪ್‌ಲೋಡ್ ಮಾಡಿ"
"upload-archive": "ಜಿಪ್ (ZIP) ಆರ್ಕೈವ್ ಅನ್ನು ಅಪ್‌ಲೋಡ್ ಮಾಡಿ"
},
"body": "ಲಿಂಕ್ಡ್‌ಇನ್‌ನಿಂದ ನಿಮ್ಮ ಡೇಟಾವನ್ನು ರಫ್ತು ಮಾಡುವ ಮೂಲಕ ಮತ್ತು ರಿಯಾಕ್ಟಿವ್ ರೆಸ್ಯೂಮ್‌ನಲ್ಲಿ ಕ್ಷೇತ್ರಗಳನ್ನು ಸ್ವಯಂ ತುಂಬಲು ಅದನ್ನು ಬಳಸುವ ಮೂಲಕ ನೀವು ಸಮಯವನ್ನು ಉಳಿಸಬಹುದು. <1>ಡೇಟಾ ಗೌಪ್ಯತೆಗೆ ಹೋಗಿ</1> ಲಿಂಕ್ಡ್‌ಇನ್‌ನಲ್ಲಿ ವಿಭಾಗ ಮತ್ತು ನಿಮ್ಮ ಡೇಟಾದ ಆರ್ಕೈವ್ ಅನ್ನು ವಿನಂತಿಸಿ. ಒಮ್ಮೆ ಅದು ಲಭ್ಯವಾದ ನಂತರ, ಕೆಳಗಿನ ಜಿಪ್ ಆರ್ಕೈವ್ ಅನ್ನು ಅಪ್‌ಲೋಡ್ ಮಾಡಿ.",
"heading": "ಲಿಂಕ್ಡಿನ್ ನಿಂದ ಆಮದು ಮಾಡಿಕೊಳ್ಳಿ"
"body": "ಲಿಂಕ್ಡ್‌ಇನ್‌ನಿಂದ ನಿಮ್ಮ ಡೇಟಾವನ್ನು ರಫ್ತು ಮಾಡುವ ಮೂಲಕ ಮತ್ತು ರಿಯಾಕ್ಟಿವ್ ರೆಸ್ಯೂಮ್‌ನಲ್ಲಿ ಕ್ಷೇತ್ರಗಳನ್ನು ಸ್ವಯಂ ತುಂಬಲು ಅದನ್ನು ಬಳಸುವ ಮೂಲಕ ನೀವು ಸಮಯವನ್ನು ಉಳಿಸಬಹುದು. <1>ಡೇಟಾ ಗೌಪ್ಯತೆಗೆ ಹೋಗಿ</1> ಲಿಂಕ್ಡ್‌ಇನ್‌ನಲ್ಲಿ ವಿಭಾಗ ಮತ್ತು ನಿಮ್ಮ ಡೇಟಾದ ಆರ್ಕೈವ್ ಅನ್ನು ವಿನಂತಿಸಿ. ಒಮ್ಮೆ ಅದು ಲಭ್ಯವಾದ ನಂತರ, ಕೆಳಗಿನ ZIP ಫೈಲ್ ಅನ್ನು ಅಪ್‌ಲೋಡ್ ಮಾಡಿ.",
"heading": "ಲಿಂಕ್ಡಿನ್(LinkedIn) ನಿಂದ ಆಮದು ಮಾಡಿಕೊಳ್ಳಿ"
},
"reactive-resume": {
"actions": {
"upload-json": "ಜೆಸನ್ ಅನ್ನು ಅಪ್‌ಲೋಡ್ ಮಾಡಿ"
},
"body": "ನೀವು ರಿಯಾಕ್ಟಿವ್ ರೆಸ್ಯೂಮ್‌ನ ಪ್ರಸ್ತುತ ಆವೃತ್ತಿಯೊಂದಿಗೆ ರಫ್ತು ಮಾಡಲಾದ ಜೆಸನ್ ಅನ್ನು ಹೊಂದಿದ್ದರೆ, ಮತ್ತೆ ಸಂಪಾದಿಸಬಹುದಾದ ಆವೃತ್ತಿಯನ್ನು ಪಡೆಯಲು ನೀವು ಅದನ್ನು ಇಲ್ಲಿಗೆ ಆಮದು ಮಾಡಿಕೊಳ್ಳಬಹುದು. ರಿಯಾಕ್ಟಿವ್ ರೆಸ್ಯೂಮ್‌ನ ಹಿಂದಿನ ಆವೃತ್ತಿಗಳು ದುರದೃಷ್ಟವಶಾತ್ ಸದ್ಯಕ್ಕೆ ಬೆಂಬಲಿತವಾಗಿಲ್ಲ.",
"body": "ನೀವು ರಿಯಾಕ್ಟಿವ್ ರೆಸ್ಯೂಮ್‌ನ ಪ್ರಸ್ತುತ ಆವೃತ್ತಿಯೊಂದಿಗೆ ರಫ್ತು ಮಾಡಲಾದ ಜೆಸನ್(JSON) ಅನ್ನು ಹೊಂದಿದ್ದರೆ, ಮತ್ತೆ ಸಂಪಾದಿಸಬಹುದಾದ ಆವೃತ್ತಿಯನ್ನು ಪಡೆಯಲು ನೀವು ಅದನ್ನು ಇಲ್ಲಿಗೆ ಆಮದು ಮಾಡಿಕೊಳ್ಳಬಹುದು. ರಿಯಾಕ್ಟಿವ್ ರೆಸ್ಯೂಮ್‌ನ ಹಿಂದಿನ ಆವೃತ್ತಿಗಳು ದುರದೃಷ್ಟವಶಾತ್ ಸದ್ಯಕ್ಕೆ ಬೆಂಬಲಿತವಾಗಿಲ್ಲ.",
"heading": "ಜೆಸನ್ ರೆಸ್ಯೂಮ್‌ನಿಂದ ಆಮದು ಮಾಡಿಕೊಳ್ಳಿ"
}
},

View File

@ -61,9 +61,15 @@
"page": "பக்கம்"
},
"list": {
"actions": {
"delete": "அழி",
"duplicate": "நகல்",
"edit": "தொகு"
},
"empty-text": "இந்த பட்டியல் காலியாக உள்ளது."
},
"tooltip": {
"delete-item": "இந்த உருப்படியை நிச்சயமாக நீக்க விரும்புகிறீர்களா? இது மீள முடியாத செயல்.",
"delete-section": "பிரிவை அழிக்கவும்",
"rename-section": "பிரிவின் பெயரை மாற்றவும்",
"toggle-visibility": "தெரிவுநிலையை நிலைமாற்று"
@ -284,6 +290,7 @@
},
"heading": "பக்கம்",
"orientation": {
"disabled": "ஒரே ஒரு பக்கம் இருக்கும் போது எந்த விளைவும் இல்லை",
"primary": "நோக்குநிலை",
"secondary": "பக்கங்களை கிடைமட்டமாகவோ அல்லது செங்குத்தாகவோ காட்ட வேண்டுமா"
}

View File

@ -7,11 +7,17 @@
},
"footer": {
"credit": "<1>அம்ருத் பிள்ளை</1>யின் திட்டம்",
"language": {
"missing": "உங்கள் மொழியைக் காணவில்லையா?"
},
"license": "சமூகத்தால், சமூகத்திற்காக."
},
"markdown": {
"help-text": "இந்தப் பிரிவு <1>மார்க் டவுன்</1> வடிவமைப்பை ஆதரிக்கிறது."
},
"date": {
"present": "தற்போது"
},
"subtitle": "இலவச மற்றும் ஓப்பன் சோர்ஸ் ரெஸ்யூம் பில்டர்.",
"title": "ரியாக்டிவ் ரெசுமே",
"toast": {

View File

@ -0,0 +1,41 @@
{
"actions": {
"app": "பயன்பாட்டிற்குச் செல்லவும்",
"login": "உள்நுழைய",
"logout": "வெளியேறு",
"register": "பதிவு"
},
"features": {
"heading": "அம்சங்கள்",
"list": {
"ads": "விளம்பரம் இல்லை",
"export": "உங்கள் விண்ணப்பத்தை JSON அல்லது PDF வடிவத்திற்கு ஏற்றுமதி செய்யவும்",
"free": "இலவசம், எப்போதும்",
"import": "LinkedIn, JSON Resume இலிருந்து தரவை இறக்குமதி செய்யவும்",
"languages": "பல மொழிகளில் அணுகக்கூடியது",
"more": "மேலும் மிகவும் அற்புதமான அம்சங்கள், <1>அதைப் பற்றி இங்கே படிக்கவும்</1>",
"tracking": "பயனர் கண்காணிப்பு இல்லை"
}
},
"links": {
"heading": "இணைப்புகள்",
"links": {
"donate": "தானம் செய்",
"github": "மூல குறியீடு",
"privacy": "தனியுரிமைக் கொள்கை",
"service": "சேவை விதிமுறைகள்"
}
},
"screenshots": {
"heading": "திரைக்காட்சிகள்"
},
"testimonials": {
"heading": "சான்றுகள்",
"body": "நல்லதோ கெட்டதோ, ரியாக்டிவ் ரெஸ்யூம் பற்றிய உங்கள் கருத்தையும் உங்களுக்கு எப்படி அனுபவம் இருந்தது என்பதையும் கேட்க விரும்புகிறேன்.<br/>உலகம் முழுவதும் உள்ள பயனர்கள் அனுப்பிய சில செய்திகள் இங்கே உள்ளன.",
"contact": "<1>எனது மின்னஞ்சல்</1> மூலமாகவோ அல்லது <3>எனது இணையதளத்தில்</3> உள்ள தொடர்புப் படிவத்தின் மூலமாகவோ நீங்கள் என்னைத் தொடர்புகொள்ளலாம்."
},
"summary": {
"body": "ரியாக்டிவ் ரெஸ்யூம் என்பது ஒரு இலவச மற்றும் ஓப்பன் சோர்ஸ் ரெஸ்யூம் பில்டராகும், இது உங்கள் விண்ணப்பத்தை உருவாக்குதல், புதுப்பித்தல் மற்றும் பகிர்தல் போன்ற சாதாரண பணிகளை 1, 2, 3 என எளிதாக்கும் வகையில் உருவாக்கப்பட்டுள்ளது. இந்தப் பயன்பாட்டின் மூலம், நீங்கள் பல ரெஸ்யூம்களை உருவாக்கலாம், ஆட்சேர்ப்பு செய்பவர்கள் அல்லது நண்பர்களுடன் பகிர்ந்து கொள்ளலாம். ஒரு தனித்துவமான இணைப்பின் மூலம் அதை PDF ஆக அச்சிடுங்கள், அனைத்தும் இலவசமாக, விளம்பரங்கள் இல்லை, கண்காணிப்பு இல்லை, உங்கள் தரவின் ஒருமைப்பாடு மற்றும் தனியுரிமையை இழக்காமல்.",
"heading": "சுருக்கம்"
}
}

View File

@ -0,0 +1,135 @@
{
"auth": {
"forgot-password": {
"actions": {
"send-email": "கடவுச்சொல்லை மீட்டமைக்கும் மின்னஞ்சலை அனுப்பவும்"
},
"body": "நீங்கள் மீட்டெடுக்க விரும்பும் கணக்குடன் தொடர்புடைய மின்னஞ்சல் முகவரியை உள்ளிடவும்.",
"form": {
"email": {
"label": "மின்னஞ்சல் முகவரி"
}
},
"heading": "உங்கள் கடவுச்சொல்லை மறந்து விட்டீர்களா?",
"help-text": "கணக்கு இருந்தால், உங்கள் கடவுச்சொல்லை மீட்டமைப்பதற்கான இணைப்புடன் மின்னஞ்சலைப் பெறுவீர்கள்."
},
"login": {
"actions": {
"login": "உள்நுழைய",
"google": "Google மூலம் உள்நுழைக"
},
"body": "உள்நுழைவதற்கும் அணுகுவதற்கும், உங்கள் பயோடேட்டாக்களை நிர்வகிப்பதற்கும் பகிரவும் உங்கள் கணக்குடன் தொடர்புடைய உங்கள் பயனர்பெயர் மற்றும் கடவுச்சொல்லை உள்ளிடவும்.",
"form": {
"password": {
"label": "கடவுச்சொல்"
},
"username": {
"help-text": "உங்கள் மின்னஞ்சல் முகவரியையும் உள்ளிடலாம்",
"label": "பயனர் பெயர்"
}
},
"heading": "உங்கள் கணக்கில் உள்நுழைக",
"recover-text": "உங்கள் கடவுச்சொல்லை மறந்துவிட்டால், இங்கே <1>உங்கள் கணக்கை மீட்டெடுக்கலாம்</1>.",
"register-text": "உங்களிடம் ஒன்று இல்லையென்றால், நீங்கள் இங்கே <1>ஒரு கணக்கை உருவாக்கலாம்</1>."
},
"register": {
"actions": {
"register": "பதிவு",
"google": "Google இல் பதிவு செய்யவும்"
},
"body": "கணக்கை உருவாக்க உங்கள் தனிப்பட்ட தகவலை உள்ளிடவும்.",
"form": {
"confirm-password": {
"label": "கடவுச்சொல்லை உறுதிப்படுத்தவும்"
},
"email": {
"label": "மின்னஞ்சல் முகவரி"
},
"name": {
"label": "முழு பெயர்"
},
"password": {
"label": "கடவுச்சொல்"
},
"username": {
"label": "பயனர் பெயர்"
}
},
"heading": "ஒரு கணக்கை உருவாக்க",
"loginText": "உங்களிடம் ஏற்கனவே கணக்கு இருந்தால், நீங்கள் <1>இங்கே உள்நுழையலாம்</1>."
},
"reset-password": {
"actions": {
"set-password": "புதிய கடவுச்சொல்லை அமை"
},
"body": "உங்கள் கணக்கிற்கான புதிய கடவுச்சொல்லை உள்ளிடவும்.",
"form": {
"confirm-password": {
"label": "கடவுச்சொல்லை உறுதிப்படுத்தவும்"
},
"password": {
"label": "கடவுச்சொல்"
}
},
"heading": "உங்கள் கடவுச்சொல்லை மீட்டமைக்க"
}
},
"dashboard": {
"create-resume": {
"actions": {
"create-resume": "ரெஸ்யூமை உருவாக்கவும்"
},
"body": "ஒரு பெயரைக் கொடுத்து உங்கள் விண்ணப்பத்தை உருவாக்கத் தொடங்குங்கள். இது நீங்கள் விண்ணப்பிக்கும் பாத்திரத்தை குறிப்பதாக இருக்கலாம் அல்லது உங்களுக்கு பிடித்த சிற்றுண்டியாக இருக்கலாம்.",
"form": {
"name": {
"label": "பெயர்"
},
"public": {
"label": "பொதுவில் அணுக முடியுமா?"
},
"slug": {
"label": "ஸ்லக்"
}
},
"heading": "புதிய விண்ணப்பத்தை உருவாக்கவும்"
},
"import-external": {
"heading": "வெளி மூலங்களிலிருந்து இறக்குமதி",
"json-resume": {
"actions": {
"upload-json": "JSON ஐப் பதிவேற்றவும்"
},
"body": "உங்களிடம் <1>சரிபார்க்கப்பட்ட JSON ரெஸ்யூம்</1> தயாராக இருந்தால், ரியாக்டிவ் ரெஸ்யூமில் உங்கள் மேம்பாட்டை விரைவாகக் கண்காணிக்க அதைப் பயன்படுத்தலாம். தொடங்குவதற்கு, கீழே உள்ள பொத்தானைக் கிளிக் செய்து சரியான JSON கோப்பைப் பதிவேற்றவும்.",
"heading": "JSON ரெஸ்யூமிலிருந்து இறக்குமதி செய்யவும்"
},
"linkedin": {
"actions": {
"upload-archive": "ZIP காப்பகத்தைப் பதிவேற்றவும்"
},
"body": "LinkedIn இலிருந்து உங்கள் தரவை ஏற்றுமதி செய்து, Reactive Resume இல் புலங்களைத் தானாக நிரப்புவதற்குப் பயன்படுத்துவதன் மூலம் நேரத்தைச் சேமிக்கலாம். LinkedIn இல் <1>தரவு தனியுரிமை</1> பகுதிக்குச் சென்று உங்கள் தரவைக் காப்பகமாகக் கோரவும். அது கிடைத்ததும், ஜிப் கோப்பை கீழே பதிவேற்றவும்.",
"heading": "LinkedIn இலிருந்து இறக்குமதி செய்யவும்"
},
"reactive-resume": {
"actions": {
"upload-json": "JSON ஐப் பதிவேற்றவும்"
},
"body": "Reactive Resume இன் தற்போதைய பதிப்பில் ஏற்றுமதி செய்யப்பட்ட JSON உங்களிடம் இருந்தால், திருத்தக்கூடிய பதிப்பை மீண்டும் பெற, அதை மீண்டும் இங்கு இறக்குமதி செய்யலாம். Reactive Resume இன் முந்தைய பதிப்புகள் துரதிருஷ்டவசமாக தற்போது ஆதரிக்கப்படவில்லை.",
"heading": "Reactive Resume லிருந்து இறக்குமதி செய்யவும்"
}
},
"rename-resume": {
"actions": {
"rename-resume": "ரெஸ்யூமை மறுபெயரிடவும்"
},
"form": {
"name": {
"label": "பெயர்"
},
"slug": {
"label": "ஸ்லக்"
}
},
"heading": "ரெஸ்யூமை மறுபெயரிடவும்"
}
}
}

View File

@ -0,0 +1,32 @@
{
"avatar": {
"menu": {
"greeting": "Xin chào",
"logout": "Đăng xuất"
}
},
"footer": {
"credit": "Một dự án làm với đam mê của <1> Amruth Pillai</1>",
"language": {
"missing": "Không có ngôn ngữ của bạn?"
},
"license": "Vì cộng đồng, cho cộng đồng."
},
"markdown": {
"help-text": "Phần này hỗ trợ định dạng <1> markdown </1>."
},
"date": {
"present": "Hiện tại"
},
"subtitle": "Một trình tạo sơ yếu lý lịch mã nguồn mở và miễn phí.",
"title": "Reactive Resume",
"toast": {
"error": {
"upload-file-size": "Vui lòng chỉ tải lên các tệp dưới 2 megabyte.",
"upload-photo-size": "Vui lòng chỉ tải lên ảnh dưới 2 megabyte, ưu tiên hình vuông."
},
"success": {
"resume-link-copied": "Một liên kết đến sơ yếu lý lịch của bạn đã được sao chép vào khay nhớ tạm của bạn."
}
}
}

View File

@ -0,0 +1,358 @@
{
"common": {
"actions": {
"add": "添加新的 {{token}}",
"delete": "删除 {{token}}",
"edit": "编辑 {{token}}"
},
"columns": {
"heading": "分栏",
"tooltip": "更改栏数"
},
"form": {
"date": {
"label": "日期"
},
"description": {
"label": "描述"
},
"email": {
"label": "Email 地址"
},
"end-date": {
"help-text": "如果仍然存在,请将此栏留空",
"label": "结束日期"
},
"keywords": {
"label": "关键字"
},
"level": {
"label": "等级"
},
"levelNum": {
"label": "等级 (数字)"
},
"name": {
"label": "名称"
},
"phone": {
"label": "电话号码"
},
"position": {
"label": "职务"
},
"start-date": {
"label": "开始日期"
},
"subtitle": {
"label": "副标题"
},
"summary": {
"label": "概要"
},
"title": {
"label": "标题"
},
"url": {
"label": "网站"
}
},
"glossary": {
"page": "页"
},
"list": {
"actions": {
"delete": "删除",
"duplicate": "创建副本",
"edit": "编辑"
},
"empty-text": "列表为空"
},
"tooltip": {
"delete-item": "您确定要删除此条数据吗? 此操作无法撤消。",
"delete-section": "删除章节",
"rename-section": "重命名章节",
"toggle-visibility": "切换显示/隐藏"
}
},
"controller": {
"tooltip": {
"center-artboard": "中心画板",
"copy-link": "复制链接地址",
"export-pdf": "输出为PDF",
"toggle-orientation": "切换页面方向",
"toggle-page-break-line": "切换分页线",
"toggle-sidebars": "显示/隐藏侧边栏",
"zoom-in": "放大",
"zoom-out": "缩小"
}
},
"header": {
"menu": {
"delete": "删除",
"duplicate": "创建副本",
"rename": "重命名",
"share-link": "分享链接",
"tooltips": {
"delete": "您确定要删除该简历吗?该操作不可撤销。",
"share-link": "您需要将简历的可见性更改为公开,以使其对其他人可见。"
}
}
},
"leftSidebar": {
"sections": {
"awards": {
"form": {
"awarder": {
"label": "获奖纪录"
}
}
},
"basics": {
"actions": {
"photo-filters": "照片滤镜"
},
"heading": "概况",
"headline": {
"label": "标题"
},
"name": {
"label": "全名"
},
"photo-filters": {
"effects": {
"border": {
"label": "边框"
},
"grayscale": {
"label": "灰度"
},
"heading": "特效"
},
"shape": {
"heading": "形状"
},
"size": {
"heading": "尺寸单位Px"
}
},
"photo-upload": {
"tooltip": {
"remove": "移除照片",
"upload": "上传照片"
}
}
},
"certifications": {
"form": {
"issuer": {
"label": "颁布方"
}
}
},
"education": {
"form": {
"area-study": {
"label": "专业"
},
"courses": {
"label": "课程"
},
"degree": {
"label": "学位"
},
"grade": {
"label": "年级"
},
"institution": {
"label": "机构"
}
}
},
"location": {
"address": {
"label": "地址"
},
"city": {
"label": "城市"
},
"country": {
"label": "国家"
},
"heading": "地点",
"postal-code": {
"label": "邮编"
},
"region": {
"label": "地区"
}
},
"profiles": {
"form": {
"network": {
"label": "网络"
},
"username": {
"label": "用户名"
}
},
"heading": "简介",
"heading_one": "简介"
},
"publications": {
"form": {
"publisher": {
"label": "发行机构"
}
}
},
"references": {
"form": {
"relationship": {
"label": "关系"
}
}
},
"section": {
"heading": "分区"
},
"volunteer": {
"form": {
"organization": {
"label": "组织"
}
}
}
}
},
"rightSidebar": {
"sections": {
"css": {
"heading": "自定义 CSS"
},
"export": {
"heading": "导出",
"json": {
"primary": "JSON",
"secondary": "下载一个JSON版本的简历可以导入到Reactive Resume中。"
},
"pdf": {
"loading": {
"primary": "正在生成 PDF",
"secondary": "请等待您的 PDF 生成,这可能需要 15 秒。"
},
"normal": {
"primary": "PDF",
"secondary": "下载您的简历 PDF您可以将其打印并发送给您期待的职位。此文件无法重新导入以进行进一步编辑。"
}
}
},
"layout": {
"heading": "布局",
"tooltip": {
"reset-layout": "重置布局"
}
},
"links": {
"bugs-features": {
"body": "是什么阻止了你制作简历?或者你有什么好主意要补充?在 GitHub 上提出问题以开始使用。",
"button": "GitHub Issues",
"heading": "发现了Bug? 想要新的功能?"
},
"donate": {
"body": "如果你喜欢使用Reactive Resume 请考虑捐款以便保持应用正常运行,没有广告和永远免费。",
"button": "送我一杯咖啡",
"heading": "捐赠给 Reactive Resume"
},
"github": "源码",
"heading": "链接"
},
"settings": {
"global": {
"date": {
"primary": "日期",
"secondary": "整个应用程序使用的日期格式"
},
"heading": "全局",
"language": {
"primary": "语言",
"secondary": "显示要在整个应用程序中使用的语言"
},
"theme": {
"primary": "主题"
}
},
"heading": "设置",
"page": {
"break-line": {
"primary": "换行",
"secondary": "在所有页面上显示一条线以标记 A4 页面的高度"
},
"heading": "页面",
"orientation": {
"disabled": "当只有一个页面时没有效果",
"primary": "方向",
"secondary": "水平或者垂直翻转图像"
}
},
"resume": {
"heading": "简历",
"reset": {
"primary": "全部重置",
"secondary": "犯了太多错误?单击此处重置所有更改并从头开始。小心,这个动作不能逆转。"
},
"sample": {
"primary": "加载样本数据",
"secondary": "不知道从哪里开始?单击此处加载一些示例数据,以查看完整简历的外观。"
}
}
},
"sharing": {
"heading": "分享",
"short-url": {
"label": "倾向于短网址"
},
"visibility": {
"subtitle": "允许任何有链接的人查看你的简历",
"title": "公开"
}
},
"templates": {
"heading": "模板"
},
"theme": {
"form": {
"background": {
"label": "背景"
},
"primary": {
"label": "主要"
},
"text": {
"label": "文本"
}
},
"heading": "主题"
},
"typography": {
"form": {
"font-family": {
"label": "字体"
},
"font-size": {
"label": "字号"
}
},
"heading": "排版",
"widgets": {
"body": {
"label": "正文内容"
},
"headings": {
"label": "标题"
}
}
}
}
}
}

View File

@ -0,0 +1,32 @@
{
"avatar": {
"menu": {
"greeting": "您好",
"logout": "退出"
}
},
"footer": {
"credit": "一个由<1>Amruth Pillai</1>开发的项目",
"language": {
"missing": "缺少您的语言?"
},
"license": "由社区驱动。"
},
"markdown": {
"help-text": "本节支持<1>markdown</1>格式化。"
},
"date": {
"present": "至今"
},
"subtitle": "一个免费开源的简历生成器。",
"title": "Reactive Resume",
"toast": {
"error": {
"upload-file-size": "请上传 2M 以下的文件。",
"upload-photo-size": "请上传 2MB 以下的照片,最好是正方形的。"
},
"success": {
"resume-link-copied": "源码的链接已复制到你的剪贴板。"
}
}
}

View File

@ -0,0 +1,25 @@
{
"create-resume": {
"subtitle": "从头创作",
"title": "创建简历"
},
"import-external": {
"subtitle": "LinkedIn, JSON 简历, Reactive Resume",
"title": "从外部导入"
},
"resume": {
"menu": {
"delete": "删除",
"duplicate": "创建副本",
"open": "打开",
"rename": "重命名",
"share-link": "分享链接",
"tooltips": {
"delete": "您确定要删除该简历吗?该操作不可撤销。",
"share-link": "您需要将简历的可见性更改为公开,以使其对其他人可见。"
}
},
"timestamp": "最近更新于 {{timestamp}}"
},
"title": "仪表盘"
}

View File

@ -0,0 +1,41 @@
{
"actions": {
"app": "前往应用",
"login": "登录",
"logout": "注销",
"register": "注册"
},
"features": {
"heading": "功能介绍",
"list": {
"ads": "无广告",
"export": "将您的简历导出为 JSON 或 PDF 格式",
"free": "永久免费",
"import": "从 LinkedIn JSON 简历导入数据",
"languages": "支持多种语言",
"more": "还有更多令人兴奋的功能,<1>在此处阅读所有相关信息</1>",
"tracking": "没有用户跟踪"
}
},
"links": {
"heading": "链接",
"links": {
"donate": "捐赠",
"github": "源码",
"privacy": "隐私政策",
"service": "服务条款"
}
},
"screenshots": {
"heading": "截屏"
},
"testimonials": {
"heading": "用户评价",
"body": "无论好坏,我很想听听您对 Reactive Resume 的看法以及您的体验如何。<br/>以下是世界各地用户发送的一些消息。",
"contact": "你可以通过<1>我的电子邮件</1>或通过<3>我的网站</3>上的联系表格与我联系。"
},
"summary": {
"body": "Reactive Resume 是一个免费和开源的简历生成器,旨在使创建、更新和共享简历的日常任务变得像 1、2、3 一样简单。使用此应用程序,您可以创建多份简历,与招聘人员或朋友分享通过一个独特的链接并将其打印为 PDF全部免费无广告无跟踪不会丢失您数据的完整性和隐私性。",
"heading": "概要"
}
}

View File

@ -0,0 +1,135 @@
{
"auth": {
"forgot-password": {
"actions": {
"send-email": "发送重置密码电子邮件"
},
"body": "只需输入与您要恢复的帐户关联的电子邮件地址。",
"form": {
"email": {
"label": "Email 地址"
}
},
"heading": "找回密码",
"help-text": "请输入您的电子邮件地址。 您将收到一封电子邮件的链接重置您的密码。"
},
"login": {
"actions": {
"login": "登录",
"google": "使用 Google 帐号登录"
},
"body": "请输入与您的帐户关联的用户名和密码,以登录和访问、管理和分享您的简历。",
"form": {
"password": {
"label": "密码"
},
"username": {
"help-text": "请输入您的电子邮箱地址",
"label": "用户名"
}
},
"heading": "登录您的账号",
"recover-text": "如果您忘记了密码,您可以<1>恢复您的帐户</1>这里。",
"register-text": "如果您没有,您可以<1>创建一个帐户</1>这里。"
},
"register": {
"actions": {
"register": "注册",
"google": "用Google注册"
},
"body": "输入您的邮箱地址并创建一个帐户",
"form": {
"confirm-password": {
"label": "确认密码"
},
"email": {
"label": "邮箱"
},
"name": {
"label": "全名"
},
"password": {
"label": "密码"
},
"username": {
"label": "用户名"
}
},
"heading": "创建一个帐户",
"loginText": "如果您已经有一个帐户,您可以<1>在此处登录</1>."
},
"reset-password": {
"actions": {
"set-password": "设置新的密码"
},
"body": "为账户设置新密码",
"form": {
"confirm-password": {
"label": "确认密码"
},
"password": {
"label": "密码"
}
},
"heading": "重置密码"
}
},
"dashboard": {
"create-resume": {
"actions": {
"create-resume": "创建简历"
},
"body": "开始建立你的简历时,要给它起个名字。它可以是指你所申请的角色,或者只是你最喜欢的零食。",
"form": {
"name": {
"label": "名称"
},
"public": {
"label": "是否可以公开访问?"
},
"slug": {
"label": "缩写"
}
},
"heading": "创建简历"
},
"import-external": {
"heading": "从外部导入",
"json-resume": {
"actions": {
"upload-json": "上传 JSON"
},
"body": "如果您有 <1> 已验证的 JSON 简历</1>准备好了,您可以使用它来快速跟踪您在 Reactive Resume 上的开发。单击下面的按钮并上传有效的 JSON 文件以开始。",
"heading": "从 JSON 简历导入"
},
"linkedin": {
"actions": {
"upload-archive": "上传ZIP压缩包"
},
"body": "您可以通过从 LinkedIn 导出数据并使用它来自动填写 Reactive Resume 上的字段来节省时间。前往<1>数据隐私</1>LinkedIn 上的部分并请求存档您的数据。一旦可用,请上传下面的 ZIP 文件。",
"heading": "从 LinkedIn 导入"
},
"reactive-resume": {
"actions": {
"upload-json": "上传 JSON"
},
"body": "如果您有一个使用当前版本的 Reactive Resume 导出的 JSON您可以在此处将其导入回来以再次获得可编辑的版本。遗憾的是目前不支持以前版本的 Reactive Resume。",
"heading": "从 Reactive Resume 导入"
}
},
"rename-resume": {
"actions": {
"rename-resume": "重命名简历"
},
"form": {
"name": {
"label": "名称"
},
"slug": {
"label": "缩写"
}
},
"heading": "重命名你的简历"
}
}
}

9
client/public/robots.txt Normal file
View File

@ -0,0 +1,9 @@
# *
User-agent: *
Allow: /
# Host
Host: https://rxresu.me
# Sitemaps
Sitemap: https://rxresu.me/sitemap.xml

View File

@ -0,0 +1,23 @@
<?xml version="1.0" encoding="UTF-8"?>
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9" xmlns:news="http://www.google.com/schemas/sitemap-news/0.9" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:mobile="http://www.google.com/schemas/sitemap-mobile/1.0" xmlns:image="http://www.google.com/schemas/sitemap-image/1.1" xmlns:video="http://www.google.com/schemas/sitemap-video/1.1">
<url><loc>https://rxresu.me</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/dashboard</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/meta/privacy</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/meta/service</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/bn/dashboard</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/de/dashboard</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/es/dashboard</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/fr/dashboard</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/hi/dashboard</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/it/dashboard</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/kn/dashboard</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/ta/dashboard</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/bn</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/de</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/es</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/fr</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/hi</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/it</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/kn</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
<url><loc>https://rxresu.me/ta</loc><changefreq>monthly</changefreq><priority>0.7</priority><lastmod>2022-03-14T08:00:09.072Z</lastmod></url>
</urlset>

View File

@ -0,0 +1,4 @@
<?xml version="1.0" encoding="UTF-8"?>
<sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
<sitemap><loc>https://rxresu.me/sitemap-0.xml</loc></sitemap>
</sitemapindex>

View File

@ -14,7 +14,7 @@ import {
setResumeState,
} from '../resume/resumeSlice';
const DEBOUNCE_WAIT = 2500;
const DEBOUNCE_WAIT = 1000;
const debouncedSync = debounce((resume: Resume) => updateResume(resume), DEBOUNCE_WAIT);

View File

@ -1,5 +1,5 @@
import { Email, Link, Phone } from '@mui/icons-material';
import { ListItem, Section } from '@reactive-resume/schema';
import { ListItem, Section as SectionType } from '@reactive-resume/schema';
import get from 'lodash/get';
import isArray from 'lodash/isArray';
import isEmpty from 'lodash/isEmpty';
@ -20,7 +20,7 @@ const Section: React.FC<SectionProps> = ({
headlinePath = 'headline',
keywordsPath = 'keywords',
}) => {
const section: Section = useAppSelector((state) => get(state.resume, path, {}));
const section: SectionType = useAppSelector((state) => get(state.resume, path, {}));
const dateFormat: string = useAppSelector((state) => get(state.resume, 'metadata.date.format'));
if (!section.visible) return null;
@ -91,13 +91,7 @@ const Section: React.FC<SectionProps> = ({
</DataDisplay>
)}
{keywords && (
<div className="leading-normal">
<span className="font-semibold">Keywords:</span>
&nbsp;
{keywords.join(', ')}
</div>
)}
{keywords && <div>{keywords.join(', ')}</div>}
{(phone || email) && (
<div className="grid gap-1">

View File

@ -1,5 +1,7 @@
import { css } from '@emotion/css';
import { alpha } from '@mui/material';
import { Theme } from '@reactive-resume/schema';
import clsx from 'clsx';
import get from 'lodash/get';
import { useMemo } from 'react';
@ -19,12 +21,16 @@ const Gengar: React.FC<PageProps> = ({ page }) => {
const theme: Theme = useAppSelector((state) => get(state.resume, 'metadata.theme', {}));
const contrast = useMemo(() => getContrastColor(theme.primary), [theme.primary]);
const backgroundColor: string = useMemo(() => alpha(theme.primary, 0.15), [theme.primary]);
const color = useMemo(() => (contrast === 'dark' ? theme.text : theme.background), [theme, contrast]);
return (
<div className={styles.page}>
<div className={styles.container}>
<div className={styles.sidebar}>
<div style={{ color: contrast === 'dark' ? theme.text : theme.background, backgroundColor: theme.primary }}>
<div
className={clsx(css(`svg { color: ${color} } --primary-color: ${color}`))}
style={{ color: contrast === 'dark' ? theme.text : theme.background, backgroundColor: theme.primary }}
>
{isFirstPage && <MastheadSidebar />}
</div>

View File

@ -1,5 +1,5 @@
import { Email, Link, Phone } from '@mui/icons-material';
import { ListItem, Section } from '@reactive-resume/schema';
import { ListItem, Section as SectionType } from '@reactive-resume/schema';
import get from 'lodash/get';
import isArray from 'lodash/isArray';
import isEmpty from 'lodash/isEmpty';
@ -20,7 +20,7 @@ const Section: React.FC<SectionProps> = ({
headlinePath = 'headline',
keywordsPath = 'keywords',
}) => {
const section: Section = useAppSelector((state) => get(state.resume, path, {}));
const section: SectionType = useAppSelector((state) => get(state.resume, path, {}));
const dateFormat: string = useAppSelector((state) => get(state.resume, 'metadata.date.format'));
const primaryColor: string = useAppSelector((state) => get(state.resume, 'metadata.theme.primary'));
@ -92,13 +92,7 @@ const Section: React.FC<SectionProps> = ({
</DataDisplay>
)}
{keywords && (
<div className="leading-normal">
<span className="font-semibold">Keywords:</span>
&nbsp;
{keywords.join(', ')}
</div>
)}
{keywords && <div>{keywords.join(', ')}</div>}
{(phone || email) && (
<div className="grid gap-1">

View File

@ -1,5 +1,5 @@
import { Email, Link, Phone } from '@mui/icons-material';
import { ListItem, Section } from '@reactive-resume/schema';
import { ListItem, Section as SectionType } from '@reactive-resume/schema';
import get from 'lodash/get';
import isArray from 'lodash/isArray';
import isEmpty from 'lodash/isEmpty';
@ -21,7 +21,7 @@ const Section: React.FC<SectionProps> = ({
headlinePath = 'headline',
keywordsPath = 'keywords',
}) => {
const section: Section = useAppSelector((state) => get(state.resume, path, {}));
const section: SectionType = useAppSelector((state) => get(state.resume, path, {}));
const dateFormat: string = useAppSelector((state) => get(state.resume, 'metadata.date.format'));
const primaryColor: string = useAppSelector((state) => get(state.resume, 'metadata.theme.primary'));

View File

@ -1,5 +1,5 @@
import { Email, Phone } from '@mui/icons-material';
import { ListItem, Section } from '@reactive-resume/schema';
import { ListItem, Section as SectionType } from '@reactive-resume/schema';
import get from 'lodash/get';
import isArray from 'lodash/isArray';
import isEmpty from 'lodash/isEmpty';
@ -20,7 +20,7 @@ const Section: React.FC<SectionProps> = ({
headlinePath = 'headline',
keywordsPath = 'keywords',
}) => {
const section: Section = useAppSelector((state) => get(state.resume, path, {}));
const section: SectionType = useAppSelector((state) => get(state.resume, path, {}));
const dateFormat: string = useAppSelector((state) => get(state.resume, 'metadata.date.format'));
const primaryColor: string = useAppSelector((state) => get(state.resume, 'metadata.theme.primary'));

View File

@ -1,5 +1,5 @@
import { Email, Link, Phone } from '@mui/icons-material';
import { ListItem, Section } from '@reactive-resume/schema';
import { ListItem, Section as SectionType } from '@reactive-resume/schema';
import get from 'lodash/get';
import isArray from 'lodash/isArray';
import isEmpty from 'lodash/isEmpty';
@ -20,7 +20,7 @@ const Section: React.FC<SectionProps> = ({
headlinePath = 'headline',
keywordsPath = 'keywords',
}) => {
const section: Section = useAppSelector((state) => get(state.resume, path, {}));
const section: SectionType = useAppSelector((state) => get(state.resume, path, {}));
const dateFormat: string = useAppSelector((state) => get(state.resume, 'metadata.date.format'));
const primaryColor: string = useAppSelector((state) => get(state.resume, 'metadata.theme.primary'));
@ -92,13 +92,7 @@ const Section: React.FC<SectionProps> = ({
</DataDisplay>
)}
{keywords && (
<div>
<span className="font-semibold">Keywords:</span>
&nbsp;
{keywords.join(', ')}
</div>
)}
{keywords && <div>{keywords.join(', ')}</div>}
{(phone || email) && (
<div className="grid gap-1">

View File

@ -1,5 +1,5 @@
import { Email, Link, Phone } from '@mui/icons-material';
import { ListItem, Section } from '@reactive-resume/schema';
import { ListItem, Section as SectionType } from '@reactive-resume/schema';
import get from 'lodash/get';
import isArray from 'lodash/isArray';
import isEmpty from 'lodash/isEmpty';
@ -20,7 +20,7 @@ const Section: React.FC<SectionProps> = ({
headlinePath = 'headline',
keywordsPath = 'keywords',
}) => {
const section: Section = useAppSelector((state) => get(state.resume, path, {}));
const section: SectionType = useAppSelector((state) => get(state.resume, path, {}));
const dateFormat: string = useAppSelector((state) => get(state.resume, 'metadata.date.format'));
const primaryColor: string = useAppSelector((state) => get(state.resume, 'metadata.theme.primary'));
@ -84,13 +84,7 @@ const Section: React.FC<SectionProps> = ({
</DataDisplay>
)}
{keywords && (
<div className="leading-normal">
<span className="font-semibold">Keywords:</span>
&nbsp;
{keywords.join(', ')}
</div>
)}
{keywords && <div>{keywords.join(', ')}</div>}
{(phone || email) && (
<div className="grid gap-1">

View File

@ -2,6 +2,7 @@ import { DateRange } from '@reactive-resume/schema';
import dayjs from 'dayjs';
import isEmpty from 'lodash/isEmpty';
import isString from 'lodash/isString';
import { i18n } from 'next-i18next';
export const dateFormatOptions: string[] = [
'MMMM DD, YYYY',
@ -14,12 +15,15 @@ export const dateFormatOptions: string[] = [
'YYYY/MM/DD',
'MMMM YYYY',
'MMM YYYY',
'MM/YYYY',
'YYYY',
];
export const getRelativeTime = (timestamp: dayjs.ConfigType): string => dayjs(timestamp).toNow(true);
export const formatDateString = (date: string | DateRange, formatStr: string): string | null => {
const presentString = i18n?.t('common.date.present') ?? '';
if (isEmpty(date)) return null;
// If `date` is a string
@ -38,5 +42,5 @@ export const formatDateString = (date: string | DateRange, formatStr: string): s
return `${dayjs(date.start).format(formatStr)} - ${dayjs(date.end).format(formatStr)}`;
}
return dayjs(date.start).format(formatStr);
return `${dayjs(date.start).format(formatStr)} - ${presentString}`;
};

View File

@ -43,7 +43,7 @@ type Separator = ', ' | ' / ' | ' | ';
export const parseListItemPath = (item: ListItem, path: string | string[], separator: Separator = ', '): string => {
if (isArray(path)) {
const value = path.map((_path) => get(item, _path));
const value = path.map((_path) => get(item, _path)).filter((x) => x);
return value.join(separator);
} else {

View File

@ -10,7 +10,16 @@ const DateWrapper: React.FC = ({ children }) => {
dayjs.extend(relativeTime);
// Locales
require('dayjs/locale/bn');
require('dayjs/locale/de');
require('dayjs/locale/en');
require('dayjs/locale/es');
require('dayjs/locale/fr');
require('dayjs/locale/hi');
require('dayjs/locale/it');
require('dayjs/locale/kn');
require('dayjs/locale/ta');
require('dayjs/locale/zh');
locale && dayjs.locale(locale);
}, [locale]);

64
docker-compose.dev.yml Normal file
View File

@ -0,0 +1,64 @@
version: '3'
services:
postgres:
image: postgres
container_name: postgres
ports:
- 5432:5432
env_file: .env
volumes:
- ./scripts/database/initialize.sql:/docker-entrypoint-initdb.d/initialize.sql
- pgdata:/var/lib/postgresql/data
traefik:
image: traefik
container_name: traefik
command:
- --providers.docker=true
- --providers.docker.exposedbydefault=false
- --entrypoints.web.address=:80
ports:
- 80:80
volumes:
- /var/run/docker.sock:/var/run/docker.sock:ro
server:
build:
context: .
dockerfile: server/Dockerfile
container_name: server
env_file: .env
environment:
- PUBLIC_URL=http://localhost
- POSTGRES_HOST=postgres
- POSTGRES_DATABASE=reactive_resume
depends_on:
- traefik
- postgres
labels:
- traefik.enable=true
- traefik.http.routers.server.entrypoints=web
- traefik.http.routers.server.rule=Host(`localhost`) && PathPrefix(`/api/`)
- traefik.http.routers.server.middlewares=server-stripprefix
- traefik.http.middlewares.server-stripprefix.stripprefix.prefixes=/api
- traefik.http.middlewares.server-stripprefix.stripprefix.forceslash=true
client:
build:
context: .
dockerfile: client/Dockerfile
container_name: client
env_file: .env
environment:
- PUBLIC_SERVER_URL=http://localhost/api
depends_on:
- traefik
- server
labels:
- traefik.enable=true
- traefik.http.routers.client.rule=Host(`localhost`)
- traefik.http.routers.client.entrypoints=web
volumes:
pgdata:

View File

@ -8,43 +8,51 @@ services:
- 5432:5432
env_file: .env
volumes:
- ./scripts/database/initialize.sql:/docker-entrypoint-initdb.d/initialize.sql
- pgdata:/var/lib/postgresql/data
server:
# Production
# image: amruthpillai/reactive-resume:server-latest
traefik:
image: traefik
container_name: traefik
command:
- --providers.docker=true
- --providers.docker.exposedbydefault=false
- --entrypoints.web.address=:80
ports:
- 80:80
volumes:
- /var/run/docker.sock:/var/run/docker.sock:ro
# Development
build:
context: .
dockerfile: server/Dockerfile
server:
image: amruthpillai/reactive-resume:server-latest
container_name: server
env_file: .env
environment:
- PUBLIC_URL=http://client:3000
- PUBLIC_URL=http://<SERVER-IP>
- POSTGRES_HOST=postgres
ports:
- 3100:3100
depends_on:
- traefik
- postgres
labels:
- traefik.enable=true
- traefik.http.routers.server.entrypoints=web
- traefik.http.routers.server.rule=Host(`<SERVER-IP>`) && PathPrefix(`/api/`)
- traefik.http.routers.server.middlewares=server-stripprefix
- traefik.http.middlewares.server-stripprefix.stripprefix.prefixes=/api
- traefik.http.middlewares.server-stripprefix.stripprefix.forceslash=true
client:
# Production
# image: amruthpillai/reactive-resume:client-latest
# Development
build:
context: .
dockerfile: client/Dockerfile
image: amruthpillai/reactive-resume:client-latest
container_name: client
env_file: .env
environment:
- PUBLIC_SERVER_URL=http://server:3100
ports:
- 3000:3000
- PUBLIC_SERVER_URL=http://<SERVER-IP>/api
depends_on:
- traefik
- server
labels:
- traefik.enable=true
- traefik.http.routers.client.rule=Host(`<SERVER-IP>`)
- traefik.http.routers.client.entrypoints=web
volumes:
pgdata:

4
docs/.eslintrc.json Normal file
View File

@ -0,0 +1,4 @@
{
"extends": "../.eslintrc.json",
"ignorePatterns": ["build", ".docusaurus"]
}

20
docs/.gitignore vendored Normal file
View File

@ -0,0 +1,20 @@
# Dependencies
/node_modules
# Production
/build
# Generated files
.docusaurus
.cache-loader
# Misc
.DS_Store
.env.local
.env.development.local
.env.test.local
.env.production.local
npm-debug.log*
yarn-debug.log*
yarn-error.log*

3
docs/babel.config.js Normal file
View File

@ -0,0 +1,3 @@
module.exports = {
presets: [require.resolve('@docusaurus/core/lib/babel/preset')],
};

View File

@ -0,0 +1,2 @@
position: 4
label: Deployment

View File

@ -0,0 +1,5 @@
---
sidebar_position: 4
---
# Deployment

75
docs/docs/index.mdx Normal file
View File

@ -0,0 +1,75 @@
---
sidebar_position: 1
sidebar_label: Introduction
title: Introduction
---
import TOCInline from '@theme/TOCInline';
# Reactive Resume
![Project Version](https://img.shields.io/github/package-json/v/AmruthPillai/Reactive-Resume?style=flat-square)
![Project License](https://img.shields.io/github/license/AmruthPillai/Reactive-Resume?style=flat-square)
[![Crowdin](https://badges.crowdin.net/reactive-resume/localized.svg)](https://translate.rxresu.me)
[![Docker Pulls](https://img.shields.io/docker/pulls/amruthpillai/reactive-resume?style=flat-square)](https://hub.docker.com/r/amruthpillai/reactive-resume)
[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2FAmruthPillai%2FReactive-Resume.svg?type=shield)](https://app.fossa.com/projects/git%2Bgithub.com%2FAmruthPillai%2FReactive-Resume?ref=badge_shield)
## [Go to App](https://rxresu.me) | [Docs](https://docs.rxresu.me)
## Summary
Reactive Resume is a free and open source resume builder that's built to make the mundane tasks of creating, updating and sharing your resume as easy as 1, 2, 3. With this app, you can create multiple resumes, share them with recruiters through a unique link and print as PDF, all for free, no advertisements, without losing the integrity and privacy of your data.
You have complete control over what goes into your resume, how it looks, what colors, what templates, even the layout in which sections placed. Want a dark mode resume? It's as easy as editing 3 values and you're done. You don't need to wait to see your changes either. Everything you type, everything you change, appears immediately on your resume and gets updated in real time.
## Features
- Free, forever
- No Advertising
- No User Tracking
- Sync your data across devices
- Import data from [LinkedIn](https://www.linkedin.com/), [JSON Resume](https://jsonresume.org/)
- Manage multiple resumes with one account
- Open Source (with large community support)
- Send your resume to others with a unique sharable link
- Accessible in multiple languages, [help translate here](https://translate.rxresu.me/)
- Pick any font from [Google Fonts](https://fonts.google.com/) to use on your resume
- Choose from 6 vibrant templates and more coming soon
- Export your resume to JSON or PDF format with just one click
- Create an account using your email, or just Sign in with Google
- Mix and match colors to any degree, even a dark mode resume?
- Add sections, add pages and change layouts the way you want to
- Tailor-made Backend and Database, isolated from Google, Amazon etc.
- **Oh, and did I mention that it's free?**
## Languages
- Bengali (বাংলা)
- Chinese (中文)
- English
- French (Français)
- German (Deutsch)
- Hindi (हिन्दी)
- Italian (Italiano)
- Kannada (ಕನ್ನಡ)
- Spanish (Español)
- Tamil (தமிழ்)
Help by [translating Reactive Resume](https://translate.rxresu.me) to your language!
## Report Issues
Use the [GitHub Issues](https://github.com/AmruthPillai/Reactive-Resume/issues/new/choose) platform to notify me about bugs or new features that you would like to see in Reactive Resume. Please check before creating new issues as there might already be one.
## Donations
Reactive Resume would be nothing without the folks who supported me and kept the project alive in the beginning, and your cotinued support is what keeps me going. If you found Reactive Resume to be useful, helpful or just insightful and appreciate the effort I took to make the project, please consider donating as little or as much as your can.
#### [☕️ Buy me a coffee](https://www.buymeacoffee.com/AmruthPillai) | [💸 PayPal](https://paypal.me/RajaRajanA)
## License
Reactive Resume is packaged and distributed using the [MIT License](https://choosealicense.com/licenses/mit/) which allows for commercial use, distribution, modification and private use provided that all copies of the software contain the same license and copyright.
_By the community, for the community._
A passion project by [Amruth Pillai](https://amruthpillai.com/)

View File

@ -0,0 +1,2 @@
position: 3
label: Source Code

View File

@ -0,0 +1,38 @@
---
sidebar_position: 1
---
# Docker
This is probably the easiest method to build the source code on your machine if you already have Docker and Docker Compose installed. If you don't have Docker on your machine, I'll let you figure that out on your own.
1. Once you have Docker set up, you can pull the source code from GitHub and dive into the repository.
```bash
git clone git@github.com:AmruthPillai/Reactive-Resume.git
cd Reactive-Resume
```
2. Install dependencies using [pnpm](https://pnpm.io/), but feel free to use any other package manager that supports [npm workspaces](https://docs.npmjs.com/cli/v8/using-npm/workspaces).
```bash
pnpm install
```
3. Copy the `.env.example` file to `.env` in the project root and fill it with values according to your setup. To know which environment variables are required, and about what they do, head over [this section](env-vars).
```bash
cp .env.example .env
```
4. Use Docker Compose to create a PostgreSQL instance and a `reactive_resume` database, or feel free to use your own and modify the variables used in `.env`
```bash
docker-compose up -d postgres
```
5. Run the project and start building!
```bash
pnpm dev
```

View File

@ -0,0 +1,163 @@
---
sidebar_position: 3
---
import TOCInline from '@theme/TOCInline';
# Environment Variables
The project source code requires certain envrionment variables to be pre-set in order to work as expected. You can get a copy of what the `.env` file should look like from the `.env.example` file in the root of the project's [source code](https://github.com/AmruthPillai/Reactive-Resume/blob/main/.env.example).
Here, I'll be explaining what each of the environment variables are for, and which ones are actually **required** and which ones aren't.
### Sections
<TOCInline toc={toc} minHeadingLevel="2" maxHeadingLevel="2" />
## App
### `TZ`
**Required**: `no`
**Default Value:** `UTC`
**Description:** Server Timezone
This field is just to indicate the timezone that the server should follow. This is just so that the date time information should be unified and all timestamps should follow the same suit.
### `SECRET_KEY`
**Required**: `yes`
**Description:** Secret Key for Client-Server Communication
The secret key can be a unique key, a randomly generated string that is used for client-server communication. You can use this [random.org](https://www.random.org/strings/?num=10&len=20&digits=on&upperalpha=on&loweralpha=on&unique=on&format=html&rnd=new) configuration to generate a long unique string.
## URLs
### `PUBLIC_URL`
**Required**: `yes`
**Description:** URL through which app is accessible
**Default Value:** `http://localhost:3000`
This URL would be used in features like link sharing functionality and authentication redirection. This points only to the client app, as the server would be running on `PORT 3100` always.
### `PUBLIC_SERVER_URL`
**Required**: `yes`
**Description:** URL through which server is accessible
**Default Value:** `http://localhost:3100`
This URL is used when export PDF functionality is used within the app and has to reach out to the server.
## Database
### `POSTGRES_HOST`
**Required**: `yes`
**Default Value:** `localhost`
**Description:** Hostname for the PostgreSQL Server
### `POSTGRES_PORT`
**Required**: `yes`
**Default Value:** `5432`
**Description:** Port of the PostgreSQL Server
### `POSTGRES_USERNAME`
**Required**: `yes`
**Default Value:** `postgres`
**Description:** Username of the PostgreSQL Server
### `POSTGRES_PASSWORD`
**Required**: `yes`
**Default Value:** `postgres`
**Description:** Password of the PostgreSQL Server
### `POSTGRES_DATABASE`
**Required**: `yes`
**Default Value:** `reactive_resume`
**Description:** Name of the Database in PostgreSQL Server
### `POSTGRES_SSL_CERT`
**Required**: `no`
**Description:** Base64 Encoded String of the SSL CA Certificate
Some production-grade managed databases require the need to pass a CA certificate along with the options. You can encode the contents of the `.crt` file sent to you by your cloud provider in _Base64_ and provide it as a environment variable.
## Authentication
### `JWT_SECRET`
**Required**: `yes`
**Description:** Secret to Sign and Extract JWT Payloads
Similar to the `SECRET_KEY`, this can also be a unique generated string. This is used for email/password authentication, to hash + salt passwords stored in the database so they are unreadable.
### `JWT_EXPIRY_TIME`
**Required**: `yes`
**Default Value:** `604800`
**Description:** How long should the JWT be valid for?
This value, in milliseconds, denotes the validity of the JWT token. A shorter value would make the user have to login more frequently.
## Google
As much as I'd like to keep Google out of the picture, they do provide a few services that are actually useful. Namely, Google OAuth (for Login with Google) and Google Fonts (to list all fonts and use them on a resume).
### `PUBLIC_GOOGLE_CLIENT_ID`
**Required**: `no`
**Description:** Google Client ID for Google Login
This field is only required if the Google Login functionality is important to you.
### `GOOGLE_CLIENT_SECRET`
**Required**: `no`
**Description:** Google Client Secret for Google Login
This field is only required if the Google Login functionality is important to you.
### `GOOGLE_API_KEY`
**Required**: `yes`
**Description:** Google API Key used for fetching Google Fonts
Within the resume builder, there's a section where you can pick any font from the Google Fonts Library. To fetch the names and IDs of these fonts, we depend on the Google Fonts API. It does not cost any payment, or the need to enter credit card information to create or use this API.
You can get your own key here: https://developers.google.com/fonts/docs/developer_api
## SendGrid
The server makes use of SendGrid to send the password reset email to those who have forgotten their password. **This section is completely optional for those who do not require this functionality.**
### `SENDGRID_API_KEY`
**Required**: `no`
**Description:** SendGrid API Key
Does not require any payment or credit card information to obtain an API key.
You can get your own key here: https://docs.sendgrid.com/ui/account-and-settings/api-keys
### `SENDGRID_FORGOT_PASSWORD_TEMPLATE_ID`
**Required**: `no`
**Description:** Dynamic Template ID for Forgot Password
### `SENDGRID_FROM_NAME`
**Required**: `no`
**Description:** Sender's Name
### `SENDGRID_FROM_EMAIL`
**Required**: `no`
**Description:** Sender's Email Address

View File

@ -0,0 +1,14 @@
---
sidebar_position: 3
---
# Source Code
No, I'm not going to be talking about [the 2011 movie](https://www.imdb.com/title/tt0945513/) here.
The source code to Reactive Resume is available on [GitHub](https://github.com/AmruthPillai) for you to poke, prod, pull and publish. It is distributed under the [MIT License](https://choosealicense.com/licenses/mit/) which allows you to do **anything you want** with it, including commercial use.
In this section, I'll be going through the steps on how you can build the project on your local machine (or the cloud). You can choose one of two paths from here:
- [Docker](docker)
- [Local Build](local-build)

View File

@ -0,0 +1,60 @@
---
sidebar_position: 2
---
# Local Build
This might not be the most versatile, but it's quite easy and my recommended way of getting the project set up. This project is heavily dependent on [pnpm](https://pnpm.io) and it's monorepo workspaces feature, so I'd pick that up if I were you.
1. Once you have `pnpm` set up, you can pull the source code from GitHub and dive into the repository.
```bash
git clone git@github.com:AmruthPillai/Reactive-Resume.git
cd Reactive-Resume
```
2. Install dependencies using [pnpm](https://pnpm.io/), and it should take just a few minutes.
```bash
pnpm install
```
3. Copy the `.env.example` file to `.env` in the project root and fill it with values according to your setup. To know which environment variables are required, and about what they do, head over [this section](env-vars).
```bash
cp .env.example .env
```
4. Run the app locally by using the command:
```bash
pnpm dev
```
Now, your **frontend** client should be running on [`http://localhost:3000`](http://localhost:3000), your **backend** server on [`http://localhost:3100`](http://localhost:3100) and this **documentation** on [`http://localhost:3200`](http://localhost:3200).
5. To ensure that the app works currently, a proxy layer has to be made between the client and server. For this, I made use of a Chrome extension called [**Rabbit URL Rewriter**](https://chrome.google.com/webstore/detail/rabbit-url-rewriter/kcbmcmeblpkcndhfhkclggekfblookii?hl=en) to forward my requests made to `localhost:3000/api` to `localhost:3100`. The configuration should look something like this:
```
Website URL: http://localhost:3000
From URL: http://localhost:3000/api/(.*)
To URL: http://localhost:3100/$1
```
![Screenshot 2022-03-12 at 4 07 37 PM](https://user-images.githubusercontent.com/1134738/158023473-d415e696-f027-4bc7-af02-648c4a99b147.png)
Now, you should be able to create accounts, login etc.
6. Build the project before deploying by running the command:
```bash
pnpm build
```
7. Finally, start the production servers for all three workspaces by running:
```bash
pnpm start
```
Additionally, you can check the `package.json` for some additional scripts on how to run commands for a specific workspace. For more information on pnpm workspaces, head over to [their documentation](https://pnpm.io/workspaces).

View File

@ -0,0 +1,2 @@
position: 2
label: Tutorial

Some files were not shown because too many files have changed in this diff Show More