Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sprint 2 #39

Open
wants to merge 27 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 16 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 15 additions & 0 deletions .editorconfig
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# Универсальные настройки редактора
#
# http://editorconfig.org
# https://habrahabr.ru/post/220131/
# https://packagecontrol.io/packages/EditorConfig

root = true

[*]
charset = utf-8
indent_style = space
indent_size = 2
end_of_line = lf
trim_trailing_whitespace = true
insert_final_newline = true
3 changes: 3 additions & 0 deletions .eslintignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
/build
**/*.min.js
/node_modules
28 changes: 28 additions & 0 deletions .eslintrc.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
{
"extends": "airbnb",
"parser": "@typescript-eslint/parser",
"plugins": ["@typescript-eslint"],
"settings": {
"import/resolver": {
"node": {
"extensions": [".js", ".ts", ".scss", ".pug"]
}
}
},
"rules": {
"max-len": [2, 100],
"@typescript-eslint/no-unused-vars": 2,
"no-console": 0,
"import/extensions": 0,
"quotes": 0,
"semi": 0,
"no-underscore-dangle": 0,
"no-tabs": 0,
"lines-between-class-members": 0,
"class-methods-use-this": 0,
"no-undef": 0,
"no-param-reassign": 0,
"import/prefer-default-export": 0,
"import/no-extraneous-dependencies": 0
}
}
25 changes: 25 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
build
dist
dist-ssr
*.local

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?
4 changes: 4 additions & 0 deletions .stylelintrc.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
{
"extends": "stylelint-config-standard-scss",
"ignoreFiles": ["build/*", "node_modules/*", "static/*"]
}
99 changes: 25 additions & 74 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,83 +1,34 @@
### Ветка, в которой делаете задания спринта, должна называться sprint_i, где i - номер спринта. Не переименовывайте её.
[Ссылка на прототип](https://www.figma.com/file/zoLY1xVwlhbMUxpHslGQDp/middle.messenger.praktikum.yandex?type=design&t=ruOBLon7eRgVs26J-6)

### Откройте pull request в ветку main из ветки, где вы разрабатывали проект, и добавьте ссылку на этот pr в README.md в ветке main.
### ВАЖНО: pull request должен называться “Sprint i” (i — номер спринта).
## Netlify links

### Например, задания для проектной работы во втором спринте вы делаете в ветке sprint_2. Открываете из неё pull request в ветку main. Ссылку на этот pr добавляете в README.md в ветке main. После этого на платформе Практикума нажимаете «Проверить задание».

### Также не забудьте проверить, что репозиторий публичный.
---


Даже законченный проект остаётся только заготовкой, пока им не начнут пользоваться. Но сначала пользователь должен понять, зачем ему пользоваться вашим кодом. В этом помогает файл README.

README — первое, что прочитает пользователь, когда попадёт в репозиторий на «Гитхабе». Хороший REAMDE отвечает на четыре вопроса:

- Готов ли проект к использованию?
- В чём его польза?
- Как установить?
- Как применять?

## Бейджи

Быстро понять статус проекта помогают бейджи на «Гитхабе». Иногда разработчики ограничиваются парой бейджев, которые сообщат о статусе тестов кода:

![Бэйджи](https://github.com/yandex-praktikum/mf.messenger.praktikum.yandex.images/blob/master/mf/b.png)

Если пользователь увидит ошибку в работе тестов, то поймёт: использовать текущую версию в важном проекте — не лучшая идея.

Бейджи помогают похвастаться достижениями: насколько популярен проект, как много разработчиков создавало этот код. Через бейджи можно даже пригласить пользователя в чат:

![Версии](https://github.com/yandex-praktikum/mf.messenger.praktikum.yandex.images/blob/master/mf/vers.png)

В README **Webpack** строка бейджев подробно рассказывает о покрытии кода тестами. Когда проект протестирован, это вызывает доверие пользователя. Последний бейдж приглашает присоединиться к разработке.

Другая строка убедит пользователя в стабильности инфраструктуры и популярности проекта. Последний бейдж зовёт в чат проекта.

## Описание

Краткое опишите, какую задачу решает проект. Пользователь не верит обещаниям и не готов читать «полотна» текста. Поэтому в описании достаточно нескольких строк:

![Описание](https://github.com/yandex-praktikum/mf.messenger.praktikum.yandex.images/blob/master/mf/desc.png)

Авторы **React** дробят описание на абзацы и списки — так проще пробежаться глазами по тексту и найти ключевую информацию.

Если у проекта есть сайт, добавьте ссылку в заголовок.
- [Sign in](https://deploy--jocular-rugelach-1c03ff.netlify.app/)
- [Sign out](https://deploy--jocular-rugelach-1c03ff.netlify.app/registration/)
- [Chats and chat](https://deploy--jocular-rugelach-1c03ff.netlify.app/chats-and-chat/)
- [User settings](https://deploy--jocular-rugelach-1c03ff.netlify.app/user-settings/)
- [User editing settings](https://deploy--jocular-rugelach-1c03ff.netlify.app/editing-settings/)
- [User editing password](https://deploy--jocular-rugelach-1c03ff.netlify.app/editing-password/)
- [Page 404](https://deploy--jocular-rugelach-1c03ff.netlify.app/404/)
- [Page 500](https://deploy--jocular-rugelach-1c03ff.netlify.app/500/)

## Установка

Лучше всего пользователя убеждает собственный опыт. Чем быстрее он начнёт пользоваться проектом, тем раньше почувствует пользу. Для этого помогите ему установить приложение: напишите краткую пошаговую инструкцию.

Если проект предназначен для разработчиков, добавьте информацию об установке тестовых версий. Например:

- `npm install` — установка стабильной версии,
- `npm start` — запуск версии для разработчика,
- `npm run build:prod` — сборка стабильной версии.

## **Примеры использования**

Хорошо, если сразу после установки пользователь сможет решить свои задачи без изучения проекта. Это особенно верно, если ваш пользователь — не профессиональный разработчик. Но даже профессионал поймёт вас лучше, если показать примеры использования:

![Ссылки](https://github.com/yandex-praktikum/mf.messenger.praktikum.yandex.images/blob/master/mf/link.png)

Для более подробных инструкции добавьте новые разделы или ссылки:

- на документацию,
- вики проекта,
- описание API.

В учебном проекте будут полезен раздел с описанием стиля кода и правилами разработки: как работать с ветками, пул-реквестами и релизами.

### **Команда**
- `npm install` — инициализация проекта,
- `npm run start` — сборка проекта и запуск сервера (http://localhost:3000),
- `npm run dev` — запуск версии для разработки,
- `npm run build` — сборка проекта.

Если вы работаете в команде, укажите основных участников: им будет приятно, а новые разработчики охотнее присоединятся к проекту. «Гитхаб» — не просто инструмент, это социальная сеть разработчиков.
## Структура

![Команда](https://github.com/yandex-praktikum/mf.messenger.praktikum.yandex.images/blob/master/mf/team.png)
- /src/pages/ - Компоненты страниц
- /src/components/ - Компоненты
- /src/components/utils/ - Утилиты компонентов
- /src/core/- Ключевые классы
- /src/scss/ - стили проекта
- /src/utils/ - Утилиты

### **Примеры README**
## Ключевые технологии

- «[Реакт](https://github.com/facebook/react)»,
- «[Эхо](https://github.com/labstack/echo)»,
- «[Вебпак](https://github.com/webpack/webpack)»,
- «[ТДенгине](https://github.com/taosdata/TDengine)»,
- «[Соул-хантинг](https://github.com/vladpereskokov/soul-hunting/)».
- typescript
- шаблонизатор - pug
- css препроцессор - sass
76 changes: 76 additions & 0 deletions _http
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
/* eslint-disable */

const METHODS = {
GET: 'GET',
POST: 'POST',
PUT: 'PUT',
DELETE: 'DELETE',
};

function queryStringify (data) {
let result = '?';

for (const [key, value] of Object.entries(data)) {
result += `${key}=${value.toString()}&`;
}

return result.slice(0, result.length - 1);
}

class HTTPTransport {
get = (url, options = {}) => {
const { data } = options;
return this.request((data ? `${url}${queryStringify(data)}` : url), {...options, method: METHODS.GET});
};

post = () => {
return this.request(url, {...options, method: METHODS.POST});
}

put = () => {
return this.request(url, {...options, method: METHODS.PUT});
}

delete = () => {
return this.request(url, {...options, method: METHODS.DELETE});
}

request = (url, options) => {
const {method, headers, data, timeout = 5000} = options;

return new Promise((resolve, reject) => {
const xhr = new XMLHttpRequest();
xhr.open(method, url);
if (headers) xhr.setRequestHeader(...headers);

xhr.onload = () => {
resolve(xhr);
};

xhr.onabort = reject;
xhr.onerror = reject;
xhr.ontimeout = reject;

if (method === METHODS.GET) {
xhr.send();
} else {
xhr.send(JSON.stringify(data));
}

setTimeout(() => {
xhr.abort();
}, timeout)
})
};
}

function fetchWithRetry (url, options = {}) {
let { retries = 2 } = options;

if (retries === 0) {
throw new Error('The number of attempts has been exhausted');
}

return new HTTPTransport().get(url, options)
.catch(err => fetchWithRetry(url, {...options, retries: retries - 1}))
}
9 changes: 9 additions & 0 deletions netlify.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
# Global settings applied to the whole site.
#
# “base” is the directory to change to before starting build. If you set base:
# that is where we will look for package.json/.nvmrc/etc, not repo root!
# “command” is your build command.
# “publish” is the directory to publish (relative to the root of your repo).

[build]
publish = "build"
Loading