mirror of
https://github.com/opensourcepos/opensourcepos.git
synced 2026-05-25 08:44:42 -04:00
Compare commits
15 Commits
feature/ap
...
feature/ub
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
86e150ad96 | ||
|
|
8f4055c711 | ||
|
|
3c25fd77e2 | ||
|
|
3f7ea18f18 | ||
|
|
36bf130bdd | ||
|
|
088ad47c99 | ||
|
|
808840b2e9 | ||
|
|
2ed74c5c0e | ||
|
|
c935fc7a2a | ||
|
|
89012054b4 | ||
|
|
89572aa289 | ||
|
|
2b56d56072 | ||
|
|
2fc9fc09a4 | ||
|
|
932b612c9e | ||
|
|
ab6e8ee083 |
33
.github/workflows/opencode.yml
vendored
33
.github/workflows/opencode.yml
vendored
@@ -1,33 +0,0 @@
|
||||
name: opencode
|
||||
|
||||
on:
|
||||
issue_comment:
|
||||
types: [created]
|
||||
pull_request_review_comment:
|
||||
types: [created]
|
||||
|
||||
jobs:
|
||||
opencode:
|
||||
if: |
|
||||
contains(github.event.comment.body, ' /oc') ||
|
||||
startsWith(github.event.comment.body, '/oc') ||
|
||||
contains(github.event.comment.body, ' /opencode') ||
|
||||
startsWith(github.event.comment.body, '/opencode')
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
id-token: write
|
||||
contents: read
|
||||
pull-requests: read
|
||||
issues: read
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v6
|
||||
with:
|
||||
persist-credentials: false
|
||||
|
||||
- name: Run opencode
|
||||
uses: anomalyco/opencode/github@latest
|
||||
env:
|
||||
ANTHROPIC_API_KEY: ${{ secrets.ANTHROPIC_API_KEY }}
|
||||
with:
|
||||
model: anthropic/claude-3-haiku-20240307
|
||||
118
.github/workflows/phpunit.yml
vendored
118
.github/workflows/phpunit.yml
vendored
@@ -1,118 +0,0 @@
|
||||
name: PHPUnit Tests
|
||||
|
||||
on:
|
||||
push:
|
||||
paths:
|
||||
- '**.php'
|
||||
- 'spark'
|
||||
- 'tests/**'
|
||||
- '.github/workflows/phpunit.yml'
|
||||
- 'gulpfile.js'
|
||||
- 'app/Database/**'
|
||||
pull_request:
|
||||
paths:
|
||||
- '**.php'
|
||||
- 'spark'
|
||||
- 'tests/**'
|
||||
- '.github/workflows/phpunit.yml'
|
||||
- 'gulpfile.js'
|
||||
- 'app/Database/**'
|
||||
|
||||
concurrency:
|
||||
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
|
||||
cancel-in-progress: true
|
||||
|
||||
permissions:
|
||||
contents: read
|
||||
|
||||
jobs:
|
||||
test:
|
||||
name: PHP ${{ matrix.php-version }} Tests
|
||||
runs-on: ubuntu-22.04
|
||||
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
php-version:
|
||||
- '8.1'
|
||||
- '8.2'
|
||||
- '8.3'
|
||||
- '8.4'
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Setup PHP
|
||||
uses: shivammathur/setup-php@v2
|
||||
with:
|
||||
php-version: ${{ matrix.php-version }}
|
||||
extensions: intl, mbstring, mysqli
|
||||
coverage: none
|
||||
|
||||
- name: Setup Node.js
|
||||
uses: actions/setup-node@v4
|
||||
with:
|
||||
node-version: '20'
|
||||
|
||||
- name: Get npm cache directory
|
||||
run: echo "NPM_CACHE_DIR=$(npm config get cache)" >> $GITHUB_ENV
|
||||
|
||||
- name: Cache npm dependencies
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: ${{ env.NPM_CACHE_DIR }}
|
||||
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
|
||||
restore-keys: |
|
||||
${{ runner.os }}-node-
|
||||
|
||||
- name: Install npm dependencies
|
||||
run: npm install
|
||||
|
||||
- name: Build database.sql
|
||||
run: npm run gulp build-database
|
||||
|
||||
- name: Start MariaDB
|
||||
run: |
|
||||
docker run -d --name mysql \
|
||||
-e MYSQL_ROOT_PASSWORD=root \
|
||||
-e MYSQL_DATABASE=ospos \
|
||||
-e MYSQL_USER=admin \
|
||||
-e MYSQL_PASSWORD=pointofsale \
|
||||
-v $PWD/app/Database/database.sql:/docker-entrypoint-initdb.d/database.sql \
|
||||
-p 3306:3306 \
|
||||
mariadb:10.5
|
||||
# Wait for MariaDB to be ready
|
||||
until docker exec mysql mysqladmin ping -h 127.0.0.1 -u root -proot --silent; do
|
||||
echo "Waiting for MariaDB..."
|
||||
sleep 2
|
||||
done
|
||||
echo "MariaDB is ready!"
|
||||
|
||||
- name: Get composer cache directory
|
||||
run: echo "COMPOSER_CACHE_FILES_DIR=$(composer config cache-files-dir)" >> $GITHUB_ENV
|
||||
|
||||
- name: Cache dependencies
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: ${{ env.COMPOSER_CACHE_FILES_DIR }}
|
||||
key: ${{ runner.os }}-${{ matrix.php-version }}-${{ hashFiles('**/composer.lock') }}
|
||||
restore-keys: |
|
||||
${{ runner.os }}-${{ matrix.php-version }}-
|
||||
${{ runner.os }}-
|
||||
|
||||
- name: Install dependencies
|
||||
run: composer update --ansi --no-interaction
|
||||
|
||||
- name: Create .env file
|
||||
run: cp .env.example .env
|
||||
|
||||
- name: Run PHPUnit tests
|
||||
env:
|
||||
CI_ENVIRONMENT: testing
|
||||
MYSQL_HOST_NAME: 127.0.0.1
|
||||
run: composer test
|
||||
|
||||
- name: Stop MariaDB
|
||||
if: always()
|
||||
run: docker stop mysql && docker rm mysql
|
||||
116
.github/workflows/unit-tests.yml
vendored
Normal file
116
.github/workflows/unit-tests.yml
vendored
Normal file
@@ -0,0 +1,116 @@
|
||||
name: Unit Tests
|
||||
|
||||
on:
|
||||
push:
|
||||
paths:
|
||||
- 'app/**/*.php'
|
||||
- 'tests/**/*.php'
|
||||
- '.github/workflows/unit-tests.yml'
|
||||
pull_request:
|
||||
paths:
|
||||
- 'app/**/*.php'
|
||||
- 'tests/**/*.php'
|
||||
- '.github/workflows/unit-tests.yml'
|
||||
|
||||
concurrency:
|
||||
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
|
||||
cancel-in-progress: true
|
||||
|
||||
permissions:
|
||||
contents: read
|
||||
|
||||
jobs:
|
||||
test:
|
||||
name: PHP ${{ matrix.php-version }} Unit Tests
|
||||
runs-on: ubuntu-22.04
|
||||
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
php-version:
|
||||
- '8.1'
|
||||
- '8.2'
|
||||
- '8.3'
|
||||
|
||||
services:
|
||||
mysql:
|
||||
image: mysql:8.0
|
||||
env:
|
||||
MYSQL_ROOT_PASSWORD: root
|
||||
MYSQL_DATABASE: ospos_test
|
||||
MYSQL_USER: ospos
|
||||
MYSQL_PASSWORD: ospos
|
||||
ports:
|
||||
- 3306:3306
|
||||
options: >-
|
||||
--health-cmd="mysqladmin ping --silent"
|
||||
--health-interval=10s
|
||||
--health-timeout=5s
|
||||
--health-retries=5
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Setup PHP
|
||||
uses: shivammathur/setup-php@v2
|
||||
with:
|
||||
php-version: ${{ matrix.php-version }}
|
||||
extensions: intl, mysqli, pdo_mysql, mbstring, json, dom, xml
|
||||
coverage: xdebug
|
||||
|
||||
- name: Get composer cache directory
|
||||
run: echo "COMPOSER_CACHE_FILES_DIR=$(composer config cache-files-dir)" >> $GITHUB_ENV
|
||||
|
||||
- name: Cache dependencies
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: ${{ env.COMPOSER_CACHE_FILES_DIR }}
|
||||
key: ${{ runner.os }}-${{ matrix.php-version }}-${{ hashFiles('**/composer.lock') }}
|
||||
restore-keys: |
|
||||
${{ runner.os }}-${{ matrix.php-version }}-
|
||||
${{ runner.os }}-
|
||||
|
||||
- name: Install dependencies
|
||||
run: composer install --no-progress --ansi --no-interaction
|
||||
|
||||
- name: Wait for MySQL
|
||||
run: |
|
||||
while ! mysqladmin ping -h"127.0.0.1" --silent; do
|
||||
echo "Waiting for MySQL..."
|
||||
sleep 1
|
||||
done
|
||||
|
||||
- name: Setup test database
|
||||
run: |
|
||||
mysql -h 127.0.0.1 -u root -proot -e "CREATE DATABASE IF NOT EXISTS ospos_test CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;"
|
||||
mysql -h 127.0.0.1 -u root -proot -e "GRANT ALL PRIVILEGES ON ospos_test.* TO 'ospos'@'%' IDENTIFIED BY 'ospos';"
|
||||
mysql -h 127.0.0.1 -u root -proot -e "FLUSH PRIVILEGES;"
|
||||
|
||||
- name: Copy test environment config
|
||||
run: |
|
||||
if [ -f ".env.testing" ]; then
|
||||
cp .env.testing .env
|
||||
else
|
||||
cp .env.example .env
|
||||
fi
|
||||
|
||||
- name: Run migrations
|
||||
run: php spark migrate --all || true
|
||||
|
||||
- name: Run unit tests
|
||||
run: vendor/bin/phpunit --configuration tests/phpunit.xml --testsuite Helpers,Models,Controllers --colors=always --verbose
|
||||
|
||||
- name: Generate test report
|
||||
if: always()
|
||||
run: |
|
||||
vendor/bin/phpunit --configuration tests/phpunit.xml --testsuite Helpers,Models,Controllers --log-junit build/logs/junit.xml --coverage-clover build/logs/clover.xml || true
|
||||
echo "Test run completed"
|
||||
|
||||
- name: Upload test results
|
||||
if: always()
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: test-results-php-${{ matrix.php-version }}
|
||||
path: build/logs/
|
||||
retention-days: 30
|
||||
@@ -28,7 +28,7 @@ script:
|
||||
env:
|
||||
global:
|
||||
- BRANCH=$(echo ${TRAVIS_BRANCH} | sed s/feature\\///)
|
||||
- TAG=$(echo "${TRAVIS_TAG:-$BRANCH}" | tr '/' '-')
|
||||
- TAG=${TRAVIS_TAG:-$BRANCH}
|
||||
- date=`date +%Y%m%d%H%M%S` && branch=${TRAVIS_BRANCH} && rev=`git rev-parse --short=6 HEAD`
|
||||
after_success:
|
||||
- docker login -u="$DOCKER_USERNAME" -p="$DOCKER_PASSWORD" && docker tag "ospos:latest"
|
||||
|
||||
295
API.md
295
API.md
@@ -1,295 +0,0 @@
|
||||
# OSPOS REST API Design
|
||||
|
||||
This document describes the proposed REST API for Open Source Point of Sale (OSPOS).
|
||||
|
||||
## Overview
|
||||
|
||||
The OSPOS REST API provides programmatic access to:
|
||||
|
||||
- **Customers** - Full CRUD operations
|
||||
- **Suppliers** - Full CRUD operations
|
||||
- **Items** - Full CRUD operations
|
||||
- **Inventory** - Stock adjustments (update only)
|
||||
- **Sales** - Read-only queries
|
||||
- **Receivings** - Read-only queries
|
||||
|
||||
## Authentication
|
||||
|
||||
All API endpoints require authentication via an API Key passed in the `X-API-Key` header.
|
||||
|
||||
```
|
||||
X-API-Key: your-api-key-here
|
||||
```
|
||||
|
||||
> **Note:** API Key authentication implementation will be added in a subsequent phase. The spec documents the intended authentication mechanism.
|
||||
|
||||
## Base URL
|
||||
|
||||
All API endpoints are relative to `/api/v1`.
|
||||
|
||||
```
|
||||
https://your-domain.com/api/v1/customers
|
||||
```
|
||||
|
||||
## Pagination
|
||||
|
||||
List endpoints support pagination using `offset` and `limit` query parameters:
|
||||
|
||||
| Parameter | Type | Default | Maximum | Description |
|
||||
|-----------|---------|---------|---------|------------------------------|
|
||||
| `offset` | integer | 0 | - | Number of records to skip |
|
||||
| `limit` | integer | 25 | 100 | Number of records to return |
|
||||
|
||||
**Example Request:**
|
||||
```
|
||||
GET /api/v1/customers?offset=0&limit=25
|
||||
```
|
||||
|
||||
**Example Response:**
|
||||
```json
|
||||
{
|
||||
"total": 150,
|
||||
"offset": 0,
|
||||
"limit": 25,
|
||||
"rows": [
|
||||
{ "person_id": 1, "first_name": "John", ... },
|
||||
{ "person_id": 2, "first_name": "Jane", ... }
|
||||
]
|
||||
}
|
||||
```
|
||||
|
||||
## Response Format
|
||||
|
||||
### Success Response
|
||||
|
||||
```json
|
||||
{
|
||||
"success": true,
|
||||
"message": "Customer created successfully",
|
||||
"id": 42
|
||||
}
|
||||
```
|
||||
|
||||
### Error Response
|
||||
|
||||
```json
|
||||
{
|
||||
"success": false,
|
||||
"message": "Error description here"
|
||||
}
|
||||
```
|
||||
|
||||
### HTTP Status Codes
|
||||
|
||||
| Status Code | Description |
|
||||
|-------------|--------------------------------------------------|
|
||||
| 200 | Success |
|
||||
| 201 | Resource created successfully |
|
||||
| 400 | Bad request / Invalid input |
|
||||
| 401 | Unauthorized / Invalid API key |
|
||||
| 404 | Resource not found |
|
||||
| 409 | Conflict (e.g., duplicate unique field) |
|
||||
| 500 | Internal server error |
|
||||
|
||||
## Endpoints Summary
|
||||
|
||||
### Customers
|
||||
|
||||
| Method | Endpoint | Description | Access |
|
||||
|--------|-------------------------------|--------------------------------|---------|
|
||||
| GET | `/customers` | List customers | Read |
|
||||
| POST | `/customers` | Create customer | Write |
|
||||
| GET | `/customers/{id}` | Get customer by ID | Read |
|
||||
| PUT | `/customers/{id}` | Update customer | Write |
|
||||
| DELETE | `/customers/{id}` | Delete customer (soft delete) | Write |
|
||||
| POST | `/customers/batch-delete` | Delete multiple customers | Write |
|
||||
| GET | `/customers/suggest` | Autocomplete suggestions | Read |
|
||||
|
||||
### Suppliers
|
||||
|
||||
| Method | Endpoint | Description | Access |
|
||||
|--------|-------------------------------|--------------------------------|---------|
|
||||
| GET | `/suppliers` | List suppliers | Read |
|
||||
| POST | `/suppliers` | Create supplier | Write |
|
||||
| GET | `/suppliers/{id}` | Get supplier by ID | Read |
|
||||
| PUT | `/suppliers/{id}` | Update supplier | Write |
|
||||
| DELETE | `/suppliers/{id}` | Delete supplier (soft delete) | Write |
|
||||
| POST | `/suppliers/batch-delete` | Delete multiple suppliers | Write |
|
||||
| GET | `/suppliers/suggest` | Autocomplete suggestions | Read |
|
||||
|
||||
### Items
|
||||
|
||||
| Method | Endpoint | Description | Access |
|
||||
|--------|-------------------------------|--------------------------------|---------|
|
||||
| GET | `/items` | List items | Read |
|
||||
| POST | `/items` | Create item | Write |
|
||||
| GET | `/items/{id}` | Get item by ID | Read |
|
||||
| PUT | `/items/{id}` | Update item | Write |
|
||||
| DELETE | `/items/{id}` | Delete item (soft delete) | Write |
|
||||
| POST | `/items/batch-delete` | Delete multiple items | Write |
|
||||
| POST | `/items/batch-update` | Update multiple items | Write |
|
||||
| GET | `/items/suggest` | Autocomplete suggestions | Read |
|
||||
| GET | `/items/{id}/quantities` | Get stock quantities | Read |
|
||||
|
||||
### Inventory
|
||||
|
||||
| Method | Endpoint | Description | Access |
|
||||
|--------|-------------------------------|--------------------------------|---------|
|
||||
| GET | `/inventory` | List inventory transactions | Read |
|
||||
| POST | `/inventory` | Create inventory adjustment | Write |
|
||||
| POST | `/inventory/bulk` | Bulk inventory adjustments | Write |
|
||||
|
||||
### Sales (Read-Only)
|
||||
|
||||
| Method | Endpoint | Description | Access |
|
||||
|--------|-------------------------------|--------------------------------|---------|
|
||||
| GET | `/sales` | List sales | Read |
|
||||
| GET | `/sales/{id}` | Get sale details | Read |
|
||||
| GET | `/sales/{id}/items` | Get sale items | Read |
|
||||
| GET | `/sales/{id}/payments` | Get sale payments | Read |
|
||||
|
||||
### Receivings (Read-Only)
|
||||
|
||||
| Method | Endpoint | Description | Access |
|
||||
|--------|-------------------------------|--------------------------------|---------|
|
||||
| GET | `/receivings` | List receivings | Read |
|
||||
| GET | `/receivings/{id}` | Get receiving details | Read |
|
||||
| GET | `/receivings/{id}/items` | Get receiving items | Read |
|
||||
|
||||
## Schema Reference
|
||||
|
||||
### Common Fields
|
||||
|
||||
#### Person Fields (base for Customer, Supplier)
|
||||
|
||||
| Field | Type | Description |
|
||||
|---------------|-----------|------------------------------|
|
||||
| `first_name` | string | First name (required) |
|
||||
| `last_name` | string | Last name (required) |
|
||||
| `gender` | integer | Gender (0=male, 1=female) |
|
||||
| `phone_number`| string | Phone number |
|
||||
| `email` | string | Email address |
|
||||
| `address_1` | string | Address line 1 |
|
||||
| `address_2` | string | Address line 2 |
|
||||
| `city` | string | City |
|
||||
| `state` | string | State/Province |
|
||||
| `zip` | string | Postal/ZIP code |
|
||||
| `country` | string | Country |
|
||||
| `comments` | string | Additional notes |
|
||||
|
||||
### Customer Fields
|
||||
|
||||
Extends Person fields with:
|
||||
|
||||
| Field | Type | Description |
|
||||
|--------------------|-----------|------------------------------------|
|
||||
| `person_id` | integer | Unique identifier (read-only) |
|
||||
| `account_number` | string | Customer account number |
|
||||
| `taxable` | integer | Taxable status (0/1) |
|
||||
| `tax_id` | string | Tax identification number |
|
||||
| `sales_tax_code_id`| integer | Sales tax code ID |
|
||||
| `discount` | decimal | Discount percentage/amount |
|
||||
| `discount_type` | integer | Discount type (0=percent, 1=fixed) |
|
||||
| `company_name` | string | Company name |
|
||||
| `package_id` | integer | Rewards package ID |
|
||||
| `points` | integer | Rewards points balance |
|
||||
| `consent` | integer | Consent status (0/1) |
|
||||
|
||||
### Supplier Fields
|
||||
|
||||
Extends Person fields with:
|
||||
|
||||
| Field | Type | Description |
|
||||
|-----------------|-----------|-------------------------------------|
|
||||
| `person_id` | integer | Unique identifier (read-only) |
|
||||
| `company_name` | string | Company name |
|
||||
| `account_number`| string | Supplier account number |
|
||||
| `tax_id` | string | Tax identification number |
|
||||
| `agency_name` | string | Agency name |
|
||||
| `category` | integer | Category (0=goods, 1=cost) |
|
||||
|
||||
### Item Fields
|
||||
|
||||
| Field | Type | Required | Description |
|
||||
|----------------------|-----------|----------|--------------------------------------|
|
||||
| `item_id` | integer | auto | Unique identifier (read-only) |
|
||||
| `name` | string | yes | Item name |
|
||||
| `category` | string | yes | Item category |
|
||||
| `supplier_id` | integer | no | Supplier ID |
|
||||
| `item_number` | string | no | Barcode/SKU |
|
||||
| `description` | string | no | Item description |
|
||||
| `cost_price` | decimal | no | Cost price |
|
||||
| `unit_price` | decimal | yes | Selling price |
|
||||
| `reorder_level` | decimal | no | Reorder threshold |
|
||||
| `receiving_quantity` | decimal | no | Receiving quantity (default 1) |
|
||||
| `allow_alt_description`| integer | no | Allow alt description (0/1) |
|
||||
| `is_serialized` | integer | no | Has serial number (0/1) |
|
||||
| `stock_type` | integer | no | Stock type (0=stocked, 1=non-stocked)|
|
||||
| `item_type` | integer | no | Item type (0=standard, 1=kit, 2=temp)|
|
||||
| `tax_category_id` | integer | no | Tax category ID |
|
||||
| `qty_per_pack` | decimal | no | Quantity per pack |
|
||||
| `pack_name` | string | no | Pack name |
|
||||
| `hsn_code` | string | no | HSN code |
|
||||
|
||||
### Inventory Adjustment
|
||||
|
||||
| Field | Type | Required | Description |
|
||||
|------------------|-----------|----------|--------------------------------------|
|
||||
| `item_id` | integer | yes | Item ID to adjust |
|
||||
| `trans_inventory`| decimal | yes | Quantity change (+ add, - remove) |
|
||||
| `trans_location` | integer | no | Stock location ID |
|
||||
| `trans_comment` | string | no | Reason for adjustment |
|
||||
|
||||
## OpenAPI Specification
|
||||
|
||||
The complete OpenAPI 3.1.0 specification is available at:
|
||||
|
||||
- **YAML format:** `/public/api/openapi.yaml`
|
||||
|
||||
This specification can be used with:
|
||||
- [Swagger UI](https://swagger.io/tools/swagger-ui/) for interactive documentation
|
||||
- [Swagger Codegen](https://swagger.io/tools/swagger-codegen/) to generate client SDKs
|
||||
- [OpenAPI Generator](https://openapi-generator.tech/) for code generation
|
||||
- API testing tools like Postman or Insomnia
|
||||
|
||||
## Implementation Notes
|
||||
|
||||
### Phase 1: Core Endpoints (Proposed)
|
||||
|
||||
1. Customers API (full CRUD)
|
||||
2. Suppliers API (full CRUD)
|
||||
3. Items API (full CRUD)
|
||||
4. Inventory adjustments API (create only)
|
||||
|
||||
### Phase 2: Read-Only Endpoints (Proposed)
|
||||
|
||||
1. Sales API (read-only)
|
||||
2. Receivings API (read-only)
|
||||
|
||||
### Phase 3: Extended Features (Future)
|
||||
|
||||
1. Batch operations for all endpoints
|
||||
2. Search/filter capabilities
|
||||
3. Authorization/permissions integration
|
||||
4. Rate limiting
|
||||
5. API key management interface
|
||||
|
||||
## Discussion Topics
|
||||
|
||||
The following aspects of the API design are open for discussion:
|
||||
|
||||
1. **Field naming conventions**: Currently following existing database column names. Should we use camelCase for JSON?
|
||||
|
||||
2. **Batch operations**: Current design separates batch-delete and batch-update. Should we consolidate?
|
||||
|
||||
3. **Date formats**: Using ISO 8601 (date-time). Is timezone handling needed?
|
||||
|
||||
4. **Error response structure**: Current format uses `{success, message}`. Should we include error codes?
|
||||
|
||||
5. **Relationship representations**: Should nested resources (e.g., sale items) always be included?
|
||||
|
||||
6. **Inventory adjustments**: Should we support setting absolute quantities vs. relative changes?
|
||||
|
||||
7. **Authorization integration**: How should API access integrate with existing employee permissions?
|
||||
|
||||
8. **Stock locations**: Multiple locations per item - do we need location-specific endpoints?
|
||||
36
INSTALL.md
36
INSTALL.md
@@ -63,3 +63,39 @@ Do **not** use below command on live deployments unless you want to tear everyth
|
||||
|
||||
If you choose DigitalOcean:
|
||||
[Through this link](https://m.do.co/c/ac38c262507b), you will get a [**free $100, 60-day credit**](https://m.do.co/c/ac38c262507b). [Check the wiki](https://github.com/opensourcepos/opensourcepos/wiki/Getting-Started-installations) for further instructions on how to install the necessary components.
|
||||
|
||||
## One-line Ubuntu Installation
|
||||
|
||||
For a fresh Ubuntu server (20.04 LTS or newer), you can install OSPOS directly with:
|
||||
|
||||
```bash
|
||||
curl -sSL https://opensourcepos.org/install | sudo bash
|
||||
```
|
||||
|
||||
> **Note:** This URL redirects to the latest installation script from the official repository. If the redirect is unavailable, use the direct GitHub URL:
|
||||
> ```bash
|
||||
> curl -sSL https://raw.githubusercontent.com/opensourcepos/opensourcepos/master/scripts/install-ubuntu.sh | sudo bash
|
||||
> ```
|
||||
|
||||
This script will:
|
||||
- Install Apache, MariaDB, PHP 8.2 and required extensions
|
||||
- Create a MySQL database and user with a secure random password
|
||||
- Download and configure OSPOS
|
||||
- Set up Apache virtual host with proper permissions
|
||||
- Display login credentials after completion
|
||||
|
||||
**Environment Variables (optional):**
|
||||
- `DB_NAME` - Database name (default: ospos)
|
||||
- `DB_USER` - Database user (default: ospos)
|
||||
- `DB_PASS` - Database password (default: auto-generated)
|
||||
- `OSPOS_DIR` - Installation directory (default: /var/www/ospos)
|
||||
- `OSPOS_BRANCH` - Git branch to install (default: master)
|
||||
- `PHP_VERSION` - PHP version (default: 8.2)
|
||||
- `APACHE_SERVER_NAME` - Server hostname (default: localhost)
|
||||
|
||||
Example with custom settings:
|
||||
```bash
|
||||
curl -sSL https://opensourcepos.org/install | DB_PASS=mypassword APACHE_SERVER_NAME=pos.example.com sudo -E bash
|
||||
```
|
||||
|
||||
**Note:** This script is designed for fresh servers. For production use, ensure you configure SSL/TLS certificates after installation.
|
||||
|
||||
@@ -1,23 +1,38 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* The environment testing is reserved for PHPUnit testing. It has special
|
||||
* conditions built into the framework at various places to assist with that.
|
||||
* You can’t use it for your development.
|
||||
*/
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| ERROR DISPLAY
|
||||
| ERROR DISPLAY
|
||||
|--------------------------------------------------------------------------
|
||||
*/
|
||||
| In development, we want to show as many errors as possible to help
|
||||
| make sure they don't make it to production. And save us hours of
|
||||
| painful debugging.
|
||||
*/
|
||||
error_reporting(E_ALL);
|
||||
ini_set('display_errors', '1');
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| DEBUG BACKTRACES
|
||||
| DEBUG BACKTRACES
|
||||
|--------------------------------------------------------------------------
|
||||
*/
|
||||
| If true, this constant will tell the error screens to display debug
|
||||
| backtraces along with the other error information. If you would
|
||||
| prefer to not see this, set this value to false.
|
||||
*/
|
||||
defined('SHOW_DEBUG_BACKTRACE') || define('SHOW_DEBUG_BACKTRACE', true);
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| DEBUG MODE
|
||||
| DEBUG MODE
|
||||
|--------------------------------------------------------------------------
|
||||
*/
|
||||
defined('CI_DEBUG') || define('CI_DEBUG', true);
|
||||
| Debug mode is an experimental flag that can allow changes throughout
|
||||
| the system. It's not widely used currently, and may not survive
|
||||
| release of the framework.
|
||||
*/
|
||||
defined('CI_DEBUG') || define('CI_DEBUG', true);
|
||||
|
||||
@@ -100,6 +100,7 @@ const CHECKBOX = 'CHECKBOX';
|
||||
const NO_DEFINITION_ID = 0;
|
||||
const CATEGORY_DEFINITION_ID = -1;
|
||||
const DEFINITION_TYPES = [GROUP, DROPDOWN, DECIMAL, TEXT, DATE, CHECKBOX];
|
||||
const ATTRIBUTE_VALUE_TYPES = ['attribute_value', 'attribute_decimal', 'attribute_date'];
|
||||
|
||||
/**
|
||||
* Item Related Constants.
|
||||
|
||||
@@ -100,25 +100,9 @@ class Filters extends BaseFilters
|
||||
* before or after URI patterns.
|
||||
*
|
||||
* Example:
|
||||
* isLoggedIn' => ['before' => ['account/*', 'profiles/*']]
|
||||
* 'isLoggedIn' => ['before' => ['account/*', 'profiles/*']]
|
||||
*
|
||||
* @var array<string, array<string, list<string>>>
|
||||
*/
|
||||
public array $filters = [];
|
||||
|
||||
/**
|
||||
* Constructor to conditionally disable CSRF filter in testing environment
|
||||
*/
|
||||
public function __construct()
|
||||
{
|
||||
// Check for testing environment via env variable or constant
|
||||
$isTesting = ($_ENV['CI_ENVIRONMENT'] ?? $_SERVER['CI_ENVIRONMENT'] ?? getenv('CI_ENVIRONMENT')) === 'testing'
|
||||
|| (defined('ENVIRONMENT') && ENVIRONMENT === 'testing');
|
||||
|
||||
// Remove CSRF filter from globals in testing environment
|
||||
if ($isTesting) {
|
||||
// Remove the 'csrf' key from $globals['before'] while preserving array structure
|
||||
$this->globals['before'] = array_filter($this->globals['before'], static fn($key) => $key !== 'csrf', ARRAY_FILTER_USE_KEY);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -13,9 +13,9 @@ class Security extends BaseConfig
|
||||
*
|
||||
* Protection Method for Cross Site Request Forgery protection.
|
||||
*
|
||||
* @var string|false 'cookie', 'session', or false
|
||||
* @var string 'cookie' or 'session'
|
||||
*/
|
||||
public string|false $csrfProtection = 'session';
|
||||
public string $csrfProtection = 'session';
|
||||
|
||||
/**
|
||||
* --------------------------------------------------------------------------
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Attribute;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Services;
|
||||
|
||||
require_once('Secure_Controller.php');
|
||||
@@ -25,19 +24,19 @@ class Attributes extends Secure_Controller
|
||||
/**
|
||||
* Gets and sends the main view for Attributes to the browser.
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
**/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['table_headers'] = get_attribute_definition_manage_table_headers();
|
||||
|
||||
return view('attributes/manage', $data);
|
||||
echo view('attributes/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns attribute table data rows. This will be called with AJAX.
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -54,15 +53,15 @@ class Attributes extends Secure_Controller
|
||||
$data_rows[] = get_attribute_definition_data_row($attribute_row);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* AJAX called function which saves the attribute value sent via POST by using the model save function.
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveAttributeValue(): ResponseInterface
|
||||
public function postSaveAttributeValue(): void
|
||||
{
|
||||
$success = $this->attribute->saveAttributeValue(
|
||||
html_entity_decode($this->request->getPost('attribute_value')),
|
||||
@@ -71,32 +70,32 @@ class Attributes extends Secure_Controller
|
||||
$this->request->getPost('attribute_id', FILTER_SANITIZE_NUMBER_INT) ?? false
|
||||
);
|
||||
|
||||
return $this->response->setJSON(['success' => $success != 0]);
|
||||
echo json_encode(['success' => $success != 0]);
|
||||
}
|
||||
|
||||
/**
|
||||
* AJAX called function deleting an attribute value using the model delete function.
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postDeleteDropdownAttributeValue(): ResponseInterface
|
||||
public function postDeleteDropdownAttributeValue(): void
|
||||
{
|
||||
$success = $this->attribute->deleteDropdownAttributeValue(
|
||||
html_entity_decode($this->request->getPost('attribute_value')),
|
||||
$this->request->getPost('definition_id', FILTER_SANITIZE_NUMBER_INT)
|
||||
);
|
||||
|
||||
return $this->response->setJSON(['success' => $success]);
|
||||
echo json_encode(['success' => $success]);
|
||||
}
|
||||
|
||||
/**
|
||||
* AJAX called function which saves the attribute definition.
|
||||
*
|
||||
* @param int $definition_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveDefinition(int $definition_id = NO_DEFINITION_ID): ResponseInterface
|
||||
public function postSaveDefinition(int $definition_id = NO_DEFINITION_ID): void
|
||||
{
|
||||
$definition_flags = 0;
|
||||
|
||||
@@ -120,7 +119,7 @@ class Attributes extends Secure_Controller
|
||||
|
||||
$definition_name = $definition_data['definition_name'];
|
||||
|
||||
if ($this->attribute->save_definition($definition_data, $definition_id)) {
|
||||
if ($this->attribute->saveDefinition($definition_data, $definition_id)) {
|
||||
// New definition
|
||||
if ($definition_id == NO_DEFINITION_ID) {
|
||||
$definition_values = json_decode(html_entity_decode($this->request->getPost('definition_values')));
|
||||
@@ -129,20 +128,20 @@ class Attributes extends Secure_Controller
|
||||
$this->attribute->saveAttributeValue($definition_value, $definition_data['definition_id']);
|
||||
}
|
||||
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Attributes.definition_successful_adding') . ' ' . $definition_name,
|
||||
'id' => $definition_data['definition_id']
|
||||
]);
|
||||
} else { // Existing definition
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Attributes.definition_successful_updating') . ' ' . $definition_name,
|
||||
'id' => $definition_id
|
||||
]);
|
||||
}
|
||||
} else { // Failure
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Attributes.definition_error_adding_updating', [$definition_name]),
|
||||
'id' => NEW_ENTRY
|
||||
@@ -153,27 +152,27 @@ class Attributes extends Secure_Controller
|
||||
/**
|
||||
*
|
||||
* @param int $definition_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSuggestAttribute(int $definition_id): ResponseInterface
|
||||
public function getSuggestAttribute(int $definition_id): void
|
||||
{
|
||||
$suggestions = $this->attribute->get_suggestions($definition_id, html_entity_decode($this->request->getGet('term')));
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$attribute_definition_info = $this->attribute->getAttributeInfo($row_id);
|
||||
$attribute_definition_info->definition_flags = $this->get_attributes($attribute_definition_info->definition_flags);
|
||||
$data_row = get_attribute_definition_data_row($attribute_definition_info);
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -193,9 +192,9 @@ class Attributes extends Secure_Controller
|
||||
|
||||
/**
|
||||
* @param int $definition_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $definition_id = NO_DEFINITION_ID): string
|
||||
public function getView(int $definition_id = NO_DEFINITION_ID): void
|
||||
{
|
||||
$info = $this->attribute->getAttributeInfo($definition_id);
|
||||
foreach (get_object_vars($info) as $property => $value) {
|
||||
@@ -213,22 +212,22 @@ class Attributes extends Secure_Controller
|
||||
$selected_flags = $info->definition_flags === '' ? $show_all : $info->definition_flags;
|
||||
$data['selected_definition_flags'] = $this->get_attributes($selected_flags);
|
||||
|
||||
return view('attributes/form', $data);
|
||||
echo view('attributes/form', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Deletes an attribute definition
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$attributes_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
|
||||
if($this->attribute->deleteDefinitionList($attributes_to_delete)) {
|
||||
$message = lang('Attributes.definition_successful_deleted') . ' ' . count($attributes_to_delete) . ' ' . lang('Attributes.definition_one_or_multiple');
|
||||
return $this->response->setJSON(['success' => true, 'message' => $message]);
|
||||
echo json_encode(['success' => true, 'message' => $message]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Attributes.definition_cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Attributes.definition_cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -5,7 +5,6 @@ namespace App\Controllers;
|
||||
use App\Models\Cashup;
|
||||
use App\Models\Expense;
|
||||
use App\Models\Reports\Summary_payments;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\OSPOS;
|
||||
use Config\Services;
|
||||
|
||||
@@ -27,22 +26,22 @@ class Cashups extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['table_headers'] = get_cashups_manage_table_headers();
|
||||
|
||||
// filters that will be loaded in the multiselect dropdown
|
||||
$data['filters'] = ['is_deleted' => lang('Cashups.is_deleted')];
|
||||
|
||||
return view('cashups/manage', $data);
|
||||
echo view('cashups/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return void
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -65,14 +64,14 @@ class Cashups extends Secure_Controller
|
||||
$data_rows[] = get_cash_up_data_row($cash_up);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $cashup_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $cashup_id = NEW_ENTRY): string
|
||||
public function getView(int $cashup_id = NEW_ENTRY): void
|
||||
{
|
||||
$data = [];
|
||||
|
||||
@@ -181,26 +180,26 @@ class Cashups extends Secure_Controller
|
||||
|
||||
$data['cash_ups_info'] = $cash_ups_info;
|
||||
|
||||
return view("cashups/form", $data);
|
||||
echo view("cashups/form", $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$cash_ups_info = $this->cashup->get_info($row_id);
|
||||
$data_row = get_cash_up_data_row($cash_ups_info);
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $cashup_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postSave(int $cashup_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $cashup_id = NEW_ENTRY): void
|
||||
{
|
||||
$open_date = $this->request->getPost('open_date');
|
||||
$open_date_formatter = date_create_from_format($this->config['dateformat'] . ' ' . $this->config['timeformat'], $open_date);
|
||||
@@ -228,36 +227,36 @@ class Cashups extends Secure_Controller
|
||||
if ($this->cashup->save_value($cash_up_data, $cashup_id)) {
|
||||
// New cashup_id
|
||||
if ($cashup_id == NEW_ENTRY) {
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Cashups.successful_adding'), 'id' => $cash_up_data['cashup_id']]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Cashups.successful_adding'), 'id' => $cash_up_data['cashup_id']]);
|
||||
} else { // Existing Cashup
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Cashups.successful_updating'), 'id' => $cashup_id]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Cashups.successful_updating'), 'id' => $cashup_id]);
|
||||
}
|
||||
} else { // Failure
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Cashups.error_adding_updating'), 'id' => NEW_ENTRY]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Cashups.error_adding_updating'), 'id' => NEW_ENTRY]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$cash_ups_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
|
||||
if ($this->cashup->delete_list($cash_ups_to_delete)) {
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Cashups.successful_deleted') . ' ' . count($cash_ups_to_delete) . ' ' . lang('Cashups.one_or_multiple'), 'ids' => $cash_ups_to_delete]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Cashups.successful_deleted') . ' ' . count($cash_ups_to_delete) . ' ' . lang('Cashups.one_or_multiple'), 'ids' => $cash_ups_to_delete]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Cashups.cannot_be_deleted'), 'ids' => $cash_ups_to_delete]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Cashups.cannot_be_deleted'), 'ids' => $cash_ups_to_delete]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Calculate the total for cashups. Used in app\Views\cashups\form.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postAjax_cashup_total(): ResponseInterface
|
||||
public function postAjax_cashup_total(): void
|
||||
{
|
||||
$open_amount_cash = parse_decimals($this->request->getPost('open_amount_cash'));
|
||||
$transfer_amount_cash = parse_decimals($this->request->getPost('transfer_amount_cash'));
|
||||
@@ -268,7 +267,7 @@ class Cashups extends Secure_Controller
|
||||
|
||||
$total = $this->_calculate_total($open_amount_cash, $transfer_amount_cash, $closed_amount_due, $closed_amount_cash, $closed_amount_card, $closed_amount_check); // TODO: hungarian notation
|
||||
|
||||
return $this->response->setJSON(['total' => to_currency_no_money($total)]);
|
||||
echo json_encode(['total' => to_currency_no_money($total)]);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -17,7 +17,6 @@ use App\Models\Stock_location;
|
||||
use App\Models\Tax;
|
||||
use CodeIgniter\Database\BaseConnection;
|
||||
use CodeIgniter\Encryption\EncrypterInterface;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Database;
|
||||
use Config\OSPOS;
|
||||
use Config\Services;
|
||||
@@ -216,9 +215,8 @@ class Config extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['stock_locations'] = $this->stock_location->get_all()->getResultArray();
|
||||
$data['dinner_tables'] = $this->dinner_table->get_all()->getResultArray();
|
||||
@@ -226,7 +224,6 @@ class Config extends Secure_Controller
|
||||
$data['support_barcode'] = $this->barcode_lib->get_list_barcodes();
|
||||
$data['barcode_fonts'] = $this->barcode_lib->listfonts('fonts');
|
||||
$data['logo_exists'] = $this->config['company_logo'] != '';
|
||||
$data['logo_src'] = !empty($this->config['company_logo']) ? base_url('uploads/' . $this->config['company_logo']) : '';
|
||||
$data['line_sequence_options'] = $this->sale_lib->get_line_sequence_options();
|
||||
$data['register_mode_options'] = $this->sale_lib->get_register_mode_options();
|
||||
$data['invoice_type_options'] = $this->sale_lib->get_invoice_type_options();
|
||||
@@ -275,17 +272,17 @@ class Config extends Secure_Controller
|
||||
|
||||
$data['mailchimp']['lists'] = $this->_mailchimp();
|
||||
|
||||
return view('configs/manage', $data);
|
||||
echo view('configs/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves company information. Used in app/Views/configs/info_config.php
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveInfo(): ResponseInterface
|
||||
public function postSaveInfo(): void
|
||||
{
|
||||
$upload_data = $this->upload_logo();
|
||||
$upload_success = empty($upload_data['error']);
|
||||
@@ -309,7 +306,7 @@ class Config extends Secure_Controller
|
||||
$message = lang('Config.saved_' . ($success ? '' : 'un') . 'successfully');
|
||||
$message = $upload_success ? $message : strip_tags($upload_data['error']);
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => $message]);
|
||||
echo json_encode(['success' => $success, 'message' => $message]);
|
||||
}
|
||||
|
||||
|
||||
@@ -361,12 +358,11 @@ class Config extends Secure_Controller
|
||||
* Saves general configuration. Used in app/Views/configs/general_config.php
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveGeneral(): ResponseInterface
|
||||
public function postSaveGeneral(): void
|
||||
{
|
||||
$batch_save_data = [
|
||||
$batchSaveData = [
|
||||
'theme' => $this->request->getPost('theme'),
|
||||
'login_form' => $this->request->getPost('login_form'),
|
||||
'default_sales_discount_type' => $this->request->getPost('default_sales_discount_type') != null,
|
||||
@@ -397,30 +393,30 @@ class Config extends Secure_Controller
|
||||
|
||||
$this->module->set_show_office_group($this->request->getPost('show_office_group') != null);
|
||||
|
||||
if ($batch_save_data['category_dropdown'] == 1) {
|
||||
$definition_data['definition_name'] = 'ospos_category';
|
||||
$definition_data['definition_flags'] = 0;
|
||||
$definition_data['definition_type'] = 'DROPDOWN';
|
||||
$definition_data['definition_id'] = CATEGORY_DEFINITION_ID;
|
||||
$definition_data['deleted'] = 0;
|
||||
if ($batchSaveData['category_dropdown']) {
|
||||
$definitionData['definition_name'] = 'ospos_category';
|
||||
$definitionData['definition_flags'] = 0;
|
||||
$definitionData['definition_type'] = 'DROPDOWN';
|
||||
$definitionData['definition_id'] = CATEGORY_DEFINITION_ID;
|
||||
$definitionData['deleted'] = 0;
|
||||
|
||||
$this->attribute->save_definition($definition_data, CATEGORY_DEFINITION_ID);
|
||||
} elseif ($batch_save_data['category_dropdown'] == NO_DEFINITION_ID) {
|
||||
$this->attribute->saveDefinition($definitionData, CATEGORY_DEFINITION_ID);
|
||||
} elseif ($batchSaveData['category_dropdown'] == NO_DEFINITION_ID) {
|
||||
$this->attribute->deleteDefinition(CATEGORY_DEFINITION_ID);
|
||||
}
|
||||
|
||||
$success = $this->appconfig->batch_save($batch_save_data);
|
||||
$success = $this->appconfig->batch_save($batchSaveData);
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks a number against the currently selected locale. Used in app/Views/configs/locale_config.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postCheckNumberLocale(): ResponseInterface
|
||||
public function postCheckNumberLocale(): void
|
||||
{
|
||||
$number_locale = $this->request->getPost('number_locale');
|
||||
$save_number_locale = $this->request->getPost('save_number_locale');
|
||||
@@ -442,7 +438,7 @@ class Config extends Secure_Controller
|
||||
$fmt->setSymbol(NumberFormatter::CURRENCY_SYMBOL, $currency_symbol);
|
||||
$number_local_example = $fmt->format(1234567890.12300);
|
||||
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => $number_local_example != false,
|
||||
'save_number_locale' => $save_number_locale,
|
||||
'number_locale_example' => $number_local_example,
|
||||
@@ -455,10 +451,10 @@ class Config extends Secure_Controller
|
||||
* Saves locale configuration. Used in app/Views/configs/locale_config.php
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveLocale(): ResponseInterface
|
||||
public function postSaveLocale(): void
|
||||
{
|
||||
$exploded = explode(":", $this->request->getPost('language'));
|
||||
$batch_save_data = [
|
||||
@@ -484,17 +480,17 @@ class Config extends Secure_Controller
|
||||
|
||||
$success = $this->appconfig->batch_save($batch_save_data);
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves email configuration. Used in app/Views/configs/email_config.php
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveEmail(): ResponseInterface
|
||||
public function postSaveEmail(): void
|
||||
{
|
||||
$password = '';
|
||||
|
||||
@@ -515,17 +511,17 @@ class Config extends Secure_Controller
|
||||
|
||||
$success = $this->appconfig->batch_save($batch_save_data);
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves SMS message configuration. Used in app/Views/configs/message_config.php.
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveMessage(): ResponseInterface
|
||||
public function postSaveMessage(): void
|
||||
{
|
||||
$password = '';
|
||||
|
||||
@@ -542,7 +538,7 @@ class Config extends Secure_Controller
|
||||
|
||||
$success = $this->appconfig->batch_save($batch_save_data);
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -569,15 +565,15 @@ class Config extends Secure_Controller
|
||||
/**
|
||||
* Gets Mailchimp lists when a valid API key is inserted. Used in app/Views/configs/integrations_config.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postCheckMailchimpApiKey(): ResponseInterface
|
||||
public function postCheckMailchimpApiKey(): void
|
||||
{
|
||||
$lists = $this->_mailchimp($this->request->getPost('mailchimp_api_key'));
|
||||
$success = count($lists) > 0;
|
||||
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => $success,
|
||||
'message' => lang('Config.mailchimp_key_' . ($success ? '' : 'un') . 'successfully'),
|
||||
'mailchimp_lists' => $lists
|
||||
@@ -588,10 +584,10 @@ class Config extends Secure_Controller
|
||||
* Saves Mailchimp configuration. Used in app/Views/configs/integrations_config.php
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveMailchimp(): ResponseInterface
|
||||
public function postSaveMailchimp(): void
|
||||
{
|
||||
$api_key = '';
|
||||
$list_id = '';
|
||||
@@ -612,56 +608,56 @@ class Config extends Secure_Controller
|
||||
|
||||
$success = $this->appconfig->batch_save($batch_save_data);
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets all stock locations. Used in app/Views/configs/stock_config.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getStockLocations(): string
|
||||
public function getStockLocations(): void
|
||||
{
|
||||
$stock_locations = $this->stock_location->get_all()->getResultArray();
|
||||
|
||||
return view('partial/stock_locations', ['stock_locations' => $stock_locations]);
|
||||
echo view('partial/stock_locations', ['stock_locations' => $stock_locations]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getDinnerTables(): string
|
||||
public function getDinnerTables(): void
|
||||
{
|
||||
$dinner_tables = $this->dinner_table->get_all()->getResultArray();
|
||||
|
||||
return view('partial/dinner_tables', ['dinner_tables' => $dinner_tables]);
|
||||
echo view('partial/dinner_tables', ['dinner_tables' => $dinner_tables]);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Gets all tax categories.
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function ajax_tax_categories(): string // TODO: Is this function called anywhere in the code?
|
||||
public function ajax_tax_categories(): void // TODO: Is this function called anywhere in the code?
|
||||
{
|
||||
$tax_categories = $this->tax->get_all_tax_categories()->getResultArray();
|
||||
|
||||
return view('partial/tax_categories', ['tax_categories' => $tax_categories]);
|
||||
echo view('partial/tax_categories', ['tax_categories' => $tax_categories]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets all customer rewards. Used in app/Views/configs/reward_config.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getCustomerRewards(): string
|
||||
public function getCustomerRewards(): void
|
||||
{
|
||||
$customer_rewards = $this->customer_rewards->get_all()->getResultArray();
|
||||
|
||||
return view('partial/customer_rewards', ['customer_rewards' => $customer_rewards]);
|
||||
echo view('partial/customer_rewards', ['customer_rewards' => $customer_rewards]);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -681,10 +677,10 @@ class Config extends Secure_Controller
|
||||
/**
|
||||
* Saves stock locations. Used in app/Views/configs/stock_config.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveLocations(): ResponseInterface
|
||||
public function postSaveLocations(): void
|
||||
{
|
||||
$this->db->transStart();
|
||||
|
||||
@@ -716,17 +712,17 @@ class Config extends Secure_Controller
|
||||
|
||||
$success = $this->db->transStatus();
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves all dinner tables. Used in app/Views/configs/table_config.php
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveTables(): ResponseInterface
|
||||
public function postSaveTables(): void
|
||||
{
|
||||
$this->db->transStart();
|
||||
|
||||
@@ -763,17 +759,17 @@ class Config extends Secure_Controller
|
||||
|
||||
$success = $this->db->transStatus();
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves tax configuration. Used in app/Views/configs/tax_config.php
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveTax(): ResponseInterface
|
||||
public function postSaveTax(): void
|
||||
{
|
||||
$default_tax_1_rate = $this->request->getPost('default_tax_1_rate');
|
||||
$default_tax_2_rate = $this->request->getPost('default_tax_2_rate');
|
||||
@@ -795,17 +791,17 @@ class Config extends Secure_Controller
|
||||
|
||||
$message = lang('Config.saved_' . ($success ? '' : 'un') . 'successfully');
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => $message]);
|
||||
echo json_encode(['success' => $success, 'message' => $message]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves customer rewards configuration. Used in app/Views/configs/reward_config.php
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveRewards(): ResponseInterface
|
||||
* @throws ReflectionException
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveRewards(): void
|
||||
{
|
||||
$this->db->transStart();
|
||||
|
||||
@@ -849,17 +845,17 @@ class Config extends Secure_Controller
|
||||
|
||||
$success = $this->db->transStatus();
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves barcode configuration. Used in app/Views/configs/barcode_config.php
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveBarcode(): ResponseInterface
|
||||
public function postSaveBarcode(): void
|
||||
{
|
||||
$batch_save_data = [
|
||||
'barcode_type' => $this->request->getPost('barcode_type'),
|
||||
@@ -881,17 +877,17 @@ class Config extends Secure_Controller
|
||||
|
||||
$success = $this->appconfig->batch_save($batch_save_data);
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves receipt configuration. Used in app/Views/configs/receipt_config.php.
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveReceipt(): ResponseInterface
|
||||
public function postSaveReceipt(): void
|
||||
{
|
||||
$batch_save_data = [
|
||||
'receipt_template' => $this->request->getPost('receipt_template'),
|
||||
@@ -916,17 +912,17 @@ class Config extends Secure_Controller
|
||||
|
||||
$success = $this->appconfig->batch_save($batch_save_data);
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves invoice configuration. Used in app/Views/configs/invoice_config.php.
|
||||
*
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveInvoice(): ResponseInterface
|
||||
public function postSaveInvoice(): void
|
||||
{
|
||||
$batch_save_data = [
|
||||
'invoice_enable' => $this->request->getPost('invoice_enable') != null,
|
||||
@@ -957,20 +953,20 @@ class Config extends Secure_Controller
|
||||
}
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
echo json_encode(['success' => $success, 'message' => lang('Config.saved_' . ($success ? '' : 'un') . 'successfully')]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Removes the company logo from the database. Used in app/Views/configs/info_config.php.
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @throws ReflectionException
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postRemoveLogo(): ResponseInterface
|
||||
public function postRemoveLogo(): void
|
||||
{
|
||||
$success = $this->appconfig->save(['company_logo' => '']);
|
||||
|
||||
return $this->response->setJSON(['success' => $success]);
|
||||
echo json_encode(['success' => $success]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -8,7 +8,6 @@ use App\Models\Customer;
|
||||
use App\Models\Customer_rewards;
|
||||
use App\Models\Tax_code;
|
||||
use CodeIgniter\HTTP\DownloadResponse;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\OSPOS;
|
||||
use Config\Services;
|
||||
use stdClass;
|
||||
@@ -41,20 +40,19 @@ class Customers extends Persons
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['table_headers'] = get_customer_manage_table_headers();
|
||||
|
||||
return view('people/manage', $data);
|
||||
echo view('people/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets one row for a customer manage table. This is called using AJAX to update one row.
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$person = $this->customer->get_info($row_id);
|
||||
|
||||
@@ -74,7 +72,7 @@ class Customers extends Persons
|
||||
|
||||
$data_row = get_customer_data_row($person, $stats);
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
|
||||
@@ -83,7 +81,7 @@ class Customers extends Persons
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -113,37 +111,35 @@ class Customers extends Persons
|
||||
$data_rows[] = get_customer_data_row($person, $stats);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gives search suggestions based on what is being searched for
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function getSuggest(): ResponseInterface
|
||||
public function getSuggest(): void
|
||||
{
|
||||
$search = $this->request->getGet('term');
|
||||
$suggestions = $this->customer->get_search_suggestions($search);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function suggest_search(): ResponseInterface
|
||||
public function suggest_search(): void
|
||||
{
|
||||
$search = $this->request->getGet('term');
|
||||
$suggestions = $this->customer->get_search_suggestions($search, 25, false);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads the customer edit form
|
||||
* @return string
|
||||
*/
|
||||
public function getView(int $customer_id = NEW_ENTRY): string
|
||||
public function getView(int $customer_id = NEW_ENTRY): void
|
||||
{
|
||||
// Set default values
|
||||
if ($customer_id == null) $customer_id = NEW_ENTRY;
|
||||
@@ -231,14 +227,13 @@ class Customers extends Persons
|
||||
}
|
||||
}
|
||||
|
||||
return view("customers/form", $data);
|
||||
echo view("customers/form", $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Inserts/updates a customer
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function postSave(int $customer_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $customer_id = NEW_ENTRY): void
|
||||
{
|
||||
$first_name = $this->request->getPost('first_name');
|
||||
$last_name = $this->request->getPost('last_name');
|
||||
@@ -293,20 +288,20 @@ class Customers extends Persons
|
||||
|
||||
// New customer
|
||||
if ($customer_id == NEW_ENTRY) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Customers.successful_adding') . ' ' . $first_name . ' ' . $last_name,
|
||||
'id' => $customer_data['person_id']
|
||||
]);
|
||||
} else { // Existing customer
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Customers.successful_updating') . ' ' . $first_name . ' ' . $last_name,
|
||||
'id' => $customer_id
|
||||
]);
|
||||
}
|
||||
} else { // Failure
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Customers.error_adding_updating') . ' ' . $first_name . ' ' . $last_name,
|
||||
'id' => NEW_ENTRY
|
||||
@@ -317,37 +312,36 @@ class Customers extends Persons
|
||||
/**
|
||||
* Verifies if an email address already exists. Used in app/Views/customers/form.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postCheckEmail(): ResponseInterface
|
||||
public function postCheckEmail(): void
|
||||
{
|
||||
$email = strtolower($this->request->getPost('email', FILTER_SANITIZE_EMAIL));
|
||||
$person_id = $this->request->getPost('person_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
|
||||
$exists = $this->customer->check_email_exists($email, $person_id);
|
||||
|
||||
return $this->response->setJSON(!$exists ? 'true' : 'false');
|
||||
echo !$exists ? 'true' : 'false';
|
||||
}
|
||||
|
||||
/**
|
||||
* Verifies if an account number already exists. Used in app/Views/customers/form.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postCheckAccountNumber(): ResponseInterface
|
||||
public function postCheckAccountNumber(): void
|
||||
{
|
||||
$exists = $this->customer->check_account_number_exists($this->request->getPost('account_number'), $this->request->getPost('person_id', FILTER_SANITIZE_NUMBER_INT));
|
||||
|
||||
return $this->response->setJSON(!$exists ? 'true' : 'false');
|
||||
echo !$exists ? 'true' : 'false';
|
||||
}
|
||||
|
||||
/**
|
||||
* This deletes customers from the customers table
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$customers_to_delete = $this->request->getPost('ids');
|
||||
$customers_info = $this->customer->get_multiple_info($customers_to_delete);
|
||||
@@ -364,12 +358,12 @@ class Customers extends Persons
|
||||
}
|
||||
|
||||
if ($count == count($customers_to_delete)) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Customers.successful_deleted') . ' ' . $count . ' ' . lang('Customers.one_or_multiple')
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Customers.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Customers.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -389,24 +383,24 @@ class Customers extends Persons
|
||||
/**
|
||||
* Displays the customer CSV import modal. Used in app/Views/people/manage.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getCsvImport(): string
|
||||
public function getCsvImport(): void
|
||||
{
|
||||
return view('customers/form_csv_import');
|
||||
echo view('customers/form_csv_import');
|
||||
}
|
||||
|
||||
/**
|
||||
* Imports a CSV file containing customers. Used in app/Views/customers/form_csv_import.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postImportCsvFile(): ResponseInterface
|
||||
public function postImportCsvFile(): void
|
||||
{
|
||||
if ($_FILES['file_path']['error'] != UPLOAD_ERR_OK) {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Customers.csv_import_failed')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Customers.csv_import_failed')]);
|
||||
} else {
|
||||
if (($handle = fopen($_FILES['file_path']['tmp_name'], 'r')) !== false) {
|
||||
// Skip the first row as it's the table description
|
||||
@@ -473,12 +467,12 @@ class Customers extends Persons
|
||||
if (count($failCodes) > 0) {
|
||||
$message = lang('Customers.csv_import_partially_failed', [count($failCodes), implode(', ', $failCodes)]);
|
||||
|
||||
return $this->response->setJSON(['success' => false, 'message' => $message]);
|
||||
echo json_encode(['success' => false, 'message' => $message]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Customers.csv_import_success')]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Customers.csv_import_success')]);
|
||||
}
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Customers.csv_import_nodata_wrongformat')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Customers.csv_import_nodata_wrongformat')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Module;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Services;
|
||||
|
||||
/**
|
||||
@@ -26,7 +25,7 @@ class Employees extends Persons
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -42,47 +41,39 @@ class Employees extends Persons
|
||||
$data_rows[] = get_person_data_row($person);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* AJAX called function gives search suggestions based on what is being searched for.
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getSuggest(): ResponseInterface
|
||||
public function getSuggest(): void
|
||||
{
|
||||
$search = $this->request->getGet('term');
|
||||
$suggestions = $this->employee->get_search_suggestions($search, 25, true);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function suggest_search(): ResponseInterface
|
||||
public function suggest_search(): void
|
||||
{
|
||||
$search = $this->request->getPost('term');
|
||||
$suggestions = $this->employee->get_search_suggestions($search);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads the employee edit form
|
||||
* @return string
|
||||
*/
|
||||
public function getView(int $employee_id = NEW_ENTRY): string
|
||||
public function getView(int $employee_id = NEW_ENTRY): void
|
||||
{
|
||||
$person_info = $this->employee->get_info($employee_id);
|
||||
$current_user = $this->employee->get_logged_in_employee_info();
|
||||
|
||||
if ($employee_id != NEW_ENTRY && !$this->employee->can_modify_employee($person_info->person_id, $current_user->person_id)) {
|
||||
header('Location: ' . base_url('no_access/employees/employees'));
|
||||
exit();
|
||||
}
|
||||
|
||||
foreach (get_object_vars($person_info) as $property => $value) {
|
||||
$person_info->$property = $value;
|
||||
}
|
||||
@@ -107,28 +98,14 @@ class Employees extends Persons
|
||||
}
|
||||
$data['all_subpermissions'] = $permissions;
|
||||
|
||||
return view('employees/form', $data);
|
||||
echo view('employees/form', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Inserts/updates an employee
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function postSave(int $employee_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $employee_id = NEW_ENTRY): void
|
||||
{
|
||||
$current_user = $this->employee->get_logged_in_employee_info();
|
||||
|
||||
if ($employee_id != NEW_ENTRY) {
|
||||
$target_employee = $this->employee->get_info($employee_id);
|
||||
if (!$this->employee->can_modify_employee($target_employee->person_id, $current_user->person_id)) {
|
||||
return $this->response->setJSON([
|
||||
'success' => false,
|
||||
'message' => lang('Employees.error_updating_admin'),
|
||||
'id' => NEW_ENTRY
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
$first_name = $this->request->getPost('first_name', FILTER_SANITIZE_FULL_SPECIAL_CHARS); // TODO: duplicated code
|
||||
$last_name = $this->request->getPost('last_name', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
$email = strtolower($this->request->getPost('email', FILTER_SANITIZE_EMAIL));
|
||||
@@ -153,16 +130,11 @@ class Employees extends Persons
|
||||
];
|
||||
|
||||
$grants_array = [];
|
||||
$is_admin = $this->employee->is_admin($current_user->person_id);
|
||||
|
||||
foreach ($this->module->get_all_permissions()->getResult() as $permission) {
|
||||
$grants = [];
|
||||
$grant = $this->request->getPost('grant_' . $permission->permission_id) != null ? $this->request->getPost('grant_' . $permission->permission_id, FILTER_SANITIZE_FULL_SPECIAL_CHARS) : '';
|
||||
|
||||
if ($grant == $permission->permission_id) {
|
||||
if (!$is_admin && !$this->employee->has_grant($permission->permission_id, $current_user->person_id)) {
|
||||
continue;
|
||||
}
|
||||
$grants['permission_id'] = $permission->permission_id;
|
||||
$grants['menu_group'] = $this->request->getPost('menu_group_' . $permission->permission_id) != null ? $this->request->getPost('menu_group_' . $permission->permission_id, FILTER_SANITIZE_FULL_SPECIAL_CHARS) : '--';
|
||||
$grants_array[] = $grants;
|
||||
@@ -191,25 +163,20 @@ class Employees extends Persons
|
||||
if ($this->employee->save_employee($person_data, $employee_data, $grants_array, $employee_id)) {
|
||||
// New employee
|
||||
if ($employee_id == NEW_ENTRY) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Employees.successful_adding') . ' ' . $first_name . ' ' . $last_name,
|
||||
'id' => $employee_data['person_id']
|
||||
]);
|
||||
} else { // Existing employee
|
||||
$logged_in_employee_id = session()->get('person_id');
|
||||
if ($employee_id == $logged_in_employee_id) {
|
||||
session()->set('language_code', $employee_data['language_code']);
|
||||
session()->set('language', $employee_data['language']);
|
||||
}
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Employees.successful_updating') . ' ' . $first_name . ' ' . $last_name,
|
||||
'id' => $employee_id
|
||||
]);
|
||||
}
|
||||
} else { // Failure
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Employees.error_adding_updating') . ' ' . $first_name . ' ' . $last_name,
|
||||
'id' => NEW_ENTRY
|
||||
@@ -219,28 +186,18 @@ class Employees extends Persons
|
||||
|
||||
/**
|
||||
* This deletes employees from the employees table
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$employees_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
$current_user = $this->employee->get_logged_in_employee_info();
|
||||
|
||||
if (!$this->employee->is_admin($current_user->person_id)) {
|
||||
foreach ($employees_to_delete as $emp_id) {
|
||||
if ($this->employee->is_admin((int)$emp_id)) {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Employees.error_deleting_admin')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if ($this->employee->delete_list($employees_to_delete)) { // TODO: this is passing a string, but delete_list expects an array
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Employees.successful_deleted') . ' ' . count($employees_to_delete) . ' ' . lang('Employees.one_or_multiple')
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Employees.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Employees.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -248,12 +205,12 @@ class Employees extends Persons
|
||||
* Checks an employee username against the database. Used in app\Views\employees\form.php
|
||||
*
|
||||
* @param $employee_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getCheckUsername($employee_id): ResponseInterface
|
||||
public function getCheckUsername($employee_id): void
|
||||
{
|
||||
$exists = $this->employee->username_exists($employee_id, $this->request->getGet('username'));
|
||||
return $this->response->setJSON(!$exists ? 'true' : 'false');
|
||||
echo !$exists ? 'true' : 'false';
|
||||
}
|
||||
}
|
||||
|
||||
@@ -4,7 +4,6 @@ namespace App\Controllers;
|
||||
|
||||
use App\Models\Expense;
|
||||
use App\Models\Expense_category;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\OSPOS;
|
||||
use Config\Services;
|
||||
|
||||
@@ -24,7 +23,7 @@ class Expenses extends Secure_Controller
|
||||
/**
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['table_headers'] = get_expenses_manage_table_headers();
|
||||
|
||||
@@ -38,13 +37,13 @@ class Expenses extends Secure_Controller
|
||||
'is_deleted' => lang('Expenses.is_deleted')
|
||||
];
|
||||
|
||||
return view('expenses/manage', $data);
|
||||
echo view('expenses/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return void
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -79,14 +78,14 @@ class Expenses extends Secure_Controller
|
||||
$data_rows[] = get_expenses_data_last_row($expenses);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows, 'payment_summary' => $payment_summary]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows, 'payment_summary' => $payment_summary]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $expense_id
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $expense_id = NEW_ENTRY): string
|
||||
public function getView(int $expense_id = NEW_ENTRY): void
|
||||
{
|
||||
$data = []; // TODO: Duplicated code
|
||||
|
||||
@@ -126,26 +125,26 @@ class Expenses extends Secure_Controller
|
||||
// Don't allow gift card to be a payment option in a sale transaction edit because it's a complex change
|
||||
$data['payment_options'] = $this->expense->get_payment_options();
|
||||
|
||||
return view("expenses/form", $data);
|
||||
echo view("expenses/form", $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$expense_info = $this->expense->get_info($row_id);
|
||||
$data_row = get_expenses_data_row($expense_info);
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $expense_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postSave(int $expense_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $expense_id = NEW_ENTRY): void
|
||||
{
|
||||
$config = config(OSPOS::class)->settings;
|
||||
$newdate = $this->request->getPost('date', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
@@ -168,26 +167,26 @@ class Expenses extends Secure_Controller
|
||||
if ($this->expense->save_value($expense_data, $expense_id)) {
|
||||
// New Expense
|
||||
if ($expense_id == NEW_ENTRY) {
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Expenses.successful_adding'), 'id' => $expense_data['expense_id']]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Expenses.successful_adding'), 'id' => $expense_data['expense_id']]);
|
||||
} else { // Existing Expense
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Expenses.successful_updating'), 'id' => $expense_id]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Expenses.successful_updating'), 'id' => $expense_id]);
|
||||
}
|
||||
} else { // Failure
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Expenses.error_adding_updating'), 'id' => NEW_ENTRY]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Expenses.error_adding_updating'), 'id' => NEW_ENTRY]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$expenses_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
|
||||
if ($this->expense->delete_list($expenses_to_delete)) {
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Expenses.successful_deleted') . ' ' . count($expenses_to_delete) . ' ' . lang('Expenses.one_or_multiple'), 'ids' => $expenses_to_delete]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Expenses.successful_deleted') . ' ' . count($expenses_to_delete) . ' ' . lang('Expenses.one_or_multiple'), 'ids' => $expenses_to_delete]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Expenses.cannot_be_deleted'), 'ids' => $expenses_to_delete]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Expenses.cannot_be_deleted'), 'ids' => $expenses_to_delete]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Expense_category;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Services;
|
||||
|
||||
class Expenses_categories extends Secure_Controller // TODO: Is this class ever used?
|
||||
@@ -20,17 +19,17 @@ class Expenses_categories extends Secure_Controller // TODO: Is this class ev
|
||||
/**
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['table_headers'] = get_expense_category_manage_table_headers();
|
||||
|
||||
return view('expenses_categories/manage', $data);
|
||||
echo view('expenses_categories/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns expense_category_manage table data rows. This will be called with AJAX.
|
||||
**/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -46,36 +45,36 @@ class Expenses_categories extends Secure_Controller // TODO: Is this class ev
|
||||
$data_rows[] = get_expense_category_data_row($expense_category);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $row_id
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$data_row = get_expense_category_data_row($this->expense_category->get_info($row_id));
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $expense_category_id
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $expense_category_id = NEW_ENTRY): string
|
||||
public function getView(int $expense_category_id = NEW_ENTRY): void
|
||||
{
|
||||
$data['category_info'] = $this->expense_category->get_info($expense_category_id);
|
||||
|
||||
return view("expenses_categories/form", $data);
|
||||
echo view("expenses_categories/form", $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $expense_category_id
|
||||
* @return void
|
||||
*/
|
||||
public function postSave(int $expense_category_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $expense_category_id = NEW_ENTRY): void
|
||||
{
|
||||
$expense_category_data = [
|
||||
'category_name' => $this->request->getPost('category_name', FILTER_SANITIZE_FULL_SPECIAL_CHARS),
|
||||
@@ -85,20 +84,20 @@ class Expenses_categories extends Secure_Controller // TODO: Is this class ev
|
||||
if ($this->expense_category->save_value($expense_category_data, $expense_category_id)) {
|
||||
// New expense_category
|
||||
if ($expense_category_id == NEW_ENTRY) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Expenses_categories.successful_adding'),
|
||||
'id' => $expense_category_data['expense_category_id']
|
||||
]);
|
||||
} else { // Existing Expense Category
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Expenses_categories.successful_updating'),
|
||||
'id' => $expense_category_id
|
||||
]);
|
||||
}
|
||||
} else { // Failure
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Expenses_categories.error_adding_updating') . ' ' . $expense_category_data['category_name'],
|
||||
'id' => NEW_ENTRY
|
||||
@@ -109,17 +108,17 @@ class Expenses_categories extends Secure_Controller // TODO: Is this class ev
|
||||
/**
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$expense_category_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
|
||||
if ($this->expense_category->delete_list($expense_category_to_delete)) { // TODO: Convert to ternary notation.
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Expenses_categories.successful_deleted') . ' ' . count($expense_category_to_delete) . ' ' . lang('Expenses_categories.one_or_multiple')
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Expenses_categories.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Expenses_categories.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Giftcard;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\OSPOS;
|
||||
use Config\Services;
|
||||
|
||||
@@ -19,19 +18,19 @@ class Giftcards extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['table_headers'] = get_giftcards_manage_table_headers();
|
||||
|
||||
return view('giftcards/manage', $data);
|
||||
echo view('giftcards/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns Giftcards table data rows. This will be called with AJAX.
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -47,50 +46,50 @@ class Giftcards extends Secure_Controller
|
||||
$data_rows[] = get_giftcard_data_row($giftcard);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets search suggestions for giftcards. Used in app\Views\sales\register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSuggest(): ResponseInterface
|
||||
public function getSuggest(): void
|
||||
{
|
||||
$search = $this->request->getGet('term');
|
||||
$suggestions = $this->giftcard->get_search_suggestions($search, true);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function suggest_search(): ResponseInterface
|
||||
public function suggest_search(): void
|
||||
{
|
||||
$search = $this->request->getPost('term');
|
||||
$suggestions = $this->giftcard->get_search_suggestions($search);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$data_row = get_giftcard_data_row($this->giftcard->get_info($row_id));
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $giftcard_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $giftcard_id = NEW_ENTRY): string
|
||||
public function getView(int $giftcard_id = NEW_ENTRY): void
|
||||
{
|
||||
$config = config(OSPOS::class)->settings;
|
||||
$giftcard_info = $this->giftcard->get_info($giftcard_id);
|
||||
@@ -107,14 +106,14 @@ class Giftcards extends Secure_Controller
|
||||
$data['giftcard_id'] = $giftcard_id;
|
||||
$data['giftcard_value'] = $giftcard_info->value;
|
||||
|
||||
return view("giftcards/form", $data);
|
||||
echo view("giftcards/form", $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $giftcard_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postSave(int $giftcard_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $giftcard_id = NEW_ENTRY): void
|
||||
{
|
||||
$giftcard_number = $this->request->getPost('giftcard_number', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
|
||||
@@ -132,20 +131,20 @@ class Giftcards extends Secure_Controller
|
||||
if ($this->giftcard->save_value($giftcard_data, $giftcard_id)) {
|
||||
// New giftcard
|
||||
if ($giftcard_id == NEW_ENTRY) { // TODO: Constant needed
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Giftcards.successful_adding') . ' ' . $giftcard_data['giftcard_number'],
|
||||
'id' => $giftcard_data['giftcard_id']
|
||||
]);
|
||||
} else { // Existing giftcard
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Giftcards.successful_updating') . ' ' . $giftcard_data['giftcard_number'],
|
||||
'id' => $giftcard_id
|
||||
]);
|
||||
}
|
||||
} else { // Failure
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Giftcards.error_adding_updating') . ' ' . $giftcard_data['giftcard_number'],
|
||||
'id' => NEW_ENTRY
|
||||
@@ -159,30 +158,30 @@ class Giftcards extends Secure_Controller
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postCheckNumberGiftcard(): ResponseInterface
|
||||
public function postCheckNumberGiftcard(): void
|
||||
{
|
||||
$existing_id = $this->request->getPost('giftcard_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
$giftcard_number = $this->request->getPost('giftcard_number', FILTER_SANITIZE_NUMBER_INT);
|
||||
$giftcard_id = $this->giftcard->get_giftcard_id($giftcard_number);
|
||||
$success = ($giftcard_id == (int) $existing_id || !$giftcard_id );
|
||||
|
||||
return $this->response->setJSON($success ? 'true' : 'false');
|
||||
echo $success ? 'true' : 'false';
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$giftcards_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
|
||||
if ($this->giftcard->delete_list($giftcards_to_delete)) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Giftcards.successful_deleted') . ' ' . count($giftcards_to_delete) . ' ' . lang('Giftcards.one_or_multiple')
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Giftcards.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Giftcards.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use CodeIgniter\HTTP\RedirectResponse;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
|
||||
class Home extends Secure_Controller
|
||||
{
|
||||
@@ -13,12 +12,12 @@ class Home extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$logged_in = $this->employee->is_logged_in();
|
||||
return view('home/home');
|
||||
echo view('home/home');
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -36,10 +35,9 @@ class Home extends Secure_Controller
|
||||
/**
|
||||
* Load "change employee password" form
|
||||
*
|
||||
* @return string
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getChangePassword(int $employee_id = -1): string // TODO: Replace -1 with a constant
|
||||
public function getChangePassword(int $employee_id = -1): void // TODO: Replace -1 with a constant
|
||||
{
|
||||
$person_info = $this->employee->get_info($employee_id);
|
||||
foreach (get_object_vars($person_info) as $property => $value) {
|
||||
@@ -47,57 +45,44 @@ class Home extends Secure_Controller
|
||||
}
|
||||
$data['person_info'] = $person_info;
|
||||
|
||||
return view('home/form_change_password', $data);
|
||||
echo view('home/form_change_password', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Change employee password
|
||||
*
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function postSave(int $employee_id = -1): ResponseInterface // TODO: Replace -1 with a constant
|
||||
public function postSave(int $employee_id = -1): void // TODO: Replace -1 with a constant
|
||||
{
|
||||
if (!empty($this->request->getPost('current_password')) && $employee_id != -1) {
|
||||
if ($this->employee->check_password($this->request->getPost('username', FILTER_SANITIZE_FULL_SPECIAL_CHARS), $this->request->getPost('current_password'))) {
|
||||
// Validate password length BEFORE hashing
|
||||
$new_password = $this->request->getPost('password');
|
||||
|
||||
if (strlen($new_password) < 8) {
|
||||
return $this->response->setJSON([
|
||||
'success' => false,
|
||||
'message' => lang('Employees.password_minlength'),
|
||||
'id' => -1
|
||||
]);
|
||||
}
|
||||
|
||||
$employee_data = [
|
||||
'username' => $this->request->getPost('username', FILTER_SANITIZE_FULL_SPECIAL_CHARS),
|
||||
'password' => password_hash($new_password, PASSWORD_DEFAULT),
|
||||
'password' => password_hash($this->request->getPost('password'), PASSWORD_DEFAULT),
|
||||
'hash_version' => 2
|
||||
];
|
||||
|
||||
if ($this->employee->change_password($employee_data, $employee_id)) {
|
||||
return $this->response->setJSON([
|
||||
if ($this->employee->change_password($employee_data, $employee_id) && strlen($employee_data['password']) >= 8) {
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Employees.successful_change_password'),
|
||||
'id' => $employee_id
|
||||
]);
|
||||
} else { // Failure // TODO: Replace -1 with constant
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Employees.unsuccessful_change_password'),
|
||||
'id' => -1
|
||||
]);
|
||||
}
|
||||
} else { // TODO: Replace -1 with constant
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Employees.current_password_invalid'),
|
||||
'id' => -1
|
||||
]);
|
||||
}
|
||||
} else { // TODO: Replace -1 with constant
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Employees.current_password_invalid'),
|
||||
'id' => -1
|
||||
|
||||
@@ -7,7 +7,6 @@ use App\Libraries\Barcode_lib;
|
||||
use App\Models\Item;
|
||||
use App\Models\Item_kit;
|
||||
use App\Models\Item_kit_items;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Services;
|
||||
|
||||
class Item_kits extends Secure_Controller
|
||||
@@ -60,19 +59,19 @@ class Item_kits extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['table_headers'] = get_item_kits_manage_table_headers();
|
||||
|
||||
return view('item_kits/manage', $data);
|
||||
echo view('item_kits/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns Item_kit table data rows. This will be called with AJAX.
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search') ?? '';
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -90,37 +89,37 @@ class Item_kits extends Secure_Controller
|
||||
$data_rows[] = get_item_kit_data_row($item_kit);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function suggest_search(): ResponseInterface
|
||||
public function suggest_search(): void
|
||||
{
|
||||
$search = $this->request->getPost('term');
|
||||
$suggestions = $this->item_kit->get_search_suggestions($search);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
// Calculate the total cost and retail price of the Kit, so it can be added to the table refresh
|
||||
$item_kit = $this->_add_totals_to_item_kit($this->item_kit->get_info($row_id));
|
||||
|
||||
return $this->response->setJSON(get_item_kit_data_row($item_kit));
|
||||
echo json_encode(get_item_kit_data_row($item_kit));
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $item_kit_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $item_kit_id = NEW_ENTRY): string
|
||||
public function getView(int $item_kit_id = NEW_ENTRY): void
|
||||
{
|
||||
$info = $this->item_kit->get_info($item_kit_id);
|
||||
|
||||
@@ -154,14 +153,14 @@ class Item_kits extends Secure_Controller
|
||||
$data['selected_kit_item_id'] = $info->kit_item_id;
|
||||
$data['selected_kit_item'] = ($item_kit_id > 0 && isset($info->kit_item_id)) ? $info->item_name : '';
|
||||
|
||||
return view("item_kits/form", $data);
|
||||
echo view("item_kits/form", $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $item_kit_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postSave(int $item_kit_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $item_kit_id = NEW_ENTRY): void
|
||||
{
|
||||
$item_kit_data = [
|
||||
'name' => $this->request->getPost('name'),
|
||||
@@ -202,20 +201,20 @@ class Item_kits extends Secure_Controller
|
||||
}
|
||||
|
||||
if ($new_item) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => $success,
|
||||
'message' => lang('Item_kits.successful_adding') . ' ' . $item_kit_data['name'],
|
||||
'id' => $item_kit_id
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => $success,
|
||||
'message' => lang('Item_kits.successful_updating') . ' ' . $item_kit_data['name'],
|
||||
'id' => $item_kit_id
|
||||
]);
|
||||
}
|
||||
} else { // Failure
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Item_kits.error_adding_updating') . ' ' . $item_kit_data['name'],
|
||||
'id' => NEW_ENTRY
|
||||
@@ -224,42 +223,42 @@ class Item_kits extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$item_kits_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
|
||||
if ($this->item_kit->delete_list($item_kits_to_delete)) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Item_kits.successful_deleted') . ' ' . count($item_kits_to_delete) . ' ' . lang('Item_kits.one_or_multiple')
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Item_kits.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Item_kits.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks the validity of the item kit number. Used in app/Views/item_kits/form.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postCheckItemNumber(): ResponseInterface
|
||||
public function postCheckItemNumber(): void
|
||||
{
|
||||
$exists = $this->item_kit->item_number_exists($this->request->getPost('item_kit_number', FILTER_SANITIZE_FULL_SPECIAL_CHARS), $this->request->getPost('item_kit_id', FILTER_SANITIZE_NUMBER_INT));
|
||||
return $this->response->setJSON(!$exists ? 'true' : 'false');
|
||||
echo !$exists ? 'true' : 'false';
|
||||
}
|
||||
|
||||
/**
|
||||
* AJAX called function that generates barcodes for selected item_kits.
|
||||
*
|
||||
* @param string $item_kit_ids Colon separated list of item_kit_id values to generate barcodes for.
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getGenerateBarcodes(string $item_kit_ids): string
|
||||
public function getGenerateBarcodes(string $item_kit_ids): void
|
||||
{
|
||||
$barcode_lib = new Barcode_lib();
|
||||
$result = [];
|
||||
@@ -290,6 +289,6 @@ class Item_kits extends Secure_Controller
|
||||
$data['barcode_config'] = $barcode_config;
|
||||
|
||||
// Display barcodes
|
||||
return view("barcodes/barcode_sheet", $data);
|
||||
echo view("barcodes/barcode_sheet", $data);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -4,7 +4,6 @@ namespace App\Controllers;
|
||||
|
||||
use App\Libraries\Barcode_lib;
|
||||
use App\Libraries\Item_lib;
|
||||
|
||||
use App\Models\Attribute;
|
||||
use App\Models\Inventory;
|
||||
use App\Models\Item;
|
||||
@@ -14,8 +13,6 @@ use App\Models\Item_taxes;
|
||||
use App\Models\Stock_location;
|
||||
use App\Models\Supplier;
|
||||
use App\Models\Tax_category;
|
||||
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use CodeIgniter\Images\Handlers\BaseHandler;
|
||||
use CodeIgniter\HTTP\DownloadResponse;
|
||||
use Config\OSPOS;
|
||||
@@ -66,9 +63,9 @@ class Items extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$this->session->set('allow_temp_items', 0);
|
||||
|
||||
@@ -87,14 +84,14 @@ class Items extends Secure_Controller
|
||||
'temporary' => lang('Items.temp')
|
||||
];
|
||||
|
||||
return view('items/manage', $data);
|
||||
echo view('items/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns Items table data rows. This will be called with AJAX.
|
||||
* @noinspection PhpUnused
|
||||
**/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -135,16 +132,16 @@ class Items extends Secure_Controller
|
||||
}
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* AJAX function. Processes thumbnail of image. Called via tabular_helper
|
||||
* @param string $pic_filename
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getPicThumb(string $pic_filename): ResponseInterface
|
||||
public function getPicThumb(string $pic_filename): void
|
||||
{
|
||||
helper('file');
|
||||
|
||||
@@ -165,17 +162,15 @@ class Items extends Secure_Controller
|
||||
|
||||
$this->response->setContentType(mime_content_type($thumb_path));
|
||||
$this->response->setBody(file_get_contents($thumb_path));
|
||||
$this->response->send();
|
||||
}
|
||||
|
||||
return $this->response;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gives search suggestions based on what is being searched for
|
||||
* @return ResponseInterface
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function suggest_search(): ResponseInterface
|
||||
public function suggest_search(): void
|
||||
{
|
||||
$options = [
|
||||
'search_custom' => $this->request->getPost('search_custom'),
|
||||
@@ -185,73 +180,71 @@ class Items extends Secure_Controller
|
||||
$search = $this->request->getPost('term');
|
||||
$suggestions = $this->item->get_search_suggestions($search, $options);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* AJAX Function used to get search suggestions from the model and return them in JSON format
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSuggest(): ResponseInterface
|
||||
public function getSuggest(): void
|
||||
{
|
||||
$search = $this->request->getGet('term');
|
||||
$suggestions = $this->item->get_search_suggestions($search, ['search_custom' => false, 'is_deleted' => false], true);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSuggestLowSell(): ResponseInterface
|
||||
public function getSuggestLowSell(): void
|
||||
{
|
||||
$suggestions = $this->item->get_low_sell_suggestions($this->request->getPostGet('name'));
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSuggestKits(): ResponseInterface
|
||||
public function getSuggestKits(): void
|
||||
{
|
||||
$suggestions = $this->item->get_kit_search_suggestions($this->request->getGet('term'), ['search_custom' => false, 'is_deleted' => false], true);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gives search suggestions based on what is being searched for. Called from the view.
|
||||
* @return ResponseInterface
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSuggestCategory(): ResponseInterface
|
||||
public function getSuggestCategory(): void
|
||||
{
|
||||
$suggestions = $this->item->get_category_suggestions($this->request->getGet('term'));
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gives search suggestions based on what is being searched for.
|
||||
* @return ResponseInterface
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSuggestLocation(): ResponseInterface
|
||||
public function getSuggestLocation(): void
|
||||
{
|
||||
$suggestions = $this->item->get_location_suggestions($this->request->getGet('term'));
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $item_ids
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(string $item_ids): ResponseInterface // TODO: An array would be better for parameter.
|
||||
public function getRow(string $item_ids): void // TODO: An array would be better for parameter.
|
||||
{
|
||||
$item_infos = $this->item->get_multiple_info(explode(':', $item_ids), $this->item_lib->get_item_location());
|
||||
|
||||
@@ -261,14 +254,14 @@ class Items extends Secure_Controller
|
||||
$result[$item_info->item_id] = get_item_data_row($item_info);
|
||||
}
|
||||
|
||||
return $this->response->setJSON($result);
|
||||
echo json_encode($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $item_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $item_id = NEW_ENTRY): string // TODO: Long function. Perhaps we need to refactor out some methods.
|
||||
public function getView(int $item_id = NEW_ENTRY): void // TODO: Long function. Perhaps we need to refactor out some methods.
|
||||
{
|
||||
$item_id ??= NEW_ENTRY;
|
||||
|
||||
@@ -400,17 +393,17 @@ class Items extends Secure_Controller
|
||||
$data['selected_low_sell_item'] = '';
|
||||
}
|
||||
|
||||
return view('items/form', $data);
|
||||
echo view('items/form', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* AJAX called function which returns the update inventory form view for an item
|
||||
*
|
||||
* @param int $item_id
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getInventory(int $item_id = NEW_ENTRY): string
|
||||
public function getInventory(int $item_id = NEW_ENTRY): void
|
||||
{
|
||||
$item_info = $this->item->get_info($item_id); // TODO: Duplicate code
|
||||
|
||||
@@ -429,15 +422,15 @@ class Items extends Secure_Controller
|
||||
$data['item_quantities'][$location['location_id']] = $quantity;
|
||||
}
|
||||
|
||||
return view('items/form_inventory', $data);
|
||||
echo view('items/form_inventory', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $item_id
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getCountDetails(int $item_id = NEW_ENTRY): string
|
||||
public function getCountDetails(int $item_id = NEW_ENTRY): void
|
||||
{
|
||||
$item_info = $this->item->get_info($item_id); // TODO: Duplicate code
|
||||
|
||||
@@ -456,17 +449,17 @@ class Items extends Secure_Controller
|
||||
$data['item_quantities'][$location['location_id']] = $quantity;
|
||||
}
|
||||
|
||||
return view('items/form_count_details', $data);
|
||||
echo view('items/form_count_details', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* AJAX called function that generates barcodes for selected items.
|
||||
*
|
||||
* @param string $item_ids Colon separated list of item_id values to generate barcodes for.
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getGenerateBarcodes(string $item_ids): string // TODO: Passing these through as a string instead of an array limits the contents of the item_ids. Perhaps a better approach would to serialize as JSON in an array and pass through post variables?
|
||||
public function getGenerateBarcodes(string $item_ids): void // TODO: Passing these through as a string instead of an array limits the contents of the item_ids. Perhaps a better approach would to serialize as JSON in an array and pass through post variables?
|
||||
{
|
||||
$item_ids = explode(':', $item_ids);
|
||||
$result = $this->item->get_multiple_info($item_ids, $this->item_lib->get_item_location())->getResultArray();
|
||||
@@ -482,16 +475,16 @@ class Items extends Secure_Controller
|
||||
}
|
||||
$data['items'] = $result;
|
||||
|
||||
return view('barcodes/barcode_sheet', $data);
|
||||
echo view('barcodes/barcode_sheet', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gathers attribute value information for an item and returns it in a view.
|
||||
*
|
||||
* @param int $item_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getAttributes(int $item_id = NEW_ENTRY): string
|
||||
public function getAttributes(int $item_id = NEW_ENTRY): void
|
||||
{
|
||||
$data['item_id'] = $item_id;
|
||||
$definition_ids = json_decode($this->request->getGet('definition_ids') ?? '', true);
|
||||
@@ -499,7 +492,7 @@ class Items extends Secure_Controller
|
||||
$data['definition_names'] = $this->attribute->get_definition_names();
|
||||
|
||||
foreach ($data['definition_values'] as $definition_id => $definition_value) {
|
||||
$attribute_value = $this->attribute->get_attribute_value($item_id, $definition_id);
|
||||
$attribute_value = $this->attribute->getAttributeValue($item_id, $definition_id);
|
||||
$attribute_id = (empty($attribute_value) || empty($attribute_value->attribute_id)) ? null : $attribute_value->attribute_id;
|
||||
$values = &$data['definition_values'][$definition_id];
|
||||
$values['attribute_id'] = $attribute_id;
|
||||
@@ -519,15 +512,15 @@ class Items extends Secure_Controller
|
||||
unset($data['definition_names'][$definition_id]);
|
||||
}
|
||||
|
||||
return view('attributes/item', $data);
|
||||
echo view('attributes/item', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $item_id
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postAttributes(int $item_id = NEW_ENTRY): string
|
||||
public function postAttributes(int $item_id = NEW_ENTRY): void
|
||||
{
|
||||
$data['item_id'] = $item_id;
|
||||
$definition_ids = json_decode($this->request->getPost('definition_ids'), true);
|
||||
@@ -535,7 +528,7 @@ class Items extends Secure_Controller
|
||||
$data['definition_names'] = $this->attribute->get_definition_names();
|
||||
|
||||
foreach ($data['definition_values'] as $definition_id => $definition_value) {
|
||||
$attribute_value = $this->attribute->get_attribute_value($item_id, $definition_id);
|
||||
$attribute_value = $this->attribute->getAttributeValue($item_id, $definition_id);
|
||||
$attribute_id = (empty($attribute_value) || empty($attribute_value->attribute_id)) ? null : $attribute_value->attribute_id;
|
||||
$values = &$data['definition_values'][$definition_id];
|
||||
$values['attribute_id'] = $attribute_id;
|
||||
@@ -555,16 +548,16 @@ class Items extends Secure_Controller
|
||||
unset($data['definition_names'][$definition_id]);
|
||||
}
|
||||
|
||||
return view('attributes/item', $data);
|
||||
echo view('attributes/item', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Edit multiple items. Used in app/Views/items/manage.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getBulkEdit(): string
|
||||
public function getBulkEdit(): void
|
||||
{
|
||||
$suppliers = ['' => lang('Items.none')];
|
||||
|
||||
@@ -585,15 +578,14 @@ class Items extends Secure_Controller
|
||||
0 => lang('Items.change_all_to_unserialized')
|
||||
];
|
||||
|
||||
return view('items/form_bulk', $data);
|
||||
echo view('items/form_bulk', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $item_id
|
||||
* @return ResponseInterface
|
||||
* @throws ReflectionException
|
||||
*/
|
||||
public function postSave(int $item_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $item_id = NEW_ENTRY): void
|
||||
{
|
||||
$upload_data = $this->upload_image();
|
||||
$upload_success = empty($upload_data['error']);
|
||||
@@ -723,16 +715,16 @@ class Items extends Secure_Controller
|
||||
if ($success && $upload_success) {
|
||||
$message = lang('Items.successful_' . ($new_item ? 'adding' : 'updating')) . ' ' . $item_data['name'];
|
||||
|
||||
return $this->response->setJSON(['success' => true, 'message' => $message, 'id' => $item_id]);
|
||||
echo json_encode(['success' => true, 'message' => $message, 'id' => $item_id]);
|
||||
} else {
|
||||
$message = $upload_success ? lang('Items.error_adding_updating') . ' ' . $item_data['name'] : strip_tags($upload_data['error']);
|
||||
|
||||
return $this->response->setJSON(['success' => false, 'message' => $message, 'id' => $item_id]);
|
||||
echo json_encode(['success' => false, 'message' => $message, 'id' => $item_id]);
|
||||
}
|
||||
} else {
|
||||
$message = lang('Items.error_adding_updating') . ' ' . $item_data['name'];
|
||||
|
||||
return $this->response->setJSON(['success' => false, 'message' => $message, 'id' => NEW_ENTRY]);
|
||||
echo json_encode(['success' => false, 'message' => $message, 'id' => NEW_ENTRY]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -783,51 +775,49 @@ class Items extends Secure_Controller
|
||||
/**
|
||||
* Ajax call to check to see if the item number, a.k.a. barcode, is already used by another item
|
||||
* If it exists then that is an error condition so return true for "error found"
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postCheckItemNumber(): ResponseInterface
|
||||
public function postCheckItemNumber(): void
|
||||
{
|
||||
$exists = $this->item->item_number_exists($this->request->getPost('item_number'), $this->request->getPost('item_id'));
|
||||
|
||||
return $this->response->setJSON(!$exists ? 'true' : 'false');
|
||||
echo !$exists ? 'true' : 'false';
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks to see if an item kit with the same name as the item already exists.
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function check_kit_exists(): ResponseInterface // TODO: This function appears to be never called in the code. Need to confirm.
|
||||
public function check_kit_exists(): void // TODO: This function appears to be never called in the code. Need to confirm.
|
||||
{
|
||||
if ($this->request->getPost('item_number') === NEW_ENTRY) {
|
||||
$exists = $this->item_kit->item_kit_exists_for_name($this->request->getPost('name')); // TODO: item_kit_exists_for_name doesn't exist in Item_kit. I looked at the blame and it appears to have never existed.
|
||||
} else {
|
||||
$exists = false;
|
||||
}
|
||||
|
||||
return $this->response->setJSON(!$exists ? 'true' : 'false');
|
||||
echo !$exists ? 'true' : 'false';
|
||||
}
|
||||
|
||||
/**
|
||||
* @param $item_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getRemoveLogo($item_id): ResponseInterface
|
||||
public function getRemoveLogo($item_id): void
|
||||
{
|
||||
$item_data = ['pic_filename' => null];
|
||||
$result = $this->item->save_value($item_data, $item_id);
|
||||
|
||||
return $this->response->setJSON(['success' => $result]);
|
||||
echo json_encode(['success' => $result]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @throws ReflectionException
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSaveInventory($item_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSaveInventory($item_id = NEW_ENTRY): void
|
||||
{
|
||||
$employee_id = $this->employee->get_logged_in_employee_info()->person_id;
|
||||
$cur_item_info = $this->item->get_info($item_id);
|
||||
@@ -855,19 +845,19 @@ class Items extends Secure_Controller
|
||||
if ($this->item_quantity->save_value($item_quantity_data, $item_id, $location_id)) {
|
||||
$message = lang('Items.successful_updating') . " $cur_item_info->name";
|
||||
|
||||
return $this->response->setJSON(['success' => true, 'message' => $message, 'id' => $item_id]);
|
||||
echo json_encode(['success' => true, 'message' => $message, 'id' => $item_id]);
|
||||
} else {
|
||||
$message = lang('Items.error_adding_updating') . " $cur_item_info->name";
|
||||
|
||||
return $this->response->setJSON(['success' => false, 'message' => $message, 'id' => NEW_ENTRY]);
|
||||
echo json_encode(['success' => false, 'message' => $message, 'id' => NEW_ENTRY]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postBulkUpdate(): ResponseInterface
|
||||
public function postBulkUpdate(): void
|
||||
{
|
||||
$items_to_update = $this->request->getPost('item_ids');
|
||||
$item_data = [];
|
||||
@@ -899,24 +889,23 @@ class Items extends Secure_Controller
|
||||
$this->item_taxes->save_multiple($items_taxes_data, $items_to_update);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Items.successful_bulk_edit'), 'id' => $items_to_update]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Items.successful_bulk_edit'), 'id' => $items_to_update]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Items.error_updating_multiple')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Items.error_updating_multiple')]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$items_to_delete = $this->request->getPost('ids');
|
||||
|
||||
if ($this->item->delete_list($items_to_delete)) {
|
||||
$message = lang('Items.successful_deleted') . ' ' . count($items_to_delete) . ' ' . lang('Items.one_or_multiple');
|
||||
return $this->response->setJSON(['success' => true, 'message' => $message]);
|
||||
echo json_encode(['success' => true, 'message' => $message]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Items.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Items.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -928,7 +917,7 @@ class Items extends Secure_Controller
|
||||
*/
|
||||
public function getGenerateCsvFile(): DownloadResponse
|
||||
{
|
||||
helper('importfile_helper');
|
||||
helper('importfile');
|
||||
$name = 'import_items.csv';
|
||||
$allowed_locations = $this->stock_location->get_allowed_locations();
|
||||
$allowed_attributes = $this->attribute->get_definition_names();
|
||||
@@ -938,56 +927,54 @@ class Items extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getCsvImport(): string
|
||||
public function getCsvImport(): void
|
||||
{
|
||||
return view('items/form_csv_import');
|
||||
echo view('items/form_csv_import');
|
||||
}
|
||||
|
||||
/**
|
||||
* Imports items from CSV formatted file.
|
||||
* @return ResponseInterface
|
||||
* @throws ReflectionException
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postImportCsvFile(): ResponseInterface
|
||||
public function postImportCsvFile(): void
|
||||
{
|
||||
helper('importfile_helper');
|
||||
helper('importfile');
|
||||
try {
|
||||
if ($_FILES['file_path']['error'] !== UPLOAD_ERR_OK) {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Items.csv_import_failed')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Items.csv_import_failed')]);
|
||||
} else {
|
||||
if (file_exists($_FILES['file_path']['tmp_name'])) {
|
||||
set_time_limit(240);
|
||||
|
||||
$failCodes = [];
|
||||
$csv_rows = get_csv_file($_FILES['file_path']['tmp_name']);
|
||||
$employee_id = $this->employee->get_logged_in_employee_info()->person_id;
|
||||
$allowed_stock_locations = $this->stock_location->get_allowed_locations();
|
||||
$attribute_definition_names = $this->attribute->get_definition_names();
|
||||
$csvRows = get_csv_file($_FILES['file_path']['tmp_name']);
|
||||
$employeeId = $this->employee->get_logged_in_employee_info()->person_id;
|
||||
$allowedStockLocations = $this->stock_location->get_allowed_locations();
|
||||
$attributeDefinitionNames = $this->attribute->get_definition_names();
|
||||
|
||||
unset($attribute_definition_names[NEW_ENTRY]); // Removes the common_none_selected_text from the array
|
||||
unset($attributeDefinitionNames[NEW_ENTRY]); // Removes the common_none_selected_text from the array
|
||||
|
||||
$attribute_data = [];
|
||||
$attributeData = [];
|
||||
|
||||
foreach ($attribute_definition_names as $definition_name) {
|
||||
$attribute_data[$definition_name] = $this->attribute->get_definition_by_name($definition_name)[0];
|
||||
foreach ($attributeDefinitionNames as $definitionName) {
|
||||
$attributeData[$definitionName] = $this->attribute->get_definition_by_name($definitionName)[0];
|
||||
|
||||
if ($attribute_data[$definition_name]['definition_type'] === DROPDOWN) {
|
||||
$attribute_data[$definition_name]['dropdown_values'] = $this->attribute->get_definition_values($attribute_data[$definition_name]['definition_id']);
|
||||
if ($attributeData[$definitionName]['definition_type'] === DROPDOWN) {
|
||||
$attributeData[$definitionName]['dropdown_values'] = $this->attribute->get_definition_values($attributeData[$definitionName]['definition_id']);
|
||||
}
|
||||
}
|
||||
$db = db_connect();
|
||||
$db->transBegin(); // TODO: This section needs to be reworked so that the data array is being created then passed to the Item model because $db doesn't exist in the controller without being instantiated, but database operations should be restricted to the model
|
||||
|
||||
foreach ($csv_rows as $key => $row) {
|
||||
$is_failed_row = false;
|
||||
$item_id = (int)$row['Id'];
|
||||
$is_update = ($item_id > 0);
|
||||
$item_data = [
|
||||
'item_id' => $item_id,
|
||||
foreach ($csvRows as $key => $row) {
|
||||
$isFailedRow = false;
|
||||
$itemId = (int)$row['Id'];
|
||||
$isUpdate = ($itemId > 0);
|
||||
$itemData = [
|
||||
'item_id' => $itemId,
|
||||
'name' => $row['Item Name'],
|
||||
'description' => $row['Description'],
|
||||
'category' => $row['Category'],
|
||||
@@ -1000,123 +987,157 @@ class Items extends Secure_Controller
|
||||
];
|
||||
|
||||
if (!empty($row['supplier ID'])) {
|
||||
$item_data['supplier_id'] = $this->supplier->exists($row['Supplier ID']) ? $row['Supplier ID'] : null;
|
||||
$itemData['supplier_id'] = $this->supplier->exists($row['Supplier ID']) ? $row['Supplier ID'] : null;
|
||||
}
|
||||
|
||||
if ($is_update) {
|
||||
$item_data['allow_alt_description'] = empty($row['Allow Alt Description']) ? null : $row['Allow Alt Description'];
|
||||
$item_data['is_serialized'] = empty($row['Item has Serial Number']) ? null : $row['Item has Serial Number'];
|
||||
if ($isUpdate) {
|
||||
$itemData['allow_alt_description'] = empty($row['Allow Alt Description']) ? null : $row['Allow Alt Description'];
|
||||
$itemData['is_serialized'] = empty($row['Item has Serial Number']) ? null : $row['Item has Serial Number'];
|
||||
} else {
|
||||
$item_data['allow_alt_description'] = empty($row['Allow Alt Description']) ? '0' : '1';
|
||||
$item_data['is_serialized'] = empty($row['Item has Serial Number']) ? '0' : '1';
|
||||
$itemData['allow_alt_description'] = empty($row['Allow Alt Description']) ? '0' : '1';
|
||||
$itemData['is_serialized'] = empty($row['Item has Serial Number']) ? '0' : '1';
|
||||
}
|
||||
|
||||
if (!empty($row['Barcode']) && !$is_update) {
|
||||
$item_data['item_number'] = $row['Barcode'];
|
||||
$is_failed_row = $this->item->item_number_exists($item_data['item_number']);
|
||||
if (!empty($row['Barcode'])) {
|
||||
$itemData['item_number'] = $row['Barcode'];
|
||||
$isFailedRow = $this->item->item_number_exists($itemData['item_number']);
|
||||
}
|
||||
|
||||
if (!$is_failed_row) {
|
||||
$is_failed_row = $this->data_error_check($row, $item_data, $allowed_stock_locations, $attribute_definition_names, $attribute_data);
|
||||
if (!$isFailedRow) {
|
||||
$invalidLocations = $this->validateCSVStockLocations($row, $allowedStockLocations);
|
||||
if (!empty($invalidLocations)) {
|
||||
$isFailedRow = true;
|
||||
log_message('error', 'CSV import: Invalid stock location(s) found: ' . implode(', ', $invalidLocations));
|
||||
}
|
||||
}
|
||||
|
||||
if (!$isFailedRow) {
|
||||
$isFailedRow = $this->validateCSVData($row, $itemData, $allowedStockLocations, $attributeDefinitionNames, $attributeData);
|
||||
}
|
||||
|
||||
// Remove false, null, '' and empty strings but keep 0
|
||||
$item_data = array_filter($item_data, function ($value) {
|
||||
$itemData = array_filter($itemData, function ($value) {
|
||||
return $value !== null && strlen($value);
|
||||
});
|
||||
|
||||
if (!$is_failed_row && $this->item->save_value($item_data, $item_id)) {
|
||||
$this->save_tax_data($row, $item_data);
|
||||
$this->save_inventory_quantities($row, $item_data, $allowed_stock_locations, $employee_id);
|
||||
$is_failed_row = $this->save_attribute_data($row, $item_data, $attribute_data); // TODO: $is_failed_row never gets used after this.
|
||||
if (!$isFailedRow && $this->item->save_value($itemData, $itemId)) {
|
||||
$this->save_tax_data($row, $itemData);
|
||||
$this->save_inventory_quantities($row, $itemData, $allowedStockLocations, $employeeId);
|
||||
$isFailedRow = $this->saveAttributeData($row, $itemData, $attributeData); // TODO: $is_failed_row never gets used after this.
|
||||
|
||||
if ($is_update) {
|
||||
$item_data = array_merge($item_data, get_object_vars($this->item->get_info_by_id_or_number($item_id)));
|
||||
if ($isUpdate) {
|
||||
$itemData = array_merge($itemData, get_object_vars($this->item->get_info_by_id_or_number($itemId)));
|
||||
}
|
||||
} else {
|
||||
$failed_row = $key + 2;
|
||||
$failCodes[] = $failed_row;
|
||||
log_message('error', "CSV Item import failed on line $failed_row. This item was not imported.");
|
||||
$failedRow = $key + 2;
|
||||
$failCodes[] = $failedRow;
|
||||
log_message('error', "CSV Item import failed on line $failedRow. This item was not imported.");
|
||||
}
|
||||
|
||||
unset($csv_rows[$key]);
|
||||
unset($csvRows[$key]);
|
||||
}
|
||||
|
||||
$csv_rows = null;
|
||||
$csvRows = null;
|
||||
|
||||
if (count($failCodes) > 0) {
|
||||
$message = lang('Items.csv_import_partially_failed', [count($failCodes), implode(', ', $failCodes)]);
|
||||
$db->transRollback();
|
||||
return $this->response->setJSON(['success' => false, 'message' => $message]);
|
||||
echo json_encode(['success' => false, 'message' => $message]);
|
||||
} else {
|
||||
$db->transCommit();
|
||||
$this->attribute->deleteOrphanedValues();
|
||||
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Items.csv_import_success')]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Items.csv_import_success')]);
|
||||
}
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Items.csv_import_nodata_wrongformat')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Items.csv_import_nodata_wrongformat')]);
|
||||
}
|
||||
}
|
||||
} catch (Exception $e) {
|
||||
return $this->response->setJSON(['success' => false, 'message' => $e->getMessage()]);
|
||||
echo json_encode(['success' => false, 'message' => $e->getMessage()]);
|
||||
return;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Validates that stock location columns in CSV row are valid locations
|
||||
*
|
||||
* @param array $row
|
||||
* @param array $allowedLocations
|
||||
* @return array Returns array of invalid location names, empty if all valid
|
||||
*/
|
||||
private function validateCSVStockLocations(array $row, array $allowedLocations): array
|
||||
{
|
||||
$invalidLocations = [];
|
||||
$allowedLocationNames = array_values($allowedLocations);
|
||||
|
||||
foreach (array_keys($row) as $key) {
|
||||
if (str_starts_with($key, 'location_')) {
|
||||
$locationName = substr($key, 9);
|
||||
if (!in_array($locationName, $allowedLocationNames)) {
|
||||
$invalidLocations[] = $locationName;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $invalidLocations;
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks the entire line of data in an import file for errors
|
||||
*
|
||||
* @param array $row
|
||||
* @param array $item_data
|
||||
* @param array $allowed_locations
|
||||
* @param array $definition_names
|
||||
* @param array $attribute_data
|
||||
* @param array $itemData
|
||||
* @param array $allowedLocations
|
||||
* @param array $definitionNames
|
||||
* @param array $attributeData
|
||||
* @return bool Returns false if all data checks out and true when there is an error in the data
|
||||
*/
|
||||
private function data_error_check(array $row, array $item_data, array $allowed_locations, array $definition_names, array $attribute_data): bool // TODO: Long function and large number of parameters in the declaration... perhaps refactoring is needed
|
||||
private function validateCSVData(array $row, array $itemData, array $allowedLocations, array $definitionNames, array $attributeData): bool // TODO: Long function and large number of parameters in the declaration... perhaps refactoring is needed
|
||||
{
|
||||
$item_id = $row['Id'];
|
||||
$is_update = (bool)$item_id;
|
||||
$itemId = $row['Id'];
|
||||
$isUpdate = (bool)$itemId;
|
||||
|
||||
// Check for empty required fields
|
||||
$check_for_empty = [
|
||||
'name' => $item_data['name'],
|
||||
'category' => $item_data['category'],
|
||||
'unit_price' => $item_data['unit_price']
|
||||
$valuesToCheckForEmpty = [
|
||||
'name' => $itemData['name'],
|
||||
'category' => $itemData['category'],
|
||||
'unit_price' => $itemData['unit_price']
|
||||
];
|
||||
|
||||
foreach ($check_for_empty as $key => $val) {
|
||||
if (empty($val) && !$is_update) {
|
||||
foreach ($valuesToCheckForEmpty as $key => $val) {
|
||||
if (empty($val) && !$isUpdate) {
|
||||
log_message('error', "Empty required value in $key.");
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
if (!$is_update) {
|
||||
$item_data['cost_price'] = empty($item_data['cost_price']) ? 0 : $item_data['cost_price']; // Allow for zero wholesale price
|
||||
if (!$isUpdate) {
|
||||
$itemData['cost_price'] = empty($itemData['cost_price']) ? 0 : $itemData['cost_price']; // Allow for zero wholesale price
|
||||
} else {
|
||||
if (!$this->item->exists($item_id)) {
|
||||
log_message('error', "non-existent item_id: '$item_id' when either existing item_id or no item_id is required.");
|
||||
if (!$this->item->exists($itemId)) {
|
||||
log_message('error', "non-existent item_id: '$itemId' when either existing item_id or no item_id is required.");
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
// Build array of fields to check for numerics
|
||||
$check_for_numeric_values = [
|
||||
'cost_price' => $item_data['cost_price'],
|
||||
'unit_price' => $item_data['unit_price'],
|
||||
'reorder_level' => $item_data['reorder_level'],
|
||||
$valuesToCheckForNumeric = [
|
||||
'cost_price' => $itemData['cost_price'],
|
||||
'unit_price' => $itemData['unit_price'],
|
||||
'reorder_level' => $itemData['reorder_level'],
|
||||
'supplier_id' => $row['Supplier ID'],
|
||||
'Tax 1 Percent' => $row['Tax 1 Percent'],
|
||||
'Tax 2 Percent' => $row['Tax 2 Percent']
|
||||
];
|
||||
|
||||
foreach ($allowed_locations as $location_name) {
|
||||
$check_for_numeric_values[] = $row["location_$location_name"];
|
||||
foreach ($allowedLocations as $location_name) {
|
||||
$valuesToCheckForNumeric[] = $row["location_$location_name"];
|
||||
}
|
||||
|
||||
// Check for non-numeric values which require numeric
|
||||
foreach ($check_for_numeric_values as $key => $value) {
|
||||
foreach ($valuesToCheckForNumeric as $key => $value) {
|
||||
if (!is_numeric($value) && !empty($value)) {
|
||||
log_message('error', "non-numeric: '$value' for '$key' when numeric is required");
|
||||
return true;
|
||||
@@ -1124,30 +1145,34 @@ class Items extends Secure_Controller
|
||||
}
|
||||
|
||||
// Check Attribute Data
|
||||
foreach ($definition_names as $definition_name) {
|
||||
if (!empty($row["attribute_$definition_name"])) {
|
||||
$definition_type = $attribute_data[$definition_name]['definition_type'];
|
||||
$attribute_value = $row["attribute_$definition_name"];
|
||||
foreach ($definitionNames as $definitionName) {
|
||||
if (!empty($row["attribute_$definitionName"])) {
|
||||
$definitionType = $attributeData[$definitionName]['definition_type'];
|
||||
$attributeValue = $row["attribute_$definitionName"];
|
||||
|
||||
switch ($definition_type) {
|
||||
if (strcasecmp($attributeValue, '_DELETE_') === 0) {
|
||||
continue;
|
||||
}
|
||||
|
||||
switch ($definitionType) {
|
||||
case DROPDOWN:
|
||||
$dropdown_values = $attribute_data[$definition_name]['dropdown_values'];
|
||||
$dropdown_values[] = '';
|
||||
$dropdownValues = $attributeData[$definitionName]['dropdown_values'];
|
||||
$dropdownValues[] = '';
|
||||
|
||||
if (!empty($attribute_value) && !in_array($attribute_value, $dropdown_values)) {
|
||||
log_message('error', "Value: '$attribute_value' is not an acceptable DROPDOWN value");
|
||||
if (!empty($attributeValue) && !in_array($attributeValue, $dropdownValues)) {
|
||||
log_message('error', "Value: '$attributeValue' is not an acceptable DROPDOWN value");
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case DECIMAL:
|
||||
if (!is_numeric($attribute_value) && !empty($attribute_value)) {
|
||||
log_message('error', "'$attribute_value' is not an acceptable DECIMAL value");
|
||||
if (!is_numeric($attributeValue) && !empty($attributeValue)) {
|
||||
log_message('error', "'$attributeValue' is not an acceptable DECIMAL value");
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case DATE:
|
||||
if (!valid_date($attribute_value) && !empty($attribute_value)) {
|
||||
log_message('error', "'$attribute_value' is not an acceptable DATE value. The value must match the set locale.");
|
||||
if (!valid_date($attributeValue) && !empty($attributeValue)) {
|
||||
log_message('error', "'$attributeValue' is not an acceptable DATE value. The value must match the set locale.");
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
@@ -1159,28 +1184,36 @@ class Items extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves attribute data found in the CSV import.
|
||||
* Saves attribute data found in one row of a CSV import file. Loops through all attribute definitions and checks
|
||||
* if there is data for that attribute in the row. If there is, it saves the attribute value and link to the item.
|
||||
*
|
||||
* @param array $row
|
||||
* @param array $item_data
|
||||
* @param array $definitions
|
||||
* @return bool
|
||||
* @param array $row Contains all parsed data from one row of the CSV import file
|
||||
* @param array $itemData Contains data for the item being imported/updated from the CSV file.
|
||||
* @param array $definitions Contains all attribute definitions in the system.
|
||||
* @return bool Returns false if all attribute data saves correctly and true if there is an error saving any of
|
||||
* the attribute data.
|
||||
*/
|
||||
private function save_attribute_data(array $row, array $item_data, array $definitions): bool
|
||||
private function saveAttributeData(array $row, array $itemData, array $definitions): bool
|
||||
{
|
||||
helper('attribute');
|
||||
foreach ($definitions as $definition) {
|
||||
$attribute_name = $definition['definition_name'];
|
||||
$attribute_value = $row["attribute_$attribute_name"];
|
||||
$attributeName = $definition['definition_name'];
|
||||
$attributeValue = $row["attribute_$attributeName"];
|
||||
|
||||
if (isset($attributeValue) && strcasecmp($attributeValue, '_DELETE_') === 0) {
|
||||
$this->attribute->deleteAttributeLinks($itemData['item_id'], $definition['definition_id']);
|
||||
continue;
|
||||
}
|
||||
|
||||
// Create attribute value
|
||||
if (!empty($attribute_value) || $attribute_value === '0') {
|
||||
if (!empty($attributeValue) || $attributeValue === '0') {
|
||||
if ($definition['definition_type'] === CHECKBOX) {
|
||||
$checkbox_is_unchecked = (strcasecmp($attribute_value, 'false') === 0 || $attribute_value === '0');
|
||||
$attribute_value = $checkbox_is_unchecked ? '0' : '1';
|
||||
$checkbox_is_unchecked = (strcasecmp($attributeValue, 'false') === 0 || $attributeValue === '0');
|
||||
$attributeValue = $checkbox_is_unchecked ? '0' : '1';
|
||||
|
||||
$attribute_id = $this->store_attribute_value($attribute_value, $definition, $item_data['item_id']);
|
||||
} elseif (!empty($attribute_value)) {
|
||||
$attribute_id = $this->store_attribute_value($attribute_value, $definition, $item_data['item_id']);
|
||||
$attribute_id = $this->storeAttributeValue($attributeValue, $definition, $itemData['item_id']);
|
||||
} elseif (!empty($attributeValue)) {
|
||||
$attribute_id = $this->storeAttributeValue($attributeValue, $definition, $itemData['item_id']);
|
||||
} else {
|
||||
return true;
|
||||
}
|
||||
@@ -1195,20 +1228,36 @@ class Items extends Secure_Controller
|
||||
|
||||
/**
|
||||
* Saves the attribute_value and attribute_link if necessary
|
||||
* @param string $value
|
||||
* @param array $attributeData
|
||||
* @param int $itemId
|
||||
* @return bool|int
|
||||
*/
|
||||
private function store_attribute_value(string $value, array $attribute_data, int $item_id)
|
||||
private function storeAttributeValue(string $value, array $attributeData, int $itemId): bool|int
|
||||
{
|
||||
$attribute_id = $this->attribute->attributeValueExists($value, $attribute_data['definition_type']);
|
||||
$attributeId = $this->attribute->attributeValueExists($value, $attributeData['definition_type']);
|
||||
|
||||
$this->attribute->deleteAttributeLinks($item_id, $attribute_data['definition_id']);
|
||||
$this->attribute->deleteAttributeLinks($itemId, $attributeData['definition_id']);
|
||||
|
||||
if (!$attribute_id) {
|
||||
$attribute_id = $this->attribute->saveAttributeValue($value, $attribute_data['definition_id'], $item_id, false, $attribute_data['definition_type']);
|
||||
} elseif (!$this->attribute->saveAttributeLink($item_id, $attribute_data['definition_id'], $attribute_id)) {
|
||||
return false;
|
||||
if (!$attributeId) {
|
||||
$attributeId = $this->attribute->saveAttributeValue($value, $attributeData['definition_id'], $itemId, false, $attributeData['definition_type']);
|
||||
} else {
|
||||
helper('attribute');
|
||||
$dataType = getAttributeDataType($attributeData['definition_type']);
|
||||
$storedValue = $this->attribute->getAttributeValueByAttributeId($attributeId, $dataType);
|
||||
|
||||
// Update attribute value if only the case has changed and only for text values.
|
||||
if ($dataType === 'attribute_value'
|
||||
&& is_string($storedValue)
|
||||
&& strcasecmp($storedValue, $value) === 0
|
||||
&& $storedValue !== $value) {
|
||||
$attributeId = $this->attribute->saveAttributeValue($value, $attributeData['definition_id'], $itemId, $attributeId, $attributeData['definition_type']);
|
||||
} elseif (!$this->attribute->saveAttributeLink($itemId, $attributeData['definition_id'], $attributeId)) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
return $attribute_id;
|
||||
return $attributeId;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1319,16 +1368,17 @@ class Items extends Secure_Controller
|
||||
switch ($definitionType) {
|
||||
case DROPDOWN:
|
||||
$attributeId = $attributeValue;
|
||||
$this->attribute->saveAttributeLink($itemId, $definitionId, $attributeId);
|
||||
break;
|
||||
case DECIMAL:
|
||||
$attributeValue = parse_decimals($attributeValue);
|
||||
// Fall through to save the attribute value
|
||||
// no break
|
||||
default:
|
||||
$attributeId = $this->attribute->saveAttributeValue($attributeValue, $definitionId, $itemId, $attributeIds[$definitionId], $definitionType);
|
||||
break;
|
||||
}
|
||||
|
||||
$this->attribute->saveAttributeLink($itemId, $definitionId, $attributeId);
|
||||
}
|
||||
|
||||
$this->attribute->deleteOrphanedValues();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -5,7 +5,6 @@ namespace App\Controllers;
|
||||
use App\Libraries\Sms_lib;
|
||||
|
||||
use App\Models\Person;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
|
||||
class Messages extends Secure_Controller
|
||||
{
|
||||
@@ -19,18 +18,18 @@ class Messages extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
return view('messages/sms');
|
||||
echo view('messages/sms');
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $person_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $person_id = NEW_ENTRY): string
|
||||
public function getView(int $person_id = NEW_ENTRY): void
|
||||
{
|
||||
$person = model(Person::class);
|
||||
$info = $person->get_info($person_id);
|
||||
@@ -40,13 +39,13 @@ class Messages extends Secure_Controller
|
||||
}
|
||||
$data['person_info'] = $info;
|
||||
|
||||
return view('messages/form_sms', $data);
|
||||
echo view('messages/form_sms', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function send(): ResponseInterface
|
||||
public function send(): void
|
||||
{
|
||||
$phone = $this->request->getPost('phone', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
$message = $this->request->getPost('message', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
@@ -54,9 +53,9 @@ class Messages extends Secure_Controller
|
||||
$response = $this->sms_lib->sendSMS($phone, $message);
|
||||
|
||||
if ($response) {
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Messages.successfully_sent') . ' ' . esc($phone)]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Messages.successfully_sent') . ' ' . esc($phone)]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Messages.unsuccessfully_sent') . ' ' . esc($phone)]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Messages.unsuccessfully_sent') . ' ' . esc($phone)]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -64,10 +63,10 @@ class Messages extends Secure_Controller
|
||||
* Sends an SMS message to a user. Used in app/Views/messages/form_sms.php.
|
||||
*
|
||||
* @param int $person_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function send_form(int $person_id = NEW_ENTRY): ResponseInterface
|
||||
public function send_form(int $person_id = NEW_ENTRY): void
|
||||
{
|
||||
$phone = $this->request->getPost('phone', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
$message = $this->request->getPost('message', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
@@ -75,13 +74,13 @@ class Messages extends Secure_Controller
|
||||
$response = $this->sms_lib->sendSMS($phone, $message);
|
||||
|
||||
if ($response) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Messages.successfully_sent') . ' ' . esc($phone),
|
||||
'person_id' => $person_id
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Messages.unsuccessfully_sent') . ' ' . esc($phone),
|
||||
'person_id' => NEW_ENTRY
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Module;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
|
||||
/**
|
||||
* Part of the grants mechanism to restrict access to modules that the user doesn't have permission for.
|
||||
@@ -23,13 +22,13 @@ class No_access extends BaseController
|
||||
/**
|
||||
* @param string $module_id
|
||||
* @param string $permission_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(string $module_id = '', string $permission_id = ''): string
|
||||
public function getIndex(string $module_id = '', string $permission_id = ''): void
|
||||
{
|
||||
$data['module_name'] = $this->module->get_module_name($module_id);
|
||||
$data['permission_id'] = $permission_id;
|
||||
|
||||
return view('no_access', $data);
|
||||
echo view('no_access', $data);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Employee;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
|
||||
/**
|
||||
* @property Employee employee
|
||||
@@ -18,11 +17,11 @@ class Office extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
return view('home/office');
|
||||
echo view('home/office');
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Person;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Services;
|
||||
use function Tamtamchik\NameCase\str_name_case;
|
||||
|
||||
@@ -22,36 +21,34 @@ abstract class Persons extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['table_headers'] = get_people_manage_table_headers();
|
||||
|
||||
return view('people/manage', $data);
|
||||
echo view('people/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gives search suggestions based on what is being searched for
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function getSuggest(): ResponseInterface
|
||||
public function getSuggest(): void
|
||||
{
|
||||
$search = $this->request->getGet('term');
|
||||
$suggestions = $this->person->get_search_suggestions($search);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets one row for a person manage table. This is called using AJAX to update one row.
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$data_row = get_person_data_row($this->person->get_info($row_id));
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -11,7 +11,6 @@ use App\Models\Item_kit;
|
||||
use App\Models\Receiving;
|
||||
use App\Models\Stock_location;
|
||||
use App\Models\Supplier;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\OSPOS;
|
||||
use Config\Services;
|
||||
use ReflectionException;
|
||||
@@ -47,66 +46,66 @@ class Receivings extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
return $this->_reload();
|
||||
$this->_reload();
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns search suggestions for an item. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getItemSearch(): ResponseInterface
|
||||
public function getItemSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('term');
|
||||
$suggestions = $this->item->get_search_suggestions($search, ['search_custom' => false, 'is_deleted' => false], true);
|
||||
$suggestions = array_merge($suggestions, $this->item_kit->get_search_suggestions($search));
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets search suggestions for a stock item. Used in app/Views/receivings/receiving.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getStockItemSearch(): ResponseInterface
|
||||
public function getStockItemSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('term');
|
||||
$suggestions = $this->item->get_stock_search_suggestions($search, ['search_custom' => false, 'is_deleted' => false], true);
|
||||
$suggestions = array_merge($suggestions, $this->item_kit->get_search_suggestions($search));
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Set supplier if it exists in the database. Used in app/Views/receivings/receiving.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSelectSupplier(): string
|
||||
public function postSelectSupplier(): void
|
||||
{
|
||||
$supplier_id = $this->request->getPost('supplier', FILTER_SANITIZE_NUMBER_INT);
|
||||
if ($this->supplier->exists($supplier_id)) {
|
||||
$this->receiving_lib->set_supplier($supplier_id);
|
||||
}
|
||||
|
||||
return $this->_reload(); // TODO: Hungarian notation
|
||||
$this->_reload(); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Change receiving mode for current receiving. Used in app/Views/receivings/receiving.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postChangeMode(): string
|
||||
public function postChangeMode(): void
|
||||
{
|
||||
$stock_destination = $this->request->getPost('stock_destination', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
$stock_source = $this->request->getPost('stock_source', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -122,49 +121,49 @@ class Receivings extends Secure_Controller
|
||||
$this->receiving_lib->set_stock_destination($stock_destination);
|
||||
}
|
||||
|
||||
return $this->_reload(); // TODO: Hungarian notation
|
||||
$this->_reload(); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets receiving comment. Used in app/Views/receivings/receiving.php
|
||||
* @return ResponseInterface
|
||||
*
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSetComment(): ResponseInterface
|
||||
public function postSetComment(): void
|
||||
{
|
||||
$this->receiving_lib->set_comment($this->request->getPost('comment', FILTER_SANITIZE_FULL_SPECIAL_CHARS));
|
||||
return $this->response->setJSON(['success' => true]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the print after sale flag for the receiving. Used in app/Views/receivings/receiving.php
|
||||
* @return ResponseInterface
|
||||
*
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSetPrintAfterSale(): ResponseInterface
|
||||
public function postSetPrintAfterSale(): void
|
||||
{
|
||||
$this->receiving_lib->set_print_after_sale($this->request->getPost('recv_print_after_sale') != null);
|
||||
return $this->response->setJSON(['success' => true]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the reference number for the receiving. Used in app/Views/receivings/receiving.php
|
||||
* @return ResponseInterface
|
||||
*
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSetReference(): ResponseInterface
|
||||
public function postSetReference(): void
|
||||
{
|
||||
$this->receiving_lib->set_reference($this->request->getPost('recv_reference', FILTER_SANITIZE_FULL_SPECIAL_CHARS));
|
||||
return $this->response->setJSON(['success' => true]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add an item to the receiving. Used in app/Views/receivings/receiving.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postAdd(): string
|
||||
public function postAdd(): void
|
||||
{
|
||||
$data = [];
|
||||
|
||||
@@ -184,17 +183,17 @@ class Receivings extends Secure_Controller
|
||||
$data['error'] = lang('Receivings.unable_to_add_item');
|
||||
}
|
||||
|
||||
return $this->_reload($data); // TODO: Hungarian notation
|
||||
$this->_reload($data); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Edit line item in current receiving. Used in app/Views/receivings/receiving.php
|
||||
*
|
||||
* @param string|int|null $item_id
|
||||
* @return string
|
||||
* @param $item_id
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postEditItem($item_id): string
|
||||
public function postEditItem($item_id): void
|
||||
{
|
||||
$data = [];
|
||||
|
||||
@@ -223,16 +222,17 @@ class Receivings extends Secure_Controller
|
||||
$data['error'] = lang('Receivings.error_editing_item');
|
||||
}
|
||||
|
||||
return $this->_reload($data); // TODO: Hungarian notation
|
||||
$this->_reload($data); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Edit a receiving. Used in app/Controllers/Receivings.php
|
||||
*
|
||||
* @param $receiving_id
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getEdit($receiving_id): string
|
||||
public function getEdit($receiving_id): void
|
||||
{
|
||||
$data = [];
|
||||
|
||||
@@ -251,65 +251,63 @@ class Receivings extends Secure_Controller
|
||||
$data['selected_supplier_id'] = $receiving_info['supplier_id'];
|
||||
$data['receiving_info'] = $receiving_info;
|
||||
|
||||
return view('receivings/form', $data);
|
||||
echo view('receivings/form', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Deletes an item from the current receiving. Used in app/Views/receivings/receiving.php
|
||||
*
|
||||
* @param $item_number
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getDeleteItem($item_number): string
|
||||
public function getDeleteItem($item_number): void
|
||||
{
|
||||
$this->receiving_lib->delete_item($item_number);
|
||||
|
||||
return $this->_reload(); // TODO: Hungarian notation
|
||||
$this->_reload(); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws ReflectionException
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function postDelete(int $receiving_id = -1, bool $update_inventory = true): ResponseInterface
|
||||
public function postDelete(int $receiving_id = -1, bool $update_inventory = true): void
|
||||
{
|
||||
$employee_id = $this->employee->get_logged_in_employee_info()->person_id;
|
||||
$receiving_ids = $receiving_id == -1 ? $this->request->getPost('ids', FILTER_SANITIZE_NUMBER_INT) : [$receiving_id]; // TODO: Replace -1 with constant
|
||||
|
||||
if ($this->receiving->delete_list($receiving_ids, $employee_id, $update_inventory)) { // TODO: Likely need to surround this block of code in a try-catch to catch the ReflectionException
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Receivings.successfully_deleted') . ' ' . count($receiving_ids) . ' ' . lang('Receivings.one_or_multiple'),
|
||||
'ids' => $receiving_ids
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Receivings.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Receivings.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Removes a supplier from a receiving. Used in app/Views/receivings/receiving.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getRemoveSupplier(): string
|
||||
public function getRemoveSupplier(): void
|
||||
{
|
||||
$this->receiving_lib->clear_reference();
|
||||
$this->receiving_lib->remove_supplier();
|
||||
|
||||
return $this->_reload(); // TODO: Hungarian notation
|
||||
$this->_reload(); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Complete and finalize receiving. Used in app/Views/receivings/receiving.php
|
||||
*
|
||||
* @return string
|
||||
* @throws ReflectionException
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postComplete(): string
|
||||
public function postComplete(): void
|
||||
{
|
||||
|
||||
$data = [];
|
||||
@@ -358,21 +356,18 @@ class Receivings extends Secure_Controller
|
||||
|
||||
$data['print_after_sale'] = $this->receiving_lib->is_print_after_sale();
|
||||
|
||||
$view = view("receivings/receipt", $data);
|
||||
echo view("receivings/receipt", $data);
|
||||
|
||||
$this->receiving_lib->clear_all();
|
||||
|
||||
return $view;
|
||||
}
|
||||
|
||||
/**
|
||||
* Complete a receiving requisition. Used in app/Views/receivings/receiving.php.
|
||||
*
|
||||
* @return string
|
||||
* @throws ReflectionException
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postRequisitionComplete(): string
|
||||
public function postRequisitionComplete(): void
|
||||
{
|
||||
if ($this->receiving_lib->get_stock_source() != $this->receiving_lib->get_stock_destination()) {
|
||||
foreach ($this->receiving_lib->get_cart() as $item) {
|
||||
@@ -381,11 +376,11 @@ class Receivings extends Secure_Controller
|
||||
$this->receiving_lib->add_item($item['item_id'], -$item['quantity'], $this->receiving_lib->get_stock_source(), $item['discount_type']);
|
||||
}
|
||||
|
||||
return $this->postComplete();
|
||||
$this->postComplete();
|
||||
} else {
|
||||
$data['error'] = lang('Receivings.error_requisition');
|
||||
|
||||
return $this->_reload($data); // TODO: Hungarian notation
|
||||
$this->_reload($data); // TODO: Hungarian notation
|
||||
}
|
||||
}
|
||||
|
||||
@@ -393,10 +388,10 @@ class Receivings extends Secure_Controller
|
||||
* Gets the receipt for a receiving. Used in app/Views/receivings/form.php
|
||||
*
|
||||
* @param $receiving_id
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getReceipt($receiving_id): string
|
||||
public function getReceipt($receiving_id): void
|
||||
{
|
||||
$receiving_info = $this->receiving->get_info($receiving_id)->getRowArray();
|
||||
$this->receiving_lib->copy_entire_receiving($receiving_id);
|
||||
@@ -429,18 +424,16 @@ class Receivings extends Secure_Controller
|
||||
|
||||
$data['print_after_sale'] = false;
|
||||
|
||||
$view = view("receivings/receipt", $data);
|
||||
echo view("receivings/receipt", $data);
|
||||
|
||||
$this->receiving_lib->clear_all();
|
||||
|
||||
return $view;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array $data
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
private function _reload(array $data = []): string // TODO: Hungarian notation
|
||||
private function _reload(array $data = []): void // TODO: Hungarian notation
|
||||
{
|
||||
$data['cart'] = $this->receiving_lib->get_cart();
|
||||
$data['modes'] = ['receive' => lang('Receivings.receiving'), 'return' => lang('Receivings.return')];
|
||||
@@ -477,14 +470,13 @@ class Receivings extends Secure_Controller
|
||||
|
||||
$data['print_after_sale'] = $this->receiving_lib->is_print_after_sale();
|
||||
|
||||
return view("receivings/receiving", $data);
|
||||
echo view("receivings/receiving", $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @throws ReflectionException
|
||||
*/
|
||||
public function postSave(int $receiving_id = -1): ResponseInterface // TODO: Replace -1 with a constant
|
||||
public function postSave(int $receiving_id = -1): void // TODO: Replace -1 with a constant
|
||||
{
|
||||
$newdate = $this->request->getPost('date', FILTER_SANITIZE_FULL_SPECIAL_CHARS); // TODO: newdate does not follow naming conventions
|
||||
|
||||
@@ -501,13 +493,13 @@ class Receivings extends Secure_Controller
|
||||
|
||||
$this->inventory->update('RECV ' . $receiving_id, ['trans_date' => $receiving_time]);
|
||||
if ($this->receiving->update($receiving_id, $receiving_data)) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Receivings.successfully_updated'),
|
||||
'id' => $receiving_id
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Receivings.unsuccessfully_updated'),
|
||||
'id' => $receiving_id
|
||||
@@ -518,13 +510,13 @@ class Receivings extends Secure_Controller
|
||||
/**
|
||||
* Cancel an in-process receiving. Used in app/Views/receivings/receiving.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postCancelReceiving(): string
|
||||
public function postCancelReceiving(): void
|
||||
{
|
||||
$this->receiving_lib->clear_all();
|
||||
|
||||
return $this->_reload(); // TODO: Hungarian Notation
|
||||
$this->_reload(); // TODO: Hungarian Notation
|
||||
}
|
||||
}
|
||||
|
||||
@@ -25,7 +25,6 @@ use App\Models\Reports\Summary_sales;
|
||||
use App\Models\Reports\Summary_sales_taxes;
|
||||
use App\Models\Reports\Summary_suppliers;
|
||||
use App\Models\Reports\Summary_taxes;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\OSPOS;
|
||||
use Config\Services;
|
||||
|
||||
@@ -85,8 +84,7 @@ class Reports extends Secure_Controller
|
||||
|
||||
// Check access to report submodule
|
||||
if (!$this->employee->has_grant('reports_' . $submodule_id, $this->employee->get_logged_in_employee_info()->person_id)) {
|
||||
header('Location: ' . base_url('no_access/reports/reports_' . $submodule_id));
|
||||
exit();
|
||||
redirect('no_access/reports/reports_' . $submodule_id);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -103,9 +101,8 @@ class Reports extends Secure_Controller
|
||||
|
||||
/**
|
||||
* Initial Report listing screen
|
||||
* @return string
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$person_id = $this->session->get('person_id');
|
||||
$grants = $this->employee->get_employee_grants($this->session->get('person_id'));
|
||||
@@ -117,7 +114,7 @@ class Reports extends Secure_Controller
|
||||
'permission_ids' => $permissions_ids,
|
||||
];
|
||||
|
||||
return view('reports/listing', $data);
|
||||
echo view('reports/listing', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -126,9 +123,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function summary_sales(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string // TODO: Perhaps these need to be passed as an array? Too many parameters in the signature.
|
||||
public function summary_sales(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void // TODO: Perhaps these need to be passed as an array? Too many parameters in the signature.
|
||||
{ // TODO: Duplicated code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -164,7 +161,7 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -173,9 +170,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function summary_categories(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function summary_categories(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{ // TODO: Duplicated code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -210,7 +207,7 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -218,9 +215,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $start_date
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function summary_expenses_categories(string $start_date, string $end_date, string $sale_type): string
|
||||
public function summary_expenses_categories(string $start_date, string $end_date, string $sale_type): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -247,7 +244,7 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -256,9 +253,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function summary_customers(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function summary_customers(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -295,7 +292,7 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -304,9 +301,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function summary_suppliers(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function summary_suppliers(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{ // TODO: Duplicated Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -341,7 +338,7 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -350,9 +347,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function summary_items(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function summary_items(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -391,7 +388,7 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -400,9 +397,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function summary_employees(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function summary_employees(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -439,7 +436,7 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -448,9 +445,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function summary_taxes(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function summary_taxes(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{ // TODO: Duplicate Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -485,14 +482,13 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Summary Sales Taxes report
|
||||
* @return string
|
||||
*/
|
||||
public function summary_sales_taxes(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function summary_sales_taxes(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{ // TODO: Duplicated code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -525,16 +521,16 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Summary Discounts report input. Used in app/Config/Routes.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function summary_discounts_input(): string
|
||||
public function summary_discounts_input(): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -545,14 +541,13 @@ class Reports extends Secure_Controller
|
||||
$data['discount_type_options'] = ['0' => lang('Reports.discount_percent'), '1' => lang('Reports.discount_fixed')];
|
||||
$data['sale_type_options'] = $this->get_sale_type_options();
|
||||
|
||||
return view('reports/date_input', $data);
|
||||
echo view('reports/date_input', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Summary Discounts report
|
||||
* @return string
|
||||
**/
|
||||
public function summary_discounts(string $start_date, string $end_date, string $sale_type, string $location_id = 'all', int $discount_type = 0): string
|
||||
public function summary_discounts(string $start_date, string $end_date, string $sale_type, string $location_id = 'all', int $discount_type = 0): void
|
||||
{ // TODO: Duplicated Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -584,14 +579,13 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Summary Payments report
|
||||
* @return string
|
||||
*/
|
||||
public function summary_payments(string $start_date, string $end_date): string
|
||||
public function summary_payments(string $start_date, string $end_date): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -643,16 +637,16 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $summary
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Input for reports that require only a date range. Used in app/Config/Routes.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function date_input(): string
|
||||
public function date_input(): void
|
||||
{ // TODO: Duplicated Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -662,30 +656,30 @@ class Reports extends Secure_Controller
|
||||
$data['mode'] = 'sale';
|
||||
$data['sale_type_options'] = $this->get_sale_type_options();
|
||||
|
||||
return view('reports/date_input', $data);
|
||||
echo view('reports/date_input', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Input for reports that require only a date range. Used in app/Config/Routes.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function date_input_only(): string
|
||||
public function date_input_only(): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
$data = [];
|
||||
return view('reports/date_input', $data);
|
||||
echo view('reports/date_input', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Input for reports that require only a date range. Used in app/Config/Routes.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function date_input_sales(): string
|
||||
public function date_input_sales(): void
|
||||
{ // TODO: Duplicated Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -695,23 +689,23 @@ class Reports extends Secure_Controller
|
||||
$data['mode'] = 'sale';
|
||||
$data['sale_type_options'] = $this->get_sale_type_options();
|
||||
|
||||
return view('reports/date_input', $data);
|
||||
echo view('reports/date_input', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Receivings date input. Used in app/Config/Routes.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function date_input_recv(): string
|
||||
public function date_input_recv(): void
|
||||
{
|
||||
$stock_locations = $data = $this->stock_location->get_allowed_locations('receivings');
|
||||
$stock_locations['all'] = lang('Reports.all');
|
||||
$data['stock_locations'] = array_reverse($stock_locations, true);
|
||||
$data['mode'] = 'receiving';
|
||||
|
||||
return view('reports/date_input', $data);
|
||||
echo view('reports/date_input', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -720,10 +714,10 @@ class Reports extends Secure_Controller
|
||||
* @param string $start_date
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function graphical_summary_expenses_categories(string $start_date, string $end_date, string $sale_type): string
|
||||
public function graphical_summary_expenses_categories(string $start_date, string $end_date, string $sale_type): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -756,7 +750,7 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => true
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -766,9 +760,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function graphical_summary_sales(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function graphical_summary_sales(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -802,7 +796,7 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => true
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -812,9 +806,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function graphical_summary_items(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function graphical_summary_items(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -849,7 +843,7 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => true
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -859,9 +853,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function graphical_summary_categories(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function graphical_summary_categories(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{ // TODO: Duplicated Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -892,7 +886,7 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => true
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -902,9 +896,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function graphical_summary_suppliers(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function graphical_summary_suppliers(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{ // TODO: Duplicated Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -937,7 +931,7 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => true
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -947,9 +941,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function graphical_summary_employees(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function graphical_summary_employees(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -981,7 +975,7 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => true
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -991,9 +985,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function graphical_summary_taxes(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function graphical_summary_taxes(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{ // TODO: Duplicated Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1025,7 +1019,7 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => true
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1035,9 +1029,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function graphical_summary_sales_taxes(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function graphical_summary_sales_taxes(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{ // TODO: Duplicated Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1069,7 +1063,7 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => true
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1079,9 +1073,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function graphical_summary_customers(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function graphical_summary_customers(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{ // TODO: Duplicated Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1115,7 +1109,7 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => true
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1126,10 +1120,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $sale_type
|
||||
* @param string $location_id ID of the location to be reported or 'all' if none is specified
|
||||
* @param int $discount_type
|
||||
* @return string
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function graphical_summary_discounts(string $start_date, string $end_date, string $sale_type, string $location_id = 'all', int $discount_type = 0): string
|
||||
public function graphical_summary_discounts(string $start_date, string $end_date, string $sale_type, string $location_id = 'all', int $discount_type = 0): void
|
||||
{ // TODO: Duplicated Code
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1164,7 +1157,7 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => false
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1174,9 +1167,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function graphical_summary_payments(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function graphical_summary_payments(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1210,16 +1203,16 @@ class Reports extends Secure_Controller
|
||||
'show_currency' => true
|
||||
];
|
||||
|
||||
return view('reports/graphical', $data);
|
||||
echo view('reports/graphical', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the specific customer input view. Used in app/Config/Routes.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function specific_customer_input(): string
|
||||
public function specific_customer_input(): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1237,7 +1230,7 @@ class Reports extends Secure_Controller
|
||||
$data['sale_type_options'] = $this->get_sale_type_options();
|
||||
|
||||
$data['payment_type'] = $this->get_payment_type();
|
||||
return view('reports/specific_customer_input', $data);
|
||||
echo view('reports/specific_customer_input', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1264,10 +1257,10 @@ class Reports extends Secure_Controller
|
||||
* @param string $customer_id
|
||||
* @param string $sale_type
|
||||
* @param string $payment_type
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function specific_customers(string $start_date, string $end_date, string $customer_id, string $sale_type, string $payment_type): string
|
||||
public function specific_customers(string $start_date, string $end_date, string $customer_id, string $sale_type, string $payment_type): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1358,16 +1351,16 @@ class Reports extends Secure_Controller
|
||||
'overall_summary_data' => $specific_customer->getSummaryData($inputs)
|
||||
];
|
||||
|
||||
return view('reports/tabular_details', $data);
|
||||
echo view('reports/tabular_details', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Detailed employee report input form. Used in app/Config/Routes.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function specific_employee_input(): string
|
||||
public function specific_employee_input(): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1381,7 +1374,7 @@ class Reports extends Secure_Controller
|
||||
$data['specific_input_data'] = $employees;
|
||||
$data['sale_type_options'] = $this->get_sale_type_options();
|
||||
|
||||
return view('reports/specific_input', $data);
|
||||
echo view('reports/specific_input', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1391,10 +1384,10 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $employee_id
|
||||
* @param string $sale_type
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function specific_employees(string $start_date, string $end_date, string $employee_id, string $sale_type): string
|
||||
public function specific_employees(string $start_date, string $end_date, string $employee_id, string $sale_type): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1481,16 +1474,16 @@ class Reports extends Secure_Controller
|
||||
'overall_summary_data' => $specific_employee->getSummaryData($inputs)
|
||||
];
|
||||
|
||||
return view('reports/tabular_details', $data);
|
||||
echo view('reports/tabular_details', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Detailed discount report. Used in app/Config/Routes.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function specific_discount_input(): string
|
||||
public function specific_discount_input(): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1505,7 +1498,7 @@ class Reports extends Secure_Controller
|
||||
$data['discount_type_options'] = ['0' => lang('Reports.discount_percent'), '1' => lang('Reports.discount_fixed')];
|
||||
$data['sale_type_options'] = $this->get_sale_type_options();
|
||||
|
||||
return view('reports/specific_input', $data);
|
||||
echo view('reports/specific_input', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1516,10 +1509,10 @@ class Reports extends Secure_Controller
|
||||
* @param string $discount
|
||||
* @param string $sale_type
|
||||
* @param string $discount_type
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function specific_discounts(string $start_date, string $end_date, string $discount, string $sale_type, string $discount_type): string
|
||||
public function specific_discounts(string $start_date, string $end_date, string $discount, string $sale_type, string $discount_type): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1612,17 +1605,17 @@ class Reports extends Secure_Controller
|
||||
'overall_summary_data' => $specific_discount->getSummaryData($inputs)
|
||||
];
|
||||
|
||||
return view('reports/tabular_details', $data);
|
||||
echo view('reports/tabular_details', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the detailed sales data row for given sale_id. Used in app/Views/reports/tabular_details.php
|
||||
*
|
||||
* @param string $sale_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getGet_detailed_sales_row(string $sale_id): ResponseInterface
|
||||
public function getGet_detailed_sales_row(string $sale_id): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1665,16 +1658,16 @@ class Reports extends Secure_Controller
|
||||
)
|
||||
];
|
||||
|
||||
return $this->response->setJSON([$sale_id => $summary_data]);
|
||||
echo json_encode([$sale_id => $summary_data]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Detailed Supplier report input form. Used in app/Config/Routes.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function specific_supplier_input(): string
|
||||
public function specific_supplier_input(): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1688,7 +1681,7 @@ class Reports extends Secure_Controller
|
||||
$data['specific_input_data'] = $suppliers;
|
||||
$data['sale_type_options'] = $this->get_sale_type_options();
|
||||
|
||||
return view('reports/specific_input', $data);
|
||||
echo view('reports/specific_input', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1698,9 +1691,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $supplier_id
|
||||
* @param string $sale_type
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function specific_suppliers(string $start_date, string $end_date, string $supplier_id, string $sale_type): string
|
||||
public function specific_suppliers(string $start_date, string $end_date, string $supplier_id, string $sale_type): void
|
||||
{
|
||||
$inputs = [
|
||||
'start_date' => $start_date,
|
||||
@@ -1743,7 +1736,7 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $specific_supplier->getSummaryData($inputs)
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1770,9 +1763,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $sale_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function detailed_sales(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): string
|
||||
public function detailed_sales(string $start_date, string $end_date, string $sale_type, string $location_id = 'all'): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -1876,17 +1869,17 @@ class Reports extends Secure_Controller
|
||||
'details_data_rewards' => $details_data_rewards,
|
||||
'overall_summary_data' => $this->detailed_sales->getSummaryData($inputs)
|
||||
];
|
||||
return view('reports/tabular_details', $data);
|
||||
echo view('reports/tabular_details', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns detailed receivings row for given receiving_id. Used in app/Views/reports/tabular_details.php
|
||||
*
|
||||
* @param string $receiving_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getGet_detailed_receivings_row(string $receiving_id): ResponseInterface
|
||||
public function getGet_detailed_receivings_row(string $receiving_id): void
|
||||
{
|
||||
$inputs = ['receiving_id' => $receiving_id];
|
||||
|
||||
@@ -1916,7 +1909,7 @@ class Reports extends Secure_Controller
|
||||
)
|
||||
];
|
||||
|
||||
return $this->response->setJSON([$receiving_id => $summary_data]);
|
||||
echo json_encode([$receiving_id => $summary_data]);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1924,9 +1917,9 @@ class Reports extends Secure_Controller
|
||||
* @param string $end_date
|
||||
* @param string $receiving_type
|
||||
* @param string $location_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function detailed_receivings(string $start_date, string $end_date, string $receiving_type, string $location_id = 'all'): string
|
||||
public function detailed_receivings(string $start_date, string $end_date, string $receiving_type, string $location_id = 'all'): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -2000,13 +1993,13 @@ class Reports extends Secure_Controller
|
||||
'overall_summary_data' => $this->detailed_receivings->getSummaryData($inputs)
|
||||
];
|
||||
|
||||
return view('reports/tabular_details', $data);
|
||||
echo view('reports/tabular_details', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function inventory_low(): string
|
||||
public function inventory_low(): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -2035,16 +2028,16 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $inventory_low->getSummaryData($inputs)
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the inventory summary input view. Used in app/Config/Routes.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function inventory_summary_input(): string
|
||||
public function inventory_summary_input(): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -2055,15 +2048,15 @@ class Reports extends Secure_Controller
|
||||
$stock_locations['all'] = lang('Reports.all');
|
||||
$data['stock_locations'] = array_reverse($stock_locations, true);
|
||||
|
||||
return view('reports/inventory_summary_input', $data);
|
||||
echo view('reports/inventory_summary_input', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $location_id
|
||||
* @param string $item_count
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function inventory_summary(string $location_id = 'all', string $item_count = 'all'): string
|
||||
public function inventory_summary(string $location_id = 'all', string $item_count = 'all'): void
|
||||
{
|
||||
$this->clearCache();
|
||||
|
||||
@@ -2095,7 +2088,7 @@ class Reports extends Secure_Controller
|
||||
'summary_data' => $this->inventory_summary->getSummaryData($report_data)
|
||||
];
|
||||
|
||||
return view('reports/tabular', $data);
|
||||
echo view('reports/tabular', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -20,7 +20,6 @@ use App\Models\Stock_location;
|
||||
use App\Models\Tokens\Token_invoice_count;
|
||||
use App\Models\Tokens\Token_customer;
|
||||
use App\Models\Tokens\Token_invoice_sequence;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Services;
|
||||
use Config\OSPOS;
|
||||
use ReflectionException;
|
||||
@@ -66,19 +65,22 @@ class Sales extends Secure_Controller
|
||||
$this->employee = model(Employee::class);
|
||||
}
|
||||
|
||||
public function getIndex(): ResponseInterface|string
|
||||
/**
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): void
|
||||
{
|
||||
$this->session->set('allow_temp_items', 1);
|
||||
return $this->_reload(); // TODO: Hungarian Notation
|
||||
$this->_reload(); // TODO: Hungarian Notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Load the sale edit modal. Used in app/Views/sales/register.php.
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getManage(): string
|
||||
public function getManage(): void
|
||||
{
|
||||
$person_id = $this->session->get('person_id');
|
||||
|
||||
@@ -105,26 +107,26 @@ class Sales extends Secure_Controller
|
||||
}
|
||||
$data['selected_filters'] = $selected_filters;
|
||||
|
||||
return view('sales/manage', $data);
|
||||
echo view('sales/manage', $data);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$sale_info = $this->sale->get_info($row_id)->getRow();
|
||||
$data_row = get_sale_data_row($sale_info);
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return void
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -164,16 +166,16 @@ class Sales extends Secure_Controller
|
||||
$data_rows[] = get_sale_data_last_row($sales);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows, 'payment_summary' => $payment_summary]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows, 'payment_summary' => $payment_summary]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets search suggestions for an item or item kit. Used in app/Views/sales/register.php.
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getItemSearch(): ResponseInterface
|
||||
public function getItemSearch(): void
|
||||
{
|
||||
$suggestions = [];
|
||||
$receipt = $search = $this->request->getGet('term') != ''
|
||||
@@ -187,13 +189,13 @@ class Sales extends Secure_Controller
|
||||
$suggestions = array_merge($suggestions, $this->item->get_search_suggestions($search, ['search_custom' => false, 'is_deleted' => false], true));
|
||||
$suggestions = array_merge($suggestions, $this->item_kit->get_search_suggestions($search));
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function suggest_search(): ResponseInterface
|
||||
public function suggest_search(): void
|
||||
{
|
||||
$search = $this->request->getPost('term') != ''
|
||||
? $this->request->getPost('term')
|
||||
@@ -201,16 +203,16 @@ class Sales extends Secure_Controller
|
||||
|
||||
$suggestions = $this->sale->get_search_suggestions($search);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Set a given customer. Used in app/Views/sales/register.php.
|
||||
*
|
||||
* @return ResponseInterface|string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSelectCustomer(): ResponseInterface|string
|
||||
public function postSelectCustomer(): void
|
||||
{
|
||||
$customer_id = (int)$this->request->getPost('customer', FILTER_SANITIZE_NUMBER_INT);
|
||||
if ($this->customer->exists($customer_id)) {
|
||||
@@ -224,16 +226,16 @@ class Sales extends Secure_Controller
|
||||
}
|
||||
}
|
||||
|
||||
return $this->_reload();
|
||||
$this->_reload();
|
||||
}
|
||||
|
||||
/**
|
||||
* Changes the sale mode in the register to carry out different types of sales
|
||||
*
|
||||
* @return ResponseInterface|string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postChangeMode(): ResponseInterface|string
|
||||
public function postChangeMode(): void
|
||||
{
|
||||
$mode = $this->request->getPost('mode', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
$this->sale_lib->set_mode($mode);
|
||||
@@ -274,14 +276,14 @@ class Sales extends Secure_Controller
|
||||
|
||||
$this->sale_lib->empty_payments();
|
||||
|
||||
return $this->_reload();
|
||||
$this->_reload();
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $sale_type
|
||||
* @return ResponseInterface|string
|
||||
* @return void
|
||||
*/
|
||||
public function change_register_mode(int $sale_type): ResponseInterface|string
|
||||
public function change_register_mode(int $sale_type): void
|
||||
{
|
||||
$mode = match ($sale_type) {
|
||||
SALE_TYPE_QUOTE => 'sale_quote',
|
||||
@@ -292,87 +294,81 @@ class Sales extends Secure_Controller
|
||||
};
|
||||
|
||||
$this->sale_lib->set_mode($mode);
|
||||
return $this->_reload();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Sets the sales comment. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSetComment(): ResponseInterface
|
||||
public function postSetComment(): void
|
||||
{
|
||||
$this->sale_lib->set_comment($this->request->getPost('comment', FILTER_SANITIZE_FULL_SPECIAL_CHARS));
|
||||
return $this->response->setJSON(['success' => true]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the invoice number. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSetInvoiceNumber(): ResponseInterface|string
|
||||
public function postSetInvoiceNumber(): void
|
||||
{
|
||||
$this->sale_lib->set_invoice_number($this->request->getPost('sales_invoice_number', FILTER_SANITIZE_NUMBER_INT));
|
||||
return $this->response->setJSON(['success' => true]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postSetPaymentType(): ResponseInterface|string // TODO: This function does not appear to be called anywhere in the code.
|
||||
public function postSetPaymentType(): void // TODO: This function does not appear to be called anywhere in the code.
|
||||
{
|
||||
$this->sale_lib->set_payment_type($this->request->getPost('selected_payment_type', FILTER_SANITIZE_FULL_SPECIAL_CHARS));
|
||||
return $this->_reload(); // TODO: Hungarian notation.
|
||||
$this->_reload(); // TODO: Hungarian notation.
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets PrintAfterSale flag. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface|string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSetPrintAfterSale(): ResponseInterface
|
||||
public function postSetPrintAfterSale(): void
|
||||
{
|
||||
$this->sale_lib->set_print_after_sale($this->request->getPost('sales_print_after_sale') != 'false');
|
||||
return $this->response->setJSON(['success' => true]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the flag to include prices in the work order. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSetPriceWorkOrders(): ResponseInterface
|
||||
public function postSetPriceWorkOrders(): void
|
||||
{
|
||||
$price_work_orders = parse_decimals($this->request->getPost('price_work_orders'));
|
||||
$this->sale_lib->set_price_work_orders($price_work_orders);
|
||||
return $this->response->setJSON(['success' => true]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the flag to email receipt to the customer. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSetEmailReceipt(): ResponseInterface
|
||||
public function postSetEmailReceipt(): void
|
||||
{
|
||||
$this->sale_lib->set_email_receipt($this->request->getPost('email_receipt', FILTER_SANITIZE_FULL_SPECIAL_CHARS));
|
||||
return $this->response->setJSON(['success' => true]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a payment to the sale. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface|string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postAddPayment(): ResponseInterface|string
|
||||
public function postAddPayment(): void
|
||||
{
|
||||
$data = [];
|
||||
$giftcard = model(Giftcard::class);
|
||||
@@ -457,32 +453,32 @@ class Sales extends Secure_Controller
|
||||
}
|
||||
}
|
||||
|
||||
return $this->_reload($data);
|
||||
$this->_reload($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Multiple Payments. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @param string $payment_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getDeletePayment(string $payment_id): ResponseInterface|string
|
||||
public function getDeletePayment(string $payment_id): void
|
||||
{
|
||||
helper('url');
|
||||
|
||||
$this->sale_lib->delete_payment(base64url_decode($payment_id));
|
||||
|
||||
return $this->_reload();
|
||||
$this->_reload(); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Add an item to the sale. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postAdd(): ResponseInterface|string
|
||||
public function postAdd(): void
|
||||
{
|
||||
$data = [];
|
||||
|
||||
@@ -553,17 +549,17 @@ class Sales extends Secure_Controller
|
||||
}
|
||||
}
|
||||
|
||||
return $this->_reload($data);
|
||||
$this->_reload($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Edit an item in the sale. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @param string $line
|
||||
* @return ResponseInterface|string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postEditItem(string $line): ResponseInterface|string
|
||||
public function postEditItem(string $line): void
|
||||
{
|
||||
$data = [];
|
||||
|
||||
@@ -598,33 +594,33 @@ class Sales extends Secure_Controller
|
||||
$data['error'] = lang('Sales.error_editing_item');
|
||||
}
|
||||
|
||||
return $this->_reload($data);
|
||||
$this->_reload($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Deletes an item specified in the parameter from the shopping cart. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @param int $item_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @throws ReflectionException
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getDeleteItem(int $item_id): ResponseInterface|string
|
||||
public function getDeleteItem(int $item_id): void
|
||||
{
|
||||
$this->sale_lib->delete_item($item_id);
|
||||
|
||||
$this->sale_lib->empty_payments();
|
||||
|
||||
return $this->_reload();
|
||||
$this->_reload(); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the current customer from the sale. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getRemoveCustomer(): ResponseInterface|string
|
||||
public function getRemoveCustomer(): void
|
||||
{
|
||||
$this->sale_lib->clear_giftcard_remainder();
|
||||
$this->sale_lib->clear_rewards_remainder();
|
||||
@@ -633,17 +629,17 @@ class Sales extends Secure_Controller
|
||||
$this->sale_lib->clear_quote_number();
|
||||
$this->sale_lib->remove_customer();
|
||||
|
||||
return $this->_reload();
|
||||
$this->_reload(); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Complete and finalize a sale. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @throws ReflectionException
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postComplete(): string // TODO: this function is huge. Probably should be refactored.
|
||||
public function postComplete(): void // TODO: this function is huge. Probably should be refactored.
|
||||
{
|
||||
$sale_id = $this->sale_lib->get_sale_id();
|
||||
$data = [];
|
||||
@@ -769,7 +765,7 @@ class Sales extends Secure_Controller
|
||||
$data['error_message'] = lang('Sales.transaction_failed');
|
||||
} else {
|
||||
$data['barcode'] = $this->barcode_lib->generate_receipt_barcode($data['sale_id']);
|
||||
return view('sales/' . $invoice_view, $data);
|
||||
echo view('sales/' . $invoice_view, $data);
|
||||
$this->sale_lib->clear_all();
|
||||
}
|
||||
}
|
||||
@@ -803,7 +799,7 @@ class Sales extends Secure_Controller
|
||||
|
||||
$data['barcode'] = null;
|
||||
|
||||
return view('sales/work_order', $data);
|
||||
echo view('sales/work_order', $data);
|
||||
$this->sale_lib->clear_mode();
|
||||
$this->sale_lib->clear_all();
|
||||
}
|
||||
@@ -831,7 +827,7 @@ class Sales extends Secure_Controller
|
||||
$data['cart'] = $this->sale_lib->sort_and_filter_cart($data['cart']);
|
||||
$data['barcode'] = null;
|
||||
|
||||
return view('sales/quote', $data);
|
||||
echo view('sales/quote', $data);
|
||||
$this->sale_lib->clear_mode();
|
||||
$this->sale_lib->clear_all();
|
||||
}
|
||||
@@ -854,7 +850,7 @@ class Sales extends Secure_Controller
|
||||
$data['error_message'] = lang('Sales.transaction_failed');
|
||||
} else {
|
||||
$data['barcode'] = $this->barcode_lib->generate_receipt_barcode($data['sale_id']);
|
||||
return view('sales/receipt', $data);
|
||||
echo view('sales/receipt', $data);
|
||||
$this->sale_lib->clear_all();
|
||||
}
|
||||
}
|
||||
@@ -865,10 +861,10 @@ class Sales extends Secure_Controller
|
||||
*
|
||||
* @param int $sale_id
|
||||
* @param string $type
|
||||
* @return ResponseInterface
|
||||
* @return bool
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSendPdf(int $sale_id, string $type = 'invoice'): ResponseInterface
|
||||
public function getSendPdf(int $sale_id, string $type = 'invoice'): bool
|
||||
{
|
||||
$sale_data = $this->_load_sale_data($sale_id);
|
||||
|
||||
@@ -903,19 +899,21 @@ class Sales extends Secure_Controller
|
||||
$message = lang($result ? "Sales." . $type . "_sent" : "Sales." . $type . "_unsent") . ' ' . $to;
|
||||
}
|
||||
|
||||
echo json_encode(['success' => $result, 'message' => $message, 'id' => $sale_id]);
|
||||
|
||||
$this->sale_lib->clear_all();
|
||||
|
||||
return $this->response->setJSON(['success' => $result, 'message' => $message, 'id' => $sale_id]);
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Emails sales receipt to customer. Used in app/Views/sales/receipt.php
|
||||
*
|
||||
* @param int $sale_id
|
||||
* @return ResponseInterface
|
||||
* @return bool
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSendReceipt(int $sale_id): ResponseInterface
|
||||
public function getSendReceipt(int $sale_id): bool
|
||||
{
|
||||
$sale_data = $this->_load_sale_data($sale_id);
|
||||
|
||||
@@ -924,13 +922,6 @@ class Sales extends Secure_Controller
|
||||
|
||||
if (!empty($sale_data['customer_email'])) {
|
||||
$sale_data['barcode'] = $this->barcode_lib->generate_receipt_barcode($sale_data['sale_id']);
|
||||
$sale_data['img_tag'] = '';
|
||||
|
||||
$logo_path = FCPATH . 'uploads/' . $this->config['company_logo'];
|
||||
if (!empty($this->config['company_logo']) && file_exists($logo_path)) {
|
||||
$logo_data = base64_encode(file_get_contents($logo_path));
|
||||
$sale_data['img_tag'] = '<img id="image" src="data:image/png;base64,' . $logo_data . '" alt="company_logo">';
|
||||
}
|
||||
|
||||
$to = $sale_data['customer_email'];
|
||||
$subject = lang('Sales.receipt');
|
||||
@@ -943,9 +934,11 @@ class Sales extends Secure_Controller
|
||||
$message = lang($result ? 'Sales.receipt_sent' : 'Sales.receipt_unsent') . ' ' . $to;
|
||||
}
|
||||
|
||||
echo json_encode(['success' => $result, 'message' => $message, 'id' => $sale_id]);
|
||||
|
||||
$this->sale_lib->clear_all();
|
||||
|
||||
return $this->response->setJSON(['success' => $result, 'message' => $message, 'id' => $sale_id]);
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1116,7 +1109,7 @@ class Sales extends Secure_Controller
|
||||
* @param array $data
|
||||
* @return void
|
||||
*/
|
||||
private function _reload(array $data = []): ResponseInterface|string // TODO: Hungarian notation
|
||||
private function _reload(array $data = []): void // TODO: Hungarian notation
|
||||
{
|
||||
$sale_id = $this->session->get('sale_id'); // TODO: This variable is never used
|
||||
|
||||
@@ -1222,47 +1215,40 @@ class Sales extends Secure_Controller
|
||||
$data['customer_required'] = lang('Sales.customer_optional');
|
||||
}
|
||||
|
||||
return view("sales/register", $data);
|
||||
echo view("sales/register", $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Load the sales receipt for a sale. Used in app/Views/sales/form.php
|
||||
*
|
||||
* @param int $sale_id
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getReceipt(int $sale_id): string
|
||||
public function getReceipt(int $sale_id): void
|
||||
{
|
||||
$data = $this->_load_sale_data($sale_id);
|
||||
echo view('sales/receipt', $data);
|
||||
$this->sale_lib->clear_all();
|
||||
|
||||
return view('sales/receipt', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads the sales invoice for a sale. Used in app/Views/sales/form.php
|
||||
*
|
||||
* @param int $sale_id
|
||||
* @return string
|
||||
* @noinspection PhpUnused
|
||||
* @return void
|
||||
*/
|
||||
public function getInvoice(int $sale_id): string
|
||||
public function getInvoice(int $sale_id): void
|
||||
{
|
||||
$data = $this->_load_sale_data($sale_id);
|
||||
$this->sale_lib->clear_all();
|
||||
|
||||
return view('sales/' . $data['invoice_view'], $data);
|
||||
echo view('sales/' . $data['invoice_view'], $data);
|
||||
$this->sale_lib->clear_all();
|
||||
}
|
||||
|
||||
/**
|
||||
* Edits an existing sale or work order. Used in app/Views/sales/form.php
|
||||
*
|
||||
* @param int $sale_id
|
||||
* @return string
|
||||
* @throws ReflectionException
|
||||
* @return void
|
||||
*/
|
||||
public function getEdit(int $sale_id): string
|
||||
public function getEdit(int $sale_id): void
|
||||
{
|
||||
$data = [];
|
||||
|
||||
@@ -1307,32 +1293,30 @@ class Sales extends Secure_Controller
|
||||
|
||||
$data['new_payment_options'] = $payment_options;
|
||||
|
||||
return view('sales/form', $data);
|
||||
echo view('sales/form', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $sale_id
|
||||
* @return ResponseInterface
|
||||
* @throws ReflectionException
|
||||
*/
|
||||
public function postDelete(int $sale_id = NEW_ENTRY, bool $update_inventory = true): ResponseInterface
|
||||
public function postDelete(int $sale_id = NEW_ENTRY, bool $update_inventory = true): void
|
||||
{
|
||||
$employee_id = $this->employee->get_logged_in_employee_info()->person_id;
|
||||
$has_grant = $this->employee->has_grant('sales_delete', $employee_id);
|
||||
|
||||
if (!$has_grant) {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Sales.not_authorized')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Sales.not_authorized')]);
|
||||
} else {
|
||||
$sale_ids = $sale_id == NEW_ENTRY ? $this->request->getPost('ids', FILTER_SANITIZE_NUMBER_INT) : [$sale_id];
|
||||
|
||||
if ($this->sale->delete_list($sale_ids, $employee_id, $update_inventory)) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Sales.successfully_deleted') . ' ' . count($sale_ids) . ' ' . lang('Sales.one_or_multiple'),
|
||||
'ids' => $sale_ids
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Sales.unsuccessfully_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Sales.unsuccessfully_deleted')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1340,26 +1324,26 @@ class Sales extends Secure_Controller
|
||||
/**
|
||||
* @param int $sale_id
|
||||
* @param bool $update_inventory
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function restore(int $sale_id = NEW_ENTRY, bool $update_inventory = true): ResponseInterface
|
||||
public function restore(int $sale_id = NEW_ENTRY, bool $update_inventory = true): void
|
||||
{
|
||||
$employee_id = $this->employee->get_logged_in_employee_info()->person_id;
|
||||
$has_grant = $this->employee->has_grant('sales_delete', $employee_id);
|
||||
|
||||
if (!$has_grant) {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Sales.not_authorized')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Sales.not_authorized')]);
|
||||
} else {
|
||||
$sale_ids = $sale_id == NEW_ENTRY ? $this->request->getPost('ids', FILTER_SANITIZE_NUMBER_INT) : [$sale_id];
|
||||
|
||||
if ($this->sale->restore_list($sale_ids, $employee_id, $update_inventory)) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Sales.successfully_restored') . ' ' . count($sale_ids) . ' ' . lang('Sales.one_or_multiple'),
|
||||
'ids' => $sale_ids
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Sales.unsuccessfully_restored')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Sales.unsuccessfully_restored')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1368,10 +1352,9 @@ class Sales extends Secure_Controller
|
||||
* This saves the sale from the update sale view (sales/form).
|
||||
* It only updates the sales table and payments.
|
||||
* @param int $sale_id
|
||||
* @return ResponseInterface
|
||||
* @throws ReflectionException
|
||||
*/
|
||||
public function postSave(int $sale_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $sale_id = NEW_ENTRY): void
|
||||
{
|
||||
$newdate = $this->request->getPost('date', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
$employee_id = $this->employee->get_logged_in_employee_info()->person_id;
|
||||
@@ -1452,9 +1435,9 @@ class Sales extends Secure_Controller
|
||||
|
||||
$inventory->update('POS ' . $sale_id, ['trans_date' => $sale_time]); // TODO: Reflection Exception
|
||||
if ($this->sale->update($sale_id, $sale_data)) {
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Sales.successfully_updated'), 'id' => $sale_id]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Sales.successfully_updated'), 'id' => $sale_id]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Sales.unsuccessfully_updated'), 'id' => $sale_id]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Sales.unsuccessfully_updated'), 'id' => $sale_id]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1464,11 +1447,10 @@ class Sales extends Secure_Controller
|
||||
* Work orders can be canceled but are not physically removed from the sales history.
|
||||
* Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @throws ReflectionException
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postCancel(): ResponseInterface|string
|
||||
public function postCancel(): void
|
||||
{
|
||||
$sale_id = $this->sale_lib->get_sale_id();
|
||||
if ($sale_id != NEW_ENTRY && $sale_id != '') {
|
||||
@@ -1490,32 +1472,32 @@ class Sales extends Secure_Controller
|
||||
}
|
||||
|
||||
$this->sale_lib->clear_all();
|
||||
return $this->_reload();
|
||||
$this->_reload(); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Discards the suspended sale. Used in app/Views/sales/quote.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getDiscardSuspendedSale(): ResponseInterface|string
|
||||
public function getDiscardSuspendedSale(): void
|
||||
{
|
||||
$suspended_id = $this->sale_lib->get_suspended_id();
|
||||
$this->sale_lib->clear_all();
|
||||
$this->sale->delete_suspended_sale($suspended_id);
|
||||
return $this->_reload();
|
||||
$this->_reload(); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Suspend the current sale.
|
||||
* If the current sale is already suspended then update the existing suspended sale otherwise create
|
||||
* it as a new suspended sale. Used in app/Views/sales/register.php
|
||||
* it as a new suspended sale. Used in app/Views/sales/register.php.
|
||||
*
|
||||
* @return ResponseInterface|string
|
||||
* @throws ReflectionException
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSuspend(): ResponseInterface|string
|
||||
public function postSuspend(): void
|
||||
{
|
||||
$sale_id = $this->sale_lib->get_sale_id();
|
||||
$dinner_table = $this->sale_lib->get_dinner_table();
|
||||
@@ -1546,29 +1528,28 @@ class Sales extends Secure_Controller
|
||||
|
||||
$this->sale_lib->clear_all();
|
||||
|
||||
return $this->_reload($data);
|
||||
$this->_reload($data); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* List suspended sales
|
||||
* @return string
|
||||
*/
|
||||
public function getSuspended(): string
|
||||
public function getSuspended(): void
|
||||
{
|
||||
$data = [];
|
||||
$customer_id = $this->sale_lib->get_customer();
|
||||
$data['suspended_sales'] = $this->sale->get_all_suspended($customer_id);
|
||||
return view('sales/suspended', $data);
|
||||
echo view('sales/suspended', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Unsuspended sales are now left in the tables and are only removed
|
||||
* when they are intentionally cancelled. Used in app/Views/sales/suspended.php.
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postUnsuspend(): ResponseInterface|string
|
||||
public function postUnsuspend(): void
|
||||
{
|
||||
$sale_id = $this->request->getPost('suspended_sale_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
$this->sale_lib->clear_all();
|
||||
@@ -1580,32 +1561,32 @@ class Sales extends Secure_Controller
|
||||
// Set current register mode to reflect that of unsuspended order type
|
||||
$this->change_register_mode($this->sale_lib->get_sale_type());
|
||||
|
||||
return $this->_reload();
|
||||
$this->_reload(); // TODO: Hungarian notation
|
||||
}
|
||||
|
||||
/**
|
||||
* Show Keyboard shortcut modal. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSalesKeyboardHelp(): string
|
||||
public function getSalesKeyboardHelp(): void
|
||||
{
|
||||
return view('sales/help');
|
||||
echo view('sales/help');
|
||||
}
|
||||
|
||||
/**
|
||||
* Check the validity of an invoice number. Used in app/Views/sales/form.php.
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postCheckInvoiceNumber(): ResponseInterface
|
||||
public function postCheckInvoiceNumber(): void
|
||||
{
|
||||
$sale_id = $this->request->getPost('sale_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
$invoice_number = $this->request->getPost('invoice_number', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
$exists = !empty($invoice_number) && $this->sale->check_invoice_number_exists($invoice_number, $sale_id);
|
||||
return $this->response->setJSON(!$exists ? 'true' : 'false');
|
||||
echo !$exists ? 'true' : 'false';
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1632,10 +1613,10 @@ class Sales extends Secure_Controller
|
||||
/**
|
||||
* Update the item number in the register. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postChangeItemNumber(): ResponseInterface
|
||||
public function postChangeItemNumber(): void
|
||||
{
|
||||
$item_id = $this->request->getPost('item_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
$item_number = $this->request->getPost('item_number', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
@@ -1651,10 +1632,10 @@ class Sales extends Secure_Controller
|
||||
/**
|
||||
* Change a given item name. Used in app/Views/sales/register.php.
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postChangeItemName(): ResponseInterface
|
||||
public function postChangeItemName(): void
|
||||
{
|
||||
$item_id = $this->request->getPost('item_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
$name = $this->request->getPost('item_name', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
@@ -1674,10 +1655,10 @@ class Sales extends Secure_Controller
|
||||
/**
|
||||
* Update the given item description. Used in app/Views/sales/register.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postChangeItemDescription(): ResponseInterface
|
||||
public function postChangeItemDescription(): void
|
||||
{
|
||||
$item_id = $this->request->getPost('item_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
$description = $this->request->getPost('item_description', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
|
||||
@@ -4,7 +4,7 @@ namespace App\Controllers;
|
||||
|
||||
use App\Models\Employee;
|
||||
use App\Models\Module;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
|
||||
use CodeIgniter\Model;
|
||||
use CodeIgniter\Session\Session;
|
||||
use Config\OSPOS;
|
||||
@@ -85,17 +85,18 @@ class Secure_Controller extends BaseController
|
||||
|
||||
/**
|
||||
* AJAX function used to confirm whether values sent in the request are numeric
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getCheckNumeric(): ResponseInterface
|
||||
public function getCheckNumeric(): void
|
||||
{
|
||||
foreach ($this->request->getGet() as $value) {
|
||||
if (parse_decimals($value) === false) {
|
||||
return $this->response->setJSON('false');
|
||||
echo 'false';
|
||||
return;
|
||||
}
|
||||
}
|
||||
return $this->response->setJSON('true');
|
||||
echo 'true';
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Supplier;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Services;
|
||||
|
||||
class Suppliers extends Persons
|
||||
@@ -18,33 +17,33 @@ class Suppliers extends Persons
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['table_headers'] = get_suppliers_manage_table_headers();
|
||||
|
||||
return view('people/manage', $data);
|
||||
echo view('people/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets one row for a supplier manage table. This is called using AJAX to update one row.
|
||||
* @param $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow($row_id): ResponseInterface
|
||||
public function getRow($row_id): void
|
||||
{
|
||||
$data_row = get_supplier_data_row($this->supplier->get_info($row_id));
|
||||
$data_row['category'] = $this->supplier->get_category_name($data_row['category']);
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns Supplier table data rows. This will be called with AJAX.
|
||||
* @return void
|
||||
**/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -63,39 +62,38 @@ class Suppliers extends Persons
|
||||
$data_rows[] = $row;
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gives search suggestions based on what is being searched for
|
||||
* @return ResponseInterface
|
||||
**/
|
||||
public function getSuggest(): ResponseInterface
|
||||
public function getSuggest(): void
|
||||
{
|
||||
$search = $this->request->getGet('term');
|
||||
$suggestions = $this->supplier->get_search_suggestions($search, true);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function suggest_search(): ResponseInterface
|
||||
public function suggest_search(): void
|
||||
{
|
||||
$search = $this->request->getPost('term');
|
||||
$suggestions = $this->supplier->get_search_suggestions($search, false);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads the supplier edit form
|
||||
*
|
||||
* @param int $supplier_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $supplier_id = NEW_ENTRY): string
|
||||
public function getView(int $supplier_id = NEW_ENTRY): void
|
||||
{
|
||||
$info = $this->supplier->get_info($supplier_id);
|
||||
foreach (get_object_vars($info) as $property => $value) {
|
||||
@@ -104,16 +102,16 @@ class Suppliers extends Persons
|
||||
$data['person_info'] = $info;
|
||||
$data['categories'] = $this->supplier->get_categories();
|
||||
|
||||
return view("suppliers/form", $data);
|
||||
echo view("suppliers/form", $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Inserts/updates a supplier
|
||||
*
|
||||
* @param int $supplier_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postSave(int $supplier_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $supplier_id = NEW_ENTRY): void
|
||||
{
|
||||
$first_name = $this->request->getPost('first_name', FILTER_SANITIZE_FULL_SPECIAL_CHARS); // TODO: Duplicate code
|
||||
$last_name = $this->request->getPost('last_name', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
@@ -149,21 +147,21 @@ class Suppliers extends Persons
|
||||
if ($this->supplier->save_supplier($person_data, $supplier_data, $supplier_id)) {
|
||||
// New supplier
|
||||
if ($supplier_id == NEW_ENTRY) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Suppliers.successful_adding') . ' ' . $supplier_data['company_name'],
|
||||
'id' => $supplier_data['person_id']
|
||||
]);
|
||||
} else { // Existing supplier
|
||||
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Suppliers.successful_updating') . ' ' . $supplier_data['company_name'],
|
||||
'id' => $supplier_id
|
||||
]);
|
||||
}
|
||||
} else { // Failure
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Suppliers.error_adding_updating') . ' ' . $supplier_data['company_name'],
|
||||
'id' => NEW_ENTRY
|
||||
@@ -174,19 +172,19 @@ class Suppliers extends Persons
|
||||
/**
|
||||
* This deletes suppliers from the suppliers table
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$suppliers_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_NUMBER_INT);
|
||||
|
||||
if ($this->supplier->delete_list($suppliers_to_delete)) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Suppliers.successful_deleted') . ' ' . count($suppliers_to_delete) . ' ' . lang('Suppliers.one_or_multiple')
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Suppliers.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Suppliers.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Tax_category;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Services;
|
||||
|
||||
/**
|
||||
@@ -21,13 +20,13 @@ class Tax_categories extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['tax_categories_table_headers'] = get_tax_categories_table_headers();
|
||||
|
||||
return view('taxes/tax_categories', $data);
|
||||
echo view('taxes/tax_categories', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -35,7 +34,7 @@ class Tax_categories extends Secure_Controller
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -51,37 +50,37 @@ class Tax_categories extends Secure_Controller
|
||||
$data_rows[] = get_tax_categories_data_row($tax_category);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow($row_id): ResponseInterface
|
||||
public function getRow($row_id): void
|
||||
{
|
||||
$data_row = get_tax_categories_data_row($this->tax_category->get_info($row_id));
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $tax_category_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $tax_category_id = NEW_ENTRY): string
|
||||
public function getView(int $tax_category_id = NEW_ENTRY): void
|
||||
{
|
||||
$data['tax_category_info'] = $this->tax_category->get_info($tax_category_id);
|
||||
|
||||
return view("taxes/tax_category_form", $data);
|
||||
echo view("taxes/tax_category_form", $data);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param int $tax_category_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postSave(int $tax_category_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $tax_category_id = NEW_ENTRY): void
|
||||
{
|
||||
$tax_category_data = [
|
||||
'tax_category' => $this->request->getPost('tax_category', FILTER_SANITIZE_FULL_SPECIAL_CHARS),
|
||||
@@ -92,20 +91,20 @@ class Tax_categories extends Secure_Controller
|
||||
if ($this->tax_category->save_value($tax_category_data, $tax_category_id)) {
|
||||
// New tax_category_id
|
||||
if ($tax_category_id == NEW_ENTRY) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Tax_categories.successful_adding'),
|
||||
'id' => $tax_category_data['tax_category_id']
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Tax_categories.successful_updating'),
|
||||
'id' => $tax_category_id
|
||||
]);
|
||||
}
|
||||
} else {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Tax_categories.error_adding_updating') . ' ' . $tax_category_data['tax_category'],
|
||||
'id' => NEW_ENTRY
|
||||
@@ -114,19 +113,19 @@ class Tax_categories extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$tax_categories_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_NUMBER_INT);
|
||||
|
||||
if ($this->tax_category->delete_list($tax_categories_to_delete)) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Tax_categories.successful_deleted') . ' ' . count($tax_categories_to_delete) . ' ' . lang('Tax_categories.one_or_multiple')
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Tax_categories.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Tax_categories.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Tax_code;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Services;
|
||||
|
||||
/**
|
||||
@@ -23,11 +22,11 @@ class Tax_codes extends Secure_Controller
|
||||
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
return view('taxes/tax_codes', $this->get_data());
|
||||
echo view('taxes/tax_codes', $this->get_data());
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -45,7 +44,7 @@ class Tax_codes extends Secure_Controller
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -62,37 +61,37 @@ class Tax_codes extends Secure_Controller
|
||||
$data_rows[] = get_tax_code_data_row($tax_code);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$data_row = get_tax_code_data_row($this->tax_code->get_info($row_id));
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $tax_code_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $tax_code_id = NEW_ENTRY): string
|
||||
public function getView(int $tax_code_id = NEW_ENTRY): void
|
||||
{
|
||||
$data['tax_code_info'] = $this->tax_code->get_info($tax_code_id);
|
||||
|
||||
return view("taxes/tax_code_form", $data);
|
||||
echo view("taxes/tax_code_form", $data);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param int $tax_code_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postSave(int $tax_code_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $tax_code_id = NEW_ENTRY): void
|
||||
{
|
||||
$tax_code_data = [
|
||||
'tax_code' => $this->request->getPost('tax_code', FILTER_SANITIZE_FULL_SPECIAL_CHARS),
|
||||
@@ -103,20 +102,20 @@ class Tax_codes extends Secure_Controller
|
||||
|
||||
if ($this->tax_code->save($tax_code_data)) {
|
||||
if ($tax_code_id == NEW_ENTRY) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Tax_codes.successful_adding'),
|
||||
'id' => $tax_code_data['tax_code_id']
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Tax_codes.successful_updating'),
|
||||
'id' => $tax_code_id
|
||||
]);
|
||||
}
|
||||
} else {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Tax_codes.error_adding_updating') . ' ' . $tax_code_data['tax_code_id'],
|
||||
'id' => NEW_ENTRY
|
||||
@@ -125,19 +124,19 @@ class Tax_codes extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$tax_codes_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_NUMBER_INT);
|
||||
|
||||
if ($this->tax_code->delete_list($tax_codes_to_delete)) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Tax_codes.successful_deleted') . ' ' . count($tax_codes_to_delete) . ' ' . lang('Tax_codes.one_or_multiple')
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Tax_codes.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Tax_codes.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
namespace App\Controllers;
|
||||
|
||||
use App\Models\Tax_jurisdiction;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\Services;
|
||||
|
||||
/**
|
||||
@@ -24,13 +23,13 @@ class Tax_jurisdictions extends Secure_Controller
|
||||
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['table_headers'] = get_tax_jurisdictions_table_headers();
|
||||
|
||||
return view('taxes/tax_jurisdictions', $data);
|
||||
echo view('taxes/tax_jurisdictions', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -38,7 +37,7 @@ class Tax_jurisdictions extends Secure_Controller
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -54,37 +53,37 @@ class Tax_jurisdictions extends Secure_Controller
|
||||
$data_rows[] = get_tax_jurisdictions_data_row($tax_jurisdiction);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$data_row = get_tax_jurisdictions_data_row($this->tax_jurisdiction->get_info($row_id));
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $tax_jurisdiction_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $tax_jurisdiction_id = NEW_ENTRY): string
|
||||
public function getView(int $tax_jurisdiction_id = NEW_ENTRY): void
|
||||
{
|
||||
$data['tax_jurisdiction_info'] = $this->tax_jurisdiction->get_info($tax_jurisdiction_id);
|
||||
|
||||
return view("taxes/tax_jurisdiction_form", $data);
|
||||
echo view("taxes/tax_jurisdiction_form", $data);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param int $jurisdiction_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postSave(int $jurisdiction_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $jurisdiction_id = NEW_ENTRY): void
|
||||
{
|
||||
$tax_jurisdiction_data = [
|
||||
'jurisdiction_name' => $this->request->getPost('jurisdiction_name', FILTER_SANITIZE_FULL_SPECIAL_CHARS),
|
||||
@@ -93,20 +92,20 @@ class Tax_jurisdictions extends Secure_Controller
|
||||
|
||||
if ($this->tax_jurisdiction->save_value($tax_jurisdiction_data)) {
|
||||
if ($jurisdiction_id == NEW_ENTRY) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Tax_jurisdictions.successful_adding'),
|
||||
'id' => $tax_jurisdiction_data['jurisdiction_id']
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Tax_jurisdictions.successful_updating'),
|
||||
'id' => $jurisdiction_id
|
||||
]);
|
||||
}
|
||||
} else {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Tax_jurisdictions.error_adding_updating') . ' ' . $tax_jurisdiction_data['jurisdiction_name'],
|
||||
'id' => NEW_ENTRY
|
||||
@@ -115,19 +114,19 @@ class Tax_jurisdictions extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$tax_jurisdictions_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_NUMBER_INT);
|
||||
|
||||
if ($this->tax_jurisdiction->delete_list($tax_jurisdictions_to_delete)) {
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => true,
|
||||
'message' => lang('Tax_jurisdictions.successful_deleted') . ' ' . count($tax_jurisdictions_to_delete) . ' ' . lang('Tax_jurisdictions.one_or_multiple')
|
||||
]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Tax_jurisdictions.cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Tax_jurisdictions.cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -8,7 +8,6 @@ use App\Models\Tax;
|
||||
use App\Models\Tax_category;
|
||||
use App\Models\Tax_code;
|
||||
use App\Models\Tax_jurisdiction;
|
||||
use CodeIgniter\HTTP\ResponseInterface;
|
||||
use Config\OSPOS;
|
||||
use Config\Services;
|
||||
|
||||
@@ -37,9 +36,9 @@ class Taxes extends Secure_Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getIndex(): string
|
||||
public function getIndex(): void
|
||||
{
|
||||
$data['tax_codes'] = $this->tax_code->get_all()->getResultArray();
|
||||
if (count($data['tax_codes']) == 0) {
|
||||
@@ -68,7 +67,7 @@ class Taxes extends Secure_Controller
|
||||
|
||||
$data['tax_type_options'] = $this->tax_lib->get_tax_type_options($data['default_tax_type']);
|
||||
|
||||
return view('taxes/manage', $data);
|
||||
echo view('taxes/manage', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -76,7 +75,7 @@ class Taxes extends Secure_Controller
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function getSearch(): ResponseInterface
|
||||
public function getSearch(): void
|
||||
{
|
||||
$search = $this->request->getGet('search');
|
||||
$limit = $this->request->getGet('limit', FILTER_SANITIZE_NUMBER_INT);
|
||||
@@ -93,50 +92,50 @@ class Taxes extends Secure_Controller
|
||||
$data_rows[] = get_tax_rates_data_row($tax_rate_row);
|
||||
}
|
||||
|
||||
return $this->response->setJSON(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
echo json_encode(['total' => $total_rows, 'rows' => $data_rows]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gives search suggestions based on what is being searched for
|
||||
* @return ResponseInterface
|
||||
*/
|
||||
public function suggest_search(): ResponseInterface
|
||||
public function suggest_search(): void
|
||||
{
|
||||
$search = $this->request->getPost('term');
|
||||
$suggestions = $this->tax->get_search_suggestions($search); // TODO: There is no get_search_suggestions function in the tax model
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Provides list of tax categories to select from
|
||||
* @return ResponseInterface
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function suggest_tax_categories(): ResponseInterface
|
||||
public function suggest_tax_categories(): void
|
||||
{
|
||||
$search = $this->request->getPost('term');
|
||||
$suggestions = $this->tax_category->get_tax_category_suggestions($search);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param int $row_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function getRow(int $row_id): ResponseInterface
|
||||
public function getRow(int $row_id): void
|
||||
{
|
||||
$data_row = get_tax_rates_data_row($this->tax->get_info($row_id));
|
||||
|
||||
return $this->response->setJSON($data_row);
|
||||
echo json_encode($data_row);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $tax_code
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView_tax_codes(int $tax_code = NEW_ENTRY): string
|
||||
public function getView_tax_codes(int $tax_code = NEW_ENTRY): void
|
||||
{
|
||||
$tax_code_info = $this->tax->get_info($tax_code);
|
||||
|
||||
@@ -193,15 +192,15 @@ class Taxes extends Secure_Controller
|
||||
|
||||
$data['tax_rates'] = $tax_rates;
|
||||
|
||||
return view('taxes/tax_code_form', $data);
|
||||
echo view('taxes/tax_code_form', $data);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param int $tax_rate_id
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView(int $tax_rate_id = NEW_ENTRY): string
|
||||
public function getView(int $tax_rate_id = NEW_ENTRY): void
|
||||
{
|
||||
$tax_rate_info = $this->tax->get_info($tax_rate_id);
|
||||
|
||||
@@ -227,14 +226,14 @@ class Taxes extends Secure_Controller
|
||||
$data['tax_rate'] = $tax_rate_info->tax_rate;
|
||||
}
|
||||
|
||||
return view('taxes/tax_rates_form', $data);
|
||||
echo view('taxes/tax_rates_form', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $tax_code
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView_tax_categories(int $tax_code = NEW_ENTRY): string // TODO: This appears to be called no where in the code.
|
||||
public function getView_tax_categories(int $tax_code = NEW_ENTRY): void // TODO: This appears to be called no where in the code.
|
||||
{
|
||||
$tax_code_info = $this->tax->get_info($tax_code); // TODO: Duplicated Code
|
||||
|
||||
@@ -291,14 +290,14 @@ class Taxes extends Secure_Controller
|
||||
|
||||
$data['tax_rates'] = $tax_rates;
|
||||
|
||||
return view('taxes/tax_category_form', $data);
|
||||
echo view('taxes/tax_category_form', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $tax_code
|
||||
* @return string
|
||||
* @return void
|
||||
*/
|
||||
public function getView_tax_jurisdictions(int $tax_code = NEW_ENTRY): string // TODO: This appears to be called no where in the code.
|
||||
public function getView_tax_jurisdictions(int $tax_code = NEW_ENTRY): void // TODO: This appears to be called no where in the code.
|
||||
{
|
||||
$tax_code_info = $this->tax->get_info($tax_code); // TODO: Duplicated code
|
||||
|
||||
@@ -355,7 +354,7 @@ class Taxes extends Secure_Controller
|
||||
|
||||
$data['tax_rates'] = $tax_rates;
|
||||
|
||||
return view('taxes/tax_jurisdiction_form', $data);
|
||||
echo view('taxes/tax_jurisdiction_form', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -368,9 +367,9 @@ class Taxes extends Secure_Controller
|
||||
|
||||
/**
|
||||
* @param int $tax_rate_id
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postSave(int $tax_rate_id = NEW_ENTRY): ResponseInterface
|
||||
public function postSave(int $tax_rate_id = NEW_ENTRY): void
|
||||
{
|
||||
$tax_category_id = $this->request->getPost('rate_tax_category_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
$tax_rate = parse_tax($this->request->getPost('tax_rate'));
|
||||
@@ -389,50 +388,50 @@ class Taxes extends Secure_Controller
|
||||
|
||||
if ($this->tax->save_value($tax_rate_data, $tax_rate_id)) {
|
||||
if ($tax_rate_id == NEW_ENTRY) { // TODO: this needs to be replaced with ternary notation
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Taxes.tax_rate_successfully_added')]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Taxes.tax_rate_successfully_added')]);
|
||||
} else { // Existing tax_code
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Taxes.tax_rate_successful_updated')]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Taxes.tax_rate_successful_updated')]);
|
||||
}
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Taxes.tax_rate_error_adding_updating')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Taxes.tax_rate_error_adding_updating')]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
*/
|
||||
public function postDelete(): ResponseInterface
|
||||
public function postDelete(): void
|
||||
{
|
||||
$tax_codes_to_delete = $this->request->getPost('ids', FILTER_SANITIZE_NUMBER_INT);
|
||||
|
||||
if ($this->tax->delete_list($tax_codes_to_delete)) { // TODO: this needs to be replaced with ternary notation
|
||||
return $this->response->setJSON(['success' => true, 'message' => lang('Taxes.tax_code_successful_deleted')]);
|
||||
echo json_encode(['success' => true, 'message' => lang('Taxes.tax_code_successful_deleted')]);
|
||||
} else {
|
||||
return $this->response->setJSON(['success' => false, 'message' => lang('Taxes.tax_code_cannot_be_deleted')]);
|
||||
echo json_encode(['success' => false, 'message' => lang('Taxes.tax_code_cannot_be_deleted')]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Get search suggestions for tax codes. Used in app/Views/customers/form.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getSuggestTaxCodes(): ResponseInterface
|
||||
public function getSuggestTaxCodes(): void
|
||||
{
|
||||
$search = $this->request->getPostGet('term');
|
||||
$suggestions = $this->tax_code->get_tax_codes_search_suggestions($search);
|
||||
|
||||
return $this->response->setJSON($suggestions);
|
||||
echo json_encode($suggestions);
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves Tax Codes. Used in app/Views/taxes/tax_codes.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSave_tax_codes(): ResponseInterface
|
||||
public function postSave_tax_codes(): void
|
||||
{
|
||||
$tax_code_id = $this->request->getPost('tax_code_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
$tax_code = $this->request->getPost('tax_code', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
@@ -453,7 +452,7 @@ class Taxes extends Secure_Controller
|
||||
|
||||
$success = $this->tax_code->save_tax_codes($array_save);
|
||||
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => $success,
|
||||
'message' => lang('Taxes.tax_codes_saved_' . ($success ? '' : 'un') . 'successfully')
|
||||
]);
|
||||
@@ -462,10 +461,10 @@ class Taxes extends Secure_Controller
|
||||
/**
|
||||
* Saves given tax jurisdiction. Used in app/Views/taxes/tax_jurisdictions.php.
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSave_tax_jurisdictions(): ResponseInterface
|
||||
public function postSave_tax_jurisdictions(): void
|
||||
{
|
||||
$jurisdiction_id = $this->request->getPost('jurisdiction_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
$jurisdiction_name = $this->request->getPost('jurisdiction_name', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
@@ -490,10 +489,11 @@ class Taxes extends Secure_Controller
|
||||
];
|
||||
|
||||
if (in_array($tax_group[$key], $unique_tax_groups)) { // TODO: This can be replaced with `in_array($tax_group[$key], $unique_tax_groups)`
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => false,
|
||||
'message' => lang('Taxes.tax_group_not_unique', [$tax_group[$key]])
|
||||
]);
|
||||
return;
|
||||
} else {
|
||||
$unique_tax_groups[] = $tax_group[$key];
|
||||
}
|
||||
@@ -501,7 +501,7 @@ class Taxes extends Secure_Controller
|
||||
|
||||
$success = $this->tax_jurisdiction->save_jurisdictions($array_save);
|
||||
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => $success,
|
||||
'message' => lang('Taxes.tax_jurisdictions_saved_' . ($success ? '' : 'un') . 'successfully')
|
||||
]);
|
||||
@@ -510,10 +510,10 @@ class Taxes extends Secure_Controller
|
||||
/**
|
||||
* Saves tax categories. Used in app/Views/taxes/tax_categories.php
|
||||
*
|
||||
* @return ResponseInterface
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function postSave_tax_categories(): ResponseInterface
|
||||
public function postSave_tax_categories(): void
|
||||
{
|
||||
$tax_category_id = $this->request->getPost('tax_category_id', FILTER_SANITIZE_NUMBER_INT);
|
||||
$tax_category = $this->request->getPost('tax_category', FILTER_SANITIZE_FULL_SPECIAL_CHARS);
|
||||
@@ -531,7 +531,7 @@ class Taxes extends Secure_Controller
|
||||
|
||||
$success = $this->tax_category->save_categories($array_save);
|
||||
|
||||
return $this->response->setJSON([
|
||||
echo json_encode([
|
||||
'success' => $success,
|
||||
'message' => lang('Taxes.tax_categories_saved_' . ($success ? '' : 'un') . 'successfully')
|
||||
]);
|
||||
@@ -540,36 +540,36 @@ class Taxes extends Secure_Controller
|
||||
/**
|
||||
* Gets tax codes partial view. Used in app/Views/taxes/tax_codes.php.
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getAjax_tax_codes(): string
|
||||
public function getAjax_tax_codes(): void
|
||||
{
|
||||
$tax_codes = $this->tax_code->get_all()->getResultArray();
|
||||
|
||||
return view('partial/tax_codes', ['tax_codes' => $tax_codes]);
|
||||
echo view('partial/tax_codes', ['tax_codes' => $tax_codes]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets current tax categories. Used in app/Views/taxes/tax_categories.php
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getAjax_tax_categories(): string
|
||||
public function getAjax_tax_categories(): void
|
||||
{
|
||||
$tax_categories = $this->tax_category->get_all()->getResultArray();
|
||||
|
||||
return view('partial/tax_categories', ['tax_categories' => $tax_categories]);
|
||||
echo view('partial/tax_categories', ['tax_categories' => $tax_categories]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the tax jurisdiction partial view. Used in app/Views/taxes/tax_jurisdictions.php.
|
||||
*
|
||||
* @return string
|
||||
* @return void
|
||||
* @noinspection PhpUnused
|
||||
*/
|
||||
public function getAjax_tax_jurisdictions(): string
|
||||
public function getAjax_tax_jurisdictions(): void
|
||||
{
|
||||
$tax_jurisdictions = $this->tax_jurisdiction->get_all()->getResultArray();
|
||||
|
||||
@@ -581,7 +581,7 @@ class Taxes extends Secure_Controller
|
||||
|
||||
$tax_types = $this->tax_lib->get_tax_types();
|
||||
|
||||
return view('partial/tax_jurisdictions', [
|
||||
echo view('partial/tax_jurisdictions', [
|
||||
'tax_jurisdictions' => $tax_jurisdictions,
|
||||
'tax_types' => $tax_types,
|
||||
'default_tax_type' => $default_tax_type
|
||||
|
||||
@@ -21,6 +21,6 @@ class Migration_receipttaxindicator extends Migration
|
||||
*/
|
||||
public function down(): void
|
||||
{
|
||||
$this->db->query('DELETE FROM ' . $this->db->prefixTable('app_config') . ' WHERE `key` = \'receipt_show_tax_ind\'');
|
||||
$this->db->query('DELETE FROM ' . $this->db->prefixTable('app_config') . ' WHERE key = \'receipt_show_tax_ind\'');
|
||||
}
|
||||
}
|
||||
|
||||
@@ -20,7 +20,7 @@ class Migration_database_optimizations extends Migration
|
||||
|
||||
$attribute = model(Attribute::class);
|
||||
|
||||
$attribute->delete_orphaned_values();
|
||||
$attribute->deleteOrphanedValues();
|
||||
|
||||
$this->migrate_duplicate_attribute_values(DECIMAL);
|
||||
$this->migrate_duplicate_attribute_values(DATE);
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
[mysqld]
|
||||
sql_mode = "STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"
|
||||
sql_mode = "STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"
|
||||
|
||||
key_buffer = 16M
|
||||
max_allowed_packet = 1M
|
||||
|
||||
33
app/Helpers/attribute_helper.php
Normal file
33
app/Helpers/attribute_helper.php
Normal file
@@ -0,0 +1,33 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* Translates the attribute type to the corresponding database column name.
|
||||
*
|
||||
* Maps attribute type constants to their corresponding attribute_values table columns.
|
||||
* Defaults to 'attribute_value' for TEXT, DROPDOWN and CHECKBOX attribute types.
|
||||
*
|
||||
* @param string $input The attribute type constant (DATE, DECIMAL, etc.)
|
||||
* @return string The database column name for storing this attribute type
|
||||
*/
|
||||
function getAttributeDataType(string $input): string
|
||||
{
|
||||
$columnMap = [
|
||||
DATE => 'attribute_date',
|
||||
DECIMAL => 'attribute_decimal',
|
||||
];
|
||||
|
||||
return $columnMap[$input] ?? 'attribute_value';
|
||||
}
|
||||
|
||||
/**
|
||||
* Validates that the provided data type is an allowed attribute value type.
|
||||
*
|
||||
* @param string $dataType
|
||||
* @return void
|
||||
*/
|
||||
function validateAttributeValueType(string $dataType): void
|
||||
{
|
||||
if (!in_array($dataType, ATTRIBUTE_VALUE_TYPES, true)) {
|
||||
throw new InvalidArgumentException('Invalid data type');
|
||||
}
|
||||
}
|
||||
@@ -1,10 +1,10 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* @param array $stock_locations
|
||||
* @param array $attributes
|
||||
* @return string
|
||||
*/
|
||||
|
||||
function generate_import_items_csv(array $stock_locations, array $attributes): string
|
||||
{
|
||||
$csv_headers = pack('CCC', 0xef, 0xbb, 0xbf); // Encode the Byte-Order Mark (BOM) so that UTF-8 File headers display properly in Microsoft Excel
|
||||
|
||||
@@ -89,8 +89,6 @@ function get_languages(): array
|
||||
'pt-BR:portuguese' => 'Portuguese (Brazil)',
|
||||
'ro:romanian' => 'Romanian',
|
||||
'ru:russian' => 'Russian',
|
||||
'sw-KE:swahili' => 'Swahili (Kenya)',
|
||||
'sw-TZ:swahili' => 'Swahili (Tanzania)',
|
||||
'sv:swedish' => 'Swedish',
|
||||
'ta:tamil' => 'Tamil',
|
||||
'th:thai' => 'Thai',
|
||||
|
||||
@@ -108,4 +108,3 @@ function remove_backup(): void
|
||||
}
|
||||
log_message('info', "File $backup_path has been removed");
|
||||
}
|
||||
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "ابداء بكتابة اسم المورد....",
|
||||
"stock" => "المخزون",
|
||||
"stock_destination" => "المخزون المحول له",
|
||||
"stock_location" => "مكان المخزون",
|
||||
"stock_locaiton" => "مكان المخزون",
|
||||
"stock_source" => "مصدر المخزون",
|
||||
"successfully_deleted" => "لقد تم الحذف",
|
||||
"successfully_updated" => "لقد تم التحديث",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "ابداء بكتابة اسم المورد....",
|
||||
"stock" => "المخزون",
|
||||
"stock_destination" => "المخزون المحول له",
|
||||
"stock_location" => "مكان المخزون",
|
||||
"stock_locaiton" => "مكان المخزون",
|
||||
"stock_source" => "مصدر المخزون",
|
||||
"successfully_deleted" => "لقد تم الحذف",
|
||||
"successfully_updated" => "لقد تم التحديث",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Təchizatçıın adını yazmağa başlayın ...",
|
||||
"stock" => "Ehtiyyat",
|
||||
"stock_destination" => "Ehtiyyatın Hədəfi",
|
||||
"stock_location" => "Ehtiyyatın Yeri",
|
||||
"stock_locaiton" => "Ehtiyyatın Yeri",
|
||||
"stock_source" => "Ehtiyyatın Mənbəyi",
|
||||
"successfully_deleted" => "cəmi",
|
||||
"successfully_updated" => "alışda sehv var",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Start Typing Supplier's name...",
|
||||
"stock" => "",
|
||||
"stock_destination" => "Stock Destination",
|
||||
"stock_location" => "Stock Location",
|
||||
"stock_locaiton" => "Stock Location",
|
||||
"stock_source" => "Stock Source",
|
||||
"successfully_deleted" => "You have successfully deleted",
|
||||
"successfully_updated" => "Receiving successfully updated",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Počnite upisivati ime dobavljača ...",
|
||||
"stock" => "Skladište",
|
||||
"stock_destination" => "Destinacija skladišta",
|
||||
"stock_location" => "Lokacija zaliha",
|
||||
"stock_locaiton" => "Lokacija zaliha",
|
||||
"stock_source" => "Izvor zaliha",
|
||||
"successfully_deleted" => "Uspješno ste izbrisali prijem",
|
||||
"successfully_updated" => "Uspješno ste ažurirali prijem",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
'start_typing_supplier_name' => "دەست بکە بە نووسینی ناوی دابینکەر...",
|
||||
'stock' => "کۆگا",
|
||||
'stock_destination' => "شوێنی مەبەستی کۆگا",
|
||||
'stock_location' => "شوێنی کۆگا",
|
||||
'stock_locaiton' => "شوێنی کۆگا",
|
||||
'stock_source' => "سەرچاوەی کۆگا",
|
||||
'successfully_deleted' => "بەسەرکەوتوویی سڕیتەوە",
|
||||
'successfully_updated' => "وەرگرتن بە سەرکەوتوویی نوێ کراوەتەوە",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Začněte psát jméno dodavatele...",
|
||||
"stock" => "Sklad",
|
||||
"stock_destination" => "Cílový sklad",
|
||||
"stock_location" => "Umístění skladu",
|
||||
"stock_locaiton" => "Umístění skladu",
|
||||
"stock_source" => "",
|
||||
"successfully_deleted" => "Smazáno",
|
||||
"successfully_updated" => "Upraveno",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "",
|
||||
"stock" => "",
|
||||
"stock_destination" => "",
|
||||
"stock_location" => "",
|
||||
"stock_locaiton" => "",
|
||||
"stock_source" => "",
|
||||
"successfully_deleted" => "",
|
||||
"successfully_updated" => "",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Lieferantenname eingeben",
|
||||
"stock" => "",
|
||||
"stock_destination" => "Lagerort (Ziel)",
|
||||
"stock_location" => "Lagerort",
|
||||
"stock_locaiton" => "Lagerort",
|
||||
"stock_source" => "Lagerort (Quelle)",
|
||||
"successfully_deleted" => "Löschung erfolgreich",
|
||||
"successfully_updated" => "Änderung erfolgreich",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Eintippen des Namens des Lieferanten beginnen...",
|
||||
"stock" => "Lager",
|
||||
"stock_destination" => "Lagerort (Ziel)",
|
||||
"stock_location" => "Lagerort",
|
||||
"stock_locaiton" => "Lagerort",
|
||||
"stock_source" => "Lagerort (Quelle)",
|
||||
"successfully_deleted" => "Löschung erfolgreich",
|
||||
"successfully_updated" => "Änderung erfolgreich",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Πληκτρολογήστε το όνομα του Προμηθευτή...",
|
||||
"stock" => "Απόθεμα",
|
||||
"stock_destination" => "Προορισμός Αποθέματος",
|
||||
"stock_location" => "Τοποθεσία Αποθέματος",
|
||||
"stock_locaiton" => "Τοποθεσία Αποθέματος",
|
||||
"stock_source" => "Προέλευση Αποθέματος",
|
||||
"successfully_deleted" => "Έχετε διαγράψει επιτυχώς",
|
||||
"successfully_updated" => "Επιτυχής ενημέρωση Παραλαβής",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Start Typing Supplier's name...",
|
||||
"stock" => "Stock",
|
||||
"stock_destination" => "Stock Destination",
|
||||
"stock_location" => "Stock Location",
|
||||
"stock_locaiton" => "Stock Location",
|
||||
"stock_source" => "Stock Source",
|
||||
"successfully_deleted" => "You have successfully deleted receiving",
|
||||
"successfully_updated" => "Receiving successfully updated",
|
||||
|
||||
@@ -14,9 +14,7 @@ return [
|
||||
"current_password_invalid" => "Current Password is invalid.",
|
||||
"employee" => "Employee",
|
||||
"error_adding_updating" => "Employee add or update failed.",
|
||||
"error_deleting_admin" => "You cannot delete an admin user.",
|
||||
"error_deleting_demo_admin" => "You can not delete the demo admin user.",
|
||||
"error_updating_admin" => "You cannot modify an admin user.",
|
||||
"error_updating_demo_admin" => "You can not change the demo admin user.",
|
||||
"language" => "Language",
|
||||
"login_info" => "Login",
|
||||
|
||||
@@ -26,6 +26,7 @@ return [
|
||||
"cost_price_required" => "Wholesale Price is a required field.",
|
||||
"count" => "Update Inventory",
|
||||
"csv_import_failed" => "CSV import failed",
|
||||
"csv_import_invalid_location" => "Invalid stock location(s) found: {0}. Only valid stock locations are allowed.",
|
||||
"csv_import_nodata_wrongformat" => "The uploaded CSV file has no data or is formatted incorrectly.",
|
||||
"csv_import_partially_failed" => "There were {0} item import failure(s) on line(s): {1}. No rows were imported.",
|
||||
"csv_import_success" => "Item CSV import successful.",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Start Typing Supplier's name...",
|
||||
"stock" => "Stock",
|
||||
"stock_destination" => "Stock Destination",
|
||||
"stock_location" => "Stock Location",
|
||||
"stock_locaiton" => "Stock Location",
|
||||
"stock_source" => "Stock Source",
|
||||
"successfully_deleted" => "You have successfully deleted",
|
||||
"successfully_updated" => "Receiving successfully updated",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Empieza a escribir el nombre del proveedor...",
|
||||
"stock" => "Inventario",
|
||||
"stock_destination" => "Inventario de Destino",
|
||||
"stock_location" => "Ubicación de Inventario",
|
||||
"stock_locaiton" => "Ubicación de Inventario",
|
||||
"stock_source" => "Inventario de Origen",
|
||||
"successfully_deleted" => "Borro exitosamente",
|
||||
"successfully_updated" => "Recepción exitosamente actualizada",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Empiece a escribir el nombre del Proveedor...",
|
||||
"stock" => "Existencia",
|
||||
"stock_destination" => "Destino del Inventario",
|
||||
"stock_location" => "Ubicación del Inventario",
|
||||
"stock_locaiton" => "Ubicación del Inventario",
|
||||
"stock_source" => "Origen del Inventario",
|
||||
"successfully_deleted" => "Se ha borrado exitosamente",
|
||||
"successfully_updated" => "Recepción actualizada exitosamente",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "شروع به تایپ کردن نام ارائه دهنده ...",
|
||||
"stock" => "موجودی",
|
||||
"stock_destination" => "مقصد سهام",
|
||||
"stock_location" => "موقعیت مکانی سهام",
|
||||
"stock_locaiton" => "موقعیت مکانی سهام",
|
||||
"stock_source" => "منبع سهام",
|
||||
"successfully_deleted" => "شما با موفقیت حذف شده اید",
|
||||
"successfully_updated" => "دریافت با موفقیت به روز شد",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Commencez à saisir le nom du fournisseur...",
|
||||
"stock" => "Inventaire",
|
||||
"stock_destination" => "Destination de stock",
|
||||
"stock_location" => "Emplacement du stock",
|
||||
"stock_locaiton" => "Emplacement du stock",
|
||||
"stock_source" => "Source de stock",
|
||||
"successfully_deleted" => "Suppression réussie",
|
||||
"successfully_updated" => "Réception correctement mise à jour",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "התחל להקליד את שם הספק ...",
|
||||
"stock" => "מלאי",
|
||||
"stock_destination" => "יעד מלאי",
|
||||
"stock_location" => "מיקום מלאי",
|
||||
"stock_locaiton" => "מיקום מלאי",
|
||||
"stock_source" => "מקור מלאי",
|
||||
"successfully_deleted" => "נמחק בהצלחה",
|
||||
"successfully_updated" => "החזרה עודכנה בהצלחה",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Počnite upisivati ime dobavljača ...",
|
||||
"stock" => "",
|
||||
"stock_destination" => "Na skladište",
|
||||
"stock_location" => "Mjesto skladišta",
|
||||
"stock_locaiton" => "Mjesto skladišta",
|
||||
"stock_source" => "Iz skladišta",
|
||||
"successfully_deleted" => "Uspješno ste obrisali primku",
|
||||
"successfully_updated" => "Uspješno ste ažurirali primku",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Kezdje gépelni a beszállitó nevét",
|
||||
"stock" => "",
|
||||
"stock_destination" => "Célraktár",
|
||||
"stock_location" => "Raktár helyszin",
|
||||
"stock_locaiton" => "Raktár helyszin",
|
||||
"stock_source" => "Raktár forrás",
|
||||
"successfully_deleted" => "Sikeres törlés",
|
||||
"successfully_updated" => "Átvétel sikeresen módositva",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "",
|
||||
"stock" => "",
|
||||
"stock_destination" => "",
|
||||
"stock_location" => "",
|
||||
"stock_locaiton" => "",
|
||||
"stock_source" => "",
|
||||
"successfully_deleted" => "",
|
||||
"successfully_updated" => "",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Ketik nama pemasok ...",
|
||||
"stock" => "Stok",
|
||||
"stock_destination" => "Tujuan Stok",
|
||||
"stock_location" => "Lokasi Stok",
|
||||
"stock_locaiton" => "Lokasi Stok",
|
||||
"stock_source" => "Asal Stok",
|
||||
"successfully_deleted" => "Berhasil Dihapus",
|
||||
"successfully_updated" => "Berhasil Diperbaharui",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Incomincia a digitare il nome del Fornitore...",
|
||||
"stock" => "Scorta",
|
||||
"stock_destination" => "Destinazione Stock",
|
||||
"stock_location" => "Luogo di Stock",
|
||||
"stock_locaiton" => "Luogo di Stock",
|
||||
"stock_source" => "Provenienza Stock",
|
||||
"successfully_deleted" => "Eliminata correttamente",
|
||||
"successfully_updated" => "Ricezione correttamente aggiornata",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "",
|
||||
"stock" => "",
|
||||
"stock_destination" => "",
|
||||
"stock_location" => "",
|
||||
"stock_locaiton" => "",
|
||||
"stock_source" => "",
|
||||
"successfully_deleted" => "",
|
||||
"successfully_updated" => "",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Start Typing Supplier's name...",
|
||||
"stock" => "",
|
||||
"stock_destination" => "Stock Destination",
|
||||
"stock_location" => "Stock Location",
|
||||
"stock_locaiton" => "Stock Location",
|
||||
"stock_source" => "Stock Source",
|
||||
"successfully_deleted" => "You have successfully deleted",
|
||||
"successfully_updated" => "Receiving successfully updated",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "",
|
||||
"stock" => "",
|
||||
"stock_destination" => "",
|
||||
"stock_location" => "",
|
||||
"stock_locaiton" => "",
|
||||
"stock_source" => "",
|
||||
"successfully_deleted" => "",
|
||||
"successfully_updated" => "",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "",
|
||||
"stock" => "",
|
||||
"stock_destination" => "",
|
||||
"stock_location" => "",
|
||||
"stock_locaiton" => "",
|
||||
"stock_source" => "",
|
||||
"successfully_deleted" => "",
|
||||
"successfully_updated" => "",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Typ naam leverancier..",
|
||||
"stock" => "Voorraad",
|
||||
"stock_destination" => "Stock bestemming",
|
||||
"stock_location" => "Stock locatie",
|
||||
"stock_locaiton" => "Stock locatie",
|
||||
"stock_source" => "Stock bron",
|
||||
"successfully_deleted" => "Er werd(en)",
|
||||
"successfully_updated" => "Order werd geupdatet",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Leveranciersnaam typen...",
|
||||
"stock" => "Voorraad",
|
||||
"stock_destination" => "Voorraad bestemming",
|
||||
"stock_location" => "Voorraad locatie",
|
||||
"stock_locaiton" => "Voorraad locatie",
|
||||
"stock_source" => "Voorraad herkomst",
|
||||
"successfully_deleted" => "Succesvol verwijderd",
|
||||
"successfully_updated" => "Levering succesvol bijgewerkt",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "",
|
||||
"stock" => "",
|
||||
"stock_destination" => "",
|
||||
"stock_location" => "",
|
||||
"stock_locaiton" => "",
|
||||
"stock_source" => "",
|
||||
"successfully_deleted" => "",
|
||||
"successfully_updated" => "",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Digite o nome do fornecedor...",
|
||||
"stock" => "Estoque",
|
||||
"stock_destination" => "Destinação do estoque",
|
||||
"stock_location" => "Localização do estoque",
|
||||
"stock_locaiton" => "Localização do estoque",
|
||||
"stock_source" => "Fonte do estoque",
|
||||
"successfully_deleted" => "Você excluiu com sucesso",
|
||||
"successfully_updated" => "Recebimento atualizado com sucesso",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "",
|
||||
"stock" => "",
|
||||
"stock_destination" => "",
|
||||
"stock_location" => "",
|
||||
"stock_locaiton" => "",
|
||||
"stock_source" => "",
|
||||
"successfully_deleted" => "",
|
||||
"successfully_updated" => "",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Начните вводить название поставщика...",
|
||||
"stock" => "Запасы",
|
||||
"stock_destination" => "Назначение запасов",
|
||||
"stock_location" => "Расположение запасов",
|
||||
"stock_locaiton" => "Расположение запасов",
|
||||
"stock_source" => "Источник запасов",
|
||||
"successfully_deleted" => "Успешно удалено",
|
||||
"successfully_updated" => "Закупка успешно обновлена",
|
||||
|
||||
@@ -43,7 +43,7 @@ return [
|
||||
"start_typing_supplier_name" => "Börja skriva leverantörens namn ...",
|
||||
"stock" => "Lager",
|
||||
"stock_destination" => "Lagerplats",
|
||||
"stock_location" => "Lagerplats",
|
||||
"stock_locaiton" => "Lagerplats",
|
||||
"stock_source" => "Lagerplats",
|
||||
"successfully_deleted" => "Du har tagit bort",
|
||||
"successfully_updated" => "Mottagning uppdaterad",
|
||||
|
||||
@@ -1,33 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"attribute_value_invalid_chars" => "Thamani ya sifa haiwezi kuwa na '_' au '|'",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta sifa iliyochaguliwa/zilizochaguliwa?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha sifa iliyochaguliwa/zilizochaguliwa?",
|
||||
"definition_cannot_be_deleted" => "Haiwezekani kufuta sifa iliyochaguliwa/zilizochaguliwa",
|
||||
"definition_error_adding_updating" => "Sifa {0} haiwezekani kuongezwa au kusasishwa. Tafadhali angalia logi ya makosa.",
|
||||
"definition_flags" => "Uonekano wa Sifa",
|
||||
"definition_group" => "Kundi",
|
||||
"definition_id" => "Id",
|
||||
"definition_name" => "Ongeza Sifa",
|
||||
"definition_name_required" => "Jina la sifa ni kiashiria kinachohitajika",
|
||||
"definition_one_or_multiple" => "Sifa",
|
||||
"definition_successful_adding" => "Umefanikiwa kuongeza kipengee(Item)",
|
||||
"definition_successful_deleted" => "Umefanikiwa kufuta",
|
||||
"definition_successful_updating" => "Umefanikiwa kusasisha sifa",
|
||||
"definition_type" => "Aina ya Sifa",
|
||||
"definition_type_required" => "Aina ya sifa ni kiashiria kinachohitajika",
|
||||
"definition_unit" => "Kipimo",
|
||||
"definition_values" => "Thamani za Sifa",
|
||||
"new" => "Sifa Mpya",
|
||||
"no_attributes_to_display" => "Hakuna Sifa za kuonyesha",
|
||||
"receipt_visibility" => "Risiti",
|
||||
"show_in_items" => "Onyesha kwenye bidhaa",
|
||||
"show_in_items_visibility" => "Bidhaa",
|
||||
"show_in_receipt" => "Onyesha kwenye risiti",
|
||||
"show_in_receivings" => "Onyesha kwenye Manunuzi",
|
||||
"show_in_receivings_visibility" => "Manunuzi",
|
||||
"show_in_sales" => "Onyesha kwenye Mauzo",
|
||||
"show_in_sales_visibility" => "Mauzo",
|
||||
"update" => "Sasisha Sifa",
|
||||
];
|
||||
@@ -1,12 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"all" => "Zote",
|
||||
"columns" => "Safu wima",
|
||||
"hide_show_pagination" => "Ficha/Onyesha upangaji kurasa",
|
||||
"loading" => "Inapakia, tafadhali subiri...",
|
||||
"page_from_to" => "Inaonyesha {0} hadi {1} kati ya Mistari {2}",
|
||||
"refresh" => "Sasisha",
|
||||
"rows_per_page" => "Mistari {0} kwa kila ukurasa",
|
||||
"toggle" => "Badilisha",
|
||||
];
|
||||
@@ -1,49 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"su" => "J2",
|
||||
"mo" => "J3",
|
||||
"tu" => "J4",
|
||||
"we" => "J5",
|
||||
"th" => "Al",
|
||||
"fr" => "Ij",
|
||||
"sa" => "Jm",
|
||||
"sun" => "Jm2",
|
||||
"mon" => "Jm3",
|
||||
"tue" => "Jm4",
|
||||
"wed" => "Jm5",
|
||||
"thu" => "Alh",
|
||||
"fri" => "Iju",
|
||||
"sat" => "Jmo",
|
||||
"sunday" => "Jumapili",
|
||||
"monday" => "Jumatatu",
|
||||
"tuesday" => "Jumanne",
|
||||
"wednesday" => "Jumatano",
|
||||
"thursday" => "Alhamisi",
|
||||
"friday" => "Ijumaa",
|
||||
"saturday" => "Jumamosi",
|
||||
"jan" => "Jan",
|
||||
"feb" => "Feb",
|
||||
"mar" => "Mac",
|
||||
"apr" => "Apr",
|
||||
"may" => "Mei",
|
||||
"jun" => "Jun",
|
||||
"jul" => "Jul",
|
||||
"aug" => "Ago",
|
||||
"sep" => "Sep",
|
||||
"oct" => "Okt",
|
||||
"nov" => "Nov",
|
||||
"dec" => "Des",
|
||||
"january" => "Januari",
|
||||
"february" => "Februari",
|
||||
"march" => "Machi",
|
||||
"april" => "Aprili",
|
||||
"mayl" => "Mei",
|
||||
"june" => "Juni",
|
||||
"july" => "Julai",
|
||||
"august" => "Agosti",
|
||||
"september" => "Septemba",
|
||||
"october" => "Oktoba",
|
||||
"november" => "Novemba",
|
||||
"december" => "Disemba",
|
||||
];
|
||||
@@ -1,50 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"amount" => "Kiasi",
|
||||
"amount_number" => "Kiasi lazima kiwe namba",
|
||||
"amount_required" => "Kiasi ni shamba linalohitajika.",
|
||||
"cancel_cashups" => "",
|
||||
"cancel_cashups_enter" => "",
|
||||
"cannot_be_deleted" => "Haiwezekani kufuta Cashup",
|
||||
"cash_difference" => "",
|
||||
"close_date" => "Tarehe ya Kufunga",
|
||||
"close_employee" => "Amefunga",
|
||||
"closed_amount_card" => "Kadi",
|
||||
"closed_amount_cash" => "Fedha Iliyofungwa",
|
||||
"closed_amount_check" => "Hundi",
|
||||
"closed_amount_due" => "Madeni",
|
||||
"closed_amount_giftcard" => "",
|
||||
"closed_amount_total" => "Jumla",
|
||||
"closed_date" => "Tarehe ya Kufungwa",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta Fedha Taslimu uliyochagua?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha Fedha Taslimu uliyochagua?",
|
||||
"confirm_submit" => "",
|
||||
"date_number" => "Tarehe lazima iwe namba",
|
||||
"date_required" => "Tarehe ni shamba linalohitajika",
|
||||
"description" => "Maelezo",
|
||||
"enable_expected" => "",
|
||||
"error_adding_updating" => "Hitilafu katika kuongeza/kusasisha Fedha Taslimu",
|
||||
"giftcard" => "",
|
||||
"id" => "Id",
|
||||
"info" => "Taarifa za Fedha Taslimu",
|
||||
"info_employee" => "",
|
||||
"is_deleted" => "Imefutwa",
|
||||
"new" => "Fedha Taslimu Mpya",
|
||||
"no_cashups_to_display" => "Hakuna Fedha Taslimu za kuonyesha",
|
||||
"none_selected" => "Hujachagua Fedha Taslimu yoyote",
|
||||
"note" => "Maelezo",
|
||||
"one_or_multiple" => "Fedha Taslimu",
|
||||
"open_amount_cash" => "Fedha Iliyofunguliwa",
|
||||
"open_date" => "Tarehe ya Kufungua",
|
||||
"open_employee" => "Imefunguliwa na",
|
||||
"opened_date" => "Tarehe ya Kufunguliwa",
|
||||
"successful_adding" => "Kuongeza Fedha Taslimu kumewezekana",
|
||||
"successful_deleted" => "Kufuta Fedha Taslimu kumewezekana",
|
||||
"successful_updating" => "Kusasisha Fedha Taslimu kumewezekana",
|
||||
"total" => "Jumla",
|
||||
"transfer_amount_cash" => "Fedha Ndani/Nje",
|
||||
"transfer_amount_cash_minus" => "",
|
||||
"update" => "Sasisha Fedha Taslimu",
|
||||
"warning" => "",
|
||||
];
|
||||
@@ -1,89 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"address_1" => "Anwani 1",
|
||||
"address_2" => "Anwani 2",
|
||||
"admin" => "",
|
||||
"city" => "Jiji",
|
||||
"clerk" => "",
|
||||
"close" => "Funga",
|
||||
"color" => "",
|
||||
"comments" => "Maoni",
|
||||
"common" => "Kawaida",
|
||||
"confirm_search" => "Umechagua safu moja au zaidi, hizi hazitachaguliwa tena baada ya utafutaji wako. Una uhakika unataka kuwasilisha utafutaji huu?",
|
||||
"copyrights" => "© 2010 - {0}",
|
||||
"correct_errors" => "Tafadhali rekebisha makosa yaliyotambuliwa kabla ya kuhifadhi",
|
||||
"country" => "Nchi",
|
||||
"dashboard" => "",
|
||||
"date" => "Tarehe",
|
||||
"delete" => "Futa",
|
||||
"det" => "Maelezo",
|
||||
"download_import_template" => "Pakua Kiolezo cha CSV cha Uingizaji",
|
||||
"edit" => "Hariri",
|
||||
"email" => "Barua Pepe",
|
||||
"email_invalid_format" => "Anwani ya barua pepe si katika muundo sahihi.",
|
||||
"export_csv" => "Hamisha CSV",
|
||||
"export_csv_no" => "Hapana",
|
||||
"export_csv_yes" => "Ndiyo",
|
||||
"fields_required_message" => "Sehemu zilizo na rangi nyekundu ni za lazima",
|
||||
"fields_required_message_unique" => "",
|
||||
"first_name" => "Jina la Kwanza",
|
||||
"first_name_required" => "Jina la kwanza ni kiashiria kinachohitajika.",
|
||||
"first_page" => "Kwanza",
|
||||
"gender" => "Jinsia",
|
||||
"gender_female" => "K",
|
||||
"gender_male" => "M",
|
||||
"gender_undefined" => "",
|
||||
"icon" => "Icon",
|
||||
"id" => "ID",
|
||||
"import" => "Ingiza",
|
||||
"import_change_file" => "Badilisha",
|
||||
"import_csv" => "Ingiza CSV",
|
||||
"import_full_path" => "Njia kamili ya faili ya CSV inahitajika",
|
||||
"import_remove_file" => "Ondoa",
|
||||
"import_select_file" => "Chagua faili",
|
||||
"inv" => "Ankara",
|
||||
"last_name" => "Jina la Mwisho",
|
||||
"last_name_required" => "Jina la mwisho ni kiashiria kinachohitajika.",
|
||||
"last_page" => "Mwisho",
|
||||
"learn_about_project" => "kujua taarifa za hivi karibuni kuhusu mradi.",
|
||||
"list_of" => "Orodha ya",
|
||||
"logo" => "Nembo",
|
||||
"logo_mark" => "Alama",
|
||||
"logout" => "",
|
||||
"manager" => "",
|
||||
"migration_needed" => "",
|
||||
"new" => "Mpya",
|
||||
"no" => "Hapana",
|
||||
"no_persons_to_display" => "Hakuna watu wa kuonyesha.",
|
||||
"none_selected_text" => "[Chagua]",
|
||||
"or" => "AU",
|
||||
"people" => "",
|
||||
"phone_number" => "Namba ya Simu",
|
||||
"phone_number_required" => "",
|
||||
"please_visit_my" => "Tafadhali tembelea",
|
||||
"position" => "",
|
||||
"powered_by" => "Imewezeshwa na",
|
||||
"price" => "Bei",
|
||||
"print" => "Chapisha",
|
||||
"remove" => "Ondoa",
|
||||
"required" => "Lazima",
|
||||
"restore" => "Rejesha",
|
||||
"return_policy" => "Sera ya Kurudisha",
|
||||
"search" => "Tafuta",
|
||||
"search_options" => "Chaguo za Utafutaji",
|
||||
"searched_for" => "Umetafuta",
|
||||
"software_short" => "OSPOS",
|
||||
"software_title" => "Open Source Point of Sale",
|
||||
"state" => "Jimbo",
|
||||
"submit" => "Wasilisha",
|
||||
"total_spent" => "Jumla Iliyotumika",
|
||||
"unknown" => "Haijulikani",
|
||||
"view_recent_sales" => "Angalia Mauzo ya Hivi Karibuni",
|
||||
"website" => "opensourcepos.org",
|
||||
"welcome" => "Karibu",
|
||||
"welcome_message" => "Karibu OSPOS, bonyeza moduli hapa chini kuanza.",
|
||||
"yes" => "Ndiyo",
|
||||
"you_are_using_ospos" => "",
|
||||
"zip" => "Namba ya Posta",
|
||||
];
|
||||
@@ -1,331 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"address" => "Anwani ya Kampuni",
|
||||
"address_required" => "Anwani ya kampuni ni kiashiria kinachohitajika.",
|
||||
"all_set" => "Ruhusa zote za faili zimewekwa vizuri!",
|
||||
"allow_duplicate_barcodes" => "Ruhusu Misimbomstari iliyorudiwa",
|
||||
"apostrophe" => "apostrofi",
|
||||
"backup_button" => "Hifadhi Nakala",
|
||||
"backup_database" => "Hifadhi Nakala ya Hifadhidata",
|
||||
"barcode" => "Msimbo wa Mstari",
|
||||
"barcode_company" => "Jina la Kampuni",
|
||||
"barcode_configuration" => "Mpangilio wa Msimbomstari",
|
||||
"barcode_content" => "Yaliyomo kwenye Msimbomstari",
|
||||
"barcode_first_row" => "Safu 1",
|
||||
"barcode_font" => "Aina ya Herufi",
|
||||
"barcode_formats" => "Aina za Uingizaji",
|
||||
"barcode_generate_if_empty" => "Tengeneza ikiwa tupu.",
|
||||
"barcode_height" => "Urefu (px)",
|
||||
"barcode_id" => "Id ya Bidhaa/Jina",
|
||||
"barcode_info" => "Taarifa za Mpangilio wa Msimbomstari",
|
||||
"barcode_layout" => "Mpangilio wa Msimbomstari",
|
||||
"barcode_name" => "Jina",
|
||||
"barcode_number" => "Msimbomstari",
|
||||
"barcode_number_in_row" => "Idadi kwenye safu",
|
||||
"barcode_page_cellspacing" => "Onyesha nafasi kati ya seli za ukurasa.",
|
||||
"barcode_page_width" => "Onyesha upana wa ukurasa",
|
||||
"barcode_price" => "Bei",
|
||||
"barcode_second_row" => "Safu 2",
|
||||
"barcode_third_row" => "Safu 3",
|
||||
"barcode_tooltip" => "Tahadhari: Kipengele hiki kinaweza kusababisha kurudiwa kwa bidhaa zilizoingizwa au kuundwa. Usitumie ikiwa hutaki Msimbomstari(Barcode) zilizorudiwa.",
|
||||
"barcode_type" => "Aina ya Msimbomstari",
|
||||
"barcode_width" => "Upana (px)",
|
||||
"bottom" => "Chini",
|
||||
"cash_button" => "",
|
||||
"cash_button_1" => "",
|
||||
"cash_button_2" => "",
|
||||
"cash_button_3" => "",
|
||||
"cash_button_4" => "",
|
||||
"cash_button_5" => "",
|
||||
"cash_button_6" => "",
|
||||
"cash_decimals" => "Desimali za Fedha Taslimu",
|
||||
"cash_decimals_tooltip" => "Ikiwa Desimali za Fedha Taslimu na Desimali za Sarafu ni sawa basi hakuna mzunguko wa fedha taslimu utakaofanyika, isipokuwa Mzunguko wa Fedha Taslimu umewekwa kwenye Nusu Tano.",
|
||||
"cash_rounding" => "Mzunguko wa Fedha Taslimu",
|
||||
"category_dropdown" => "Onyesha Kategoria kama orodha ya kushuka",
|
||||
"center" => "Katikati",
|
||||
"change_apperance_tooltip" => "",
|
||||
"comma" => "koma",
|
||||
"company" => "Jina la Kampuni",
|
||||
"company_avatar" => "",
|
||||
"company_change_image" => "Badilisha Picha",
|
||||
"company_logo" => "Nembo ya Kampuni",
|
||||
"company_remove_image" => "Ondoa Picha",
|
||||
"company_required" => "Jina la kampuni ni kiashiria kinachohitajika",
|
||||
"company_select_image" => "Chagua Picha",
|
||||
"company_website_url" => "Tovuti ya kampuni si URL halali (http://...).",
|
||||
"country_codes" => "Msimbo wa Nchi",
|
||||
"country_codes_tooltip" => "Orodha ya misimbo ya nchi zilizotenganishwa kwa koma kwa utafutaji wa anwani wa uteuzi.",
|
||||
"currency_code" => "Nambari ya Sarafu",
|
||||
"currency_decimals" => "Desimali za Sarafu",
|
||||
"currency_symbol" => "Alama ya Sarafu",
|
||||
"current_employee_only" => "",
|
||||
"customer_reward" => "Zawadi",
|
||||
"customer_reward_duplicate" => "Zawadi lazima iwe ya kipekee.",
|
||||
"customer_reward_enable" => "Washa Zawadi kwa Wateja",
|
||||
"customer_reward_invalid_chars" => "Zawadi haiwezi kuwa na '_'",
|
||||
"customer_reward_required" => "Zawadi ni kiashiria kinachohitajika",
|
||||
"customer_sales_tax_support" => "",
|
||||
"date_or_time_format" => "Kichujio cha Tarehe na Muda",
|
||||
"datetimeformat" => "Muundo wa Tarehe na Muda",
|
||||
"decimal_point" => "Nukta ya Desimali",
|
||||
"default_barcode_font_size_number" => "Ukubwa wa herufi wa Msimbomstari lazima uwe nambari.",
|
||||
"default_barcode_font_size_required" => "Ukubwa wa herufi wa Msimbomstari ni kiashiria kinachohitajika.",
|
||||
"default_barcode_height_number" => "Urefu wa Msimbomstari lazima uwe nambari.",
|
||||
"default_barcode_height_required" => "Urefu wa Msimbomstari ni kiashiria kinachohitajika.",
|
||||
"default_barcode_num_in_row_number" => "Idadi ya Msimbomstari kwenye safu lazima iwe nambari.",
|
||||
"default_barcode_num_in_row_required" => "Idadi ya Msimbomstari kwenye safu ni kiashiria kinachohitajika.",
|
||||
"default_barcode_page_cellspacing_number" => "Nafasi kati ya chumba cha ukurasa wa Msimbomstari lazima iwe nambari.",
|
||||
"default_barcode_page_cellspacing_required" => "Nafasi kati ya chumba cha ukurasa wa Msimbomstari ni kiashiria kinachohitajika.",
|
||||
"default_barcode_page_width_number" => "Upana wa ukurasa wa Msimbomstari lazima uwe nambari.",
|
||||
"default_barcode_page_width_required" => "Upana wa ukurasa wa Msimbomstari ni kiashiria kinachohitajika.",
|
||||
"default_barcode_width_number" => "Upana wa Msimbomstari lazima uwe nambari.",
|
||||
"default_barcode_width_required" => "Upana wa Msimbomstari ni kiashiria kinachohitajika.",
|
||||
"default_item_columns" => "Safu wima za Bidhaa Zinazoonekana Kwa Chaguo-msingi",
|
||||
"default_origin_tax_code" => "Nambari ya Kodi ya Asili kwa Chaguo-msingi",
|
||||
"default_receivings_discount" => "Punguzo la Manunuzi kwa Chaguo-msingi",
|
||||
"default_receivings_discount_number" => "Punguzo la Manunuzi kwa Chaguo-msingi lazima liwe nambari.",
|
||||
"default_receivings_discount_required" => "Punguzo la Manunuzi kwa Chaguo-msingi ni kiashiria kinachohitajika.",
|
||||
"default_sales_discount" => "Punguzo la Mauzo kwa Chaguo-msingi",
|
||||
"default_sales_discount_number" => "Punguzo la Mauzo kwa Chaguo-msingi lazima liwe nambari.",
|
||||
"default_sales_discount_required" => "Punguzo la Mauzo kwa Chaguo-msingi ni kiashiria kinachohitajika.",
|
||||
"default_tax_category" => "Aina ya Kodi kwa Chaguo-msingi",
|
||||
"default_tax_code" => "Nambari ya Kodi kwa Chaguo-msingi",
|
||||
"default_tax_jurisdiction" => "Eneo la Kodi kwa Chaguo-msingi",
|
||||
"default_tax_name_number" => "Jina la Kodi lazima liwe maandishi.",
|
||||
"default_tax_name_required" => "Jina la Kodi ni kiashiria kinachohitajika.",
|
||||
"default_tax_rate" => "Kiwango cha Kodi kwa Chaguo-msingi %",
|
||||
"default_tax_rate_1" => "Kiwango cha Kodi 1",
|
||||
"default_tax_rate_2" => "Kiwango cha Kodi 2",
|
||||
"default_tax_rate_3" => "",
|
||||
"default_tax_rate_number" => "Kiwango cha Kodi kwa Chaguo-msingi lazima kiwe nambari.",
|
||||
"default_tax_rate_required" => "Kiwango cha Kodi kwa Chaguo-msingi ni kiashiria kinachohitajika.",
|
||||
"derive_sale_quantity" => "Ruhusu Kiasi cha Mauzo Kilichotokana",
|
||||
"derive_sale_quantity_tooltip" => "Ikiwa imechaguliwa basi aina mpya ya bidhaa itatolewa kwa bidhaa zilizoagizwa kwa kiasi kilichoongezwa",
|
||||
"dinner_table" => "Jedwali",
|
||||
"dinner_table_duplicate" => "Jedwali lazima iwe ya kipekee.",
|
||||
"dinner_table_enable" => "Washa Jedwali za Chakula",
|
||||
"dinner_table_invalid_chars" => "Jina la Jedwali haliwezi kuwa na '_'.",
|
||||
"dinner_table_required" => "Jedwali ni kiashiria kinachohitajika.",
|
||||
"dot" => "nukta",
|
||||
"email" => "Barua Pepe",
|
||||
"email_configuration" => "Mpangilio wa Barua Pepe",
|
||||
"email_mailpath" => "Njia ya Sendmail",
|
||||
"email_protocol" => "Itifaki",
|
||||
"email_receipt_check_behaviour" => "Kisanduku cha Risiti ya Barua Pepe",
|
||||
"email_receipt_check_behaviour_always" => "Daima imechaguliwa",
|
||||
"email_receipt_check_behaviour_last" => "Kumbuka chaguo la mwisho",
|
||||
"email_receipt_check_behaviour_never" => "Daima haijachaguliwa",
|
||||
"email_smtp_crypto" => "Usimbaji wa SMTP",
|
||||
"email_smtp_host" => "Seva ya SMTP",
|
||||
"email_smtp_pass" => "Nenosiri la SMTP",
|
||||
"email_smtp_port" => "Lango la SMTP",
|
||||
"email_smtp_timeout" => "Muda wa SMTP kuisha",
|
||||
"email_smtp_user" => "Jina la Mtumiaji la SMTP",
|
||||
"enable_avatar" => "",
|
||||
"enable_avatar_tooltip" => "",
|
||||
"enable_dropdown_tooltip" => "",
|
||||
"enable_new_look" => "",
|
||||
"enable_right_bar" => "",
|
||||
"enable_right_bar_tooltip" => "",
|
||||
"enforce_privacy" => "Lazimisha Faragha",
|
||||
"enforce_privacy_tooltip" => "Linda faragha ya Wateja kwa kulazimisha kuchanganya data endapo data zao zitafutwa",
|
||||
"fax" => "Faksi",
|
||||
"file_perm" => "Kuna matatizo na ruhusa za faili. Tafadhali rekebisha na upakie upya ukurasa huu.",
|
||||
"financial_year" => "Mwanzo wa Mwaka wa Fedha",
|
||||
"financial_year_apr" => "1 Aprili",
|
||||
"financial_year_aug" => "1 Agosti",
|
||||
"financial_year_dec" => "1 Desemba",
|
||||
"financial_year_feb" => "1 Februari",
|
||||
"financial_year_jan" => "1 Januari",
|
||||
"financial_year_jul" => "1 Julai",
|
||||
"financial_year_jun" => "1 Juni",
|
||||
"financial_year_mar" => "1 Machi",
|
||||
"financial_year_may" => "1 Mei",
|
||||
"financial_year_nov" => "1 Novemba",
|
||||
"financial_year_oct" => "1 Oktoba",
|
||||
"financial_year_sep" => "1 Septemba",
|
||||
"floating_labels" => "Lebo Zinazoelea",
|
||||
"gcaptcha_enable" => "Ukurasa wa Ingia reCAPTCHA",
|
||||
"gcaptcha_secret_key" => "Funguo ya Siri ya reCAPTCHA",
|
||||
"gcaptcha_secret_key_required" => "Funguo ya Siri ya reCAPTCHA ni kiashiria kinachohitajika",
|
||||
"gcaptcha_site_key" => "Funguo ya Tovuti ya reCAPTCHA",
|
||||
"gcaptcha_site_key_required" => "Funguo ya Tovuti ya reCAPTCHA ni kiashiria kinachohitajika",
|
||||
"gcaptcha_tooltip" => "Linda ukurasa wa Ingia kwa Google reCAPTCHA, bonyeza ikoni kupata jozi ya funguo za API.",
|
||||
"general" => "Jumla",
|
||||
"general_configuration" => "Mpangilio wa Jumla",
|
||||
"giftcard_number" => "Nambari ya Kadi ya Zawadi",
|
||||
"giftcard_random" => "Tengeneza kwa Nasibu",
|
||||
"giftcard_series" => "Tengeneza kwa Mfululizo",
|
||||
"image_allowed_file_types" => "Aina za faili zinazoruhusiwa",
|
||||
"image_max_height_tooltip" => "Urefu wa juu wa picha zinazopakiwa kwa pikseli (px).",
|
||||
"image_max_size_tooltip" => "Ukubwa wa juu wa faili za picha zinazopakiwa kwa kilobaiti (kb).",
|
||||
"image_max_width_tooltip" => "Upana wa juu wa picha zinazopakiwa kwa pikseli (px).",
|
||||
"image_restrictions" => "Vizuizi vya Upakiaji wa Picha",
|
||||
"include_hsn" => "Jumuisha Msaada wa Nambari za HSN",
|
||||
"info" => "Taarifa",
|
||||
"info_configuration" => "Taarifa za Duka",
|
||||
"input_groups" => "Makundi ya Uingizaji",
|
||||
"integrations" => "Muunganiko",
|
||||
"integrations_configuration" => "Muunganiko wa Watu wengine",
|
||||
"invoice" => "Ankara",
|
||||
"invoice_configuration" => "Mpangilio wa Uchapishaji wa Ankara",
|
||||
"invoice_default_comments" => "Maoni ya Chaguo-msingi ya Ankara",
|
||||
"invoice_email_message" => "Kiolezo cha Barua Pepe ya Ankara",
|
||||
"invoice_enable" => "Washa Utoaji wa Ankara",
|
||||
"invoice_printer" => "Kichapishi cha Ankara",
|
||||
"invoice_type" => "Aina ya Ankara",
|
||||
"is_readable" => "inasomeka, lakini ruhusa zimewekwa vibaya. Tafadhali weka 640 au 660 na upakie upya.",
|
||||
"is_writable" => "inaandikika, lakini ruhusa zimewekwa vibaya. Tafadhali weka 750 na upakie upya.",
|
||||
"item_markup" => "",
|
||||
"jsprintsetup_required" => "Tahadhari: Kipengele hiki kitafanya kazi tu ikiwa una kiendelezi cha FireFox jsPrintSetup kimewekwa. Hifadhi hata hivyo?",
|
||||
"language" => "Lugha",
|
||||
"last_used_invoice_number" => "Nambari ya mwisho ya Ankara iliyotumika",
|
||||
"last_used_quote_number" => "Nambari ya mwisho ya Nukuu iliyotumika",
|
||||
"last_used_work_order_number" => "Nambari ya mwisho ya Agizo la Kazi iliyotumika",
|
||||
"left" => "Kushoto",
|
||||
"license" => "Leseni",
|
||||
"license_configuration" => "Taarifa ya Leseni",
|
||||
"line_sequence" => "Mpangilio wa Mistari",
|
||||
"lines_per_page" => "Mistari kwa Kila Ukurasa",
|
||||
"lines_per_page_number" => "Mistari kwa Kila Ukurasa lazima iwe nambari.",
|
||||
"lines_per_page_required" => "Mistari kwa Kila Ukurasa ni kiashiria kinachohitajika.",
|
||||
"locale" => "Ujanibishaji",
|
||||
"locale_configuration" => "Mpangilio wa Ujanibishaji",
|
||||
"locale_info" => "Taarifa za Mpangilio wa Ujanibishaji",
|
||||
"location" => "Stoo",
|
||||
"location_configuration" => "Maeneo ya Stoo",
|
||||
"location_info" => "Taarifa za Mpangilio wa Stoo",
|
||||
"login_form" => "Aina ya Fomu ya Ingia",
|
||||
"logout" => "Unataka kufanya hifadhi nakala kabla ya kutoka? Bonyeza [Sawa] kuhifadhi au [Ghairi] kutoka.",
|
||||
"mailchimp" => "MailChimp",
|
||||
"mailchimp_api_key" => "Funguo ya API ya MailChimp",
|
||||
"mailchimp_configuration" => "Mpangilio wa MailChimp",
|
||||
"mailchimp_key_successfully" => "Funguo ya API ni sahihi.",
|
||||
"mailchimp_key_unsuccessfully" => "Funguo ya API si sahihi.",
|
||||
"mailchimp_lists" => "Orodha za MailChimp",
|
||||
"mailchimp_tooltip" => "Bonyeza ikoni kupata Funguo ya API.",
|
||||
"message" => "Ujumbe",
|
||||
"message_configuration" => "Mpangilio wa Ujumbe",
|
||||
"msg_msg" => "Ujumbe wa SMS uliohifadhiwa",
|
||||
"msg_msg_placeholder" => "Ikiwa unataka kutumia kiolezo cha SMS hifadhi ujumbe wako hapa, vinginevyo acha kisanduku wazi.",
|
||||
"msg_pwd" => "Nenosiri la SMS-API",
|
||||
"msg_pwd_required" => "Nenosiri la SMS-API ni kiashiria kinachohitajika",
|
||||
"msg_src" => "ID ya Mtumaji wa SMS-API",
|
||||
"msg_src_required" => "ID ya Mtumaji wa SMS-API ni kiashiria kinachohitajika",
|
||||
"msg_uid" => "Jina la Mtumiaji la SMS-API",
|
||||
"msg_uid_required" => "Jina la Mtumiaji la SMS-API ni kiashiria kinachohitajika",
|
||||
"multi_pack_enabled" => "Vifurushi Vingi kwa Kila Bidhaa",
|
||||
"no_risk" => "Hakuna hatari za usalama/udhaifu.",
|
||||
"none" => "hakuna",
|
||||
"notify_alignment" => "Nafasi ya Taarifa Ibukizi",
|
||||
"number_format" => "Muundo wa Nambari",
|
||||
"number_locale" => "Ujanibishaji",
|
||||
"number_locale_invalid" => "Ujanibishaji uliyoingiza si sahihi. Angalia kiungo kwenye kidokezo kupata Ujanibishaji sahihi.",
|
||||
"number_locale_required" => "Ujanibishaji ya Nambari ni kiashiria kinachohitajika.",
|
||||
"number_locale_tooltip" => "Tafuta Ujanibishaji inayofaa kupitia kiungo hiki.",
|
||||
"os_timezone" => "Saa ya OSPOS:",
|
||||
"ospos_info" => "Taarifa za Usakinishaji wa OSPOS",
|
||||
"payment_options_order" => "Mpangilio wa Chaguo za Malipo",
|
||||
"perm_risk" => "Ruhusa zisizo sahihi zinaacha programu hii kwenye hatari.",
|
||||
"phone" => "Namba ya simu ya Kampuni",
|
||||
"phone_required" => "Namba ya simu ya Kampuni ni kiashiria kinachohitajika.",
|
||||
"print_bottom_margin" => "Pembe ya Chini",
|
||||
"print_bottom_margin_number" => "Pembe ya Chini lazima iwe nambari.",
|
||||
"print_bottom_margin_required" => "Pembe ya Chini ni kiashiria kinachohitajika.",
|
||||
"print_delay_autoreturn" => "Muda wa Kurudi Moja kwa Moja kwenye Mauzo",
|
||||
"print_delay_autoreturn_number" => "Muda wa Kurudi Moja kwa Moja kwenye Mauzo ni kiashiria kinachohitajika.",
|
||||
"print_delay_autoreturn_required" => "Muda wa Kurudi Moja kwa Moja kwenye Mauzo lazima uwe nambari.",
|
||||
"print_footer" => "Chapisha Kijachini cha Kivinjari",
|
||||
"print_header" => "Chapisha Kijuu cha Kivinjari",
|
||||
"print_left_margin" => "Pembe ya Kushoto",
|
||||
"print_left_margin_number" => "Pembe ya Kushoto lazima iwe nambari.",
|
||||
"print_left_margin_required" => "Pembe ya Kushoto ni kiashiria kinachohitajika.",
|
||||
"print_receipt_check_behaviour" => "Kisanduku cha Risiti ya Kuchapisha",
|
||||
"print_receipt_check_behaviour_always" => "Daima imechaguliwa",
|
||||
"print_receipt_check_behaviour_last" => "Kumbuka chaguo la mwisho",
|
||||
"print_receipt_check_behaviour_never" => "Daima haijachaguliwa",
|
||||
"print_right_margin" => "Pembe ya Kulia",
|
||||
"print_right_margin_number" => "Pembe ya Kulia lazima iwe nambari.",
|
||||
"print_right_margin_required" => "Pembe ya Kulia ni kiashiria kinachohitajika.",
|
||||
"print_silently" => "Onyesha Dirisha la Kuchapisha",
|
||||
"print_top_margin" => "Pembe ya Juu",
|
||||
"print_top_margin_number" => "Pembe ya Juu lazima iwe nambari.",
|
||||
"print_top_margin_required" => "Pembe ya Juu ni kiashiria kinachohitajika.",
|
||||
"quantity_decimals" => "Desimali za Kiasi",
|
||||
"quick_cash_enable" => "",
|
||||
"quote_default_comments" => "Maoni ya Chaguo-msingi la Nukuu",
|
||||
"receipt" => "Risiti",
|
||||
"receipt_category" => "",
|
||||
"receipt_configuration" => "Mpangilio wa Uchapishaji wa Risiti",
|
||||
"receipt_default" => "Chaguo-msingi",
|
||||
"receipt_font_size" => "Ukubwa wa Herufi",
|
||||
"receipt_font_size_number" => "Ukubwa wa Herufi lazima uwe nambari.",
|
||||
"receipt_font_size_required" => "Ukubwa wa Herufi ni kiashiria kinachohitajika.",
|
||||
"receipt_info" => "Taarifa za Mpangilio wa Risiti",
|
||||
"receipt_printer" => "Kichapishi cha Tiketi",
|
||||
"receipt_short" => "Fupi",
|
||||
"receipt_show_company_name" => "Onyesha Jina la Kampuni",
|
||||
"receipt_show_description" => "Onyesha Maelezo",
|
||||
"receipt_show_serialnumber" => "Onyesha Serial Number",
|
||||
"receipt_show_tax_ind" => "Onyesha Kiashiria cha Kodi",
|
||||
"receipt_show_taxes" => "Onyesha Kodi",
|
||||
"receipt_show_total_discount" => "Onyesha Jumla ya Punguzo",
|
||||
"receipt_template" => "Kiolezo cha Risiti",
|
||||
"receiving_calculate_average_price" => "Hesabu Bei ya wastani (Manunuzi)",
|
||||
"recv_invoice_format" => "Muundo wa Ankara ya Manunuzi",
|
||||
"register_mode_default" => "Hali ya Usajili kwa Chaguo-msingi",
|
||||
"report_an_issue" => "Ripoti tatizo",
|
||||
"return_policy_required" => "Return Policy ni kiashiria kinachohitajika.",
|
||||
"reward" => "Zawadi",
|
||||
"reward_configuration" => "Mpangilio wa Zawadi",
|
||||
"right" => "Kulia",
|
||||
"sales_invoice_format" => "Muundo wa Ankara ya Mauzo",
|
||||
"sales_quote_format" => "Muundo wa Nukuu ya Mauzo",
|
||||
"saved_successfully" => "Mpangilio umehifadhiwa kwa mafanikio.",
|
||||
"saved_unsuccessfully" => "Mpangilio umeshindwa kuhifadhiwa.",
|
||||
"security_issue" => "Onyo la Udhaifu wa Usalama",
|
||||
"server_notice" => "Tafadhali tumia taarifa zilizo hapa chini kuripoti tatizo.",
|
||||
"service_charge" => "",
|
||||
"show_due_enable" => "",
|
||||
"show_office_group" => "Onyesha ikoni ya ofisi",
|
||||
"statistics" => "Tuma Takwimu",
|
||||
"statistics_tooltip" => "Tuma takwimu kwa madhumuni ya maendeleo na uboreshaji wa vipengele.",
|
||||
"stock_location" => "Stoo",
|
||||
"stock_location_duplicate" => "Stoo lazima iwe ya kipekee.",
|
||||
"stock_location_invalid_chars" => "Stoo haiwezi kuwa na '_'.",
|
||||
"stock_location_required" => "Stoo ni kiashiria kinachohitajika.",
|
||||
"suggestions_fifth_column" => "",
|
||||
"suggestions_first_column" => "Safu wima 1",
|
||||
"suggestions_fourth_column" => "",
|
||||
"suggestions_layout" => "Mpangilio wa Mapendekezo ya Utafutaji",
|
||||
"suggestions_second_column" => "Safu wima 2",
|
||||
"suggestions_third_column" => "Safu wima 3",
|
||||
"system_conf" => "Usanidi & Mpangilio",
|
||||
"system_info" => "Taarifa za Mfumo",
|
||||
"table" => "Jedwali",
|
||||
"table_configuration" => "Jedwali la Mpangilio",
|
||||
"takings_printer" => "Kichapishi cha Risiti",
|
||||
"tax" => "Kodi",
|
||||
"tax_category" => "Aina ya Kodi",
|
||||
"tax_category_duplicate" => "Aina ya kodi uliyoingiza tayari ipo.",
|
||||
"tax_category_invalid_chars" => "Aina ya kodi uliyoingiza si sahihi.",
|
||||
"tax_category_required" => "Aina ya kodi ni lazima.",
|
||||
"tax_category_used" => "Aina ya kodi haiwezi kufutwa kwa sababu inatumika.",
|
||||
"tax_configuration" => "Mpangilio wa Kodi",
|
||||
"tax_decimals" => "Desimali za Kodi",
|
||||
"tax_id" => "Nambari ya Kodi",
|
||||
"tax_included" => "Kodi Imejumuishwa",
|
||||
"theme" => "Mandhari",
|
||||
"theme_preview" => "Onyesha Mandhari:",
|
||||
"thousands_separator" => "Kitenganishi cha Maelfu",
|
||||
"timezone" => "Saa za Eneo",
|
||||
"timezone_error" => "Saa za OSPOS ni tofauti na Saa za Eneo lako.",
|
||||
"top" => "Juu",
|
||||
"use_destination_based_tax" => "Tumia Kodi ya Kulingana na Eneo",
|
||||
"user_timezone" => "Saa za Eneo lako:",
|
||||
"website" => "Tovuti",
|
||||
"wholesale_markup" => "",
|
||||
"work_order_enable" => "Msaada wa Agizo la Kazi",
|
||||
"work_order_format" => "Muundo wa Agizo la Kazi",
|
||||
];
|
||||
@@ -1,57 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"account_number" => "Nambari ya Akaunti",
|
||||
"account_number_duplicate" => "Nambari ya Akaunti tayari ipo kwenye kanzidata.",
|
||||
"available_points" => "Pointi Zinazopatikana",
|
||||
"available_points_value" => "",
|
||||
"average" => "Wastani wa matumizi",
|
||||
"avg_discount" => "Wastani wa punguzo",
|
||||
"basic_information" => "Taarifa za Msingi",
|
||||
"cannot_be_deleted" => "Haiwezekani kufuta wateja waliochaguliwa, mmoja au zaidi tayari ana mauzo.",
|
||||
"company_name" => "Kampuni",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta mteja/wateja waliochaguliwa?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha mteja/wateja waliochaguliwa?",
|
||||
"consent" => "Idhini ya Usajili",
|
||||
"consent_required" => "Idhini ya usajili ni shamba linalohitajika.",
|
||||
"csv_import_failed" => "Uingizaji wa CSV umeshindikana",
|
||||
"csv_import_nodata_wrongformat" => "Faili iliyopakiwa haina data au imepangwa vibaya.",
|
||||
"csv_import_partially_failed" => "Uingizaji wa wateja umefanikiwa na baadhi ya makosa:",
|
||||
"csv_import_success" => "Uingizaji wa wateja umefanikiwa.",
|
||||
"customer" => "Mteja",
|
||||
"date" => "Tarehe",
|
||||
"discount" => "Punguzo",
|
||||
"discount_fixed" => "Punguzo la Kudumu",
|
||||
"discount_percent" => "Punguzo la Asilimia",
|
||||
"discount_type" => "Aina ya Punguzo",
|
||||
"email_duplicate" => "Barua pepe tayari ipo kwenye kanzidata.",
|
||||
"employee" => "Mfanyakazi",
|
||||
"error_adding_updating" => "Kuongeza au kusasisha mteja kimeshindikana.",
|
||||
"import_items_csv" => "Ingiza Wateja kutoka CSV",
|
||||
"mailchimp_activity_click" => "Bofya Barua Pepe",
|
||||
"mailchimp_activity_lastopen" => "Barua Pepe ya Mwisho Kufunguliwa",
|
||||
"mailchimp_activity_open" => "Barua Pepe Zilizofunguliwa",
|
||||
"mailchimp_activity_total" => "Barua Pepe Zilizotumwa",
|
||||
"mailchimp_activity_unopen" => "Barua Pepe Zisizofunguliwa",
|
||||
"mailchimp_email_client" => "Mteja wa Barua Pepe",
|
||||
"mailchimp_info" => "MailChimp",
|
||||
"mailchimp_member_rating" => "Tathmini",
|
||||
"mailchimp_status" => "Hadhi",
|
||||
"mailchimp_vip" => "VIP",
|
||||
"max" => "Matumizi ya Juu",
|
||||
"min" => "Matumizi ya Chini",
|
||||
"new" => "Mteja Mpya",
|
||||
"none_selected" => "Hujachagua mteja/wateja wa kufuta.",
|
||||
"one_or_multiple" => "Mteja/wateja",
|
||||
"quantity" => "Kiasi",
|
||||
"stats_info" => "Takwimu",
|
||||
"successful_adding" => "Umefanikiwa kuongeza mteja",
|
||||
"successful_deleted" => "Umefanikiwa kufuta",
|
||||
"successful_updating" => "Umefanikiwa kusasisha mteja",
|
||||
"tax_code" => "Nambari ya Kodi",
|
||||
"tax_id" => "Kitambulisho cha Kodi",
|
||||
"taxable" => "Inatozwa Kodi",
|
||||
"total" => "Jumla ya matumizi",
|
||||
"update" => "Sasisha Mteja",
|
||||
"rewards_package" => "Kifurushi cha Zawadi",
|
||||
];
|
||||
@@ -1,24 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"all_time" => "Wakati Wote",
|
||||
"apply" => "Weka",
|
||||
"cancel" => "Ghairi",
|
||||
"custom" => "Maalum",
|
||||
"from" => "Kutoka",
|
||||
"last_30" => "Siku 30 Zilizopita",
|
||||
"last_7" => "Siku 7 Zilizopita",
|
||||
"last_financial_year" => "Mwaka wa Fedha Uliopita",
|
||||
"last_month" => "Mwezi Uliopita",
|
||||
"last_year" => "Mwaka Uliopita",
|
||||
"same_month_last_year" => "Mwezi huu Mwaka Uliopita",
|
||||
"same_month_to_same_day_last_year" => "Mwezi huu hadi Siku hii Mwaka Uliopita",
|
||||
"this_financial_year" => "Mwaka wa Fedha wa Sasa",
|
||||
"this_month" => "Mwezi wa Sasa",
|
||||
"this_year" => "Mwaka wa Sasa",
|
||||
"to" => "Hadi",
|
||||
"today" => "Leo",
|
||||
"today_last_year" => "Leo Mwaka Uliopita",
|
||||
"weekstart" => "0",
|
||||
"yesterday" => "Jana",
|
||||
];
|
||||
@@ -1,45 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"administrator" => "",
|
||||
"basic_information" => "Taarifa za Msingi",
|
||||
"cannot_be_deleted" => "Haiwezekani kufuta M/Wafanyakazi aliyechaguliwa, mmoja au zaidi ameshashughulikia mauzo au unajaribu kufuta akaunti yako.",
|
||||
"change_employee" => "",
|
||||
"change_password" => "Badilisha Nenosiri",
|
||||
"clerk" => "",
|
||||
"commission" => "",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta mfanyakazi aliyechaguliwa?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha Mfanyakazi/Wafanyakazi aliyechaguliwa?",
|
||||
"current_password" => "Nenosiri la Sasa",
|
||||
"current_password_invalid" => "Nenosiri la sasa si sahihi.",
|
||||
"employee" => "Mfanyakazi",
|
||||
"error_adding_updating" => "Kuongeza au kusasisha mfanyakazi kumeshindikana.",
|
||||
"error_deleting_demo_admin" => "Huwezi kufuta mtumiaji wa admin wa majaribio.",
|
||||
"error_updating_demo_admin" => "Huwezi kubadilisha mtumiaji wa admin wa majaribio.",
|
||||
"language" => "Lugha",
|
||||
"login_info" => "Ingia",
|
||||
"manager" => "",
|
||||
"new" => "Mfanyakazi Mpya",
|
||||
"none_selected" => "Hujachagua Mfanyakazi/Wafanyakazi yeyote wa kufuta.",
|
||||
"one_or_multiple" => "Mfanyakazi/Wafanyakazi",
|
||||
"password" => "Nenosiri",
|
||||
"password_minlength" => "Nenosiri lazima liwe na angalau herufi 8.",
|
||||
"password_must_match" => "Manenosiri hayafanani.",
|
||||
"password_not_must_match" => "Nenosiri la sasa na jipya lazima liwe tofauti.",
|
||||
"password_required" => "Nenosiri linahitajika.",
|
||||
"permission_desc" => "Chagua visanduku hapa chini kutoa ruhusa kwa moduli.",
|
||||
"permission_info" => "Ruhusa",
|
||||
"repeat_password" => "Rudia Nenosiri",
|
||||
"subpermission_required" => "Ongeza angalau ruhusa moja kwa kila moduli.",
|
||||
"successful_adding" => "Umefanikiwa kuongeza mfanyakazi.",
|
||||
"successful_change_password" => "Umefanikiwa kubadili nenosiri.",
|
||||
"successful_deleted" => "Umefanikiwa kufuta",
|
||||
"successful_updating" => "Umefanikiwa kusasisha mfanyakazi",
|
||||
"system_language" => "Lugha ya Mfumo",
|
||||
"unsuccessful_change_password" => "Imeshindikana kubadili Nenosiri.",
|
||||
"update" => "Sasisha Mfanyakazi",
|
||||
"username" => "Jina la Mtumiaji",
|
||||
"username_duplicate" => "Jina la mtumiaji tayari linatumika. Tafadhali chagua lingine.",
|
||||
"username_minlength" => "Jina la mtumiaji lazima liwe na angalau herufi 5.",
|
||||
"username_required" => "Jina la mtumiaji ni lazima.",
|
||||
];
|
||||
@@ -1,11 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"half_down" => "Nusu Chini",
|
||||
"half_even" => "Nusu Shufwa",
|
||||
"half_five" => "Nusu Tano",
|
||||
"half_odd" => "Nusu Witiri",
|
||||
"half_up" => "Nusu Juu",
|
||||
"round_down" => "Punguza",
|
||||
"round_up" => "Ongeza",
|
||||
];
|
||||
@@ -1,6 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"no_permission_module" => "Huna ruhusa ya kufikia moduli iliyoitwa",
|
||||
"unknown" => "Hitilafu isiyotarajiwa",
|
||||
];
|
||||
@@ -1,51 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"add_item" => "Ongeza Matumizi",
|
||||
"amount" => "Kiasi",
|
||||
"amount_number" => "Kiasi lazima kiwe Namba",
|
||||
"amount_required" => "Kiasi cha Matumizi kinahitajika",
|
||||
"by_category" => "Kategoria",
|
||||
"cannot_be_deleted" => "Haiwezekani kufuta Kategoria ya Matumizi",
|
||||
"cash" => "Fedha Taslimu",
|
||||
"cash_filter" => "Fedha Taslimu",
|
||||
"categories_name" => "Kategoria",
|
||||
"category_required" => "Kategoria ni kiashiria kinachohitajika",
|
||||
"check" => "Hundi",
|
||||
"check_filter" => "Hundi",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta Matumizi uliyoyachagua?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha Matumizi uliyoyachagua?",
|
||||
"credit" => "Kadi ya Mkopo",
|
||||
"credit_filter" => "Kadi ya Mkopo",
|
||||
"date" => "Tarehe",
|
||||
"date_number" => "Tarehe lazima iwe Namba",
|
||||
"date_required" => "Tarehe ni kiashiria kinachohitajika",
|
||||
"debit" => "Kadi ya Debit",
|
||||
"debit_filter" => "Kadi ya Debit",
|
||||
"description" => "Maelezo",
|
||||
"due" => "Deni",
|
||||
"due_filter" => "Deni",
|
||||
"employee" => "Imeundwa na",
|
||||
"error_adding_updating" => "Hitilafu katika kuongeza/kusasisha Matumizi",
|
||||
"expense_id" => "Id",
|
||||
"expenses_employee" => "Mfanyakazi",
|
||||
"info" => "Taarifa za Matumizi",
|
||||
"ip_address" => "",
|
||||
"is_deleted" => "Imefutwa",
|
||||
"name_required" => "Jina la Matumizi linahitajika",
|
||||
"new" => "Matumizi Mpya",
|
||||
"new_supplier" => "",
|
||||
"no_expenses_to_display" => "Hakuna Matumizi ya kuonyesha",
|
||||
"none_selected" => "Hujachagua Matumizi yoyote",
|
||||
"one_or_multiple" => "Matumizi",
|
||||
"payment" => "Aina ya Malipo",
|
||||
"start_typing_supplier_name" => "Anza kuandika jina la Msambazaji...",
|
||||
"successful_adding" => "Kuongeza Matumizi kumewezekana",
|
||||
"successful_deleted" => "Kufuta Matumizi kumewezekana",
|
||||
"successful_updating" => "Kusasisha Matumizi kumewezekana",
|
||||
"supplier_name" => "Msambazaji",
|
||||
"supplier_tax_code" => "Namba ya Kodi",
|
||||
"tax_amount" => "Kodi",
|
||||
"tax_amount_number" => "",
|
||||
"update" => "Sasisha Matumizi",
|
||||
];
|
||||
@@ -1,23 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"category_name_required" => "Jina la Kategoria ya Matumizi linahitajika",
|
||||
"add_item" => "Ongeza Kategoria",
|
||||
"cannot_be_deleted" => "Haiwezekani kufuta Kategoria ya Matumizi",
|
||||
"category_id" => "Id",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta Kategoria ya Matumizi uliyochagua?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha Kategoria ya Matumizi uliyochagua?",
|
||||
"description" => "Maelezo ya Kategoria",
|
||||
"error_adding_updating" => "Hitilafu katika kuongeza/kusasisha Kategoria ya Matumizi",
|
||||
"info" => "Taarifa za Kategoria ya Matumizi",
|
||||
"name" => "Jina la Kategoria",
|
||||
"new" => "Kategoria Mpya",
|
||||
"no_expenses_categories_to_display" => "Hakuna Kategoria ya kuonyesha",
|
||||
"none_selected" => "Hujachagua Kategoria yoyote ya Matumizi",
|
||||
"one_or_multiple" => "Kategoria ya Matumizi",
|
||||
"quantity" => "Kiasi",
|
||||
"successful_adding" => "Kuongeza Kategoria ya Matumizi kumewezekana",
|
||||
"successful_deleted" => "Kufuta Kategoria ya Matumizi kumewezekana",
|
||||
"successful_updating" => "Kusasisha Kategoria ya Matumizi kumewezekana",
|
||||
"update" => "Sasisha Kategoria",
|
||||
];
|
||||
@@ -1,72 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"add_minus" => "Hisa ya kuongeza au kutoa.",
|
||||
"allow_alt_description" => "Ruhusu Maelezo Mbadala",
|
||||
"bulk_edit" => "Hariri kwa Wingi",
|
||||
"cannot_be_deleted" => "Haiwezekani kufuta Kadi za Zawadi ulizochagua, moja au zaidi tayari ina mauzo.",
|
||||
"cannot_find_giftcard" => "Kadi ya Zawadi haijapatikana.",
|
||||
"cannot_use" => "Kadi ya Zawadi {0} haiwezi kutumika kwa mauzo haya: Mteja si sahihi.",
|
||||
"card_value" => "Thamani",
|
||||
"category" => "Kategoria",
|
||||
"change_all_to_allow_alt_desc" => "Ruhusu maelezo mbadala kwa zote.",
|
||||
"change_all_to_not_allow_allow_desc" => "Usiruhusu maelezo mbadala kwa zote.",
|
||||
"change_all_to_serialized" => "Badilisha zote kuwa katika Mfululizo",
|
||||
"change_all_to_unserialized" => "Badilisha zote zisiwe katika Mfululizo",
|
||||
"confirm_bulk_edit" => "Una uhakika unataka kuhariri Kadi za Zawadi ulizochagua?",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta Kadi za Zawadi ulizochagua?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha Kadi za Zawadi ulizochagua?",
|
||||
"cost_price" => "Bei ya Jumla",
|
||||
"count" => "Sasisha Hisa",
|
||||
"csv_import_failed" => "Uingizaji wa CSV umeshindikana.",
|
||||
"current_quantity" => "Kiasi Kilichopo",
|
||||
"description" => "Maelezo",
|
||||
"details_count" => "Maelezo ya Hesabu ya Hisa",
|
||||
"do_nothing" => "Usifanye chochote",
|
||||
"edit_fields_you_want_to_update" => "Hariri sehemu unazotaka kwa Kadi za Zawadi ulizochagua.",
|
||||
"edit_multiple_giftcards" => "Hariri Kadi za Zawadi Nyingi.",
|
||||
"error_adding_updating" => "Kuongeza au kusasisha Kadi ya Zawadi kimeshindikana.",
|
||||
"error_updating_multiple" => "Kusasisha Kadi za Zawadi kumesindikana.",
|
||||
"generate_barcodes" => "Tengeneza Misimbomstari",
|
||||
"giftcard" => "Kadi ya Zawadi",
|
||||
"giftcard_number" => "Nambari ya Kadi ya Zawadi",
|
||||
"info_provided_by" => "Taarifa imetolewa na",
|
||||
"inventory_comments" => "Maoni",
|
||||
"is_serialized" => "Kadi ya Zawadi ina Nambari ya Seriali",
|
||||
"low_inventory_giftcards" => "Kadi za Zawadi zilizobakia kidogo",
|
||||
"manually_editing_of_quantity" => "Hariri Kiasi kwa Mkono",
|
||||
"must_select_giftcard_for_barcode" => "Lazima uchague angalau Kadi moja ya Zawadi kutengeneza misimbomstari.",
|
||||
"new" => "Kadi Mpya ya Zawadi",
|
||||
"no_description_giftcards" => "Kadi za Zawadi bila Maelezo",
|
||||
"no_giftcards_to_display" => "Hakuna Kadi za Zawadi za kuonyesha.",
|
||||
"none" => "Hakuna",
|
||||
"none_selected" => "Hakuna Kadi za Zawadi zilizochaguliwa kuhariri.",
|
||||
"number" => "Nambari ya Kadi ya Zawadi lazima iwe nambari.",
|
||||
"number_information" => "Nambari ya Kadi ya Zawadi",
|
||||
"number_required" => "Nambari ya Kadi ya Zawadi ni kiashiria kinachohitajika.",
|
||||
"one_or_multiple" => "Kadi za Zawadi",
|
||||
"person_id" => "Mteja",
|
||||
"quantity" => "Kiasi",
|
||||
"quantity_required" => "Kiasi ni kiashiria kinachohitajika. Tafadhali funga (X) kughairi.",
|
||||
"remaining_balance" => "Thamani iliyobaki ya Kadi ya Zawadi {0} ni {1}!",
|
||||
"reorder_level" => "Kiwango cha Kuagiza Tena",
|
||||
"retrive_giftcard_info" => "Pata Taarifa ya Kadi ya Zawadi",
|
||||
"sales_tax_1" => "Kodi ya Mauzo",
|
||||
"sales_tax_2" => "Kodi ya Mauzo 2",
|
||||
"serialized_giftcards" => "Kadi za Zawadi katika Mfululizo",
|
||||
"successful_adding" => "Umefanikiwa kuongeza Kadi ya Zawadi",
|
||||
"successful_bulk_edit" => "Umefanikiwa kusasisha Kadi za Zawadi ulizochagua",
|
||||
"successful_deleted" => "Umefanikiwa kufuta",
|
||||
"successful_updating" => "Umefanikiwa kusasisha Kadi ya Zawadi",
|
||||
"supplier" => "Msambazaji",
|
||||
"tax_1" => "Kodi 1",
|
||||
"tax_2" => "Kodi 2",
|
||||
"tax_percent" => "Asilimia ya Kodi",
|
||||
"tax_percents" => "Asilimia za Kodi",
|
||||
"unit_price" => "Thamani ya Rejareja",
|
||||
"upc_database" => "Kanzidata ya Misimbomstari",
|
||||
"update" => "Sasisha Kadi ya Zawadi",
|
||||
"use_inventory_menu" => "Tumia Menyu ya Hisa",
|
||||
"value" => "Thamani ya Kadi ya Zawadi lazima iwe nambari.",
|
||||
"value_required" => "Thamani ya Kadi ya Zawadi ni kiashiria kinachohitajika.",
|
||||
];
|
||||
@@ -1,42 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"add_item" => "Ongeza Bidhaa",
|
||||
"all" => "Zote",
|
||||
"cannot_be_deleted" => "Imeshindikana Kufuta Vifurushi vya Bidhaa.",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta Vifurushi vya Bidhaa ulivyochagua?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha Vifurushi vya Bidhaa ulivyochagua?",
|
||||
"description" => "Maelezo ya Kifurushi cha Bidhaa",
|
||||
"discount" => "Punguzo",
|
||||
"discount_fixed" => "Punguzo la Kudumu",
|
||||
"discount_percent" => "Asilimia ya Punguzo",
|
||||
"discount_type" => "Aina ya Punguzo",
|
||||
"error_adding_updating" => "Imeshindikana Kuongeza au kusasisha Kifurushi cha Bidhaa.",
|
||||
"find_kit_item" => "Bidhaa ya Kifurushi",
|
||||
"info" => "Taarifa za Kifurushi cha Bidhaa",
|
||||
"item" => "Bidhaa",
|
||||
"item_kit_number" => "Msimbo wa Mstari",
|
||||
"item_kit_number_duplicate" => "Nambari ya Kifurushi cha Bidhaa tayari ipo kwenye kanzidata.",
|
||||
"item_number" => "",
|
||||
"item_number_duplicate" => "",
|
||||
"items" => "Bidhaa",
|
||||
"kit" => "ID ya Kifurushi",
|
||||
"kit_and_components" => "Kifurushi na Vipengele",
|
||||
"kit_and_stock" => "Kifurushi na Hisa",
|
||||
"kit_only" => "Kifurushi Pekee",
|
||||
"name" => "Jina la Kifurushi cha Bidhaa",
|
||||
"new" => "Kifurushi Kipya cha Bidhaa",
|
||||
"no_item_kits_to_display" => "Hakuna Vifurushi vya Bidhaa vya kuonyesha.",
|
||||
"none_selected" => "Hujachagua Kifurushi chochote cha Bidhaa.",
|
||||
"one_or_multiple" => "Kifurushi cha Bidhaa",
|
||||
"price_option" => "Chaguo la Bei",
|
||||
"priced_only" => "Bei Pekee",
|
||||
"print_option" => "Chaguo la Kuchapisha",
|
||||
"quantity" => "Kiasi",
|
||||
"sequence" => "Mpangilio",
|
||||
"successful_adding" => "Umefanikiwa kuongeza Kifurushi cha Bidhaa",
|
||||
"successful_deleted" => "Umefanikiwa kufuta",
|
||||
"successful_updating" => "Umefanikiwa kusasisha Kifurushi cha Bidhaa",
|
||||
"unit_price" => "",
|
||||
"update" => "Sasisha Kifurushi cha Bidhaa",
|
||||
];
|
||||
@@ -1,121 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"add_minus" => "Hisa ya kuongeza au kutoa.",
|
||||
"allow_alt_description" => "Ruhusu Maelezo Mbadala",
|
||||
"amount_entry" => "Uingizaji wa Kiasi",
|
||||
"bulk_edit" => "Hariri kwa Wingi",
|
||||
"buy_price_required" => "Bei ya Ununuzi ni kiashiria kinachohitajika.",
|
||||
"cannot_be_deleted" => "Haiwezekani kufuta Bidhaa ulizochagua, moja au zaidi tayari ina mauzo.",
|
||||
"cannot_find_item" => "Bidhaa haijapatikana.",
|
||||
"categories" => "",
|
||||
"category" => "Kategoria",
|
||||
"category_new" => "",
|
||||
"category_required" => "Kategoria ni kiashiria kinachohitajika.",
|
||||
"change_all_to_allow_alt_desc" => "Ruhusu Maelezo Mbadala kwa zote.",
|
||||
"change_all_to_not_allow_allow_desc" => "Usiruhusu Maelezo Mbadala kwa zote.",
|
||||
"change_all_to_serialized" => "Badilisha zote kuwa na Serialized",
|
||||
"change_all_to_unserialized" => "Badilisha zote kuwa bila Unserialized",
|
||||
"change_image" => "Badilisha Picha",
|
||||
"confirm_bulk_edit" => "Una uhakika unataka kuhariri Bidhaa ulizochagua?",
|
||||
"confirm_bulk_edit_wipe_taxes" => "Taarifa zote za Kodi ya Bidhaa zitabadilishwa.",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta Bidhaa ulizochagua?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha Bidhaa ulizochagua?",
|
||||
"cost_price" => "Bei ya Jumla",
|
||||
"cost_price_number" => "Bei ya Jumla lazima iwe namba.",
|
||||
"cost_price_required" => "Bei ya Jumla ni kiashiria kinachohitajika.",
|
||||
"count" => "Sasisha Hisa",
|
||||
"csv_import_failed" => "Uingizaji wa CSV umeshindikana",
|
||||
"csv_import_nodata_wrongformat" => "Faili ya CSV iliyopakiwa haina data au imepangwa vibaya.",
|
||||
"csv_import_partially_failed" => "Kumekuwa na makosa {0} ya uingizaji wa bidhaa kwenye mstari: {1}. Hakuna safu zilizoingizwa.",
|
||||
"csv_import_success" => "Uingizaji wa Bidhaa kutoka CSV umefanikiwa.",
|
||||
"current_quantity" => "Kiasi Kilichopo",
|
||||
"default_pack_name" => "Kila",
|
||||
"description" => "Maelezo",
|
||||
"details_count" => "Maelezo ya Hesabu ya Hisa",
|
||||
"do_nothing" => "Usifanye chochote",
|
||||
"edit" => "",
|
||||
"edit_fields_you_want_to_update" => "Hariri sehemu unazotaka kwa Bidhaa ulizochagua.",
|
||||
"edit_multiple_items" => "Hariri Bidhaa Nyingi",
|
||||
"empty_upc_items" => "Bidhaa zisizo na Msimbo wa Mstari",
|
||||
"error_adding_updating" => "Hitilafu katika kuongeza/kusasisha Bidhaa",
|
||||
"error_updating_multiple" => "Hitilafu katika kusasisha Bidhaa",
|
||||
"generate_barcodes" => "Tengeneza Misimbomstari",
|
||||
"hsn_code" => "Harmonized System Nomenclature",
|
||||
"image" => "Picha",
|
||||
"import_items_csv" => "Ingiza Bidhaa kutoka CSV",
|
||||
"info_provided_by" => "Taarifa imetolewa na",
|
||||
"inventory" => "Hisa",
|
||||
"inventory_CSV_import_quantity" => "Kiasi kilichoingizwa kutoka CSV",
|
||||
"inventory_comments" => "Maoni",
|
||||
"inventory_data_tracking" => "Inventory Data Tracking",
|
||||
"inventory_date" => "Tarehe",
|
||||
"inventory_employee" => "Mfanyakazi",
|
||||
"inventory_in_out_quantity" => "Kiasi Ndani/Nje",
|
||||
"inventory_remarks" => "Maelezo",
|
||||
"is_deleted" => "Imefutwa",
|
||||
"is_printed" => "",
|
||||
"is_serialized" => "Bidhaa ina Serial Number",
|
||||
"item" => "Bidhaa",
|
||||
"item_id" => "",
|
||||
"item_number" => "Msimbo wa Mstari",
|
||||
"item_number_duplicate" => "namba ya Bidhaa tayari ipo kwenye Kanzidata.",
|
||||
"kit" => "Kifurushi",
|
||||
"location" => "Mahali",
|
||||
"low_inventory_items" => "Bidhaa Zilizokwisha Stoo",
|
||||
"low_sell_item" => "Bidhaa yenye mauzo kidogo",
|
||||
"manually_editing_of_quantity" => "Hariri Kiasi kwa kuandika",
|
||||
"markup" => "",
|
||||
"name" => "Jina la Bidhaa",
|
||||
"name_required" => "Jina la Bidhaa ni kiashiria kinachohitajika.",
|
||||
"new" => "Bidhaa Mpya",
|
||||
"no_description_items" => "Bidhaa zisizo na Maelezo",
|
||||
"no_items_to_display" => "Hakuna Bidhaa za kuonyesha.",
|
||||
"none" => "Hakuna",
|
||||
"none_selected" => "Hujachagua Bidhaa yoyote kuhariri",
|
||||
"nonstock" => "Isiyo na Akiba",
|
||||
"number_information" => "Namba ya Bidhaa",
|
||||
"number_required" => "Msimbo wa Mstari ni kiashiria kinachohitajika.",
|
||||
"one_or_multiple" => "bidhaa",
|
||||
"pack_name" => "Jina la Pakiti",
|
||||
"qty_per_pack" => "Kiasi kwa kila pakiti",
|
||||
"quantity" => "Kiasi",
|
||||
"quantity_number" => "Kiasi lazima kiwe namba.",
|
||||
"quantity_required" => "Kiasi ni kiashiria kinachohitajika.",
|
||||
"receiving_quantity" => "Kiasi Kinachopokelewa",
|
||||
"remove_image" => "Ondoa Picha",
|
||||
"reorder_level" => "Kiwango cha Kuagiza Tena",
|
||||
"reorder_level_number" => "Kiwango cha Kuagiza Tena lazima kiwe namba.",
|
||||
"reorder_level_required" => "Kiwango cha Kuagiza Tena ni kiashiria kinachohitajika.",
|
||||
"retrive_item_info" => "Pata Taarifa ya Bidhaa",
|
||||
"sales_tax_1" => "Kodi ya Mauzo",
|
||||
"sales_tax_2" => "Kodi ya Mauzo 2",
|
||||
"search_attributes" => "Tafuta Sifa",
|
||||
"select_image" => "Chagua Picha",
|
||||
"serialized_items" => "Bidhaa katika Mfululizo",
|
||||
"standard" => "Kawaida",
|
||||
"stock" => "Hisa",
|
||||
"stock_location" => "Stoo",
|
||||
"stock_type" => "Aina ya Hisa",
|
||||
"successful_adding" => "Umefanikiwa kuongeza Bidhaa",
|
||||
"successful_bulk_edit" => "Umefanikiwa kusasisha Bidhaa ulizochagua",
|
||||
"successful_deleted" => "Umefanikiwa kufuta",
|
||||
"successful_updating" => "Umefanikiwa kusasisha Bidhaa",
|
||||
"supplier" => "Msambazaji",
|
||||
"tax_1" => "Kodi 1",
|
||||
"tax_2" => "Kodi 2",
|
||||
"tax_3" => "",
|
||||
"tax_category" => "Aina ya Kodi",
|
||||
"tax_percent" => "Asilimia ya Kodi",
|
||||
"tax_percent_number" => "Asilimia ya Kodi lazima iwe namba",
|
||||
"tax_percent_required" => "Asilimia ya Kodi ni kiashiria kinachohitajika.",
|
||||
"tax_percents" => "Asilimia za Kodi",
|
||||
"temp" => "isiyodumu",
|
||||
"type" => "Aina ya Bidhaa",
|
||||
"unit_price" => "Bei ya Rejareja",
|
||||
"unit_price_number" => "Bei ya Rejareja lazima iwe namba.",
|
||||
"unit_price_required" => "Bei ya Rejareja ni kiashiria kinachohitajika.",
|
||||
"upc_database" => "Kanzidata ya Misimbomstari",
|
||||
"update" => "Sasisha Bidhaa",
|
||||
"use_inventory_menu" => "Tumia Menyu ya Hisa",
|
||||
];
|
||||
@@ -1,16 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"gcaptcha" => "Mimi si roboti.",
|
||||
"go" => "Nenda",
|
||||
"invalid_gcaptcha" => "Tafadhali thibitisha kuwa wewe si roboti.",
|
||||
"invalid_installation" => "Usakinishaji si sahihi, angalia faili yako ya php.ini.",
|
||||
"invalid_username_and_password" => "Jina la mtumiaji na/au nenosiri si sahihi.",
|
||||
"login" => "Ingia",
|
||||
"logout" => "Toka",
|
||||
"migration_needed" => "Uhamishaji wa kanzidata hadi {0} utaanza baada ya kuingia.",
|
||||
"password" => "Nenosiri",
|
||||
"required_username" => "Jina la mtumiaji ni lazima.",
|
||||
"username" => "Jina la Mtumiaji",
|
||||
"welcome" => "Karibu kwenye {0}!",
|
||||
];
|
||||
@@ -1,16 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"first_name" => "Jina la Kwanza",
|
||||
"last_name" => "Jina la Mwisho",
|
||||
"message" => "Ujumbe",
|
||||
"message_placeholder" => "Ujumbe wako hapa...",
|
||||
"message_required" => "Ujumbe unahitajika",
|
||||
"multiple_phones" => "(Ikiwa kuna wapokeaji wengi, ingiza nambari za simu zilizotenganishwa kwa koma)",
|
||||
"phone" => "Namba ya Simu",
|
||||
"phone_number_required" => "Namba ya simu inahitajika",
|
||||
"phone_placeholder" => "Namba ya Simu hapa...",
|
||||
"sms_send" => "Tuma ujumbe mfupi wa maneno",
|
||||
"successfully_sent" => "Ujumbe umetumwa kwa mafanikio kwa: ",
|
||||
"unsuccessfully_sent" => "Ujumbe umetumwa bila mafanikio kwa: ",
|
||||
];
|
||||
@@ -1,49 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"admin_cashups" => "",
|
||||
"admin_cashups_desc" => "",
|
||||
"attributes" => "Sifa",
|
||||
"attributes_desc" => "Ongeza, Sasisha, Futa, na Tafuta sifa.",
|
||||
"both" => "Vyote",
|
||||
"cashups" => "Fedha Taslimu",
|
||||
"cashups_desc" => "Ongeza, Sasisha, Futa, na Tafuta Fedha Taslimu.",
|
||||
"config" => "Mipangilio",
|
||||
"config_desc" => "Badilisha Mipangilio ya OSPOS.",
|
||||
"customers" => "Wateja",
|
||||
"customers_desc" => "Ongeza, Sasisha, Futa, na Tafuta Wateja.",
|
||||
"employees" => "Wafanyakazi",
|
||||
"employees_desc" => "Ongeza, Sasisha, Futa, na Tafuta Wafanyakazi.",
|
||||
"expenses" => "Matumizi",
|
||||
"expenses_categories" => "Aina za Matumizi",
|
||||
"expenses_categories_desc" => "Ongeza, Sasisha, na Futa Aina za Matumizi.",
|
||||
"expenses_desc" => "Ongeza, Sasisha, Futa, na Tafuta Matumizi.",
|
||||
"giftcards" => "Kadi za Zawadi",
|
||||
"giftcards_desc" => "Ongeza, Sasisha, Futa na Tafuta Kadi za Zawadi.",
|
||||
"home" => "Mwanzo",
|
||||
"home_desc" => "Orodhesha moduli za menyu ya mwanzo.",
|
||||
"item_kits" => "Vifurushi vya Bidhaa",
|
||||
"item_kits_desc" => "Ongeza, Sasisha, Futa na Tafuta Vifurushi vya Bidhaa.",
|
||||
"items" => "Bidhaa",
|
||||
"items_desc" => "Ongeza, Sasisha, Futa, na Tafuta Bidhaa.",
|
||||
"messages" => "Ujumbe",
|
||||
"messages_desc" => "Tuma Ujumbe kwa Wateja, Wasambazaji na Wafanyakazi.",
|
||||
"migrate" => "Hamisha",
|
||||
"migrate_desc" => "Sasisha kanzidata ya OSPOS.",
|
||||
"office" => "Ofisi",
|
||||
"office_desc" => "Orodhesha moduli za menyu ya ofisi.",
|
||||
"receivings" => "Manunuzi",
|
||||
"receivings_desc" => "Shughulikia Maagizo ya Ununuzi.",
|
||||
"reports" => "Ripoti",
|
||||
"reports_desc" => "Angalia na tengeneza Ripoti.",
|
||||
"sales" => "Mauzo",
|
||||
"sales_desc" => "Shughulikia Mauzo na Marejesho.",
|
||||
"suppliers" => "Wasambazaji",
|
||||
"suppliers_desc" => "Ongeza, Sasisha, Futa, na Tafuta Wasambazaji.",
|
||||
"taxes" => "Kodi",
|
||||
"taxes_desc" => "Sanidi Kodi ya Mauzo.",
|
||||
"timeclocks" => "",
|
||||
"timeclocks_categories" => "",
|
||||
"timeclocks_categories_desc" => "",
|
||||
"timeclocks_desc" => "",
|
||||
];
|
||||
@@ -1,59 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"amount_due" => "",
|
||||
"cancel_receiving" => "Ghairi",
|
||||
"cannot_be_deleted" => "Kufuta Manunuzi kimeshindikana.",
|
||||
"comments" => "Maoni",
|
||||
"complete_receiving" => "Kamilisha",
|
||||
"confirm_cancel_receiving" => "Una uhakika unataka kufuta Manunuzi haya? Bidhaa zote zitaondolewa.",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta Manunuzi haya? Hatua hii haiwezi kubatilishwa.",
|
||||
"confirm_finish_receiving" => "Una uhakika unataka kuwasilisha Manunuzi haya? Hatua hii haiwezi kubatilishwa.",
|
||||
"confirm_restore" => "",
|
||||
"cost" => "Gharama",
|
||||
"daily" => "",
|
||||
"date" => "Tarehe ya Kupokea",
|
||||
"date_required" => "Tafadhali ingiza tarehe sahihi.",
|
||||
"date_type" => "Tarehe ni kiashiria kinachohitajika.",
|
||||
"delete_entire_sale" => "Futa Mauzo Yote",
|
||||
"discount" => "Punguzo",
|
||||
"edit" => "Hariri",
|
||||
"edit_sale" => "Hariri Manunuzi",
|
||||
"employee" => "Mfanyakazi",
|
||||
"error_editing_item" => "Kuhariri bidhaa kimeshindikana.",
|
||||
"error_requisition" => "Haiwezekani kuhamisha Hesabu kutoka au kwenda mahali pamoja.",
|
||||
"find_or_scan_item" => "Tafuta au Changanua Bidhaa",
|
||||
"find_or_scan_item_or_receipt" => "Tafuta au Changanua Bidhaa au Risiti",
|
||||
"id" => "ID ya Manunuzi",
|
||||
"item_name" => "Jina la Bidhaa",
|
||||
"mode" => "Hali ya Manunuzi",
|
||||
"new_supplier" => "Msambazaji Mpya",
|
||||
"one_or_multiple" => "Manunuzi",
|
||||
"print_after_sale" => "Chapisha Baada ya Mauzo",
|
||||
"quantity" => "Kiasi",
|
||||
"receipt" => "Risiti ya Manunuzi",
|
||||
"receipt_number" => "Nambari ya Manunuzi",
|
||||
"receiving" => "Pokea",
|
||||
"reference" => "Rejea",
|
||||
"register" => "Bidhaa Zinazopokelewa",
|
||||
"requisition" => "Mahitaji",
|
||||
"return" => "Rudisha",
|
||||
"select_supplier" => "Chagua Msambazaji (Hiari)",
|
||||
"ship_pack" => "Furushi la Usafirishaji",
|
||||
"start_typing_supplier_name" => "Anza kuandika jina la msambazaji...",
|
||||
"stock" => "Hisa",
|
||||
"stock_destination" => "Mahali Hisa Inapoenda",
|
||||
"stock_locaiton" => "Mahali pa Hisa", /*stock_locaiton -> stock_location */
|
||||
"stock_source" => "Chanzo cha Hisa",
|
||||
"successfully_deleted" => "Umefanikiwa kufuta",
|
||||
"successfully_updated" => "Manunuzi yamesasishwa kwa mafanikio",
|
||||
"supplier" => "Msambazaji",
|
||||
"supplier_address" => "Anwani",
|
||||
"supplier_email" => "Barua Pepe",
|
||||
"supplier_location" => "Mahali",
|
||||
"total" => "Jumla",
|
||||
"transaction_failed" => "Muamala wa Manunuzi umeshindikana.",
|
||||
"unable_to_add_item" => "Kuongeza bidhaa kwenye Manunuzi kimeshindikana.",
|
||||
"unsuccessfully_updated" => "Kusasisha Manunuzi kimeshindikana.",
|
||||
"update" => "Sasisha",
|
||||
];
|
||||
@@ -1,150 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"all" => "Zote",
|
||||
"authority" => "Mamlaka",
|
||||
"canceled" => "Imeghairiwa",
|
||||
"categories" => "Karegoria",
|
||||
"categories_summary_report" => "Ripoti ya Muhtasari wa Karegoria",
|
||||
"category" => "Kategoria",
|
||||
"code_canceled" => "CNL",
|
||||
"code_invoice" => "INV",
|
||||
"code_pos" => "POS",
|
||||
"code_quote" => "Q",
|
||||
"code_return" => "RET",
|
||||
"code_type" => "Aina",
|
||||
"code_work_order" => "W/O",
|
||||
"comments" => "Maoni",
|
||||
"commission" => "",
|
||||
"complete" => "Mauzo na Marejesho Yaliyokamilika",
|
||||
"completed_sales" => "Mauzo Yaliyokamilika",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta kipengele kilichochaguliwa?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha kipengele kilichochaguliwa?",
|
||||
"cost" => "Jumla",
|
||||
"cost_price" => "Bei ya Jumla",
|
||||
"count" => "Idadi",
|
||||
"customer" => "Mteja",
|
||||
"customers" => "Wateja",
|
||||
"customers_summary_report" => "Ripoti ya Muhtasari wa Wateja",
|
||||
"date" => "Tarehe",
|
||||
"date_range" => "Wigo wa Tarehe",
|
||||
"description" => "Maelezo",
|
||||
"detailed_receivings_report" => "Ripoti ya Mapokezi ya Kina",
|
||||
"detailed_receivings_report_input" => "",
|
||||
"detailed_reports" => "Ripoti za Kina",
|
||||
"detailed_requisition_report" => "",
|
||||
"detailed_sales_report" => "Ripoti ya Muamala wa Kina",
|
||||
"discount" => "Punguzo",
|
||||
"discount_fixed" => "Punguzo la Kawaida (Kudumu)",
|
||||
"discount_percent" => "Asilimia ya Punguzo",
|
||||
"discount_type" => "Aina ya Punguzo",
|
||||
"discounts" => "Punguzo",
|
||||
"discounts_summary_report" => "Ripoti ya Muhtasari wa Punguzo",
|
||||
"earned" => "Alama Zilizopatikana",
|
||||
"employee" => "Mfanyakazi",
|
||||
"employees" => "Wafanyakazi",
|
||||
"employees_summary_report" => "Ripoti ya Muhtasari wa Wafanyakazi",
|
||||
"expenses" => "Matumizi",
|
||||
"expenses_amount" => "Kiasi",
|
||||
"expenses_categories" => "Makundi ya Matumizi",
|
||||
"expenses_categories_summary_report" => "Ripoti ya Muhtasari wa Makundi ya Matumizi",
|
||||
"expenses_category" => "Kundi la Matumizi",
|
||||
"expenses_payment_amount" => "",
|
||||
"expenses_tax_amount" => "Kodi",
|
||||
"expenses_total_amount" => "Jumla ya Kiasi",
|
||||
"expenses_total_tax_amount" => "Jumla ya Kodi",
|
||||
"graphical_reports" => "Ripoti za Picha",
|
||||
"inventory" => "Hisa",
|
||||
"inventory_low" => "Hisa Chache",
|
||||
"inventory_low_report" => "Ripoti ya Hisa Chache",
|
||||
"inventory_reports" => "Ripoti za Hisa",
|
||||
"inventory_summary" => "Muhtasari wa Hisa",
|
||||
"inventory_summary_report" => "Ripoti ya Muhtasari wa Hisa",
|
||||
"item" => "Bidhaa",
|
||||
"item_count" => "Chuja Idadi ya Bidhaa",
|
||||
"item_name" => "Jina la Bidhaa",
|
||||
"item_number" => "Msimbo wa Bidhaa",
|
||||
"items" => "Bidhaa",
|
||||
"items_purchased" => "Bidhaa Zilizonunuliwa",
|
||||
"items_received" => "Bidhaa Zilizopokelewa",
|
||||
"items_summary_report" => "Ripoti ya Muhtasari wa Bidhaa",
|
||||
"jurisdiction" => "Mamlaka",
|
||||
"low_inventory" => "",
|
||||
"low_inventory_report" => "",
|
||||
"low_sell_quantity" => "Kiasi Kidogo cha Mauzo",
|
||||
"more_than_zero" => "Zaidi ya Sifuri",
|
||||
"name" => "Jina",
|
||||
"no_reports_to_display" => "Hakuna Bidhaa za Kuonyesha.",
|
||||
"payment_type" => "Aina ya Malipo",
|
||||
"payments" => "Malipo",
|
||||
"payments_summary_report" => "Ripoti ya Muhtasari wa Malipo",
|
||||
"profit" => "Faida",
|
||||
"quantity" => "Kiasi",
|
||||
"quantity_purchased" => "Kiasi Kilichonunuliwa",
|
||||
"quotes" => "Makadirio",
|
||||
"received_by" => "Imepokelewa na",
|
||||
"receiving_id" => "ID ya Mapokezi",
|
||||
"receiving_type" => "Aina ya Mapokezi",
|
||||
"receivings" => "Mapokezi",
|
||||
"reorder_level" => "Kiwango cha Kuagiza Tena",
|
||||
"report" => "Ripoti",
|
||||
"report_input" => "Ingizo la Ripoti",
|
||||
"reports" => "Ripoti",
|
||||
"requisition" => "",
|
||||
"requisition_by" => "",
|
||||
"requisition_id" => "",
|
||||
"requisition_item" => "",
|
||||
"requisition_item_quantity" => "",
|
||||
"requisition_related_item" => "",
|
||||
"requisition_related_item_total_quantity" => "",
|
||||
"requisition_related_item_unit_quantity" => "",
|
||||
"requisitions" => "Maombi",
|
||||
"returns" => "Marejesho",
|
||||
"revenue" => "Mapato",
|
||||
"sale_id" => "ID ya Muamala",
|
||||
"sale_type" => "Aina ya Muamala",
|
||||
"sales" => "Miamala",
|
||||
"sales_amount" => "Kiasi cha Miamala",
|
||||
"sales_summary_report" => "Ripoti ya Muhtasari wa Miamala",
|
||||
"sales_taxes" => "Kodi ya Mauzo",
|
||||
"sales_taxes_summary_report" => "Ripoti ya Muhtasari wa Kodi ya Mauzo",
|
||||
"serial_number" => "Namba ya Seriali",
|
||||
"service_charge" => "",
|
||||
"sold_by" => "Imeuzwa na",
|
||||
"sold_items" => "",
|
||||
"sold_to" => "Imeuzwa kwa",
|
||||
"stock_location" => "Mahali pa Hisa",
|
||||
"sub_total_value" => "Jumla Ndogo",
|
||||
"subtotal" => "Jumla Ndogo",
|
||||
"summary_reports" => "Ripoti za Muhtasari",
|
||||
"supplied_by" => "Imesambazwa na",
|
||||
"supplier" => "Msambazaji",
|
||||
"suppliers" => "Wasambazaji",
|
||||
"suppliers_summary_report" => "Ripoti ya Muhtasari wa Wasambazaji",
|
||||
"tax" => "Kodi",
|
||||
"tax_category" => "Kategoria ya Kodi",
|
||||
"tax_name" => "Jina la Kodi",
|
||||
"tax_percent" => "Asilimia ya Kodi",
|
||||
"tax_rate" => "Kiwango cha Kodi",
|
||||
"taxes" => "Kodi",
|
||||
"taxes_summary_report" => "Ripoti ya Muhtasari wa Kodi",
|
||||
"total" => "Jumla",
|
||||
"total_inventory_value" => "Jumla ya Thamani ya Hisa",
|
||||
"total_low_sell_quantity" => "Jumla ya Kiasi Kidogo cha Mauzo",
|
||||
"total_quantity" => "Jumla ya Kiasi",
|
||||
"total_retail" => "Jumla ya Thamani ya Rejareja",
|
||||
"trans_amount" => "Kiasi cha Muamala",
|
||||
"trans_due" => "Deni",
|
||||
"trans_group" => "Kundi la Muamala",
|
||||
"trans_nopay_sales" => "Mauzo Bila Malipo",
|
||||
"trans_payments" => "Malipo",
|
||||
"trans_refunded" => "Imerejeshwa",
|
||||
"trans_sales" => "Mauzo",
|
||||
"trans_type" => "Aina ya Muamala",
|
||||
"type" => "Aina",
|
||||
"unit_price" => "Bei ya Rejareja",
|
||||
"used" => "Alama Zilizotumika",
|
||||
"work_orders" => "Maagizo ya Kazi",
|
||||
"zero_and_less" => "Sifuri na Chini",
|
||||
"toggle_cost_and_profit" => "Badilisha Bei ya Jumla & Faida",
|
||||
];
|
||||
@@ -1,227 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"customers_available_points" => "Pointi Zinazopatikana",
|
||||
"rewards_package" => "Zawadi",
|
||||
"rewards_remaining_balance" => "Thamani ya pointi za zawadi zilizobaki ni ",
|
||||
"account_number" => "Nambari ya Akaunti",
|
||||
"add_payment" => "Ongeza Malipo",
|
||||
"amount_due" => "Kiasi Kinachodaiwa",
|
||||
"amount_tendered" => "Kiasi Kilicholipwa",
|
||||
"authorized_signature" => "Sahihi Iliyothibitishwa",
|
||||
"cancel_sale" => "Ghairi",
|
||||
"cash" => "Fedha Taslimu",
|
||||
"cash_1" => "",
|
||||
"cash_2" => "",
|
||||
"cash_3" => "",
|
||||
"cash_4" => "",
|
||||
"cash_adjustment" => "Marekebisho ya Fedha",
|
||||
"cash_deposit" => "Amana ya Fedha",
|
||||
"cash_filter" => "Fedha Taslimu",
|
||||
"change_due" => "Chenji Inayodaiwa",
|
||||
"change_price" => "Badilisha Bei ya Uuzaji",
|
||||
"check" => "Hundi",
|
||||
"check_balance" => "Salio la Hundi",
|
||||
"check_filter" => "Hundi",
|
||||
"close" => "",
|
||||
"comment" => "Maoni",
|
||||
"comments" => "Maoni",
|
||||
"company_name" => "",
|
||||
"complete" => "",
|
||||
"complete_sale" => "Kamilisha",
|
||||
"confirm_cancel_sale" => "Una uhakika unataka kufuta mauzo haya? Bidhaa zote zitaondolewa.",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta mauzo uliyoyachagua?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha mauzo uliyoyachagua?",
|
||||
"credit" => "Kadi ya Mkopo",
|
||||
"credit_deposit" => "Amana ya Mkopo",
|
||||
"credit_filter" => "Kadi ya Mkopo",
|
||||
"current_table" => "",
|
||||
"customer" => "Mteja",
|
||||
"customer_address" => "Anwani",
|
||||
"customer_discount" => "Punguzo",
|
||||
"customer_email" => "Barua Pepe",
|
||||
"customer_location" => "Mahali",
|
||||
"customer_mailchimp_status" => "Hali ya MailChimp",
|
||||
"customer_optional" => "(Inahitajika kwa Malipo ya Madeni)",
|
||||
"customer_required" => "(Inahitajika)",
|
||||
"customer_total" => "Jumla",
|
||||
"customer_total_spent" => "",
|
||||
"daily_sales" => "",
|
||||
"date" => "Tarehe ya Mauzo",
|
||||
"date_range" => "Wigo wa Tarehe",
|
||||
"date_required" => "Tafadhali ingiza tarehe sahihi.",
|
||||
"date_type" => "Tarehe ni kiashiria kinachohitajika.",
|
||||
"debit" => "Kadi ya Debit",
|
||||
"debit_filter" => "",
|
||||
"delete" => "Ruhusu Kufuta",
|
||||
"delete_confirmation" => "Una uhakika unataka kufuta mauzo haya? Hatua hii haiwezi kubatilishwa.",
|
||||
"delete_entire_sale" => "Futa Mauzo Yote",
|
||||
"delete_successful" => "Mauzo yamefutwa kwa mafanikio.",
|
||||
"delete_unsuccessful" => "Kufuta mauzo kimeshindikana.",
|
||||
"description_abbrv" => "Desc.",
|
||||
"discard" => "Ondoa", //Tupa
|
||||
"discard_quote" => "",
|
||||
"discount" => "Punguzo",
|
||||
"discount_included" => "% Punguzo",
|
||||
"discount_short" => "%",
|
||||
"due" => "Deni",
|
||||
"due_filter" => "",
|
||||
"edit" => "Hariri",
|
||||
"edit_item" => "Hariri Bidhaa",
|
||||
"edit_sale" => "Hariri Mauzo",
|
||||
"email_receipt" => "Tuma Risiti kwa Barua Pepe",
|
||||
"employee" => "Mfanyakazi",
|
||||
"entry" => "Ingizo",
|
||||
"error_editing_item" => "Hitilafu katika kuhariri bidhaa",
|
||||
"find_or_scan_item" => "Tafuta au Changanua Bidhaa",
|
||||
"find_or_scan_item_or_receipt" => "Tafuta au Changanua Bidhaa au Risiti",
|
||||
"giftcard" => "Kadi ya Zawadi",
|
||||
"giftcard_balance" => "Salio la Kadi ya Zawadi",
|
||||
"giftcard_filter" => "",
|
||||
"giftcard_number" => "Namba ya Kadi ya Zawadi",
|
||||
"group_by_category" => "Panga kwa Kategoria",
|
||||
"group_by_type" => "Panga kwa Aina",
|
||||
"hsn" => "HSN",
|
||||
"id" => "Namba ya Mauzo",
|
||||
"include_prices" => "Jumuisha Bei?",
|
||||
"invoice" => "Ankara",
|
||||
"invoice_confirm" => "Ankara hii itatumwa kwa",
|
||||
"invoice_enable" => "Namba ya Ankara",
|
||||
"invoice_filter" => "Ankara",
|
||||
"invoice_no_email" => "Mteja huyu hana anwani halali ya barua pepe.",
|
||||
"invoice_number" => "Namba ya Ankara",
|
||||
"invoice_number_duplicate" => "Namba ya Ankara {0} lazima iwe ya kipekee.",
|
||||
"invoice_sent" => "Ankara imetumwa kwa",
|
||||
"invoice_total" => "Jumla ya Ankara",
|
||||
"invoice_type_custom_invoice" => "Ankara Maalum (custom_invoice.php)",
|
||||
"invoice_type_custom_tax_invoice" => "Ankara ya Kodi Maalum (custom_tax_invoice.php)",
|
||||
"invoice_type_invoice" => "Ankara (invoice.php)",
|
||||
"invoice_type_tax_invoice" => "Ankara ya Kodi (tax_invoice.php)",
|
||||
"invoice_unsent" => "Imeshindikana kutuma ankara kwa",
|
||||
"invoice_update" => "Hesabu upya",
|
||||
"item_insufficient_of_stock" => "Bidhaa haina hisa ya kutosha.",
|
||||
"item_name" => "Jina la Bidhaa",
|
||||
"item_number" => "Namba ya Bidhaa",
|
||||
"item_out_of_stock" => "Bidhaa haina hisa.",
|
||||
"key_browser" => "Vifupisho vya Msaada",
|
||||
"key_cancel" => "Ghairi Nukuu/Ankara/Mauzo ya Sasa",
|
||||
"key_customer_search" => "Tafuta Mteja",
|
||||
"key_finish_quote" => "Kamilisha Nukuu/Ankara bila malipo",
|
||||
"key_finish_sale" => "Ongeza Malipo na Kamilisha Ankara/Mauzo",
|
||||
"key_full" => "Fungua kwa Skrini Nzima",
|
||||
"key_function" => "Function",
|
||||
"key_help" => "Vifupisho",
|
||||
"key_help_modal" => "Fungua Dirisha la Vifupisho",
|
||||
"key_in" => "Kuza",
|
||||
"key_item_search" => "Tafuta Bidhaa",
|
||||
"key_out" => "Punguza",
|
||||
"key_payment" => "Ongeza Malipo",
|
||||
"key_print" => "Chapisha Ukurasa wa Sasa",
|
||||
"key_restore" => "Rejesha Mwonekano wa Awali/Zoom",
|
||||
"key_search" => "Tafuta Jedwali la Ripoti",
|
||||
"key_suspend" => "Sitisha Mauzo ya Sasa",
|
||||
"key_suspended" => "Onyesha Mauzo Yaliyositishwa",
|
||||
"key_system" => "Vifupisho vya Mfumo",
|
||||
"key_tendered" => "Hariri Kiasi Kilicholipwa",
|
||||
"key_title" => "Vifupisho vya Kibodi (Keyboard) vya Mauzo",
|
||||
"mc" => "",
|
||||
"mode" => "Hali ya Usajili",
|
||||
"must_enter_numeric" => "Kiasi Kilicholipwa lazima kiwe Namba.",
|
||||
"must_enter_numeric_giftcard" => "Namba ya Kadi ya Zawadi lazima iwe Namba.",
|
||||
"new_customer" => "Mteja Mpya",
|
||||
"new_item" => "Bidhaa Mpya",
|
||||
"no_description" => "Hakuna maelezo",
|
||||
"no_filter" => "Zote",
|
||||
"no_items_in_cart" => "Hakuna bidhaa kwenye Kikapu cha Ununuzi.",
|
||||
"no_sales_to_display" => "Hakuna mauzo ya kuonyesha.",
|
||||
"none_selected" => "Hujachagua mauzo yoyote ya kufuta.",
|
||||
"nontaxed_ind" => " ",
|
||||
"not_authorized" => "Hatua hii haijaruhusiwa.",
|
||||
"one_or_multiple" => "Mauzo",
|
||||
"payment" => "Aina ya Malipo",
|
||||
"payment_amount" => "Kiasi",
|
||||
"payment_not_cover_total" => "Kiasi cha malipo lazima kiwe sawa au zaidi ya jumla kuu.",
|
||||
"payment_type" => "Aina",
|
||||
"payments" => "",
|
||||
"payments_total" => "Jumla ya Malipo",
|
||||
"price" => "Bei",
|
||||
"print_after_sale" => "Chapisha baada ya Mauzo",
|
||||
"quantity" => "Kiasi",
|
||||
"quantity_less_than_reorder_level" => "Onyo: Kiasi kilichotakiwa kiko chini ya kiwango cha kuagiza tena kwa bidhaa hiyo.",
|
||||
"quantity_less_than_zero" => "Onyo: Kiasi kilichotakiwa hakitoshi. Unaweza kuendelea na mauzo, lakini hakiki hesabu yako.",
|
||||
"quantity_of_items" => "Kiasi cha bidhaa {0}",
|
||||
"quote" => "Nukuu (Quote)",
|
||||
"quote_number" => "Nambari ya Nukuu",
|
||||
"quote_number_duplicate" => "Nambari ya Nukuu lazima iwe ya kipekee.",
|
||||
"quote_sent" => "Nukuu imetumwa kwa",
|
||||
"quote_unsent" => "Imeshindikana kutuma nukuu kwa",
|
||||
"receipt" => "Risiti ya Mauzo",
|
||||
"receipt_no_email" => "Mteja huyu hana anwani halali ya barua pepe.",
|
||||
"receipt_number" => "Namba ya Mauzo",
|
||||
"receipt_sent" => "Risiti imetumwa kwa",
|
||||
"receipt_unsent" => "Imeshindikana kutuma risiti kwa",
|
||||
"refund" => "Aina ya Marejesho",
|
||||
"register" => "Usajili wa Mauzo",
|
||||
"remove_customer" => "Ondoa Mteja",
|
||||
"remove_discount" => "Ondoa Punguzo",
|
||||
"return" => "Rudisha",
|
||||
"rewards" => "Pointi za Zawadi",
|
||||
"rewards_balance" => "Salio la Pointi za Zawadi",
|
||||
"sale" => "Mauzo",
|
||||
"sale_by_invoice" => "Mauzo kwa Ankara",
|
||||
"sale_for_customer" => "Mteja:",
|
||||
"sale_time" => "Muda",
|
||||
"sales_tax" => "Kodi ya Mauzo",
|
||||
"sales_total" => "",
|
||||
"select_customer" => "Chagua Mteja",
|
||||
"selected_customer" => "Mteja Uliyemchagua",
|
||||
"send_invoice" => "Tuma Ankara",
|
||||
"send_quote" => "Tuma Nukuu",
|
||||
"send_receipt" => "Tuma Risiti",
|
||||
"send_work_order" => "Tuma Agizo la Kazi",
|
||||
"serial" => "Nambari ya Seriali",
|
||||
"service_charge" => "",
|
||||
"show_due" => "",
|
||||
"show_invoice" => "Onyesha Ankara",
|
||||
"show_receipt" => "Onyesha Risiti",
|
||||
"start_typing_customer_name" => "Anza kuandika taarifa za mteja...",
|
||||
"start_typing_item_name" => "Anza kuandika jina la bidhaa au changanua msimbo wa mstari (Scan Barcode)...",
|
||||
"stock" => "Hisa",
|
||||
"stock_location" => "Eneo la Hisa",
|
||||
"sub_total" => "Jumla Ndogo",
|
||||
"successfully_deleted" => "Umefanikiwa kufuta",
|
||||
"successfully_restored" => "Umefanikiwa kurejesha",
|
||||
"successfully_suspended_sale" => "Kusitisha mauzo kumewezekana.",
|
||||
"successfully_updated" => "Kusasisha mauzo kumewezekana.",
|
||||
"suspend_sale" => "Sitisha",
|
||||
"suspended_doc_id" => "Nyaraka",
|
||||
"suspended_sale_id" => "ID",
|
||||
"suspended_sales" => "Yaliyositishwa",
|
||||
"table" => "Jedwali",
|
||||
"takings" => "Mauzo ya Kila Siku",
|
||||
"tax" => "Kodi",
|
||||
"tax_id" => "Kitambulisho cha Kodi",
|
||||
"tax_invoice" => "Ankara ya Kodi",
|
||||
"tax_percent" => "Kodi %",
|
||||
"taxed_ind" => "K",
|
||||
"total" => "Jumla",
|
||||
"total_tax_exclusive" => "Kodi haijajumuishwa",
|
||||
"transaction_failed" => "Muamala wa Mauzo umeshindikana.",
|
||||
"unable_to_add_item" => "Imeshindikana kuongeza bidhaa kwenye Mauzo",
|
||||
"unsuccessfully_deleted" => "Imeshindikana kufuta Mauzo.",
|
||||
"unsuccessfully_restored" => "Imeshindikana kurejesha Mauzo.",
|
||||
"unsuccessfully_suspended_sale" => "Imeshindikana kusitisha Mauzo.",
|
||||
"unsuccessfully_updated" => "Kusasisha mauzo kimeshindikana.",
|
||||
"unsuspend" => "Ondoa Kusitishwa",
|
||||
// "unsuspend_and_delete" => "Hatua (Action)",
|
||||
"unsuspend_and_delete" => "Hatua",
|
||||
"update" => "Sasisha",
|
||||
"upi" => "UPI",
|
||||
"visa" => "",
|
||||
"wholesale" => "",
|
||||
"work_order" => "Agizo la Kazi (Work Order)",
|
||||
"work_order_number" => "Nambari ya Agizo la Kazi",
|
||||
"work_order_number_duplicate" => "Nambari ya Agizo la Kazi lazima iwe ya kipekee.",
|
||||
"work_order_sent" => "Agizo la Kazi limetumwa kwa",
|
||||
"work_order_unsent" => "Imeshindikana kutuma Agizo la Kazi kwa",
|
||||
];
|
||||
@@ -1,25 +0,0 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
"account_number" => "Nambari ya Akaunti",
|
||||
"agency_name" => "Jina la Wakala",
|
||||
"cannot_be_deleted" => "Haiwezekani kufuta Wasambazaji waliochaguliwa. Mmoja au zaidi tayari ana mauzo.",
|
||||
"category" => "Kategoria",
|
||||
"company_name" => "Jina la Kampuni",
|
||||
"company_name_required" => "Jina la Kampuni ni kiashiria kinachohitajika.",
|
||||
"confirm_delete" => "Una uhakika unataka kufuta Wasambazaji waliochaguliwa?",
|
||||
"confirm_restore" => "Una uhakika unataka kurejesha Wasambazaji waliochaguliwa?",
|
||||
"cost" => "Wasambazaji wa Wazalishaji (Cost Supplier) ",
|
||||
"error_adding_updating" => "Kusasisha au kuongeza Wasambazaji kimeshindikana.",
|
||||
"goods" => "Wasambazaji wa Bidhaa (Goods Supplier)",
|
||||
"new" => "Msambazaji Mpya",
|
||||
"none_selected" => "Hujachagua Wasambazaji wa kufuta.",
|
||||
"one_or_multiple" => "Wasambazaji",
|
||||
"successful_adding" => "Umefanikiwa kuongeza Msambazaji",
|
||||
"successful_deleted" => "Umefanikiwa kufuta",
|
||||
"successful_updating" => "Umefanikiwa kusasisha Msambazaji",
|
||||
"supplier" => "Msambazaji",
|
||||
"supplier_id" => "Id",
|
||||
"tax_id" => "Kitambulisho cha Kodi",
|
||||
"update" => "Sasisha Msambazaji",
|
||||
];
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user