remove legacy serv_spa (yalarba Vue SPA)

- Deleted main_dc/yalarba/serv_spa/ directory
- No docker-compose.yml changes needed (service was already unused)
- Updated docs references to point to yalarba-nuxt
- docker-compose.yml and nginx configs had no references to serv_spa
This commit is contained in:
valitovgaziz
2026-06-12 11:26:18 +05:00
parent eee067f0ca
commit 0898315910
194 changed files with 5 additions and 28235 deletions
+3 -3
View File
@@ -18,7 +18,7 @@ main_dc/
yalarba/api_es/ -- Go REST API (GORM+Chi), port 8088, DB: db (5432)
yalarba/api_yal/ -- Go REST API (GORM+Chi), port 8787, DB: db (5432)
yalarba/easySite/easySite/ -- Nuxt 4 SPA for easysite102.ru
yalarba/serv_spa/spa/vue/ -- Vue 3 + Vite SPA for yalarba.ru
yalarba/yalarba-nuxt/ -- Nuxt 4 SPA for yalarba.ru
valitovgaziz/analytics/ -- Node.js (Express) analytics server, port 9999
valitovgaziz/html/ -- static HTML for valitovgaziz.ru
nginx/ -- nginx with automatic HTTP↔HTTPS switching
@@ -47,7 +47,7 @@ cd main_dc/BB/bbvue && npm run dev # Vite dev server
cd main_dc/BB/bbvue && npm run lint # ESLint --fix
cd main_dc/BB/bbvue && npm run format # Prettier --write src/
cd main_dc/yalarba/serv_spa/spa/vue && npm run dev # Vite dev (yalarba SPA)
# serv_spa удалён — yalarba работает через yalarba-nuxt (Nuxt SSR)
cd main_dc/yalarba/easySite/easySite && npm run dev # Nuxt dev
cd main_dc/yalarba/easySite/easySite && npm run build # Nuxt build
@@ -56,7 +56,7 @@ cd main_dc/yalarba/easySite/easySite && npm run build # Nuxt build
## Service quirks
- **Nginx SSL**: `switch-config.sh` is all-or-nothing — HTTPS only activates when *every* domain has a cert. Until then, SSL port redirects back to HTTP.
- **`yalarba/serv_spa/spa/`**: Dockerfile is incomplete (build stage only, no runtime). The `spa/vue/` package.json includes express/pg deps despite being a Vite SPA — likely unused or legacy. The nginx compose mounts `yalarba/serv_spa/spa/vue/dist`.
- **`yalarba/serv_spa/`**: удалён — был legacy Vue SPA, не использовался.
- **`api_yal`** is the only container that runs as non-root. Runs on port 8787.
- **`api_es`** port is configurable via `API_ES_APP_PORT` in `.env` (default 8088). All other API ports are hardcoded.
- **Databases**: `db` (port 5432) is shared between api_tp, api_es, api_yal. `db_bb` (port 5433) is dedicated to api_bb.
+1 -1
View File
@@ -165,7 +165,7 @@ Nginx запускается только после подтверждения
### Монтирование статических файлов
```
./stubSite → /usr/share/nginx/stub/html
./yalarba/serv_spa/spa/vue/dist → /usr/share/nginx/yalarba/html
# удалено: serv_spa больше не используется, yalarba работает через Nuxt SSR (yalarba-nuxt)
./valitovgaziz/html → /usr/share/nginx/valitovgaziz/html
./BB/bbvue/dist → /usr/share/nginx/begushiybashkir/html
```
+1 -1
View File
@@ -155,7 +155,7 @@ docker-compose up -d
### Репозитории:
- Фронтенд EasySite: `./yalarba/easySite/`
- Фронтенд YalArba: `./yalarba/serv_spa/`
- Фронтенд YalArba: `./yalarba/yalarba-nuxt/`
- API-сервисы: `./yalarba/api_*`, `./BB/api_bb`
---
-11
View File
@@ -1,11 +0,0 @@
# Используем Node.js для сборки
FROM node:18-alpine as builde
WORKDIR /app
# Копируем package.json и package-lock.json для установки зависимостей
COPY vue/package*.json ./
RUN npm install
copy ./vue .
-13
View File
@@ -1,13 +0,0 @@
build:
npm run build
run:
npm run dev
deploy:
npm run build
git add .
git commit -m 'build deploy'
git push
.DEFAULT_GOAL := run
@@ -1,17 +0,0 @@
## Project Setup
```sh
npm install
```
### Compile and Hot-Reload for Development
```sh
npm run dev
```
### Compile and Minify for Production
```sh
npm run build
```
@@ -1,262 +0,0 @@
# Документация проекта YalArba
**Версия документации:** 1.0 (Первичная)
**Дата составления:** 03 декабря 2025 года
**Актуальный статус проекта:** Разработка в процессе (базовый функционал)
---
## 1. Общая информация
### 1.1. Назначение проекта
**YalArba** — это веб-приложение, созданное на Vue 3 с использованием современных инструментов разработки. На текущем этапе реализована базовая структура SPA (Single Page Application) с системой авторизации и основными страницами-заглушками для будущего функционала.
### 1.2. Технологический стек
- **Фреймворк:** Vue 3 (Composition API, `<script setup>`)
- **Маршрутизация:** Vue Router 4
- **Состояние приложения:** Pinia (стейт-менеджмент)
- **Интернационализация:** Vue I18n
- **Сборка:** Vite (предположительно)
- **Стилизация:** CSS (с использованием модульных компонентов)
### 1.3. Текущий статус функционала
**Реализовано:**
- Базовая структура SPA с маршрутизацией
- Система авторизации (логин, регистрация, защищенные маршруты)
- Главная страница с поисковой строкой
- Страницы профиля, настроек, поддержки, обратной связи
- Страница "О нас" с разделами о разработчиках
🔄 **В разработке:**
- Функционал поиска и отображения результатов
- Детальные страницы объектов (restObject)
- Основная бизнес-логика приложения
---
## 2. Архитектура проекта
### 2.1. Структура каталогов
```
src/
├── assets/ # Глобальные стили, шрифты, изображения
├── auth/ # Логика авторизации (store)
├── components/ # Vue-компоненты (сгруппированы по функциям)
├── locales/ # Файлы интернационализации (i18n)
├── router/ # Конфигурация маршрутизации
├── views/ # Страницы приложения (роуты)
├── App.vue # Корневой компонент
└── main.js # Точка входа приложения
```
### 2.2. Маршрутизация (router/index.js)
Приложение использует Vue Router с защитой маршрутов через мета-поле `requiresAuth`.
#### 2.2.1. Публичные маршруты (доступны без авторизации):
- `/` - Главная страница (HomeView)
- `/about` - О проекте
- `/support` - Поддержка
- `/feetback` - Обратная связь
- `/results` - Результаты поиска
- `/registration` - Регистрация
- `/login` - Вход в систему
#### 2.2.2. Защищенные маршруты (требуют авторизации):
- `/profile` - Профиль пользователя
- `/settings` - Настройки
- `/restObject` - Детальная страница объекта
#### 2.2.3. Механизм защиты маршрутов:
```javascript
router.beforeEach(async (to, from, next) => {
const authStore = useAuthStore();
await authStore.checkAuth();
if (to.meta.requiresAuth && !authStore.isAuthenticated) {
next('/login'); // Перенаправление на страницу входа
} else {
next();
}
});
```
### 2.3. Компонентная структура
Каждая страница (view) состоит из:
1. **FHeader** - Полный заголовок (шапка сайта)
2. **Основной компонент страницы** (контент)
3. **FooterB** - Нижний колонтитул
---
## 3. Страницы приложения
### 3.1. Главная страница (`/`)
**Компоненты:** `FHeader + SearchLine + FooterB`
**Назначение:** Отображает поисковую строку для будущего поискового функционала.
### 3.2. Страница авторизации (`/login`)
**Компоненты:** `FHeader + LogIn + FooterB`
**Компонент:** `inout.vue` (логика входа)
### 3.3. Страница регистрации (`/registration`)
**Компоненты:** `FHeader + Registration + FooterB`
**Компонент:** `registration.vue`
### 3.4. Профиль пользователя (`/profile`)
**Статус:** Требует авторизации
**Компоненты:** `FHeader + Profile + FooterB`
**Компонент:** `profile.vue`
### 3.5. Настройки (`/settings`)
**Статус:** Требует авторизации
**Компоненты:** `FHeader + Settings + FooterB`
**Компонент:** `settings.vue`
### 3.6. Объект (`/restObject`)
**Статус:** Требует авторизации, в разработке
**Компоненты:** `FHeader + RestObject + FooterB`
**Особенность:** Использует моковые данные (`mockPlace`)
### 3.7. Результаты поиска (`/results`)
**Компоненты:** `FHeader + SearchLine + Results + FooterB`
**Компоненты:** `searchLine.vue`, `results.vue`
### 3.8. О проекте (`/about`)
**Компоненты:** `FHeader + About + Developers + Commits + FooterB`
**Разделы:** Информация о проекте, разработчики, коммиты
### 3.9. Поддержка (`/support`)
**Компоненты:** `FHeader + Support + FooterB`
**Компонент:** `support.vue`
### 3.10. Обратная связь (`/feetback`)
**Примечание:** Возможна опечатка в названии (feedback → feetback)
**Компоненты:** `FHeader + Feetback + FooterB`
**Компонент:** `feetback.vue`
---
## 4. Система авторизации
### 4.1. Хранилище состояния (Pinia Store)
Расположение: `/src/auth/stores/auth.store.js` (предположительно)
**Основные функции:**
- `checkAuth()` - проверка статуса авторизации
- `isAuthenticated` - реактивное состояние авторизации
### 4.2. Процесс авторизации
1. Пользователь переходит на защищенный маршрут
2. `router.beforeEach` вызывает `authStore.checkAuth()`
3. Если пользователь не авторизован → перенаправление на `/login`
4. После успешной авторизации доступ к защищенным маршрутам разрешен
---
## 5. Конфигурация приложения
### 5.1. Точка входа (main.js)
```javascript
import { createApp } from 'vue';
import SPA_VUE_App from './App.vue';
import appRouter from './router/index.js';
import i18n from './locales/i18n.js';
import { createPinia } from 'pinia';
const spaAppVue3 = createApp(SPA_VUE_App);
const pinia = createPinia();
spaAppVue3.use(pinia);
spaAppVue3.use(appRouter);
spaAppVue3.use(i18n);
spaAppVue3.mount('#app');
```
### 5.2. Глобальные стили и шрифты
- `/src/assets/main.css` - основные стили
- `/src/assets/fonts.css` - подключение шрифтов
### 5.3. Интернационализация (i18n)
Конфигурация находится в `/src/locales/i18n.js`
(контент файла не предоставлен)
---
## 6. Текущие задачи и TODO
### 6.1. Необходимо исправить:
1. **Опечатка в маршруте:** `feetback``feedback`
2. **Импорты в ResultsView.vue:**
```javascript
// Избыточный импорт (дважды)
import searchLine from '@/components/searchLine/searchLine.vue';
import SearchLine from '@/components/searchLine/searchLine.vue';
```
### 6.2. Планируемый функционал:
1. **Реализация поиска** (компоненты `SearchLine`, `Results`)
2. **Работа с API** для получения реальных данных
3. **Детальная страница объекта** (заполнение `RestObject`)
4. **Интеграция бэкенда** для авторизации
5. **Заполнение страниц контентом** (About, Support, Settings)
### 6.3. Архитектурные улучшения:
1. Добавить Error Boundary для обработки ошибок
2. Реализовать ленивую загрузку компонентов для всех маршрутов
3. Добавить мета-теги для SEO
4. Реализовать систему уведомлений
5. Добавить валидацию форм
---
## 7. Рекомендации по разработке
### 7.1. Соглашения по именованию:
- **Компоненты:** PascalCase (`RestObjectView.vue`)
- **Файлы маршрутов:** Папка `views/` + суффикс `View`
- **Вложенные компоненты:** Группировка по функциональности
### 7.2. Структура компонентов:
```vue
<template>
<!-- 1. Шапка -->
<!-- 2. Основной контент -->
<!-- 3. Подвал -->
</template>
<script setup>
// Импорты в порядке: header → основной компонент → footer
</script>
```
### 7.3. Работа с состоянием:
- Использовать Pinia stores для глобального состояния
- Локальное состояние хранить в компонентах через `ref()`, `reactive()`
- Авторизацию обрабатывать через `auth.store`
---
## 8. Развертывание и сборка
### 8.1. Предполагаемая команда сборки:
```bash
npm run build # или yarn build
```
### 8.2. Структура сборки:
- **Входная точка:** `index.html`
- **Основной скрипт:** `main.js`
- **Базовая настройка:** Мета-теги, фавиконка, подключение стилей
---
## 9. Контакты и поддержка
**Сайт проекта:** [yalarba.ru](https://yalarba.ru)
**Дата начала разработки:** Не указана (актуально на 03.12.2025)
**Статус:** Активная разработка
---
*Документация будет обновляться по мере добавления нового функционала. Все изменения в архитектуре и API должны отражаться в соответствующих разделах документации.*
@@ -1,14 +0,0 @@
<!DOCTYPE html>
<html lang="ru">
<head>
<meta charset="UTF-8">
<link rel="icon" href="/src/components/images/YalArbaLogo300.png">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="/src/assets/main.css">
<title>YalArba</title>
</head>
<body>
<div id="app"></div>
<script type="module" src="/src/main.js"></script>
</body>
</html>
@@ -1,8 +0,0 @@
{
"compilerOptions": {
"paths": {
"@/*": ["./src/*"]
},
},
"exclude": ["node_modules", "dist"],
}
File diff suppressed because it is too large Load Diff
@@ -1,29 +0,0 @@
{
"name": "spa",
"version": "0.0.1",
"private": true,
"type": "module",
"scripts": {
"dev": "vite",
"build": "vite build",
"preview": "vite preview"
},
"dependencies": {
"axios": "^1.7.9",
"body-parser": "^1.20.3",
"cors": "^2.8.5",
"express": "^4.21.2",
"jwt-decode": "^4.0.0",
"pg": "^8.13.1",
"pinia": "^2.3.1",
"vue": "^3.5.13",
"vue-i18n": "^11.1.0",
"vue-material-design-icons": "^5.3.1",
"vue-router": "^4.5.0"
},
"devDependencies": {
"@vitejs/plugin-vue": "^5.2.1",
"vite": "^6.4.1",
"vite-plugin-vue-devtools": "^7.6.8"
}
}
@@ -1,12 +0,0 @@
<script setup>
import { RouterLink, RouterView } from 'vue-router'
</script>
<template>
<div class="main">
<RouterView />
</div>
</template>
<style>
</style>
@@ -1,30 +0,0 @@
Выбор шрифтов и размеров для мобильных устройств и десктопа зависит от множества факторов, таких как целевая аудитория, дизайн сайта/приложения и цели использования. Тем не менее, есть несколько общих рекомендаций, которые помогут обеспечить хорошую читаемость текста на разных устройствах.
### Шрифты
#### Для мобильных устройств:
- **Roboto**: Один из самых популярных шрифтов для Android. Он имеет четкий и чистый вид, хорошо подходит для чтения на небольших экранах.
- **San Francisco**: Стандартный шрифт для iOS. Хорошо сбалансирован и удобен для чтения.
- **Open Sans**: Универсальный шрифт, который отлично смотрится на любых устройствах благодаря своей нейтральной стилистике.
#### Для десктопных устройств:
- **Georgia**: Классический шрифт с засечками, который идеально подходит для длинных текстов. Обеспечивает комфортное чтение даже на больших экранах.
- **Lato**: Современный шрифт без засечек, легкий и элегантный. Подходит для заголовков и основного текста.
- **Merriweather**: Отличный выбор для длинных статей и блогов. Имеет хорошие пропорции и контрастность.
### Размеры шрифта
#### Мобильные устройства:
- **Основной текст**: 16px–18px. Это оптимальный размер для комфортного чтения на маленьких экранах.
- **Заголовки**: 20px24px для h2, 18px22px для h3, 16px20px для h4.
#### Десктопные устройства:
- **Основной текст**: 18px–20px. Такой размер обеспечивает удобство чтения на больших экранах.
- **Заголовки**: 28px32px для h2, 24px28px для h3, 20px24px для h4.
### Дополнительные советы:
- Используйте **относительные единицы измерения** (em, rem) вместо абсолютных (px), чтобы шрифт масштабировался вместе с изменением размера экрана.
- Следите за **межстрочным интервалом** (line-height). Оптимальное значение — около 1.5–1.6 для основного текста.
- Убедитесь, что у вас достаточно **контраста между текстом и фоном**. Черный текст на белом фоне — классический пример хорошего сочетания.
Эти рекомендации помогут создать удобный интерфейс как для мобильных пользователей, так и для тех, кто работает за компьютером.
@@ -1,23 +0,0 @@
/* Светлая тема (по умолчанию) */
:root {
--background-color: #ffffff;
--text-color: #1c1d1d;
--light-dark-background-color: #ffffff;
--light-dark-text-color: #273f2c;
--disabled-backgroud-color: rgba(23, 62, 31, 0.281);
--button-text-color: #bac677;
--disabled-dark-background-color: rgba(55, 64, 62, 0.2);
--button-dark-background-color: #3cbf40;
--light-dark-background-color: #8cd68f;
}
/* Темная тема */
[data-theme="dark"] {
--background-color: #282828;
--text-color: #3cb756;
--light-dark-background-color: #4e5e49;
--light-dark-text-color: #59f37b;
--disabled-dark-background-color: rgba(159, 193, 185, 0.2);
--button-dark-background-color: #395e3a;
}
@@ -1,56 +0,0 @@
@font-face {
font-family: 'OpenSansVariableFont';
src: url('./fonts/Open_Sans/hinted-OpenSans-Regular.ttf') format('truetype-variations'),
url('./fonts/Open_Sans/OpenSans-Regular.woff') format('woff'),
url('./fonts/Open_Sans/OpenSans-Regular.woff2') format('woff2');
font-weight: 100 900;
font-stretch: 50% 200%;
}
@font-face {
font-family: 'OpenSansItalicVariableFont';
src: url('./fonts/Open_Sans/hinted-OpenSans-Italic.ttf') format('truetype-variations'),
url('./fonts/Open_Sans/OpenSans-Italic.woff') format('woff'),
url('./fonts/Open_Sans/OpenSans-Italic.woff2') format('woff2');
font-style: italic;
font-weight: 100 900;
font-stretch: 50% 200%;
}
@font-face {
font-family: 'RobotoVariableFont';
src: url('./fonts/Roboto/hinted-Roboto-Regular.ttf') format('truetype-variations'),
url('./fonts/Roboto/Roboto-Regular.woff') format('woff'),
url('./fonts/Roboto/Roboto-Regular.woff2') format('woff2');
font-weight: 100 900;
font-stretch: 50% 200%;
}
@font-face {
font-family: 'RobotoItalicVarFont';
src: url('./fonts/Roboto/hinted-Roboto-Italic.ttf') format('truetype-variations'),
url('./fonts/Roboto/Roboto-Italic.woff') format('woff'),
url('./fonts/Roboto/Roboto-Italic.woff2') format('woff2');
font-style: italic;
font-weight: 100 900;
font-stretch: 50% 200%;
}
:root {
--font-primary: 'OpenSansVariableFont', Arial, sans-serif;
--font-secondary: 'RobotoItalicVarFont', Arial, sans-serif;
--weight-light: 300;
--weight-normal: 400;
--weight-bold: 700;
}
body {
font-family: var(--font-primary);
font-weight: var(--weight-normal);
}
h1, h2, h3 {
font-family: var(--font-secondary);
font-weight: var(--weight-light);
}
@@ -1,93 +0,0 @@
Copyright 2020 The Open Sans Project Authors (https://github.com/googlefonts/opensans)
This Font Software is licensed under the SIL Open Font License, Version 1.1.
This license is copied below, and is also available with a FAQ at:
https://openfontlicense.org
-----------------------------------------------------------
SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
-----------------------------------------------------------
PREAMBLE
The goals of the Open Font License (OFL) are to stimulate worldwide
development of collaborative font projects, to support the font creation
efforts of academic and linguistic communities, and to provide a free and
open framework in which fonts may be shared and improved in partnership
with others.
The OFL allows the licensed fonts to be used, studied, modified and
redistributed freely as long as they are not sold by themselves. The
fonts, including any derivative works, can be bundled, embedded,
redistributed and/or sold with any software provided that any reserved
names are not used by derivative works. The fonts and derivatives,
however, cannot be released under any other type of license. The
requirement for fonts to remain under this license does not apply
to any document created using the fonts or their derivatives.
DEFINITIONS
"Font Software" refers to the set of files released by the Copyright
Holder(s) under this license and clearly marked as such. This may
include source files, build scripts and documentation.
"Reserved Font Name" refers to any names specified as such after the
copyright statement(s).
"Original Version" refers to the collection of Font Software components as
distributed by the Copyright Holder(s).
"Modified Version" refers to any derivative made by adding to, deleting,
or substituting -- in part or in whole -- any of the components of the
Original Version, by changing formats or by porting the Font Software to a
new environment.
"Author" refers to any designer, engineer, programmer, technical
writer or other person who contributed to the Font Software.
PERMISSION & CONDITIONS
Permission is hereby granted, free of charge, to any person obtaining
a copy of the Font Software, to use, study, copy, merge, embed, modify,
redistribute, and sell modified and unmodified copies of the Font
Software, subject to the following conditions:
1) Neither the Font Software nor any of its individual components,
in Original or Modified Versions, may be sold by itself.
2) Original or Modified Versions of the Font Software may be bundled,
redistributed and/or sold with any software, provided that each copy
contains the above copyright notice and this license. These can be
included either as stand-alone text files, human-readable headers or
in the appropriate machine-readable metadata fields within text or
binary files as long as those fields can be easily viewed by the user.
3) No Modified Version of the Font Software may use the Reserved Font
Name(s) unless explicit written permission is granted by the corresponding
Copyright Holder. This restriction only applies to the primary font name as
presented to the users.
4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
Software shall not be used to promote, endorse or advertise any
Modified Version, except to acknowledge the contribution(s) of the
Copyright Holder(s) and the Author(s) or with their explicit written
permission.
5) The Font Software, modified or unmodified, in part or in whole,
must be distributed entirely under this license, and must not be
distributed under any other license. The requirement for fonts to
remain under this license does not apply to any document created
using the Font Software.
TERMINATION
This license becomes null and void if any of the above conditions are
not met.
DISCLAIMER
THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
OTHER DEALINGS IN THE FONT SOFTWARE.
@@ -1,100 +0,0 @@
Open Sans Variable Font
=======================
This download contains Open Sans as both variable fonts and static fonts.
Open Sans is a variable font with these axes:
wdth
wght
This means all the styles are contained in these files:
OpenSans-VariableFont_wdth,wght.ttf
OpenSans-Italic-VariableFont_wdth,wght.ttf
If your app fully supports variable fonts, you can now pick intermediate styles
that arent available as static fonts. Not all apps support variable fonts, and
in those cases you can use the static font files for Open Sans:
static/OpenSans_Condensed-Light.ttf
static/OpenSans_Condensed-Regular.ttf
static/OpenSans_Condensed-Medium.ttf
static/OpenSans_Condensed-SemiBold.ttf
static/OpenSans_Condensed-Bold.ttf
static/OpenSans_Condensed-ExtraBold.ttf
static/OpenSans_SemiCondensed-Light.ttf
static/OpenSans_SemiCondensed-Regular.ttf
static/OpenSans_SemiCondensed-Medium.ttf
static/OpenSans_SemiCondensed-SemiBold.ttf
static/OpenSans_SemiCondensed-Bold.ttf
static/OpenSans_SemiCondensed-ExtraBold.ttf
static/OpenSans-Light.ttf
static/OpenSans-Regular.ttf
static/OpenSans-Medium.ttf
static/OpenSans-SemiBold.ttf
static/OpenSans-Bold.ttf
static/OpenSans-ExtraBold.ttf
static/OpenSans_Condensed-LightItalic.ttf
static/OpenSans_Condensed-Italic.ttf
static/OpenSans_Condensed-MediumItalic.ttf
static/OpenSans_Condensed-SemiBoldItalic.ttf
static/OpenSans_Condensed-BoldItalic.ttf
static/OpenSans_Condensed-ExtraBoldItalic.ttf
static/OpenSans_SemiCondensed-LightItalic.ttf
static/OpenSans_SemiCondensed-Italic.ttf
static/OpenSans_SemiCondensed-MediumItalic.ttf
static/OpenSans_SemiCondensed-SemiBoldItalic.ttf
static/OpenSans_SemiCondensed-BoldItalic.ttf
static/OpenSans_SemiCondensed-ExtraBoldItalic.ttf
static/OpenSans-LightItalic.ttf
static/OpenSans-Italic.ttf
static/OpenSans-MediumItalic.ttf
static/OpenSans-SemiBoldItalic.ttf
static/OpenSans-BoldItalic.ttf
static/OpenSans-ExtraBoldItalic.ttf
Get started
-----------
1. Install the font files you want to use
2. Use your app's font picker to view the font family and all the
available styles
Learn more about variable fonts
-------------------------------
https://developers.google.com/web/fundamentals/design-and-ux/typography/variable-fonts
https://variablefonts.typenetwork.com
https://medium.com/variable-fonts
In desktop apps
https://theblog.adobe.com/can-variable-fonts-illustrator-cc
https://helpx.adobe.com/nz/photoshop/using/fonts.html#variable_fonts
Online
https://developers.google.com/fonts/docs/getting_started
https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Fonts/Variable_Fonts_Guide
https://developer.microsoft.com/en-us/microsoft-edge/testdrive/demos/variable-fonts
Installing fonts
MacOS: https://support.apple.com/en-us/HT201749
Linux: https://www.google.com/search?q=how+to+install+a+font+on+gnu%2Blinux
Windows: https://support.microsoft.com/en-us/help/314960/how-to-install-or-remove-a-font-in-windows
Android Apps
https://developers.google.com/fonts/docs/android
https://developer.android.com/guide/topics/ui/look-and-feel/downloadable-fonts
License
-------
Please read the full license text (OFL.txt) to understand the permissions,
restrictions and requirements for usage, redistribution, and modification.
You can use them in your products & projects print or digital,
commercial or otherwise.
This isn't legal advice, please consider consulting a lawyer and see the full
license for all details.
File diff suppressed because it is too large Load Diff

Before

Width:  |  Height:  |  Size: 460 KiB

File diff suppressed because it is too large Load Diff

Before

Width:  |  Height:  |  Size: 406 KiB

@@ -1,93 +0,0 @@
Copyright 2011 The Roboto Project Authors (https://github.com/googlefonts/roboto-classic)
This Font Software is licensed under the SIL Open Font License, Version 1.1.
This license is copied below, and is also available with a FAQ at:
https://openfontlicense.org
-----------------------------------------------------------
SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
-----------------------------------------------------------
PREAMBLE
The goals of the Open Font License (OFL) are to stimulate worldwide
development of collaborative font projects, to support the font creation
efforts of academic and linguistic communities, and to provide a free and
open framework in which fonts may be shared and improved in partnership
with others.
The OFL allows the licensed fonts to be used, studied, modified and
redistributed freely as long as they are not sold by themselves. The
fonts, including any derivative works, can be bundled, embedded,
redistributed and/or sold with any software provided that any reserved
names are not used by derivative works. The fonts and derivatives,
however, cannot be released under any other type of license. The
requirement for fonts to remain under this license does not apply
to any document created using the fonts or their derivatives.
DEFINITIONS
"Font Software" refers to the set of files released by the Copyright
Holder(s) under this license and clearly marked as such. This may
include source files, build scripts and documentation.
"Reserved Font Name" refers to any names specified as such after the
copyright statement(s).
"Original Version" refers to the collection of Font Software components as
distributed by the Copyright Holder(s).
"Modified Version" refers to any derivative made by adding to, deleting,
or substituting -- in part or in whole -- any of the components of the
Original Version, by changing formats or by porting the Font Software to a
new environment.
"Author" refers to any designer, engineer, programmer, technical
writer or other person who contributed to the Font Software.
PERMISSION & CONDITIONS
Permission is hereby granted, free of charge, to any person obtaining
a copy of the Font Software, to use, study, copy, merge, embed, modify,
redistribute, and sell modified and unmodified copies of the Font
Software, subject to the following conditions:
1) Neither the Font Software nor any of its individual components,
in Original or Modified Versions, may be sold by itself.
2) Original or Modified Versions of the Font Software may be bundled,
redistributed and/or sold with any software, provided that each copy
contains the above copyright notice and this license. These can be
included either as stand-alone text files, human-readable headers or
in the appropriate machine-readable metadata fields within text or
binary files as long as those fields can be easily viewed by the user.
3) No Modified Version of the Font Software may use the Reserved Font
Name(s) unless explicit written permission is granted by the corresponding
Copyright Holder. This restriction only applies to the primary font name as
presented to the users.
4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
Software shall not be used to promote, endorse or advertise any
Modified Version, except to acknowledge the contribution(s) of the
Copyright Holder(s) and the Author(s) or with their explicit written
permission.
5) The Font Software, modified or unmodified, in part or in whole,
must be distributed entirely under this license, and must not be
distributed under any other license. The requirement for fonts to
remain under this license does not apply to any document created
using the Font Software.
TERMINATION
This license becomes null and void if any of the above conditions are
not met.
DISCLAIMER
THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
OTHER DEALINGS IN THE FONT SOFTWARE.
@@ -1,118 +0,0 @@
Roboto Variable Font
====================
This download contains Roboto as both variable fonts and static fonts.
Roboto is a variable font with these axes:
wdth
wght
This means all the styles are contained in these files:
Roboto-VariableFont_wdth,wght.ttf
Roboto-Italic-VariableFont_wdth,wght.ttf
If your app fully supports variable fonts, you can now pick intermediate styles
that arent available as static fonts. Not all apps support variable fonts, and
in those cases you can use the static font files for Roboto:
static/Roboto_Condensed-Thin.ttf
static/Roboto_Condensed-ExtraLight.ttf
static/Roboto_Condensed-Light.ttf
static/Roboto_Condensed-Regular.ttf
static/Roboto_Condensed-Medium.ttf
static/Roboto_Condensed-SemiBold.ttf
static/Roboto_Condensed-Bold.ttf
static/Roboto_Condensed-ExtraBold.ttf
static/Roboto_Condensed-Black.ttf
static/Roboto_SemiCondensed-Thin.ttf
static/Roboto_SemiCondensed-ExtraLight.ttf
static/Roboto_SemiCondensed-Light.ttf
static/Roboto_SemiCondensed-Regular.ttf
static/Roboto_SemiCondensed-Medium.ttf
static/Roboto_SemiCondensed-SemiBold.ttf
static/Roboto_SemiCondensed-Bold.ttf
static/Roboto_SemiCondensed-ExtraBold.ttf
static/Roboto_SemiCondensed-Black.ttf
static/Roboto-Thin.ttf
static/Roboto-ExtraLight.ttf
static/Roboto-Light.ttf
static/Roboto-Regular.ttf
static/Roboto-Medium.ttf
static/Roboto-SemiBold.ttf
static/Roboto-Bold.ttf
static/Roboto-ExtraBold.ttf
static/Roboto-Black.ttf
static/Roboto_Condensed-ThinItalic.ttf
static/Roboto_Condensed-ExtraLightItalic.ttf
static/Roboto_Condensed-LightItalic.ttf
static/Roboto_Condensed-Italic.ttf
static/Roboto_Condensed-MediumItalic.ttf
static/Roboto_Condensed-SemiBoldItalic.ttf
static/Roboto_Condensed-BoldItalic.ttf
static/Roboto_Condensed-ExtraBoldItalic.ttf
static/Roboto_Condensed-BlackItalic.ttf
static/Roboto_SemiCondensed-ThinItalic.ttf
static/Roboto_SemiCondensed-ExtraLightItalic.ttf
static/Roboto_SemiCondensed-LightItalic.ttf
static/Roboto_SemiCondensed-Italic.ttf
static/Roboto_SemiCondensed-MediumItalic.ttf
static/Roboto_SemiCondensed-SemiBoldItalic.ttf
static/Roboto_SemiCondensed-BoldItalic.ttf
static/Roboto_SemiCondensed-ExtraBoldItalic.ttf
static/Roboto_SemiCondensed-BlackItalic.ttf
static/Roboto-ThinItalic.ttf
static/Roboto-ExtraLightItalic.ttf
static/Roboto-LightItalic.ttf
static/Roboto-Italic.ttf
static/Roboto-MediumItalic.ttf
static/Roboto-SemiBoldItalic.ttf
static/Roboto-BoldItalic.ttf
static/Roboto-ExtraBoldItalic.ttf
static/Roboto-BlackItalic.ttf
Get started
-----------
1. Install the font files you want to use
2. Use your app's font picker to view the font family and all the
available styles
Learn more about variable fonts
-------------------------------
https://developers.google.com/web/fundamentals/design-and-ux/typography/variable-fonts
https://variablefonts.typenetwork.com
https://medium.com/variable-fonts
In desktop apps
https://theblog.adobe.com/can-variable-fonts-illustrator-cc
https://helpx.adobe.com/nz/photoshop/using/fonts.html#variable_fonts
Online
https://developers.google.com/fonts/docs/getting_started
https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Fonts/Variable_Fonts_Guide
https://developer.microsoft.com/en-us/microsoft-edge/testdrive/demos/variable-fonts
Installing fonts
MacOS: https://support.apple.com/en-us/HT201749
Linux: https://www.google.com/search?q=how+to+install+a+font+on+gnu%2Blinux
Windows: https://support.microsoft.com/en-us/help/314960/how-to-install-or-remove-a-font-in-windows
Android Apps
https://developers.google.com/fonts/docs/android
https://developer.android.com/guide/topics/ui/look-and-feel/downloadable-fonts
License
-------
Please read the full license text (OFL.txt) to understand the permissions,
restrictions and requirements for usage, redistribution, and modification.
You can use them in your products & projects print or digital,
commercial or otherwise.
This isn't legal advice, please consider consulting a lawyer and see the full
license for all details.
File diff suppressed because it is too large Load Diff

Before

Width:  |  Height:  |  Size: 657 KiB

File diff suppressed because it is too large Load Diff

Before

Width:  |  Height:  |  Size: 636 KiB

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