Публичная версия Portal
Go to file
2025-06-19 17:50:02 +03:00
.github T: Add telegram reporting 2025-03-20 16:17:28 +03:00
.vscode M: Small fixes 2025-05-29 15:38:57 +03:00
nginx F: Enable caching for generated assets 2025-03-20 14:13:25 +03:00
postgresql Setup dev and prod configurations for docker 2023-08-29 00:34:56 +03:00
rsconcept M: Minor UI fixes 2025-06-19 17:50:02 +03:00
scripts R: Fix build action sequence 2025-03-06 21:34:02 +03:00
.cursorignore R: Migrating to cursor IDE 2025-06-17 19:47:07 +03:00
.dockerignore Refactoring: improving backend 2024-07-22 21:20:51 +03:00
.gitignore R: Integrate Playwright as end-to-end testing 2025-01-14 16:25:05 +03:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2024-04-08 11:57:13 +03:00
docker-compose-dev.yml Add missing dependency 2024-03-15 14:40:47 +03:00
docker-compose-prod-local.yml Fix builds 2024-06-04 01:43:04 +03:00
docker-compose-prod.yml Fix builds 2024-06-04 01:43:04 +03:00
LICENSE Update LICENSE 2024-04-14 15:37:26 +03:00
README.md F: Improve color and animation styling 2025-04-16 15:22:31 +03:00
SECURITY.md Create SECURITY.md 2024-04-08 11:54:51 +03:00
TODO.txt F: Improve node UI context menu 2025-04-22 23:42:13 +03:00



Backend CI Frontend CI Uptime Robot status

React + Django based web portal for editing RSForm schemas. This readme file is used mostly to document project dependencies and conventions.

❤️ Contributing notes

  • feel free to open issues, discussion topics, contact maintainer directly
  • use Test config in VSCode to run tests before pushing commits / requests
  • use github actions to setup linter checks and test builds
  • use conventional commits to describe changes

Frontend [Vite + React + Typescript]

  • to regenerate parsers use 'npm run generate' script
npm install
  - axios
  - clsx
  - react-icons
  - react-router
  - react-toastify
  - react-tabs
  - react-intl
  - react-error-boundary
  - react-tooltip
  - react-zoom-pan-pinch
  - react-hook-form
  - react-scan
  - reactflow
  - js-file-download
  - use-debounce
  - qrcode.react
  - zustand
  - zod
  - @hookform/resolvers
  - @tanstack/react-table
  - @tanstack/react-query
  - @tanstack/react-query-devtools
  - @uiw/react-codemirror
  - @uiw/codemirror-themes
  - @lezer/lr
  - @dagrejs/dagre
  
npm install -D
  - tailwindcss
  - eslint-plugin-import
  - eslint-plugin-react-compiler
  - eslint-plugin-simple-import-sort
  - eslint-plugin-react-hooks
  - eslint-plugin-tsdoc
  - eslint-plugin-playwright
  - babel-plugin-react-compiler
  - vite
  - jest
  - shadcn
  - ts-jest
  - stylelint
  - stylelint-config-recommended
  - stylelint-config-standard
  - stylelint-config-tailwindcss
  - @vitejs/plugin-react
  - @types/jest
  - @lezer/generator
  - @playwright/test
  
VS Code plugins
  - ESLint
  - Oklch Color Preview
  - Tailwind CSS IntelliSense
  - Code Spell Checker (eng + rus)
  - Backticks
  - Svg Preview
  - TODO Highlight v2
  - Prettier
  - PowerShell (for Windows dev env)
  
Google fonts
  - Fira Code
  - Rubik
  - Alegreya Sans SC
  - Noto Sans Math
  - Noto Sans Symbol
  - Noto Color Emoji
  

🗃️ Backend [Django + PostgreSQL/SQLite]

requirements
  - django
  - djangorestframework
  - django-cors-headers
  - django-filter
  - drf-spectacular
  - tzdata
  - gunicorn
  - coreapi
  - psycopg2-binary
  - cctext
  - pyconcept
  
requirements-dev
  - coverage
  - pylint
  - mypy
  - djangorestframework-stubs[compatible-mypy]
  
VS Code plugins
  - Pylance
  - Pylint
  - autopep8
  - isort
  - Django
  - SQLite
  - Playwright
  

⚙️ DevOps

  • Docker compose
  • PowerShell
  • Certbot
  • Docker VSCode extension

Developer Notes

📝 Commit conventions

  • 🚀 F: major feature implementation
  • 🔥 B: bug fix
  • 🚑 M: Minor fixes
  • 🔧 R: refactoring and code improvement
  • 📝 D: documentation

🖥️ Local build (Windows 10+)

This is the build for local Development

  • Install Python 3.12, NodeJS, VSCode, Docker Desktop
  • copy import wheels from ConceptCore to rsconcept/backend/import
  • run scripts/dev/LocalEnvSetup.ps1
  • use VSCode configs in root folder to start development
  • use 'npm run prepare' to regenerate frontend parsers (if you change grammar files)

🔭 Local docker build

This build does not use HTTPS and nginx for networking

  • backend and frontend debugging is supported
  • hmr (hot updates) for frontend
  • run via 'docker compose -f "docker-compose-dev.yml" up --build -d'
  • populate initial data: 'scripts/dev/PopulateDevData.ps1'

📦 Local production build

This build is same as production except not using production secrets and working on localhost

  • provide TLS certificate (can be self-signed) 'nginx/cert/local-cert.pem' and 'nginx/cert/local-key.pem'
  • run via 'docker compose -f "docker-compose-prod-local.yml" up --build -d'

🔥 Production build

This build is deployed on server.

  • provide secrets: 'secrets/db_password.txt', 'django_key.txt', 'email_host.txt', 'email_password.txt', 'email_user.txt'
  • check if you need to change SSL/TLS and PORT in 'rsconcept\backend.env.prod'
  • setup domain names for application and API in configs: 'frontend\env.env.production', 'rsconcept\backend.env.dev', 'nginx\production.conf'
  • provide privacy policy document in PDF: 'frontend/public/privacy.pdf'
  • use certbot to obtain certificates via 'docker compose -f "docker-compose-prod.yml" run --rm certbot certonly --webroot --webroot-path /var/www/certbot/ -d portal.acconcept.ru api.portal.acconcept.ru'
  • run via 'docker compose -f "docker-compose-prod.yml" up --build -d'
  • update via 'bash scripts/prod/UpdateProd.sh'