Compare commits
9 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| d3a152e177 | |||
| 515506e01e | |||
| 35763617b5 | |||
| 979df1205a | |||
|
|
d9b9748691 | ||
| 32892fb799 | |||
|
|
c6803710c6 | ||
| 2dfdc78c79 | |||
|
|
9d0ac66cdc |
@@ -9,7 +9,7 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
if: "!contains(github.event.head_commit.message, '[skip ci]')"
|
if: "!contains(github.event.head_commit.message, '[skip ci]')"
|
||||||
outputs:
|
outputs:
|
||||||
new_tag: ${{ steps.tag.outputs.new_tag }}
|
version: ${{ steps.version.outputs.version }}
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
@@ -21,42 +21,41 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
node-version: 24
|
node-version: 24
|
||||||
|
|
||||||
- name: Генерация ARCHITECTURE.md
|
- name: Версия из package.json
|
||||||
|
id: version
|
||||||
|
run: |
|
||||||
|
VERSION="v$(node -p "require('./package.json').version")"
|
||||||
|
echo "version=$VERSION" >> $GITHUB_OUTPUT
|
||||||
|
echo "Версия: $VERSION"
|
||||||
|
|
||||||
|
- name: Генерация docs
|
||||||
run: |
|
run: |
|
||||||
npm ci
|
npm ci
|
||||||
npm run docs
|
npm run docs
|
||||||
|
|
||||||
- name: Автоматический тег (semver patch)
|
- name: Коммит generated/
|
||||||
id: tag
|
|
||||||
run: |
|
run: |
|
||||||
LAST_TAG=$(git tag -l 'v*' --sort=-v:refname | head -1)
|
|
||||||
if [ -z "$LAST_TAG" ]; then
|
|
||||||
NEW_TAG="v0.1.0"
|
|
||||||
else
|
|
||||||
MAJOR=$(echo "$LAST_TAG" | cut -d. -f1)
|
|
||||||
MINOR=$(echo "$LAST_TAG" | cut -d. -f2)
|
|
||||||
PATCH=$(echo "$LAST_TAG" | cut -d. -f3)
|
|
||||||
NEW_TAG="${MAJOR}.${MINOR}.$((PATCH + 1))"
|
|
||||||
fi
|
|
||||||
git tag "$NEW_TAG"
|
|
||||||
git push origin "$NEW_TAG"
|
|
||||||
echo "new_tag=$NEW_TAG" >> $GITHUB_OUTPUT
|
|
||||||
echo "Создан тег: $NEW_TAG"
|
|
||||||
|
|
||||||
- name: Подставить URL с тегом и коммит
|
|
||||||
run: |
|
|
||||||
NEW_TAG=${{ steps.tag.outputs.new_tag }}
|
|
||||||
sed -i "s|raw/branch/main|raw/tag/${NEW_TAG}|g" README_RU.md
|
|
||||||
git config user.name "CI Bot"
|
git config user.name "CI Bot"
|
||||||
git config user.email "ci@gromlab.ru"
|
git config user.email "ci@gromlab.ru"
|
||||||
git add generated/ README_RU.md
|
git add generated/ README_RU.md
|
||||||
if git diff --cached --quiet; then
|
if git diff --cached --quiet; then
|
||||||
echo "Нет изменений, пропуск"
|
echo "Нет изменений, пропуск"
|
||||||
else
|
else
|
||||||
git commit -m "docs: обновить ARCHITECTURE.md и README (${NEW_TAG}) [skip ci]"
|
git commit -m "docs: обновить generated (${{ steps.version.outputs.version }}) [skip ci]"
|
||||||
git push origin main
|
git push origin main
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
- name: Создать тег
|
||||||
|
run: |
|
||||||
|
VERSION=${{ steps.version.outputs.version }}
|
||||||
|
if git tag -l "$VERSION" | grep -q "$VERSION"; then
|
||||||
|
echo "Тег $VERSION уже существует, пропуск"
|
||||||
|
else
|
||||||
|
git tag "$VERSION"
|
||||||
|
git push origin "$VERSION"
|
||||||
|
echo "Создан тег: $VERSION"
|
||||||
|
fi
|
||||||
|
|
||||||
docker:
|
docker:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: docs
|
needs: docs
|
||||||
@@ -93,7 +92,7 @@ jobs:
|
|||||||
type=ref,event=branch
|
type=ref,event=branch
|
||||||
type=sha,prefix=
|
type=sha,prefix=
|
||||||
type=raw,value=latest,enable={{is_default_branch}}
|
type=raw,value=latest,enable={{is_default_branch}}
|
||||||
type=raw,value=${{ needs.docs.outputs.new_tag }}
|
type=raw,value=${{ needs.docs.outputs.version }}
|
||||||
|
|
||||||
- name: Build and push
|
- name: Build and push
|
||||||
uses: docker/build-push-action@v5
|
uses: docker/build-push-action@v5
|
||||||
@@ -105,7 +104,7 @@ jobs:
|
|||||||
tags: ${{ steps.meta.outputs.tags }}
|
tags: ${{ steps.meta.outputs.tags }}
|
||||||
labels: ${{ steps.meta.outputs.labels }}
|
labels: ${{ steps.meta.outputs.labels }}
|
||||||
build-args: |
|
build-args: |
|
||||||
VERSION_TAG=${{ needs.docs.outputs.new_tag }}
|
VERSION_TAG=${{ needs.docs.outputs.version }}
|
||||||
provenance: false
|
provenance: false
|
||||||
sbom: false
|
sbom: false
|
||||||
|
|
||||||
@@ -134,31 +133,23 @@ jobs:
|
|||||||
IMAGE="${{ env.REGISTRY_IMAGE }}:latest"
|
IMAGE="${{ env.REGISTRY_IMAGE }}:latest"
|
||||||
CONTAINER="slm-design"
|
CONTAINER="slm-design"
|
||||||
|
|
||||||
# Логин в реестр
|
|
||||||
echo '${{ secrets.CR_TOKEN }}' | docker login ${{ env.DOCKER_REGISTRY }} -u '${{ secrets.CR_USER }}' --password-stdin
|
echo '${{ secrets.CR_TOKEN }}' | docker login ${{ env.DOCKER_REGISTRY }} -u '${{ secrets.CR_USER }}' --password-stdin
|
||||||
|
|
||||||
# Сохранить ID текущего образа до pull
|
|
||||||
OLD_IMAGE_ID=$(docker images -q "$IMAGE" 2>/dev/null || true)
|
OLD_IMAGE_ID=$(docker images -q "$IMAGE" 2>/dev/null || true)
|
||||||
|
|
||||||
# Скачать новый образ
|
|
||||||
docker pull "$IMAGE"
|
docker pull "$IMAGE"
|
||||||
|
|
||||||
# Перезапустить контейнер
|
|
||||||
docker stop "$CONTAINER" 2>/dev/null || true
|
docker stop "$CONTAINER" 2>/dev/null || true
|
||||||
docker rm "$CONTAINER" 2>/dev/null || true
|
docker rm "$CONTAINER" 2>/dev/null || true
|
||||||
docker run -d --name "$CONTAINER" --network web --restart unless-stopped "$IMAGE"
|
docker run -d --name "$CONTAINER" --network web --restart unless-stopped "$IMAGE"
|
||||||
|
|
||||||
# Удалить старый образ если он отличается от нового
|
|
||||||
NEW_IMAGE_ID=$(docker images -q "$IMAGE")
|
NEW_IMAGE_ID=$(docker images -q "$IMAGE")
|
||||||
if [ -n "$OLD_IMAGE_ID" ] && [ "$OLD_IMAGE_ID" != "$NEW_IMAGE_ID" ]; then
|
if [ -n "$OLD_IMAGE_ID" ] && [ "$OLD_IMAGE_ID" != "$NEW_IMAGE_ID" ]; then
|
||||||
docker rmi "$OLD_IMAGE_ID" 2>/dev/null || true
|
docker rmi "$OLD_IMAGE_ID" 2>/dev/null || true
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Очистка
|
|
||||||
docker image prune -af --filter "label=org.opencontainers.image.title=$CONTAINER"
|
docker image prune -af --filter "label=org.opencontainers.image.title=$CONTAINER"
|
||||||
docker image prune -f
|
docker image prune -f
|
||||||
docker builder prune -f 2>/dev/null || true
|
docker builder prune -f 2>/dev/null || true
|
||||||
|
|
||||||
# Статус
|
|
||||||
docker ps --filter "name=$CONTAINER"
|
docker ps --filter "name=$CONTAINER"
|
||||||
SCRIPT
|
SCRIPT
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
Scoped Layered Module Design — модульная архитектура фронтенд-приложений. Код организован по слоям ответственности, а модуль содержит всё, что ему нужно: компоненты, хуки, сторы, типы, стили.
|
Scoped Layered Module Design — модульная архитектура фронтенд-приложений. Код организован по слоям ответственности, а модуль содержит всё, что ему нужно: компоненты, хуки, сторы, типы, стили.
|
||||||
|
|
||||||
<!-- rules-link -->
|
<!-- rules-link -->
|
||||||
🤖 Для AI-ассистентов доступен единый файл правил: [gromlab.ru/.../raw/tag/v0.1.1/.../ARCHITECTURE.md](https://gromlab.ru/gromov/slm-design/raw/tag/v0.1.1/generated/ru/ARCHITECTURE.md)
|
🤖 Для AI-ассистентов доступен единый файл правил:<br>[https://gromlab.ru/gromov/slm-design/raw/tag/v0.1.5/generated/ru/ARCHITECTURE.md](https://gromlab.ru/gromov/slm-design/raw/tag/v0.1.5/generated/ru/ARCHITECTURE.md)
|
||||||
<!-- /rules-link -->
|
<!-- /rules-link -->
|
||||||
|
|
||||||
## Преимущества
|
## Преимущества
|
||||||
|
|||||||
12
concat-md.js
12
concat-md.js
@@ -73,6 +73,14 @@ const buildRules = (lang) => {
|
|||||||
buildRules("ru");
|
buildRules("ru");
|
||||||
buildRules("en");
|
buildRules("en");
|
||||||
|
|
||||||
|
// Версия из package.json
|
||||||
|
const pkg = JSON.parse(fs.readFileSync("./package.json", "utf8"));
|
||||||
|
const version = `v${pkg.version}`;
|
||||||
|
|
||||||
|
// Подставить версию в ссылки
|
||||||
|
const replaceVersion = (content) =>
|
||||||
|
content.replace(/raw\/branch\/main/g, `raw/tag/${version}`);
|
||||||
|
|
||||||
// Генерируем README из index.md
|
// Генерируем README из index.md
|
||||||
const buildReadme = (lang, outFile) => {
|
const buildReadme = (lang, outFile) => {
|
||||||
const indexPath = `./docs/${lang}/index.md`;
|
const indexPath = `./docs/${lang}/index.md`;
|
||||||
@@ -82,9 +90,9 @@ const buildReadme = (lang, outFile) => {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const content = stripFrontmatter(fs.readFileSync(indexPath, "utf8"));
|
const content = replaceVersion(stripFrontmatter(fs.readFileSync(indexPath, "utf8")));
|
||||||
fs.writeFileSync(outFile, content, "utf8");
|
fs.writeFileSync(outFile, content, "utf8");
|
||||||
console.log(`${outFile} создан из ${indexPath}`);
|
console.log(`${outFile} создан из ${indexPath} (${version})`);
|
||||||
};
|
};
|
||||||
|
|
||||||
buildReadme("ru", "./README_RU.md");
|
buildReadme("ru", "./README_RU.md");
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ title: SLM Design
|
|||||||
Scoped Layered Module Design — модульная архитектура фронтенд-приложений. Код организован по слоям ответственности, а модуль содержит всё, что ему нужно: компоненты, хуки, сторы, типы, стили.
|
Scoped Layered Module Design — модульная архитектура фронтенд-приложений. Код организован по слоям ответственности, а модуль содержит всё, что ему нужно: компоненты, хуки, сторы, типы, стили.
|
||||||
|
|
||||||
<!-- rules-link -->
|
<!-- rules-link -->
|
||||||
🤖 Для AI-ассистентов доступен единый файл правил: [gromlab.ru/.../raw/branch/main/.../ARCHITECTURE.md](https://gromlab.ru/gromov/slm-design/raw/branch/main/generated/ru/ARCHITECTURE.md)
|
🤖 Для AI-ассистентов доступен единый файл правил:<br>[https://gromlab.ru/gromov/slm-design/raw/branch/main/generated/ru/ARCHITECTURE.md](https://gromlab.ru/gromov/slm-design/raw/branch/main/generated/ru/ARCHITECTURE.md)
|
||||||
<!-- /rules-link -->
|
<!-- /rules-link -->
|
||||||
|
|
||||||
## Преимущества
|
## Преимущества
|
||||||
|
|||||||
4
package-lock.json
generated
4
package-lock.json
generated
@@ -1,11 +1,11 @@
|
|||||||
{
|
{
|
||||||
"name": "nextjs-style-guide",
|
"name": "slm-design",
|
||||||
"version": "0.0.0",
|
"version": "0.0.0",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "nextjs-style-guide",
|
"name": "slm-design",
|
||||||
"version": "0.0.0",
|
"version": "0.0.0",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"vitepress": "^1.6.3"
|
"vitepress": "^1.6.3"
|
||||||
|
|||||||
@@ -2,14 +2,13 @@
|
|||||||
"name": "slm-design",
|
"name": "slm-design",
|
||||||
"private": true,
|
"private": true,
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"version": "0.0.0",
|
"version": "0.1.5",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"docs": "node ./concat-md.js",
|
"docs": "node ./concat-md.js",
|
||||||
"dev": "vitepress dev .",
|
"dev": "vitepress dev .",
|
||||||
"build": "vitepress build .",
|
"build": "vitepress build .",
|
||||||
"serve": "vitepress serve ."
|
"serve": "vitepress serve ."
|
||||||
},
|
},
|
||||||
"dependencies": {},
|
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"vitepress": "^1.6.3"
|
"vitepress": "^1.6.3"
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user