chci-attendance-system Cursor Rules — Cursor Rules | Neura Market
    Neura MarketNeura Market/Cursor
    ChatGPTChatGPTClaudeClaudeGeminiGeminiCursorCursorGrokGrokPerplexityPerplexityDeepSeekDeepSeek
    CoPilotCoPilotStable DiffusionStable DiffusionMidjourneyMidjourney
    View All Directories
    OverviewRulesPromptsMCPsAgentsBlogVideosGuidesCoursesCommunityExtensionsTrendingGenerate
    CursorRuleschci-attendance-system Cursor Rules
    Back to Rules
    Frontend

    chci-attendance-system Cursor Rules

    kliea April 15, 2026
    0 copies 0 downloads

    It bridges ZKTeco biometric devices (via USB .dat file import) with a

    Rule Content
    # Klinth — Cursor IDE Rules
    # Team Attendance System | Vue 3 + Supabase | MVP Beta
    
    ## Project Identity
    You are building **Klinth**, a minimal web-based team attendance system.
    It bridges ZKTeco biometric devices (via USB .dat file import) with a
    real-time web dashboard powered by Vue 3 and Supabase.
    
    ## Tech Stack
    - **Frontend:** Vue 3 (Composition API + <script setup>), Vite
    - **State:** Pinia
    - **Routing:** Vue Router 4
    - **UI:** Tailwind CSS (utility-first, no component framework)
    - **Backend:** Supabase (PostgreSQL, Auth, Realtime, RLS)
    - **File Parsing:** Custom ZKTeco .dat parser (binary + text)
    - **Language:** JavaScript (no TypeScript unless explicitly requested)
    
    ## Database (already migrated — do not re-create tables)
    Tables in Supabase:
    - `userrole` — id, role_name
    - `users` — id (uuid, FK auth.users), username, email, fname, minit, lname,
                 age, hours_rendered, bio_id, userrole_id, is_active
    - `attendance` — attendance_id, user_id, date, time_in, time_out,
                     overtime_in, overtime_out, undertime, status
    - `rectification_requests` — id, user_id, attendance_id, rectification_title,
                                  description, rectification_type, date, reviewed_by
    - `holidays` — id, holiday_name, holiday_type, date
    
    ## Supabase Client
    - Always import from `@/lib/supabase.js`
    - Never expose service role keys in frontend code
    - Always handle Supabase errors explicitly: `const { data, error } = await supabase...`
    
    ## Code Style
    - Use `<script setup>` syntax for all Vue components
    - Use `async/await` over `.then()` chains
    - Keep components focused — one responsibility per component
    - Composables go in `src/composables/use<Name>.js`
    - Stores go in `src/stores/<name>.js` using Pinia `defineStore`
    - No inline styles — Tailwind classes only
    - Prefer `const` over `let`; never use `var`
    - Always validate file input before parsing
    
    ## Naming Conventions
    - Components: PascalCase (e.g. `AttendanceTable.vue`)
    - Composables: camelCase prefixed with `use` (e.g. `useZkParser.js`)
    - Stores: camelCase (e.g. `useAttendanceStore`)
    - Database columns: snake_case (match Supabase schema exactly)
    - Frontend variables: camelCase
    
    ## ZKTeco .dat File Rules
    - There are TWO file types: user data and attendance logs
    - User .dat: fixed-width text, fields — PIN, Name, Password, Card, Role
    - Attendance .dat: fixed-width text, fields — PIN, Date(YYYY-MM-DD), Time(HH:MM:SS), Verify, In/Out
    - Always parse line by line, skip empty or malformed lines silently
    - Match parsed users to `users.bio_id` before upserting attendance
    - Use `upsert` with `onConflict` to avoid duplicate records
    - Never overwrite a `time_out` if it already exists and incoming is `time_in`
    
    ## Import Flow (strict order)
    1. User uploads .dat file via `DatImportView.vue`
    2. `useZkParser.js` reads and classifies the file (user or attendance)
    3. Parsed records are previewed in a table before any DB write
    4. On confirm, `useImportStore.js` upserts to Supabase in batches of 50
    5. Show per-record success/error feedback after import
    
    ## Component Structure Reminder
    src/
    ├── lib/supabase.js
    ├── router/index.js
    ├── stores/
    │   ├── auth.js
    │   ├── attendance.js
    │   └── import.js
    ├── composables/
    │   ├── useZkParser.js
    │   └── useAttendance.js
    ├── views/
    │   ├── auth/LoginView.vue
    │   ├── admin/DashboardView.vue
    │   ├── admin/ImportView.vue
    │   ├── admin/EmployeesView.vue
    │   ├── admin/ReportsView.vue
    │   └── employee/MyAttendanceView.vue
    └── components/
        ├── import/FileDropzone.vue
        ├── import/ParsePreviewTable.vue
        ├── import/ImportSummary.vue
        ├── attendance/AttendanceTable.vue
        ├── attendance/StatusBadge.vue
        └── layout/AppSidebar.vue
    
    ## Do Not
    - Do not use Options API
    - Do not use Vuex (use Pinia only)
    - Do not use any CSS framework other than Tailwind
    - Do not create new Supabase tables — schema is already set
    - Do not store raw passwords anywhere in the frontend
    - Do not import .dat files larger than 10MB without chunking
    - Do not skip the preview step before DB writes
    

    Tags

    vuetypescriptgotailwindcsssupabase

    Comments

    More Rules

    View all
    Web Development

    Next.js 15 + TypeScript Cursor Rules

    Comprehensive .cursorrules file for Next.js 15 App Router projects with TypeScript, enforcing server components by default, proper use of "use client" directive, and App Router conventions.

    C
    Community
    Backend Development

    Python FastAPI Best Practices Rules

    Cursor rules for Python FastAPI projects enforcing async patterns, Pydantic v2 models, dependency injection, and proper error handling.

    C
    Community
    Frontend Development

    React + TypeScript Component Rules

    Rules for consistent React component development with TypeScript interfaces, proper hook patterns, and component composition.

    C
    Community
    AI/ML

    Cursor Agent Mode Configuration

    Rules optimizing Cursor Agent mode behavior including multi-file editing context, session management, and autonomous task completion patterns.

    C
    Cursor Team
    Frontend Development

    Tailwind CSS + shadcn/ui Rules

    Cursor rules for projects using Tailwind CSS with shadcn/ui component library, enforcing consistent utility class usage and component patterns.

    C
    Community
    Backend Development

    Go Backend Service Rules

    Rules for Go backend services enforcing idiomatic Go patterns, proper error handling, and clean architecture conventions.

    C
    Community

    Stay up to date

    Get the latest Cursor prompts, rules, and resources delivered to your inbox weekly.

    Neura Market LogoNeura Market

    Discover the best AI prompts, plugins, and resources for Cursor and more.

    Content Types

    • Rules
    • Prompts
    • MCPs
    • Agents
    • Guides

    Platforms

    • ChatGPT Directory
    • Claude Directory
    • Gemini Directory
    • Cursor Directory
    • Grok Directory
    • Perplexity Directory
    • DeepSeek Directory
    • CoPilot Directory
    • Stable Diffusion Directory
    • Midjourney Directory
    • All Directories

    Resources

    • Blog
    • Documentation
    • Help Center
    • Marketplace

    Legal

    • Privacy Policy
    • Terms of Service

    © 2026 Neura Market. All rights reserved.

    |

    Not affiliated with any AI platform vendors.