diff --git a/build.js b/build.js index af5d7e5..a4f34c0 100644 --- a/build.js +++ b/build.js @@ -2,25 +2,53 @@ const puppeteer = require('puppeteer'); const fs = require('fs'); const mdHtml = new (require('showdown').Converter)(); -const content = getParts({ - path: './src/ru/clean-copy/', - l10n: { - chapter: 'Глава' +const l10n = { + en: { + title: 'Sergey Konstantinov. The API', + author: 'Sergey Konstantinov', + chapter: 'Chapter' }, - pageBreak:'
' -}).join(''); + ru: { + title: 'Сергей Константинов. API', + author: 'Сергей Константинов', + chapter: 'Глава' + } +}; -const html = ` - -This work is licensed under a Creative Commons Attribution-NonCommercial 4.0 International License.
+The book you're holding in your hands comprises this Introduction and three large sections.
+In Section I we are to talk about deisgning the API as a concept: how to build the architecture properly, from a high-level planning down to final interfaces.
+Section II is dedicated to API's lifecycle: how interfaces evolve over time, and how to elaborate the product to match users' needs.
+Finally, Section III is more about un-engineering sides of the API, like supporting, marketing and working with a community.
+First two sections are much of of interest to engineers, when third section being more relevant to both engineers and product managers. But we insist that this section is the most important for the API software developer. Since API is the product for engineers, you cannot simply pronounce non-engineering team responsible for its product planning and support. Nobody but you understands more what product features your API is capable of.
+Let's start.
Это произведение доступно по лицензии Creative Commons «Attribution-NonCommercial» («Атрибуция — Некоммерческое использование») 4.0 Всемирная.
Важно: различайте локализацию для конечного пользователя и локализацию для разработчика. В примере из п. 12 сообщение localized_message
адресовано пользователю — его должно показать приложение, если в коде обработка такой ошибки невозможно. Это сообщение должно быть написано на указанном в запросе языке и отформатировано согласно правилам локации пользователя. А вот сообщение details.checks_failed[].message
написано не для пользователя, а для разработчика, который будет разбираться с проблемой. Соответственно, написано и отформатировано оно должно быть понятно для разработчика — что, скорее всего, означает «на английском языке», т.к. английский де факто является стандартом в мире разработки программного обеспечения.
Следует отметить, что индикация, какие сообщения следует показать пользователю, а какие написаны для разработчика, должна, разумеется, быть явной конвенцией вашего API. В примере для этого используется префикс localized_
.
И ещё одна вещь: все строки должны быть в кодировке UTF-8 и никакой другой.