diff --git a/.yfm b/.yfm index 7c16ee3a..f020e3dd 100644 --- a/.yfm +++ b/.yfm @@ -1,4 +1,3 @@ -disableLiquid: true allowHTML: true langs: ['en','ru'] diff --git a/en/project/leading-page.md b/en/project/leading-page.md index 8f94f86b..2405c499 100644 --- a/en/project/leading-page.md +++ b/en/project/leading-page.md @@ -51,12 +51,12 @@ Possible comparison operators: `==`, `!=`, `<`, `>`, `<=`, and `>=`. Title and description of document and links support [substitutions](../syntax/vars#subtitudes) and [conditional operators](../syntax/vars#conditions). ```yaml -title: "{{ title }}" -description: "{% if version == 10 %}{{ description_legacy }}{% else %}{{ description }}{% endif %}" +title: "not_var{{ title }}" +description: "{% if version == 10 %}not_var{{ description_legacy }}{% else %}not_var{{ description }}{% endif %}" meta: - title: "{{ meta_title }}" + title: "not_var{{ meta_title }}" links: -- title: "{{ link_title }}" - description: "{{ link_description }}" +- title: "not_var{{ link_title }}" + description: "not_var{{ link_description }}" href: path/to/conditional/file.md ``` diff --git a/en/project/toc.md b/en/project/toc.md index 0b8e7d46..c7d828fb 100644 --- a/en/project/toc.md +++ b/en/project/toc.md @@ -50,7 +50,7 @@ Possible comparison operators: `==`, `!=`, `<`, `>`, `<=`, `>=`. Document title supports [substitutions](../syntax/vars#subtitudes) and [conditional operators](../syntax/vars#conditions). ```yaml -title: "{{ title }}" +title: "not_var{{ title }}" ``` {% note warning %} diff --git a/en/syntax/vars.md b/en/syntax/vars.md index f396a85a..5af66586 100644 --- a/en/syntax/vars.md +++ b/en/syntax/vars.md @@ -12,13 +12,13 @@ Methods for using variables in documents are discussed below. To substitute a value with a variable in the text, enter the variable name with double curly brackets before and after. ``` -Some text {{ variable_name }} text continued. +Some text not_var{{ variable_name }} text continued. ``` If the text contains double curly brackets but doesn't require variable substitution, add `not_var` before the construction. ``` -Some text not_var{{ also_text }} text continued. +Some text not_varnot_var{{ also_text }} text continued. ``` ## Conditional operators {#conditions} @@ -50,7 +50,7 @@ Use loops to output repetitive content for each element of an array. Inside the ``` {% for variable_name in array_name %} -Some text {{ variable_name }} text continued. +Some text not_var{{ variable_name }} text continued. {% endfor %} ``` @@ -69,7 +69,7 @@ default: Then using loops will result in the following: ```markdown -Prefix {% for user in users %} {{user}} {% endfor %} Postfix +Prefix {% for user in users %} not_var{{user}} {% endfor %} Postfix ``` Prefix Alice Mark Postfix @@ -79,7 +79,7 @@ Prefix {% for user in users %} -{{user}} +not_var{{user}} {% endfor %} @@ -118,15 +118,15 @@ default: Then using filters will result in the following: ```markdown -Hello {{ user.name | capitalize }}! +Hello not_var{{ user.name | capitalize }}! ``` Hello Alice! ```markdown -{{ users | length }} +not_var{{ users | length }} -{{ user.name | length }} | length +not_var{{ user.name | length }} | length ``` 2 @@ -156,9 +156,9 @@ default: Then using functions will result in the following: ```markdown -Hello P{{ user.name.slice(1) }}! +Hello Pnot_var{{ user.name.slice(1) }}! -Hello P{{ user.name.slice(1, 2) }}vel! +Hello Pnot_var{{ user.name.slice(1, 2) }}vel! ``` Hello Pasha! diff --git a/ru/_images/camera.svg b/ru/_images/camera.svg new file mode 100644 index 00000000..2db335dd --- /dev/null +++ b/ru/_images/camera.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/ru/_images/highload.png b/ru/_images/highload.png new file mode 100644 index 00000000..5bcffdc8 Binary files /dev/null and b/ru/_images/highload.png differ diff --git a/ru/_images/subbotnik.jpg b/ru/_images/subbotnik.jpg new file mode 100644 index 00000000..028ac658 Binary files /dev/null and b/ru/_images/subbotnik.jpg differ diff --git a/ru/presets.yaml b/ru/presets.yaml new file mode 100644 index 00000000..159be9b8 --- /dev/null +++ b/ru/presets.yaml @@ -0,0 +1,18 @@ +default: + algorithms: | + - Массив - и его отличие от списков + - Связный список - и его реализации на js + - Двусвязный список - и где его применяют + - Hash-map - почему эффективен + - Дерево, бинарное дерево, AST - красно-черные не нужны, мы про другое + + servers: | + - NodeJS - основная среда исполнения кода + - S3/S3 API - хранилище контента + - PostgreSQL - хранилище пользовательских данных + - OpenSearch/ElasticSearch - индекс по документациям + - Redis - кеширование серверных ответов + - Kubernetes/Kubernetes like - управление контейнерами + - Terraform + Helm - автоматическое разворачивание инсталяции, автоматический деплой + - ALB/API Gateway/Nginx - балансеры + - Serverless - внутренние задачи инсталяции \ No newline at end of file diff --git a/ru/project/leading-page.md b/ru/project/leading-page.md index d054fbe5..d72d90e0 100644 --- a/ru/project/leading-page.md +++ b/ru/project/leading-page.md @@ -52,12 +52,12 @@ links: Название и описание документа и ссылок поддерживают [подстановки](../syntax/vars#subtitudes) и [условные операторы](../syntax/vars#conditions). ```yaml -title: "{{ title }}" -description: "{% if version == 10 %}{{ description_legacy }}{% else %}{{ description }}{% endif %}" +title: "not_var{{ title }}" +description: "{% if version == 10 %}not_var{{ description_legacy }}{% else %}not_var{{ description }}{% endif %}" meta: - title: "{{ meta_title }}" + title: "not_var{{ meta_title }}" links: -- title: "{{ link_title }}" - description: "{{ link_description }}" +- title: "not_var{{ link_title }}" + description: "not_var{{ link_description }}" href: path/to/conditional/file.md ``` diff --git a/ru/project/toc.md b/ru/project/toc.md index 0441ba4b..65aa1044 100644 --- a/ru/project/toc.md +++ b/ru/project/toc.md @@ -50,7 +50,7 @@ items: Название документа поддерживает [подстановки](../syntax/vars#subtitudes) и [условные операторы](../syntax/vars#conditions). ```yaml -title: "{{ title }}" +title: "not_var{{ title }}" ``` {% note warning %} diff --git a/ru/syntax/vars.md b/ru/syntax/vars.md index 304e6da1..1642186e 100644 --- a/ru/syntax/vars.md +++ b/ru/syntax/vars.md @@ -63,7 +63,7 @@ default: ``` Тогда использование циклов приведет к следующим результатам: ```markdown -Prefix {% for user in users %} {{user}} {% endfor %} Postfix +Prefix {% for user in users %} not_var{{user}} {% endfor %} Postfix ``` Prefix Alice Mark Postfix @@ -72,7 +72,7 @@ Prefix {% for user in users %} -{{user}} +not_var{{user}} {% endfor %} @@ -110,15 +110,15 @@ default: Тогда использование фильтров приведет к следующим результатам: ```markdown -Hello {{ user.name | capitalize }}! +Hello not_var{{ user.name | capitalize }}! ``` Hello Alice! ```markdown -{{ users | length }} +not_var{{ users | length }} -{{ user.name | length }} | length +not_var{{ user.name | length }} | length ``` 2 @@ -147,9 +147,9 @@ default: Тогда использование функций приведет к следующим результатам: ```markdown -Hello P{{ user.name.slice(1) }}! +Hello Pnot_var{{ user.name.slice(1) }}! -Hello P{{ user.name.slice(1, 2) }}vel! +Hello Pnot_var{{ user.name.slice(1, 2) }}vel! ``` Hello Pasha! diff --git a/ru/toc.yaml b/ru/toc.yaml index 7f32ee56..82a692b1 100644 --- a/ru/toc.yaml +++ b/ru/toc.yaml @@ -118,3 +118,8 @@ items: href: contribution.md - name: Релизы YFM href: changelog.md + - name: Вакансии + hidden: true + items: + - name: Старший разработчик + href: vacancy.md \ No newline at end of file diff --git a/ru/vacancy.md b/ru/vacancy.md new file mode 100644 index 00000000..d21b1242 --- /dev/null +++ b/ru/vacancy.md @@ -0,0 +1,153 @@ +# Веб-разработчик в Платформу документации + + + +## Специфика нашей работы + +Мы занимаемся разработкой программной платформы документации в парадигме [documentation as a code](https://yandex.ru/search/?text=documentation+as+a+code&clid=1955453&win=547&lr=2). + +Платформа помогает разработчикам и техническим писателям получать качественную документацию, прилагая минимум усилий. + +На нешей платформе создана вся документация [Облака](https://cloud.yandex.ru/ru/docs), [Diplodoc](https://diplodoc.com/docs/ru/), страница, которую вы сейчас читаете, и много других продуктов, которые вы пока не сможете увидеть. + +Концепция documentation as a code предполагает, что написание документов следует **[принципам написания кода](*documentation-as-a-code-rules)**, целью которых является создание четкой структуры для легкого понимания и чтения. + +### Минимум верстки + +В плане интерфейса документация - простой сервис. + +Основные интерфейсные компоненты мы берем из open source библиотеки [@gravity-ui/uikit](https://gravity-ui.com/libraries/uikit). + +Для сложного пользовательского контента мы предоставляем интеграцию с [@gravity-ui/page-constructor](https://gravity-ui.com/libraries/page-constructor). + +### Максимум логики + +Большая часть нашей работы связана с процессингом текстов, расширением синтаксических [конструкций маркдауна](https://github.com/diplodoc-platform/transform/blob/master/src/transform/plugins/table/index.ts), созданием новых [расширений](https://github.com/diplodoc-platform/mermaid-extension) для платформы. + +Важно не теряться в инкрементах циклов, не создавать излишней вложенности. умело выбирать **[структуры данных](*data-structures)**. + +### Сервера{#servers} + +Платформа работает не только как набор утилит для сборки документации, +но и в виде нескольких серверных инсталяций, которые помогают динамически рендерить документацию, индексировать ее. + +Основные технологии с которыми мы работаем на серверах: +{{servers}} + +Со всеми перечисленными технологиями мы работаем лично. Следим за стабильностью серверов. Прорабатываем архитектуру. Выстраиваем процессы для обеспечения стабильности. + +{% note info %} + +Суммарно на наши сервера заходит больше одного миллиона уникальных пользователей в день. + +{% endnote %} + +{% note warning %} + +Наша задача быстро и без ошибок, в любую погоду, показывать документацию пользователям. + +{% endnote %} + +### OpenSource + +Большая часть нашей платформы [размещена в open source](https://github.com/diplodoc-platform/diplodoc). + +Поддержка open source является важной частью нашей ежедневной работы: + +- Общение в issues и pull requests в GitHub на русском и преимущественно английском языке. +- Презентация/продвижение продукта на разных **![i](./_images/camera.svg) [конференциях](*conference)**{.photo} и **![i](./_images/camera.svg) [митапах](*meetup)**{.photo}. +- Разработка продукта не под конкретную компанию, а под совокупный опыт/ожидания сообщества. + +## Ожидания от кандидата + +Мы ожидаем что вы уже знаете или вам было бы **интересно** быcтро изучить: + +{% cut "Алгоритмы и структуры данных" %} + +Ничего экзотического не требуется. Но в базовых нужно разбираться хорошо. Умело их применять. + +{{algorithms}} + +Отдельным плюсом будет, если вы сталкивались с алгоритмами токенизации текстов, разбираетесь в алгоритмах поиска по текстам. + +Потому что мы разбираем тексты на кусочки, а потом собираем из них что-нибудь новое и прекрасное. + +{% endcut %} + +{% cut "Серверные архитектуры" %} + +{{servers}} + +Потому что [мы много работаем с серверами](#servers) + +{% endcut %} + +{% cut "Форматы" %} + +**CommonMark** спецификаци маркдауна. + +**GitHub Flavored Markdown** спецификаци маркдауна. + +**JSONSchema** - работаем со схемами чаще среднестатистического разработчика + +{% endcut %} + +{% cut "Open Source технологии" %} + +**Git** - чуть глубже чем просто создание коммитов. Мы используем его на программном уровне. + +**GitHub** - так же глубоко интегрирован в наш продукт. Пишем gh-actions, gh-extensions дл внешних потребителей платформы документации. + +**Webpack** - на уровне написани собственных плагинов. + +{% endcut %} + +{% cut "Литература" %} + +Мы будем лучше друг друга понимать, если вы уже читали: + +**Чистый код** Роберта Мартина + +**Чистая архитектура** Роберта Мартина + +**Site Reliability Engineering** Бетси Бейер и др. + +{% endcut %} + +Так же мы ожидаем хороший скилл коммуникации. У нас много внешних и внутренних заказчиков. +Много демократичных процессов в рамках развития общей опенсорс технологии. +Нужно много слушать, анализировать, договариваться. + + +[*documentation-as-a-code-rules]: +- **DRY (Don’t Repeat Yourself)**: важно избегать дублирования информации в документах. +- **KISS (Keep It Simple, Stupid)**: необходимо избегать ненужной сложности и стремиться к простоте изложения информации. +- **SRP (Single Responsibility Principle)**: каждый блок документации должен быть ответственным только за одну часть функциональности для сохранения четкости. структуры. +- **SLAP (Single Level of Abstraction Principle)**: необходимо разбивать большие документы на уровни абстракции и делать для каждого уровня отдельные лаконичные документы. +- **LoD (Law of Demeter)**: необходимо делать ссылки только на релевантные документы. +- Система ориентирована на пользователя, в ней ценятся не только читаемость, но и визуальная составляющая. Поэтому использование визуальных средств, таких как диаграммы, графики и видеоруководства, также становятся все более важными. +- **Проверка качества**: система предполагает единый стиль кодирования, включая структуру текста, отступы, пробелы и т.д. для облегчения понимания. +- **Версионирование**: система интегрирована с популярными vcs. +- **Локализация**: система доступна пользователям на нескольких языках. Это обеспечивается интеграцией с [автоматическими](https://cloud.yandex.ru/ru/docs/translate/?from=int-console-empty-state) и [полу-автоматическими](https://ru.smartcat.com/) сервисами перевода. +- **Доступность**: система доступна плохо видящим пользователям. + +[*data-structures]: +{{algorithms}} + +[*meetup]: +![i](./_images/subbotnik.jpg) + +[*conference]: +![i](./_images/highload.png)