This commit is contained in:
2020-12-01 17:23:13 -03:00
parent 09e8c226bb
commit 9852a8cbdc
274 changed files with 24706 additions and 0 deletions

View File

@ -0,0 +1,18 @@
<?php
namespace App\Alias\Excel\Style;
use Slam\Excel\Helper\CellStyleInterface;
use Slam\Excel\Pear\Writer\Format;
class Mes implements CellStyleInterface
{
public function decorateValue($value)
{
return $value;
}
public function styleCell(Format $format): void
{
$format->setNumFormat('mmm-YY');
$format->setAlign('center');
}
}

12
app/Alias/Format.php Normal file
View File

@ -0,0 +1,12 @@
<?php
use App\Helper\Format as F;
class Format
{
public static function __callstatic($name, $params)
{
if (method_exists(F, $name)) {
return F::$name($params);
}
}
}
?>

87
app/Alias/Model.php Normal file
View File

@ -0,0 +1,87 @@
<?php
namespace App\Alias;
use Stringy\Stringy;
use App\Contract\Auth;
class Model extends \Model
{
public function getTable()
{
return parent::_get_table_name(static::class);
}
protected function log()
{
if (strpos(get_called_class(), 'Incoviba\\common\\') !== false) {
return;
}
$user = Auth::User()->id;
$orm = $this->orm;
$ref = new \ReflectionObject($orm);
if (!$ref->hasProperty('_dirty_fields')) {
return;
}
$dirty = $ref->getProperty('_dirty_fields');
$dirty->setAccessible(true);
$new_values = $dirty->getValue($orm);
$changes = array_combine(array_keys($new_values), array_fill(0, count($new_values), ['old' => '', 'new' => '']));
if ($this->isNew()) {
$old = (object) array_combine(array_keys($new_values), array_fill(0, count($new_values), ''));
} else {
$old = model(get_called_class())->findOne($this->{$this->getId()});
}
foreach ($new_values as $column => $value) {
$changes[$column] = ['column' => $column, 'old' => $old->$column, 'new' => $value];
}
$action = '[' . get_called_class() . ']';
doLog($user, $action, $changes);
}
public function getId()
{
if (property_exists(get_called_class(), '_id_column')) {
return static::$_id_column;
}
return $this->id;
}
public function save()
{
$ref = new \ReflectionObject($this);
if ($ref->hasProperty('_timestamps')) {
$ref = $ref->getProperty('_timestamps');
$ref->setAccessible(true);
if ($ref->getValue()) {
if ($this->is_new()) {
$this->setExpr('created_at', 'NOW()');
}
$this->setExpr('updated_at', 'NOW()');
}
}
if (!\ORM::getDb()->inTransaction()) {
\ORM::getDb()->beginTransaction();
}
try {
parent::save();
if (\ORM::getDb()->inTransaction()) {
\ORM::getDb()->commit();
}
} catch (\Exception $e) {
if (\ORM::getDb()->inTransaction()) {
\ORM::getDb()->rollBack();
}
throw $e;
}
$this->log();
}
public function __call($method, $args)
{
if (!method_exists($this, $method)) {
$str = '' . Stringy::create($method)->underscored();
if (method_exists($this, $str)) {
return call_user_func_array([$this, $str], $args);
}
throw new \BadMethodCallException($method . ' not found in ' . get_class($this));
}
return call_user_func_array([$this, $str], $args);
}
}
?>

20
app/Alias/NewEstado.php Normal file
View File

@ -0,0 +1,20 @@
<?php
namespace App\Alias;
use Carbon\Carbon;
/**
*
* @author Aldarien
* @property int id
* @property Date fecha
*
*/
class NewEstado extends NewModel
{
public function fecha()
{
return Carbon::parse($this->fecha, config('app.timezone'));
}
}
?>

9
app/Alias/NewModel.php Normal file
View File

@ -0,0 +1,9 @@
<?php
namespace App\Alias;
class NewModel extends Model
{
protected static $_connection_name = 'mysql_copy';
protected static $_timestamps = true;
}
?>

15
app/Alias/NewTipo.php Normal file
View File

@ -0,0 +1,15 @@
<?php
namespace App\Alias;
/**
*
* @author Aldarien
* @property int id
* @property string descripcion
*
*/
class NewTipo extends NewModel
{
protected static $_timestamps = true;
}
?>

8
app/Alias/OldModel.php Normal file
View File

@ -0,0 +1,8 @@
<?php
namespace App\Alias;
class OldModel extends Model
{
protected static $_connection_name = 'mysql';
}
?>

155
app/Alias/PHPExcel.php Normal file
View File

@ -0,0 +1,155 @@
<?php
namespace App\Alias;
use Slam\Excel\Helper as ExcelHelper;
class PHPExcel
{
protected $name;
protected $filename;
protected $columns;
protected $data;
public function __construct($name, $filename)
{
$this->name = $name;
$this->filename = $filename;
}
public function addColumns($fields)
{
$columns = [];
foreach ($fields as $i => $field) {
if (is_object($field)) {
if (isset($field->style)) {
$style = $this->getExcelStyle($field->style);
} else {
$style = $this->getExcelStyle();
}
$column = new ExcelHelper\Column($field->name, $field->name, 10, $style);
} elseif (is_array($field)) {
if (isset($field['style'])) {
$style = $this->getExcelStyle($field['style']);
} else {
$style = $this->getExcelStyle();
}
$column = new ExcelHelper\Column($field['name'], $field['name'], 10, $style);
} else {
$style = $this->getExcelStyle();
$column = new ExcelHelper\Column($field, $field, 10, $style);
}
$columns []= $column;
}
$collection = new ExcelHelper\ColumnCollection($columns);
$this->columns = $collection;
}
protected function getExcelStyle($style = 'text')
{
switch (strtolower($style)) {
case 'date':
return new ExcelHelper\CellStyle\Date();
case 'mes':
return new Excel\Style\Mes();
case 'currency':
case 'amount':
return new ExcelHelper\CellStyle\Amount();
case 'number':
case 'integer':
return new ExcelHelper\CellStyle\Integer();
case 'percent':
case 'percentage':
return new ExcelHelper\CellStyle\Percentage();
case 'text':
case 'string':
default:
return new ExcelHelper\CellStyle\Text();
}
}
public function addData($data)
{
if ($this->data == null) {
$this->data = [];
}
$this->data = array_merge($data);
}
public function addRow($rowData)
{
if ($this->data == null) {
$this->data = [];
}
$this->data []= $rowData;
}
public function addTotals($totals)
{
$columns = (array) $this->columns;
$columns = array_pop($columns);
$ts = [];
foreach ($columns as $column) {
$col = $column->getHeading();
if (isset($totals[$col])) {
$ts[$col] = $this->getTotal($col, $totals[$col]);
continue;
}
$ts[$col] = '';
}
$this->data []= $ts;
}
protected function getTotal($col, $aggr)
{
$col_num = $this->getColNumber($col);
$col = $this->getColName($col_num);
switch(strtolower($aggr)) {
case 'sum':
$num = 109;
break;
case 'count':
$num = 102;
break;
case 'counta':
$num = 103;
break;
default:
$num = 0;
}
if ($num > 0) {
$end = count($this->data) + 2;
$str = "=SUBTOTAL({$num};{$col}3:{$col}{$end})";
return $str;
}
return $aggr;
}
protected function getColNumber($col)
{
$columns = (array) $this->columns;
$columns = array_keys(array_pop($columns));
return array_search($col, $columns);
}
protected function getColName($col_num)
{
$cols = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
$N = strlen($cols);
$name = '';
if ($col_num > $N) {
$name .= $cols[floor($col_num / $N)];
$col_num = $N * ($col_num / $N - floor($col_num / $N));
}
$name .= $cols[$col_num];
return $name;
}
public function informe()
{
header("Content-Type: application/octet-stream; charset=utf-8");
header('Content-Transfer-Encoding: binary');
header('Content-Disposition: attachment; filename="' . $this->filename . '"');
header('Cache-Control: max-age=0');
$pE = new ExcelHelper\TableWorkbook('php://output');
$ws = $pE->addWorksheet($this->name);
$table = new ExcelHelper\Table($ws, 0, 0, $this->name, new \ArrayIterator($this->data));
$table->setColumnCollection($this->columns);
$pE->writeTable($table);
$pE->close();
}
}

27
app/Contract/Auth.php Normal file
View File

@ -0,0 +1,27 @@
<?php
namespace App\Contract;
use App\Definition\Contract;
use App\Service\Auth as AuthService;
class Auth
{
use Contract;
protected static function newInstance()
{
return new AuthService();
}
public static function __callStatic($name, $params)
{
if (!method_exists(Response::class, $name)) {
$instance = self::getInstance();
if (method_exists($instance, $name)) {
return call_user_func_array([$instance, $name], $params);
}
return null;
}
return call_user_func_array([self, $name], $params);
}
}
?>

27
app/Contract/Route.php Normal file
View File

@ -0,0 +1,27 @@
<?php
namespace App\Contract;
use App\Definition\Contract;
use App\Service\Route as RouteService;
class Route
{
use Contract;
protected static function newInstance()
{
return new RouteService();
}
public static function __callStatic($name, $params)
{
if (!method_exists(Response::class, $name)) {
$instance = self::getInstance();
if (method_exists($instance, $name)) {
return call_user_func_array([$instance, $name], $params);
}
return null;
}
return call_user_func_array([self, $name], $params);
}
}
?>

233
app/Controller/Admin.php Normal file
View File

@ -0,0 +1,233 @@
<?php
namespace App\Controller;
use App\Service\DBToModel;
use App\Definition\Controller;
use Incoviba\common\Action;
class Admin
{
use Controller;
protected static function setDefault()
{
self::$default = view('admin.base');
}
public static function models()
{
$data = config('databases');
$databases = array_keys($data);
return view('admin.models', compact('databases'));
}
public static function listModels()
{
$db = post('database');
$modeler = new DBToModel($db);
echo $modeler->list();
}
public static function listNamespaces()
{
$base = [
'Common',
'Inmobiliaria',
'Proyecto',
'Venta'
];
$nss = [
'Incoviba' => [
'old' => $base,
'new' => $base
]
];
echo json_encode(['namespaces' => self::collapseMultiArray($nss)]);
}
protected static function collapseMultiArray($array, $level = '')
{
$output = [];
foreach ($array as $key => $subarray) {
if (is_array($subarray)) {
$output = array_merge($output, self::collapseMultiArray($subarray, $level . '\\' . $key));
} else {
$output []= $level . '\\' . $subarray;
}
}
return $output;
}
public static function createModel()
{
$db = post('database');
$ns = post('namespace');
$table = post('table');
$modeler = new DBToModel($db);
echo $modeler->create($ns, $table);
}
public static function list_roles()
{
$roles = \Model::factory(\Incoviba\common\Role::class)->findMany();
echo view('admin.roles.list', compact('roles'));
}
public static function add_role()
{
echo view('admin.roles.add');
}
public static function do_add_role()
{
$role = \Model::factory(\Incoviba\common\Role::class)->where('description', post('description'))->findOne();
if ($role === false) {
$role = \Model::factory(\Incoviba\common\Role::class)->create(['description' => post('description')]);
$role->save();
}
header('Location: ' . nUrl('admin', 'add_role'));
}
public static function role()
{
$role = \Model::factory(\Incoviba\common\Role::class)->findOne(get('role'));
$actions = model(Action::class)->orderByAsc('description')->findMany();
$permissions = [];
foreach ($actions as $action) {
$permissions []= (object) ['description' => $action->description, 'status' => false, 'inherited' => false];
}
array_walk($permissions, function(&$el, $i, $role) {
if ($role->checkAccess($el->description)) {
$el->status = true;
if ($role->isInherited($el->description)) {
$el->inherited = true;
}
}
}, $role);
echo view('admin.roles.show', compact('role', 'permissions'));
}
public static function add_role_permissions()
{
$role = \Model::factory(\Incoviba\common\Role::class)->findOne(get('role'));
$locations = \Model::factory(\Incoviba\common\Location::class)->findMany();
$actions = model(\Incoviba\common\Action::class)->findMany();
echo view('admin.roles.add_permissions', compact('role', 'locations', 'actions'));
}
public static function do_add_role_permissions()
{
$role = \Model::factory(\Incoviba\common\Role::class)->findOne(get('role'));
$actions = model(\Incoviba\common\Action::class)->findMany();
foreach ($actions as $action) {
$p = \Model::factory(\Incoviba\common\Permission::class)->where('type', 2)->where('ext_id', $role->id)->where('action_id', $action->id)->findOne();
if (array_search($action->id, post('allowed'))) {
if (!$p) {
$data = [
'type' => 2,
'ext_id' => $role->id,
'action_id' => $action->id
];
$p = model(\Incoviba\common\Permission::class)->create($data);
}
$p->status = 1;
} else {
if ($p !== false) {
$p->status = 0;
}
}
if ($p !== false) {
$p->save();
}
}
header('Location: ' . nUrl('admin', 'role', ['role' => $role->id]));
}
public static function list_users()
{
$users = \Model::factory(\Incoviba\common\User::class)->orderByAsc('name')->findMany();
echo view('admin.users.list', compact('users'));
}
public static function add_user()
{
echo view('admin.users.add');
}
public static function do_add_user()
{
$user = \Model::factory(\Incoviba\common\User::class)->where('name', post('name'))->findOne();
if ($user === false) {
$user = \Model::factory(\Incoviba\common\User::class)->create();
$user->name = post('name');
$user->password(post('password'));
$user->save();
}
header('Location: ' . url('', ['p' => 'admin', 'a' => 'add_user']));
}
public static function user()
{
$user = \Model::factory(\Incoviba\common\User::class)->findOne(get('user'));
echo view('admin.users.show', compact('user'));
}
public static function add_user_role()
{
if (get('user') !== false) {
$user = \Model::factory(\Incoviba\common\User::class)->findOne(get('user'));
$roles = \Model::factory(\Incoviba\common\Role::class)->findMany();
return view('admin.users.add_role', compact('user', 'roles'));
} elseif (get('role') !== false) {
$role = \Model::factory(\Incoviba\common\Role::class)->findOne(get('role'));
$users = \Model::factory(\Incoviba\common\User::class)->findMany();
return view('admin.roles.add_users', compact('users', 'role'));
}
}
public static function do_add_user_role()
{
if (get('user') !== false) {
$user = \Model::factory(\Incoviba\common\User::class)->findOne(get('user'));
foreach (post('role') as $r_id) {
$role = \Model::factory(\Incoviba\common\Role::class)->findOne($r_id);
$usrRl = \Model::factory(\Incoviba\common\UserRole::class)->where('user', $user->id)->where('role', $role->id)->findOne();
if ($usrRl === false) {
$usrRl = \Model::factory(\Incoviba\common\UserRole::class)->create(['user' => $user->id, 'role' => $role->id]);
$usrRl->save();
}
}
header('Location: ' . url('', ['p' => 'admin', 'a' => 'user', 'user' => $user->id]));
} elseif (get('role') !== false) {
$role = \Model::factory(\Incoviba\common\Role::class)->findOne(get('role'));
foreach (post('users') as $u_id) {
$user = \Model::factory(\Incoviba\common\User::class)->findOne($u_id);
$usrRl = \Model::factory(\Incoviba\common\UserRole::class)->where('user', $user->id)->where('role', $role->id)->findOne();
if ($usrRl === false) {
$usrRl = \Model::factory(\Incoviba\common\UserRole::class)->create(['user' => $user->id, 'role' => $role->id]);
$usrRl->save();
}
}
header('Location: ' . url('', ['p' => 'admin', 'a' => 'role', 'role' => $role->id]));
}
}
public static function remove_user_role()
{
$q = "DELETE FROM user_roles WHERE user = ? AND role = ?";
$st = \ORM::getDb()->prepare($q);
$st->execute([get('user'), get('role')]);
header('Location: ' . nUrl('admin'));
}
public static function delete_user()
{
$q = "DELETE FROM user_roles WHERE user = ?";
$st = \ORM::getDb()->prepare($q);
$st->execute([get('user')]);
$q = "DELETE FROM logins WHERE user = ?";
$st = \ORM::getDb()->prepare($q);
$st->execute([get('user')]);
$q = "DELETE FROM permissions WHERE type = 1 AND ext_id = ?";
$st = \ORM::getDb()->prepare($q);
$st->execute([get('user')]);
$user = \model(\Incoviba\common\User::class)->findOne(get('user'));
$user->delete();
header('Location: ' . nUrl('admin', 'list_users'));
}
public static function reset_user()
{
$user = model(\Incoviba\common\User::class)->findOne(get('user'));
$user->password('123456');
$user->save();
header('Location: ' . nUrl('admin', 'user', ['user' => $user->id]));
}
}
?>

215
app/Controller/Ajax.php Normal file
View File

@ -0,0 +1,215 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Propietario;
use Incoviba\old\Common\Direccion;
use Incoviba\old\Inmobiliaria\Inmobiliaria;
class Ajax
{
use Controller;
protected static function setDefault()
{
self::$default = '';
}
public static function buscar()
{
$t = get('t');
if ($t == null) {
$t = get('tipo');
if ($t == null) {
return '';
}
}
$method = 'buscar' . str_replace(' ', '', ucwords(str_replace('_', ' ', $t)));
if (is_callable('self', $method)) {
return self::$method();
}
}
protected static function buscarBancos()
{
$bancos = \Model::factory(\Incoviba\old\Common\Banco::class)->whereNotEqual('nombre', '')->order_by_asc('nombre')->findMany();
foreach ($bancos as &$banco) {
$banco = $banco->as_array('nombre')['nombre'];
}
return json_encode($bancos);
}
protected static function buscarBanco()
{
$q = get('q');
if ($q == null) {
$q = get('query');
if ($q == null) {
return '';
}
}
$bancos = \Model::factory(\Incoviba\old\Common\Banco::class)->whereLike('nombre', '%' . $q . '%')->order_by_asc('nombre')->findMany();
foreach ($bancos as &$banco) {
$banco = $banco->as_array('nombre')['nombre'];
}
return json_encode($bancos);
}
public static function comunas()
{
$id = post('region');
$comunas = \Model::factory(\Incoviba\old\Common\Comuna::class)
->select('comuna.*')
->join('provincia', ['provincia.id', '=', 'comuna.provincia'])
->where('provincia.region', $id)
->order_by_asc('comuna.descripcion')
->findMany();
foreach ($comunas as &$comuna) {
$comuna = $comuna->as_array('id', 'descripcion');
}
return json_encode($comunas);
}
public static function propietario()
{
$id = post('rut');
$propietario = \Model::factory(\Incoviba\old\Venta\Propietario::class)->where('rut', $id)->findOne();
if ($propietario) {
$propietario = $propietario->as_array();
return json_encode($propietario);
}
return null;
}
public static function direccion()
{
$id = post('direccion');
$direccion = \Model::factory(\Incoviba\old\Common\Direccion::class)->findOne($id);
$comuna = $direccion->comuna();
$provincia = $comuna->provincia();
$region = $provincia->region();
$direccion = $direccion->as_array();
$direccion['comuna'] = $comuna->as_array();
$direccion['comuna']['provincia'] = $provincia->as_array();
$direccion['comuna']['provincia']['region'] = $region->as_array();
return json_encode($direccion);
}
public static function tipo_unidades()
{
$id = post('proyecto');
$proyecto = \Model::factory(\Incoviba\old\Proyecto\Proyecto::class)->findOne($id);
$tipos = $proyecto->tipoUnidades();
foreach ($tipos as &$tipo) {
$tipo = $tipo->as_array();
}
return json_encode($tipos);
}
public static function unidades()
{
$id_proyecto = post('proyecto');
$id_tipo = post('tipo');
$proyecto = model(\Incoviba\old\Proyecto\Proyecto::class)->findOne($id_proyecto);
$unidades = $proyecto->unidadesDisponibles($id_tipo);
foreach ($unidades as &$unidad) {
$tipologia = $unidad->tipologia();
$unidad = $unidad->as_array();
$unidad['tipologia'] = $tipologia->as_array();
if ($tipologia->tipologia()) {
$unidad['tipologia']['tipologia'] = (array) $tipologia->tipologia();
continue;
}
$unidad['tipologia']['tipologia'] = ['descripcion' => $tipologia->abreviacion];
}
return json_encode($unidades);
}
public static function unidades_precios()
{
$proyecto = model(\Incoviba\old\Proyecto\Proyecto::class)->findOne(post('proyecto'));
$unidades = $proyecto->unidades();
usort($unidades, function($a, $b) {
$t = $a->tipo - $b->tipo;
if ($t == 0) {
return (int) $a->descripcion - (int) $b->descripcion;
}
return $t;
});
$output = [];
foreach ($unidades as $u) {
$info = [
'id' => $u->id,
'abreviacion' => $u->abreviacion,
'descripcion' => $u->descripcion,
'valor' => '--'
];
if ($u->precio()) {
$info['valor'] = format('ufs', $u->precio()->valor, null, true);
}
$output []= $info;
}
return json_encode($output);
}
public static function operadores()
{
$id_proyecto = post('proyecto');
$proyecto = \Model::factory(\Incoviba\old\Proyecto\Proyecto::class)->findOne($id_proyecto);
$operadores = $proyecto->operadores();
foreach ($operadores as &$operador) {
$operador = [
'id' => $operador->id,
'abreviacion' => $operador->abreviacion
];
}
return json_encode($operadores);
}
public static function promociones()
{
$id = post('proyecto');
$proyecto = \Model::factory(\Incoviba\old\Proyecto\Proyecto::class)->findOne($id);
$promociones = $proyecto->promociones();
foreach ($promociones as &$promocion) {
$promocion = $promocion->as_array();
}
return json_encode($promociones);
}
public static function nombres()
{
$nss = model(Propietario::class)->select('nombres')->orderByAsc('nombres')->findMany();
$nombres = [];
foreach ($nss as $n) {
$ns = explode(' ', $n->nombres);
foreach ($ns as $nombre) {
$nombres []= $nombre;
}
}
$nombres = array_values(array_unique($nombres));
return json_encode($nombres);
}
public static function apellidos()
{
$aps = model(Propietario::class)->select('apellido_paterno')->orderByAsc('apellido_paterno')->findMany();
$apellidos = [];
foreach ($aps as $ap) {
$apellidos []= $ap->apellido_paterno;
}
$aps = model(Propietario::class)->select('apellido_materno')->orderByAsc('apellido_materno')->findMany();
foreach ($aps as $ap) {
$apellidos []= $ap->apellido_paterno;
}
$apellidos = array_values(array_unique($apellidos));
sort($apellidos);
return json_encode($apellidos);
}
public static function calles()
{
$results = model(Direccion::class)->select('calle')->orderByAsc('calle')->findMany();
$calles = [];
foreach ($results as $result) {
$calles []= $result->calle;
}
$calles = array_values(array_unique($calles));
return json_encode($calles);
}
public static function inmobiliarias()
{
$q = post('rut');
$inmobiliaria = model(Inmobiliaria::class)->findOne($q);
return json_encode($inmobiliaria->as_array());
}
}
?>

56
app/Controller/Auth.php Normal file
View File

@ -0,0 +1,56 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use App\Contract\Auth as sAuth;
class Auth
{
use Controller;
public static function login()
{
return view('auth.login');
}
public static function do_login()
{
$name = post('name');
$password = post('password');
$bool = sAuth::login($name, $password);
if ($bool) {
header('Location: .');
} else {
header('Location: ' . url('', ['p' => 'auth', 'a' => 'login']));
}
}
public static function logout()
{
sAuth::logout();
header('Location: .');
}
public static function check_pass()
{
if (\password_verify(post('password'), sAuth::User()->password)) {
return 'OK';
}
return 'KO';
}
public static function change_pass()
{
return view('auth.change_pass');
}
public static function do_change_pass()
{
if (\password_verify(post('old'), sAuth::User()->password)) {
if (post('new') == post('new2')) {
$user = sAuth::User();
$user->password(post('new'));
$user->save();
header('Location: .');
die();
}
}
header('Location: ' . url('', ['p' => 'auth', 'a' => 'change_pass']));
}
}
?>

57
app/Controller/Bonos.php Normal file
View File

@ -0,0 +1,57 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Venta;
use Incoviba\old\Venta\BonoPie;
use Incoviba\old\Venta\Pago;
class Bonos
{
use Controller;
public static function add()
{
$id_venta = get('venta');
$venta = model(Venta::class)->findOne($id_venta);
return view('ventas.bonos.add', compact('venta'));
}
public static function do_add()
{
$id_venta = get('venta');
$venta = model(Venta::class)->findOne($id_venta);
if ($venta->bono_pie != 0) {
header('Location: ' . nUrl('ventas', 'show', ['venta' => $venta->id]));
return;
}
$uf = uf($venta->fecha());
$valor = post('valor');
$data = [
'fecha' => $venta->fecha,
'valor' => $valor * $uf->uf->value,
'tipo' => 8,
'uf' => $uf->uf->value
];
$pago = model(Pago::class)->create($data);
$pago->save();
$data = [
'valor' => $valor,
'pago' => $pago->id
];
$bono = model(BonoPie::class)->create($data);
$bono->save();
$venta->bono_pie = $bono->id;
$venta->save();
header('Location: ' . nUrl('ventas', 'show', ['venta' => $venta->id]));
}
public static function edit()
{
$id_venta = get('venta');
$venta = model(Venta::class)->findOne($id_venta);
return view('ventas.bonos.edit', compact('venta'));
}
public static function do_edit()
{
d(post());
}
}

340
app/Controller/Buscar.php Normal file
View File

@ -0,0 +1,340 @@
<?php
namespace App\Controller;
use Incoviba\old\Venta\Venta;
use Incoviba\old\Venta\Unidad;
use Incoviba\old\Venta\Propiedad;
class Buscar
{
protected static $tipos = ['cualquiera', 'departamento', 'estacionamiento', 'bodega', 'propietario', 'precio venta', 'proyecto', 'pago', 'unidad'];
public static function index()
{
$results = self::getResults();
$tipos = self::$tipos;
return view('buscar.buscar', compact('tipos', 'results'));
}
public static function ajax()
{
$results = self::getResults();
return json_encode(['results' => $results]);
}
protected static function getResults()
{
$q = get('q');
if ($q == null) {
$q = get('query');
}
$t = get('t');
if ($t == null) {
$t = get('tipo');
}
$t = urldecode($t);
if ($t == null) {
$t = 'cualquiera';
}
$results = null;
if ($q != null) {
$q = urldecode($q);
$results = self::buscar($q, $t);
}
return $results;
}
public static function buscar($query, $tipo)
{
$method = 'buscar' . str_replace(' ', '', ucwords($tipo));
if (is_callable(['self', $method])) {
$results = self::$method(self::prepareQuery($query));
$results = self::removeDuplicates($results);
$results = self::sort($results);
return $results;
}
return [];
}
protected static function prepareQuery($query)
{
$query = str_replace('&#34;', '"', $query);
$data = explode(' ', $query);
$regex = "~(?=\\S)[^'\"\\s]*(?:'[^']*'[^'\"\\s]*|\"[^\"]*\"[^'\"\\s]*)*~";
preg_match_all($regex, $query, $data);
$data = $data[0];
foreach ($data as &$l) {
$l = str_replace('"', '', str_replace("'", '', $l));
}
if (is_array($data) and count($data) == 1) {
$data = $data[0];
}
return $data;
}
protected static function removeDuplicates($results)
{
$output = [];
foreach ($results as $result) {
if (array_search($result, $output) === false) {
$output []= $result;
}
}
return $output;
}
protected static function sort($results)
{
usort($results, function($a, $b) {
$py = strcmp($a->proyecto()->descripcion, $b->proyecto()->descripcion);
if ($py == 0) {
if (!method_exists($a, 'unidad') and !method_exists($b, 'unidad')) {
return $a->descripcion - $b->descripcion;
}
if (!method_exists($a, 'unidad')) {
return $a->descripcion - $b->unidad()->descripcion;
}
if (!method_exists($b, 'unidad')) {
return $a->unidad()->descripcion - $b->descripcion;
}
$u = $a->unidad()->descripcion - $b->unidad()->descripcion;
if ($u == 0) {
return strcmp($a->propietario()->apellido_paterno, $b->propietario()->apellido_paterno);
}
return $u;
}
return $py;
});
return $results;
}
protected static function buscarCualquiera($query)
{
$results = [];
foreach (self::$tipos as $tipo) {
if ($tipo == 'cualquiera') {
continue;
}
$method = 'buscar' . str_replace(' ', '', ucwords($tipo));
if (is_callable(['self', $method])) {
$results = array_merge($results, self::$method($query));
}
}
return $results;
}
protected static function buscarDepartamento($query)
{
if (is_array($query)) {
$results = [];
foreach ($query as $segment) {
$results = array_merge($results, self::buscarDepartamento($segment));
}
} else {
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('propiedad', ['propiedad.id', '=', 'venta.propiedad'])
->join('unidad', ['unidad.id', '=', 'propiedad.unidad_principal'])
->whereLike('unidad.descripcion', '%' . $query . '%')
->findMany();
}
return $results;
}
protected static function buscarEstacionamiento($query)
{
if (is_array($query)) {
$results = [];
foreach ($query as $segment) {
$results = array_merge($results, self::buscarEstacionamiento($segment));
}
} else {
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('propiedad', ['propiedad.id', '=', 'venta.propiedad'])
->join('unidad', "`propiedad`.`estacionamientos` LIKE `unidad`.`id` OR `propiedad`.`estacionamientos` LIKE CONCAT('%;', `unidad`.`id`) OR `propiedad`.`estacionamientos` LIKE CONCAT(`unidad`.`id`, ';%') OR `propiedad`.`estacionamientos` LIKE CONCAT('%;', `unidad`.`id`, ';%')")
->where('unidad.descripcion', $query)
->findMany();
}
return $results;
}
protected static function buscarBodega($query)
{
if (is_array($query)) {
$results = [];
foreach ($query as $segment) {
$results = array_merge($results, self::buscarBodega($segment));
}
} else {
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('propiedad', ['propiedad.id', '=', 'venta.propiedad'])
->join('unidad', "`propiedad`.`bodegas` LIKE `unidad`.`id` OR `propiedad`.`bodegas` LIKE CONCAT('%;', `unidad`.`id`) OR `propiedad`.`bodegas` LIKE CONCAT(`unidad`.`id`, ';%') OR `propiedad`.`bodegas` LIKE CONCAT('%;', `unidad`.`id`, ';%')")
->where('unidad.descripcion', $query)
->findMany();
}
return $results;
}
protected static function buscarPropietario($query)
{
if (is_array($query)) {
$results = [];
foreach ($query as $segment) {
$results = array_merge($results, self::buscarPropietario($segment));
}
} else {
$results = self::buscarPropietarioNombres($query);
$results = array_merge($results, self::buscarPropietarioApellido($query));
$results = array_merge($results, self::buscarPropietarioNombreCompleto($query));
}
return $results;
}
protected static function buscarPropietarioNombres($query)
{
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('propietario', ['propietario.rut', '=', 'venta.propietario'])
->whereLike('propietario.nombres', '%' . $query . '%')
->findMany();
return $results;
}
protected static function buscarPropietarioApellido($query)
{
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('propietario', ['propietario.rut', '=', 'venta.propietario'])
->whereAnyIs([
['propietario.apellido_paterno' => '%' . $query . '%'],
['propietario.apellido_materno' => '%' . $query . '%']
], 'LIKE')
->findMany();
return $results;
}
protected static function buscarPropietarioNombreCompleto($query)
{
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('propietario', ['propietario.rut', '=', 'venta.propietario'])
->whereRaw("CONCAT_WS(' ', propietario.nombres, propietario.apellido_paterno, propietario.apellido_materno) LIKE '%" . $query . "%'")
->findMany();
return $results;
}
protected static function buscarPrecioVenta($query)
{
if (is_array($query)) {
$results = [];
foreach ($query as $segment) {
$results = array_merge($results, self::buscarPrecioVenta($segment));
}
} else {
$query = str_replace([',', '.'], ['.', ''], $query);
$results = \Model::factory(Venta::class)->where('valor_uf', $query)->findMany();
}
return $results;
}
protected static function buscarProyecto($query)
{
if (is_array($query)) {
$results = [];
foreach ($query as $segment) {
$results = array_merge($results, self::buscarProyecto($segment));
}
} else {
$results = model(Venta::class)
->select('venta.*')
->join('propiedad', ['propiedad.id', '=', 'venta.propiedad'])
->join('unidad', ['unidad.id', '=', 'propiedad.unidad_principal'])
->join('proyecto', ['proyecto.id', '=', 'unidad.proyecto'])
->whereLike('proyecto.descripcion', '%' . $query . '%')
->findMany();
}
return $results;
}
protected static function buscarPago($query)
{
if (is_array($query)) {
$results = [];
foreach ($query as $segment) {
$results = array_merge($results, self::buscarPrecioVenta($segment));
}
} else {
$query = str_replace(',', '.', str_replace('.', '', $query));
$query2 = (float) $query;
if ($query != $query2) {
return [];
}
if (!is_float($query2)) {
return [];
}
$query = $query2;
$results = self::buscarValorCuota($query);
$results = array_merge($results, self::buscarReajuste($query));
$results = array_merge($results, self::buscarEscritura($query));
$results = array_merge($results, self::buscarSubsidio($query));
$results = array_merge($results, self::buscarCredito($query));
}
return $results;
}
protected static function buscarValorCuota($query)
{
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('cuota', ['cuota.pie', '=', 'venta.pie'])
->join('pago', ['pago.id', '=', 'cuota.pago'])
->whereRaw("`pago`.`valor` = " . $query . " OR `pago`.`valor` / `pago`.`uf` = " . $query)
->findMany();
return $results;
}
protected static function buscarReajuste($query)
{
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('pie', ['pie.id', '=', 'venta.pie'])
->join('pago', ['pago.id', '=', 'pie.reajuste'])
->whereRaw("`pago`.`valor` = " . $query . " OR `pago`.`valor` / `pago`.`uf` = " . $query)
->findMany();
return $results;
}
protected static function buscarEscritura($query)
{
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('escritura', ['escritura.id', '=', 'venta.escritura'])
->join('pago', ['pago.id', '=', 'escritura.pago'])
->whereRaw("`pago`.`valor` = " . $query . " OR `pago`.`valor` / `pago`.`uf` = " . $query)
->findMany();
return $results;
}
protected static function buscarSubsidio($query)
{
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('subsidio', ['subsidio.id', '=', 'venta.subsidio'])
->join('pago', ['pago.id', '=', 'subsidio.pago'])
->whereRaw("`pago`.`valor` = " . $query . " OR `pago`.`valor` / `pago`.`uf` = " . $query)
->findMany();
return $results;
}
protected static function buscarCredito($query)
{
$results = \Model::factory(Venta::class)
->select('venta.*')
->join('credito', ['credito.id', '=', 'venta.credito'])
->join('pago', ['pago.id', '=', 'credito.pago'])
->whereRaw("`pago`.`valor` = " . $query . " OR `pago`.`valor` / `pago`.`uf` = " . $query)
->findMany();
return $results;
}
protected static function buscarUnidad($query)
{
if (is_array($query)) {
$results = [];
foreach ($query as $segment) {
$results = array_merge($results, self::buscarUnidad($segment));
}
} else {
$results = model(Unidad::class)->where('descripcion', $query)->findMany();
foreach ($results as $i => $u) {
if ($u->venta()) {
unset($results[$i]);
}
}
}
return $results;
}
}
?>

428
app/Controller/Cierres.php Normal file
View File

@ -0,0 +1,428 @@
<?php
namespace App\Controller;
use Carbon\Carbon;
use App\Definition\Controller;
use App\Service\Borrador;
use App\Service\Factory;
use Incoviba\old\Common\Direccion;
use Incoviba\old\Common\Region;
use Incoviba\old\Proyecto\Agente;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Venta\Propietario;
use Incoviba\old\Venta\Unidad;
use Incoviba\old\Venta\Cierre;
use Incoviba\old\Venta\EstadoCierre;
use Incoviba\nuevo\Venta\Precio;
use Incoviba\nuevo\Venta\Reserva;
use Incoviba\old\Venta\TipoEstadoCierre;
use Incoviba\old\Venta\TipoValorCierre;
use Incoviba\nuevo\Venta\UnidadReserva;
use Incoviba\old\Venta\Unidad as U;
class Cierres
{
use Controller;
public static function add()
{
$proyectos = model(Proyecto::class)
->select('proyecto.*')
->join('estado_proyecto', ['estado.proyecto', '=', 'proyecto.id'], 'estado')
->join('tipo_estado_proyecto', ['tipo.id', '=', 'estado.estado'], 'tipo')
->join('etapa_proyecto', ['etapa.id', '=', 'tipo.etapa'], 'etapa')
->whereGte('etapa.orden', 3)
->orderByAsc('proyecto.descripcion')
->groupBy('proyecto.id')
->findMany();
$regiones = model(Region::class)->order_by_asc('numeracion')->findMany();
return view('ventas.cierres.add', compact('proyectos', 'regiones'));
}
public static function agregar()
{
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$id_proyecto = post('proyecto');
$proyecto = model(Proyecto::class)->findOne($id_proyecto);
$id_agente = post('agente');
$agente = model(Agente::class)->findOne($id_agente);
$direccion = model(Direccion::class)
->where('calle', post('calle'))
->where('numero', post('numero'))
->where('extra', post('extra'))
->where('comuna', post('comuna'))
->findOne();
if (!$direccion) {
$data = [
'calle' => post('calle'),
'numero' => post('numero'),
'extra' => post('extra'),
'comuna' => post('comuna')
];
$direccion = model(Direccion::class)->create($data);
$direccion->save();
}
list($rut, $dv) = explode('-', str_replace('.', '', post('rut')));
$propietario = model(Propietario::class)->findOne($rut);
if (!$propietario) {
$data = [
'rut' => $rut,
'dv' => $dv,
'nombres' => trim(post('nombres')),
'apellido_paterno' => post('paterno'),
'apellido_materno' => post('materno'),
'sexo' => post('sexo'),
'estado_civil' => post('estado_civil'),
'profesion' => post('profesion'),
'direccion' => $direccion->id,
'telefono' => post('codigo_telefono') . post('telefono'),
'email' => post('email') . '@' . post('email_domain'),
'representante' => 0,
'otro' => 0
];
$propietario = model(Propietario::class)->create($data);
$propietario->save();
}
$unis = json_decode(post('unidades'));
$id_principal = array_shift($unis);
$unidad = model(Unidad::class)->findOne(post('unidad' . $id_principal));
$u = model(U::class)->findOne($unidad->id);
if (!$u) {
$unidad->save();
}
$data = [
'unidad_id' => $unidad->id
];
$reserva = model(Reserva::class)->create($data);
$reserva->save();
foreach ($unis as $id_unidad) {
$unidad = model(Unidad::class)->findOne(post('unidad' . $id_unidad));
$data = [
'reserva_id' => $reserva->id,
'unidad_id' => $unidad->id
];
$ur = model(UnidadReserva::class)->create($data);
$ur->save();
}
$data = [
'proyecto_id' => $proyecto->id,
'agente_id' => $agente->id,
'propietario_rut' => $propietario->rut,
'reserva_id' => $reserva->id,
'fecha' => $f->format('Y-m-d'),
'valor' => correctNumber(post('valor')),
'pie' => correctNumber(post('pie')),
'credito' => correctNumber(post('credito')),
'estado' => 1
];
$cierre = model(Cierre::class)->create($data);
$cierre->save();
header('Location: ' . url('', ['p' => 'cierres', 'a' => 'list']));
}
public static function list()
{
$proyectos = Cierre::proyectos();
return view('ventas.cierres.list', compact('proyectos'));
}
public static function show()
{
$id = get('cierre');
$cierre = model(Cierre::class)->findOne($id);
return view('ventas.cierres.show', compact('cierre'));
}
public static function guardar()
{
$proyecto = \model(Proyecto::class)->findOne(post('proyecto'));
$fecha = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$unidad = \model(Unidad::class)->findOne(post('departamento'));
$relacionado = (post('relacionado') === true) ? true : false;
$subrelacionado = (post('subrelacionado') === true) ? true : false;
$precio = (float) post('precio') ?: 0;
$input = [
'proyecto' => $proyecto,
'fecha' => $fecha,
'departamento' => $unidad,
'precio' => $precio,
'relacionado' => $relacionado,
'subrelacionado' => $subrelacionado,
'unidades' => [],
'pie' => (float) post('pie')
];
$ebs = 0;
if (post('unidades') != '') {
$unidades = json_decode(html_entity_decode(post('unidades')), true);
foreach ($unidades as $un) {
$u = \model(Unidad::class)->findOne($un);
$input['unidades'] []= $u;
if ($u->precio($fecha) !== false) {
$ebs += $u->precio($fecha)->valor;
}
}
}
$promo = 0;
if (post('promocion') != null) {
$promo = (float) post('promocion');
$input['promocion'] = $promo;
}
$bono = 0;
if (post('bono') != null) {
$bono = (float) post('bono');
$input['bono'] = $bono;
}
$operador = 0;
if (post('operador') != null) {
$operador = ($precio - $bono - $promo) * (float) post('operador') / 100;
$input['operador'] = $operador;
}
$cierre = Cierre::find($proyecto, $unidad, $precio)->findOne();
if ($cierre === false) {
$cierre = model(Cierre::class)->create();
$cierre->guardar((object) $input);
}
$output = ['status' => 'ok', 'cierre' => $cierre->asArray()];
return json_encode($output);
}
public static function aprobar()
{
$fecha = Carbon::today(config('app.timezone'));
$cierre = model(Cierre::class)->findOne(post('cierre'));
if ($cierre->estado()->tipo()->descripcion == "revisado" or $cierre->estado()->tipo()->descripcion == "rechazado") {
$cierre->aprobar($fecha);
return json_encode(['estado' => 'aprobado']);
}
return json_encode(['estado' => 'no vigente']);
}
public static function rechazar()
{
$fecha = Carbon::today(config('app.timezone'));
$cierre = model(Cierre::class)->findOne(post('cierre'));
if ($cierre->estado()->tipo()->vigente == 1) {
$cierre->rechazar($fecha);
return json_encode(['estado' => 'rechazado']);
}
return json_encode(['estado' => 'no vigente']);
}
public static function abandonar()
{
$id = get('cierre');
$cierre = model(Cierre::class)->findOne($id);
$tipo = model(TipoEstadoCierre::class)->where('descripcion', 'abandonado')->findOne();
$today = Carbon::today(config('app.timezone'));
$data = [
'cierre' => $cierre->id,
'tipo' => $tipo->id,
'fecha' => $today->format('Y-m-d')
];
$estado = model(EstadoCierre::class)->create($data);
$estado->save();
header('Location: ' . url('', ['p' => 'cierres', 'a' => 'list']));
}
public static function promesar()
{
$id = get('cierre');
$cierre = model(Cierre::class)->findOne($id);
$tipo = model(TipoEstadoCierre::class)->where('descripcion', 'promesado')->findOne();
$today = Carbon::today(config('app.timezone'));
$data = [
'cierre' => $cierre->id,
'tipo' => $tipo->id,
'fecha' => $today->format('Y-m-d')
];
$estado = model(EstadoCierre::class)->create($data);
$estado->save();
header('Location: ' . url('', ['p' => 'cierres', 'a' => 'show', 'cierre' => $cierre->id]));
}
public static function borrador()
{
$id = get('cierre');
$cierre = model(Cierre::class)->findOne($id);
$borrador = new Borrador($cierre);
d($borrador->show());
$borrador->create();
}
public static function evalue()
{
$proyectos = \model(Proyecto::class)->orderByAsc('descripcion')->findMany();
return view('ventas.cierres.evaluar', compact('proyectos'));
}
public static function evaluar()
{
$proyecto = \model(Proyecto::class)->findOne(post('proyecto'));
$fecha = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$unidad = \model(Unidad::class)->findOne(post('departamento'));
$relacionado = (post('relacionado') === 'true') ? true : false;
$subrelacionado = (post('subrelacionado') === 'true') ? true : false;
$precio = (float) post('precio') ?: 0;
$neto = $precio;
$ebs = 0;
if (post('unidades') != '') {
$unidades = json_decode(html_entity_decode(post('unidades')), true);
foreach ($unidades as $un) {
$u = \model(Unidad::class)->findOne($un);
if ($u->precio($fecha) !== false) {
$ebs += $u->precio($fecha)->valor;
}
}
}
$promocion = 0;
if (post('promocion') != null) {
$promocion = (float) post('promocion');
}
$bono = 0;
if (post('bono') != null) {
$bono = (float) post('bono');
}
$operador = 0;
if (post('operador') != null) {
$operador = ($precio - $bono - $promocion) * (float) post('operador') / 100;
}
$rel = 0;
if ($relacionado) {
$rel = ($unidad->precio($fecha)->valor) * 6 / 100;
}
if ($subrelacionado) {
$rel = ($unidad->precio($fecha)->valor) * 3 / 100;
}
$neto = $precio - $bono - $promocion - $operador - $ebs;
$output = [
'unidad' => [
'tipo' => [
'nombre' => $unidad->tipologia()->nombre,
'tipologia' => $unidad->tipologia()->tipologia()->descripcion
],
'superficie' => format('m2', $unidad->m2()) . ' m&#0178;'
],
'oferta' => [
'bruto' => format('ufs', $precio, null, true),
'neto' => format('ufs', $neto, null, true),
'uf_m2' => format('ufs', $neto / $unidad->m2('vendible'), null, true) . '/m&#0178;',
'fecha' => format('shortDate', $unidad->precio($fecha)->inicio()->fecha())
],
'lista' => [
'precio' => format('ufs', $unidad->precio($fecha)->valor, null, true),
'uf_m2' => format('ufs', $unidad->precio($fecha)->valor / $unidad->m2('vendible'), null, true) . '/m&#0178;'
],
'precios' => [
'bruto' => format('ufs', $precio, null, true),
'neto' => format('ufs', $neto, null, true),
'departamento' => format('ufs', $unidad->precio($fecha)->valor, null, true),
'relacionado' => format('ufs', $unidad->precio($fecha)->valor - $rel, null, true),
'fecha' => format('shortDate', $unidad->precio($fecha)->inicio()->fecha())
],
'uf_m2' => [
'neto' => format('ufs', $neto / $unidad->m2('vendible'), null, true) . '/m&#0178;',
'departamento' => format('ufs', $unidad->precio($fecha)->valor / $unidad->m2('vendible'), null, true) . '/m&#0178;',
'relacionado' => format('ufs', ($unidad->precio($fecha)->valor - $rel) / $unidad->m2('vendible'), null, true) . '/&#0178;'
],
'evaluacion' => Cierre::evaluar($neto, $unidad, $fecha, $rel),
'estado' => ['id' => 0, 'descripcion' => 'no existe']
];
if ($rel > 0) {
$output ['relacionado'] = [
'precio' => format('ufs', $unidad->precio($fecha)->valor - $rel, null, true),
'uf_m2' => format('ufs', ($unidad->precio($fecha)->valor - $rel) / $unidad->m2('vendible'), null, true) . '/&#0178;'
];
}
$estado = Cierre::find($proyecto, $unidad, $precio)->findOne();
if ($estado) {
$output['estado'] = [
'id' => $estado->estado()->tipo()->id,
'cierre' => $estado->id,
'descripcion' => $estado->estado()->tipo()->descripcion,
'fecha' => format('shortDate', $estado->estado()->fecha)
];
}
return json_encode($output);
}
public static function edit()
{
$cierre = model(Cierre::class)->findOne(get('cierre'));
$proyectos = model(Proyecto::class)->findMany();
$regiones = model(Region::class)->findMany();
$valores = model(TipoValorCierre::class)->findMany();
return view('ventas.cierres.edit', compact('cierre', 'proyectos', 'regiones', 'valores'));
}
public static function do_edit()
{
$cierre = model(Cierre::class)->findOne(get('cierre'));
$data = [
'calle' => post('calle'),
'numero' => post('numero'),
'extra' => post('extra'),
'comuna' => post('comuna')
];
$direccion = (new Factory(Direccion::class))->where($data)->find();
if (!$direccion) {
$direccion = model(Direccion::class)->create($data);
$direccion->save();
}
if (post('rut') != '') {
$data = [
'rut' => explode('-', str_replace('.', '', post('rut')))[0],
];
$propietario = (new Factory(Propietario::class))->where($data)->find();
if (!$propietario) {
$data = array_merge($data, [
'nombres' => post('nombres'),
'apellido_paterno' => post('paterno'),
'apellido_materno' => post('materno'),
'dv' => (post('rut')) ? explode('-', str_replace('.', '', post('rut')))[1] : '',
'sexo' => post('sexo'),
'estado_civil' => post('estado_civil'),
'profesion' => post('profesion'),
'telefono' => post('codigo_telefono') . post('telefono'),
'email' => post('email') . '@' . post('email_domain'),
'direccion' => $direccion->id
]);
$propietario = model(Propietario::class)->create($data);
$propietario->save();
}
}
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$data = [
'proyecto' => post('proyecto'),
'precio' => post('precio'),
'fecha' => $f->format('Y-m-d'),
'relacionado' => (post('relacionado')) ? 1 : 0,
'propietario' => (isset($propietario) and $propietario) ? $propietario->rut : 0
];
foreach ($data as $field => $value) {
if ($value != $cierre->$field) {
$cierre->$field = $value;
}
}
$cierre->save();
$valores = model(TipoValorCierre::class)->findMany();
foreach ($valores as $valor) {
if (post($valor->descripcion) == '') {
continue;
}
if ($cierre->valor($valor->descripcion)) {
if ($cierre->valor($valor->descripcion)->valor != post($valor->descripcion)) {
$v = $cierre->valor($valor->descripcion);
$v->valor = post($valor->descripcion);
$v->save();
}
continue;
}
$data = [
'tipo' => $valor->descripcion,
'valor' => post($valor->descripcion)
];
$cierre->addValor($data);
}
header('Location: ' . nUrl('cierres', 'show', ['cierre' => $cierre->id]));
}
}
?>

View File

@ -0,0 +1,39 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
class Comentarios
{
use Controller;
public static function add()
{
$venta = \Model::factory(\Incoviba\old\Venta\Venta::class)->findOne(get('venta'));
echo view('ventas.comentarios.add', compact('venta'));
}
public static function agregar()
{
$venta = \Model::factory(\Incoviba\old\Venta\Venta::class)->findOne(get('venta'));
if ($venta === false) {
throw new Exception('Venta no existe.');
}
$data = [
'venta' => $venta->id,
'fecha' => \Carbon\Carbon::now(config('app.timezone'))->format('Y-m-d H:i:s'),
'texto' => post('comentario')
];
$comentario = \Model::factory(\Incoviba\old\Venta\Comentario::class)->create($data);
$comentario->save();
header('Location: ' . nUrl('ventas', 'show', ['venta' => $venta->id]));
}
public static function delete()
{
$comentario = \Model::factory(\Incoviba\old\Venta\Comentario::class)->findOne(get('comentario'));
$venta = $comentario->venta();
$comentario->estado = 0;
$comentario->save();
header('Location: ' . nUrl('ventas', 'show', ['venta' => $venta->id]));
}
}
?>

207
app/Controller/Creditos.php Normal file
View File

@ -0,0 +1,207 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Venta;
use Incoviba\old\Common\Banco;
use Incoviba\old\Venta\Credito;
use Carbon\Carbon;
use Incoviba\old\Venta\Pago;
use Incoviba\old\Venta\EstadoPago;
class Creditos
{
use Controller;
protected static function setDefault()
{
self::$default = view('construccion');
}
public static function agregar()
{
$id = get('venta');
if ($id == null) {
header('Location: .');
}
$venta = \Model::factory(Venta::class)->findOne($id);
return view('ventas.creditos.add', compact('venta'));
}
public static function agregado()
{
$id = get('venta');
if ($id == null) {
header('Location: .');
}
$venta = \Model::factory(Venta::class)->findOne($id);
$banco = \Model::factory(Banco::class)->where('nombre', post('banco'))->findOne();
$f = Carbon::createFromDate(post('y'), post('m'), post('d'), config('app.timezone'));
$uf = uf($f);
$pago = \Model::factory(Pago::class)->create();
$pago->banco = $banco->id;
$pago->fecha = $f->format('Y-m-d');
$pago->uf = $uf->uf->value;
$pago->valor = post('valor') * $pago->uf;
$pago->tipo = 2;
$credito = \Model::factory(Credito::class)->create();
$credito->banco = $pago->banco;
$credito->valor = $pago->valor;
$credito->fecha = $pago->fecha;
$credito->uf = $pago->uf;
$pago->new();
$credito->pago = $pago->id;
$credito->save();
$venta->credito = $credito->id;
$venta->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function pagar()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
return view('ventas.creditos.pagar', compact('venta'));
}
public static function pagando()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
$valor = str_replace(',', '.', str_replace('.', '', post('valor')));
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$pago = $venta->credito()->pago();
if ($pago->valor != $valor) {
$pago->valor = $valor;
}
$estado = \Model::factory(EstadoPago::class)->create();
$estado->pago = $pago->id;
$estado->fecha = $f->format('Y-m-d');
$estado->estado = 1;
$estado->save();
if ($pago->is_dirty('valor')) {
$pago->save();
}
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function abonar()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
return view('ventas.creditos.abonar', compact('venta'));
}
public static function abonando()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
$valor = str_replace(',', '.', str_replace('.', '', post('valor')));
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$pago = $venta->credito()->pago();
if ($pago->valor != $valor) {
$pago->valor = $valor;
}
$estado = \Model::factory(EstadoPago::class)->create();
$estado->pago = $pago->id;
$estado->fecha = $f->format('Y-m-d');
$estado->estado = 2;
$estado->save();
if ($pago->is_dirty('valor')) {
$pago->save();
}
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function show()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.creditos.show', compact('venta'));
}
public static function edit()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.creditos.edit', compact('venta'));
}
public static function editado()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$pago = $venta->credito()->pago();
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$uf = uf($f);
$banco = model(Banco::class)->where('nombre', post('banco'))->findOne();
$valor = correctNumber(post('valor')) * $uf->uf->value;
$fields = ['valor', 'uf', 'fecha', 'banco'];
$data = ['valor' => $valor, 'uf' => $uf->uf->value, 'fecha' => $f->format('Y-m-d'), 'banco' => $banco->id];
$change = false;
foreach ($fields as $field) {
if ($pago->$field != $data[$field]) {
$change = true;
$pago->$field = $data[$field];
if ($field == 'fecha') {
$eps = $pago->estados();
foreach ($eps as $ep) {
if ($ep->estado == 0) {
$ep->fecha = $data[$field];
$ep->save();
break;
}
}
}
}
}
if ($change) {
$pago->save();
}
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function remove()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$pago = $venta->credito()->pago();
$f = Carbon::today(config('app.timezone'));
$data = [
'pago' => $pago->id,
'estado' => -3,
'fecha' => $f->format('Y-m-d')
];
$estado = model(EstadoPago::class)->create($data);
$estado->save();
$venta->credito = 0;
$venta->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function pendientes()
{
$creditos = model(Credito::class)
->select('credito.*')
->join('venta', ['venta.credito', '=', 'credito.id'])
->join('pago', ['pago.id', '=', 'credito.pago'])
->rawJoin('JOIN (SELECT ep.* FROM (SELECT pago, MAX(id) AS id FROM estado_pago GROUP BY pago) e0 JOIN estado_pago ep ON ep.id = e0.id)', ['estado_pago.pago', '=', 'pago.id'], 'estado_pago')
->whereLt('estado_pago.estado', 2)
->where('venta.estado', 1)
->orderByAsc('estado_pago.fecha')
->findMany();
return view('ventas.creditos.pendientes', compact('creditos'));
}
}
?>

230
app/Controller/Cuotas.php Normal file
View File

@ -0,0 +1,230 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Cuota;
use Incoviba\old\Venta\EstadoPago;
use Carbon\Carbon;
use Incoviba\old\Venta\Pie;
use Incoviba\old\Venta\Pago;
use Incoviba\old\Common\Banco;
class Cuotas
{
use Controller;
protected static function setDefault()
{
self::$default = view('construccion');
}
public static function show()
{
$id = get('cuota');
$cuota = \Model::factory(Cuota::class)->findOne($id);
return view('ventas.pies.cuotas.show', compact('cuota'));
}
public static function edit()
{
$id = get('cuota');
$cuota = \Model::factory(Cuota::class)->findOne($id);
return view('ventas.pies.cuotas.edit', compact('cuota'));
}
public static function editar()
{
$id = get('cuota');
$cuota = \Model::factory(Cuota::class)->findOne($id);
$cuota->numero = post('numero');
$cuota->{'valor_$'} = post('valor');
$banco = \Model::factory(\Incoviba\old\Common\Banco::class)->where('nombre', post('banco'))->findOne();
if ($banco) {
$cuota->banco = $banco->id;
} else {
$cuota->banco = 0;
}
$f = \Carbon\Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$cuota->fecha = $f->format('Y-m-d');
$pago = $cuota->pago();
$pago->valor = post('valor');
$pago->banco = $banco->id;
$pago->identificador = post('identificador');
$pago->fecha = $f->format('Y-m-d');
$uf = uf($f);
if ($uf->total > 0) {
$pago->uf = $uf->uf->value;
} else {
$pago->uf = 0;
}
$pago->save();
$cuota->save();
header('Location: ' . url('', ['p' => 'pies', 'a' => 'resumen', 'pie' => $cuota->pie()->id]));
}
public static function edited()
{
$id = get('cuota');
$cuota = \Model::factory(Cuota::class)->findOne($id);
$pago = $cuota->pago();
foreach ($_POST as $key => $value) {
$pago->$key = $value;
}
$pago->save();
}
public static function pendientes()
{
$f = \Carbon\Carbon::today(config('app.timezone'));
$cuotas = \Model::factory(Cuota::class)
->select('cuota.*')
->join('pago', ['pago.id', '=', 'cuota.pago'])
->join('venta', ['venta.pie', '=', 'cuota.pie'])
->raw_join('JOIN (SELECT e1.* FROM (SELECT pago, MAX(id) AS id FROM estado_pago GROUP BY pago) e0 JOIN estado_pago e1 ON e1.id = e0.id)', ['ep.pago', '=', 'pago.id'], 'ep')
->where('ep.estado', 0)
->where('venta.estado', 1)
->whereLte('pago.fecha', $f->format('Y-m-d'))
->order_by_asc('pago.fecha')
->findMany();
$sum = 0;
if (count($cuotas) > 0) {
$sum = array_reduce($cuotas, function($carry, $item) {
$carry += $item->pago()->valor;
return $carry;
});
}
setlocale(LC_TIME, 'es');
return view('ventas.pies.cuotas.pendientes', compact('cuotas', 'sum'));
}
public static function depositar()
{
$id = post('cuota');
$cuota = \Model::factory(Cuota::class)->findOne($id);
if ($cuota->pago()->estado()->estado == 1) {
return 'ok';
}
$estado = \Model::factory(EstadoPago::class)->create();
$estado->pago = $cuota->pago()->id;
$estado->estado = 1;
$f = Carbon::parse(post('fecha'), config('app.timezone'));
$estado->fecha = $f->format('Y-m-d');
$estado->save();
return 'ok';
}
public static function remove()
{
$id = get('cuota');
$cuota = \Model::factory(Cuota::class)->findOne($id);
$estado = \Model::factory(EstadoPago::class)->create();
$estado->pago = $cuota->pago()->id;
$estado->estado = -3;
$f = Carbon::today(config('app.timezone'));
$estado->fecha = $f->format('Y-m-d');
$estado->save();
header('Location: ' . url('', ['p' => 'pies', 'a' => 'resumen', 'pie' => $cuota->pie()->id]));
}
public static function para_abonar()
{
$cuotas = \Model::factory(Cuota::class)
->select('cuota.*')
->join('pago', ['pago.id', '=', 'cuota.pago'])
->join('venta', ['venta.pie', '=', 'cuota.pie'])
->raw_join('JOIN (SELECT e1.* FROM (SELECT pago, MAX(id) AS id FROM estado_pago GROUP BY pago) e0 JOIN estado_pago e1 ON e1.id = e0.id)', ['ep.pago', '=', 'pago.id'], 'ep')
->where('ep.estado', 1)
->where('venta.estado', 1)
->order_by_asc('ep.fecha')
->findMany();
$ini = get('start');
if ($ini == null) {
$ini = 0;
}
$n = get('step');
if ($n == 0) {
$n = 30;
}
$total = count($cuotas);
$cuotas = array_slice($cuotas, $ini, $n);
$pages = ceil($total / $n);
$current = ($ini + $n) / $n;
return view('ventas.pies.cuotas.abonar', compact('cuotas', 'total', 'pages', 'current'));
}
public static function abonar()
{
$id = post('cuota');
$cuota = \Model::factory(Cuota::class)->findOne($id);
if ($cuota->pago()->estado()->estado == 2) {
return 'ok';
}
$estado = \Model::factory(EstadoPago::class)->create();
$estado->pago = $cuota->pago()->id;
$estado->estado = 2;
$f = Carbon::parse(post('fecha'), config('app.timezone'));
$estado->fecha = $f->format('Y-m-d');
$estado->save();
return 'ok';
}
public static function rebotar()
{
$id = post('cuota');
$cuota = \Model::factory(Cuota::class)->findOne($id);
if ($cuota->pago()->estado()->estado == -1) {
return 'ok';
}
$estado = \Model::factory(EstadoPago::class)->create();
$estado->pago = $cuota->pago()->id;
$estado->estado = -1;
$f = Carbon::parse(post('fecha'), config('app.timezone'));
$estado->fecha = $f->format('Y-m-d');
$estado->save();
return 'ok';
}
public static function add()
{
$id = get('pie');
$pie = \Model::factory(Pie::class)->findOne($id);
return view('ventas.pies.cuotas.add', compact('pie'));
}
public static function agregar()
{
$id = get('pie');
$pie = \Model::factory(Pie::class)->findOne($id);
$cant = $pie->cuotas - count($pie->cuotas());
for ($i = 0; $i < $cant; $i ++) {
if (trim(post('valor' . $i)) == '') {
continue;
}
$banco = \Model::factory(Banco::class)->where('nombre', post('banco' . $i))->findOne();
$f = Carbon::createFromDate(post('year' . $i), post('month' . $i), post('day' . $i), config('app.timezone'));
$uf = uf($f);
$valor = correctNumber(post('valor' . $i));
$pago = \Model::factory(Pago::class)->create();
$pago->banco = $banco->id;
$pago->fecha = $f->format('Y-m-d');
if ($uf and $uf->total > 0) {
$pago->uf = $uf->uf->value;
} else {
$pago->uf = 0;
}
$pago->tipo = 1;
$pago->valor = $valor;
$pago->identificador = post('identificador' . $i);
$cuota = \Model::factory(Cuota::class)->create();
$cuota->pie = $pie->id;
$cuota->fecha = $pago->fecha;
$cuota->{'valor_$'} = $pago->valor;
$cuota->estado = 0;
$cuota->banco = $pago->banco;
$cuota->uf = $pago->uf;
$cuota->numero = post('numero' . $i);
$pago->new();
$cuota->pago = $pago->id;
$cuota->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $pie->venta()->id]));
}
}
}
?>

View File

@ -0,0 +1,19 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Venta;
class Devoluciones
{
use Controller;
public static function liquidacion()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('print.devolucion', compact('venta'));
}
}
?>

View File

@ -0,0 +1,212 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Venta;
use Incoviba\old\Venta\Pago;
use Carbon\Carbon;
use Incoviba\old\Venta\Escritura;
use Incoviba\old\Common\Banco;
use Incoviba\old\Venta\Credito;
use Incoviba\old\Venta\Subsidio;
use Incoviba\old\Venta\EstadoPago;
use Incoviba\old\Venta\TipoEstadoVenta;
use Incoviba\old\Venta\EstadoVenta;
class Escrituras
{
use Controller;
protected static function setDefault()
{
self::$default = view('construccion');
}
public static function add()
{
$id = get('venta');
if ($id == null) {
header('Location: .');
}
$venta = \Model::factory(Venta::class)->findOne($id);
return view('ventas.escrituras.add', compact('venta'));
}
public static function agregar()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('escritura_year'), post('escritura_month'), post('escritura_day'), config('app.timezone'));
$venta->escriturado = $f->format('Y-m-d');
if (post('valor_reajuste')) {
$reajuste = \Model::factory(Pago::class)->create();
$reajuste->valor = correctNumber(post('valor_reajuste'));
$fp = Carbon::createFromDate(post('reajuste_year'), post('reajuste_month'), post('reajuste_day'), config('app.timezone'));
$reajuste->fecha = $fp->format('Y-m-d');
$reajuste->uf = (float) uf($fp)->uf->value;
$reajuste->newPagado();
$pie = $venta->pie();
$pie->reajuste = $reajuste->id;
$pie->save();
}
if (post('escritura_valor') or post('escritura_valor_uf')) {
$pago = \Model::factory(Pago::class)->create();
$fp = Carbon::createFromDate(post('pago_escritura_year'), post('pago_escritura_month'), post('pago_escritura_day'), config('app.timezone'));
$pago->fecha = $fp->format('Y-m-d');
$pago->uf = (float) uf($fp)->uf->value;
if (post('escritura_valor')) {
$pago->valor = correctNumber(post('escritura_valor'));
$pago->newPagado();
} else {
$pago->valor = correctNumber(post('escritura_valor_uf')) * $pago->uf;
$pago->new();
}
$escritura = \Model::factory(Escritura::class)->create();
$escritura->pago = $pago->id;
$escritura->valor = $pago->valor('uf');
$escritura->fecha = $pago->fecha;
$escritura->save();
$venta->escritura = $escritura->id;
}
if (post('subsidio_ahorrado') or post('subsidio_valor')) {
$total = post('subsidio_ahorrado') + post('subsidio_valor');
$subsidio = \Model::factory(Subsidio::class)->create();
$pago = \Model::factory(Pago::class)->create();
$pago->fecha = $f->format('Y-m-d');
$pago->uf = (float) uf($f)->uf->value;
$pago->valor = correctNumber(post('subsidio_ahorrado')) * $pago->uf;
$pago->new();
$subsidio->pago = $pago->id;
$pago = \Model::factory(Pago::class)->create();
$pago->fecha = $f->format('Y-m-d');
$pago->uf = (float) uf($f)->uf->value;
$pago->valor = correctNumber(post('subsidio_valor')) * $pago->uf;
$pago->new();
$subsidio->subsidio = $pago->id;
$subsidio->save();
$venta->subsidio = $subsidio->id;
}
if (post('credito_valor')) {
$pago = \Model::factory(Pago::class)->create();
$pago->fecha = $f->format('Y-m-d');
$pago->uf = (float) uf($f)->uf->value;
$valor = post('credito_valor');
if (strpos($valor, ',') !== false) {
$valor = correctNumber($valor);
}
$pago->valor = $valor * $pago->uf;
$banco = \Model::factory(Banco::class)->where('nombre', post('credito_banco'))->findOne();
$pago->banco = $banco->id;
$pago->new();
$credito = \Model::factory(Credito::class)->create();
$credito->pago = $pago->id;
$credito->save();
$venta->credito = $credito->id;
} elseif (post('credito_banco')) {
$pago = $venta->credito()->pago();
$banco = \Model::factory(Banco::class)->where('nombre', post('credito_banco'))->findOne();
$pago->banco = $banco->id;
$pago->save();
}
$tipo = \Model::factory(TipoEstadoVenta::class)->where('descripcion', 'escriturando')->findOne();
$data = [
'venta' => $venta->id,
'estado' => $tipo->id,
'fecha' => $venta->escriturado
];
$estado = \Model::factory(EstadoVenta::class)->create($data);
$estado->save();
$venta->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function edit()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
echo view('ventas.escrituras.edit', compact('venta'));
}
public static function editar()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$uf = uf($f);
$valor = correctNumber(post('valor'));
if ($valor == '') {
$valor_uf = correctNumber(post('valor_uf'));
$valor = $valor_uf * $uf->uf->value;
}
$pago = $venta->escritura()->pago();
if ($pago->valor != $valor) {
$pago->valor = $valor;
}
if ($pago->fecha != $f->format('Y-m-d')) {
$pago->fecha = $f->format('Y-m-d');
$pago->uf = $uf->uf->value;
}
$pago->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function informe()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
return view('ventas.escrituras.informe', compact('venta'));
}
public static function pagar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.escrituras.pagar', compact('venta'));
}
public static function pagado()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$data = [
'pago' => $venta->escritura()->pago()->id,
'fecha' => $f->format('Y-m-d'),
'estado' => 1
];
$estado = model(EstadoPago::class)->create($data);
$estado->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function abonar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.escrituras.abonar', compact('venta'));
}
public static function abonado()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$data = [
'pago' => $venta->escritura()->pago()->id,
'fecha' => $f->format('Y-m-d'),
'estado' => 2
];
$estado = model(EstadoPago::class)->create($data);
$estado->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
}
?>

View File

@ -0,0 +1,98 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Venta;
use Carbon\Carbon;
use Incoviba\old\Venta\Pie;
use Incoviba\old\Venta\Escritura;
use Incoviba\old\Venta\Pago;
class FormaPago
{
use Controller;
public static function edit()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.forma_pago.edit', compact('venta'));
}
public static function editar()
{
d(post());
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$valor = correctNumber(post('valor_pie'));
$cuotas = post('cuotas_pie');
if ($venta->pie != 0) {
$pie = $venta->pie();
$changed = false;
if ($pie->valor != $valor) {
$pie->valor = $valor;
$changed = true;
}
if ($pie->cuotas != $cuotas) {
$pie->cuotas = $cuotas;
$changed = true;
}
if ($changed) {
d($pie);
}
$valor = correctNumber(post('valor_reajuste'));
$f = Carbon::createFromDate(post('year_reajuste'), post('month_reajuste'), post('day_reajuste'), config('app.timezone'));
$uf = uf($f);
$reajuste = $pie->reajuste();
$changed = false;
if ($reajuste->valor != $valor) {
$reajuste->valor = $valor;
$changed = true;
}
if ($reajuste->fecha != $f->format('Y-m-d')) {
$reajuste->fecha = $f->format('Y-m-d');
$reajuste->uf = $uf->uf->value;
$changed = true;
}
if ($changed) {
d($reajuste);
}
} elseif ($valor != '') {
$f = Carbon::parse($venta->fecha, config('app.timezone'));
$uf = uf($f);
$data = [
'valor' => $valor,
'cuotas' => $cuotas,
'uf' => $uf->uf->value,
'fecha' => $f->format('Y-m-d')
];
$pie = model(Pie::class)->create($data);
d($pie);
}
$valor = correctNumber(post('valor_escritura'));
$f = Carbon::createFromDate(post('year_escritura'), post('month_escritura'), post('day_escritura'), config('app.timezone'));
if ($venta->escritura != 0) {
$escritura = $venta->escritura();
d($escritura);
} elseif ($valor != '') {
$data = [
'valor' => $valor,
'fecha' => $f->format('Y-m-d'),
'uf' => $uf->uf->value,
'tipo' => 7
];
$pago = model(Pago::class)->create($data);
$pago->newPagado();
$data['pago'] = $pago->id;
unset($data['tipo']);
$escritura = model(Escritura::class)->create($data);
$escritura->save();
$venta->escritura = $escritura->id;
$venta->save();
}
}
}
?>

907
app/Controller/Informes.php Normal file
View File

@ -0,0 +1,907 @@
<?php
namespace App\Controller;
use Carbon\Carbon;
use GuzzleHttp\Client;
use App\Definition\Controller;
use App\Alias\PHPExcel;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Proyecto\Agente;
use Incoviba\old\Proyecto\ProyectoAgente;
use Incoviba\old\Venta\Venta;
use Incoviba\old\Venta\Pie;
use Incoviba\old\Venta\Credito;
use Incoviba\old\Venta\Cuota;
class Informes
{
use Controller;
protected static function setDefault()
{
self::$default = view('informes.list');
}
public static function gantt_entregas()
{
if (get('proyecto')) {
$id_proyecto = get('proyecto');
$proyecto = model(Proyecto::class)->find_one($id_proyecto);
$ini = \Carbon\Carbon::parse($proyecto->estado()->fecha, config('app.timezone'));
#$informe = new Informador('Carta Gantt Proyecto - ' . $proyecto->descripcion);
$name = 'Carta Gantt Proyecto - ' . $proyecto->descripcion;
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = ['Departamento', 'Propietario', 'Entrega', 'Estado'];
$today = \Carbon\Carbon::today(config('app.timezone'));
$end = $today->copy()->addDays(30);
$dif = $end->diffInDays($ini);
for ($i = 0; $i <= $dif; $i ++) {
$f = $ini->copy()->addDays($i);
if ($f->isWeekend()) {
continue;
}
$columnas []= $f->format('Y-m-d');
}
$informe->addColumns($columnas);
$data = [];
foreach ($proyecto->entregas() as $venta) {
$info = [];
$info []= $venta->unidad()->descripcion;
$info []= $venta->propietario()->findOne()->nombreCompleto();
$fe = Carbon::parse($venta->entrega()->find_one()->fecha, config('app.timezone'));
$info []= $fe->format('Y-m-d');
$info []= '';
for ($i = 0; $i <= $dif; $i ++) {
$f = $ini->copy()->addDays($i);
if ($f->isWeekend()) {
continue;
}
if ($f >= $fe and $f <= $fe->copy()->addDays(14)) {
$info []= 'X';
} else {
$info []= '';
}
}
$data []= $info;
}
$informe->addDatas($data);
return $informe->informe();
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.gantt_entregas', compact('proyectos'));
}
}
public static function escrituras()
{
if (get('proyecto')) {
set_time_limit(60);
$id_proyecto = get('proyecto');
$proyecto = model(Proyecto::class)->find_one($id_proyecto);
#$informe = new Informador('Escrituras - ' . $proyecto->descripcion);
$name = 'Escrituras';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = [
'Departamento',
'Estacionamientos',
'Bodegas',
'Propietario',
(object) ['name' => 'Promesa', 'style' => 'number'],
['name' => 'Bono Pie', 'style' => 'amount'],
['name' => 'Pie Pagado', 'style' => 'amount'],
['name' => 'Reajuste', 'style' => 'amount'],
['name' => 'Abono Contado', 'style' => 'amount'],
['name' => 'Subsidio', 'style' => 'amount'],
'Estado Subsidio',
['name' => 'Credito', 'style' => 'amount'],
'Banco',
'Estado Credito',
['name' => 'Saldo', 'style' => 'amount'],
['name' => 'Escritura', 'style' => 'amount'],
['name' => 'Entrega', 'style' => 'date']
];
$informe->addColumns($columnas);
//$ventas = $proyecto->escrituras();
$ventas = $proyecto->ventas();
$data = [];
foreach ($ventas as $venta) {
$info = [];
$info['Departamento'] = $venta->unidad()->descripcion;
$ests = [];
foreach ($venta->propiedad()->estacionamientos() as $e) {
$ests []= $e->descripcion;
}
$bods = [];
foreach ($venta->propiedad()->bodegas() as $b) {
$bods []= $b->descripcion;
}
$info['Estacionamientos'] = implode(' - ', $ests);
$info['Bodegas'] = implode(' - ', $bods);
$info['Propietario'] = $venta->propietario()->nombreCompleto();
$info['Promesa'] = $venta->valor_uf;
$saldo = $venta->valor_uf;
$info['Bono Pie'] = '';
if ($venta->bono_pie != 0) {
$info['Bono Pie'] = $venta->bonoPie()->pago()->valor('ufs');
$saldo -= $venta->bonoPie()->pago()->valor('ufs');
}
$info['Pie'] = '';
$info['Reajuste'] = '';
if ($venta->pie != 0) {
$info['Pie'] = $venta->pie()->valorPagado();
$saldo -= $venta->pie()->valorPagado();
if ($venta->pie()->reajuste != 0) {
$info['Reajuste'] = $venta->pie()->reajuste()->valor('ufs');
$saldo -= $venta->pie()->reajuste()->valor('ufs');
}
}
$info['Abono Contado'] = '';
if ($venta->escritura != 0) {
$info['Abono Contado'] = $venta->escritura()->pago()->valor('ufs');
$saldo -= $venta->escritura()->pago()->valor('ufs');
}
$info['Subsidio'] = '';
$info['Estado Subsidio'] = '';
if ($venta->subsidio != 0) {
$info['Subsidio'] = $venta->subsidio()->total('ufs');
$info['Estado Subsidio'] = implode(' - ', [
$venta->subsidio()->subsidio()->estado()->tipo()->descripcion,
$venta->subsidio()->pago()->estado()->tipo()->descripcion
]);
$saldo -= $venta->subsidio()->total('ufs');
}
$info['Credito'] = '';
$info['Banco'] = '';
$info['Estado Credito'] = '';
if ($venta->credito != 0) {
$info['Credito'] = $venta->credito()->pago()->valor('ufs');
$saldo -= $venta->credito()->pago()->valor('ufs');
if ($venta->credito()->pago()->banco != 0) {
$info['Banco'] = $venta->credito()->pago()->banco()->nombre;
}
$info['Estado Credito'] = $venta->credito()->pago()->estado()->tipo()->descripcion;
}
$info['Saldo'] = -$saldo;
$info['Escritura'] = '';
if ($venta->escriturado != 0) {
$info['Escritura'] = $venta->escriturado;
}
$info['Entrega'] = '';
if ($venta->entregado != 0) {
$info['Entrega'] = $venta->entregado;
}
$data []= $info;
}
$informe->addData($data);
return $informe->informe();
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.escrituras', compact('proyectos'));
}
}
public static function consolidacion()
{
$id_proyecto = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id_proyecto);
$ventas = $proyecto->ventas();
set_time_limit(count($ventas));
$f = Carbon::today(config('app.timezone'));
setlocale(LC_TIME, 'es');
$data = [
[$proyecto->descripcion],
[strftime('%d de %B de %Y', $f->timestamp)],
[''],
['']
];
$columns = [
['name' => 'Fecha', 'style' => 'date'],
'Glosa',
['name' => 'Debe', 'style' => 'number'],
['name' => 'Haber', 'style' => 'number'],
['name' => 'Saldo', 'style' => 'number'],
'Comentario'
];
$bold_rows = [];
foreach ($ventas as $venta) {
$data []= ['Departamento ' . $venta->unidad()->descripcion . ' (' . format('ufs', $venta->valor_uf) . ' UF)'];
$data []= $columns;
$bold_rows []= count($data) - 1;
$ufs = 0;
$debe = 0;
$haber = 0;
$sum = 0;
if ($venta->pie != 0) {
$cuotas = $venta->pie()->cuotas();
foreach ($cuotas as $cuota) {
$sum += $cuota->pago()->valor();
$ufs += $cuota->pago()->valor('ufs');
$haber += $cuota->pago()->valor();
$info = [
$cuota->pago()->estado()->fecha,
'Pie - Cuota ' . $cuota->numero() . ' - ' . $venta->pie()->cuotas . ' (' . format('ufs', $cuota->pago()->valor('ufs')) . ' UF)',
'',
$cuota->pago()->valor(),
$sum
];
if ($cuota->pago()->estado()->estado < 2) {
$info []= 'No ha sido abonada.';
}
$data []= $info;
}
if ($venta->pie()->reajuste != 0) {
$sum += $venta->pie()->reajuste()->valor();
$ufs += $venta->pie()->reajuste()->valor('ufs');
$haber += $venta->pie()->reajuste()->valor();
$info = [
$venta->pie()->reajuste()->estado()->fecha,
'Reajuste (' . format('ufs', $venta->pie()->reajuste()->valor('ufs')) . ' UF)',
'',
$venta->pie()->reajuste()->valor(),
$sum
];
if ($venta->pie()->reajuste()->estado()->estado < 2) {
$info []= 'No ha sido abonado.';
}
$data []= $info;
}
}
if ($venta->escritura != 0) {
$sum += $venta->escritura()->pago()->valor();
$ufs += $venta->escritura()->pago()->valor('ufs');
$haber += $venta->escritura()->pago()->valor();
$info = [
$venta->escritura()->pago()->estado()->fecha,
'Abono Escritura (' . format('ufs', $venta->escritura()->pago()->valor('ufs')) . ' UF)',
'',
$venta->escritura()->pago()->valor(),
$sum
];
if ($venta->escritura()->pago()->estado()->estado < 2) {
$info []= 'No ha sido abonado.';
}
$data []= $info;
}
if ($venta->credito != 0) {
$sum += $venta->credito()->pago()->valor();
$ufs += $venta->credito()->pago()->valor('ufs');
$haber += $venta->credito()->pago()->valor();
$info = [
$venta->credito()->pago()->estado()->fecha,
'Crédito (' . format('ufs', $venta->credito()->pago()->valor('ufs')) . ' UF)',
'',
$venta->credito()->pago()->valor(),
$sum
];
if ($venta->credito()->pago()->estado()->estado < 2) {
$info []= 'No ha sido pagado.';
}
$data []= $info;
}
if ($venta->bono_pie != 0) {
try {
$sum -= $venta->bonoPie()->pago()->valor();
$debe += $venta->bonoPie()->pago()->valor();
$info = [
$venta->bonoPie()->pago()->estado()->fecha,
'Bono Pie (' . format('ufs', $venta->bonoPie()->pago()->valor('ufs')) . ' UF)'.
$venta->bonoPie()->pago()->valor(),
'',
$sum
];
$data []= $info;
$sum += $venta->bonoPie()->pago()->valor();
$haber += $venta->bonoPie()->pago()->valor();
$info = [
$venta->bonoPie()->pago()->estado()->fecha,
'Bono Pie (' . format('ufs', $venta->bonoPie()->pago()->valor('ufs')) . ' UF)'.
'',
$venta->bonoPie()->pago()->valor(),
$sum
];
$data []= $info;
} catch (\Exception $e) {
}
}
$info = [
'',
'TOTAL (' . format('ufs', $ufs) . ' UF)',
$debe,
$haber,
$sum
];
$data []= $info;
$bold_rows []= count($data) - 1;
$data []= [''];
}
/**
* Departamento #
* Fecha |Glosa |Debe |Haber |Saldo
* <fecha> |Pie - Cuota 1 - n (# UF) |- |$# |<sum>
* <fecha> |Reajuste (# UF) |- |$# |<sum>
* <fecha> |Abono Escritura (# UF) |- |$# |<sum>
* <fecha> |Crédito (# UF) |- |$# |<sum>
* <fecha> |Bono Pie (# UF) |$# |- |<sum>
* <fecha> |Bono Pie (# UF) |- |$# |<sum>
* <fecha> |Devolución (# UF) |$# |- |<sum>
* - |TOTAL (# UF) |<sumDebe> |<sumHaber> |<sum>
*/
array_walk($data, function(&$e, $i) use ($columns) {
if (count($e) < count($columns)) {
$n = count($columns) - count($e);
for ($j = 0; $j < $n; $j ++) {
$e []= '';
}
}
});
#$informe = new Informador('Consolidación - ' . $proyecto->descripcion);
$name = 'Consolidación';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$informe->addColumns($columns);
$informe->addData($data);
return $informe->informe();
}
public static function creditos_pendientes()
{
function creditos() {
$creditos = model(Credito::class)
->select('credito.*')
->join('venta', ['venta.credito', '=', 'credito.id'])
->join('pago', ['pago.id', '=', 'credito.pago'])
->rawJoin('JOIN (SELECT ep.* FROM (SELECT pago, MAX(id) AS id FROM estado_pago GROUP BY pago) e0 JOIN estado_pago ep ON ep.id = e0.id)', ['estado_pago.pago', '=', 'pago.id'], 'estado_pago')
->whereLt('estado_pago.estado', 2)
->where('venta.estado', 1)
->orderByAsc('estado_pago.fecha')
->findMany();
foreach ($creditos as $credito) {
yield $credito;
}
}
$informe = new Informador('Créditos Pendientes');
$columnas = ['Proyecto', 'Departamento', 'Valor', 'Fecha Escritura', 'Estado'];
$informe->addColumns($columnas);
$row = 0;
foreach (creditos() as $credito) {
$informe->addData($row, $credito->venta()->proyecto()->descripcion, 'Proyecto');
$informe->addData($row, $credito->venta()->unidad()->descripcion, 'Departamento');
$informe->addData($row, $credito->pago()->valor('ufs'), 'Valor');
$informe->addData($row, (($credito->venta()->escriturado) ? $credito->venta()->escriturado : $credito->pago()->estado()->fecha), 'Fecha Escritura');
$informe->addData($row, ucwords($credito->pago()->estado()->tipo()->descripcion), 'Estado');
$row ++;
}
$date = [
'numberFormat' => ['short-date']
];
$ufs = [
'numberFormat' => ['thousands']
];
$formats = ['Valor' => $ufs, 'Fecha Escritura' => $date];
$informe->addFormats($formats);
return $informe->informe();
}
public static function ventas()
{
if (get('proyecto')) {
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$ventas = $proyecto->ventas();
$procasa = model(Agente::class)->findOne(1);
$pa = model(ProyectoAgente::class)->where('agente', $procasa->id)->where('proyecto', $proyecto->id)->findOne();
if ($pa) {
$comision = $pa->comision / 100;
} else {
$comision = 0.03;
}
$name = 'Informe de Ventas';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xlsx');
$columnas = [
'Propietario',
['name' => 'Departamento', 'style' => 'number'],
['name' => 'Estacionamientos', 'style' => 'number'],
['name' => 'Bodegas', 'style' => 'number'],
'Fecha Venta',
['name' => 'Mes', 'style' => 'mes'],
'Tipo',
['name' => 'm² Ponderados', 'style' => 'amount'],
['name' => 'Valor Promesa', 'style' => 'amount'],
['name' => 'Pie', 'style' => 'amount'],
['name' => 'Pie Pagado', 'style' => 'amount'],
['name' => '% Pie Pagado', 'style' => 'percent'],
['name' => 'Bono Pie', 'style' => 'amount'],
'Operador',
['name' => 'Valor Operador', 'style' => 'amount'],
['name' => 'Premios', 'style' => 'amount'],
['name' => 'Subsidio', 'style' => 'amount'],
['name' => 'Ahorro', 'style' => 'amount'],
['name' => 'Credito', 'style' => 'amount'],
'Banco',
['name' => 'Valor Ests & Bods', 'style' => 'amount'],
['name' => 'Valor Neto', 'style' => 'amount'],
['name' => 'UF/m²*', 'style' => 'amount'],
['name' => 'Comision', 'style' => 'amount'],
['name' => 'Venta s/Comision', 'style' => 'amount']
];
$data = [];
foreach ($ventas as $venta) {
$info = [];
$info['Propietario'] = mb_strtoupper($venta->propietario()->nombreCompleto());
$info['Departamento'] = trim(array_reduce($venta->propiedad()->departamentos(), function($carry, $item) {
return implode(' - ', [$carry, $item->descripcion]);
}), ' -');
$es = $venta->propiedad()->estacionamientos();
$info['Estacionamientos'] = implode(', ', array_map(function($item) {
return $item->descripcion;
}, $es));
$bs = $venta->propiedad()->bodegas();
$info['Bodegas'] = implode(', ', array_map(function($item) {
return $item->descripcion;
}, $bs));
$info['Fecha Venta'] = $venta->fecha()->format('Y-m-d');
$info['Mes'] = $venta->fecha()->format('M-y');
$info['Tipo'] = $venta->unidad()->abreviacion;
$info['m² Ponderados'] = $venta->unidad()->m2('vendible');
$info['Valor Promesa'] = $venta->valor_uf;
$info['Pie'] = $venta->pie()->valor;
$info['Pie Pagado'] = 0;
$info['% Pie Pagado'] = 0;
if ($venta->pie()) {
$info['Pie Pagado'] = $venta->pie()->valorPagado('uf');
$info['% Pie Pagado'] = $venta->pie()->valorPagado('uf') / $venta->valor_uf;
}
$info['Bono Pie'] = ($venta->bono_pie == 0 or $venta->bonoPie() === false) ? '' : $venta->bonoPie()->pago()->valor('ufs');
$info['Operador'] = ($venta->agente and $venta->agente()->agente()->tipo == 19) ? $venta->agente()->agente()->descripcion : '';
$info['Valor Operador'] = $venta->valorComision();
$ps = $venta->promociones();
$info['Premios'] = array_reduce($ps, function($sum, $item) {
return $sum + $item->valor;
});
$info['Subsidio'] = 0;
$info['Ahorro'] = 0;
if ($venta->subsidio != 0) {
$info['Subsidio'] = $venta->subsidio()->subsidio()->valor('ufs');
$info['Ahorro'] = $venta->subsidio()->pago()->valor('ufs');
}
$info['Credito'] = 0;
$info['Banco'] = '';
if ($venta->credito != 0) {
$info['Credito'] = $venta->credito()->pago()->valor('ufs');
if ($venta->credito()->pago()->banco != 0) {
$info['Banco'] = $venta->credito()->pago()->banco()->nombre;
}
}
$info['Valor Ests & Bods'] = $venta->valorEstacionamientosYBodegas();
$info['Valor Neto'] = $venta->valorFinal();
$info['UF/m²*'] = $venta->uf_m2();
$info['Comision'] = $venta->valorFinal() * $comision;
$info['Venta s/Comision'] = $venta->valorFinal() - $info['Comision'];
$data []= $info;
}
$body = [
"Proyecto" => $proyecto->descripcion,
"Compañía" => $proyecto->inmobiliaria()->abreviacion,
"data" => $data
];
$client = new Client(['base_uri' => 'localhost:8011']);
$response = $client->post('/ventas', ['json' => $body]);
header("Content-Type: application/octet-stream; charset=utf-8");
header('Content-Transfer-Encoding: binary');
header('Content-Disposition: attachment; filename="' . $filename . '"');
header('Cache-Control: max-age=0');
return $response->getBody();
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.ventas', compact('proyectos'));
}
}
public static function resumen_contabilidad()
{
if (get('proyecto')) {
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$ventas = $proyecto->ventas();
usort($ventas, function($a, $b) {
return $a->fecha()->timestamp - $b->fecha()->timestamp;
});
$name = 'Ventas';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = [
'Propietario',
['name' => 'Departamento', 'style' => 'general_number'],
['name' => 'Estacionamientos', 'style' => 'number'],
['name' => 'Bodegas', 'style' => 'number'],
'Fecha Venta',
['name' => 'Mes', 'style' => 'mes'],
'Tipo',
['name' => 'm² Ponderados', 'style' => 'amount'],
['name' => 'Valor Promesa', 'style' => 'amount'],
['name' => 'Pie [UF]', 'style' => 'amount'],
['name' => 'Pie [$]', 'style' => 'amount'],
['name' => 'Abono Escritura', 'style' => 'amount'],
['name' => 'Crédito', 'style' => 'amount'],
['name' => 'Cuotas', 'style' => 'number'],
['name' => 'Cuotas Pagadas', 'style' => 'number'],
['name' => 'Pie Pagado [UF]', 'style' => 'amount'],
['name' => 'Pie Pagado [$]', 'style' => 'amount']
];
$informe->addColumns($columnas);
$data = [];
foreach ($ventas as $venta) {
$info = [];
$info['Propietario'] = mb_strtoupper($venta->propietario()->nombreCompleto());
$info['Departamento'] = $venta->unidad()->descripcion;
$ests = [];
if ($venta->propiedad()->estacionamientos != '') {
$es = $venta->propiedad()->estacionamientos();
foreach ($es as $e) {
$ests []= $e->descripcion;
}
}
$info['Estacionamientos'] = implode(', ', $ests);
$bods = [];
if ($venta->propiedad()->bodegas != '') {
$bs = $venta->propiedad()->bodegas();
foreach ($bs as $b) {
$bods []= $b->descripcion;
}
}
$info['Bodegas'] = implode(', ', $bods);
$info['Fecha Venta'] = $venta->fecha()->format('d.m.Y');
$info['Mes'] = $venta->fecha()->format('M-y');
$info['Tipo'] = $venta->unidad()->abreviacion;
$info['m² Ponderados'] = $venta->unidad()->m2('vendible');
$info['Valor Promesa'] = $venta->valor_uf;
$info['Pie [UF]'] = 0;
$info['Pie [$]'] = 0;
$info['Abono Escritura'] = 0;
$info['Crédito'] = 0;
$info['Cuotas'] = 0;
$info['Cuotas Pagadas'] = 0;
$info['Pie Pagado [UF]'] = 0;
$info['Pie Pagado [$]'] = 0;
if ($venta->pie()) {
$info['Pie [UF]'] = $venta->pie()->valor;
$info['Pie [$]'] = $venta->pie()->valorPesos();
$info['Abono Escritura'] = ($venta->escritura != 0) ? $venta->escritura()->valor('ufs') : ($venta->valor_uf - $venta->pie()->valor - (($venta->credito != 0) ? $venta->credito()->pago()->valor('ufs') : 0));
$info['Crédito'] = ($venta->credito != 0) ? $venta->credito()->pago()->valor('ufs') : 0;
$info['Cuotas'] = $venta->pie()->cuotas;
$info['Cuotas Pagadas'] = count($venta->pie()->pagadas());
$info['Pie Pagado [UF]'] = $venta->pie()->valorPagado('uf');
$info['Pie Pagado [$]'] = $venta->pie()->valorPagado('pesos');
}
$data []= $info;
}
//$informe->addData($data);
/*$totals = [
'Departamento' => 'count',
'Estacionamientos' => 'count',
'Bodegas' => 'count',
'm² Ponderados' => 'sum',
'Valor Promesa' => 'sum',
'Pie' => 'sum',
'Pie Pagado' => 'sum'
];*/
//$informe->addTotals($totals);
//return $informe->informe();
$body = [
"Proyecto" => $proyecto->descripcion,
"Compañía" => $proyecto->inmobiliaria()->abreviacion,
"Mes" => $mes,
"data" => $data
];
$client = new Client(['base_uri' => 'localhost:8011']);
$response = $client->post('/ventas', ['json' => $body]);
header("Content-Type: application/octet-stream; charset=utf-8");
header('Content-Transfer-Encoding: binary');
header('Content-Disposition: attachment; filename="' . $filename . '"');
header('Cache-Control: max-age=0');
return $response->getBody();
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.resumen_contabilidad', compact('proyectos'));
}
}
public static function contabilidad()
{
if (get('proyecto')) {
$id = get('proyecto');
$fecha = get('fecha');
$mes = null;
if ($fecha != null) {
$mes = Carbon::parse($fecha);
}
$proyecto = model(Proyecto::class)->findOne($id);
$q = "SELECT pago.*, venta.id AS vid, venta.tipo AS ctipo, venta.pie AS pie
FROM (
SELECT pago.id, banco.nombre AS banco, pago.fecha, pago.valor, pago.uf, ep.estado, ep.fecha AS efecha
FROM pago JOIN banco ON banco.id = pago.banco JOIN ((
SELECT pago, MAX(id) AS id FROM estado_pago GROUP BY pago) e0 JOIN estado_pago ep ON ep.id = e0.id) ON ep.pago = pago.id
WHERE ep.estado > 0 ";
if ($mes != null) {
$q .= "AND (pago.fecha BETWEEN '" . $mes->format('Y-m-01') . "' AND '" . $mes->format('Y-m-t') . "'
OR ep.fecha BETWEEN '" . $mes->format('Y-m-01') . "' AND '" . $mes->format('Y-m-t') . "')";
}
$q .= ") pago JOIN (SELECT venta.*
FROM ((
SELECT venta.id, venta.pie, venta.propiedad, credito.pago, 'credito' AS tipo
FROM venta JOIN credito ON credito.id = venta.credito)
UNION ALL (
SELECT venta.id, venta.pie, venta.propiedad, escritura.pago, 'escritura' AS tipo
FROM venta JOIN escritura ON escritura.id = venta.escritura)
UNION ALL (
SELECT venta.id, venta.pie, venta.propiedad, cuota.pago, 'cuota' AS tipo
FROM venta JOIN cuota ON cuota.pie = venta.pie)) venta
JOIN propiedad ON propiedad.id = venta.propiedad
JOIN unidad ON unidad.id = propiedad.unidad_principal
WHERE unidad.proyecto = ?) venta
ON venta.pago = pago.id";
$st = \ORM::getDB()->prepare($q);
$st->execute([$id]);
if ($st->rowCount() > 0) {
$R = $st->fetchAll(\PDO::FETCH_OBJ);
//$informe = new Informador('Contabilidad - ' . (($mes != null) ? $mes->format('Y-m') . ' - ' : '') . $proyecto->descripcion);
$name = 'Contabilidad';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', 'Contabilidad - ' . (($mes != null) ? $mes->format('Y-m') . ' - ' : '') . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = ['Proyecto', 'Fecha', 'Banco', 'Departamento', 'RUT', 'Propietario', 'Glosa', 'Glosa2', (object) ['name' => 'Valor', 'style' => 'integer'], (object) ['name' => 'Valor UF', 'style' => 'currency']];
$informe->addColumns($columnas);
$data = [];
foreach ($R as $r) {
$info = [];
$info['Proyecto'] = $proyecto->descripcion;
$f1 = \Carbon\Carbon::parse($r->fecha, config('app.timezone'));
$f2 = \Carbon\Carbon::parse($r->efecha, config('app.timezone'));
$info['Fecha'] = ($f1->max($f2))->format('Y-m-d');
$info['Banco'] = $r->banco;
$venta = model(Venta::class)->findOne($r->vid);
$info['Departamento'] = $venta->unidad()->descripcion;
$info['RUT'] = $venta->propietario()->rut();
$info['Propietario'] = $venta->propietario()->nombreCompleto();
$info['Glosa'] = ucwords($r->ctipo);
$info['Glosa2'] = '';
if ($r->ctipo == 'cuota') {
$cuota = model(Cuota::class)->where('pago', $r->id)->findOne();
$info['Glosa'] = 'Pie - ' . format('ufs', $cuota->pie()->valor('ufs'), null, true);
$info['Glosa2'] = $cuota->numero() . ' - ' . $cuota->pie()->cuotas;
}
$info['Valor'] = $r->valor;
$info['Valor UF'] = '0';
if ($r->uf > 0) {
$info['Valor UF'] = $r->valor / $r->uf;
}
$data []= $info;
}
$informe->addData($data);
return $informe->informe();
}
} else {
setlocale(LC_TIME, 'es_ES');
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.contabilidad', compact('proyectos'));
}
}
public static function para_comision()
{
$proyectos = model(Proyecto::class)->orderByAsc('descripcion')->findMany();
return view('informes.para_comision', compact('proyectos'));
}
public static function comisiones()
{
$id = post('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$unidades = explode('-', str_replace([';', '.', ':', ' ', PHP_EOL, '|', '+', ','], '-', post('unidades')));
$ventas = model(Venta::class)
->select('venta.*')
->join('propiedad', ['propiedad.id', '=', 'venta.propiedad'])
->join('unidad', ['unidad.id', '=', 'propiedad.unidad_principal'])
->where('unidad.proyecto', $proyecto->id)
->where('venta.estado', 1)
->whereIn('unidad.descripcion', $unidades)
->orderByExpr('FIELD(unidad.descripcion, ' . implode(', ', $unidades) . ')')
->findMany();
$ids = [];
$totales = (object) ['precio' => 0, 'neto' => 0, 'comision' => 0];
foreach ($ventas as $venta) {
$ids []= $venta->id;
$totales->precio += $venta->valor_uf;
$totales->neto += $venta->valorCorredora();
$totales->comision += $venta->valorCorredora() * 1.5 / 100;
}
return view('informes.comisiones', compact('ventas', 'proyecto', 'totales', 'ids'));
}
public static function comisiones_xlsx()
{
$id_ventas = explode(',', get('ventas'));
$ventas = model(Venta::class)
->whereIn('id', $id_ventas)
->orderByExpr('FIELD(id, ' . implode(', ', $id_ventas) . ')')
->findMany();
$informe = new Informador('Comisiones - ' . $ventas[0]->proyecto()->descripcion);
$columnas = ['Departamento', 'Estacionamientos', 'Bodegas', 'Propietario', 'Precio', '% Com', 'Com UF'];
$informe->addColumns($columnas);
$data = [];
foreach ($ventas as $venta) {
$info = [];
$info['Departamento'] = $venta->unidad()->descripcion;
$info['Estacionamientos'] = implode(' - ', $venta->propiedad()->estacionamientos('array'));
$info['Bodegas'] = implode(' - ', $venta->propiedad()->bodegas('array'));
$info['Propietario'] = $venta->propietario()->nombreCompleto();
$info['Precio'] = "'" . format('ufs', $venta->valorCorredora());
$info['% Com'] = '1,5 %';
$info['Com UF'] = "'" . format('ufs', $venta->valorCorredora() * 1.5 / 100);
$data []= $info;
}
$informe->addDatas($data);
return $informe->informe();
}
public static function cuotas()
{
$id_venta = get('venta');
$venta = model(Venta::class)->findOne($id_venta);
$name = 'Cuotas - ' . $venta->unidad()->descripcion;
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $venta->proyecto()->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = [
['name' => 'Cuota', 'style' => 'number'],
['name' => 'Fecha Cuota', 'style' => 'date'],
'Banco',
'Identificador',
['name' => 'Valor $', 'style' => 'number'],
['name' => 'Valor UF', 'style' => 'currency'],
['name' => 'Fecha Pago', 'style' => 'date']
];
$informe->addColumns($columnas);
$data = [];
foreach ($venta->pie()->cuotas() as $cuota) {
$info = [];
$info['Cuota'] = $cuota->numero();
$info['Fecha Cuota'] = $cuota->pago()->fecha()->format('Y-m-d');
$info['Banco'] = $cuota->pago()->banco()->descripcion;
$info['Identificador'] = $cuota->pago()->identificador;
$info['Valor $'] = $cuota->pago()->valor();
$info['Valor UF'] = $cuota->pago()->valor('ufs');
$info['Fecha Pago'] = $cuota->pago()->estado()->fecha()->format('Y-m-d');
$data []= $info;
}
$informe->addData($data);
return $informe->informe();
}
public static function resciliaciones()
{
if (get('proyecto')) {
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$ventas = $proyecto->resciliaciones();
usort($ventas, function($a, $b) {
return $a->fecha()->timestamp - $b->fecha()->timestamp;
});
$name = 'Resciliaciones';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = [
'Propietario',
['name' => 'Departamento', 'style' => 'number'],
['name' => 'Estacionamientos', 'style' => 'number'],
['name' => 'Bodegas', 'style' => 'number'],
'Fecha Venta',
'Fecha Resciliación',
['name' => 'Mes', 'style' => 'mes'],
'Tipo',
['name' => 'm² Ponderados', 'style' => 'amount'],
['name' => 'Valor Promesa', 'style' => 'amount'],
];
$informe->addColumns($columnas);
$data = [];
foreach ($ventas as $venta) {
$info = [];
$info['Propietario'] = mb_strtoupper($venta->propietario()->nombreCompleto());
$info['Departamento'] = $venta->unidad()->descripcion;
$ests = [];
if ($venta->propiedad()->estacionamientos != '') {
$es = $venta->propiedad()->estacionamientos();
foreach ($es as $e) {
$ests []= $e->descripcion;
}
}
$info['Estacionamientos'] = implode(', ', $ests);
$bods = [];
if ($venta->propiedad()->bodegas != '') {
$bs = $venta->propiedad()->bodegas();
foreach ($bs as $b) {
$bods []= $b->descripcion;
}
}
$info['Bodegas'] = implode(', ', $bods);
$info['Fecha Venta'] = $venta->fecha()->format('d.m.Y');
$info['Fecha Resciliación'] = $venta->estado()->fecha()->format('d.m.Y');
$info['Mes'] = $venta->estado()->fecha()->format('M-y');
$info['Tipo'] = $venta->unidad()->abreviacion;
$info['m² Ponderados'] = $venta->unidad()->m2('vendible');
$info['Valor Promesa'] = $venta->valor_uf;
$data []= $info;
}
$informe->addData($data);
$totals = [
'Departamento' => 'count',
'Estacionamientos' => 'count',
'Bodegas' => 'count',
'm² Ponderados' => 'sum',
'Valor Promesa' => 'sum'
];
$informe->addTotals($totals);
return $informe->informe();
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.resciliaciones', compact('proyectos'));
}
}
}

View File

@ -0,0 +1,901 @@
<?php
namespace App\Controller;
use Carbon\Carbon;
use App\Definition\Controller;
use App\Alias\PHPExcel;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Proyecto\Agente;
use Incoviba\old\Proyecto\ProyectoAgente;
use Incoviba\old\Venta\Venta;
use Incoviba\old\Venta\Pie;
use Incoviba\old\Venta\Credito;
use Incoviba\old\Venta\Cuota;
class Informes
{
use Controller;
protected static function setDefault()
{
self::$default = view('informes.list');
}
public static function gantt_entregas()
{
if (get('proyecto')) {
$id_proyecto = get('proyecto');
$proyecto = model(Proyecto::class)->find_one($id_proyecto);
$ini = \Carbon\Carbon::parse($proyecto->estado()->fecha, config('app.timezone'));
#$informe = new Informador('Carta Gantt Proyecto - ' . $proyecto->descripcion);
$name = 'Carta Gantt Proyecto - ' . $proyecto->descripcion;
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = ['Departamento', 'Propietario', 'Entrega', 'Estado'];
$today = \Carbon\Carbon::today(config('app.timezone'));
$end = $today->copy()->addDays(30);
$dif = $end->diffInDays($ini);
for ($i = 0; $i <= $dif; $i ++) {
$f = $ini->copy()->addDays($i);
if ($f->isWeekend()) {
continue;
}
$columnas []= $f->format('Y-m-d');
}
$informe->addColumns($columnas);
$data = [];
foreach ($proyecto->entregas() as $venta) {
$info = [];
$info []= $venta->unidad()->descripcion;
$info []= $venta->propietario()->findOne()->nombreCompleto();
$fe = Carbon::parse($venta->entrega()->find_one()->fecha, config('app.timezone'));
$info []= $fe->format('Y-m-d');
$info []= '';
for ($i = 0; $i <= $dif; $i ++) {
$f = $ini->copy()->addDays($i);
if ($f->isWeekend()) {
continue;
}
if ($f >= $fe and $f <= $fe->copy()->addDays(14)) {
$info []= 'X';
} else {
$info []= '';
}
}
$data []= $info;
}
$informe->addDatas($data);
return $informe->informe();
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.gantt_entregas', compact('proyectos'));
}
}
public static function escrituras()
{
if (get('proyecto')) {
set_time_limit(60);
$id_proyecto = get('proyecto');
$proyecto = model(Proyecto::class)->find_one($id_proyecto);
#$informe = new Informador('Escrituras - ' . $proyecto->descripcion);
$name = 'Escrituras';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = [
'Departamento',
'Estacionamientos',
'Bodegas',
'Propietario',
(object) ['name' => 'Promesa', 'style' => 'number'],
['name' => 'Bono Pie', 'style' => 'amount'],
['name' => 'Pie Pagado', 'style' => 'amount'],
['name' => 'Reajuste', 'style' => 'amount'],
['name' => 'Abono Contado', 'style' => 'amount'],
['name' => 'Subsidio', 'style' => 'amount'],
'Estado Subsidio',
['name' => 'Credito', 'style' => 'amount'],
'Banco',
'Estado Credito',
['name' => 'Saldo', 'style' => 'amount'],
['name' => 'Escritura', 'style' => 'amount'],
['name' => 'Entrega', 'style' => 'date']
];
$informe->addColumns($columnas);
//$ventas = $proyecto->escrituras();
$ventas = $proyecto->ventas();
$data = [];
foreach ($ventas as $venta) {
$info = [];
$info['Departamento'] = $venta->unidad()->descripcion;
$ests = [];
foreach ($venta->propiedad()->estacionamientos() as $e) {
$ests []= $e->descripcion;
}
$bods = [];
foreach ($venta->propiedad()->bodegas() as $b) {
$bods []= $b->descripcion;
}
$info['Estacionamientos'] = implode(' - ', $ests);
$info['Bodegas'] = implode(' - ', $bods);
$info['Propietario'] = $venta->propietario()->nombreCompleto();
$info['Promesa'] = $venta->valor_uf;
$saldo = $venta->valor_uf;
$info['Bono Pie'] = '';
if ($venta->bono_pie != 0) {
$info['Bono Pie'] = $venta->bonoPie()->pago()->valor('ufs');
$saldo -= $venta->bonoPie()->pago()->valor('ufs');
}
$info['Pie'] = '';
$info['Reajuste'] = '';
if ($venta->pie != 0) {
$info['Pie'] = $venta->pie()->valorPagado();
$saldo -= $venta->pie()->valorPagado();
if ($venta->pie()->reajuste != 0) {
$info['Reajuste'] = $venta->pie()->reajuste()->valor('ufs');
$saldo -= $venta->pie()->reajuste()->valor('ufs');
}
}
$info['Abono Contado'] = '';
if ($venta->escritura != 0) {
$info['Abono Contado'] = $venta->escritura()->pago()->valor('ufs');
$saldo -= $venta->escritura()->pago()->valor('ufs');
}
$info['Subsidio'] = '';
$info['Estado Subsidio'] = '';
if ($venta->subsidio != 0) {
$info['Subsidio'] = $venta->subsidio()->total('ufs');
$info['Estado Subsidio'] = implode(' - ', [
$venta->subsidio()->subsidio()->estado()->tipo()->descripcion,
$venta->subsidio()->pago()->estado()->tipo()->descripcion
]);
$saldo -= $venta->subsidio()->total('ufs');
}
$info['Credito'] = '';
$info['Banco'] = '';
$info['Estado Credito'] = '';
if ($venta->credito != 0) {
$info['Credito'] = $venta->credito()->pago()->valor('ufs');
$saldo -= $venta->credito()->pago()->valor('ufs');
if ($venta->credito()->pago()->banco != 0) {
$info['Banco'] = $venta->credito()->pago()->banco()->nombre;
}
$info['Estado Credito'] = $venta->credito()->pago()->estado()->tipo()->descripcion;
}
$info['Saldo'] = -$saldo;
$info['Escritura'] = '';
if ($venta->escriturado != 0) {
$info['Escritura'] = $venta->escriturado;
}
$info['Entrega'] = '';
if ($venta->entregado != 0) {
$info['Entrega'] = $venta->entregado;
}
$data []= $info;
}
$informe->addData($data);
return $informe->informe();
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.escrituras', compact('proyectos'));
}
}
public static function consolidacion()
{
$id_proyecto = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id_proyecto);
$ventas = $proyecto->ventas();
set_time_limit(count($ventas));
$f = Carbon::today(config('app.timezone'));
setlocale(LC_TIME, 'es');
$data = [
[$proyecto->descripcion],
[strftime('%d de %B de %Y', $f->timestamp)],
[''],
['']
];
$columns = [
['name' => 'Fecha', 'style' => 'date'],
'Glosa',
['name' => 'Debe', 'style' => 'number'],
['name' => 'Haber', 'style' => 'number'],
['name' => 'Saldo', 'style' => 'number'],
'Comentario'
];
$bold_rows = [];
foreach ($ventas as $venta) {
$data []= ['Departamento ' . $venta->unidad()->descripcion . ' (' . format('ufs', $venta->valor_uf) . ' UF)'];
$data []= $columns;
$bold_rows []= count($data) - 1;
$ufs = 0;
$debe = 0;
$haber = 0;
$sum = 0;
if ($venta->pie != 0) {
$cuotas = $venta->pie()->cuotas();
foreach ($cuotas as $cuota) {
$sum += $cuota->pago()->valor();
$ufs += $cuota->pago()->valor('ufs');
$haber += $cuota->pago()->valor();
$info = [
$cuota->pago()->estado()->fecha,
'Pie - Cuota ' . $cuota->numero() . ' - ' . $venta->pie()->cuotas . ' (' . format('ufs', $cuota->pago()->valor('ufs')) . ' UF)',
'',
$cuota->pago()->valor(),
$sum
];
if ($cuota->pago()->estado()->estado < 2) {
$info []= 'No ha sido abonada.';
}
$data []= $info;
}
if ($venta->pie()->reajuste != 0) {
$sum += $venta->pie()->reajuste()->valor();
$ufs += $venta->pie()->reajuste()->valor('ufs');
$haber += $venta->pie()->reajuste()->valor();
$info = [
$venta->pie()->reajuste()->estado()->fecha,
'Reajuste (' . format('ufs', $venta->pie()->reajuste()->valor('ufs')) . ' UF)',
'',
$venta->pie()->reajuste()->valor(),
$sum
];
if ($venta->pie()->reajuste()->estado()->estado < 2) {
$info []= 'No ha sido abonado.';
}
$data []= $info;
}
}
if ($venta->escritura != 0) {
$sum += $venta->escritura()->pago()->valor();
$ufs += $venta->escritura()->pago()->valor('ufs');
$haber += $venta->escritura()->pago()->valor();
$info = [
$venta->escritura()->pago()->estado()->fecha,
'Abono Escritura (' . format('ufs', $venta->escritura()->pago()->valor('ufs')) . ' UF)',
'',
$venta->escritura()->pago()->valor(),
$sum
];
if ($venta->escritura()->pago()->estado()->estado < 2) {
$info []= 'No ha sido abonado.';
}
$data []= $info;
}
if ($venta->credito != 0) {
$sum += $venta->credito()->pago()->valor();
$ufs += $venta->credito()->pago()->valor('ufs');
$haber += $venta->credito()->pago()->valor();
$info = [
$venta->credito()->pago()->estado()->fecha,
'Crédito (' . format('ufs', $venta->credito()->pago()->valor('ufs')) . ' UF)',
'',
$venta->credito()->pago()->valor(),
$sum
];
if ($venta->credito()->pago()->estado()->estado < 2) {
$info []= 'No ha sido pagado.';
}
$data []= $info;
}
if ($venta->bono_pie != 0) {
try {
$sum -= $venta->bonoPie()->pago()->valor();
$debe += $venta->bonoPie()->pago()->valor();
$info = [
$venta->bonoPie()->pago()->estado()->fecha,
'Bono Pie (' . format('ufs', $venta->bonoPie()->pago()->valor('ufs')) . ' UF)'.
$venta->bonoPie()->pago()->valor(),
'',
$sum
];
$data []= $info;
$sum += $venta->bonoPie()->pago()->valor();
$haber += $venta->bonoPie()->pago()->valor();
$info = [
$venta->bonoPie()->pago()->estado()->fecha,
'Bono Pie (' . format('ufs', $venta->bonoPie()->pago()->valor('ufs')) . ' UF)'.
'',
$venta->bonoPie()->pago()->valor(),
$sum
];
$data []= $info;
} catch (\Exception $e) {
}
}
$info = [
'',
'TOTAL (' . format('ufs', $ufs) . ' UF)',
$debe,
$haber,
$sum
];
$data []= $info;
$bold_rows []= count($data) - 1;
$data []= [''];
}
/**
* Departamento #
* Fecha |Glosa |Debe |Haber |Saldo
* <fecha> |Pie - Cuota 1 - n (# UF) |- |$# |<sum>
* <fecha> |Reajuste (# UF) |- |$# |<sum>
* <fecha> |Abono Escritura (# UF) |- |$# |<sum>
* <fecha> |Crédito (# UF) |- |$# |<sum>
* <fecha> |Bono Pie (# UF) |$# |- |<sum>
* <fecha> |Bono Pie (# UF) |- |$# |<sum>
* <fecha> |Devolución (# UF) |$# |- |<sum>
* - |TOTAL (# UF) |<sumDebe> |<sumHaber> |<sum>
*/
array_walk($data, function(&$e, $i) use ($columns) {
if (count($e) < count($columns)) {
$n = count($columns) - count($e);
for ($j = 0; $j < $n; $j ++) {
$e []= '';
}
}
});
#$informe = new Informador('Consolidación - ' . $proyecto->descripcion);
$name = 'Consolidación';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$informe->addColumns($columns);
$informe->addData($data);
return $informe->informe();
}
public static function creditos_pendientes()
{
function creditos() {
$creditos = model(Credito::class)
->select('credito.*')
->join('venta', ['venta.credito', '=', 'credito.id'])
->join('pago', ['pago.id', '=', 'credito.pago'])
->rawJoin('JOIN (SELECT ep.* FROM (SELECT pago, MAX(id) AS id FROM estado_pago GROUP BY pago) e0 JOIN estado_pago ep ON ep.id = e0.id)', ['estado_pago.pago', '=', 'pago.id'], 'estado_pago')
->whereLt('estado_pago.estado', 2)
->where('venta.estado', 1)
->orderByAsc('estado_pago.fecha')
->findMany();
foreach ($creditos as $credito) {
yield $credito;
}
}
$informe = new Informador('Créditos Pendientes');
$columnas = ['Proyecto', 'Departamento', 'Valor', 'Fecha Escritura', 'Estado'];
$informe->addColumns($columnas);
$row = 0;
foreach (creditos() as $credito) {
$informe->addData($row, $credito->venta()->proyecto()->descripcion, 'Proyecto');
$informe->addData($row, $credito->venta()->unidad()->descripcion, 'Departamento');
$informe->addData($row, $credito->pago()->valor('ufs'), 'Valor');
$informe->addData($row, (($credito->venta()->escriturado) ? $credito->venta()->escriturado : $credito->pago()->estado()->fecha), 'Fecha Escritura');
$informe->addData($row, ucwords($credito->pago()->estado()->tipo()->descripcion), 'Estado');
$row ++;
}
$date = [
'numberFormat' => ['short-date']
];
$ufs = [
'numberFormat' => ['thousands']
];
$formats = ['Valor' => $ufs, 'Fecha Escritura' => $date];
$informe->addFormats($formats);
return $informe->informe();
}
public static function ventas()
{
if (get('proyecto')) {
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$ventas = $proyecto->ventas();
usort($ventas, function($a, $b) {
return $a->fecha()->timestamp - $b->fecha()->timestamp;
});
$procasa = model(Agente::class)->findOne(1);
$pa = model(ProyectoAgente::class)->where('agente', $procasa->id)->where('proyecto', $proyecto->id)->findOne();
if ($pa) {
$comision = $pa->comision / 100;
} else {
$comision = 0.03;
}
#$informe = new Informador('Ventas - ' . $proyecto->descripcion);
$name = 'Ventas';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = [
'Propietario',
['name' => 'Departamento', 'style' => 'number'],
['name' => 'Estacionamientos', 'style' => 'number'],
['name' => 'Bodegas', 'style' => 'number'],
'Fecha Venta',
['name' => 'Mes', 'style' => 'mes'],
'Tipo',
['name' => 'm² Ponderados', 'style' => 'amount'],
['name' => 'Valor Promesa', 'style' => 'amount'],
['name' => 'Bono Pie', 'style' => 'amount'],
'Operador',
['name' => 'Valor Operador', 'style' => 'amount'],
['name' => 'Premios', 'style' => 'amount'],
['name' => 'Subsidio', 'style' => 'amount'],
['name' => 'Ahorro', 'style' => 'amount'],
['name' => 'Credito', 'style' => 'amount'],
'Banco',
['name' => 'Valor Ests & Bods', 'style' => 'amount'],
['name' => 'Valor Neto', 'style' => 'amount'],
['name' => 'UF/m²*', 'style' => 'amount'],
['name' => 'Comision', 'style' => 'amount'],
['name' => 'Venta s/Comision', 'style' => 'amount']
];
$informe->addColumns($columnas);
$data = [];
foreach ($ventas as $venta) {
$info = [];
$info['Propietario'] = mb_strtoupper($venta->propietario()->nombreCompleto());
$info['Departamento'] = $venta->unidad()->descripcion;
$ests = [];
if ($venta->propiedad()->estacionamientos != '') {
$es = $venta->propiedad()->estacionamientos();
foreach ($es as $e) {
$ests []= $e->descripcion;
}
}
$info['Estacionamientos'] = implode(', ', $ests);
$bods = [];
if ($venta->propiedad()->bodegas != '') {
$bs = $venta->propiedad()->bodegas();
foreach ($bs as $b) {
$bods []= $b->descripcion;
}
}
$info['Bodegas'] = implode(', ', $bods);
$info['Fecha Venta'] = $venta->fecha()->format('d.m.Y');
$info['Mes'] = $venta->fecha()->format('M-y');
$info['Tipo'] = $venta->unidad()->abreviacion;
$info['m² Ponderados'] = $venta->unidad()->m2('vendible');
$info['Valor Promesa'] = $venta->valor_uf;
$info['Bono Pie'] = ($venta->bono_pie == 0 or $venta->bonoPie() === false) ? '' : $venta->bonoPie()->pago()->valor('ufs');
$info['Operador'] = ($venta->agente and $venta->agente()->agente()->tipo == 19) ? $venta->agente()->agente()->descripcion : '';
$info['Valor Operador'] = $venta->valorComision();
$promos = 0;
$ps = $venta->promociones();
if (count($ps) > 0) {
foreach ($ps as $promo) {
$promos += $promo->valor;
}
}
$info['Premios'] = $promos;
$info['Subsidio'] = 0;
$info['Ahorro'] = 0;
if ($venta->subsidio != 0) {
$info['Subsidio'] = $venta->subsidio()->subsidio()->valor('ufs');
$info['Ahorro'] = $venta->subsidio()->pago()->valor('ufs');
}
$info['Credito'] = 0;
$info['Banco'] = '';
if ($venta->credito != 0) {
$info['Credito'] = $venta->credito()->pago()->valor('ufs');
if ($venta->credito()->pago()->banco != 0) {
$info['Banco'] = $venta->credito()->pago()->banco()->nombre;
}
}
$info['Valor Ests & Bods'] = $venta->valorEstacionamientosYBodegas();
$info['Valor Neto'] = $venta->valorFinal();
$info['UF/m²*'] = $venta->uf_m2();
$info['Comision'] = $venta->valorFinal() * $comision;
$info['Venta s/Comision'] = $venta->valorFinal() - $info['Comision'];
$data []= $info;
}
$informe->addData($data);
$totals = [
'Propietario' => 'TOTAL',
'Departamento' => 'count',
'Estacionamientos' => 'count',
'Bodegas' => 'count',
'm² Ponderados' => 'sum',
'Valor Promesa' => 'sum',
'Bono Pie' => 'sum',
'Subsidio' => 'sum',
'Ahorro' => 'sum',
'Credito' => 'sum',
'Valor Operador' => 'sum',
'Premios' => 'sum',
'Valor Ests & Bods' => 'sum',
'Valor Neto' => 'sum',
'Comision' => 'sum'
];
$informe->addTotals($totals);
return $informe->informe();
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.ventas', compact('proyectos'));
}
}
public static function resumen_contabilidad()
{
if (get('proyecto')) {
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$ventas = $proyecto->ventas();
usort($ventas, function($a, $b) {
return $a->fecha()->timestamp - $b->fecha()->timestamp;
});
$name = 'Ventas';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = [
'Propietario',
['name' => 'Departamento', 'style' => 'general_number'],
['name' => 'Estacionamientos', 'style' => 'number'],
['name' => 'Bodegas', 'style' => 'number'],
'Fecha Venta',
['name' => 'Mes', 'style' => 'mes'],
'Tipo',
['name' => 'm² Ponderados', 'style' => 'amount'],
['name' => 'Valor Promesa', 'style' => 'amount'],
['name' => 'Pie [UF]', 'style' => 'amount'],
['name' => 'Pie [$]', 'style' => 'amount'],
['name' => 'Abono Escritura', 'style' => 'amount'],
['name' => 'Crédito', 'style' => 'amount'],
['name' => 'Cuotas', 'style' => 'number'],
['name' => 'Cuotas Pagadas', 'style' => 'number'],
['name' => 'Pie Pagado [UF]', 'style' => 'amount'],
['name' => 'Pie Pagado [$]', 'style' => 'amount']
];
$informe->addColumns($columnas);
$data = [];
foreach ($ventas as $venta) {
$info = [];
$info['Propietario'] = mb_strtoupper($venta->propietario()->nombreCompleto());
$info['Departamento'] = $venta->unidad()->descripcion;
$ests = [];
if ($venta->propiedad()->estacionamientos != '') {
$es = $venta->propiedad()->estacionamientos();
foreach ($es as $e) {
$ests []= $e->descripcion;
}
}
$info['Estacionamientos'] = implode(', ', $ests);
$bods = [];
if ($venta->propiedad()->bodegas != '') {
$bs = $venta->propiedad()->bodegas();
foreach ($bs as $b) {
$bods []= $b->descripcion;
}
}
$info['Bodegas'] = implode(', ', $bods);
$info['Fecha Venta'] = $venta->fecha()->format('d.m.Y');
$info['Mes'] = $venta->fecha()->format('M-y');
$info['Tipo'] = $venta->unidad()->abreviacion;
$info['m² Ponderados'] = $venta->unidad()->m2('vendible');
$info['Valor Promesa'] = $venta->valor_uf;
$info['Pie [UF]'] = 0;
$info['Pie [$]'] = 0;
if ($venta->pie()) {
$info['Pie [UF]'] = $venta->pie()->valor;
$info['Pie [$]'] = $venta->pie()->valorPesos();
}
$info['Abono Escritura'] = ($venta->escritura != 0) ? $venta->escritura()->valor('ufs') : ($venta->valor_uf - $venta->pie()->valor - (($venta->credito != 0) ? $venta->credito()->pago()->valor('ufs') : 0));
$info['Crédito'] = ($venta->credito != 0) ? $venta->credito()->pago()->valor('ufs') : 0;
$info['Cuotas'] = $venta->pie()->cuotas;
$info['Cuotas Pagadas'] = count($venta->pie()->pagadas());
$info['Pie Pagado [UF]'] = $venta->pie()->valorPagado('uf');
$info['Pie Pagado [$]'] = $venta->pie()->valorPagado('pesos');
$data []= $info;
}
$informe->addData($data);
$totals = [
'Departamento' => 'count',
'Estacionamientos' => 'count',
'Bodegas' => 'count',
'm² Ponderados' => 'sum',
'Valor Promesa' => 'sum',
'Pie' => 'sum',
'Pie Pagado' => 'sum'
];
$informe->addTotals($totals);
return $informe->informe();
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.resumen_contabilidad', compact('proyectos'));
}
}
public static function contabilidad()
{
if (get('proyecto')) {
$id = get('proyecto');
$fecha = get('fecha');
$mes = null;
if ($fecha != null) {
$mes = Carbon::parse($fecha);
}
$proyecto = model(Proyecto::class)->findOne($id);
$q = "SELECT pago.*, venta.id AS vid, venta.tipo AS ctipo, venta.pie AS pie
FROM (
SELECT pago.id, banco.nombre AS banco, pago.fecha, pago.valor, pago.uf, ep.estado, ep.fecha AS efecha
FROM pago JOIN banco ON banco.id = pago.banco JOIN ((
SELECT pago, MAX(id) AS id FROM estado_pago GROUP BY pago) e0 JOIN estado_pago ep ON ep.id = e0.id) ON ep.pago = pago.id
WHERE ep.estado > 0 ";
if ($mes != null) {
$q .= "AND (pago.fecha BETWEEN '" . $mes->format('Y-m-01') . "' AND '" . $mes->format('Y-m-t') . "'
OR ep.fecha BETWEEN '" . $mes->format('Y-m-01') . "' AND '" . $mes->format('Y-m-t') . "')";
}
$q .= ") pago JOIN (SELECT venta.*
FROM ((
SELECT venta.id, venta.pie, venta.propiedad, credito.pago, 'credito' AS tipo
FROM venta JOIN credito ON credito.id = venta.credito)
UNION ALL (
SELECT venta.id, venta.pie, venta.propiedad, escritura.pago, 'escritura' AS tipo
FROM venta JOIN escritura ON escritura.id = venta.escritura)
UNION ALL (
SELECT venta.id, venta.pie, venta.propiedad, cuota.pago, 'cuota' AS tipo
FROM venta JOIN cuota ON cuota.pie = venta.pie)) venta
JOIN propiedad ON propiedad.id = venta.propiedad
JOIN unidad ON unidad.id = propiedad.unidad_principal
WHERE unidad.proyecto = ?) venta
ON venta.pago = pago.id";
$st = \ORM::getDB()->prepare($q);
$st->execute([$id]);
if ($st->rowCount() > 0) {
$R = $st->fetchAll(\PDO::FETCH_OBJ);
#$informe = new Informador('Contabilidad - ' . (($mes != null) ? $mes->format('Y-m') . ' - ' : '') . $proyecto->descripcion);
$name = 'Contabilidad';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', 'Contabilidad - ' . (($mes != null) ? $mes->format('Y-m') . ' - ' : '') . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = ['Proyecto', 'Fecha', 'Banco', 'Departamento', 'RUT', 'Propietario', 'Glosa', 'Glosa2', (object) ['name' => 'Valor', 'style' => 'integer'], (object) ['name' => 'Valor UF', 'style' => 'currency']];
$informe->addColumns($columnas);
$data = [];
foreach ($R as $r) {
$info = [];
$info['Proyecto'] = $proyecto->descripcion;
$f1 = \Carbon\Carbon::parse($r->fecha, config('app.timezone'));
$f2 = \Carbon\Carbon::parse($r->efecha, config('app.timezone'));
$info['Fecha'] = ($f1->max($f2))->format('Y-m-d');
$info['Banco'] = $r->banco;
$venta = model(Venta::class)->findOne($r->vid);
$info['Departamento'] = $venta->unidad()->descripcion;
$info['RUT'] = $venta->propietario()->rut();
$info['Propietario'] = $venta->propietario()->nombreCompleto();
$info['Glosa'] = ucwords($r->ctipo);
$info['Glosa2'] = '';
if ($r->ctipo == 'cuota') {
$cuota = model(Cuota::class)->where('pago', $r->id)->findOne();
$info['Glosa'] = 'Pie - ' . format('ufs', $cuota->pie()->valor('ufs'), null, true);
$info['Glosa2'] = $cuota->numero() . ' - ' . $cuota->pie()->cuotas;
}
$info['Valor'] = $r->valor;
$info['Valor UF'] = '0';
if ($r->uf > 0) {
$info['Valor UF'] = $r->valor / $r->uf;
}
$data []= $info;
}
$informe->addData($data);
return $informe->informe();
}
} else {
setlocale(LC_TIME, 'es');
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.contabilidad', compact('proyectos'));
}
}
public static function para_comision()
{
$proyectos = model(Proyecto::class)->orderByAsc('descripcion')->findMany();
return view('informes.para_comision', compact('proyectos'));
}
public static function comisiones()
{
$id = post('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$unidades = explode('-', str_replace([';', '.', ':', ' ', PHP_EOL, '|', '+', ','], '-', post('unidades')));
$ventas = model(Venta::class)
->select('venta.*')
->join('propiedad', ['propiedad.id', '=', 'venta.propiedad'])
->join('unidad', ['unidad.id', '=', 'propiedad.unidad_principal'])
->where('unidad.proyecto', $proyecto->id)
->where('venta.estado', 1)
->whereIn('unidad.descripcion', $unidades)
->orderByExpr('FIELD(unidad.descripcion, ' . implode(', ', $unidades) . ')')
->findMany();
$ids = [];
$totales = (object) ['precio' => 0, 'neto' => 0, 'comision' => 0];
foreach ($ventas as $venta) {
$ids []= $venta->id;
$totales->precio += $venta->valor_uf;
$totales->neto += $venta->valorCorredora();
$totales->comision += $venta->valorCorredora() * 1.5 / 100;
}
return view('informes.comisiones', compact('ventas', 'proyecto', 'totales', 'ids'));
}
public static function comisiones_xlsx()
{
$id_ventas = explode(',', get('ventas'));
$ventas = model(Venta::class)
->whereIn('id', $id_ventas)
->orderByExpr('FIELD(id, ' . implode(', ', $id_ventas) . ')')
->findMany();
$informe = new Informador('Comisiones - ' . $ventas[0]->proyecto()->descripcion);
$columnas = ['Departamento', 'Estacionamientos', 'Bodegas', 'Propietario', 'Precio', '% Com', 'Com UF'];
$informe->addColumns($columnas);
$data = [];
foreach ($ventas as $venta) {
$info = [];
$info['Departamento'] = $venta->unidad()->descripcion;
$info['Estacionamientos'] = implode(' - ', $venta->propiedad()->estacionamientos('array'));
$info['Bodegas'] = implode(' - ', $venta->propiedad()->bodegas('array'));
$info['Propietario'] = $venta->propietario()->nombreCompleto();
$info['Precio'] = "'" . format('ufs', $venta->valorCorredora());
$info['% Com'] = '1,5 %';
$info['Com UF'] = "'" . format('ufs', $venta->valorCorredora() * 1.5 / 100);
$data []= $info;
}
$informe->addDatas($data);
return $informe->informe();
}
public static function cuotas()
{
$id_venta = get('venta');
$venta = model(Venta::class)->findOne($id_venta);
$name = 'Cuotas - ' . $venta->unidad()->descripcion;
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $venta->proyecto()->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = [
['name' => 'Cuota', 'style' => 'number'],
['name' => 'Fecha Cuota', 'style' => 'date'],
'Banco',
'Identificador',
['name' => 'Valor $', 'style' => 'number'],
['name' => 'Valor UF', 'style' => 'currency'],
['name' => 'Fecha Pago', 'style' => 'date']
];
$informe->addColumns($columnas);
$data = [];
foreach ($venta->pie()->cuotas() as $cuota) {
$info = [];
$info['Cuota'] = $cuota->numero();
$info['Fecha Cuota'] = $cuota->pago()->fecha()->format('Y-m-d');
$info['Banco'] = $cuota->pago()->banco()->descripcion;
$info['Identificador'] = $cuota->pago()->identificador;
$info['Valor $'] = $cuota->pago()->valor();
$info['Valor UF'] = $cuota->pago()->valor('ufs');
$info['Fecha Pago'] = $cuota->pago()->estado()->fecha()->format('Y-m-d');
$data []= $info;
}
$informe->addData($data);
return $informe->informe();
}
public static function resciliaciones()
{
if (get('proyecto')) {
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$ventas = $proyecto->resciliaciones();
usort($ventas, function($a, $b) {
return $a->fecha()->timestamp - $b->fecha()->timestamp;
});
$name = 'Resciliaciones';
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $name . ' - ' . $proyecto->descripcion . ' - ' . $hoy->format('Y-m-d') . '.xls');
$informe = new PHPExcel($name, $filename);
$columnas = [
'Propietario',
['name' => 'Departamento', 'style' => 'number'],
['name' => 'Estacionamientos', 'style' => 'number'],
['name' => 'Bodegas', 'style' => 'number'],
'Fecha Venta',
'Fecha Resciliación',
['name' => 'Mes', 'style' => 'mes'],
'Tipo',
['name' => 'm² Ponderados', 'style' => 'amount'],
['name' => 'Valor Promesa', 'style' => 'amount'],
];
$informe->addColumns($columnas);
$data = [];
foreach ($ventas as $venta) {
$info = [];
$info['Propietario'] = mb_strtoupper($venta->propietario()->nombreCompleto());
$info['Departamento'] = $venta->unidad()->descripcion;
$ests = [];
if ($venta->propiedad()->estacionamientos != '') {
$es = $venta->propiedad()->estacionamientos();
foreach ($es as $e) {
$ests []= $e->descripcion;
}
}
$info['Estacionamientos'] = implode(', ', $ests);
$bods = [];
if ($venta->propiedad()->bodegas != '') {
$bs = $venta->propiedad()->bodegas();
foreach ($bs as $b) {
$bods []= $b->descripcion;
}
}
$info['Bodegas'] = implode(', ', $bods);
$info['Fecha Venta'] = $venta->fecha()->format('d.m.Y');
$info['Fecha Resciliación'] = $venta->estado()->fecha()->format('d.m.Y');
$info['Mes'] = $venta->estado()->fecha()->format('M-y');
$info['Tipo'] = $venta->unidad()->abreviacion;
$info['m² Ponderados'] = $venta->unidad()->m2('vendible');
$info['Valor Promesa'] = $venta->valor_uf;
$data []= $info;
}
$informe->addData($data);
$totals = [
'Departamento' => 'count',
'Estacionamientos' => 'count',
'Bodegas' => 'count',
'm² Ponderados' => 'sum',
'Valor Promesa' => 'sum'
];
$informe->addTotals($totals);
return $informe->informe();
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('informes.resciliaciones', compact('proyectos'));
}
}
}

View File

@ -0,0 +1,74 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Inmobiliaria\Inmobiliaria;
use Incoviba\old\Inmobiliaria\TipoSociedad;
use Incoviba\old\Common\Banco;
class Inmobiliarias
{
use Controller;
public static function list()
{
$inmobiliarias = model(Inmobiliaria::class)->orderByAsc('abreviacion')->findMany();
return view('inmobiliarias.list', compact('inmobiliarias'));
}
public static function show()
{
$rut = get('rut');
$inmobiliaria = model(Inmobiliaria::class)->findOne($rut);
return view('inmobiliarias.show', compact('inmobiliaria'));
}
public static function add()
{
$sociedades = model(TipoSociedad::class)->findMany();
return view('inmobiliarias.add', compact('sociedades'));
}
public static function agregar()
{
list($rut, $dv) = explode('-', str_replace('.', '', post('rut')));
$inmobiliaria = model(Inmobiliaria::class)->findOne($rut);
if ($inmobiliaria) {
header('Location: ' . url('', ['p' => 'inmobiliarias', 'a' => 'show', 'rut' => $inmobiliaria->rut]));
die();
}
$inmobiliaria = model(Inmobiliaria::class)->create();
$inmobiliaria->rut = $rut;
$inmobiliaria->dv = $dv;
$inmobiliaria->razon = post('razon');
$inmobiliaria->abreviacion = post('abrev');
$inmobiliaria->sociedad = post('sociedad');
$inmobiliaria->save();
header('Location: ' . url('', ['p' => 'inmobiliarias', 'a' => 'show', 'rut' => $inmobiliaria->rut]));
}
public static function edit()
{
$sociedades = model(TipoSociedad::class)->findMany();
$rut = get('rut');
$inmobiliaria = model(Inmobiliaria::class)->findOne($rut);
$bancos = model(Banco::class)->findMany();
usort($bancos, function($a, $b) {
return strcmp($a->nombre, $b->nombre);
});
return view('inmobiliarias.edit', compact('inmobiliaria', 'bancos', 'sociedades'));
}
public static function do_edit()
{
$rut = get('rut');
$inmobiliaria = model(Inmobiliaria::class)->findOne($rut);
foreach (post() as $field => $value) {
if ($value != '' and $inmobiliaria->{$field} != $value) {
$inmobiliaria->{$field} = $value;
}
}
$inmobiliaria->save();
header('Location: ' . nUrl('inmobiliarias', 'show', ['rut' => $inmobiliaria->rut]));
}
}
?>

View File

@ -0,0 +1,47 @@
<?php
namespace App\Controller;
use Carbon\Carbon;
use App\Definition\Controller;
use Incoviba\old\Proyecto\Agente;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Proyecto\ProyectoAgente;
class Operadores
{
use Controller;
public static function agregar()
{
$proyecto = model(Proyecto::class)->findOne(get('proyecto'));
$operadores = model(Agente::class)
->select('agente.*')
->join('agente_tipo', ['agente_tipo.agente', '=', 'agente.id'])
->join('tipo_agente', ['tipo_agente.id', '=', 'agente_tipo.tipo'])
->where('tipo_agente.descripcion', 'operador')
->orderByAsc('agente.abreviacion')
->findMany();
$vigentes = array_map(function($item) {
return $item->agente()->agente();
}, $proyecto->operadoresVigentes());
echo view('proyectos.operadores.add', compact('proyecto', 'operadores', 'vigentes'));
}
public static function add()
{
$proyecto = model(Proyecto::class)->findOne(get('proyecto'));
$fecha = Carbon::today(config('app.timezone'));
foreach (post('operadores') as $op) {
$operador = model(Agente::class)->findOne($op);
$at = $operador->tipos(19);
$data = [
'proyecto' => $proyecto->id,
'agente' => $at->id,
'fecha' => $fecha->format('Y-m-d'),
'comision' => 2
];
$pa = model(ProyectoAgente::class)->create($data);
$pa->new();
}
header('Location: ' . nUrl('proyectos', 'show', ['proyecto' => $proyecto->id]));
}
}

71
app/Controller/Other.php Normal file
View File

@ -0,0 +1,71 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Entrega;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Venta\Unidad;
use Stringy\Stringy;
class Other
{
use Controller;
protected static function setDefault()
{
self::$default = view('other.list');
}
public static function entregar_multiple()
{
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
$file = $_FILES['entregas'];
$data = explode(PHP_EOL, trim(file_get_contents($file['tmp_name'])));
foreach ($data as $line) {
$info = explode(';', $line);
if ($info[0] == 'Departamento' or $info[1] == 'Fecha') {
continue;
}
$entrega = \Model::factory(Entrega::class)->create();
$unidad = \Model::factory(Unidad::class)->where('descripcion', $info[0])->where('proyecto', post('proyecto'))->find_one();
if (!$unidad->venta()->find_one()) {
echo 'x';
continue;
}
$venta = $unidad->venta()->find_one();
$entrega->fecha = \Carbon\Carbon::parse($info[1])->format('Y-m-d');
if ($venta->entrega == '0') {
$entrega->save();
$venta->entrega = $entrega->id;
$venta->save();
echo '.';
} else {
echo 'x';
}
}
} else {
$proyectos = \Model::factory(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('other.entregar_multiple', compact('proyectos'));
}
}
public static function capacidades()
{
$capacidades = [];
$controllers = glob(config('locations.app') . '/Controller/*.php');
foreach ($controllers as $controller) {
if (basename($controller) == 'Admin.php' or basename($controller) == 'Other.php') {
continue;
}
$class = Stringy::create($controller)->replace(config('locations.app'), '/App')->replace('.php', '')->replace('/', '\\')->__toString();
$ref = new \ReflectionClass($class);
$static = $ref->getMethods(\ReflectionMethod::IS_STATIC && \ReflectionMethod::IS_PUBLIC);
foreach ($static as $method) {
if ($method->name == 'setDefault' or $method->name == 'index') {
continue;
}
$capacidades []= $method;
}
}
return view('other.capacidades', compact('capacidades'));
}
}
?>

271
app/Controller/Pagares.php Normal file
View File

@ -0,0 +1,271 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Proyecto\Pagare;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Proyecto\RenovacionPagare;
use Incoviba\old\Proyecto\TipoMonedaPagare;
class Pagares
{
use Controller;
public static function show()
{
$pagare = model(Pagare::class)->findOne(get('pagare'));
return view('proyectos.pagares.show', compact('pagare'));
}
public static function add()
{
$proyecto = model(Proyecto::class)->findOne(get('proyecto'));
return view('proyectos.pagares.add', compact('proyecto'));
}
public static function do_add()
{
$proyecto = model(Proyecto::class)->findOne(get('proyecto'));
$data = post();
$data['id'] = $data['numero'];
unset($data['numero']);
$data['proyecto'] = $proyecto->id;
$moneda = model(TipoMonedaPagare::class)->where('descripcion', $data['moneda'])->findOne();
$data['moneda'] = $moneda->id;
$fecha = ['year', 'month', 'day'];
$fecha_arr = array_filter($data, function($item) use ($fecha) {
return (array_search($item, $fecha) !== false);
}, \ARRAY_FILTER_USE_KEY);
uksort($fecha_arr, function($a, $b) use ($fecha) {
return array_search($a, $fecha) - array_search($b, $fecha);
});
foreach ($fecha as $f) {
unset($data[$f]);
}
array_walk($fecha_arr, function(&$item) {
if (strlen($item) < 4) {
$item = str_pad($item, 2, '0', \STR_PAD_LEFT);
}
});
$data['fecha'] = implode('-', $fecha_arr);
foreach ($fecha as &$key) {
$key .= '_banco';
}
$fecha_arr = array_filter($data, function($item) use ($fecha) {
return (array_search($item, $fecha) !== false);
}, \ARRAY_FILTER_USE_KEY);
uksort($fecha_arr, function($a, $b) use ($fecha) {
return array_search($a, $fecha) - array_search($b, $fecha);
});
foreach ($fecha as $f) {
unset($data[$f]);
}
array_walk($fecha_arr, function(&$item) {
if (strlen($item) < 4) {
$item = str_pad($item, 2, '0', \STR_PAD_LEFT);
}
});
$data['fecha_banco'] = implode('-', $fecha_arr);
$data['abonado'] = (int) $data['abonado'];
if ($data['abonado'] == 0) {
$data['fecha'] = '0000-00-00';
}
$pagare = model(Pagare::class)->create($data);
$pagare->save();
header('Location: ' . nUrl('pagares', 'show', ['pagare' => $pagare->id]));
}
public static function edit()
{
$pagare = model(Pagare::class)->findOne(get('pagare'));
return view('proyectos.pagares.edit', compact('pagare'));
}
public static function do_edit()
{
$pagare = model(Pagare::class)->findOne(get('pagare'));
$data = post();
if ($pagare->id != $data['numero']) {
foreach ($pagare->renovaciones() as $renovacion) {
$renovacion->pagare = $data['numero'];
$renovacion->save();
}
$pagare->id = $data['numero'];
$changed = true;
}
unset($data['numero']);
$moneda = model(TipoMonedaPagare::class)->where('descripcion', $data['moneda'])->findOne();
$data['moneda'] = $moneda->id;
$fecha = ['year', 'month', 'day'];
$fecha_arr = array_filter($data, function($item) use ($fecha) {
return (array_search($item, $fecha) !== false);
}, \ARRAY_FILTER_USE_KEY);
uksort($fecha_arr, function($a, $b) use ($fecha) {
return array_search($a, $fecha) - array_search($b, $fecha);
});
foreach ($fecha as $f) {
unset($data[$f]);
}
array_walk($fecha_arr, function(&$item) {
if (strlen($item) < 4) {
$item = str_pad($item, 2, '0', \STR_PAD_LEFT);
}
});
$data['fecha'] = implode('-', $fecha_arr);
foreach ($fecha as &$key) {
$key .= '_banco';
}
$fecha_arr = array_filter($data, function($item) use ($fecha) {
return (array_search($item, $fecha) !== false);
}, \ARRAY_FILTER_USE_KEY);
uksort($fecha_arr, function($a, $b) use ($fecha) {
return array_search($a, $fecha) - array_search($b, $fecha);
});
foreach ($fecha as $f) {
unset($data[$f]);
}
array_walk($fecha_arr, function(&$item) {
if (strlen($item) < 4) {
$item = str_pad($item, 2, '0', \STR_PAD_LEFT);
}
});
$data['fecha_banco'] = implode('-', $fecha_arr);
$data['abonado'] = (int) $data['abonado'];
if ($data['abonado'] == 0) {
$data['fecha'] = '0000-00-00';
}
$changed = false;
foreach ($data as $k => $v) {
if ($pagare->$k != $v) {
$pagare->$k = $v;
$changed = true;
if (strpos($k, 'fecha') !== false) {
$pagare->uf = 0;
}
}
}
if ($changed) {
$pagare->save();
}
header('Location: ' . nUrl('pagares', 'show', ['pagare' => $pagare->id]));
}
public static function edit_renovacion()
{
$renovacion = model(RenovacionPagare::class)->findOne(get('renovacion'));
return view('proyectos.pagares.edit_renovacion', compact('renovacion'));
}
public static function do_edit_renovacion()
{
$renovacion = model(RenovacionPagare::class)->findOne(get('renovacion'));
$data = post();
$fecha = ['year', 'month', 'day'];
$fecha_arr = array_filter($data, function($item) use ($fecha) {
return (array_search($item, $fecha) !== false);
}, \ARRAY_FILTER_USE_KEY);
uksort($fecha_arr, function($a, $b) use ($fecha) {
return array_search($a, $fecha) - array_search($b, $fecha);
});
foreach ($fecha as $f) {
unset($data[$f]);
}
array_walk($fecha_arr, function(&$item) {
if (strlen($item) < 4) {
$item = str_pad($item, 2, '0', \STR_PAD_LEFT);
}
});
$data['fecha'] = implode('-', $fecha_arr);
foreach ($fecha as &$key) {
$key .= '_banco';
}
$fecha_arr = array_filter($data, function($item) use ($fecha) {
return (array_search($item, $fecha) !== false);
}, \ARRAY_FILTER_USE_KEY);
uksort($fecha_arr, function($a, $b) use ($fecha) {
return array_search($a, $fecha) - array_search($b, $fecha);
});
foreach ($fecha as $f) {
unset($data[$f]);
}
array_walk($fecha_arr, function(&$item) {
if (strlen($item) < 4) {
$item = str_pad($item, 2, '0', \STR_PAD_LEFT);
}
});
$data['fecha_banco'] = implode('-', $fecha_arr);
$changed = false;
foreach ($data as $k => $v) {
if ($renovacion->$k != $v) {
$renovacion->$k = $v;
$changed = true;
if (strpos($k, 'fecha') !== false) {
$renovacion->uf = 0;
}
}
}
if ($changed) {
$renovacion->save();
}
header('Location: ' . nUrl('pagares', 'show', ['pagare' => $renovacion->pagare]));
}
public static function add_renovacion()
{
$pagare = model(Pagare::class)->findOne(get('pagare'));
return view('proyectos.pagares.add_renovacion', compact('pagare'));
}
public static function do_add_renovacion()
{
$pagare = model(Pagare::class)->findOne(get('pagare'));
$data = post();
$data['pagare'] = $pagare->id;
$fecha = ['year', 'month', 'day'];
$fecha_arr = array_filter($data, function($item) use ($fecha) {
return (array_search($item, $fecha) !== false);
}, \ARRAY_FILTER_USE_KEY);
uksort($fecha_arr, function($a, $b) use ($fecha) {
return array_search($a, $fecha) - array_search($b, $fecha);
});
foreach ($fecha as $f) {
unset($data[$f]);
}
array_walk($fecha_arr, function(&$item) {
if (strlen($item) < 4) {
$item = str_pad($item, 2, '0', \STR_PAD_LEFT);
}
});
$data['fecha'] = implode('-', $fecha_arr);
foreach ($fecha as &$key) {
$key .= '_banco';
}
$fecha_arr = array_filter($data, function($item) use ($fecha) {
return (array_search($item, $fecha) !== false);
}, \ARRAY_FILTER_USE_KEY);
uksort($fecha_arr, function($a, $b) use ($fecha) {
return array_search($a, $fecha) - array_search($b, $fecha);
});
foreach ($fecha as $f) {
unset($data[$f]);
}
array_walk($fecha_arr, function(&$item) {
if (strlen($item) < 4) {
$item = str_pad($item, 2, '0', \STR_PAD_LEFT);
}
});
$data['fecha_banco'] = implode('-', $fecha_arr);
$renovacion = model(RenovacionPagare::class)->create($data);
$renovacion->save();
header('Location: ' . nUrl('pagares', 'show', ['pagare' => $renovacion->pagare]));
}
}

358
app/Controller/Pagos.php Normal file
View File

@ -0,0 +1,358 @@
<?php
namespace App\Controller;
use Carbon\Carbon;
use App\Definition\Controller;
use Incoviba\old\Venta\Pago;
use Incoviba\old\Venta\TipoPago;
use Incoviba\old\Venta\TipoEstadoPago;
use Incoviba\old\Common\Banco;
use Incoviba\old\Venta\Venta;
use Incoviba\old\Venta\EstadoPago;
class Pagos
{
use Controller;
public static function edit()
{
$id = get('pago');
$asociado = get('asociado');
$id_asociado = get($asociado);
$pago = model(Pago::class)->findOne($id);
$tipos = model(TipoPago::class)->orderByAsc('descripcion')->findMany();
$estados = model(TipoEstadoPago::class)->orderByAsc('descripcion')->findMany();
return view('ventas.pagos.edit', compact('pago', 'asociado', 'id_asociado', 'tipos', 'estados'));
}
public static function editar()
{
$id = get('pago');
$pago = model(Pago::class)->findOne($id);
$fp = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$tipo = model(TipoPago::class)->findOne(post('tipo'));
$valor = correctNumber(post('valor'));
$banco = model(Banco::class)->where('nombre', post('banco'))->findOne();
$fe = Carbon::createFromDate(post('yearestado'), post('monthestado'), post('dayestado'), config('app.timezone'));
$estado = model(TipoEstadoPago::class)->findOne(post('estado'));
$uf = uf($fe);
$est = $pago->estado();
if ($est->fecha != $fe->format('Y-m-d')) {
$est->fecha = $fe->format('Y-m-d');
$pago->uf = $uf->uf->value;
}
if ($est->estado != $estado->id) {
$est->estado = $estado->id;
}
if ($pago->fecha != $fp->format('Y-m-d')) {
$pago->fecha = $fp->format('Y-m-d');
}
if ($pago->tipo != $tipo->id) {
$pago->tipo = $tipo->id;
}
if ($pago->valor != $valor) {
$pago->valor = $valor;
}
if ($pago->identificador != post('identificador')) {
$pago->identificador = post('identificador');
}
if ($pago->pagador != post('pagador')) {
$pago->pagador = post('pagador');
}
if ($pago->banco != $banco->id) {
$pago->banco = $banco->id;
}
$est->save();
$pago->save();
header('Location: ' . url('', ['p' => get('asociado') . 's', 'a' => 'show', get('asociado') => get(get('asociado'))]));
}
public static function pendientes()
{
$ventas = model(Venta::class)
->select('venta.*')
->rawJoin('JOIN (SELECT e1.* FROM estado_venta e1 JOIN (SELECT venta, MAX(id) AS id FROM estado_venta GROUP BY venta) e0 ON e0.id = e1.id)', ['ev.venta', '=', 'venta.id'], 'ev')
->join('tipo_estado_venta', ['te.id', '=', 'ev.estado'], 'te')
->join('propiedad', ['propiedad.id', '=', 'venta.propiedad'])
->join('unidad', ['unidad.id', '=', 'propiedad.unidad_principal'])
->join('proyecto', ['proyecto.id', '=', 'unidad.proyecto'])
->where('te.activa', 1)
->orderByAsc('proyecto.descripcion')
->orderByExpr('LPAD(unidad.descripcion, 4, "0")')
->findMany();
$n = 30;
$mod = floor(count($ventas) / $n);
$i_rest = count($ventas) - count($ventas) % $mod + 1;
$rest = count($ventas) - $i_rest;
$lots = (object) ['size' => $mod, 'N' => $n, 'rest' => (object) [
'size' => $rest,
'start' => $i_rest
]
];
return view('ventas.pagos.pendientes', compact('ventas', 'lots'));
}
public static function para_pendientes()
{
$timezone = config('app.timezone');
$today = Carbon::today($timezone);
$days = [];
$fechas = [];
for ($i = $today->copy()->subDays(15); $i <= $today->copy()->addDays(15); $i = $i->copy()->addDay()) {
$days []= $i->format('Y-m-d');
$fechas []= $i->format('d-m-Y');
}
$pagos_pendientes = model(Pago::class)
->select('estado_pago.fecha')
->selectExpr('COUNT(pago.id)', 'cantidad')
->join('cuota', ['cuota.pago', '=', 'pago.id'])
->join('venta', ['venta.pie', '=', 'cuota.pie'])
->filter('filterEstado')
->where('estado_pago.estado', 0)
->where('venta.estado', 1)
->whereGte('estado_pago.fecha', $today->copy()->subDays(15)->format('Y-m-d'))
->whereLte('estado_pago.fecha', $today->copy()->addDays(15)->format('Y-m-d'))
->orderByAsc('estado_pago.fecha')
->groupBy('estado_pago.fecha')
->findMany();
$valores = array_fill(0, count($days), 0);
$anteriores = model(Pago::class)
->join('cuota', ['cuota.pago', '=', 'pago.id'])
->join('venta', ['venta.pie', '=', 'cuota.pie'])
->filter('filterEstado')
->where('estado_pago.estado', 0)
->where('venta.estado', 1)
->whereLt('estado_pago.fecha', $today->copy()->subDays(15)->format('Y-m-d'))
->count();
foreach ($pagos_pendientes as $pago) {
$valores[array_search($pago->fecha()->format('Y-m-d'), $days)] = $pago->cantidad;
}
$acum = [];
$sum = 0;
foreach ($valores as $valor) {
$sum += $valor;
$acum []= $sum;
}
$t = array_search($today->format('Y-m-d'), $days);
$color = array_merge(
array_fill(0, $t, 'red'),
['blue'],
array_fill(0, count($days) - $t, 'green')
);
$pagos = ['data' => $acum, 'historico' => $anteriores, 'backgroundColor' => $color];
$abonos_pendientes = model(Pago::class)
->select('estado_pago.fecha')
->selectExpr('COUNT(pago.id)', 'cantidad')
->filter('filterEstado')
->where('estado_pago.estado', 1)
->whereGte('estado_pago.fecha', $today->copy()->subDays(15)->format('Y-m-d'))
->whereLt('estado_pago.fecha', $today->copy()->format('Y-m-d'))
->orderByAsc('estado_pago.fecha')
->groupBy('estado_pago.fecha')
->findMany();
$anteriores = model(Pago::class)
->join('cuota', ['cuota.pago', '=', 'pago.id'])
->join('venta', ['venta.pie', '=', 'cuota.pie'])
->filter('filterEstado')
->where('estado_pago.estado', 1)
->where('venta.estado', 1)
->whereLt('estado_pago.fecha', $today->copy()->subDays(15)->format('Y-m-d'))
->count();
$valores = array_fill(0, count($days), 0);
foreach ($abonos_pendientes as $pago) {
$valores[array_search($pago->fecha()->format('Y-m-d'), $days)] = $pago->cantidad;
}
$acum = [];
$sum = 0;
foreach ($valores as $valor) {
$sum += $valor;
$acum []= $sum;
}
$color = array_fill(0, count($pagos), 'rgb(200, 0, 0)');
$abonos = ['data' => $acum, 'historico' => $anteriores, 'backgroundColor' => $color];
$output = ['count' => count($days), 'fechas' => $fechas, 'pagos' => $pagos, 'abonos' => $abonos];
echo json_encode($output);
}
public static function para_abonar()
{
$ids = json_decode(post('ids'));
//$id = get('id');
function checkPago(&$pagos, $tipo, $pago) {
if (!$pago) {
return;
}
if (!$pago->estado()) {
$pagos []= [
'tipo' => $tipo,
'pago' => $pago->asArray(),
'estado' => -1
];
return;
}
if ($pago->estado()->tipo()->descripcion == 'depositado') {
$pagos []= [
'tipo' => $tipo,
'pago' => $pago->asArray(),
'fecha' => format('shortDate', $pago->estado()->fecha),
'valor' => format('pesos', $pago->valor, true),
'estado' => 1
];
}
}
$output = [];
foreach ($ids as $id) {
$venta = model(Venta::class)->findOne($id);
if ($venta->estado()->tipo()->activa == 0) {
$output []= ['status' => -1, 'venta' => $venta->id];
continue;
}
$pagos = [];
if ($venta->pie()) {
foreach ($venta->pie()->cuotas() as $cuota) {
checkPago($pagos, 'Pie', $cuota->pago());
}
if ($venta->pie()->reajuste()) {
checkPago($pagos, 'Reajuste', $venta->pie()->reajuste());
}
}
if ($venta->credito()) {
checkPago($pagos, 'Credito', $venta->credito()->pago());
}
if ($venta->escritura()) {
checkPago($pagos, 'Abono Escritura', $venta->escritura()->pago());
}
if ($venta->subsidio()) {
checkPago($pagos, 'Subsidio', $venta->subsidio()->subsidio());
checkPago($pagos, 'Ahorro', $venta->subsidio()->pago());
}
if (count($pagos) <= 0) {
$output []= ['status' => -1, 'venta' => $venta->id];
continue;
}
$output []= [
'status' => 1,
'proyecto' => $venta->proyecto()->descripcion,
'venta' => $venta->id,
'propietario' => $venta->propietario()->nombreCompleto(),
'departamento' => $venta->unidad()->descripcion,
'pagos' => $pagos
];
}
return json_encode($output);
}
public static function rebotes()
{
$ids = json_decode(post('ids'));
$response = [];
foreach ($ids as $id) {
//$id = get('id');
$venta = model(Venta::class)->findOne($id);
$rebotes = $venta->pagos(-1);
if (count($rebotes) < 1) {
$response []= ['status' => -1, 'venta' => $venta->id];
continue;
}
usort($rebotes, function($a, $b) {
return $b->estado()->fecha()->diffInDays($a->estado()->fecha(), false);
});
$output = [];
$textos = [];
foreach ($rebotes as $rebote) {
$fuente = $rebote->fuente()[0];
$text = '<td>' . ucwords(str_replace('_', ' ', $fuente->tipo)) . '</td>';
$info = ['tipo' => ucwords(str_replace('_', ' ', $fuente->tipo))];
switch ($fuente->tipo) {
case('cuota'):
$text .= '<td>' . $fuente->obj->pie()->venta()->proyecto()->descripcion
. '</td><td><a href="' . nUrl('ventas', 'show', ['venta' => $fuente->obj->pie()->venta()->id])
. '">' . $fuente->obj->pie()->venta()->unidad()->descripcion . '</a></td><td>'
. $fuente->obj->pie()->venta()->propietario()->nombreCompleto()
. '</td><td>' . format('shortDate', $rebote->estado()->fecha) . '</td>';
$info['proyecto'] = $fuente->obj->pie()->venta()->proyecto()->descripcion;
$info['venta'] = $fuente->obj->pie()->venta()->id;
$info['departamento'] = $fuente->obj->pie()->venta()->unidad()->descripcion;
$info['propietario'] = $fuente->obj->pie()->venta()->propietario()->nombreCompleto();
$info['fecha'] = format('shortDate', $rebote->estado()->fecha);
break;
}
$text .= '<td>' . format('pesos', $rebote->valor('pesos'), true) . '</td>';
$info['valor'] = format('pesos', $rebote->valor('pesos'), true);
$output []= array_merge(['id' => $rebote->id], $info);
$textos []= ['id' => $rebote->id, 'text' => $text];
}
$response []= ['status' => 1, 'venta' => $venta->id, 'textos' => $textos, 'rebotes' => $output];
}
return json_encode($response);
}
public static function show()
{
$id = get('pago');
$asociado = get('asociado');
$id_asociado = get($asociado);
$pago = model(Pago::class)->findOne($id);
return view('ventas.pagos.show', compact('pago', 'asociado', 'id_asociado'));
}
public static function pagar()
{
$id = get('pago');
$pago = model(Pago::class)->findOne($id);
$asociado = get('asociado');
$id_asociado = get($asociado);
return view('ventas.pagos.pagar', compact('pago', 'asociado', 'id_asociado'));
}
public static function pagando()
{
$id = get('pago');
$pago = model(Pago::class)->findOne($id);
$asociado = get('asociado');
$id_asociado = get($asociado);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$data = [
'fecha' => $f->format('Y-m-d'),
'pago' => $pago->id,
'estado' => 1
];
$estado = model(EstadoPago::class)->create($data);
$estado->save();
header('Location: ' . url('', ['p' => $asociado . 's', 'a' => 'show', $asociado => $id_asociado]));
}
public static function abonar()
{
$id = get('pago');
$pago = model(Pago::class)->findOne($id);
$asociado = get('asociado');
$id_asociado = get($asociado);
return view('ventas.pagos.abonar', compact('pago', 'asociado', 'id_asociado'));
}
public static function abonando()
{
$id = get('pago');
$pago = model(Pago::class)->findOne($id);
$asociado = get('asociado');
$id_asociado = get($asociado);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$data = [
'fecha' => $f->format('Y-m-d'),
'pago' => $pago->id,
'estado' => 2
];
$estado = model(EstadoPago::class)->create($data);
$estado->save();
header('Location: ' . url('', ['p' => $asociado . 's', 'a' => 'show', $asociado => $id_asociado]));
}
}
?>

104
app/Controller/Pies.php Normal file
View File

@ -0,0 +1,104 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Pie;
use Incoviba\old\Venta\Venta;
use Incoviba\old\Venta\Pago;
use Carbon\Carbon;
class Pies
{
use Controller;
protected static function setDefault()
{
self::$default = self::list();
}
public static function list()
{
$proyecto = get('proyecto');
if ($proyecto == null) {
return self::listProyectos();
}
$proyecto = \Model::factory(Proyecto::class)->findOne($proyecto);
$ventas = $proyecto->ventas();
self::sort($ventas);
return view('ventas.list', compact('proyecto', 'ventas'));
}
public static function listProyectos()
{
$proyectos = \Model::factory(Proyecto::class)
->select('proyecto.*')
->join('estado_proyecto', ['estado.proyecto', '=', 'proyecto.id'], 'estado')
->join('tipo_estado_proyecto', ['tipo.id', '=', 'estado.estado'], 'tipo')
->join('etapa_proyecto', ['etapa.id', '=', 'tipo.etapa'], 'etapa')
->whereGte('etapa.orden', 4)
->groupBy('proyecto.id')
->findMany();
echo view('ventas.proyectos', compact('proyectos'));
}
public static function resumen()
{
$id = get('pie');
$pie = \Model::factory(\Incoviba\old\Venta\Pie::class)->findOne($id);
$venta = $pie->venta();
return view('ventas.pies.resumen', compact('venta'));
}
public static function reajustar()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
return view('ventas.pies.reajustar', compact('venta'));
}
public static function reajuste()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$pago = \Model::factory(Pago::class)->create();
$pago->fecha = $f->format('Y-m-d');
$pago->uf = (float) uf($f)->uf->value;
$pago->valor = str_replace('.', '', post('valor'));
$pago->new();
$pie = $venta->pie();
$pie->reajuste = $pago->id;
$pie->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function edit()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
return view('ventas.pies.edit', compact('venta'));
}
public static function editar()
{
$id = get('venta');
$venta = \Model::factory(Venta::class)->findOne($id);
$pie = $venta->pie();
$valor = correctNumber(post('valor'));
if ($pie->valor != $valor) {
$pie->valor = $valor;
}
if ($pie->cuotas != post('cuotas')) {
$pie->cuotas = post('cuotas');
}
$pie->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function asociar()
{
$id = get('pie');
$pie = \Model::factory(Pie::class)->findOne($id);
$pie->asociado = post('asociado');
$pie->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $pie->venta()->id]));
}
}
?>

View File

@ -0,0 +1,69 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Venta;
use Carbon\Carbon;
use Incoviba\nuevo\Venta\Observacion;
use Incoviba\nuevo\Venta\EstadoObservacion;
use Incoviba\nuevo\Venta\Postventa;
use Incoviba\nuevo\Venta\PostventaObservacion;
use Incoviba\nuevo\Venta\EstadoPostventa;
class Postventas
{
use Controller;
public static function add()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.postventas.add', compact('venta'));
}
public static function agregar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$observaciones = json_decode(post('observaciones'));
$postventa = model(Postventa::class)->create();
$postventa->venta_id = $venta->id;
$postventa->save();
$estado = model(EstadoPostventa::class)->create();
$estado->postventa_id = $postventa->id;
$estado->tipo_estado_postventa_id = 1;
$estado->fecha = $f->format('Y-m-d');
$estado->save();
foreach ($observaciones as $o) {
$observacion = model(Observacion::class)->create();
$observacion->texto = post('observacion' . $o);
$observacion->save();
$estado = model(EstadoObservacion::class)->create();
$estado->observacion_id = $observacion->id;
$estado->tipo_estado_observacion_id = 1;
$estado->fecha = $f->format('Y-m-d');
$estado->save();
$po = model(PostventaObservacion::class)->create();
$po->postventa_id = $postventa->id;
$po->observacion_id = $observacion->id;
$po->save();
}
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function show()
{
$id = get('postventa');
$postventa = model(Postventa::class)->findOne($id);
$venta = model(Venta::class)->findOne($postventa->venta_id);
return view('ventas.postventas.show', compact('postventa', 'venta'));
}
}
?>

166
app/Controller/Precios.php Normal file
View File

@ -0,0 +1,166 @@
<?php
namespace App\Controller;
use Carbon\Carbon;
use Stringy\Stringy;
use App\Definition\Controller;
use App\Service\Factory;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Proyecto\ProyectoTipoUnidad;
use Incoviba\old\Venta\Precio;
use Incoviba\old\Venta\EstadoPrecio;
use Incoviba\old\Venta\Unidad;
use Incoviba\old\Venta\TipoUnidad;
use Incoviba\old\Venta\TipoEstadoPrecio;
class Precios
{
use Controller;
public static function listProyectos()
{
$proyectos = \model(Proyecto::class)->orderByAsc('descripcion')->findMany();
return view('ventas.precios.proyectos', compact('proyectos'));
}
public static function list()
{
$proyecto = \model(Proyecto::class)->findOne(get('proyecto'));
return view('ventas.precios.list', compact('proyecto'));
}
public static function import()
{
$proyectos = \model(Proyecto::class)->orderByAsc('descripcion')->findMany();
return view('ventas.precios.import', compact('proyectos'));
}
public static function importar()
{
$proyecto = \model(Proyecto::class)->findOne(post('proyecto'));
$fecha = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$file = explode(PHP_EOL, trim(file_get_contents($_FILES['archivo']['tmp_name'])));
$columnas = explode(';', array_shift($file));
$tr = model(TipoEstadoPrecio::class)->where('descripcion', 'reemplazado')->findOne()->id;
$tv = model(TipoEstadoPrecio::class)->where('descripcion', 'vigente')->findOne()->id;
foreach ($file as $line) {
if (trim($line) == '') {
continue;
}
$info = explode(';', $line);
$tipo = \model(TipoUnidad::class)->where('descripcion', $info[0])->findOne();
$unidad = \model(Unidad::class)->where('tipo', $tipo->id)->where('descripcion', $info[1])->where('proyecto', $proyecto->id)->findOne();
self::reemplazar($unidad->id, $info[2], $fecha, $tr, $tv);
}
header('Location: ' . nUrl('precios', 'list', ['proyecto' => $proyecto->id]));
}
public static function add()
{
$proyecto = \model(Proyecto::class)->findOne(get('proyecto'));
return view('ventas.precios.add', compact('proyecto'));
}
public static function agregar()
{
$proyecto = get('proyecto');
$fecha = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$precios = [];
foreach (post() as $name => $valor) {
if ($valor == '' or strpos($name, 'precio') === false) {
continue;
}
list($tipo, $id) = explode(':', $name);
$tipo = trim(str_replace('precio', '', $tipo), '_');
$id = explode('-', $id);
switch (count($id)) {
case 1:
$precios []= ['tipo' => 'pt', 'id' => $id[0], 'valor' => $valor];
break;
case 2:
$exists = false;
foreach ($precios as $precio) {
if ($precio['tipo'] == 'pt' and $precio['id'] == $id[0]) {
$exists = true;
break;
}
}
if (!$exists) {
$precios []= ['tipo' => 'subtipo', 'id' => $id[1], 'pt' => $id[0], 'valor' => $valor];
}
break;
case 3:
$exists = false;
foreach ($precios as $precio) {
if ($precio['tipo'] == 'pt' and $precio['id'] == $id[0]) {
$exists = true;
break;
}
if ($precio['tipo'] == 'subtipo' and 'id' == $id[1] and 'pt' == $id[0]) {
$exists = true;
break;
}
}
if (!$exists) {
$precios []= ['tipo' => 'unidad', 'id' => $id[2], 'valor' => $valor];
}
break;
}
}
foreach ($precios as $precio) {
$precio = (object) $precio;
switch ($precio->tipo) {
case 'pt':
$pt = model(ProyectoTipoUnidad::class)->findOne($precio->id);
$pt->setPrecios($fecha, $precio->valor);
break;
case 'subtipo':
$pt = model(ProyectoTipoUnidad::class)->findOne($precio->pt);
$pt->setPreciosSubtipo($precios->id, $fecha, $precio->valor);
break;
case 'unidad':
$unidad = model(Unidad::class)->findOne($precio->id);
$unidad->setPrecio($fecha, $precio->valor);
break;
}
}
header('Location: ' . nUrl('precios', 'list', ['proyecto' => $proyecto]));
}
protected static function reemplazar(int $unidad_id, float $valor, \DateTime $fecha, int $tr = 0, int $tv = 0)
{
if ($tr == 0) {
$tr = model(TipoEstadoPrecio::class)->where('descripcion', 'reemplazado')->findOne()->id;
}
if ($tv == 0) {
$tv = model(TipoEstadoPrecio::class)->where('descripcion', 'vigente')->findOne()->id;
}
$olds = \model(Precio::class)->where('unidad', $unidad_id)->findMany();
if ($olds !== false) {
foreach ($olds as $old) {
if (!$old->vigente()) {
continue;
}
$data = [
'precio' => $old->id,
'fecha' => $fecha->format('Y-m-d'),
'estado' => $tr
];
$estado = \model(EstadoPrecio::class)->create($data);
$estado->save();
}
}
$data = [
'unidad' => $unidad_id,
'valor' => $valor
];
$precio = (new Factory(Precio::class))->where($data)->find();
if (!$precio) {
$precio = \model(Precio::class)->create($data);
$precio->save();
}
$data = [
'precio' => $precio->id,
'fecha' => $fecha->format('Y-m-d'),
'estado' => $tv
];
$estado = \model(EstadoPrecio::class)->create($data);
$estado->save();
}
}

View File

@ -0,0 +1,129 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Propietario;
use Incoviba\old\Common\Region;
use Incoviba\old\Common\Direccion;
use Incoviba\old\Venta\Venta;
class Propietarios
{
use Controller;
public static function edit()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$propietario = $venta->propietario();
$regiones = model(Region::class)->orderByAsc('numeracion')->findMany();
return view('ventas.propietarios.edit', compact('venta', 'propietario', 'regiones'));
}
public static function editar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$info = post();
list($info['rut'], $info['dv']) = explode('-', str_replace('.', '', $info['rut']));
$propietario = model(Propietario::class)->findOne($info['rut']);
if (!$propietario) {
$propietario = model(Propietario::class)->create();
}
if ($propietario->direccion != 0) {
$direccion = $propietario->direccion();
} else {
$direccion = model(Direccion::class)
->where('calle', post('calle'))
->where('numero', post('numero'))
->where('extra', post('extra'))
->where('comuna', post('comuna'))
->findOne();
if (!$direccion) {
$data = [
'calle' => post('calle'),
'numero' => post('numero'),
'extra' => post('extra'),
'comuna' => post('comuna')
];
$direccion = model(Direccion::class)->create($data);
}
}
if (isset($info['empresa'])) {
$info['apellido_paterno'] = '';
$info['apellido_materno'] = '';
}
if ($propietario->representante != 0) {
list($info['rep_rut'], $info['rep_dv']) = explode('-', str_replace('.', '', $info['rep_rut']));
$representante = $propietario->representante();
} elseif (isset($info['rep_rut'])) {
list($info['rep_rut'], $info['rep_dv']) = explode('-', str_replace('.', '', $info['rep_rut']));
$representante= model(Propietario::class)->findOne($info['rep_rut']);
if (!$representante) {
$representante= model(Propietario::class)->create();
}
}
$fields = ['rut', 'dv', 'nombres', 'apellido_paterno', 'apellido_materno'];
$change = false;
foreach ($fields as $key) {
if ($propietario->$key != $info[$key]) {
$propietario->$key = $info[$key];
$change = true;
}
}
if ($direccion->isNew()) {
$direccion->save();
}
if ($propietario->direccion != $direccion->id) {
$propietario->direccion = $direccion->id;
$change = true;
}
if ($change) {
d($propietario);
$propietario->save();
}
if (isset($info['rep_rut'])) {
$change = false;
if ($representante->rut != $info['rep_rut']) {
$representante->rut = $info['rep_rut'];
$representante->dv = $info['rep_dv'];
$change = true;
}
if ($representante->nombres != $info['rep_nombres']) {
$representante->nombres = $info['rep_nombres'];
$change = true;
}
if ($representante->apellido_paterno != $info['rep_apaterno']) {
$representante->apellido_paterno = $info['rep_apaterno'];
$change = true;
}
if ($representante->apellido_materno != $info['rep_amaterno']) {
$representante->apellido_materno = $info['rep_amaterno'];
$change = true;
}
if ($representante->direccion != $direccion->id) {
$representante->direccion = $direccion->id;
$change = true;
}
if ($change) {
$representante->save();
}
if ($propietario->representante != $representante->rut) {
$propietario->representante = $representante->rut;
$propietario->save();
}
}
if ($venta->propietario != $propietario->rut) {
$venta->propietario = $propietario->rut;
$venta->save();
}
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
}
?>

View File

@ -0,0 +1,77 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Proyecto\ProyectoTipoUnidad;
use Incoviba\old\Venta\Unidad;
use Incoviba\old\Venta\TipoUnidad;
class ProyectoTipoUnidades
{
use Controller;
protected static function setDefault()
{
self::$default = self::list();
}
public static function list()
{
d(get());
}
public static function edit()
{
$id = get('tipo_unidad');
$tipo = model(ProyectoTipoUnidad::class)->findOne($id);
$tipos = model(TipoUnidad::class)->findMany();
return view('proyectos.tipo_unidades.edit', compact('tipo', 'tipos'));
}
public static function editar()
{
$id = get('tipo_unidad');
$tipo = model(ProyectoTipoUnidad::class)->findOne($id);
$changed = false;
foreach (post() as $field => $value) {
if ($tipo->{$field} != $value) {
$tipo->{$field} = $value;
$changed = true;
}
}
if ($changed) {
$tipo->save();
}
header('Location: ' . nUrl('proyectos', 'list_unidades', ['proyecto' => $tipo->proyecto()->id]));
}
public static function add_unidad()
{
$id = get('tipo_unidad');
$tipo = model(ProyectoTipoUnidad::class)->findOne($id);
if ($tipo->tipo()->descripcion == 'departamento') {
return view('proyectos.unidades.add', compact('tipo'));
}
return view('proyectos.unidades.add2', compact('tipo'));
}
public static function assign()
{
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$tipos = model(ProyectoTipoUnidad::class)->where('proyecto', $proyecto->id)->findMany();
$libres = model(Unidad::class)->where('proyecto', $proyecto->id)->where('pt', 0)->findMany();
return view('proyectos.unidades.assign', compact('proyecto', 'tipos', 'libres'));
}
public static function asignar()
{
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$libres = model(Unidad::class)->where('proyecto', $proyecto->id)->where('pt', 0)->findMany();
foreach ($libres as $unidad) {
$unidad->pt = post('tipo' . $unidad->id);
$unidad->save();
}
header('Location: ' . nUrl('proyectos', 'list_unidades', ['proyecto' => $proyecto->id]));
}
}

View File

@ -0,0 +1,327 @@
<?php
namespace App\Controller;
use Carbon\Carbon;
use App\Definition\Controller;
use Incoviba\old\Common\Direccion;
use Incoviba\old\Common\Region;
use Incoviba\nuevo\Common\Direccion as D;
use Incoviba\old\Inmobiliaria\Inmobiliaria;
use Incoviba\old\Proyecto\AvanceConstruccion;
use Incoviba\old\Proyecto\EstadoProyecto;
use Incoviba\old\Proyecto\Pagare;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Proyecto\ProyectoTipoUnidad;
use Incoviba\old\Proyecto\TipoEstadoProyecto;
use Incoviba\old\Proyecto\TipoMonedaPagare;
use Incoviba\old\Venta\TipoUnidad;
use Incoviba\old\Venta\Unidad;
class Proyectos
{
use Controller;
protected static function setDefault()
{
self::$default = self::list();
}
public static function list()
{
$id_inmobiliaria = get('inmobiliaria');
if ($id_inmobiliaria != null) {
$proyectos = model(Proyecto::class)->where('inmobiliaria', $id_inmobiliaria);
} else {
$proyectos = model(Proyecto::class);
}
$proyectos = $proyectos->order_by_asc('descripcion')->findMany();
return view('proyectos.list', compact('proyectos'));
}
public static function show()
{
$id_proyecto = get('proyecto');
if ($id_proyecto == null) {
header('Location: ' . url('', ['p' => 'proyectos', 'a' => 'list']));
}
$proyecto = model(Proyecto::class)->findOne($id_proyecto);
$estados = model(TipoEstadoProyecto::class)->findMany();
foreach ($estados as &$estado) {
$estado = $estado->asArray()['orden'] + 1;
}
$colors = [];
$ventas_pt = (object) ['fields' => [], 'data' => [], 'totales' => [], 'vendidas' => []];
$ventas = $proyecto->ventas('fecha');
$months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
if (count($ventas) > 0) {
$inicio = $ventas[0]->fecha()->format('Y');
$fin = $ventas[count($ventas) - 1]->fecha()->format('Y');
$end = $ventas[count($ventas) - 1]->fecha()->format('M');
for ($y = $inicio; $y <= $fin; $y ++) {
foreach ($months as $month) {
$ventas_pt->fields []= $y . ' ' . $month;
if ($y == $fin and $month == $end) {
break;
}
}
}
}
foreach ($proyecto->tipologias() as $tipo) {
if (!isset($ventas_pt->data[$tipo->tipologia->descripcion])) {
$ventas_pt->data[$tipo->tipologia->descripcion] = [];
$ventas_pt->data[$tipo->tipologia->descripcion] = array_fill(0, count($ventas_pt->fields), 0);
$ventas_pt->totales[$tipo->tipologia->descripcion] = 0;
$ventas_pt->vendidas[$tipo->tipologia->descripcion] = 0;
}
foreach ($tipo->tipos as $pt) {
foreach ($pt->ventas('fecha') as $venta) {
$ventas_pt->data[$tipo->tipologia->descripcion][array_search($venta->fecha()->format('Y M'), $ventas_pt->fields)] ++;
$ventas_pt->vendidas[$tipo->tipologia->descripcion] ++;
}
$ventas_pt->totales[$tipo->tipologia->descripcion] += count($pt->unidades());
}
}
foreach ($ventas_pt->data as $tipo => $data) {
$acum = 0;
foreach ($data as $i => $cantidad) {
$acum += $cantidad;
$ventas_pt->data[$tipo][$i] = round($acum / $ventas_pt->totales[$tipo] * 100, 2);
}
}
$meses = ['Ene', 'Feb', 'Mar', 'Abr', 'May', 'Jun', 'Jul', 'Ago', 'Sep', 'Oct', 'Nov', 'Dic'];
array_walk($ventas_pt->fields, function(&$item) use ($meses, $months) {
$item = str_replace($months, $meses, $item);
});
for ($i = 0; $i < 10; $i ++) {
$colors[$i] = 'rgb(' . mt_rand(0, 255) . ', ' . mt_rand(0, 255) . ', ' . mt_rand(0, 255) . ')';
}
return view('proyectos.show', compact('proyecto', 'estados', 'colors', 'ventas_pt'));
}
public static function historial()
{
$proyecto = model(Proyecto::class)->findOne(get('proyecto'));
return view('proyectos.historia', compact('proyecto'));
}
public static function advance()
{
$id_proyecto = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id_proyecto);
$estados = model(TipoEstadoProyecto::class)->whereGt('orden', $proyecto->estado()->tipo()->orden)->orderByAsc('orden')->findMany();
return view('proyectos.advance', compact('proyecto', 'estados'));
}
public static function avanzar()
{
$id_proyecto = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id_proyecto);
$id_tipo = post('estado');
$tipo = model(TipoEstadoProyecto::class)->findOne($id_tipo);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$tipos = model(TipoEstadoProyecto::class)
->whereGt('orden', $proyecto->estado()->tipo()->orden)
->whereLte('orden', $tipo->orden)
->orderByAsc('orden')
->findMany();
foreach ($tipos as $t) {
$estado = model(EstadoProyecto::class)->create();
$estado->proyecto = $proyecto->id;
$estado->estado = $t->id;
$estado->fecha = $f->format('Y-m-d');
$estado->save();
}
header('Location: ' . url('', ['p' => 'proyectos', 'a' => 'show', 'proyecto' => $proyecto->id]));
}
public static function avance()
{
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$av = post('avance') / 100;
$ep = (double) post('estado_pago');
$avance = model(AvanceConstruccion::class)
->where('proyecto', $proyecto->id)
->where('fecha', $f->format('Y-m-d'))
->findOne();
if (!$avance) {
$data = [
'proyecto' => $proyecto->id,
'fecha' => $f->format('Y-m-d'),
'numero' => post('numero'),
'avance' => $av,
'estado_pago' => $ep
];
$avance = model(AvanceConstruccion::class)->create($data);
}
$avance->save();
header('Location: ' . url('', ['p' => 'proyectos', 'a' => 'historial', 'proyecto' => $proyecto->id]));
}
public static function add()
{
$rut = get('inmobiliaria');
$inmobiliarias = model(Inmobiliaria::class)->orderByAsc('abreviacion')->findMany();
$regiones = model(Region::class)->orderByAsc('numeracion')->findMany();
return view('proyectos.add', compact('inmobiliarias', 'rut', 'regiones'));
}
public static function agregar()
{
$proyecto = model(Proyecto::class)->where('descripcion', post('descripcion'))->where('inmobiliaria', post('inmobiliaria'))->find_one();
if ($proyecto) {
header('Location: ' . url('', ['p' => 'proyectos', 'a' => 'show', 'proyecto' => $proyecto->id]));
die();
}
$proyecto = model(Proyecto::class)->create();
$proyecto->descripcion = post('descripcion');
$proyecto->inmobiliaria = post('inmobiliaria');
$direccion = model(Direccion::class)
->where('calle', post('calle'))
->where('numero', post('numero'))
->where('extra', post('extra'))
->where('comuna', post('comuna'))
->findOne();
if (!$direccion) {
$direccion = model(Direccion::class)->create();
$direccion->calle = post('calle');
$direccion->numero = post('numero');
$direccion->extra = post('extra');
$direccion->comuna = post('comuna');
$direccion->save();
}
$proyecto->direccion = $direccion->id;
$proyecto->save();
$fecha = Carbon::parse(post('year'), post('month'), post('day'), config('app.timezone'));
$estado = model(EstadoProyecto::class)->create();
$estado->proyecto = $proyecto->id;
$estado->estado = 1;
$estado->fecha = $fecha->format('Y-m-d');
$estado->save();
header('Location: ' . url('', ['p' => 'proyectos', 'a' => 'show', 'proyecto' => $proyecto->id]));
}
public static function disponibles()
{
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
return view('proyectos.disponibles', compact('proyecto'));
}
public static function list_unidades()
{
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$libres = model(Unidad::class)->where('proyecto', $proyecto->id)->where('pt', 0)->findMany();
return view('proyectos.unidades.list', compact('proyecto', 'libres'));
}
public static function add_tipo_unidad()
{
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$tipos = model(TipoUnidad::class)->findMany();
return view('proyectos.tipo_unidades.add', compact('proyecto', 'tipos'));
}
public static function agregar_tipo_unidad()
{
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
$data = post();
$data['proyecto'] = $proyecto->id;
$tipo = model(ProyectoTipoUnidad::class)->where('proyecto', $data['proyecto'])
->where('tipo', $data['tipo'])->where('nombre', $data['nombre'])->findOne();
if ($tipo === false) {
$tipo = model(ProyectoTipoUnidad::class)->create($data);
$tipo->save();
}
header('Location: ' . nUrl('proyectos', 'list_unidades', ['proyecto' => $proyecto->id]));
}
public static function construccion()
{
$id = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id);
return view('proyectos.construccion', compact('proyecto'));
}
public static function editar_avance()
{
$avance = model(AvanceConstruccion::class)->findOne(get('avance'));
return view('proyectos.avances.edit', compact('avance'));
}
public static function edit_avance()
{
$avance = model(AvanceConstruccion::class)->findOne(get('avance'));
$cols = [
'day',
'month',
'year',
'avance',
'estado_pago',
'pagado',
'day_pago',
'month_pago',
'year_pago'
];
$data = array_filter(post(), function($key) use ($cols) {
return (array_search($key, $cols) !== false);
}, \ARRAY_FILTER_USE_KEY);
$data['fecha'] = implode('-', [$data['year'], $data['month'], $data['day']]);
unset($data['year']);
unset($data['month']);
unset($data['day']);
$data['fecha_pagado'] = implode('-', [$data['year_pago'], $data['month_pago'], $data['day_pago']]);
unset($data['year_pago']);
unset($data['month_pago']);
unset($data['day_pago']);
$data['avance'] /= 100;
$avance->edit($data);
header('Location: ' . nUrl('proyectos', 'construccion', ['proyecto' => $avance->proyecto]));
}
public static function reservas()
{
$proyecto = model(Proyecto::class)->findOne(get('proyecto'));
$pisos = [];
$totales = [];
foreach ($proyecto->unidades('departamento') as $unidad) {
if (!isset($pisos[$unidad->piso - 1])) {
$piso = (object) ['descripcion' => $unidad->piso, 'unidades' => []];
$pisos[$unidad->piso - 1] = $piso;
}
if (!isset($totales[$unidad->linea()])) {
$totales[$unidad->linea()] = (object) ['ventas' => 0, 'reservas' => 0];
}
$pisos[$unidad->piso - 1]->unidades[$unidad->linea()] = $unidad;
if ($unidad->isVendida()) {
$totales[$unidad->linea()]->ventas ++;
}
if ($unidad->isReservada()) {
$totales[$unidad->linea()]->reservas ++;
}
}
ksort($pisos);
$max_unidades = 0;
foreach ($pisos as $piso) {
if (count($piso->unidades) > $max_unidades) {
$max_unidades = count($piso->unidades);
}
}
return view('proyectos.reservas.base', compact('proyecto', 'pisos', 'max_unidades', 'totales'));
}
public function unidades()
{
if (get('proyecto')) {
$proyecto = model(Proyecto::class)->findOne(get('proyecto'));
$libres = model(Unidad::class)->where('proyecto', $proyecto->id)->where('pt', 0)->findMany();
return view('proyectos.unidades.list', compact('proyecto', 'libres'));
}
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->findMany();
return view('proyectos.unidades.proyectos', compact('proyectos'));
}
}
?>

View File

@ -0,0 +1,90 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Venta\Venta;
use Incoviba\old\Venta\EstadoPago;
use Carbon\Carbon;
class Reajustes
{
use Controller;
public static function edit()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.pies.reajustes.edit', compact('venta'));
}
public static function editar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$uf = uf($f);
$valor = correctNumber(post('valor'));
if ($valor == '') {
$valor_uf = correctNumber(post('valor_uf'));
$valor = $valor_uf * $uf->uf->value;
}
$pago = $venta->pie()->reajuste();
if ($pago->valor != $valor) {
$pago->valor = $valor;
}
if ($pago->fecha != $f->format('Y-m-d')) {
$pago->fecha = $f->format('Y-m-d');
$pago->uf = $uf->uf->value;
}
$pago->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function pagar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.pies.reajustes.pagar', compact('venta'));
}
public static function pagado()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$data = [
'pago' => $venta->pie()->reajuste()->id,
'fecha' => $f->format('Y-m-d'),
'estado' => 1
];
$estado = model(EstadoPago::class)->create($data);
$estado->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function abonar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.pies.reajustes.abonar', compact('venta'));
}
public static function abonado()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$data = [
'pago' => $venta->pie()->reajuste()->id,
'fecha' => $f->format('Y-m-d'),
'estado' => 2
];
$estado = model(EstadoPago::class)->create($data);
$estado->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
}
?>

View File

@ -0,0 +1,39 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use App\Helper\Color;
use App\Helper\Line;
use Incoviba\common\Registry as RModel;
class Registros
{
use Controller;
public static function list()
{
$registros = model(RModel::class)->orderByDesc('time')->findMany();
$ini = new Color(0, 100, 0);
$end = new Color(255, 255, 255);
$colores = self::colores($end, $ini, 100);
return view('admin.registros.list', compact('registros', 'colores'));
}
public static function show()
{
$registro = model(RModel::class)->findOne(get('registro'));
$ini = new Color(0, 100, 0);
$end = new Color(255, 255, 255);
$colores = self::colores($end, $ini, 100);
return view('admin.registros.show', compact('registro', 'colores'));
}
protected static function colores($ini, $end, $max)
{
$current = $ini->toVector();
$colores = [];
$line = new Line($ini->toVector(), $end->toVector());
for ($i = 0; $i < $max; $i ++) {
$colores[$i] = new Color($current);
$current = $line->move($current, $line->length() / $max);
}
return $colores;
}
}

View File

@ -0,0 +1,184 @@
<?php
namespace App\Controller;
use Carbon\Carbon;
use App\Definition\Controller;
use Incoviba\old\Venta\Venta;
use Incoviba\old\Venta\Subsidio;
use Incoviba\old\Venta\Pago;
use Incoviba\old\Venta\EstadoPago;
use Incoviba\old\Venta\TipoEstadoPago;
class Subsidios
{
use Controller;
public static function add()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
echo view('ventas.subsidios.add', compact('venta'));
}
public static function do_add()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$uf = uf($f);
$pago1 = model(Pago::class)->create();
$valor = post('ahorro_uf') * $uf->uf->value;
if (post('ahorro') != null) {
$valor = post('ahorro');
}
$pago1->valor = $valor;
$pago1->fecha = $f->format('Y-m-d');
$pago1->uf = $uf->uf->value;
$pago2 = model(Pago::class)->create();
$valor = post('subsidio_uf') * $uf->uf->value;
if (post('subsidio') != null) {
$valor = post('subsidio');
}
$pago2->valor = $valor;
$pago2->fecha = $f->format('Y-m-d');
$pago2->uf = $uf->uf->value;
$pago1->new();
$pago2->new();
$subsidio = model(Subsidio::class)->create();
$subsidio->pago = $pago1->id;
$subsidio->subsidio = $pago2->id;
$subsidio->save();
$venta->subsidio = $subsidio->id();
$venta->save();
header('Location: ' . nUrl('ventas', 'show', ['venta' => $venta->id]));
}
public static function edit()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
echo view('ventas.subsidios.edit', compact('venta'));
}
public static function do_edit()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$uf = uf($f);
$pago1 = $venta->subsidio()->pago();
$valor = post('ahorro_uf') * $uf->uf->value;
if (post('ahorro') != null) {
$valor = post('ahorro');
}
$pago1->valor = $valor;
$pago1->fecha = $f->format('Y-m-d');
$pago1->uf = $uf->uf->value;
$pago2 = $venta->subsidio()->subsidio();
$valor = post('subsidio_uf') * $uf->uf->value;
if (post('subsidio') != null) {
$valor = post('subsidio');
}
$pago2->valor = $valor;
$pago2->fecha = $f->format('Y-m-d');
$pago2->uf = $uf->uf->value;
$pago1->save();
$pago2->save();
header('Location: ' . nUrl('ventas', 'show', ['venta' => $venta->id]));
}
public static function pagar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$tipo = get('tipo');
switch($tipo) {
case 'subsidio':
$pago = $venta->subsidio()->subsidio();
break;
case 'pago':
$pago = $venta->subsidio()->pago();
break;
default:
$pago = null;
}
echo view('ventas.subsidios.pagar', compact('venta', 'pago'));
}
public static function do_pagar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$tipo = post('tipo');
switch($tipo) {
case 'subsidio':
$pago = $venta->subsidio()->subsidio();
break;
case 'pago':
$pago = $venta->subsidio()->pago();
break;
default:
$pago = null;
}
$pago->valor = post('valor');
$tipo = model(TipoEstadoPago::class)->where('descripcion', 'depositado')->findOne();
$data = [
'pago' => $pago->id,
'fecha' => $f->format('Y-m-d'),
'estado' => $tipo->id
];
$estado = model(EstadoPago::class)->create($data);
$pago->save();
$estado->save();
header('Location: ' . nUrl('ventas', 'show', ['venta' => $venta->id]));
}
public static function abonar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$tipo = get('tipo');
switch($tipo) {
case 'subsidio':
$pago = $venta->subsidio()->subsidio();
break;
case 'pago':
$pago = $venta->subsidio()->pago();
break;
default:
$pago = null;
}
echo view('ventas.subsidios.abonar', compact('venta', 'pago'));
}
public static function do_abonar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$tipo = post('tipo');
switch($tipo) {
case 'subsidio':
$pago = $venta->subsidio()->subsidio();
break;
case 'pago':
$pago = $venta->subsidio()->pago();
break;
default:
$pago = null;
}
$pago->valor = post('valor');
$tipo = model(TipoEstadoPago::class)->where('descripcion', 'abonado')->findOne();
$data = [
'pago' => $pago->id,
'fecha' => $f->format('Y-m-d'),
'estado' => $tipo->id
];
$estado = model(EstadoPago::class)->create($data);
$pago->save();
$estado->save();
header('Location: ' . nUrl('ventas', 'show', ['venta' => $venta->id]));
}
}

111
app/Controller/Temas.php Normal file
View File

@ -0,0 +1,111 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Proyecto\Proyecto;
use Carbon\Carbon;
use Incoviba\nuevo\Proyecto\Tema;
class Temas
{
use Controller;
public static function add()
{
$proyectos = model(Proyecto::class)->orderByAsc('descripcion')->findMany();
return view('temas.add', compact('proyectos'));
}
public static function agregar()
{
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$data = [
"proyecto_id" => post('proyecto'),
"inicio" => $f->format('Y-m-d'),
"texto" => post('texto')
];
$tema = model(Tema::class)->create($data);
$tema->save();
header('Location: ' . url('', ['p' => 'temas', 'a' => 'list']));
}
public static function list()
{
$temas = model(Tema::class)->findMany();
$t = Carbon::today(config('app.timezone'));
foreach ($temas as $i => $tema) {
if ($tema->cierre()->year != -1 and $t->diff($tema->cierre())->days > 10) {
unset($temas[$i]);
}
}
$temas = array_values($temas);
usort($temas, function($a, $b) {
$p = strcmp($a->proyecto()->descripcion, $b->proyecto()->descripcion);
if ($p == 0) {
$f = $b->inicio()->diff($a->inicio())->format('%r%a');
if ($f == 0) {
return $a->id - $b->id;
}
return $f;
}
return $p;
});
return view('temas.list', compact('temas'));
}
public static function edit()
{
$id = get('tema');
$tema = model(Tema::class)->findOne($id);
$proyectos = model(Proyecto::class)->orderByAsc('descripcion')->findMany();
return view('temas.edit', compact('tema', 'proyectos'));
}
public static function editar()
{
$id = get('tema');
$tema = model(Tema::class)->findOne($id);
$proyecto = post('proyecto');
$changed = false;
if ($tema->proyecto_id != $proyecto) {
$tema->proyecto_id = $proyecto;
$changed = true;
}
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
if ($tema->inicio() != $f) {
$tema->inicio = $f->format('Y-m-d');
$changed = true;
}
$texto = post('texto');
if ($tema->texto != $texto) {
$tema->texto = $texto;
$changed = true;
}
if ($changed) {
$tema->save();
}
header('Location: ' . url('', ['p' => 'temas', 'a' => 'list']));
}
public static function cerrar()
{
$id = get('tema');
$tema = model(Tema::class)->findOne($id);
$f = Carbon::today(config('app.timezone'));
$tema->cierre = $f->format('Y-m-d');
$tema->save();
header('Location: ' . url('', ['p' => 'temas', 'a' => 'list']));
}
public static function abrir()
{
$id = get('tema');
$tema = model(Tema::class)->findOne($id)->as_array();
unset($tema['id'], $tema['cierre'], $tema['created_at'], $tema['updated_at']);
$tema = model(Tema::class)->create($tema);
$tema->save();
header('Location: ' . url('', ['p' => 'temas', 'a' => 'list']));
}
}
?>

126
app/Controller/Unidades.php Normal file
View File

@ -0,0 +1,126 @@
<?php
namespace App\Controller;
use App\Definition\Controller;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Venta\TipoUnidad;
use Incoviba\old\Proyecto\ProyectoTipoUnidad;
use Incoviba\old\Venta\Unidad;
class Unidades
{
use Controller;
public static function agregar()
{
$id = get('tipo');
$tipo = model(ProyectoTipoUnidad::class)->findOne($id);
$len = strlen(post('total'));
$unis = json_decode(post('unidades'));
$data = [];
foreach ($unis as $n_unidad) {
if ($tipo->tipo()->descripcion == 'departamento') {
$ini = post('piso_ini' . $n_unidad);
$end = post('piso_end' . $n_unidad);
$subtipo = post('linea' . $n_unidad);
$orientacion = post('orientacion' . $n_unidad);
for ($piso = $ini; $piso <= $end; $piso ++) {
$descripcion = $piso . str_pad(post('linea' . $n_unidad), $len, '0', \STR_PAD_LEFT);
$data []= [
'proyecto' => $tipo->proyecto()->id,
'tipo' => $tipo->tipo()->id,
'subtipo' => $subtipo,
'piso' => $piso,
'descripcion' => $descripcion,
'abreviacion' => $tipo->abreviacion,
'm2' => $tipo->m2,
'terraza' => $tipo->terraza,
'logia' => $tipo->logia,
'orientacion' => $orientacion,
'pt' => $tipo->id
];
}
} else {
$descripcion = post('descripcion' . $n_unidad);
$piso = post('piso' . $n_unidad);
$data []= [
'proyecto' => $tipo->proyecto()->id,
'tipo' => $tipo->tipo()->id,
'piso' => $piso,
'descripcion' => $descripcion,
'abreviacion' => $tipo->abreviacion,
'm2' => $tipo->m2,
'terraza' => $tipo->terraza,
'logia' => $tipo->logia,
'pt' => $tipo->id
];
}
}
foreach ($data as $uni) {
$unidad = model(Unidad::class)
->where('descripcion', $uni['descripcion'])
->where('proyecto', $uni['proyecto'])
->where('tipo', $uni['tipo'])
->findOne();
if ($unidad) {
continue;
}
$unidad = model(Unidad::class)->create($uni);
$unidad->save();
}
header('Location: ' . url('', ['p' => 'proyectos', 'a' => 'list_unidades', 'proyecto' => $tipo->proyecto()->id]));
}
public static function edit()
{
$id = get('unidad');
$unidad = model(Unidad::class)->findOne($id);
$tipos = model(ProyectoTipoUnidad::class)->where('proyecto', $unidad->proyecto()->id)->findMany();
$abreviaciones = ['N', 'NE', 'E', 'SE', 'S', 'SO', 'O', 'NO'];
$descripciones = ['Norte', 'Noreste', 'Este', 'Sureste', 'Sur', 'Suroeste', 'Oeste', 'Noroeste'];
$orientaciones = [];
foreach ($abreviaciones as $i => $ab) {
$orientaciones []= (object) ['abreviacion' => $ab, 'descripcion' => $descripciones[$i]];
}
return view('proyectos.unidades.edit', compact('unidad', 'tipos', 'orientaciones'));
}
public static function editar()
{
$id = get('unidad');
$unidad = model(Unidad::class)->findOne($id);
$change = false;
$fields = ['descripcion', 'tipo', 'piso', 'linea', 'orientacion'];
foreach ($fields as $field) {
$f = $field;
if ($f == 'tipo') {
$f = 'pt';
}
if ($f == 'linea') {
$f = 'subtipo';
}
if ($unidad->{$f} != post($field)) {
$unidad->{$f} = post($field);
$change = true;
}
}
if ($change) {
$unidad->save();
}
header('Location: ' . nUrl('proyectos', 'list_unidades', ['proyecto' => $unidad->proyecto()->id]));
}
public static function remove()
{
$id = get('unidad');
$unidad = model(Unidad::class)->findOne($id);
$unidad->delete();
$id = get('proyecto');
header('Location: ' . nUrl('proyectos', 'list_unidades', ['proyecto' => $id]));
}
}
?>

View File

@ -0,0 +1,83 @@
<?php
namespace App\Controller;
use Carbon\Carbon;
use App\Definition\Controller;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Proyecto\ProyectoAgente;
use Incoviba\old\Venta\Unidad;
use Incoviba\old\Venta\UnidadBloqueada;
class UnidadesBloqueadas
{
use Controller;
public static function list()
{
$proyectos = model(Proyecto::class)->findMany();
echo view('ventas.operadores.unidades.list', compact('proyectos'));
}
public static function add()
{
$proyectos = model(Proyecto::class)->findMany();
echo view('ventas.operadores.unidades.add', compact('proyectos'));
}
public static function bloquear()
{
$operador = model(ProyectoAgente::class)->findOne(get('operador'));
echo view('ventas.operadores.unidades.bloquear', compact('operador'));
}
public static function do_bloquear()
{
$operador = model(ProyectoAgente::class)->findOne(get('operador'));
$fecha = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$unidades = self::getUnidades([], 'departamentos', 1);
$unidades = self::getUnidades($unidades, 'estacionamientos', 2);
$unidades = self::getUnidades($unidades, 'bodegas', 3);
if (post('unidad') != null) {
foreach (post('unidad') as $u) {
$unidad = model(Unidad::class)->findOne($u);
if (array_search($unidad, $unidades) === false) {
$unidades []= $unidad;
}
}
}
foreach ($unidades as $unidad) {
$data = [
'agente' => $operador->id,
'unidad' => $unidad->id
];
$ub = model(UnidadBloqueada::class)->create($data);
$ub->new($fecha);
}
header('Location: ' . nUrl('unidades_bloqueadas', 'list'));
}
protected static function getUnidades(array $unidades, string $name, int $tipo): array
{
if (trim(post($name)) == '') {
return $unidades;
}
$unis = [];
$separators = [PHP_EOL, ';', ',', '-'];
foreach ($separators as $separator) {
if (strpos(post($name), $separator) !== false) {
$unis = explode($separator, post($name));
break;
}
}
if (count($unis) == 0) {
return $unidades;
}
array_walk($unis, function(&$item) {
$item = trim($item);
$item = model(Unidad::class)->where('descripcion', $item)->where('tipo', 1)->findOne();
});
foreach ($unis as $uni) {
if (array_search($uni, $unidades) === false) {
$unidades []= $uni;
}
}
return $unidades;
}
}

598
app/Controller/Ventas.php Normal file
View File

@ -0,0 +1,598 @@
<?php
namespace App\Controller;
use Carbon\Carbon;
use App\Definition\Controller;
use Incoviba\old\Common\Banco;
use Incoviba\old\Common\Direccion;
use Incoviba\old\Common\Region;
use Incoviba\old\Proyecto\Agente;
use Incoviba\old\Proyecto\Proyecto;
use Incoviba\old\Venta\BonoPie;
use Incoviba\old\Venta\Credito;
use Incoviba\old\Venta\EstadoVenta;
use Incoviba\old\Venta\Pago;
use Incoviba\old\Venta\Pie;
use Incoviba\old\Venta\Promocion;
use Incoviba\old\Venta\PromocionVenta;
use Incoviba\old\Venta\Propiedad;
use Incoviba\old\Venta\PropiedadUnidad;
use Incoviba\old\Venta\Propietario;
use Incoviba\old\Venta\TipoEstadoVenta;
use Incoviba\old\Venta\Unidad;
use Incoviba\old\Venta\Venta;
class Ventas
{
use Controller;
protected static function setDefault()
{
self::$default = self::list();
}
public static function list()
{
$proyecto = get('proyecto');
if ($proyecto == null) {
return self::listProyectos();
}
$proyecto = model(Proyecto::class)->findOne($proyecto);
$ventas = $proyecto->ventas();
self::sort($ventas);
return view('ventas.list', compact('proyecto', 'ventas'));
}
protected static function sort(&$ventas)
{
$sort = get('sort');
if ($sort == null) {
$sort = 'departamento';
}
$direction = get('sort_dir');
if ($direction == null) {
$direction = 1;
}
switch ($sort) {
case 'departamento':
usort($ventas, function($a, $b) use ($direction) {
return ($a->propiedad()->unidad()->descripcion - $b->propiedad()->unidad()->descripcion) * $direction;
});
break;
case 'propietario':
usort($ventas, function($a, $b) use ($direction) {
$pa = trim($a->propietario()->nombreCompleto(true), ', ');
$pb = trim($b->propietario()->nombreCompleto(true), ', ');
return $direction * strcasecmp($pa, $pb);
});
break;
case 'valor_uf':
usort($ventas, function($a, $b) use ($direction) {
return $direction * ($a->valor_uf - $b->valor_uf);
});
break;
case 'uf_m2':
usort($ventas, function($a, $b) use ($direction) {
return $direction * ($a->uf_m2() - $b->uf_m2());
});
break;
case 'fecha_venta':
usort($ventas, function($a, $b) use ($direction) {
return ($a->fecha()->timestamp - $b->fecha()->timestamp) * $direction;
});
break;
}
if ($direction == 'desc') {
$ventas = array_reverse($ventas);
}
}
public static function listProyectos()
{
$proyectos = model(Proyecto::class)
->select('proyecto.*')
->join('estado_proyecto', ['estado.proyecto', '=', 'proyecto.id'], 'estado')
->join('tipo_estado_proyecto', ['tipo.id', '=', 'estado.estado'], 'tipo')
->join('etapa_proyecto', ['etapa.id', '=', 'tipo.etapa'], 'etapa')
->whereGte('etapa.orden', 4)
->orderByAsc('proyecto.descripcion')
->groupBy('proyecto.id')
->findMany();
echo view('ventas.proyectos', compact('proyectos'));
}
public static function show()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.show', compact('venta'));
}
public static function new()
{
$proyectos = model(Proyecto::class)
->select('proyecto.*')
->join('estado_proyecto', ['estado.proyecto', '=', 'proyecto.id'], 'estado')
->join('tipo_estado_proyecto', ['tipo.id', '=', 'estado.estado'], 'tipo')
->join('etapa_proyecto', ['etapa.id', '=', 'tipo.etapa'], 'etapa')
->whereGte('etapa.orden', 3)
->orderByAsc('proyecto.descripcion')
->groupBy('proyecto.id')
->findMany();
$regiones = model(Region::class)->order_by_asc('numeracion')->findMany();
return view('ventas.add', compact('proyectos', 'regiones'));
}
public static function agregar()
{
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$t = Carbon::today(config('app.timezone'));
$uf = uf($f);
$calle = trim(post('calle'));
$numero = post('numero');
$extra = trim(post('extra'));
$comuna = post('comuna');
$direccion = model(Direccion::class)
->where('calle', $calle)
->where('numero', $numero)
->where('extra', $extra)
->where('comuna', $comuna)
->findOne();
if (!$direccion) {
$direccion = model(Direccion::class)->create();
$direccion->calle = $calle;
$direccion->numero = $numero;
$direccion->extra = $extra;
$direccion->comuna = $comuna;
$direccion->save();
}
list($rut, $dv) = explode('-', str_replace('.', '', post('rut')));
$propietario = model(Propietario::class)->where('rut', $rut)->findOne();
if (!$propietario) {
$propietario = model(Propietario::class)->create();
$propietario->rut = $rut;
$propietario->dv = $dv;
$propietario->nombres = trim(post('nombres'));
$propietario->apellido_paterno = trim(post('paterno'));
$propietario->apellido_materno = trim(post('materno'));
$propietario->direccion = $direccion->id;
if (post('otro') != null) {
$propietario->otro = 1;
}
$propietario->save();
}
$unis = json_decode(post('unidades'));
$id_principal = array_shift($unis);
$principal = model(Unidad::class)->findOne(post('unidad' . $id_principal));
$propiedad = model(Propiedad::class)
->select('propiedad.*')
->join('unidad', ['unidad.id', '=', 'propiedad.unidad_principal'])
->where('propiedad.unidad_principal', $principal->id)
->where('unidad.proyecto', post('proyecto'))
->orderByDesc('propiedad.id')
->findOne();
// Revisar si existe la propiedad y si está vigente.
if (!$propiedad or ($propiedad->venta() and $propiedad->venta()->estado() and $propiedad->venta()->estado()->tipo()->descripcion != 'vigente')) {
if (!$propiedad) {
$propiedad = model(Propiedad::class)->create();
}
$propiedad->unidad_principal = $principal->id;
$propiedad->save();
$data = [
'propiedad' => $propiedad->id,
'unidad' => $principal->id,
'principal' => 1
];
$pu = model(PropiedadUnidad::class)->create($data);
$pu->save();
foreach ($unis as $id_unidad) {
$data = [
'propiedad' => $propiedad->id,
'unidad' => post('unidad' . $id_unidad),
'principal' => 0
];
$pu = model(PropiedadUnidad::class)->create($data);
$pu->save();
}
/*$ests = [];
$bods = [];
foreach ($unis as $id_unidad) {
$unidad = model(Unidad::class)->findOne(post('unidad' . $id_unidad));
if ($unidad->tipo == 2) {
$ests []= $unidad->id;
}
if ($unidad->tipo == 3) {
$bods []= $unidad->id;
}
}
$propiedad->estacionamientos = implode(';', $ests);
$propiedad->bodegas = implode(';', $bods);
$propiedad->save();*/
} elseif ($propiedad->venta() and $propiedad->venta()->estado()->tipo()->descripcion == 'vigente') {
// Existe la propiedad en este proyecto y está vigente. Error, no se debiese vender si está vigente.
throw new \Exception('Existe la propiedad en este proyecto y está vigente. Error, no se debiese vender si está vigente.');
}
$venta = model(Venta::class)->create();
$venta->propietario = $propietario->rut;
$venta->propiedad = $propiedad->id;
if (post('pie')) {
$pie = model(Pie::class)->create();
$pie->valor = post('pie');
$pie->fecha = $f->format('Y-m-d');
$pie->cuotas = post('cuotas');
$pie->uf = $uf->uf->value;
$pie->save();
$venta->pie = $pie->id;
}
if (post('bono_pie')) {
$bono = model(BonoPie::class)->create();
$bono->valor = post('bono_pie');
$pago = model(Pago::class)->create();
$pago->fecha = $f->format('Y-m-d');
$pago->uf = $uf->uf->value;
$pago->valor = $bono->valor * $uf->uf->value;
$pago->tipo = 8;
$pago->new();
$bono->pago = $pago->id;
$bono->save();
$venta->bono_pie = $bono->id;
}
if (post('credito')) {
$pago = model(Pago::class)->create();
$pago->fecha = $f->format('Y-m-d');
$pago->uf = $uf->uf->value;
$pago->valor = post('credito') * $uf->uf->value;
$pago->tipo = 2;
$pago->new();
$credito = model(Credito::class)->create();
$credito->pago = $pago->id;
$credito->save();
$venta->credito = $credito->id;
}
$venta->fecha = $f->format('Y-m-d');
$venta->valor_uf = post('valor');
$venta->fecha_ingreso = $t->format('Y-m-d');
if (post('operador') != 0) {
$venta->agente = post('operador');
}
$venta->uf = $uf->uf->value;
$venta->new();
if (post('promociones') != 0) {
$promos = json_decode(post('promociones'));
foreach ($promos as $id_promo) {
$promocion = model(Promocion::class)->findOne(post('promocion' . $id_promo));
$promo = model(PromocionVenta::class)->create();
$promo->promocion = $promocion->id;
$promo->venta = $venta->id;
$promo->valor = post('promo' . $id_promo);
$promo->save();
}
}
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function edit()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->findMany();
$regiones = model(Region::class)->order_by_asc('numeracion')->findMany();
return view('ventas.edit', compact('venta', 'proyectos', 'regiones'));
}
public static function editar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$uf = uf($f);
$valor = correctNumber(post('valor'));
$change = false;
if ($venta->fecha != $f->format('Y-m-d')) {
$venta->fecha = $f->format('Y-m-d');
$venta->uf = $uf->uf->value;
$change = true;
}
if ($venta->valor_uf != $valor) {
$venta->valor_uf = $valor;
$change = true;
}
if ($change) {
$venta->save();
}
$direccion = $venta->propietario()->direccion();
$calle = post('calle');
$numero = post('numero');
$extra = post('extra');
$comuna = post('comuna');
$change = false;
if ($direccion->calle != $calle) {
$direccion->calle = $calle;
$change = true;
}
if ($direccion->numero != $numero) {
$direccion->numero = $numero;
$change = true;
}
if ($direccion->extra != $extra) {
$direccion->extra = $extra;
$change = true;
}
if ($direccion->comuna != $comuna) {
$direccion->comuna = $comuna;
$change = true;
}
if ($change) {
$direccion->save();
}
$propietario = $venta->propietario();
list($rut, $dv) = explode('-', str_replace('.', '', post('rut')));
$nombres = post('nombres');
$paterno = post('paterno');
$materno = post('materno');
$change = false;
if ($propietario->rut != $rut) {
$propietario->rut = $rut;
$propietario->dv = $dv;
$venta->propietario = $rut;
$venta->save();
$change = true;
}
if ($propietario->nombres != $nombres) {
$propietario->nombres = $nombres;
$change = true;
}
if ($propietario->apellido_paterno != $paterno) {
$propietario->apellido_paterno = $paterno;
$change = true;
}
if ($propietario->apellido_materno != $materno) {
$propietario->apellido_materno = $materno;
$change = true;
}
if ($change) {
$propietario->save();
}
$unidades = json_decode(post('unidades'));
if (count($unidades) > 0) {
$propiedad = $venta->propiedad();
$ests = explode(';', $propiedad->estacionamientos);
$bods = explode(';', $propiedad->bodegas);
$change = false;
foreach ($unidades as $n) {
$id = post('unidad' . $n);
$unidad = model(Unidad::class)->findOne($id);
if ($unidad->tipo == 1 and $propiedad->unidad_principal != $unidad->id) {
$propiedad->unidad_principal = $unidad->id;
$change = true;
}
if ($unidad->tipo == 2 and array_search($unidad->id, $ests) === false) {
$ests []= $unidad->id;
}
if ($unidad->tipo == 3 and array_search($unidad->id, $bods) === false) {
$bods []= $unidad->id;
}
}
$ests = implode(';', $ests);
$bods = implode(';', $bods);
if ($propiedad->estacionamientos != $ests) {
$propiedad->estacionamientos = $ests;
$change = true;
}
if ($propiedad->bodegas != $bods) {
$propiedad->bodegas = $bods;
$change = true;
}
if ($change) {
$propiedad->save();
}
}
if (post('pie')) {
$pie = $venta->pie();
$valor = correctNumber(post('pie'));
$cuotas = post('cuotas');
$change = false;
if ($pie->valor != $valor) {
$pie->valor = $valor;
$change = true;
}
if ($pie->cuotas != $cuotas) {
$pie->cuotas = $cuotas;
$change = true;
}
if ($change) {
$pie->save();
}
}
$credito = $venta->credito();
$valor = post('credito');
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function desistir()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.desist', compact('venta'));
}
public static function desistiendo()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$valor = correctNumber(post('pago'));
$uf = uf($f);
$venta->estado = 0;
$tipo = model(TipoEstadoVenta::class)->where('descripcion', 'desistida')->findOne();
$data = [
'venta' => $venta->id,
'estado' => $tipo->id,
'fecha' => $f->format('Y-m-d')
];
$estado = model(EstadoVenta::class)->create($data);
$propiedad = $venta->propiedad();
$propiedad->estado = 0;
$pago = model(Pago::class)->create();
$pago->fecha = $f->format('Y-m-d');
$pago->valor = (double) $valor;
$pago->uf = $uf->uf->value;
$pago->tipo = 1;
$pago->new();
$propiedad->save();
$estado->save();
$venta->resciliacion = $pago->id;
$venta->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function ceder()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.ceder', compact('venta'));
}
public static function cediendo()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$valor = correctNumber(post('pago'));
$uf = uf($f);
$venta->estado = -1;
$tipo = model(TipoEstadoVenta::class)->where('descripcion', 'cedida')->findOne();
$data = [
'venta' => $venta->id,
'estado' => $tipo->id,
'fecha' => $f->format('Y-m-d')
];
$estado = model(EstadoVenta::class)->create($data);
$propiedad = $venta->propiedad();
$propiedad->estado = 0;
$pago = model(Pago::class)->create();
$pago->fecha = $f->format('Y-m-d');
$pago->valor = $valor;
$pago->uf = $uf->uf->value;
$pago->tipo = 1;
$pago->new();
$propiedad->save();
$estado->save();
$venta->resciliacion = $pago->id;
$venta->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function entregar()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
return view('ventas.entregar', compact('venta'));
}
public static function consolidacion()
{
if (get('proyecto')) {
$id_proyecto = get('proyecto');
$proyecto = model(Proyecto::class)->findOne($id_proyecto);
$ventas = $proyecto->ventas();
set_time_limit(count($ventas));
$f = Carbon::today(config('app.timezone'));
setlocale(LC_TIME, 'es');
return view('ventas.consolidacion.show', compact('ventas', 'f'));
} else {
$proyectos = model(Proyecto::class)->order_by_asc('descripcion')->find_many();
return view('ventas.consolidacion.proyectos', compact('proyectos'));
}
}
public static function devolucion()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$uf = uf(Carbon::now(config('app.config')))->uf->value;
$valor = round($venta->saldo() * $uf);
return view('ventas.devolucion', compact('venta', 'valor', 'uf'));
}
public static function devolver()
{
$id = get('venta');
$venta = model(Venta::class)->findOne($id);
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$uf = uf($f);
$valor = correctNumber(post('valor'));
$data = [
'fecha' => $f->format('Y-m-d'),
'valor' => $valor,
'tipo' => 1,
'uf' => $uf->uf->value,
'identificador' => post('identificador'),
'banco' => 0
];
$banco = model(Banco::class)->where('nombre', post('banco'))->findOne();
if ($banco) {
$data['banco'] = $banco->id;
}
$pago = model(Pago::class)->create($data);
$pago->newPagado();
$venta->devolucion = $pago->id;
$venta->save();
header('Location: ' . url('', ['p' => 'ventas', 'a' => 'show', 'venta' => $venta->id]));
}
public static function resciliaciones()
{
$resciliaciones = model(Venta::class)->where('estado', 0)->findMany();
return view('ventas.resciliaciones', compact('resciliaciones'));
}
public static function firmar()
{
$venta = \model(Venta::class)->findOne(get('venta'));
return view('ventas.firmar', compact('venta'));
}
public static function firmando()
{
$venta = \model(Venta::class)->findOne(get('venta'));
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$venta->firmar($f);
header('Location: ' . nUrl('ventas', 'show', ['venta' => $venta->id]));
}
public static function archivar()
{
$venta = \model(Venta::class)->findOne(get('venta'));
return view('ventas.archivar', compact('venta'));
}
public static function archivando()
{
$venta = \model(Venta::class)->findOne(get('venta'));
$f = Carbon::createFromDate(post('year'), post('month'), post('day'), config('app.timezone'));
$venta->archivar($f);
header('Location: ' . nUrl('ventas', 'show', ['venta' => $venta->id]));
}
}
?>

View File

@ -0,0 +1,31 @@
<?php
namespace App\Definition;
trait Controller
{
protected static $default;
public static function index()
{
$action = get('a');
if ($action == null) {
$action = get('action');
}
if ($action != null) {
$ref = new \ReflectionMethod(self::class, $action);
if (method_exists(self::class, $action) and $ref->isPublic()) {
return self::{$action}();
}
}
if (self::$default == null and \method_exists(self::class, 'setDefault')) {
self::setDefault();
}
if (self::$default == null) {
header('Location: .');
return;
}
return self::$default;
}
}
?>

View File

@ -0,0 +1,38 @@
<?php
namespace App\Definition;
use Stringy\Stringy;
trait hasEstado
{
public function estados()
{
$table = $this->getTable();
$self = Stringy::create(get_class($this));
$ns = $self->substr(0, $self->indexOfLast('\\'));
$self = $self->substr($self->indexOfLast('\\') + 1);
$column = $self->underscored();
$class = $ns . '\\Estado' . $self;
if (substr($table, -1, 1) == 's') {
$column .= '_id';
}
return $this->has_many($class, $column)->findMany();
}
public function estado()
{
$table = $this->getTable();
$self = Stringy::create(get_class($this));
$ns = $self->substr(0, $self->indexOfLast('\\'));
$self = $self->substr($self->indexOfLast('\\') + 1);
$column = $self->underscored();
$class = $ns . '\\Estado' . $self;
if (substr($table, -1, 1) == 's') {
$column .= '_id';
}
$id = $this->has_many($class, $column)->max('id');
return $this->has_many($class, $column)->findOne($id);
}
}
?>

20
app/Definition/hasRUT.php Normal file
View File

@ -0,0 +1,20 @@
<?php
namespace App\Definition;
/**
*
* @author Aldarien
* @property int rut
* @property char dv
*
*/
trait hasRUT
{
protected static $_id_column = 'rut';
public function fullRut()
{
return format('rut', $this->rut) . '-' . $this->dv;
}
}
?>

View File

@ -0,0 +1,16 @@
<?php
namespace App\Exception;
class PropertyNotFound extends \LogicException
{
protected $class;
protected $property;
public function __construct($class, $property)
{
$this->class = $class;
$this->property = $property;
$msg = "Property '" . $property . "' for class '" . $class . "' not found.";
parent::__construct($msg);
}
}

169
app/Helper/Color.php Normal file
View File

@ -0,0 +1,169 @@
<?php
namespace App\Helper;
class Color
{
protected $color;
public function __construct()
{
$args = func_get_args();
switch (count($args)) {
case 1:
if (is_array($args[0])) {
$this->color = $args[0];
break;
}
$this->color = $this->hex2dec($this->hex2array($args[0]));
break;
case 2:
if (is_array($args[0])) {
$this->color = $args[0];
$this->color []= $args[1];
break;
}
$color = $this->hex2array($args[0]);
$color []= $args[1];
$this->color = $this->hex2dec($color);
break;
case 3:
case 4:
if (is_numeric($args[0])) {
$this->color = $args;
break;
}
$this->color = $this->hex2dec($args);
break;
}
}
protected function hex2dec(array $hex)
{
return array_map('hexdec', $hex);
}
protected function dec2hex(array $bin)
{
return array_map('dechex', $bin);
}
protected function hex2array(string $hex)
{
switch (strlen($hex)) {
case 3:
case 4:
case 6:
case 7:
return str_split($hex, 2);
default:
throw new OutOfBoundsException('The string ' . $hex . ' is not a correct color code.');
}
}
protected function array2hex(array $arr)
{
return implode('', $arr);
}
public function convertTo($type)
{
switch (strtolower($type)) {
case 'hex':
if (is_numeric($this->color[0])) {
$this->color = $this->dec2hex($this->color);
}
break;
case 'dec':
if (!is_numeric($this->color[0])) {
$this->color = $this->hex2dec($this->color);
}
break;
default:
throw new InvalidArgumentException($type . ' is not a valid argument.');
}
}
public function add($base_color, $amount)
{
$changed = false;
if (!is_numeric($this->color)) {
$this->convertTo('dec');
$changed = true;
}
switch (strtolower($base_color)) {
case 'r':
$base_color = 0;
break;
case 'g':
$base_color = 1;
break;
case 'b':
$base_color = 2;
break;
case 'a':
$base_color = 3;
break;
default:
throw new OutOfBoundsException("Base color '" . $base_color . "' does not exist.");
}
$this->color[$base_color] += $amount;
if ($changed) {
$this->convertTo('hex');
}
}
public function print()
{
$this->convertTo('hex');
return implode('', $this->color);
}
public function toRGB()
{
$changed = false;
$this->convertTo('dec');
$str = 'rgb(' . implode(', ', array_map(function($a) {
return round($a, 2);
}, $this->color)) . ')';
if ($changed) {
$this->convertTo('hex');
}
return $str;
}
public function __toString()
{
return $this->print();
}
public function toArray()
{
return $this->color;
}
public function toVector()
{
$changed = false;
$this->convertTo('dec');
$arr = $this->toArray();
if ($changed) {
$this->convertTo('hex');
}
return $arr;
}
public function luminosity()
{
$changed = false;
$this->convertTo('dec');
//sqrt( 0.299*R^2 + 0.587*G^2 + 0.114*B^2 )
$str = sqrt(0.299 * pow($this->color[0], 2) + 0.587 * pow($this->color[1], 2) + 0.114 * pow($this->color[2], 2)) / 255 * 100;
if ($changed) {
$this->convertTo('hex');
}
return $str;
}
public function isDark()
{
if ($this->luminosity() < 50) {
return true;
}
return false;
}
public function isBright()
{
if ($this->luminosity() > 75) {
return true;
}
return false;
}
}

61
app/Helper/Line.php Normal file
View File

@ -0,0 +1,61 @@
<?php
namespace App\Helper;
class Line
{
protected $origin;
protected $length;
protected $direction;
public function __construct($point_a, $point_b)
{
$this->origin = $point_a;
$this->length = $this->distance($point_a, $point_b);
$this->direction = $this->gradient($point_a, $point_b);
}
public function origin()
{
return $this->origin;
}
public function length()
{
return $this->length;
}
public function direction()
{
return $this->direction;
}
/**
* Calculate the gradient to move from point a to point b
* @param array $point_a [Vector]
* @param array $point_b [Vector]
* @return array [Vector]
*/
public function gradient($point_a, $point_b)
{
$distance = $this->distance($point_a, $point_b);
return array_map(function($a, $b) use ($distance) {
return ($a - $b) / $distance;
}, $point_b, $point_a);
}
// sqrt((a0-b0)²+(a1-b1)²+(a2-b2)²)
public function distance($point_a, $point_b)
{
return sqrt(array_sum(array_map(function($a, $b) {
return pow($a - $b, 2);
}, $point_a, $point_b)));
}
/**
* Move from point in the direction of the gradient acording to step_size
* @param array $point [Vector]
* @param int $step_size [step size]
* @return array [Vector]
*/
public function move($point, $step_size)
{
$gradient = $this->direction;
return array_map(function($a, $b) use ($step_size) {
return $a + $b * $step_size;
}, $point, $gradient);
}
}

102
app/Helper/functions.php Normal file
View File

@ -0,0 +1,102 @@
<?php
function route() {
return App\Contract\Route::route();
}
function uf($date, $async = false) {
if (is_string($date)) {
$date = Carbon\Carbon::parse($date, config('app.timezone'));
}
$next_m_9 = Carbon\Carbon::today(config('app.timezone'))->copy()->endOfMonth()->addDays(9);
if ($date->greaterThanOrEqualTo($next_m_9)) {
return (object) ['total' => 0];
}
$url = 'http://' . config('locations.money') . '/api/uf/value/' . $date->format('Y-m-d');
$client = new \Goutte\Client();
$client->setHeader('Accept', 'application/json');
$client->request('GET', $url);
$response = $client->getResponse();
if (!$response) {
return (object) ['total' => 0];
}
$status = $response->getStatusCode();
if ($status >= 200 and $status < 300) {
$data = json_decode($response->getContent());
return $data;
}
return (object) ['total' => 0];
}
function format($tipo, $valor, $format = null, $print = false) {
if (strtolower($tipo) == 'localdate') {
$d = \Carbon\Carbon::parse($valor);
$d->locale('es_ES');
if ($format == null) {
$format = 'DD [de] MMMM [de] YYYY';
}
return $d->isoFormat($format);
}
if (method_exists('\App\Helper\Format', $tipo)) {
if ($print) {
return \App\Helper\Format::$tipo($valor, $print);
} else {
return \App\Helper\Format::$tipo($valor);
}
} else {
switch ($tipo) {
case 'localDate':
if (isset($format)) {
$intl = new IntlDateFormatter('es_ES', IntlDateFormatter::SHORT, IntlDateFormatter::SHORT, 'America/Santiago');
$intl->setPattern($format);
return ucwords($intl->format($valor));
}
case 'percent':
return \App\Helper\Format::number($valor, 2);
case 'rut':
return \App\Helper\Format::number($valor, 0);
}
}
}
function model(string $class_name) {
return \Model::factory($class_name);
}
function correctNumber($number) {
if (strpos($number, ',') !== false) {
return str_replace(',', '.', str_replace('.', '', $number));
} elseif (substr_count($number, '.') > 1) {
return str_replace('.', '', $number);
}
return $number;
}
function parseRanges($range, $numeric = true, $negatives = true) {
$rns = preg_split('/[,;]+/', $range);
$data = [];
foreach ($rns as $p) {
if (!$negatives) {
if (strpos($p, '-') !== false) {
list($ini, $end) = explode('-', $p);
$data = array_merge($data, range($ini, $end));
continue;
}
}
if ($numeric) {
$data []= (float) $p;
continue;
}
$data []= $p;
}
return $data;
}
function nUrl($p, $a = null, $data = null) {
$query = ['p' => $p];
if ($a != null) {
$query['a'] = $a;
if ($data != null) {
$query = array_merge($query, $data);
}
}
return url('', $query);
}
function doLog($user, $action, $variables) {
App\Service\Register::log($user, $action, $variables);
}
?>

163
app/Service/Auth.php Normal file
View File

@ -0,0 +1,163 @@
<?php
namespace App\Service;
class Auth
{
protected $selector;
protected $token;
public function __construct()
{
$this->getCookie();
}
protected function getCookie()
{
if (isset($_COOKIE['rememberMe'])) {
list($s, $t) = \explode(':', $_COOKIE['rememberMe']);
$this->selector = $s;
$this->token = $t;
}
}
protected function saveCookie()
{
$now = \Carbon\Carbon::now(config('app.timezone'));
$exp = $now->addHours(config('app.login_hours'));
\setcookie('rememberMe', $this->selector . ':' . $this->token, $exp->timestamp);
}
protected function clearCookie()
{
\setcookie('rememberMe', '', \Carbon\Carbon::now(config('app.timezone'))->timestamp);
}
protected function generateToken()
{
$this->selector = bin2hex(\random_bytes(12));
$this->token = bin2hex(\random_bytes(20));
}
public function login($username, $password)
{
$user = \Model::factory(\Incoviba\common\User::class)->where('name', $username)->where('enabled', 1)->findOne();
if ($user !== false) {
if (\password_verify($password, $user->password) === false) {
$this->clearCookie();
return false;
}
$this->generateToken();
$now = \Carbon\Carbon::now(config('app.timezone'));
$exp = $now->addHours(-config('app.login_hours'));
$auth = \Model::factory(\Incoviba\common\Auth::class)->where('user_id', $user->id)->whereGt('time', $exp->timestamp)->where('status', 1)->findOne();
if ($auth !== false) {
$auth->time('now');
$auth->selector = $this->selector;
$auth->token($this->token);
$auth->save();
$this->saveCookie();
return true;
}
$auth = \Model::factory(\Incoviba\common\Auth::class)->create();
$auth->user_id = $user->id;
$auth->time('now');
$auth->selector = $this->selector;
$auth->token($this->token);
try {
$auth->save();
$this->saveCookie();
return true;
} catch (\Exception $e) {
$this->clearCookie();
return false;
}
}
return false;
}
public function isIn()
{
if ($this->selector == null) {
return false;
}
$auths = \Model::factory(\Incoviba\common\Auth::class)->where('selector', $this->selector)->findMany();
if ($auths === false) {
$this->clearCookie();
return false;
}
foreach ($auths as $auth) {
if (\password_verify($this->token, $auth->token)) {
return $auth->isIn();
}
}
return false;
}
public function User()
{
if ($this->selector == null) {
return false;
}
$auths = \Model::factory(\Incoviba\common\Auth::class)->where('selector', $this->selector)->findMany();
if ($auths === false) {
return false;
}
foreach ($auths as $auth) {
if (\password_verify($this->token, $auth->token)) {
return $auth->user();
}
}
return false;
}
public function hasAccess()
{
if ($this->selector == null) {
return false;
}
$auths = \Model::factory(\Incoviba\common\Auth::class)->where('selector', $this->selector)->findMany();
if ($auths === false) {
return false;
}
foreach ($auths as $auth) {
if (\password_verify($this->token, $auth->token)) {
return $auth->user()->hasAccess();
}
}
return false;
}
public function checkAccess($controller, $action = null)
{
if ($this->selector == null) {
return false;
}
$auths = \Model::factory(\Incoviba\common\Auth::class)->where('selector', $this->selector)->findMany();
if ($auths === false) {
return false;
}
foreach ($auths as $auth) {
if (\password_verify($this->token, $auth->token)) {
return $auth->user()->checkAccess($controller, $action);
}
}
return false;
}
public function logout()
{
$this->clearCookie();
if ($this->selector == null) {
return true;
}
$auths = \Model::factory(\Incoviba\common\Auth::class)->where('selector', $this->selector)->findMany();
if ($auths === false) {
return true;
}
foreach ($auths as $auth) {
if (\password_verify($this->token, $auth->token)) {
$auth->status = 0;
try {
$auth->save();
return true;
} catch (\Exception $e) {
return false;
}
}
}
return true;
}
}

118
app/Service/Borrador.php Normal file
View File

@ -0,0 +1,118 @@
<?php
namespace App\Service;
use Incoviba\nuevo\Venta\Cierre;
use PhpOffice\PhpWord\IOFactory;
use PhpOffice\PhpWord\Element\TextBreak;
use PhpOffice\PhpWord\Element\Text;
use PhpOffice\PhpWord\Element\TextRun;
use PhpOffice\PhpWord\PhpWord;
use PhpOffice\PhpWord\Style\Language;
class Borrador
{
protected $cierre;
protected $lineas;
protected $word;
protected $text;
public function __construct(Cierre $cierre)
{
$this->cierre = $cierre;
$this->lineas = [];
}
protected function add(string $str, int $new_line = 0)
{
$this->lineas []= $str;
if ($new_line > 0) {
$this->newLine($new_line);
}
}
protected function newLine($n = 1)
{
for ($i = 0; $i < $n; $i ++) {
$this->lineas []= '';
}
}
protected function load()
{
$this->word = IOFactory::load('borrador-' . $this->cierre->proyecto()->nombre . '.docx');
}
protected function extract()
{
$this->load();
$data = [];
foreach ($this->word->getSections() as $section) {
foreach ($section->getElements() as $element) {
$r = $this->elementGet($element);
$data []= $r;
}
}
if (count($data) > 0) {
$this->text = $data;
}
}
protected function elementGet($element)
{
if ($element instanceof TextBreak) {
return PHP_EOL;
}
if ($element instanceof TextRun) {
$data = [];
foreach ($element->getElements() as $e) {
$data []= $this->elementGet($e);
}
return implode('', $data);
}
if (!method_exists($element, 'getText')) {
d($element);
}
return $element->getText();
}
protected function build()
{
if ($this->text == null) {
$this->extract();
}
foreach ($this->text as $line) {
if ($line == PHP_EOL) {
$this->newLine();
continue;
}
if (strpos($line, '[[') !== false) {
$replacer = new Replacer();
$this->add($replacer->replace($line, $this->cierre));
continue;
}
$this->add($line);
}
}
public function create()
{
$output = new PhpWord();
$output->getSettings()->setDecimalSymbol(',');
$output->getSettings()->setThemeFontLang(new Language(Language::ES_ES));
$section = $output->addSection();
foreach ($this->lineas as $linea) {
if ($linea == '') {
$section->addTextBreak();
continue;
}
$section->addText($linea);
}
$output->getSettings()->setTrackRevisions(true);
$writer = IOFactory::createWriter($output);
$filename = 'Borrador ' . $this->cierre->propietario()->nombreCompleto() . ' con ' . $this->cierre->proyecto()->inmobiliaria()->razon_social . '.docx';
$writer->save($filename);
}
public function show()
{
$this->build();
return implode(PHP_EOL, $this->lineas);
}
}
?>

158
app/Service/DBToModel.php Normal file
View File

@ -0,0 +1,158 @@
<?php
namespace App\Service;
use Stringy\Stringy;
class DBToModel
{
protected $name;
protected $db;
protected $tables;
public function __construct($name = 'mysql')
{
$this->name = $name;
$this->db = \ORM::get_db($name);
}
public function run()
{
$this->getTables();
foreach ($this->tables as $table) {
if ($this->createClass($table)) {
echo 'ok<br />', PHP_EOL;
}
}
}
protected function getType($type)
{
if (strpos($type, '(') !== false) {
$type = substr($type, 0, strpos($type, '('));
}
if (strpos($type, ' ') !== false) {
$type = substr($type, 0, strpos($type, ' '));
}
switch ($type) {
case 'int':
case 'float':
case 'double':
case 'char':
return trim($type);
case 'date':
case 'datetime':
return trim(strtolower($type));
case 'varchar':
case 'text':
case 'blob':
return 'string';
case 'bigint':
case 'tinyint':
case 'enum':
return 'int';
default:
d($type);
}
}
protected function getTables()
{
$q = "SHOW TABLES";
$st = $this->db->query($q);
$results = $st->fetchAll(\PDO::FETCH_COLUMN);
$this->tables = [];
foreach ($results as $result) {
$this->tables []= $result;
}
}
protected function getColumns($table)
{
$q = "SHOW COLUMNS FROM `" . $table . "`";
$st = $this->db->query($q);
$results = $st->fetchAll(\PDO::FETCH_OBJ);
return $results;
}
protected function phpDoc($columns)
{
$str = ['/**'];
$str []= ' *';
foreach ($columns as $column) {
$str []= ' * @property ' . $this->getType($column->Type) . ' ' . $column->Field;
}
$str []= ' *';
$str []= ' */';
return implode(PHP_EOL, $str);
}
protected function className($table)
{
$name = Stringy::create($table)->upperCamelize();
return $name;
}
protected function createClass($table)
{
$class = '' . $this->className($table);
$columns = $this->getColumns($table);
$docs = $this->phpDoc($columns);
$output = ['<?php'];
$output []= '';
$output []= $docs;
$output []= 'class ' . $class . ' extends \\Model';
$output []= '{';
$output []= "\tpublic static \$_connection_name = '{$this->name}';";
$output []= '}';
$output []= '?>';
//d(implode(PHP_EOL, $output));
$filename = realpath(root() . '/src') . DIRECTORY_SEPARATOR . $class . '.php';
return file_put_contents($filename, implode(PHP_EOL, $output));
}
public function create($namespace, $table)
{
$class = '' . $this->className($table);
$columns = $this->getColumns($table);
$docs = $this->phpDoc($columns);
$namespace = trim($namespace, '\\');
$output = ['<?php'];
$output []= 'namespace ' . $namespace . ';';
$output []= '';
$output []= $docs;
$output []= 'class ' . $class . ' extends \\Model';
$output []= '{';
$output []= "\tpublic static \$_connection_name = '{$this->name}';";
$output []= '}';
$output []= '?>';
$output = implode(PHP_EOL, $output);
$namespace = explode('\\', $namespace);
array_shift($namespace);
$namespace = implode('/', $namespace);
$filename = realpath(root() . '/src/' . $namespace) . DIRECTORY_SEPARATOR . $class . '.php';
$result = [
'result' => false,
'filename' => $filename,
'output' => $output
];
if (!file_exists($filename)) {
$result['result'] = file_put_contents($filename, $output);
} else {
$result['result'] = true;
}
return json_encode($result);
}
public function list()
{
$this->getTables();
$output = [];
foreach ($this->tables as $table) {
$output []= ['table' => $table, 'model' => '' . $this->className($table)];
}
return json_encode(['models' => $output]);
}
}
?>

204
app/Service/Factory.php Normal file
View File

@ -0,0 +1,204 @@
<?php
namespace App\Service;
use Stringy\Stringy;
class Factory
{
protected $class;
protected $is_aggregator;
public function __construct($class)
{
$this->class = $class;
$this->is_aggregator = true;
if (is_subclass_of($class, 'Model')) {
$this->is_aggregator = false;
}
}
public function new()
{
$class = $this->class;
if ($this->is_aggregator) {
return new $class();
}
return model($class)->create();
}
public function create($data)
{
$class = $this->class;
if ($this->is_aggregator) {
$obj = new $class();
$obj->create($data);
return $obj;
}
return model($class)->create($data);
}
/**
* [column => value, column => [value, operator]]
* @var array
*/
protected $conditions;
public function where(array $data)
{
if ($this->conditions == null) {
$this->conditions = $data;
return $this;
}
$this->conditions = array_merge($this->conditions, $data);
return $this;
}
/**
* [column, column => order]
* @var array
*/
protected $order;
public function order(array $data)
{
if ($this->order == null) {
$this->order = $data;
return $this;
}
$this->order = array_merge($this->order, $data);
return $this;
}
protected $limit;
public function limit(array $data)
{
if (!isset($data['limit'])) {
$data['limit'] = $data[0];
}
if (!isset($data['offset'])) {
$data['offset'] = 0;
if (isset($data[1])) {
$data['offset'] = $data[1];
}
}
$this->limit = (object) ['limit' => $data['limit'], 'offset' => $data['offset']];
return $this;
}
protected $many;
public function find($many = false)
{
$this->many = $many;
if ($this->is_aggregator) {
return $this->findAggregator();
}
return $this->findModel();
}
protected function findModel()
{
$objs = model($this->class);
$objs = $this->parseLimit($this->parseOrder($this->parseConditions($objs)));
if ($this->many) {
return $objs->findMany();
}
return $objs->findOne();
}
protected function parseConditions($orm)
{
if ($this->conditions == null) {
return $orm;
}
foreach ($this->conditions as $column => $value) {
if (is_array($value)) {
list($value, $op) = $value;
switch ($op) {
case '>':
case 'gt':
$orm = $orm->whereGt($column, $value);
break;
}
} else {
$orm = $orm->where($column, $value);
}
}
return $orm;
}
protected function parseOrder($orm)
{
if ($this->order == null) {
return $orm;
}
foreach ($this->order as $column => $order) {
if (is_numeric($column)) {
$column = $order;
$order = 'asc';
}
switch (strtolower($order)) {
case 'asc':
default:
$orm = $orm->orderByAsc($column);
break;
case 'desc':
$orm = $orm->orderByDesc($column);
break;
case 'expr':
$orm = $orm->orderByExpr($column);
break;
}
}
return $orm;
}
protected function parseLimit($orm)
{
if ($this->limit == null) {
return $orm;
}
$orm = $orm->limit($this->limit->limit);
if (isset($this->limit->offset)) {
$orm = $orm->offset($this->limit->offset);
}
return $orm;
}
protected function findAggregator()
{
$model = $this->modelName($this->class);
$ids = $this->getIds($model);
$class = $this->class;
if (count($ids) == 0) {
return false;
}
if ($this->many) {
$objs = [];
foreach ($ids as $id) {
$objs []= new $class($id);
}
} else {
$objs = new $class($ids[0]);
}
return $objs;
}
protected function getIds($model)
{
$id = $this->getModelId($model);
$table = $this->getTable($model);
$st = \ORM::forTable($table)->select($id);
$st = $this->parseConditions($st);
$results = $st->findArray();
$output = array_map(function($a) use($id) {
return $a[$id];
}, $results);
return $output;
}
protected function modelName($class)
{
$arr = explode("\\", $class);
\array_push($arr, end($arr));
return implode("\\", $arr);
}
protected function getModelId($model)
{
$table = $this->getTable($model);
$query = "SHOW KEYS FROM {$table} WHERE Key_name = 'PRIMARY'";
$st = \ORM::getDb()->query($query);
$results = $st->fetchAll(\PDO::FETCH_OBJ);
return $results[0]->Column_name;
}
protected function getTable($model)
{
$arr = explode("\\", $model);
return Stringy::create(end($arr))->toLowerCase() . '';
}
}

463
app/Service/Informador.php Normal file
View File

@ -0,0 +1,463 @@
<?php
namespace App\Service;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Shared\Date;
use PhpOffice\PhpSpreadsheet\Style\Alignment;
use PhpOffice\PhpSpreadsheet\Style\Fill;
use Carbon\Carbon;
use PhpOffice\PhpSpreadsheet\IOFactory;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;
class Informador
{
protected $title;
protected $columns;
protected $data;
protected $col_formats;
protected $totals;
public function __construct($title = '')
{
if ($title != '') {
$this->title = $title;
} else {
$this->title = 'Informe';
}
}
public function addColumn(string $title, $col = '')
{
if ($col == '') {
if ($this->columns == null) {
$i = 0;
} else{
$i = count($this->columns);
}
$col = $this->mapColumn($i);
}
if (isset($this->columns[$col])) {
$columns = [];
foreach ($this->columns as $c => $data) {
if (ord($c) < ord($col)) {
$columns[$c] = $data;
} elseif (ord($c) == ord($col)) {
$columns[$col] = $title;
} else {
$columns[chr(ord($c) + 1)] = $data;
}
}
$this->columns = $columns;
} else {
$this->columns[$col] = $title;
}
}
public function mapColumn($n)
{
$letters = range('A', 'Z');
$max = count($letters);
$r = $n / $max + 1;
$p = floor($r - 1) - 1;
$i = $n % $max;
if ($r >= 2) {
return $letters[$p] . $letters[$i];
}
return $letters[$i];
}
public function getColumn($col_title)
{
return array_search($col_title, $this->columns);
}
public function getColumnNumber($col)
{
$letters = range('A', 'Z');
if (strlen($col) > 1) {
$ls = str_split($col);
$n = 0;
foreach ($ls as $i => $l) {
$n += array_search($l, $letters) + $i * count($letters) + 1;
}
return $n;
}
return array_search($col, $letters);
}
public function addColumns(array $columns)
{
foreach ($columns as $column) {
$this->addColumn($column);
}
}
public function addData(int $row, $data, $col = '')
{
if (!isset($this->data[$row])) {
$this->data[$row] = [];
}
if ($col == '') {
$i = count($this->data[$row]);
$col = $this->mapColumn($i);
} elseif (ctype_print($col)) {
$col = $this->getColumn($col);
} else {
$col = $this->mapColumn($col);
}
if (isset($this->data[$row][$col])) {
$data_array = [];
foreach ($this->data[$row] as $c => $d) {
if (ord($c) < ord($col)) {
$data_array[$c] = $d;
} elseif (ord($c) == ord($col)) {
$data_array[$col] = $this->parseData($data);
} else {
$data_array[chr(ord($c) + 1)] = $d;
}
}
$this->data[$row] = $data_array;
} else {
$this->data[$row][$col] = $this->parseData($data);
}
}
protected function parseData($data)
{
if ($this->isDate($data)) {
// Date
return Date::PHPToExcel($data);
}
return $data;
}
protected function isDate($data)
{
try {
if (strpos($data, '-') === false) {
return false;
}
$fecha = explode('-', $data);
if (count($fecha) != 3) {
return false;
}
list($year, $month, $day) = $fecha;
if (strlen($year) == 4 and strlen($month) <= 2 and strlen($day) <= 2) {
return true;
}
if (ctype_digit($year) and ctype_digit($month) and ctype_digit($day)) {
$f = Carbon::parse($data, config('app.timezone'));
return true;
}
return false;
} catch(\Exception $e) {
return false;
}
return false;
}
public function addDataRow(int $row, array $data_array)
{
foreach ($data_array as $data) {
$this->addData($row, $data);
}
}
public function addDatas(array $data_matrix)
{
foreach ($data_matrix as $row => $data_array) {
$this->addDataRow($row, $data_array);
}
}
protected function findTitleColumn($title)
{
return array_search($title, $this->columns);
}
public function addFormat($format, $title = '')
{
$col = 'A';
if ($title == '') {
$i = count($this->col_formats);
$col = $this->mapColumn($i);
} else {
$col = $this->findTitleColumn($title);
}
if (isset($this->col_formats[$col])) {
$columns = [];
foreach ($this->col_formats as $c => $data) {
if (ord($c) < ord($col)) {
$columns[$c] = $data;
} elseif (ord($c) == ord($col)) {
$columns[$col] = $this->translateFormat($format);
} else {
$columns[chr(ord($c) + 1)] = $data;
}
}
$this->col_formats = $columns;
} else {
$this->col_formats[$col] = $this->translateFormat($format);
}
uksort($this->col_formats, function($ak, $bk) {
return strcmp($ak, $bk);
});
}
protected function translateFormat(array $format)
{
$translated = [];
foreach ($format as $category => $values) {
switch ($category) {
case 'numberFormat':
$data = $this->translateNumberFormat($values);
break;
case 'alignment':
$data = $this->translateAlignment($values);
break;
case 'font':
$data = $this->translateFont($values);
break;
case 'fill':
$data = $this->translateFill($values);
break;
case 'borders':
$data = $this->translateBorders($values);
break;
}
$translated[$category] = $data;
}
return $translated;
}
protected function translateNumberFormat(array $values)
{
$translated = [];
foreach ($values as $value) {
switch ($value) {
case 'short-date':
$translated['formatCode'] = 'dd-mm-yyyy';
break;
case 'date':
$translated['formatCode'] = 'dd mmmm, yyyy';
break;
case 'thousands':
$translated['formatCode'] = NumberFormat::FORMAT_NUMBER_COMMA_SEPARATED1;
break;
case 'pesos':
$translated['formatCode'] = '$ #.###';
break;
default:
$translated['formatCode'] = $value;
}
}
return $translated;
}
protected function translateAlignment(array $values)
{
$translated = [];
foreach ($values as $type => $value) {
switch ($type) {
case 'horizontal':
switch ($value) {
case 'center':
$new = Alignment::HORIZONTAL_CENTER;
break;
}
break;
case 'vertical':
switch ($value) {
case 'middle':
case 'center':
$new = Alignment::VERTICAL_CENTER;
}
default:
$new = $value;
break;
}
$translated[$type] = $new;
}
return $translated;
}
protected function translateFont(array $values)
{
$translated = [];
foreach ($values as $type => $value) {
switch ($type) {
case 'color':
$new = $this->translateColor($value);
break;
default:
$new = $value;
break;
}
$translated[$type] = $new;
}
return $translated;
}
protected function translateFill(array $values)
{
$translated = [];
foreach ($values as $type => $value) {
switch ($type) {
case 'fillType':
switch ($value) {
case 'solid':
$new = Fill::FILL_SOLID;
break;
default:
$new = $value;
break;
}
break;
case 'color':
$new = $this->translateColor($value);
break;
default:
$new = $value;
break;
}
$translated[$type] = $new;
}
return $translated;
}
protected function translateBorders(array $values)
{
$translated = [];
foreach ($format as $category => $value) {
switch ($category) {
case 'allBorders':
case 'left':
case 'right':
case 'top':
case 'bottom':
case 'diagonal':
case 'vertical':
case 'horizontal':
$data = $this->translateBorder($value);
break;
default:
$data = $value;
}
$translated[$category] = $data;
}
return $translated;
}
protected function translateBorder(array $values)
{
$translated = [];
foreach ($values as $type => $value) {
switch ($type) {
case 'color':
$new = $this->translateColor($value);
break;
default:
$new = $value;
break;
}
$translated[$type] = $new;
}
return $translated;
}
protected function translateColor($color)
{
$color_definitions = [
'red' => 'ff0000',
'light-red' => 'ffcccc',
'dark-red' => 'a00000'
];
if (is_array($color)) {
$t = dechex(255 * $color['transparency'] / 100);
$c = $color_definitions[$color['color']];
$hex = $t . $c;
return ['argb' => $hex];
}
return ['rgb' => $color_definitions[$color]];
}
public function addFormats(array $formats)
{
foreach ($formats as $title => $format) {
$this->addFormat($format, $title);
}
}
public function addTotal(string $col)
{
if (isset($this->columns[$col])) {
$sum = 0;
foreach ($this->data as $row => $data) {
$sum += $data[$col];
}
$this->totals[$col] = $sum;
}
}
public function addAverage(string $col)
{
$this->addTotal($col);
$this->totals[$col] /= count($this->data);
}
protected function fillData()
{
foreach ($this->data as $row => $data) {
$this->data[$row] = $this->fillAndSort($data);
}
if (count($this->totals) > 0) {
$this->totals = $this->fillAndSort($this->totals);
}
}
protected function fillAndSort(array $row)
{
foreach ($this->columns as $val) {
if (!isset($row[$val])) {
$row[$val] = '';
}
}
function sortArrayByArray(Array $array, Array $orderArray) {
$ordered = array();
foreach($orderArray as $key) {
if(array_key_exists($key, $array)) {
$ordered[$key] = $array[$key];
unset($array[$key]);
}
}
return $ordered + $array;
}
$row = sortArrayByArray($row, $this->columns);
return $row;
}
public function informe()
{
$ea = new Spreadsheet();
$ea->getProperties()->setCreator('Juan Pablo Vial B.');
$ea->getProperties()->setTitle($this->title);
$ea->getProperties()->setCompany('Incoviba S.A.');
$ews = $ea->getActiveSheet();
$ews->fromArray(array($this->columns), '', 'A1');
$ews->fromArray($this->data, '', 'A2');
$end = 2;
if ($this->totals != null and count($this->totals) > 0) {
$ews->fromArray($this->totals, '', 'A' . count($data) + 2);
$end = 3;
}
if ($this->col_formats != null and count($this->col_formats) > 0) {
foreach ($this->col_formats as $col => $format) {
$ews->getStyleByColumnAndRow($this->getColumnNumber($col), 2, $this->getColumnNumber($col), count($this->data) + $end)->applyFromArray($format);
}
}
for ($col = 0; $col < count($this->columns); $col ++) {
$ews->getColumnDimensionByColumn($col)->setAutoSize(true);
}
$ews->setAutoFilterByColumnAndRow(0, 1, count($this->columns) - 1, count($this->data));
$hoy = Carbon::now(config('app.timezone'));
$filename = str_replace('ñ', 'n', $this->title . ' - ' . $hoy->format('Y-m-d') . '.xlsx');
$writer = IOFactory::createWriter($ea, "Xlsx");
header("Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet; charset=utf-8");
header('Content-Transfer-Encoding: binary');
header('Content-Disposition: attachment; filename="' . $filename . '"');
header('Cache-Control: max-age=0');
$writer->save('php://output');
}
}
?>

34
app/Service/Register.php Normal file
View File

@ -0,0 +1,34 @@
<?php
namespace App\Service;
use Carbon\Carbon;
use Incoviba\common\Registry as RModel;
class Register
{
public static function log($user, $action, $variables)
{
$data = [
'user' => $user,
'action' => $action,
'time' => Carbon::now(config('app.timezone'))->toDateTimeString()//->format('Y-m-d HH:mm:ss')
];
$registry = model(RModel::class)
->where('user', $user)
->where('action', $action)
->where('time', $data['time'])
->findOne();
if (!$registry) {
$registry = model(RModel::class)->create($data);
$registry->save();
}
foreach ($variables as $data) {
$data['registry'] = $registry->id;
$log = (new Factory(RegistryData::class))->where($data)->find();
if (!$log) {
$log = model(RegistryData::class)->create($data);
$log->save();
}
}
}
}

127
app/Service/Replacer.php Normal file
View File

@ -0,0 +1,127 @@
<?php
namespace App\Service;
use Carbon\Carbon;
class Replacer
{
public function replace($line, $data)
{
$instructions = $this->parseLine($line);
$output = $line;
foreach ($instructions as $instruction) {
$output = str_replace($instruction['original'], $this->buildLine($instruction['instruction'], $data), $output);
}
return $output;
}
protected function parseLine($line)
{
$ini_el = '[[';
$end_el = ']]';
$instructions = [];
$offset = 0;
while (strpos($line, $ini_el, $offset) !== false) {
$ini = strpos($line, $ini_el, $offset) + strlen($ini_el);
$end = strpos($line, $end_el, $offset);
$find = substr($line, $ini, $end - $ini);
$instructions []= ['original' => $ini_el . $find . $end_el, 'instruction' => $find];
$offset = $end + 1;
}
return $instructions;
}
protected function buildLine($instructions, $data)
{
if (strpos($instructions, '|') !== false) {
$instructions = explode('|', $instructions);
} else {
$instructions = [$instructions];
}
$output = '';
foreach ($instructions as $instruction) {
$output = $this->buildReplace($instruction, $data, $output);
}
return $output;
}
protected function buildReplace($instruction, $data, $output = null)
{
if (strpos($instruction, '(') !== false) {
$ini = strpos($instruction, '(') + 1;
$end = strpos($instruction, ')');
$mod = substr($instruction, $ini, $end - $ini);
$instruction = substr($instruction, 0, $ini - 1);
}
switch ($instruction) {
case 'UPPER':
return strtoupper($output);
case 'LOWER':
return strtolower($output);
case 'ISSET':
if ($output != '') {
return ', ' . $output;
}
return '';
case 'UFS':
return format('ufs', $output);
case 'PESOS':
return format('pesos', $output);
}
if (isset($mod)) {
$obj = $this->find($instruction . '(' . $mod .')', $data);
} else {
$obj = $this->find($instruction, $data);
}
if ($obj) {
return $obj;
}
if (is_object($output) and method_exists($output, $instruction)) {
if (isset($mod)) {
return $output->$instruction($mod);
}
return $output->$instruction();
}
if (is_object($output) and isset($output->$instruction)) {
return $output->$instruction;
}
if ($instruction == 'strftime') {
setlocale(LC_TIME, 'es-CL', 'es');
$f = Carbon::parse($output, config('app.timezone'));
$output = strftime($mod, $f->timestamp);
return $output;
}
d($output, $instruction, function_exists($instruction), is_object($output), is_object($output) and isset($output->$instruction));
}
protected function find($instruction, $data)
{
if (strpos($instruction, '(') !== false) {
$ini = strpos($instruction, '(') + 1;
$end = strpos($instruction, ')');
$mod = substr($instruction, $ini, $end - $ini);
$instruction = substr($instruction, 0, $ini - 1);
}
if (method_exists($data, $instruction)) {
if (isset($mod)) {
return $data->$instruction($mod);
}
return $data->$instruction();
}
if (isset($data->$instruction)) {
return $data->$instruction;
}
switch ($instruction) {
case 'Unidades':
$str = 'Departamento ' . $data->reserva()->unidad()->numeracion;
foreach ($data->reserva()->unidades() as $unidad) {
$str .= ', ' . ucwords($unidad->unidadProyecto()->tipo()->descripcion) . ' ' . $unidad->numeracion;
}
return $str;
case 'inmobiliaria':
return $data->proyecto()->inmobiliaria();
}
return false;
}
}
?>

131
app/Service/Route.php Normal file
View File

@ -0,0 +1,131 @@
<?php
namespace App\Service;
class Route
{
protected $routes;
public function __construct()
{
}
public function add($type, $query, $callback)
{
if (is_array($type)) {
foreach ($type as $t) {
$this->add($t, $query, $callback);
}
} else {
switch (strtoupper($type)) {
case 'GET':
$this->get($query, $callback);
break;
case 'POST':
$this->post($query, $callback);
break;
}
}
}
public function get($query, $callback)
{
if ($this->exists('get', $query)) {
return;
}
$this->routes['get'][$query] = (object) ['query' => $query, 'callback' => $this->parseCallback($callback)];
}
public function post($query, $callback)
{
if ($this->exists('post', $query)) {
return;
}
$this->routes['post'][$query] = (object) ['query' => $query, 'callback' => $this->parseCallback($callback)];
}
protected function exists($type, $query)
{
return isset($this->routes['post'][$query]);
}
protected function parseCallback($callback)
{
if (is_callable($callback)) {
return $callback;
}
elseif (is_object($callback)) {
return [$callback, 'index'];
}
elseif (is_string($callback) and strpos($callback, '@') !== false) {
list($class, $method) = explode('@', $callback);
$class = '\\App\\Controller\\' . $class;
if (method_exists($class, $method)) {
return [$class, $method];
}
}
elseif (is_string($callback)) {
$class = '\\App\\Controller\\' . $callback;
return [$class, 'index'];
}
}
public function route()
{
$url = $_SERVER['SCRIPT_NAME'];
$query = $_SERVER['QUERY_STRING'];
$method = $_SERVER['REQUEST_METHOD'];
$route = null;
switch (strtoupper($method)) {
case 'GET':
$route = $this->getGet($url, $query);
break;
case 'POST':
$route = $this->getPost($url, $query);
break;
}
if ($route) {
return $this->run($route->callback);
}
return false;
}
protected function getGet($url, $query)
{
if (isset($this->routes['get'][$url])) {
return $this->routes['get'][$url];
}
$p = get('p');
if ($p == null) {
$p = get('page');
if ($p == null) {
$p = get('m');
if ($p == null) {
$p = get('module');
}
}
}
if (isset($this->routes['get'][$p])) {
return $this->routes['get'][$p];
}
return false;
}
protected function getPost($url, $query)
{
if (isset($this->routes['post'][$url])) {
return $this->routes['post'][$url];
}
$p = get('p');
if ($p == null) {
$p = get('page');
if ($p == null) {
$p = get('m');
if ($p == null) {
$p = get('module');
}
}
}
if (isset($this->routes['post'][$p])) {
return $this->routes['post'][$p];
}
return false;
}
protected function run($callback)
{
return call_user_func($callback);
}
}
?>

6
bootstrap/autoload.php Normal file
View File

@ -0,0 +1,6 @@
<?php
include_once dirname(__DIR__) . '/vendor/autoload.php';
include_once 'errors.php';
include_once 'database.php';
include_once 'routes.php';
?>

30
bootstrap/database.php Normal file
View File

@ -0,0 +1,30 @@
<?php
$databases = config('databases');
load($databases['mysql']);
foreach ($databases as $name => $data) {
load($data, $name);
}
function load($data, $name = '') {
if (!isset($data['port'])) {
$port = 3306;
} else {
$port = $data['port'];
}
$dsn = 'mysql:host=' . $data['host'] . ';port=' . $port . ';dbname=' . $data['database'] . ';charset=utf8';
if ($name != '') {
ORM::configure($dsn, null, $name);
ORM::configure('username', $data['username'], $name);
ORM::configure('password', $data['password'], $name);
} else {
ORM::configure($dsn, null);
ORM::configure('username', $data['username']);
ORM::configure('password', $data['password']);
}
}
Model::$short_table_names = true;
?>

7
bootstrap/errors.php Normal file
View File

@ -0,0 +1,7 @@
<?php
if (config('app.debug')) {
$whoops = new \Whoops\Run;
$whoops->pushHandler(new \Whoops\Handler\PrettyPageHandler);
$whoops->register();
}
?>

21
bootstrap/routes.php Normal file
View File

@ -0,0 +1,21 @@
<?php
use App\Contract\Route;
use Stringy\Stringy;
/*
* TODO: Language Changer
* Route::add('GET', 'change_language', function() {
\App\Contract\Session::set('App', 'lang', get('lang'));
header('Location: .');
});*/
$controllers = glob(config('locations.controllers') . '/*.php');
foreach ($controllers as $controller) {
$info = pathinfo($controller);
$name = $info['filename'];
$route = '' . Stringy::create($name)->underscored();
Route::add(['GET', 'POST'], $route, $name);
}
Route::add(['GET', 'POST'], 'buscar', 'Buscar');
?>

57
composer.json Normal file
View File

@ -0,0 +1,57 @@
{
"name" : "aldarien/incoviba",
"description" : "Intranet portal for Incoviba",
"type" : "project",
"require" : {
"aldarien/config" : "1.0.10",
"aldarien/asset" : "^1.0",
"aldarien/format" : "^1",
"aldarien/response" : "^1.0",
"aldarien/view" : "^1.0",
"aldarien/session" : "^1.0",
"j4mie/paris" : "^1.5",
"danielstjules/stringy" : "^3.1",
"phpoffice/phpspreadsheet": "1-beta",
"aldarien/url": "^1",
"nesbot/carbon": "^2",
"phpoffice/phpword": "^0.14.0",
"slam/php-excel": "^4.4",
"fabpot/goutte": "^3.2",
"incoviba/modelos": "dev-master",
"aldarien/models": "dev-master",
"incoviba/auth": "dev-master"
},
"require-dev" : {
"phpunit/phpunit" : "^6.3",
"kint-php/kint" : "^2.1",
"filp/whoops" : "^2.1"
},
"license" : "GNU AGPLv3",
"authors" : [{
"name" : "Aldarien",
"email" : "jpvial@gmail.com"
}
],
"autoload" : {
"psr-4" : {
"App\\" : "app"
},
"files" : [
"app/Helper/functions.php"
]
},
"repositories": [
{
"type": "git",
"url": "//192.168.1.100/git/modelos.git"
},
{
"type": "git",
"url": "//192.168.1.100/git/models.git"
},
{
"type": "git",
"url": "//192.168.1.100/git/auth.git"
}
]
}

10
config/app.php Normal file
View File

@ -0,0 +1,10 @@
<?php
return [
'timezone' => 'America/Santiago',
'locale' => 'es',
'database' => 'mysql',
'debug' => false,
'benchmark' => false,
'login_hours' => 5*24
];
?>

17
config/databases.php Normal file
View File

@ -0,0 +1,17 @@
<?php
return [
'mysql' => [
'host' => 'localhost',
//'port' => 3306,
'database' => 'incoviba',
'username' => 'incoviba',
'password' => '5GQYFvRjVw2A4KcD'
],
'mysql_copy' => [
'host' => 'localhost',
'database' => 'incoviba3',
'username' => 'incoviba',
'password' => '5GQYFvRjVw2A4KcD'
]
]
?>

6
config/incoviba.php Normal file
View File

@ -0,0 +1,6 @@
<?php
return [
'cierres' => [
'caducidad' => 30
]
];

15
config/locations.php Normal file
View File

@ -0,0 +1,15 @@
<?php
return [
'base' => root(),
'cache' => '{locations.base}/cache',
'public' => '{locations.base}/public',
'resources' => '{locations.base}/resources',
'views' => '{locations.resources}/views',
'src' => '{locations.base}/src',
//'languages' => '{locations.resources}/languages'
'app' => '{locations.base}/app',
'controllers' => '{locations.app}/Controller',
'money' => 'provm.cl/optimus/money',
'api' => '192.168.1.100/intranet/api'
];
?>

11
public/Pipfile Normal file
View File

@ -0,0 +1,11 @@
[[source]]
name = "pypi"
url = "https://pypi.org/simple"
verify_ssl = true
[dev-packages]
[packages]
[requires]
python_version = "3.8"

14
public/css/app.css Normal file

File diff suppressed because one or more lines are too long

6
public/css/custom.css Normal file
View File

@ -0,0 +1,6 @@
.success {
background-color: #a0ff80 !important;
}
.warning {
background-color: #ffe050 !important;
}

Binary file not shown.

Binary file not shown.

File diff suppressed because it is too large Load Diff

After

Width:  |  Height:  |  Size: 434 KiB

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -0,0 +1,288 @@
<?xml version="1.0" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
<svg xmlns="http://www.w3.org/2000/svg">
<metadata></metadata>
<defs>
<font id="glyphicons_halflingsregular" horiz-adv-x="1200" >
<font-face units-per-em="1200" ascent="960" descent="-240" />
<missing-glyph horiz-adv-x="500" />
<glyph horiz-adv-x="0" />
<glyph horiz-adv-x="400" />
<glyph unicode=" " />
<glyph unicode="*" d="M600 1100q15 0 34 -1.5t30 -3.5l11 -1q10 -2 17.5 -10.5t7.5 -18.5v-224l158 158q7 7 18 8t19 -6l106 -106q7 -8 6 -19t-8 -18l-158 -158h224q10 0 18.5 -7.5t10.5 -17.5q6 -41 6 -75q0 -15 -1.5 -34t-3.5 -30l-1 -11q-2 -10 -10.5 -17.5t-18.5 -7.5h-224l158 -158 q7 -7 8 -18t-6 -19l-106 -106q-8 -7 -19 -6t-18 8l-158 158v-224q0 -10 -7.5 -18.5t-17.5 -10.5q-41 -6 -75 -6q-15 0 -34 1.5t-30 3.5l-11 1q-10 2 -17.5 10.5t-7.5 18.5v224l-158 -158q-7 -7 -18 -8t-19 6l-106 106q-7 8 -6 19t8 18l158 158h-224q-10 0 -18.5 7.5 t-10.5 17.5q-6 41 -6 75q0 15 1.5 34t3.5 30l1 11q2 10 10.5 17.5t18.5 7.5h224l-158 158q-7 7 -8 18t6 19l106 106q8 7 19 6t18 -8l158 -158v224q0 10 7.5 18.5t17.5 10.5q41 6 75 6z" />
<glyph unicode="+" d="M450 1100h200q21 0 35.5 -14.5t14.5 -35.5v-350h350q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-350v-350q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v350h-350q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5 h350v350q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xa0;" />
<glyph unicode="&#xa5;" d="M825 1100h250q10 0 12.5 -5t-5.5 -13l-364 -364q-6 -6 -11 -18h268q10 0 13 -6t-3 -14l-120 -160q-6 -8 -18 -14t-22 -6h-125v-100h275q10 0 13 -6t-3 -14l-120 -160q-6 -8 -18 -14t-22 -6h-125v-174q0 -11 -7.5 -18.5t-18.5 -7.5h-148q-11 0 -18.5 7.5t-7.5 18.5v174 h-275q-10 0 -13 6t3 14l120 160q6 8 18 14t22 6h125v100h-275q-10 0 -13 6t3 14l120 160q6 8 18 14t22 6h118q-5 12 -11 18l-364 364q-8 8 -5.5 13t12.5 5h250q25 0 43 -18l164 -164q8 -8 18 -8t18 8l164 164q18 18 43 18z" />
<glyph unicode="&#x2000;" horiz-adv-x="650" />
<glyph unicode="&#x2001;" horiz-adv-x="1300" />
<glyph unicode="&#x2002;" horiz-adv-x="650" />
<glyph unicode="&#x2003;" horiz-adv-x="1300" />
<glyph unicode="&#x2004;" horiz-adv-x="433" />
<glyph unicode="&#x2005;" horiz-adv-x="325" />
<glyph unicode="&#x2006;" horiz-adv-x="216" />
<glyph unicode="&#x2007;" horiz-adv-x="216" />
<glyph unicode="&#x2008;" horiz-adv-x="162" />
<glyph unicode="&#x2009;" horiz-adv-x="260" />
<glyph unicode="&#x200a;" horiz-adv-x="72" />
<glyph unicode="&#x202f;" horiz-adv-x="260" />
<glyph unicode="&#x205f;" horiz-adv-x="325" />
<glyph unicode="&#x20ac;" d="M744 1198q242 0 354 -189q60 -104 66 -209h-181q0 45 -17.5 82.5t-43.5 61.5t-58 40.5t-60.5 24t-51.5 7.5q-19 0 -40.5 -5.5t-49.5 -20.5t-53 -38t-49 -62.5t-39 -89.5h379l-100 -100h-300q-6 -50 -6 -100h406l-100 -100h-300q9 -74 33 -132t52.5 -91t61.5 -54.5t59 -29 t47 -7.5q22 0 50.5 7.5t60.5 24.5t58 41t43.5 61t17.5 80h174q-30 -171 -128 -278q-107 -117 -274 -117q-206 0 -324 158q-36 48 -69 133t-45 204h-217l100 100h112q1 47 6 100h-218l100 100h134q20 87 51 153.5t62 103.5q117 141 297 141z" />
<glyph unicode="&#x20bd;" d="M428 1200h350q67 0 120 -13t86 -31t57 -49.5t35 -56.5t17 -64.5t6.5 -60.5t0.5 -57v-16.5v-16.5q0 -36 -0.5 -57t-6.5 -61t-17 -65t-35 -57t-57 -50.5t-86 -31.5t-120 -13h-178l-2 -100h288q10 0 13 -6t-3 -14l-120 -160q-6 -8 -18 -14t-22 -6h-138v-175q0 -11 -5.5 -18 t-15.5 -7h-149q-10 0 -17.5 7.5t-7.5 17.5v175h-267q-10 0 -13 6t3 14l120 160q6 8 18 14t22 6h117v100h-267q-10 0 -13 6t3 14l120 160q6 8 18 14t22 6h117v475q0 10 7.5 17.5t17.5 7.5zM600 1000v-300h203q64 0 86.5 33t22.5 119q0 84 -22.5 116t-86.5 32h-203z" />
<glyph unicode="&#x2212;" d="M250 700h800q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-800q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#x231b;" d="M1000 1200v-150q0 -21 -14.5 -35.5t-35.5 -14.5h-50v-100q0 -91 -49.5 -165.5t-130.5 -109.5q81 -35 130.5 -109.5t49.5 -165.5v-150h50q21 0 35.5 -14.5t14.5 -35.5v-150h-800v150q0 21 14.5 35.5t35.5 14.5h50v150q0 91 49.5 165.5t130.5 109.5q-81 35 -130.5 109.5 t-49.5 165.5v100h-50q-21 0 -35.5 14.5t-14.5 35.5v150h800zM400 1000v-100q0 -60 32.5 -109.5t87.5 -73.5q28 -12 44 -37t16 -55t-16 -55t-44 -37q-55 -24 -87.5 -73.5t-32.5 -109.5v-150h400v150q0 60 -32.5 109.5t-87.5 73.5q-28 12 -44 37t-16 55t16 55t44 37 q55 24 87.5 73.5t32.5 109.5v100h-400z" />
<glyph unicode="&#x25fc;" horiz-adv-x="500" d="M0 0z" />
<glyph unicode="&#x2601;" d="M503 1089q110 0 200.5 -59.5t134.5 -156.5q44 14 90 14q120 0 205 -86.5t85 -206.5q0 -121 -85 -207.5t-205 -86.5h-750q-79 0 -135.5 57t-56.5 137q0 69 42.5 122.5t108.5 67.5q-2 12 -2 37q0 153 108 260.5t260 107.5z" />
<glyph unicode="&#x26fa;" d="M774 1193.5q16 -9.5 20.5 -27t-5.5 -33.5l-136 -187l467 -746h30q20 0 35 -18.5t15 -39.5v-42h-1200v42q0 21 15 39.5t35 18.5h30l468 746l-135 183q-10 16 -5.5 34t20.5 28t34 5.5t28 -20.5l111 -148l112 150q9 16 27 20.5t34 -5zM600 200h377l-182 112l-195 534v-646z " />
<glyph unicode="&#x2709;" d="M25 1100h1150q10 0 12.5 -5t-5.5 -13l-564 -567q-8 -8 -18 -8t-18 8l-564 567q-8 8 -5.5 13t12.5 5zM18 882l264 -264q8 -8 8 -18t-8 -18l-264 -264q-8 -8 -13 -5.5t-5 12.5v550q0 10 5 12.5t13 -5.5zM918 618l264 264q8 8 13 5.5t5 -12.5v-550q0 -10 -5 -12.5t-13 5.5 l-264 264q-8 8 -8 18t8 18zM818 482l364 -364q8 -8 5.5 -13t-12.5 -5h-1150q-10 0 -12.5 5t5.5 13l364 364q8 8 18 8t18 -8l164 -164q8 -8 18 -8t18 8l164 164q8 8 18 8t18 -8z" />
<glyph unicode="&#x270f;" d="M1011 1210q19 0 33 -13l153 -153q13 -14 13 -33t-13 -33l-99 -92l-214 214l95 96q13 14 32 14zM1013 800l-615 -614l-214 214l614 614zM317 96l-333 -112l110 335z" />
<glyph unicode="&#xe001;" d="M700 650v-550h250q21 0 35.5 -14.5t14.5 -35.5v-50h-800v50q0 21 14.5 35.5t35.5 14.5h250v550l-500 550h1200z" />
<glyph unicode="&#xe002;" d="M368 1017l645 163q39 15 63 0t24 -49v-831q0 -55 -41.5 -95.5t-111.5 -63.5q-79 -25 -147 -4.5t-86 75t25.5 111.5t122.5 82q72 24 138 8v521l-600 -155v-606q0 -42 -44 -90t-109 -69q-79 -26 -147 -5.5t-86 75.5t25.5 111.5t122.5 82.5q72 24 138 7v639q0 38 14.5 59 t53.5 34z" />
<glyph unicode="&#xe003;" d="M500 1191q100 0 191 -39t156.5 -104.5t104.5 -156.5t39 -191l-1 -2l1 -5q0 -141 -78 -262l275 -274q23 -26 22.5 -44.5t-22.5 -42.5l-59 -58q-26 -20 -46.5 -20t-39.5 20l-275 274q-119 -77 -261 -77l-5 1l-2 -1q-100 0 -191 39t-156.5 104.5t-104.5 156.5t-39 191 t39 191t104.5 156.5t156.5 104.5t191 39zM500 1022q-88 0 -162 -43t-117 -117t-43 -162t43 -162t117 -117t162 -43t162 43t117 117t43 162t-43 162t-117 117t-162 43z" />
<glyph unicode="&#xe005;" d="M649 949q48 68 109.5 104t121.5 38.5t118.5 -20t102.5 -64t71 -100.5t27 -123q0 -57 -33.5 -117.5t-94 -124.5t-126.5 -127.5t-150 -152.5t-146 -174q-62 85 -145.5 174t-150 152.5t-126.5 127.5t-93.5 124.5t-33.5 117.5q0 64 28 123t73 100.5t104 64t119 20 t120.5 -38.5t104.5 -104z" />
<glyph unicode="&#xe006;" d="M407 800l131 353q7 19 17.5 19t17.5 -19l129 -353h421q21 0 24 -8.5t-14 -20.5l-342 -249l130 -401q7 -20 -0.5 -25.5t-24.5 6.5l-343 246l-342 -247q-17 -12 -24.5 -6.5t-0.5 25.5l130 400l-347 251q-17 12 -14 20.5t23 8.5h429z" />
<glyph unicode="&#xe007;" d="M407 800l131 353q7 19 17.5 19t17.5 -19l129 -353h421q21 0 24 -8.5t-14 -20.5l-342 -249l130 -401q7 -20 -0.5 -25.5t-24.5 6.5l-343 246l-342 -247q-17 -12 -24.5 -6.5t-0.5 25.5l130 400l-347 251q-17 12 -14 20.5t23 8.5h429zM477 700h-240l197 -142l-74 -226 l193 139l195 -140l-74 229l192 140h-234l-78 211z" />
<glyph unicode="&#xe008;" d="M600 1200q124 0 212 -88t88 -212v-250q0 -46 -31 -98t-69 -52v-75q0 -10 6 -21.5t15 -17.5l358 -230q9 -5 15 -16.5t6 -21.5v-93q0 -10 -7.5 -17.5t-17.5 -7.5h-1150q-10 0 -17.5 7.5t-7.5 17.5v93q0 10 6 21.5t15 16.5l358 230q9 6 15 17.5t6 21.5v75q-38 0 -69 52 t-31 98v250q0 124 88 212t212 88z" />
<glyph unicode="&#xe009;" d="M25 1100h1150q10 0 17.5 -7.5t7.5 -17.5v-1050q0 -10 -7.5 -17.5t-17.5 -7.5h-1150q-10 0 -17.5 7.5t-7.5 17.5v1050q0 10 7.5 17.5t17.5 7.5zM100 1000v-100h100v100h-100zM875 1000h-550q-10 0 -17.5 -7.5t-7.5 -17.5v-350q0 -10 7.5 -17.5t17.5 -7.5h550 q10 0 17.5 7.5t7.5 17.5v350q0 10 -7.5 17.5t-17.5 7.5zM1000 1000v-100h100v100h-100zM100 800v-100h100v100h-100zM1000 800v-100h100v100h-100zM100 600v-100h100v100h-100zM1000 600v-100h100v100h-100zM875 500h-550q-10 0 -17.5 -7.5t-7.5 -17.5v-350q0 -10 7.5 -17.5 t17.5 -7.5h550q10 0 17.5 7.5t7.5 17.5v350q0 10 -7.5 17.5t-17.5 7.5zM100 400v-100h100v100h-100zM1000 400v-100h100v100h-100zM100 200v-100h100v100h-100zM1000 200v-100h100v100h-100z" />
<glyph unicode="&#xe010;" d="M50 1100h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5zM650 1100h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5v400 q0 21 14.5 35.5t35.5 14.5zM50 500h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5zM650 500h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400 q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe011;" d="M50 1100h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM450 1100h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200 q0 21 14.5 35.5t35.5 14.5zM850 1100h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM50 700h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200 q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM450 700h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM850 700h200q21 0 35.5 -14.5t14.5 -35.5v-200 q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM50 300h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM450 300h200 q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM850 300h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5 t35.5 14.5z" />
<glyph unicode="&#xe012;" d="M50 1100h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM450 1100h700q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-700q-21 0 -35.5 14.5t-14.5 35.5v200 q0 21 14.5 35.5t35.5 14.5zM50 700h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM450 700h700q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-700 q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM50 300h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5zM450 300h700q21 0 35.5 -14.5t14.5 -35.5v-200 q0 -21 -14.5 -35.5t-35.5 -14.5h-700q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe013;" d="M465 477l571 571q8 8 18 8t17 -8l177 -177q8 -7 8 -17t-8 -18l-783 -784q-7 -8 -17.5 -8t-17.5 8l-384 384q-8 8 -8 18t8 17l177 177q7 8 17 8t18 -8l171 -171q7 -7 18 -7t18 7z" />
<glyph unicode="&#xe014;" d="M904 1083l178 -179q8 -8 8 -18.5t-8 -17.5l-267 -268l267 -268q8 -7 8 -17.5t-8 -18.5l-178 -178q-8 -8 -18.5 -8t-17.5 8l-268 267l-268 -267q-7 -8 -17.5 -8t-18.5 8l-178 178q-8 8 -8 18.5t8 17.5l267 268l-267 268q-8 7 -8 17.5t8 18.5l178 178q8 8 18.5 8t17.5 -8 l268 -267l268 268q7 7 17.5 7t18.5 -7z" />
<glyph unicode="&#xe015;" d="M507 1177q98 0 187.5 -38.5t154.5 -103.5t103.5 -154.5t38.5 -187.5q0 -141 -78 -262l300 -299q8 -8 8 -18.5t-8 -18.5l-109 -108q-7 -8 -17.5 -8t-18.5 8l-300 299q-119 -77 -261 -77q-98 0 -188 38.5t-154.5 103t-103 154.5t-38.5 188t38.5 187.5t103 154.5 t154.5 103.5t188 38.5zM506.5 1023q-89.5 0 -165.5 -44t-120 -120.5t-44 -166t44 -165.5t120 -120t165.5 -44t166 44t120.5 120t44 165.5t-44 166t-120.5 120.5t-166 44zM425 900h150q10 0 17.5 -7.5t7.5 -17.5v-75h75q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5 t-17.5 -7.5h-75v-75q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5v75h-75q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5h75v75q0 10 7.5 17.5t17.5 7.5z" />
<glyph unicode="&#xe016;" d="M507 1177q98 0 187.5 -38.5t154.5 -103.5t103.5 -154.5t38.5 -187.5q0 -141 -78 -262l300 -299q8 -8 8 -18.5t-8 -18.5l-109 -108q-7 -8 -17.5 -8t-18.5 8l-300 299q-119 -77 -261 -77q-98 0 -188 38.5t-154.5 103t-103 154.5t-38.5 188t38.5 187.5t103 154.5 t154.5 103.5t188 38.5zM506.5 1023q-89.5 0 -165.5 -44t-120 -120.5t-44 -166t44 -165.5t120 -120t165.5 -44t166 44t120.5 120t44 165.5t-44 166t-120.5 120.5t-166 44zM325 800h350q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-350q-10 0 -17.5 7.5 t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5z" />
<glyph unicode="&#xe017;" d="M550 1200h100q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5zM800 975v166q167 -62 272 -209.5t105 -331.5q0 -117 -45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5 t-184.5 123t-123 184.5t-45.5 224q0 184 105 331.5t272 209.5v-166q-103 -55 -165 -155t-62 -220q0 -116 57 -214.5t155.5 -155.5t214.5 -57t214.5 57t155.5 155.5t57 214.5q0 120 -62 220t-165 155z" />
<glyph unicode="&#xe018;" d="M1025 1200h150q10 0 17.5 -7.5t7.5 -17.5v-1150q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5v1150q0 10 7.5 17.5t17.5 7.5zM725 800h150q10 0 17.5 -7.5t7.5 -17.5v-750q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5v750 q0 10 7.5 17.5t17.5 7.5zM425 500h150q10 0 17.5 -7.5t7.5 -17.5v-450q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5v450q0 10 7.5 17.5t17.5 7.5zM125 300h150q10 0 17.5 -7.5t7.5 -17.5v-250q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5 v250q0 10 7.5 17.5t17.5 7.5z" />
<glyph unicode="&#xe019;" d="M600 1174q33 0 74 -5l38 -152l5 -1q49 -14 94 -39l5 -2l134 80q61 -48 104 -105l-80 -134l3 -5q25 -44 39 -93l1 -6l152 -38q5 -43 5 -73q0 -34 -5 -74l-152 -38l-1 -6q-15 -49 -39 -93l-3 -5l80 -134q-48 -61 -104 -105l-134 81l-5 -3q-44 -25 -94 -39l-5 -2l-38 -151 q-43 -5 -74 -5q-33 0 -74 5l-38 151l-5 2q-49 14 -94 39l-5 3l-134 -81q-60 48 -104 105l80 134l-3 5q-25 45 -38 93l-2 6l-151 38q-6 42 -6 74q0 33 6 73l151 38l2 6q13 48 38 93l3 5l-80 134q47 61 105 105l133 -80l5 2q45 25 94 39l5 1l38 152q43 5 74 5zM600 815 q-89 0 -152 -63t-63 -151.5t63 -151.5t152 -63t152 63t63 151.5t-63 151.5t-152 63z" />
<glyph unicode="&#xe020;" d="M500 1300h300q41 0 70.5 -29.5t29.5 -70.5v-100h275q10 0 17.5 -7.5t7.5 -17.5v-75h-1100v75q0 10 7.5 17.5t17.5 7.5h275v100q0 41 29.5 70.5t70.5 29.5zM500 1200v-100h300v100h-300zM1100 900v-800q0 -41 -29.5 -70.5t-70.5 -29.5h-700q-41 0 -70.5 29.5t-29.5 70.5 v800h900zM300 800v-700h100v700h-100zM500 800v-700h100v700h-100zM700 800v-700h100v700h-100zM900 800v-700h100v700h-100z" />
<glyph unicode="&#xe021;" d="M18 618l620 608q8 7 18.5 7t17.5 -7l608 -608q8 -8 5.5 -13t-12.5 -5h-175v-575q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5v375h-300v-375q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5v575h-175q-10 0 -12.5 5t5.5 13z" />
<glyph unicode="&#xe022;" d="M600 1200v-400q0 -41 29.5 -70.5t70.5 -29.5h300v-650q0 -21 -14.5 -35.5t-35.5 -14.5h-800q-21 0 -35.5 14.5t-14.5 35.5v1100q0 21 14.5 35.5t35.5 14.5h450zM1000 800h-250q-21 0 -35.5 14.5t-14.5 35.5v250z" />
<glyph unicode="&#xe023;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM600 1027q-116 0 -214.5 -57t-155.5 -155.5t-57 -214.5t57 -214.5 t155.5 -155.5t214.5 -57t214.5 57t155.5 155.5t57 214.5t-57 214.5t-155.5 155.5t-214.5 57zM525 900h50q10 0 17.5 -7.5t7.5 -17.5v-275h175q10 0 17.5 -7.5t7.5 -17.5v-50q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5v350q0 10 7.5 17.5t17.5 7.5z" />
<glyph unicode="&#xe024;" d="M1300 0h-538l-41 400h-242l-41 -400h-538l431 1200h209l-21 -300h162l-20 300h208zM515 800l-27 -300h224l-27 300h-170z" />
<glyph unicode="&#xe025;" d="M550 1200h200q21 0 35.5 -14.5t14.5 -35.5v-450h191q20 0 25.5 -11.5t-7.5 -27.5l-327 -400q-13 -16 -32 -16t-32 16l-327 400q-13 16 -7.5 27.5t25.5 11.5h191v450q0 21 14.5 35.5t35.5 14.5zM1125 400h50q10 0 17.5 -7.5t7.5 -17.5v-350q0 -10 -7.5 -17.5t-17.5 -7.5 h-1050q-10 0 -17.5 7.5t-7.5 17.5v350q0 10 7.5 17.5t17.5 7.5h50q10 0 17.5 -7.5t7.5 -17.5v-175h900v175q0 10 7.5 17.5t17.5 7.5z" />
<glyph unicode="&#xe026;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM600 1027q-116 0 -214.5 -57t-155.5 -155.5t-57 -214.5t57 -214.5 t155.5 -155.5t214.5 -57t214.5 57t155.5 155.5t57 214.5t-57 214.5t-155.5 155.5t-214.5 57zM525 900h150q10 0 17.5 -7.5t7.5 -17.5v-275h137q21 0 26 -11.5t-8 -27.5l-223 -275q-13 -16 -32 -16t-32 16l-223 275q-13 16 -8 27.5t26 11.5h137v275q0 10 7.5 17.5t17.5 7.5z " />
<glyph unicode="&#xe027;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM600 1027q-116 0 -214.5 -57t-155.5 -155.5t-57 -214.5t57 -214.5 t155.5 -155.5t214.5 -57t214.5 57t155.5 155.5t57 214.5t-57 214.5t-155.5 155.5t-214.5 57zM632 914l223 -275q13 -16 8 -27.5t-26 -11.5h-137v-275q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5v275h-137q-21 0 -26 11.5t8 27.5l223 275q13 16 32 16 t32 -16z" />
<glyph unicode="&#xe028;" d="M225 1200h750q10 0 19.5 -7t12.5 -17l186 -652q7 -24 7 -49v-425q0 -12 -4 -27t-9 -17q-12 -6 -37 -6h-1100q-12 0 -27 4t-17 8q-6 13 -6 38l1 425q0 25 7 49l185 652q3 10 12.5 17t19.5 7zM878 1000h-556q-10 0 -19 -7t-11 -18l-87 -450q-2 -11 4 -18t16 -7h150 q10 0 19.5 -7t11.5 -17l38 -152q2 -10 11.5 -17t19.5 -7h250q10 0 19.5 7t11.5 17l38 152q2 10 11.5 17t19.5 7h150q10 0 16 7t4 18l-87 450q-2 11 -11 18t-19 7z" />
<glyph unicode="&#xe029;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM600 1027q-116 0 -214.5 -57t-155.5 -155.5t-57 -214.5t57 -214.5 t155.5 -155.5t214.5 -57t214.5 57t155.5 155.5t57 214.5t-57 214.5t-155.5 155.5t-214.5 57zM540 820l253 -190q17 -12 17 -30t-17 -30l-253 -190q-16 -12 -28 -6.5t-12 26.5v400q0 21 12 26.5t28 -6.5z" />
<glyph unicode="&#xe030;" d="M947 1060l135 135q7 7 12.5 5t5.5 -13v-362q0 -10 -7.5 -17.5t-17.5 -7.5h-362q-11 0 -13 5.5t5 12.5l133 133q-109 76 -238 76q-116 0 -214.5 -57t-155.5 -155.5t-57 -214.5t57 -214.5t155.5 -155.5t214.5 -57t214.5 57t155.5 155.5t57 214.5h150q0 -117 -45.5 -224 t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5q192 0 347 -117z" />
<glyph unicode="&#xe031;" d="M947 1060l135 135q7 7 12.5 5t5.5 -13v-361q0 -11 -7.5 -18.5t-18.5 -7.5h-361q-11 0 -13 5.5t5 12.5l134 134q-110 75 -239 75q-116 0 -214.5 -57t-155.5 -155.5t-57 -214.5h-150q0 117 45.5 224t123 184.5t184.5 123t224 45.5q192 0 347 -117zM1027 600h150 q0 -117 -45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5q-192 0 -348 118l-134 -134q-7 -8 -12.5 -5.5t-5.5 12.5v360q0 11 7.5 18.5t18.5 7.5h360q10 0 12.5 -5.5t-5.5 -12.5l-133 -133q110 -76 240 -76q116 0 214.5 57t155.5 155.5t57 214.5z" />
<glyph unicode="&#xe032;" d="M125 1200h1050q10 0 17.5 -7.5t7.5 -17.5v-1150q0 -10 -7.5 -17.5t-17.5 -7.5h-1050q-10 0 -17.5 7.5t-7.5 17.5v1150q0 10 7.5 17.5t17.5 7.5zM1075 1000h-850q-10 0 -17.5 -7.5t-7.5 -17.5v-850q0 -10 7.5 -17.5t17.5 -7.5h850q10 0 17.5 7.5t7.5 17.5v850 q0 10 -7.5 17.5t-17.5 7.5zM325 900h50q10 0 17.5 -7.5t7.5 -17.5v-50q0 -10 -7.5 -17.5t-17.5 -7.5h-50q-10 0 -17.5 7.5t-7.5 17.5v50q0 10 7.5 17.5t17.5 7.5zM525 900h450q10 0 17.5 -7.5t7.5 -17.5v-50q0 -10 -7.5 -17.5t-17.5 -7.5h-450q-10 0 -17.5 7.5t-7.5 17.5v50 q0 10 7.5 17.5t17.5 7.5zM325 700h50q10 0 17.5 -7.5t7.5 -17.5v-50q0 -10 -7.5 -17.5t-17.5 -7.5h-50q-10 0 -17.5 7.5t-7.5 17.5v50q0 10 7.5 17.5t17.5 7.5zM525 700h450q10 0 17.5 -7.5t7.5 -17.5v-50q0 -10 -7.5 -17.5t-17.5 -7.5h-450q-10 0 -17.5 7.5t-7.5 17.5v50 q0 10 7.5 17.5t17.5 7.5zM325 500h50q10 0 17.5 -7.5t7.5 -17.5v-50q0 -10 -7.5 -17.5t-17.5 -7.5h-50q-10 0 -17.5 7.5t-7.5 17.5v50q0 10 7.5 17.5t17.5 7.5zM525 500h450q10 0 17.5 -7.5t7.5 -17.5v-50q0 -10 -7.5 -17.5t-17.5 -7.5h-450q-10 0 -17.5 7.5t-7.5 17.5v50 q0 10 7.5 17.5t17.5 7.5zM325 300h50q10 0 17.5 -7.5t7.5 -17.5v-50q0 -10 -7.5 -17.5t-17.5 -7.5h-50q-10 0 -17.5 7.5t-7.5 17.5v50q0 10 7.5 17.5t17.5 7.5zM525 300h450q10 0 17.5 -7.5t7.5 -17.5v-50q0 -10 -7.5 -17.5t-17.5 -7.5h-450q-10 0 -17.5 7.5t-7.5 17.5v50 q0 10 7.5 17.5t17.5 7.5z" />
<glyph unicode="&#xe033;" d="M900 800v200q0 83 -58.5 141.5t-141.5 58.5h-300q-82 0 -141 -59t-59 -141v-200h-100q-41 0 -70.5 -29.5t-29.5 -70.5v-600q0 -41 29.5 -70.5t70.5 -29.5h900q41 0 70.5 29.5t29.5 70.5v600q0 41 -29.5 70.5t-70.5 29.5h-100zM400 800v150q0 21 15 35.5t35 14.5h200 q20 0 35 -14.5t15 -35.5v-150h-300z" />
<glyph unicode="&#xe034;" d="M125 1100h50q10 0 17.5 -7.5t7.5 -17.5v-1075h-100v1075q0 10 7.5 17.5t17.5 7.5zM1075 1052q4 0 9 -2q16 -6 16 -23v-421q0 -6 -3 -12q-33 -59 -66.5 -99t-65.5 -58t-56.5 -24.5t-52.5 -6.5q-26 0 -57.5 6.5t-52.5 13.5t-60 21q-41 15 -63 22.5t-57.5 15t-65.5 7.5 q-85 0 -160 -57q-7 -5 -15 -5q-6 0 -11 3q-14 7 -14 22v438q22 55 82 98.5t119 46.5q23 2 43 0.5t43 -7t32.5 -8.5t38 -13t32.5 -11q41 -14 63.5 -21t57 -14t63.5 -7q103 0 183 87q7 8 18 8z" />
<glyph unicode="&#xe035;" d="M600 1175q116 0 227 -49.5t192.5 -131t131 -192.5t49.5 -227v-300q0 -10 -7.5 -17.5t-17.5 -7.5h-50q-10 0 -17.5 7.5t-7.5 17.5v300q0 127 -70.5 231.5t-184.5 161.5t-245 57t-245 -57t-184.5 -161.5t-70.5 -231.5v-300q0 -10 -7.5 -17.5t-17.5 -7.5h-50 q-10 0 -17.5 7.5t-7.5 17.5v300q0 116 49.5 227t131 192.5t192.5 131t227 49.5zM220 500h160q8 0 14 -6t6 -14v-460q0 -8 -6 -14t-14 -6h-160q-8 0 -14 6t-6 14v460q0 8 6 14t14 6zM820 500h160q8 0 14 -6t6 -14v-460q0 -8 -6 -14t-14 -6h-160q-8 0 -14 6t-6 14v460 q0 8 6 14t14 6z" />
<glyph unicode="&#xe036;" d="M321 814l258 172q9 6 15 2.5t6 -13.5v-750q0 -10 -6 -13.5t-15 2.5l-258 172q-21 14 -46 14h-250q-10 0 -17.5 7.5t-7.5 17.5v350q0 10 7.5 17.5t17.5 7.5h250q25 0 46 14zM900 668l120 120q7 7 17 7t17 -7l34 -34q7 -7 7 -17t-7 -17l-120 -120l120 -120q7 -7 7 -17 t-7 -17l-34 -34q-7 -7 -17 -7t-17 7l-120 119l-120 -119q-7 -7 -17 -7t-17 7l-34 34q-7 7 -7 17t7 17l119 120l-119 120q-7 7 -7 17t7 17l34 34q7 8 17 8t17 -8z" />
<glyph unicode="&#xe037;" d="M321 814l258 172q9 6 15 2.5t6 -13.5v-750q0 -10 -6 -13.5t-15 2.5l-258 172q-21 14 -46 14h-250q-10 0 -17.5 7.5t-7.5 17.5v350q0 10 7.5 17.5t17.5 7.5h250q25 0 46 14zM766 900h4q10 -1 16 -10q96 -129 96 -290q0 -154 -90 -281q-6 -9 -17 -10l-3 -1q-9 0 -16 6 l-29 23q-7 7 -8.5 16.5t4.5 17.5q72 103 72 229q0 132 -78 238q-6 8 -4.5 18t9.5 17l29 22q7 5 15 5z" />
<glyph unicode="&#xe038;" d="M967 1004h3q11 -1 17 -10q135 -179 135 -396q0 -105 -34 -206.5t-98 -185.5q-7 -9 -17 -10h-3q-9 0 -16 6l-42 34q-8 6 -9 16t5 18q111 150 111 328q0 90 -29.5 176t-84.5 157q-6 9 -5 19t10 16l42 33q7 5 15 5zM321 814l258 172q9 6 15 2.5t6 -13.5v-750q0 -10 -6 -13.5 t-15 2.5l-258 172q-21 14 -46 14h-250q-10 0 -17.5 7.5t-7.5 17.5v350q0 10 7.5 17.5t17.5 7.5h250q25 0 46 14zM766 900h4q10 -1 16 -10q96 -129 96 -290q0 -154 -90 -281q-6 -9 -17 -10l-3 -1q-9 0 -16 6l-29 23q-7 7 -8.5 16.5t4.5 17.5q72 103 72 229q0 132 -78 238 q-6 8 -4.5 18.5t9.5 16.5l29 22q7 5 15 5z" />
<glyph unicode="&#xe039;" d="M500 900h100v-100h-100v-100h-400v-100h-100v600h500v-300zM1200 700h-200v-100h200v-200h-300v300h-200v300h-100v200h600v-500zM100 1100v-300h300v300h-300zM800 1100v-300h300v300h-300zM300 900h-100v100h100v-100zM1000 900h-100v100h100v-100zM300 500h200v-500 h-500v500h200v100h100v-100zM800 300h200v-100h-100v-100h-200v100h-100v100h100v200h-200v100h300v-300zM100 400v-300h300v300h-300zM300 200h-100v100h100v-100zM1200 200h-100v100h100v-100zM700 0h-100v100h100v-100zM1200 0h-300v100h300v-100z" />
<glyph unicode="&#xe040;" d="M100 200h-100v1000h100v-1000zM300 200h-100v1000h100v-1000zM700 200h-200v1000h200v-1000zM900 200h-100v1000h100v-1000zM1200 200h-200v1000h200v-1000zM400 0h-300v100h300v-100zM600 0h-100v91h100v-91zM800 0h-100v91h100v-91zM1100 0h-200v91h200v-91z" />
<glyph unicode="&#xe041;" d="M500 1200l682 -682q8 -8 8 -18t-8 -18l-464 -464q-8 -8 -18 -8t-18 8l-682 682l1 475q0 10 7.5 17.5t17.5 7.5h474zM319.5 1024.5q-29.5 29.5 -71 29.5t-71 -29.5t-29.5 -71.5t29.5 -71.5t71 -29.5t71 29.5t29.5 71.5t-29.5 71.5z" />
<glyph unicode="&#xe042;" d="M500 1200l682 -682q8 -8 8 -18t-8 -18l-464 -464q-8 -8 -18 -8t-18 8l-682 682l1 475q0 10 7.5 17.5t17.5 7.5h474zM800 1200l682 -682q8 -8 8 -18t-8 -18l-464 -464q-8 -8 -18 -8t-18 8l-56 56l424 426l-700 700h150zM319.5 1024.5q-29.5 29.5 -71 29.5t-71 -29.5 t-29.5 -71.5t29.5 -71.5t71 -29.5t71 29.5t29.5 71.5t-29.5 71.5z" />
<glyph unicode="&#xe043;" d="M300 1200h825q75 0 75 -75v-900q0 -25 -18 -43l-64 -64q-8 -8 -13 -5.5t-5 12.5v950q0 10 -7.5 17.5t-17.5 7.5h-700q-25 0 -43 -18l-64 -64q-8 -8 -5.5 -13t12.5 -5h700q10 0 17.5 -7.5t7.5 -17.5v-950q0 -10 -7.5 -17.5t-17.5 -7.5h-850q-10 0 -17.5 7.5t-7.5 17.5v975 q0 25 18 43l139 139q18 18 43 18z" />
<glyph unicode="&#xe044;" d="M250 1200h800q21 0 35.5 -14.5t14.5 -35.5v-1150l-450 444l-450 -445v1151q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe045;" d="M822 1200h-444q-11 0 -19 -7.5t-9 -17.5l-78 -301q-7 -24 7 -45l57 -108q6 -9 17.5 -15t21.5 -6h450q10 0 21.5 6t17.5 15l62 108q14 21 7 45l-83 301q-1 10 -9 17.5t-19 7.5zM1175 800h-150q-10 0 -21 -6.5t-15 -15.5l-78 -156q-4 -9 -15 -15.5t-21 -6.5h-550 q-10 0 -21 6.5t-15 15.5l-78 156q-4 9 -15 15.5t-21 6.5h-150q-10 0 -17.5 -7.5t-7.5 -17.5v-650q0 -10 7.5 -17.5t17.5 -7.5h150q10 0 17.5 7.5t7.5 17.5v150q0 10 7.5 17.5t17.5 7.5h750q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 7.5 -17.5t17.5 -7.5h150q10 0 17.5 7.5 t7.5 17.5v650q0 10 -7.5 17.5t-17.5 7.5zM850 200h-500q-10 0 -19.5 -7t-11.5 -17l-38 -152q-2 -10 3.5 -17t15.5 -7h600q10 0 15.5 7t3.5 17l-38 152q-2 10 -11.5 17t-19.5 7z" />
<glyph unicode="&#xe046;" d="M500 1100h200q56 0 102.5 -20.5t72.5 -50t44 -59t25 -50.5l6 -20h150q41 0 70.5 -29.5t29.5 -70.5v-600q0 -41 -29.5 -70.5t-70.5 -29.5h-1000q-41 0 -70.5 29.5t-29.5 70.5v600q0 41 29.5 70.5t70.5 29.5h150q2 8 6.5 21.5t24 48t45 61t72 48t102.5 21.5zM900 800v-100 h100v100h-100zM600 730q-95 0 -162.5 -67.5t-67.5 -162.5t67.5 -162.5t162.5 -67.5t162.5 67.5t67.5 162.5t-67.5 162.5t-162.5 67.5zM600 603q43 0 73 -30t30 -73t-30 -73t-73 -30t-73 30t-30 73t30 73t73 30z" />
<glyph unicode="&#xe047;" d="M681 1199l385 -998q20 -50 60 -92q18 -19 36.5 -29.5t27.5 -11.5l10 -2v-66h-417v66q53 0 75 43.5t5 88.5l-82 222h-391q-58 -145 -92 -234q-11 -34 -6.5 -57t25.5 -37t46 -20t55 -6v-66h-365v66q56 24 84 52q12 12 25 30.5t20 31.5l7 13l399 1006h93zM416 521h340 l-162 457z" />
<glyph unicode="&#xe048;" d="M753 641q5 -1 14.5 -4.5t36 -15.5t50.5 -26.5t53.5 -40t50.5 -54.5t35.5 -70t14.5 -87q0 -67 -27.5 -125.5t-71.5 -97.5t-98.5 -66.5t-108.5 -40.5t-102 -13h-500v89q41 7 70.5 32.5t29.5 65.5v827q0 24 -0.5 34t-3.5 24t-8.5 19.5t-17 13.5t-28 12.5t-42.5 11.5v71 l471 -1q57 0 115.5 -20.5t108 -57t80.5 -94t31 -124.5q0 -51 -15.5 -96.5t-38 -74.5t-45 -50.5t-38.5 -30.5zM400 700h139q78 0 130.5 48.5t52.5 122.5q0 41 -8.5 70.5t-29.5 55.5t-62.5 39.5t-103.5 13.5h-118v-350zM400 200h216q80 0 121 50.5t41 130.5q0 90 -62.5 154.5 t-156.5 64.5h-159v-400z" />
<glyph unicode="&#xe049;" d="M877 1200l2 -57q-83 -19 -116 -45.5t-40 -66.5l-132 -839q-9 -49 13 -69t96 -26v-97h-500v97q186 16 200 98l173 832q3 17 3 30t-1.5 22.5t-9 17.5t-13.5 12.5t-21.5 10t-26 8.5t-33.5 10q-13 3 -19 5v57h425z" />
<glyph unicode="&#xe050;" d="M1300 900h-50q0 21 -4 37t-9.5 26.5t-18 17.5t-22 11t-28.5 5.5t-31 2t-37 0.5h-200v-850q0 -22 25 -34.5t50 -13.5l25 -2v-100h-400v100q4 0 11 0.5t24 3t30 7t24 15t11 24.5v850h-200q-25 0 -37 -0.5t-31 -2t-28.5 -5.5t-22 -11t-18 -17.5t-9.5 -26.5t-4 -37h-50v300 h1000v-300zM175 1000h-75v-800h75l-125 -167l-125 167h75v800h-75l125 167z" />
<glyph unicode="&#xe051;" d="M1100 900h-50q0 21 -4 37t-9.5 26.5t-18 17.5t-22 11t-28.5 5.5t-31 2t-37 0.5h-200v-650q0 -22 25 -34.5t50 -13.5l25 -2v-100h-400v100q4 0 11 0.5t24 3t30 7t24 15t11 24.5v650h-200q-25 0 -37 -0.5t-31 -2t-28.5 -5.5t-22 -11t-18 -17.5t-9.5 -26.5t-4 -37h-50v300 h1000v-300zM1167 50l-167 -125v75h-800v-75l-167 125l167 125v-75h800v75z" />
<glyph unicode="&#xe052;" d="M50 1100h600q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-600q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM50 800h1000q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1000q-21 0 -35.5 14.5t-14.5 35.5v100 q0 21 14.5 35.5t35.5 14.5zM50 500h800q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-800q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM50 200h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1100 q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe053;" d="M250 1100h700q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-700q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM50 800h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1100q-21 0 -35.5 14.5t-14.5 35.5v100 q0 21 14.5 35.5t35.5 14.5zM250 500h700q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-700q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM50 200h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1100 q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe054;" d="M500 950v100q0 21 14.5 35.5t35.5 14.5h600q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-600q-21 0 -35.5 14.5t-14.5 35.5zM100 650v100q0 21 14.5 35.5t35.5 14.5h1000q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1000 q-21 0 -35.5 14.5t-14.5 35.5zM300 350v100q0 21 14.5 35.5t35.5 14.5h800q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-800q-21 0 -35.5 14.5t-14.5 35.5zM0 50v100q0 21 14.5 35.5t35.5 14.5h1100q21 0 35.5 -14.5t14.5 -35.5v-100 q0 -21 -14.5 -35.5t-35.5 -14.5h-1100q-21 0 -35.5 14.5t-14.5 35.5z" />
<glyph unicode="&#xe055;" d="M50 1100h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1100q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM50 800h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1100q-21 0 -35.5 14.5t-14.5 35.5v100 q0 21 14.5 35.5t35.5 14.5zM50 500h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1100q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM50 200h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1100 q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe056;" d="M50 1100h100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM350 1100h800q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-800q-21 0 -35.5 14.5t-14.5 35.5v100 q0 21 14.5 35.5t35.5 14.5zM50 800h100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM350 800h800q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-800 q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM50 500h100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM350 500h800q21 0 35.5 -14.5t14.5 -35.5v-100 q0 -21 -14.5 -35.5t-35.5 -14.5h-800q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM50 200h100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM350 200h800 q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-800q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe057;" d="M400 0h-100v1100h100v-1100zM550 1100h100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM550 800h500q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-500 q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM267 550l-167 -125v75h-200v100h200v75zM550 500h300q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-300q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM550 200h600 q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-600q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe058;" d="M50 1100h100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM900 0h-100v1100h100v-1100zM50 800h500q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-500 q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM1100 600h200v-100h-200v-75l-167 125l167 125v-75zM50 500h300q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-300q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5zM50 200h600 q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-600q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe059;" d="M75 1000h750q31 0 53 -22t22 -53v-650q0 -31 -22 -53t-53 -22h-750q-31 0 -53 22t-22 53v650q0 31 22 53t53 22zM1200 300l-300 300l300 300v-600z" />
<glyph unicode="&#xe060;" d="M44 1100h1112q18 0 31 -13t13 -31v-1012q0 -18 -13 -31t-31 -13h-1112q-18 0 -31 13t-13 31v1012q0 18 13 31t31 13zM100 1000v-737l247 182l298 -131l-74 156l293 318l236 -288v500h-1000zM342 884q56 0 95 -39t39 -94.5t-39 -95t-95 -39.5t-95 39.5t-39 95t39 94.5 t95 39z" />
<glyph unicode="&#xe062;" d="M648 1169q117 0 216 -60t156.5 -161t57.5 -218q0 -115 -70 -258q-69 -109 -158 -225.5t-143 -179.5l-54 -62q-9 8 -25.5 24.5t-63.5 67.5t-91 103t-98.5 128t-95.5 148q-60 132 -60 249q0 88 34 169.5t91.5 142t137 96.5t166.5 36zM652.5 974q-91.5 0 -156.5 -65 t-65 -157t65 -156.5t156.5 -64.5t156.5 64.5t65 156.5t-65 157t-156.5 65z" />
<glyph unicode="&#xe063;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM600 173v854q-116 0 -214.5 -57t-155.5 -155.5t-57 -214.5t57 -214.5 t155.5 -155.5t214.5 -57z" />
<glyph unicode="&#xe064;" d="M554 1295q21 -72 57.5 -143.5t76 -130t83 -118t82.5 -117t70 -116t49.5 -126t18.5 -136.5q0 -71 -25.5 -135t-68.5 -111t-99 -82t-118.5 -54t-125.5 -23q-84 5 -161.5 34t-139.5 78.5t-99 125t-37 164.5q0 69 18 136.5t49.5 126.5t69.5 116.5t81.5 117.5t83.5 119 t76.5 131t58.5 143zM344 710q-23 -33 -43.5 -70.5t-40.5 -102.5t-17 -123q1 -37 14.5 -69.5t30 -52t41 -37t38.5 -24.5t33 -15q21 -7 32 -1t13 22l6 34q2 10 -2.5 22t-13.5 19q-5 4 -14 12t-29.5 40.5t-32.5 73.5q-26 89 6 271q2 11 -6 11q-8 1 -15 -10z" />
<glyph unicode="&#xe065;" d="M1000 1013l108 115q2 1 5 2t13 2t20.5 -1t25 -9.5t28.5 -21.5q22 -22 27 -43t0 -32l-6 -10l-108 -115zM350 1100h400q50 0 105 -13l-187 -187h-368q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5v182l200 200v-332 q0 -165 -93.5 -257.5t-256.5 -92.5h-400q-165 0 -257.5 92.5t-92.5 257.5v400q0 165 92.5 257.5t257.5 92.5zM1009 803l-362 -362l-161 -50l55 170l355 355z" />
<glyph unicode="&#xe066;" d="M350 1100h361q-164 -146 -216 -200h-195q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5l200 153v-103q0 -165 -92.5 -257.5t-257.5 -92.5h-400q-165 0 -257.5 92.5t-92.5 257.5v400q0 165 92.5 257.5t257.5 92.5z M824 1073l339 -301q8 -7 8 -17.5t-8 -17.5l-340 -306q-7 -6 -12.5 -4t-6.5 11v203q-26 1 -54.5 0t-78.5 -7.5t-92 -17.5t-86 -35t-70 -57q10 59 33 108t51.5 81.5t65 58.5t68.5 40.5t67 24.5t56 13.5t40 4.5v210q1 10 6.5 12.5t13.5 -4.5z" />
<glyph unicode="&#xe067;" d="M350 1100h350q60 0 127 -23l-178 -177h-349q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5v69l200 200v-219q0 -165 -92.5 -257.5t-257.5 -92.5h-400q-165 0 -257.5 92.5t-92.5 257.5v400q0 165 92.5 257.5t257.5 92.5z M643 639l395 395q7 7 17.5 7t17.5 -7l101 -101q7 -7 7 -17.5t-7 -17.5l-531 -532q-7 -7 -17.5 -7t-17.5 7l-248 248q-7 7 -7 17.5t7 17.5l101 101q7 7 17.5 7t17.5 -7l111 -111q8 -7 18 -7t18 7z" />
<glyph unicode="&#xe068;" d="M318 918l264 264q8 8 18 8t18 -8l260 -264q7 -8 4.5 -13t-12.5 -5h-170v-200h200v173q0 10 5 12t13 -5l264 -260q8 -7 8 -17.5t-8 -17.5l-264 -265q-8 -7 -13 -5t-5 12v173h-200v-200h170q10 0 12.5 -5t-4.5 -13l-260 -264q-8 -8 -18 -8t-18 8l-264 264q-8 8 -5.5 13 t12.5 5h175v200h-200v-173q0 -10 -5 -12t-13 5l-264 265q-8 7 -8 17.5t8 17.5l264 260q8 7 13 5t5 -12v-173h200v200h-175q-10 0 -12.5 5t5.5 13z" />
<glyph unicode="&#xe069;" d="M250 1100h100q21 0 35.5 -14.5t14.5 -35.5v-438l464 453q15 14 25.5 10t10.5 -25v-1000q0 -21 -10.5 -25t-25.5 10l-464 453v-438q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v1000q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe070;" d="M50 1100h100q21 0 35.5 -14.5t14.5 -35.5v-438l464 453q15 14 25.5 10t10.5 -25v-438l464 453q15 14 25.5 10t10.5 -25v-1000q0 -21 -10.5 -25t-25.5 10l-464 453v-438q0 -21 -10.5 -25t-25.5 10l-464 453v-438q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5 t-14.5 35.5v1000q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe071;" d="M1200 1050v-1000q0 -21 -10.5 -25t-25.5 10l-464 453v-438q0 -21 -10.5 -25t-25.5 10l-492 480q-15 14 -15 35t15 35l492 480q15 14 25.5 10t10.5 -25v-438l464 453q15 14 25.5 10t10.5 -25z" />
<glyph unicode="&#xe072;" d="M243 1074l814 -498q18 -11 18 -26t-18 -26l-814 -498q-18 -11 -30.5 -4t-12.5 28v1000q0 21 12.5 28t30.5 -4z" />
<glyph unicode="&#xe073;" d="M250 1000h200q21 0 35.5 -14.5t14.5 -35.5v-800q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v800q0 21 14.5 35.5t35.5 14.5zM650 1000h200q21 0 35.5 -14.5t14.5 -35.5v-800q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v800 q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe074;" d="M1100 950v-800q0 -21 -14.5 -35.5t-35.5 -14.5h-800q-21 0 -35.5 14.5t-14.5 35.5v800q0 21 14.5 35.5t35.5 14.5h800q21 0 35.5 -14.5t14.5 -35.5z" />
<glyph unicode="&#xe075;" d="M500 612v438q0 21 10.5 25t25.5 -10l492 -480q15 -14 15 -35t-15 -35l-492 -480q-15 -14 -25.5 -10t-10.5 25v438l-464 -453q-15 -14 -25.5 -10t-10.5 25v1000q0 21 10.5 25t25.5 -10z" />
<glyph unicode="&#xe076;" d="M1048 1102l100 1q20 0 35 -14.5t15 -35.5l5 -1000q0 -21 -14.5 -35.5t-35.5 -14.5l-100 -1q-21 0 -35.5 14.5t-14.5 35.5l-2 437l-463 -454q-14 -15 -24.5 -10.5t-10.5 25.5l-2 437l-462 -455q-15 -14 -25.5 -9.5t-10.5 24.5l-5 1000q0 21 10.5 25.5t25.5 -10.5l466 -450 l-2 438q0 20 10.5 24.5t25.5 -9.5l466 -451l-2 438q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe077;" d="M850 1100h100q21 0 35.5 -14.5t14.5 -35.5v-1000q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v438l-464 -453q-15 -14 -25.5 -10t-10.5 25v1000q0 21 10.5 25t25.5 -10l464 -453v438q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe078;" d="M686 1081l501 -540q15 -15 10.5 -26t-26.5 -11h-1042q-22 0 -26.5 11t10.5 26l501 540q15 15 36 15t36 -15zM150 400h1000q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1000q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe079;" d="M885 900l-352 -353l352 -353l-197 -198l-552 552l552 550z" />
<glyph unicode="&#xe080;" d="M1064 547l-551 -551l-198 198l353 353l-353 353l198 198z" />
<glyph unicode="&#xe081;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM650 900h-100q-21 0 -35.5 -14.5t-14.5 -35.5v-150h-150 q-21 0 -35.5 -14.5t-14.5 -35.5v-100q0 -21 14.5 -35.5t35.5 -14.5h150v-150q0 -21 14.5 -35.5t35.5 -14.5h100q21 0 35.5 14.5t14.5 35.5v150h150q21 0 35.5 14.5t14.5 35.5v100q0 21 -14.5 35.5t-35.5 14.5h-150v150q0 21 -14.5 35.5t-35.5 14.5z" />
<glyph unicode="&#xe082;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM850 700h-500q-21 0 -35.5 -14.5t-14.5 -35.5v-100q0 -21 14.5 -35.5 t35.5 -14.5h500q21 0 35.5 14.5t14.5 35.5v100q0 21 -14.5 35.5t-35.5 14.5z" />
<glyph unicode="&#xe083;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM741.5 913q-12.5 0 -21.5 -9l-120 -120l-120 120q-9 9 -21.5 9 t-21.5 -9l-141 -141q-9 -9 -9 -21.5t9 -21.5l120 -120l-120 -120q-9 -9 -9 -21.5t9 -21.5l141 -141q9 -9 21.5 -9t21.5 9l120 120l120 -120q9 -9 21.5 -9t21.5 9l141 141q9 9 9 21.5t-9 21.5l-120 120l120 120q9 9 9 21.5t-9 21.5l-141 141q-9 9 -21.5 9z" />
<glyph unicode="&#xe084;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM546 623l-84 85q-7 7 -17.5 7t-18.5 -7l-139 -139q-7 -8 -7 -18t7 -18 l242 -241q7 -8 17.5 -8t17.5 8l375 375q7 7 7 17.5t-7 18.5l-139 139q-7 7 -17.5 7t-17.5 -7z" />
<glyph unicode="&#xe085;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM588 941q-29 0 -59 -5.5t-63 -20.5t-58 -38.5t-41.5 -63t-16.5 -89.5 q0 -25 20 -25h131q30 -5 35 11q6 20 20.5 28t45.5 8q20 0 31.5 -10.5t11.5 -28.5q0 -23 -7 -34t-26 -18q-1 0 -13.5 -4t-19.5 -7.5t-20 -10.5t-22 -17t-18.5 -24t-15.5 -35t-8 -46q-1 -8 5.5 -16.5t20.5 -8.5h173q7 0 22 8t35 28t37.5 48t29.5 74t12 100q0 47 -17 83 t-42.5 57t-59.5 34.5t-64 18t-59 4.5zM675 400h-150q-10 0 -17.5 -7.5t-7.5 -17.5v-150q0 -10 7.5 -17.5t17.5 -7.5h150q10 0 17.5 7.5t7.5 17.5v150q0 10 -7.5 17.5t-17.5 7.5z" />
<glyph unicode="&#xe086;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM675 1000h-150q-10 0 -17.5 -7.5t-7.5 -17.5v-150q0 -10 7.5 -17.5 t17.5 -7.5h150q10 0 17.5 7.5t7.5 17.5v150q0 10 -7.5 17.5t-17.5 7.5zM675 700h-250q-10 0 -17.5 -7.5t-7.5 -17.5v-50q0 -10 7.5 -17.5t17.5 -7.5h75v-200h-75q-10 0 -17.5 -7.5t-7.5 -17.5v-50q0 -10 7.5 -17.5t17.5 -7.5h350q10 0 17.5 7.5t7.5 17.5v50q0 10 -7.5 17.5 t-17.5 7.5h-75v275q0 10 -7.5 17.5t-17.5 7.5z" />
<glyph unicode="&#xe087;" d="M525 1200h150q10 0 17.5 -7.5t7.5 -17.5v-194q103 -27 178.5 -102.5t102.5 -178.5h194q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-194q-27 -103 -102.5 -178.5t-178.5 -102.5v-194q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5v194 q-103 27 -178.5 102.5t-102.5 178.5h-194q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5h194q27 103 102.5 178.5t178.5 102.5v194q0 10 7.5 17.5t17.5 7.5zM700 893v-168q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5v168q-68 -23 -119 -74 t-74 -119h168q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-168q23 -68 74 -119t119 -74v168q0 10 7.5 17.5t17.5 7.5h150q10 0 17.5 -7.5t7.5 -17.5v-168q68 23 119 74t74 119h-168q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5h168 q-23 68 -74 119t-119 74z" />
<glyph unicode="&#xe088;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM600 1027q-116 0 -214.5 -57t-155.5 -155.5t-57 -214.5t57 -214.5 t155.5 -155.5t214.5 -57t214.5 57t155.5 155.5t57 214.5t-57 214.5t-155.5 155.5t-214.5 57zM759 823l64 -64q7 -7 7 -17.5t-7 -17.5l-124 -124l124 -124q7 -7 7 -17.5t-7 -17.5l-64 -64q-7 -7 -17.5 -7t-17.5 7l-124 124l-124 -124q-7 -7 -17.5 -7t-17.5 7l-64 64 q-7 7 -7 17.5t7 17.5l124 124l-124 124q-7 7 -7 17.5t7 17.5l64 64q7 7 17.5 7t17.5 -7l124 -124l124 124q7 7 17.5 7t17.5 -7z" />
<glyph unicode="&#xe089;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM600 1027q-116 0 -214.5 -57t-155.5 -155.5t-57 -214.5t57 -214.5 t155.5 -155.5t214.5 -57t214.5 57t155.5 155.5t57 214.5t-57 214.5t-155.5 155.5t-214.5 57zM782 788l106 -106q7 -7 7 -17.5t-7 -17.5l-320 -321q-8 -7 -18 -7t-18 7l-202 203q-8 7 -8 17.5t8 17.5l106 106q7 8 17.5 8t17.5 -8l79 -79l197 197q7 7 17.5 7t17.5 -7z" />
<glyph unicode="&#xe090;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM600 1027q-116 0 -214.5 -57t-155.5 -155.5t-57 -214.5q0 -120 65 -225 l587 587q-105 65 -225 65zM965 819l-584 -584q104 -62 219 -62q116 0 214.5 57t155.5 155.5t57 214.5q0 115 -62 219z" />
<glyph unicode="&#xe091;" d="M39 582l522 427q16 13 27.5 8t11.5 -26v-291h550q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-550v-291q0 -21 -11.5 -26t-27.5 8l-522 427q-16 13 -16 32t16 32z" />
<glyph unicode="&#xe092;" d="M639 1009l522 -427q16 -13 16 -32t-16 -32l-522 -427q-16 -13 -27.5 -8t-11.5 26v291h-550q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5h550v291q0 21 11.5 26t27.5 -8z" />
<glyph unicode="&#xe093;" d="M682 1161l427 -522q13 -16 8 -27.5t-26 -11.5h-291v-550q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v550h-291q-21 0 -26 11.5t8 27.5l427 522q13 16 32 16t32 -16z" />
<glyph unicode="&#xe094;" d="M550 1200h200q21 0 35.5 -14.5t14.5 -35.5v-550h291q21 0 26 -11.5t-8 -27.5l-427 -522q-13 -16 -32 -16t-32 16l-427 522q-13 16 -8 27.5t26 11.5h291v550q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe095;" d="M639 1109l522 -427q16 -13 16 -32t-16 -32l-522 -427q-16 -13 -27.5 -8t-11.5 26v291q-94 -2 -182 -20t-170.5 -52t-147 -92.5t-100.5 -135.5q5 105 27 193.5t67.5 167t113 135t167 91.5t225.5 42v262q0 21 11.5 26t27.5 -8z" />
<glyph unicode="&#xe096;" d="M850 1200h300q21 0 35.5 -14.5t14.5 -35.5v-300q0 -21 -10.5 -25t-24.5 10l-94 94l-249 -249q-8 -7 -18 -7t-18 7l-106 106q-7 8 -7 18t7 18l249 249l-94 94q-14 14 -10 24.5t25 10.5zM350 0h-300q-21 0 -35.5 14.5t-14.5 35.5v300q0 21 10.5 25t24.5 -10l94 -94l249 249 q8 7 18 7t18 -7l106 -106q7 -8 7 -18t-7 -18l-249 -249l94 -94q14 -14 10 -24.5t-25 -10.5z" />
<glyph unicode="&#xe097;" d="M1014 1120l106 -106q7 -8 7 -18t-7 -18l-249 -249l94 -94q14 -14 10 -24.5t-25 -10.5h-300q-21 0 -35.5 14.5t-14.5 35.5v300q0 21 10.5 25t24.5 -10l94 -94l249 249q8 7 18 7t18 -7zM250 600h300q21 0 35.5 -14.5t14.5 -35.5v-300q0 -21 -10.5 -25t-24.5 10l-94 94 l-249 -249q-8 -7 -18 -7t-18 7l-106 106q-7 8 -7 18t7 18l249 249l-94 94q-14 14 -10 24.5t25 10.5z" />
<glyph unicode="&#xe101;" d="M600 1177q117 0 224 -45.5t184.5 -123t123 -184.5t45.5 -224t-45.5 -224t-123 -184.5t-184.5 -123t-224 -45.5t-224 45.5t-184.5 123t-123 184.5t-45.5 224t45.5 224t123 184.5t184.5 123t224 45.5zM704 900h-208q-20 0 -32 -14.5t-8 -34.5l58 -302q4 -20 21.5 -34.5 t37.5 -14.5h54q20 0 37.5 14.5t21.5 34.5l58 302q4 20 -8 34.5t-32 14.5zM675 400h-150q-10 0 -17.5 -7.5t-7.5 -17.5v-150q0 -10 7.5 -17.5t17.5 -7.5h150q10 0 17.5 7.5t7.5 17.5v150q0 10 -7.5 17.5t-17.5 7.5z" />
<glyph unicode="&#xe102;" d="M260 1200q9 0 19 -2t15 -4l5 -2q22 -10 44 -23l196 -118q21 -13 36 -24q29 -21 37 -12q11 13 49 35l196 118q22 13 45 23q17 7 38 7q23 0 47 -16.5t37 -33.5l13 -16q14 -21 18 -45l25 -123l8 -44q1 -9 8.5 -14.5t17.5 -5.5h61q10 0 17.5 -7.5t7.5 -17.5v-50 q0 -10 -7.5 -17.5t-17.5 -7.5h-50q-10 0 -17.5 -7.5t-7.5 -17.5v-175h-400v300h-200v-300h-400v175q0 10 -7.5 17.5t-17.5 7.5h-50q-10 0 -17.5 7.5t-7.5 17.5v50q0 10 7.5 17.5t17.5 7.5h61q11 0 18 3t7 8q0 4 9 52l25 128q5 25 19 45q2 3 5 7t13.5 15t21.5 19.5t26.5 15.5 t29.5 7zM915 1079l-166 -162q-7 -7 -5 -12t12 -5h219q10 0 15 7t2 17l-51 149q-3 10 -11 12t-15 -6zM463 917l-177 157q-8 7 -16 5t-11 -12l-51 -143q-3 -10 2 -17t15 -7h231q11 0 12.5 5t-5.5 12zM500 0h-375q-10 0 -17.5 7.5t-7.5 17.5v375h400v-400zM1100 400v-375 q0 -10 -7.5 -17.5t-17.5 -7.5h-375v400h400z" />
<glyph unicode="&#xe103;" d="M1165 1190q8 3 21 -6.5t13 -17.5q-2 -178 -24.5 -323.5t-55.5 -245.5t-87 -174.5t-102.5 -118.5t-118 -68.5t-118.5 -33t-120 -4.5t-105 9.5t-90 16.5q-61 12 -78 11q-4 1 -12.5 0t-34 -14.5t-52.5 -40.5l-153 -153q-26 -24 -37 -14.5t-11 43.5q0 64 42 102q8 8 50.5 45 t66.5 58q19 17 35 47t13 61q-9 55 -10 102.5t7 111t37 130t78 129.5q39 51 80 88t89.5 63.5t94.5 45t113.5 36t129 31t157.5 37t182 47.5zM1116 1098q-8 9 -22.5 -3t-45.5 -50q-38 -47 -119 -103.5t-142 -89.5l-62 -33q-56 -30 -102 -57t-104 -68t-102.5 -80.5t-85.5 -91 t-64 -104.5q-24 -56 -31 -86t2 -32t31.5 17.5t55.5 59.5q25 30 94 75.5t125.5 77.5t147.5 81q70 37 118.5 69t102 79.5t99 111t86.5 148.5q22 50 24 60t-6 19z" />
<glyph unicode="&#xe104;" d="M653 1231q-39 -67 -54.5 -131t-10.5 -114.5t24.5 -96.5t47.5 -80t63.5 -62.5t68.5 -46.5t65 -30q-4 7 -17.5 35t-18.5 39.5t-17 39.5t-17 43t-13 42t-9.5 44.5t-2 42t4 43t13.5 39t23 38.5q96 -42 165 -107.5t105 -138t52 -156t13 -159t-19 -149.5q-13 -55 -44 -106.5 t-68 -87t-78.5 -64.5t-72.5 -45t-53 -22q-72 -22 -127 -11q-31 6 -13 19q6 3 17 7q13 5 32.5 21t41 44t38.5 63.5t21.5 81.5t-6.5 94.5t-50 107t-104 115.5q10 -104 -0.5 -189t-37 -140.5t-65 -93t-84 -52t-93.5 -11t-95 24.5q-80 36 -131.5 114t-53.5 171q-2 23 0 49.5 t4.5 52.5t13.5 56t27.5 60t46 64.5t69.5 68.5q-8 -53 -5 -102.5t17.5 -90t34 -68.5t44.5 -39t49 -2q31 13 38.5 36t-4.5 55t-29 64.5t-36 75t-26 75.5q-15 85 2 161.5t53.5 128.5t85.5 92.5t93.5 61t81.5 25.5z" />
<glyph unicode="&#xe105;" d="M600 1094q82 0 160.5 -22.5t140 -59t116.5 -82.5t94.5 -95t68 -95t42.5 -82.5t14 -57.5t-14 -57.5t-43 -82.5t-68.5 -95t-94.5 -95t-116.5 -82.5t-140 -59t-159.5 -22.5t-159.5 22.5t-140 59t-116.5 82.5t-94.5 95t-68.5 95t-43 82.5t-14 57.5t14 57.5t42.5 82.5t68 95 t94.5 95t116.5 82.5t140 59t160.5 22.5zM888 829q-15 15 -18 12t5 -22q25 -57 25 -119q0 -124 -88 -212t-212 -88t-212 88t-88 212q0 59 23 114q8 19 4.5 22t-17.5 -12q-70 -69 -160 -184q-13 -16 -15 -40.5t9 -42.5q22 -36 47 -71t70 -82t92.5 -81t113 -58.5t133.5 -24.5 t133.5 24t113 58.5t92.5 81.5t70 81.5t47 70.5q11 18 9 42.5t-14 41.5q-90 117 -163 189zM448 727l-35 -36q-15 -15 -19.5 -38.5t4.5 -41.5q37 -68 93 -116q16 -13 38.5 -11t36.5 17l35 34q14 15 12.5 33.5t-16.5 33.5q-44 44 -89 117q-11 18 -28 20t-32 -12z" />
<glyph unicode="&#xe106;" d="M592 0h-148l31 120q-91 20 -175.5 68.5t-143.5 106.5t-103.5 119t-66.5 110t-22 76q0 21 14 57.5t42.5 82.5t68 95t94.5 95t116.5 82.5t140 59t160.5 22.5q61 0 126 -15l32 121h148zM944 770l47 181q108 -85 176.5 -192t68.5 -159q0 -26 -19.5 -71t-59.5 -102t-93 -112 t-129 -104.5t-158 -75.5l46 173q77 49 136 117t97 131q11 18 9 42.5t-14 41.5q-54 70 -107 130zM310 824q-70 -69 -160 -184q-13 -16 -15 -40.5t9 -42.5q18 -30 39 -60t57 -70.5t74 -73t90 -61t105 -41.5l41 154q-107 18 -178.5 101.5t-71.5 193.5q0 59 23 114q8 19 4.5 22 t-17.5 -12zM448 727l-35 -36q-15 -15 -19.5 -38.5t4.5 -41.5q37 -68 93 -116q16 -13 38.5 -11t36.5 17l12 11l22 86l-3 4q-44 44 -89 117q-11 18 -28 20t-32 -12z" />
<glyph unicode="&#xe107;" d="M-90 100l642 1066q20 31 48 28.5t48 -35.5l642 -1056q21 -32 7.5 -67.5t-50.5 -35.5h-1294q-37 0 -50.5 34t7.5 66zM155 200h345v75q0 10 7.5 17.5t17.5 7.5h150q10 0 17.5 -7.5t7.5 -17.5v-75h345l-445 723zM496 700h208q20 0 32 -14.5t8 -34.5l-58 -252 q-4 -20 -21.5 -34.5t-37.5 -14.5h-54q-20 0 -37.5 14.5t-21.5 34.5l-58 252q-4 20 8 34.5t32 14.5z" />
<glyph unicode="&#xe108;" d="M650 1200q62 0 106 -44t44 -106v-339l363 -325q15 -14 26 -38.5t11 -44.5v-41q0 -20 -12 -26.5t-29 5.5l-359 249v-263q100 -93 100 -113v-64q0 -21 -13 -29t-32 1l-205 128l-205 -128q-19 -9 -32 -1t-13 29v64q0 20 100 113v263l-359 -249q-17 -12 -29 -5.5t-12 26.5v41 q0 20 11 44.5t26 38.5l363 325v339q0 62 44 106t106 44z" />
<glyph unicode="&#xe109;" d="M850 1200h100q21 0 35.5 -14.5t14.5 -35.5v-50h50q21 0 35.5 -14.5t14.5 -35.5v-150h-1100v150q0 21 14.5 35.5t35.5 14.5h50v50q0 21 14.5 35.5t35.5 14.5h100q21 0 35.5 -14.5t14.5 -35.5v-50h500v50q0 21 14.5 35.5t35.5 14.5zM1100 800v-750q0 -21 -14.5 -35.5 t-35.5 -14.5h-1000q-21 0 -35.5 14.5t-14.5 35.5v750h1100zM100 600v-100h100v100h-100zM300 600v-100h100v100h-100zM500 600v-100h100v100h-100zM700 600v-100h100v100h-100zM900 600v-100h100v100h-100zM100 400v-100h100v100h-100zM300 400v-100h100v100h-100zM500 400 v-100h100v100h-100zM700 400v-100h100v100h-100zM900 400v-100h100v100h-100zM100 200v-100h100v100h-100zM300 200v-100h100v100h-100zM500 200v-100h100v100h-100zM700 200v-100h100v100h-100zM900 200v-100h100v100h-100z" />
<glyph unicode="&#xe110;" d="M1135 1165l249 -230q15 -14 15 -35t-15 -35l-249 -230q-14 -14 -24.5 -10t-10.5 25v150h-159l-600 -600h-291q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5h209l600 600h241v150q0 21 10.5 25t24.5 -10zM522 819l-141 -141l-122 122h-209q-21 0 -35.5 14.5 t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5h291zM1135 565l249 -230q15 -14 15 -35t-15 -35l-249 -230q-14 -14 -24.5 -10t-10.5 25v150h-241l-181 181l141 141l122 -122h159v150q0 21 10.5 25t24.5 -10z" />
<glyph unicode="&#xe111;" d="M100 1100h1000q41 0 70.5 -29.5t29.5 -70.5v-600q0 -41 -29.5 -70.5t-70.5 -29.5h-596l-304 -300v300h-100q-41 0 -70.5 29.5t-29.5 70.5v600q0 41 29.5 70.5t70.5 29.5z" />
<glyph unicode="&#xe112;" d="M150 1200h200q21 0 35.5 -14.5t14.5 -35.5v-250h-300v250q0 21 14.5 35.5t35.5 14.5zM850 1200h200q21 0 35.5 -14.5t14.5 -35.5v-250h-300v250q0 21 14.5 35.5t35.5 14.5zM1100 800v-300q0 -41 -3 -77.5t-15 -89.5t-32 -96t-58 -89t-89 -77t-129 -51t-174 -20t-174 20 t-129 51t-89 77t-58 89t-32 96t-15 89.5t-3 77.5v300h300v-250v-27v-42.5t1.5 -41t5 -38t10 -35t16.5 -30t25.5 -24.5t35 -19t46.5 -12t60 -4t60 4.5t46.5 12.5t35 19.5t25 25.5t17 30.5t10 35t5 38t2 40.5t-0.5 42v25v250h300z" />
<glyph unicode="&#xe113;" d="M1100 411l-198 -199l-353 353l-353 -353l-197 199l551 551z" />
<glyph unicode="&#xe114;" d="M1101 789l-550 -551l-551 551l198 199l353 -353l353 353z" />
<glyph unicode="&#xe115;" d="M404 1000h746q21 0 35.5 -14.5t14.5 -35.5v-551h150q21 0 25 -10.5t-10 -24.5l-230 -249q-14 -15 -35 -15t-35 15l-230 249q-14 14 -10 24.5t25 10.5h150v401h-381zM135 984l230 -249q14 -14 10 -24.5t-25 -10.5h-150v-400h385l215 -200h-750q-21 0 -35.5 14.5 t-14.5 35.5v550h-150q-21 0 -25 10.5t10 24.5l230 249q14 15 35 15t35 -15z" />
<glyph unicode="&#xe116;" d="M56 1200h94q17 0 31 -11t18 -27l38 -162h896q24 0 39 -18.5t10 -42.5l-100 -475q-5 -21 -27 -42.5t-55 -21.5h-633l48 -200h535q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-50v-50q0 -21 -14.5 -35.5t-35.5 -14.5t-35.5 14.5t-14.5 35.5v50h-300v-50 q0 -21 -14.5 -35.5t-35.5 -14.5t-35.5 14.5t-14.5 35.5v50h-31q-18 0 -32.5 10t-20.5 19l-5 10l-201 961h-54q-20 0 -35 14.5t-15 35.5t15 35.5t35 14.5z" />
<glyph unicode="&#xe117;" d="M1200 1000v-100h-1200v100h200q0 41 29.5 70.5t70.5 29.5h300q41 0 70.5 -29.5t29.5 -70.5h500zM0 800h1200v-800h-1200v800z" />
<glyph unicode="&#xe118;" d="M200 800l-200 -400v600h200q0 41 29.5 70.5t70.5 29.5h300q42 0 71 -29.5t29 -70.5h500v-200h-1000zM1500 700l-300 -700h-1200l300 700h1200z" />
<glyph unicode="&#xe119;" d="M635 1184l230 -249q14 -14 10 -24.5t-25 -10.5h-150v-601h150q21 0 25 -10.5t-10 -24.5l-230 -249q-14 -15 -35 -15t-35 15l-230 249q-14 14 -10 24.5t25 10.5h150v601h-150q-21 0 -25 10.5t10 24.5l230 249q14 15 35 15t35 -15z" />
<glyph unicode="&#xe120;" d="M936 864l249 -229q14 -15 14 -35.5t-14 -35.5l-249 -229q-15 -15 -25.5 -10.5t-10.5 24.5v151h-600v-151q0 -20 -10.5 -24.5t-25.5 10.5l-249 229q-14 15 -14 35.5t14 35.5l249 229q15 15 25.5 10.5t10.5 -25.5v-149h600v149q0 21 10.5 25.5t25.5 -10.5z" />
<glyph unicode="&#xe121;" d="M1169 400l-172 732q-5 23 -23 45.5t-38 22.5h-672q-20 0 -38 -20t-23 -41l-172 -739h1138zM1100 300h-1000q-41 0 -70.5 -29.5t-29.5 -70.5v-100q0 -41 29.5 -70.5t70.5 -29.5h1000q41 0 70.5 29.5t29.5 70.5v100q0 41 -29.5 70.5t-70.5 29.5zM800 100v100h100v-100h-100 zM1000 100v100h100v-100h-100z" />
<glyph unicode="&#xe122;" d="M1150 1100q21 0 35.5 -14.5t14.5 -35.5v-850q0 -21 -14.5 -35.5t-35.5 -14.5t-35.5 14.5t-14.5 35.5v850q0 21 14.5 35.5t35.5 14.5zM1000 200l-675 200h-38l47 -276q3 -16 -5.5 -20t-29.5 -4h-7h-84q-20 0 -34.5 14t-18.5 35q-55 337 -55 351v250v6q0 16 1 23.5t6.5 14 t17.5 6.5h200l675 250v-850zM0 750v-250q-4 0 -11 0.5t-24 6t-30 15t-24 30t-11 48.5v50q0 26 10.5 46t25 30t29 16t25.5 7z" />
<glyph unicode="&#xe123;" d="M553 1200h94q20 0 29 -10.5t3 -29.5l-18 -37q83 -19 144 -82.5t76 -140.5l63 -327l118 -173h17q19 0 33 -14.5t14 -35t-13 -40.5t-31 -27q-8 -4 -23 -9.5t-65 -19.5t-103 -25t-132.5 -20t-158.5 -9q-57 0 -115 5t-104 12t-88.5 15.5t-73.5 17.5t-54.5 16t-35.5 12l-11 4 q-18 8 -31 28t-13 40.5t14 35t33 14.5h17l118 173l63 327q15 77 76 140t144 83l-18 32q-6 19 3.5 32t28.5 13zM498 110q50 -6 102 -6q53 0 102 6q-12 -49 -39.5 -79.5t-62.5 -30.5t-63 30.5t-39 79.5z" />
<glyph unicode="&#xe124;" d="M800 946l224 78l-78 -224l234 -45l-180 -155l180 -155l-234 -45l78 -224l-224 78l-45 -234l-155 180l-155 -180l-45 234l-224 -78l78 224l-234 45l180 155l-180 155l234 45l-78 224l224 -78l45 234l155 -180l155 180z" />
<glyph unicode="&#xe125;" d="M650 1200h50q40 0 70 -40.5t30 -84.5v-150l-28 -125h328q40 0 70 -40.5t30 -84.5v-100q0 -45 -29 -74l-238 -344q-16 -24 -38 -40.5t-45 -16.5h-250q-7 0 -42 25t-66 50l-31 25h-61q-45 0 -72.5 18t-27.5 57v400q0 36 20 63l145 196l96 198q13 28 37.5 48t51.5 20z M650 1100l-100 -212l-150 -213v-375h100l136 -100h214l250 375v125h-450l50 225v175h-50zM50 800h100q21 0 35.5 -14.5t14.5 -35.5v-500q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v500q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe126;" d="M600 1100h250q23 0 45 -16.5t38 -40.5l238 -344q29 -29 29 -74v-100q0 -44 -30 -84.5t-70 -40.5h-328q28 -118 28 -125v-150q0 -44 -30 -84.5t-70 -40.5h-50q-27 0 -51.5 20t-37.5 48l-96 198l-145 196q-20 27 -20 63v400q0 39 27.5 57t72.5 18h61q124 100 139 100z M50 1000h100q21 0 35.5 -14.5t14.5 -35.5v-500q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v500q0 21 14.5 35.5t35.5 14.5zM636 1000l-136 -100h-100v-375l150 -213l100 -212h50v175l-50 225h450v125l-250 375h-214z" />
<glyph unicode="&#xe127;" d="M356 873l363 230q31 16 53 -6l110 -112q13 -13 13.5 -32t-11.5 -34l-84 -121h302q84 0 138 -38t54 -110t-55 -111t-139 -39h-106l-131 -339q-6 -21 -19.5 -41t-28.5 -20h-342q-7 0 -90 81t-83 94v525q0 17 14 35.5t28 28.5zM400 792v-503l100 -89h293l131 339 q6 21 19.5 41t28.5 20h203q21 0 30.5 25t0.5 50t-31 25h-456h-7h-6h-5.5t-6 0.5t-5 1.5t-5 2t-4 2.5t-4 4t-2.5 4.5q-12 25 5 47l146 183l-86 83zM50 800h100q21 0 35.5 -14.5t14.5 -35.5v-500q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v500 q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe128;" d="M475 1103l366 -230q2 -1 6 -3.5t14 -10.5t18 -16.5t14.5 -20t6.5 -22.5v-525q0 -13 -86 -94t-93 -81h-342q-15 0 -28.5 20t-19.5 41l-131 339h-106q-85 0 -139.5 39t-54.5 111t54 110t138 38h302l-85 121q-11 15 -10.5 34t13.5 32l110 112q22 22 53 6zM370 945l146 -183 q17 -22 5 -47q-2 -2 -3.5 -4.5t-4 -4t-4 -2.5t-5 -2t-5 -1.5t-6 -0.5h-6h-6.5h-6h-475v-100h221q15 0 29 -20t20 -41l130 -339h294l106 89v503l-342 236zM1050 800h100q21 0 35.5 -14.5t14.5 -35.5v-500q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5 v500q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe129;" d="M550 1294q72 0 111 -55t39 -139v-106l339 -131q21 -6 41 -19.5t20 -28.5v-342q0 -7 -81 -90t-94 -83h-525q-17 0 -35.5 14t-28.5 28l-9 14l-230 363q-16 31 6 53l112 110q13 13 32 13.5t34 -11.5l121 -84v302q0 84 38 138t110 54zM600 972v203q0 21 -25 30.5t-50 0.5 t-25 -31v-456v-7v-6v-5.5t-0.5 -6t-1.5 -5t-2 -5t-2.5 -4t-4 -4t-4.5 -2.5q-25 -12 -47 5l-183 146l-83 -86l236 -339h503l89 100v293l-339 131q-21 6 -41 19.5t-20 28.5zM450 200h500q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-500 q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe130;" d="M350 1100h500q21 0 35.5 14.5t14.5 35.5v100q0 21 -14.5 35.5t-35.5 14.5h-500q-21 0 -35.5 -14.5t-14.5 -35.5v-100q0 -21 14.5 -35.5t35.5 -14.5zM600 306v-106q0 -84 -39 -139t-111 -55t-110 54t-38 138v302l-121 -84q-15 -12 -34 -11.5t-32 13.5l-112 110 q-22 22 -6 53l230 363q1 2 3.5 6t10.5 13.5t16.5 17t20 13.5t22.5 6h525q13 0 94 -83t81 -90v-342q0 -15 -20 -28.5t-41 -19.5zM308 900l-236 -339l83 -86l183 146q22 17 47 5q2 -1 4.5 -2.5t4 -4t2.5 -4t2 -5t1.5 -5t0.5 -6v-5.5v-6v-7v-456q0 -22 25 -31t50 0.5t25 30.5 v203q0 15 20 28.5t41 19.5l339 131v293l-89 100h-503z" />
<glyph unicode="&#xe131;" d="M600 1178q118 0 225 -45.5t184.5 -123t123 -184.5t45.5 -225t-45.5 -225t-123 -184.5t-184.5 -123t-225 -45.5t-225 45.5t-184.5 123t-123 184.5t-45.5 225t45.5 225t123 184.5t184.5 123t225 45.5zM914 632l-275 223q-16 13 -27.5 8t-11.5 -26v-137h-275 q-10 0 -17.5 -7.5t-7.5 -17.5v-150q0 -10 7.5 -17.5t17.5 -7.5h275v-137q0 -21 11.5 -26t27.5 8l275 223q16 13 16 32t-16 32z" />
<glyph unicode="&#xe132;" d="M600 1178q118 0 225 -45.5t184.5 -123t123 -184.5t45.5 -225t-45.5 -225t-123 -184.5t-184.5 -123t-225 -45.5t-225 45.5t-184.5 123t-123 184.5t-45.5 225t45.5 225t123 184.5t184.5 123t225 45.5zM561 855l-275 -223q-16 -13 -16 -32t16 -32l275 -223q16 -13 27.5 -8 t11.5 26v137h275q10 0 17.5 7.5t7.5 17.5v150q0 10 -7.5 17.5t-17.5 7.5h-275v137q0 21 -11.5 26t-27.5 -8z" />
<glyph unicode="&#xe133;" d="M600 1178q118 0 225 -45.5t184.5 -123t123 -184.5t45.5 -225t-45.5 -225t-123 -184.5t-184.5 -123t-225 -45.5t-225 45.5t-184.5 123t-123 184.5t-45.5 225t45.5 225t123 184.5t184.5 123t225 45.5zM855 639l-223 275q-13 16 -32 16t-32 -16l-223 -275q-13 -16 -8 -27.5 t26 -11.5h137v-275q0 -10 7.5 -17.5t17.5 -7.5h150q10 0 17.5 7.5t7.5 17.5v275h137q21 0 26 11.5t-8 27.5z" />
<glyph unicode="&#xe134;" d="M600 1178q118 0 225 -45.5t184.5 -123t123 -184.5t45.5 -225t-45.5 -225t-123 -184.5t-184.5 -123t-225 -45.5t-225 45.5t-184.5 123t-123 184.5t-45.5 225t45.5 225t123 184.5t184.5 123t225 45.5zM675 900h-150q-10 0 -17.5 -7.5t-7.5 -17.5v-275h-137q-21 0 -26 -11.5 t8 -27.5l223 -275q13 -16 32 -16t32 16l223 275q13 16 8 27.5t-26 11.5h-137v275q0 10 -7.5 17.5t-17.5 7.5z" />
<glyph unicode="&#xe135;" d="M600 1176q116 0 222.5 -46t184 -123.5t123.5 -184t46 -222.5t-46 -222.5t-123.5 -184t-184 -123.5t-222.5 -46t-222.5 46t-184 123.5t-123.5 184t-46 222.5t46 222.5t123.5 184t184 123.5t222.5 46zM627 1101q-15 -12 -36.5 -20.5t-35.5 -12t-43 -8t-39 -6.5 q-15 -3 -45.5 0t-45.5 -2q-20 -7 -51.5 -26.5t-34.5 -34.5q-3 -11 6.5 -22.5t8.5 -18.5q-3 -34 -27.5 -91t-29.5 -79q-9 -34 5 -93t8 -87q0 -9 17 -44.5t16 -59.5q12 0 23 -5t23.5 -15t19.5 -14q16 -8 33 -15t40.5 -15t34.5 -12q21 -9 52.5 -32t60 -38t57.5 -11 q7 -15 -3 -34t-22.5 -40t-9.5 -38q13 -21 23 -34.5t27.5 -27.5t36.5 -18q0 -7 -3.5 -16t-3.5 -14t5 -17q104 -2 221 112q30 29 46.5 47t34.5 49t21 63q-13 8 -37 8.5t-36 7.5q-15 7 -49.5 15t-51.5 19q-18 0 -41 -0.5t-43 -1.5t-42 -6.5t-38 -16.5q-51 -35 -66 -12 q-4 1 -3.5 25.5t0.5 25.5q-6 13 -26.5 17.5t-24.5 6.5q1 15 -0.5 30.5t-7 28t-18.5 11.5t-31 -21q-23 -25 -42 4q-19 28 -8 58q6 16 22 22q6 -1 26 -1.5t33.5 -4t19.5 -13.5q7 -12 18 -24t21.5 -20.5t20 -15t15.5 -10.5l5 -3q2 12 7.5 30.5t8 34.5t-0.5 32q-3 18 3.5 29 t18 22.5t15.5 24.5q6 14 10.5 35t8 31t15.5 22.5t34 22.5q-6 18 10 36q8 0 24 -1.5t24.5 -1.5t20 4.5t20.5 15.5q-10 23 -31 42.5t-37.5 29.5t-49 27t-43.5 23q0 1 2 8t3 11.5t1.5 10.5t-1 9.5t-4.5 4.5q31 -13 58.5 -14.5t38.5 2.5l12 5q5 28 -9.5 46t-36.5 24t-50 15 t-41 20q-18 -4 -37 0zM613 994q0 -17 8 -42t17 -45t9 -23q-8 1 -39.5 5.5t-52.5 10t-37 16.5q3 11 16 29.5t16 25.5q10 -10 19 -10t14 6t13.5 14.5t16.5 12.5z" />
<glyph unicode="&#xe136;" d="M756 1157q164 92 306 -9l-259 -138l145 -232l251 126q6 -89 -34 -156.5t-117 -110.5q-60 -34 -127 -39.5t-126 16.5l-596 -596q-15 -16 -36.5 -16t-36.5 16l-111 110q-15 15 -15 36.5t15 37.5l600 599q-34 101 5.5 201.5t135.5 154.5z" />
<glyph unicode="&#xe137;" horiz-adv-x="1220" d="M100 1196h1000q41 0 70.5 -29.5t29.5 -70.5v-100q0 -41 -29.5 -70.5t-70.5 -29.5h-1000q-41 0 -70.5 29.5t-29.5 70.5v100q0 41 29.5 70.5t70.5 29.5zM1100 1096h-200v-100h200v100zM100 796h1000q41 0 70.5 -29.5t29.5 -70.5v-100q0 -41 -29.5 -70.5t-70.5 -29.5h-1000 q-41 0 -70.5 29.5t-29.5 70.5v100q0 41 29.5 70.5t70.5 29.5zM1100 696h-500v-100h500v100zM100 396h1000q41 0 70.5 -29.5t29.5 -70.5v-100q0 -41 -29.5 -70.5t-70.5 -29.5h-1000q-41 0 -70.5 29.5t-29.5 70.5v100q0 41 29.5 70.5t70.5 29.5zM1100 296h-300v-100h300v100z " />
<glyph unicode="&#xe138;" d="M150 1200h900q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-900q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5zM700 500v-300l-200 -200v500l-350 500h900z" />
<glyph unicode="&#xe139;" d="M500 1200h200q41 0 70.5 -29.5t29.5 -70.5v-100h300q41 0 70.5 -29.5t29.5 -70.5v-400h-500v100h-200v-100h-500v400q0 41 29.5 70.5t70.5 29.5h300v100q0 41 29.5 70.5t70.5 29.5zM500 1100v-100h200v100h-200zM1200 400v-200q0 -41 -29.5 -70.5t-70.5 -29.5h-1000 q-41 0 -70.5 29.5t-29.5 70.5v200h1200z" />
<glyph unicode="&#xe140;" d="M50 1200h300q21 0 25 -10.5t-10 -24.5l-94 -94l199 -199q7 -8 7 -18t-7 -18l-106 -106q-8 -7 -18 -7t-18 7l-199 199l-94 -94q-14 -14 -24.5 -10t-10.5 25v300q0 21 14.5 35.5t35.5 14.5zM850 1200h300q21 0 35.5 -14.5t14.5 -35.5v-300q0 -21 -10.5 -25t-24.5 10l-94 94 l-199 -199q-8 -7 -18 -7t-18 7l-106 106q-7 8 -7 18t7 18l199 199l-94 94q-14 14 -10 24.5t25 10.5zM364 470l106 -106q7 -8 7 -18t-7 -18l-199 -199l94 -94q14 -14 10 -24.5t-25 -10.5h-300q-21 0 -35.5 14.5t-14.5 35.5v300q0 21 10.5 25t24.5 -10l94 -94l199 199 q8 7 18 7t18 -7zM1071 271l94 94q14 14 24.5 10t10.5 -25v-300q0 -21 -14.5 -35.5t-35.5 -14.5h-300q-21 0 -25 10.5t10 24.5l94 94l-199 199q-7 8 -7 18t7 18l106 106q8 7 18 7t18 -7z" />
<glyph unicode="&#xe141;" d="M596 1192q121 0 231.5 -47.5t190 -127t127 -190t47.5 -231.5t-47.5 -231.5t-127 -190.5t-190 -127t-231.5 -47t-231.5 47t-190.5 127t-127 190.5t-47 231.5t47 231.5t127 190t190.5 127t231.5 47.5zM596 1010q-112 0 -207.5 -55.5t-151 -151t-55.5 -207.5t55.5 -207.5 t151 -151t207.5 -55.5t207.5 55.5t151 151t55.5 207.5t-55.5 207.5t-151 151t-207.5 55.5zM454.5 905q22.5 0 38.5 -16t16 -38.5t-16 -39t-38.5 -16.5t-38.5 16.5t-16 39t16 38.5t38.5 16zM754.5 905q22.5 0 38.5 -16t16 -38.5t-16 -39t-38 -16.5q-14 0 -29 10l-55 -145 q17 -23 17 -51q0 -36 -25.5 -61.5t-61.5 -25.5t-61.5 25.5t-25.5 61.5q0 32 20.5 56.5t51.5 29.5l122 126l1 1q-9 14 -9 28q0 23 16 39t38.5 16zM345.5 709q22.5 0 38.5 -16t16 -38.5t-16 -38.5t-38.5 -16t-38.5 16t-16 38.5t16 38.5t38.5 16zM854.5 709q22.5 0 38.5 -16 t16 -38.5t-16 -38.5t-38.5 -16t-38.5 16t-16 38.5t16 38.5t38.5 16z" />
<glyph unicode="&#xe142;" d="M546 173l469 470q91 91 99 192q7 98 -52 175.5t-154 94.5q-22 4 -47 4q-34 0 -66.5 -10t-56.5 -23t-55.5 -38t-48 -41.5t-48.5 -47.5q-376 -375 -391 -390q-30 -27 -45 -41.5t-37.5 -41t-32 -46.5t-16 -47.5t-1.5 -56.5q9 -62 53.5 -95t99.5 -33q74 0 125 51l548 548 q36 36 20 75q-7 16 -21.5 26t-32.5 10q-26 0 -50 -23q-13 -12 -39 -38l-341 -338q-15 -15 -35.5 -15.5t-34.5 13.5t-14 34.5t14 34.5q327 333 361 367q35 35 67.5 51.5t78.5 16.5q14 0 29 -1q44 -8 74.5 -35.5t43.5 -68.5q14 -47 2 -96.5t-47 -84.5q-12 -11 -32 -32 t-79.5 -81t-114.5 -115t-124.5 -123.5t-123 -119.5t-96.5 -89t-57 -45q-56 -27 -120 -27q-70 0 -129 32t-93 89q-48 78 -35 173t81 163l511 511q71 72 111 96q91 55 198 55q80 0 152 -33q78 -36 129.5 -103t66.5 -154q17 -93 -11 -183.5t-94 -156.5l-482 -476 q-15 -15 -36 -16t-37 14t-17.5 34t14.5 35z" />
<glyph unicode="&#xe143;" d="M649 949q48 68 109.5 104t121.5 38.5t118.5 -20t102.5 -64t71 -100.5t27 -123q0 -57 -33.5 -117.5t-94 -124.5t-126.5 -127.5t-150 -152.5t-146 -174q-62 85 -145.5 174t-150 152.5t-126.5 127.5t-93.5 124.5t-33.5 117.5q0 64 28 123t73 100.5t104 64t119 20 t120.5 -38.5t104.5 -104zM896 972q-33 0 -64.5 -19t-56.5 -46t-47.5 -53.5t-43.5 -45.5t-37.5 -19t-36 19t-40 45.5t-43 53.5t-54 46t-65.5 19q-67 0 -122.5 -55.5t-55.5 -132.5q0 -23 13.5 -51t46 -65t57.5 -63t76 -75l22 -22q15 -14 44 -44t50.5 -51t46 -44t41 -35t23 -12 t23.5 12t42.5 36t46 44t52.5 52t44 43q4 4 12 13q43 41 63.5 62t52 55t46 55t26 46t11.5 44q0 79 -53 133.5t-120 54.5z" />
<glyph unicode="&#xe144;" d="M776.5 1214q93.5 0 159.5 -66l141 -141q66 -66 66 -160q0 -42 -28 -95.5t-62 -87.5l-29 -29q-31 53 -77 99l-18 18l95 95l-247 248l-389 -389l212 -212l-105 -106l-19 18l-141 141q-66 66 -66 159t66 159l283 283q65 66 158.5 66zM600 706l105 105q10 -8 19 -17l141 -141 q66 -66 66 -159t-66 -159l-283 -283q-66 -66 -159 -66t-159 66l-141 141q-66 66 -66 159.5t66 159.5l55 55q29 -55 75 -102l18 -17l-95 -95l247 -248l389 389z" />
<glyph unicode="&#xe145;" d="M603 1200q85 0 162 -15t127 -38t79 -48t29 -46v-953q0 -41 -29.5 -70.5t-70.5 -29.5h-600q-41 0 -70.5 29.5t-29.5 70.5v953q0 21 30 46.5t81 48t129 37.5t163 15zM300 1000v-700h600v700h-600zM600 254q-43 0 -73.5 -30.5t-30.5 -73.5t30.5 -73.5t73.5 -30.5t73.5 30.5 t30.5 73.5t-30.5 73.5t-73.5 30.5z" />
<glyph unicode="&#xe146;" d="M902 1185l283 -282q15 -15 15 -36t-14.5 -35.5t-35.5 -14.5t-35 15l-36 35l-279 -267v-300l-212 210l-308 -307l-280 -203l203 280l307 308l-210 212h300l267 279l-35 36q-15 14 -15 35t14.5 35.5t35.5 14.5t35 -15z" />
<glyph unicode="&#xe148;" d="M700 1248v-78q38 -5 72.5 -14.5t75.5 -31.5t71 -53.5t52 -84t24 -118.5h-159q-4 36 -10.5 59t-21 45t-40 35.5t-64.5 20.5v-307l64 -13q34 -7 64 -16.5t70 -32t67.5 -52.5t47.5 -80t20 -112q0 -139 -89 -224t-244 -97v-77h-100v79q-150 16 -237 103q-40 40 -52.5 93.5 t-15.5 139.5h139q5 -77 48.5 -126t117.5 -65v335l-27 8q-46 14 -79 26.5t-72 36t-63 52t-40 72.5t-16 98q0 70 25 126t67.5 92t94.5 57t110 27v77h100zM600 754v274q-29 -4 -50 -11t-42 -21.5t-31.5 -41.5t-10.5 -65q0 -29 7 -50.5t16.5 -34t28.5 -22.5t31.5 -14t37.5 -10 q9 -3 13 -4zM700 547v-310q22 2 42.5 6.5t45 15.5t41.5 27t29 42t12 59.5t-12.5 59.5t-38 44.5t-53 31t-66.5 24.5z" />
<glyph unicode="&#xe149;" d="M561 1197q84 0 160.5 -40t123.5 -109.5t47 -147.5h-153q0 40 -19.5 71.5t-49.5 48.5t-59.5 26t-55.5 9q-37 0 -79 -14.5t-62 -35.5q-41 -44 -41 -101q0 -26 13.5 -63t26.5 -61t37 -66q6 -9 9 -14h241v-100h-197q8 -50 -2.5 -115t-31.5 -95q-45 -62 -99 -112 q34 10 83 17.5t71 7.5q32 1 102 -16t104 -17q83 0 136 30l50 -147q-31 -19 -58 -30.5t-55 -15.5t-42 -4.5t-46 -0.5q-23 0 -76 17t-111 32.5t-96 11.5q-39 -3 -82 -16t-67 -25l-23 -11l-55 145q4 3 16 11t15.5 10.5t13 9t15.5 12t14.5 14t17.5 18.5q48 55 54 126.5 t-30 142.5h-221v100h166q-23 47 -44 104q-7 20 -12 41.5t-6 55.5t6 66.5t29.5 70.5t58.5 71q97 88 263 88z" />
<glyph unicode="&#xe150;" d="M400 300h150q21 0 25 -11t-10 -25l-230 -250q-14 -15 -35 -15t-35 15l-230 250q-14 14 -10 25t25 11h150v900h200v-900zM935 1184l230 -249q14 -14 10 -24.5t-25 -10.5h-150v-900h-200v900h-150q-21 0 -25 10.5t10 24.5l230 249q14 15 35 15t35 -15z" />
<glyph unicode="&#xe151;" d="M1000 700h-100v100h-100v-100h-100v500h300v-500zM400 300h150q21 0 25 -11t-10 -25l-230 -250q-14 -15 -35 -15t-35 15l-230 250q-14 14 -10 25t25 11h150v900h200v-900zM801 1100v-200h100v200h-100zM1000 350l-200 -250h200v-100h-300v150l200 250h-200v100h300v-150z " />
<glyph unicode="&#xe152;" d="M400 300h150q21 0 25 -11t-10 -25l-230 -250q-14 -15 -35 -15t-35 15l-230 250q-14 14 -10 25t25 11h150v900h200v-900zM1000 1050l-200 -250h200v-100h-300v150l200 250h-200v100h300v-150zM1000 0h-100v100h-100v-100h-100v500h300v-500zM801 400v-200h100v200h-100z " />
<glyph unicode="&#xe153;" d="M400 300h150q21 0 25 -11t-10 -25l-230 -250q-14 -15 -35 -15t-35 15l-230 250q-14 14 -10 25t25 11h150v900h200v-900zM1000 700h-100v400h-100v100h200v-500zM1100 0h-100v100h-200v400h300v-500zM901 400v-200h100v200h-100z" />
<glyph unicode="&#xe154;" d="M400 300h150q21 0 25 -11t-10 -25l-230 -250q-14 -15 -35 -15t-35 15l-230 250q-14 14 -10 25t25 11h150v900h200v-900zM1100 700h-100v100h-200v400h300v-500zM901 1100v-200h100v200h-100zM1000 0h-100v400h-100v100h200v-500z" />
<glyph unicode="&#xe155;" d="M400 300h150q21 0 25 -11t-10 -25l-230 -250q-14 -15 -35 -15t-35 15l-230 250q-14 14 -10 25t25 11h150v900h200v-900zM900 1000h-200v200h200v-200zM1000 700h-300v200h300v-200zM1100 400h-400v200h400v-200zM1200 100h-500v200h500v-200z" />
<glyph unicode="&#xe156;" d="M400 300h150q21 0 25 -11t-10 -25l-230 -250q-14 -15 -35 -15t-35 15l-230 250q-14 14 -10 25t25 11h150v900h200v-900zM1200 1000h-500v200h500v-200zM1100 700h-400v200h400v-200zM1000 400h-300v200h300v-200zM900 100h-200v200h200v-200z" />
<glyph unicode="&#xe157;" d="M350 1100h400q162 0 256 -93.5t94 -256.5v-400q0 -165 -93.5 -257.5t-256.5 -92.5h-400q-165 0 -257.5 92.5t-92.5 257.5v400q0 165 92.5 257.5t257.5 92.5zM800 900h-500q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5 v500q0 41 -29.5 70.5t-70.5 29.5z" />
<glyph unicode="&#xe158;" d="M350 1100h400q165 0 257.5 -92.5t92.5 -257.5v-400q0 -165 -92.5 -257.5t-257.5 -92.5h-400q-163 0 -256.5 92.5t-93.5 257.5v400q0 163 94 256.5t256 93.5zM800 900h-500q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5 v500q0 41 -29.5 70.5t-70.5 29.5zM440 770l253 -190q17 -12 17 -30t-17 -30l-253 -190q-16 -12 -28 -6.5t-12 26.5v400q0 21 12 26.5t28 -6.5z" />
<glyph unicode="&#xe159;" d="M350 1100h400q163 0 256.5 -94t93.5 -256v-400q0 -165 -92.5 -257.5t-257.5 -92.5h-400q-165 0 -257.5 92.5t-92.5 257.5v400q0 163 92.5 256.5t257.5 93.5zM800 900h-500q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5 v500q0 41 -29.5 70.5t-70.5 29.5zM350 700h400q21 0 26.5 -12t-6.5 -28l-190 -253q-12 -17 -30 -17t-30 17l-190 253q-12 16 -6.5 28t26.5 12z" />
<glyph unicode="&#xe160;" d="M350 1100h400q165 0 257.5 -92.5t92.5 -257.5v-400q0 -163 -92.5 -256.5t-257.5 -93.5h-400q-163 0 -256.5 94t-93.5 256v400q0 165 92.5 257.5t257.5 92.5zM800 900h-500q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5 v500q0 41 -29.5 70.5t-70.5 29.5zM580 693l190 -253q12 -16 6.5 -28t-26.5 -12h-400q-21 0 -26.5 12t6.5 28l190 253q12 17 30 17t30 -17z" />
<glyph unicode="&#xe161;" d="M550 1100h400q165 0 257.5 -92.5t92.5 -257.5v-400q0 -165 -92.5 -257.5t-257.5 -92.5h-400q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5h450q41 0 70.5 29.5t29.5 70.5v500q0 41 -29.5 70.5t-70.5 29.5h-450q-21 0 -35.5 14.5t-14.5 35.5v100 q0 21 14.5 35.5t35.5 14.5zM338 867l324 -284q16 -14 16 -33t-16 -33l-324 -284q-16 -14 -27 -9t-11 26v150h-250q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5h250v150q0 21 11 26t27 -9z" />
<glyph unicode="&#xe162;" d="M793 1182l9 -9q8 -10 5 -27q-3 -11 -79 -225.5t-78 -221.5l300 1q24 0 32.5 -17.5t-5.5 -35.5q-1 0 -133.5 -155t-267 -312.5t-138.5 -162.5q-12 -15 -26 -15h-9l-9 8q-9 11 -4 32q2 9 42 123.5t79 224.5l39 110h-302q-23 0 -31 19q-10 21 6 41q75 86 209.5 237.5 t228 257t98.5 111.5q9 16 25 16h9z" />
<glyph unicode="&#xe163;" d="M350 1100h400q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-450q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h450q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-165 0 -257.5 92.5t-92.5 257.5v400 q0 165 92.5 257.5t257.5 92.5zM938 867l324 -284q16 -14 16 -33t-16 -33l-324 -284q-16 -14 -27 -9t-11 26v150h-250q-21 0 -35.5 14.5t-14.5 35.5v200q0 21 14.5 35.5t35.5 14.5h250v150q0 21 11 26t27 -9z" />
<glyph unicode="&#xe164;" d="M750 1200h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -10.5 -25t-24.5 10l-109 109l-312 -312q-15 -15 -35.5 -15t-35.5 15l-141 141q-15 15 -15 35.5t15 35.5l312 312l-109 109q-14 14 -10 24.5t25 10.5zM456 900h-156q-41 0 -70.5 -29.5t-29.5 -70.5v-500 q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5v148l200 200v-298q0 -165 -93.5 -257.5t-256.5 -92.5h-400q-165 0 -257.5 92.5t-92.5 257.5v400q0 165 92.5 257.5t257.5 92.5h300z" />
<glyph unicode="&#xe165;" d="M600 1186q119 0 227.5 -46.5t187 -125t125 -187t46.5 -227.5t-46.5 -227.5t-125 -187t-187 -125t-227.5 -46.5t-227.5 46.5t-187 125t-125 187t-46.5 227.5t46.5 227.5t125 187t187 125t227.5 46.5zM600 1022q-115 0 -212 -56.5t-153.5 -153.5t-56.5 -212t56.5 -212 t153.5 -153.5t212 -56.5t212 56.5t153.5 153.5t56.5 212t-56.5 212t-153.5 153.5t-212 56.5zM600 794q80 0 137 -57t57 -137t-57 -137t-137 -57t-137 57t-57 137t57 137t137 57z" />
<glyph unicode="&#xe166;" d="M450 1200h200q21 0 35.5 -14.5t14.5 -35.5v-350h245q20 0 25 -11t-9 -26l-383 -426q-14 -15 -33.5 -15t-32.5 15l-379 426q-13 15 -8.5 26t25.5 11h250v350q0 21 14.5 35.5t35.5 14.5zM50 300h1000q21 0 35.5 -14.5t14.5 -35.5v-250h-1100v250q0 21 14.5 35.5t35.5 14.5z M900 200v-50h100v50h-100z" />
<glyph unicode="&#xe167;" d="M583 1182l378 -435q14 -15 9 -31t-26 -16h-244v-250q0 -20 -17 -35t-39 -15h-200q-20 0 -32 14.5t-12 35.5v250h-250q-20 0 -25.5 16.5t8.5 31.5l383 431q14 16 33.5 17t33.5 -14zM50 300h1000q21 0 35.5 -14.5t14.5 -35.5v-250h-1100v250q0 21 14.5 35.5t35.5 14.5z M900 200v-50h100v50h-100z" />
<glyph unicode="&#xe168;" d="M396 723l369 369q7 7 17.5 7t17.5 -7l139 -139q7 -8 7 -18.5t-7 -17.5l-525 -525q-7 -8 -17.5 -8t-17.5 8l-292 291q-7 8 -7 18t7 18l139 139q8 7 18.5 7t17.5 -7zM50 300h1000q21 0 35.5 -14.5t14.5 -35.5v-250h-1100v250q0 21 14.5 35.5t35.5 14.5zM900 200v-50h100v50 h-100z" />
<glyph unicode="&#xe169;" d="M135 1023l142 142q14 14 35 14t35 -14l77 -77l-212 -212l-77 76q-14 15 -14 36t14 35zM655 855l210 210q14 14 24.5 10t10.5 -25l-2 -599q-1 -20 -15.5 -35t-35.5 -15l-597 -1q-21 0 -25 10.5t10 24.5l208 208l-154 155l212 212zM50 300h1000q21 0 35.5 -14.5t14.5 -35.5 v-250h-1100v250q0 21 14.5 35.5t35.5 14.5zM900 200v-50h100v50h-100z" />
<glyph unicode="&#xe170;" d="M350 1200l599 -2q20 -1 35 -15.5t15 -35.5l1 -597q0 -21 -10.5 -25t-24.5 10l-208 208l-155 -154l-212 212l155 154l-210 210q-14 14 -10 24.5t25 10.5zM524 512l-76 -77q-15 -14 -36 -14t-35 14l-142 142q-14 14 -14 35t14 35l77 77zM50 300h1000q21 0 35.5 -14.5 t14.5 -35.5v-250h-1100v250q0 21 14.5 35.5t35.5 14.5zM900 200v-50h100v50h-100z" />
<glyph unicode="&#xe171;" d="M1200 103l-483 276l-314 -399v423h-399l1196 796v-1096zM483 424v-230l683 953z" />
<glyph unicode="&#xe172;" d="M1100 1000v-850q0 -21 -14.5 -35.5t-35.5 -14.5h-150v400h-700v-400h-150q-21 0 -35.5 14.5t-14.5 35.5v1000q0 20 14.5 35t35.5 15h250v-300h500v300h100zM700 1000h-100v200h100v-200z" />
<glyph unicode="&#xe173;" d="M1100 1000l-2 -149l-299 -299l-95 95q-9 9 -21.5 9t-21.5 -9l-149 -147h-312v-400h-150q-21 0 -35.5 14.5t-14.5 35.5v1000q0 20 14.5 35t35.5 15h250v-300h500v300h100zM700 1000h-100v200h100v-200zM1132 638l106 -106q7 -7 7 -17.5t-7 -17.5l-420 -421q-8 -7 -18 -7 t-18 7l-202 203q-8 7 -8 17.5t8 17.5l106 106q7 8 17.5 8t17.5 -8l79 -79l297 297q7 7 17.5 7t17.5 -7z" />
<glyph unicode="&#xe174;" d="M1100 1000v-269l-103 -103l-134 134q-15 15 -33.5 16.5t-34.5 -12.5l-266 -266h-329v-400h-150q-21 0 -35.5 14.5t-14.5 35.5v1000q0 20 14.5 35t35.5 15h250v-300h500v300h100zM700 1000h-100v200h100v-200zM1202 572l70 -70q15 -15 15 -35.5t-15 -35.5l-131 -131 l131 -131q15 -15 15 -35.5t-15 -35.5l-70 -70q-15 -15 -35.5 -15t-35.5 15l-131 131l-131 -131q-15 -15 -35.5 -15t-35.5 15l-70 70q-15 15 -15 35.5t15 35.5l131 131l-131 131q-15 15 -15 35.5t15 35.5l70 70q15 15 35.5 15t35.5 -15l131 -131l131 131q15 15 35.5 15 t35.5 -15z" />
<glyph unicode="&#xe175;" d="M1100 1000v-300h-350q-21 0 -35.5 -14.5t-14.5 -35.5v-150h-500v-400h-150q-21 0 -35.5 14.5t-14.5 35.5v1000q0 20 14.5 35t35.5 15h250v-300h500v300h100zM700 1000h-100v200h100v-200zM850 600h100q21 0 35.5 -14.5t14.5 -35.5v-250h150q21 0 25 -10.5t-10 -24.5 l-230 -230q-14 -14 -35 -14t-35 14l-230 230q-14 14 -10 24.5t25 10.5h150v250q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe176;" d="M1100 1000v-400l-165 165q-14 15 -35 15t-35 -15l-263 -265h-402v-400h-150q-21 0 -35.5 14.5t-14.5 35.5v1000q0 20 14.5 35t35.5 15h250v-300h500v300h100zM700 1000h-100v200h100v-200zM935 565l230 -229q14 -15 10 -25.5t-25 -10.5h-150v-250q0 -20 -14.5 -35 t-35.5 -15h-100q-21 0 -35.5 15t-14.5 35v250h-150q-21 0 -25 10.5t10 25.5l230 229q14 15 35 15t35 -15z" />
<glyph unicode="&#xe177;" d="M50 1100h1100q21 0 35.5 -14.5t14.5 -35.5v-150h-1200v150q0 21 14.5 35.5t35.5 14.5zM1200 800v-550q0 -21 -14.5 -35.5t-35.5 -14.5h-1100q-21 0 -35.5 14.5t-14.5 35.5v550h1200zM100 500v-200h400v200h-400z" />
<glyph unicode="&#xe178;" d="M935 1165l248 -230q14 -14 14 -35t-14 -35l-248 -230q-14 -14 -24.5 -10t-10.5 25v150h-400v200h400v150q0 21 10.5 25t24.5 -10zM200 800h-50q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5h50v-200zM400 800h-100v200h100v-200zM18 435l247 230 q14 14 24.5 10t10.5 -25v-150h400v-200h-400v-150q0 -21 -10.5 -25t-24.5 10l-247 230q-15 14 -15 35t15 35zM900 300h-100v200h100v-200zM1000 500h51q20 0 34.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-34.5 -14.5h-51v200z" />
<glyph unicode="&#xe179;" d="M862 1073l276 116q25 18 43.5 8t18.5 -41v-1106q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v397q-4 1 -11 5t-24 17.5t-30 29t-24 42t-11 56.5v359q0 31 18.5 65t43.5 52zM550 1200q22 0 34.5 -12.5t14.5 -24.5l1 -13v-450q0 -28 -10.5 -59.5 t-25 -56t-29 -45t-25.5 -31.5l-10 -11v-447q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v447q-4 4 -11 11.5t-24 30.5t-30 46t-24 55t-11 60v450q0 2 0.5 5.5t4 12t8.5 15t14.5 12t22.5 5.5q20 0 32.5 -12.5t14.5 -24.5l3 -13v-350h100v350v5.5t2.5 12 t7 15t15 12t25.5 5.5q23 0 35.5 -12.5t13.5 -24.5l1 -13v-350h100v350q0 2 0.5 5.5t3 12t7 15t15 12t24.5 5.5z" />
<glyph unicode="&#xe180;" d="M1200 1100v-56q-4 0 -11 -0.5t-24 -3t-30 -7.5t-24 -15t-11 -24v-888q0 -22 25 -34.5t50 -13.5l25 -2v-56h-400v56q75 0 87.5 6.5t12.5 43.5v394h-500v-394q0 -37 12.5 -43.5t87.5 -6.5v-56h-400v56q4 0 11 0.5t24 3t30 7.5t24 15t11 24v888q0 22 -25 34.5t-50 13.5 l-25 2v56h400v-56q-75 0 -87.5 -6.5t-12.5 -43.5v-394h500v394q0 37 -12.5 43.5t-87.5 6.5v56h400z" />
<glyph unicode="&#xe181;" d="M675 1000h375q21 0 35.5 -14.5t14.5 -35.5v-150h-105l-295 -98v98l-200 200h-400l100 100h375zM100 900h300q41 0 70.5 -29.5t29.5 -70.5v-500q0 -41 -29.5 -70.5t-70.5 -29.5h-300q-41 0 -70.5 29.5t-29.5 70.5v500q0 41 29.5 70.5t70.5 29.5zM100 800v-200h300v200 h-300zM1100 535l-400 -133v163l400 133v-163zM100 500v-200h300v200h-300zM1100 398v-248q0 -21 -14.5 -35.5t-35.5 -14.5h-375l-100 -100h-375l-100 100h400l200 200h105z" />
<glyph unicode="&#xe182;" d="M17 1007l162 162q17 17 40 14t37 -22l139 -194q14 -20 11 -44.5t-20 -41.5l-119 -118q102 -142 228 -268t267 -227l119 118q17 17 42.5 19t44.5 -12l192 -136q19 -14 22.5 -37.5t-13.5 -40.5l-163 -162q-3 -1 -9.5 -1t-29.5 2t-47.5 6t-62.5 14.5t-77.5 26.5t-90 42.5 t-101.5 60t-111 83t-119 108.5q-74 74 -133.5 150.5t-94.5 138.5t-60 119.5t-34.5 100t-15 74.5t-4.5 48z" />
<glyph unicode="&#xe183;" d="M600 1100q92 0 175 -10.5t141.5 -27t108.5 -36.5t81.5 -40t53.5 -37t31 -27l9 -10v-200q0 -21 -14.5 -33t-34.5 -9l-202 34q-20 3 -34.5 20t-14.5 38v146q-141 24 -300 24t-300 -24v-146q0 -21 -14.5 -38t-34.5 -20l-202 -34q-20 -3 -34.5 9t-14.5 33v200q3 4 9.5 10.5 t31 26t54 37.5t80.5 39.5t109 37.5t141 26.5t175 10.5zM600 795q56 0 97 -9.5t60 -23.5t30 -28t12 -24l1 -10v-50l365 -303q14 -15 24.5 -40t10.5 -45v-212q0 -21 -14.5 -35.5t-35.5 -14.5h-1100q-21 0 -35.5 14.5t-14.5 35.5v212q0 20 10.5 45t24.5 40l365 303v50 q0 4 1 10.5t12 23t30 29t60 22.5t97 10z" />
<glyph unicode="&#xe184;" d="M1100 700l-200 -200h-600l-200 200v500h200v-200h200v200h200v-200h200v200h200v-500zM250 400h700q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-12l137 -100h-950l137 100h-12q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5zM50 100h1100q21 0 35.5 -14.5 t14.5 -35.5v-50h-1200v50q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe185;" d="M700 1100h-100q-41 0 -70.5 -29.5t-29.5 -70.5v-1000h300v1000q0 41 -29.5 70.5t-70.5 29.5zM1100 800h-100q-41 0 -70.5 -29.5t-29.5 -70.5v-700h300v700q0 41 -29.5 70.5t-70.5 29.5zM400 0h-300v400q0 41 29.5 70.5t70.5 29.5h100q41 0 70.5 -29.5t29.5 -70.5v-400z " />
<glyph unicode="&#xe186;" d="M200 1100h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212v500q0 124 88 212t212 88zM100 900v-700h900v700h-900zM500 700h-200v-100h200v-300h-300v100h200v100h-200v300h300v-100zM900 700v-300l-100 -100h-200v500h200z M700 700v-300h100v300h-100z" />
<glyph unicode="&#xe187;" d="M200 1100h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212v500q0 124 88 212t212 88zM100 900v-700h900v700h-900zM500 300h-100v200h-100v-200h-100v500h100v-200h100v200h100v-500zM900 700v-300l-100 -100h-200v500h200z M700 700v-300h100v300h-100z" />
<glyph unicode="&#xe188;" d="M200 1100h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212v500q0 124 88 212t212 88zM100 900v-700h900v700h-900zM500 700h-200v-300h200v-100h-300v500h300v-100zM900 700h-200v-300h200v-100h-300v500h300v-100z" />
<glyph unicode="&#xe189;" d="M200 1100h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212v500q0 124 88 212t212 88zM100 900v-700h900v700h-900zM500 400l-300 150l300 150v-300zM900 550l-300 -150v300z" />
<glyph unicode="&#xe190;" d="M200 1100h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212v500q0 124 88 212t212 88zM100 900v-700h900v700h-900zM900 300h-700v500h700v-500zM800 700h-130q-38 0 -66.5 -43t-28.5 -108t27 -107t68 -42h130v300zM300 700v-300 h130q41 0 68 42t27 107t-28.5 108t-66.5 43h-130z" />
<glyph unicode="&#xe191;" d="M200 1100h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212v500q0 124 88 212t212 88zM100 900v-700h900v700h-900zM500 700h-200v-100h200v-300h-300v100h200v100h-200v300h300v-100zM900 300h-100v400h-100v100h200v-500z M700 300h-100v100h100v-100z" />
<glyph unicode="&#xe192;" d="M200 1100h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212v500q0 124 88 212t212 88zM100 900v-700h900v700h-900zM300 700h200v-400h-300v500h100v-100zM900 300h-100v400h-100v100h200v-500zM300 600v-200h100v200h-100z M700 300h-100v100h100v-100z" />
<glyph unicode="&#xe193;" d="M200 1100h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212v500q0 124 88 212t212 88zM100 900v-700h900v700h-900zM500 500l-199 -200h-100v50l199 200v150h-200v100h300v-300zM900 300h-100v400h-100v100h200v-500zM701 300h-100 v100h100v-100z" />
<glyph unicode="&#xe194;" d="M600 1191q120 0 229.5 -47t188.5 -126t126 -188.5t47 -229.5t-47 -229.5t-126 -188.5t-188.5 -126t-229.5 -47t-229.5 47t-188.5 126t-126 188.5t-47 229.5t47 229.5t126 188.5t188.5 126t229.5 47zM600 1021q-114 0 -211 -56.5t-153.5 -153.5t-56.5 -211t56.5 -211 t153.5 -153.5t211 -56.5t211 56.5t153.5 153.5t56.5 211t-56.5 211t-153.5 153.5t-211 56.5zM800 700h-300v-200h300v-100h-300l-100 100v200l100 100h300v-100z" />
<glyph unicode="&#xe195;" d="M600 1191q120 0 229.5 -47t188.5 -126t126 -188.5t47 -229.5t-47 -229.5t-126 -188.5t-188.5 -126t-229.5 -47t-229.5 47t-188.5 126t-126 188.5t-47 229.5t47 229.5t126 188.5t188.5 126t229.5 47zM600 1021q-114 0 -211 -56.5t-153.5 -153.5t-56.5 -211t56.5 -211 t153.5 -153.5t211 -56.5t211 56.5t153.5 153.5t56.5 211t-56.5 211t-153.5 153.5t-211 56.5zM800 700v-100l-50 -50l100 -100v-50h-100l-100 100h-150v-100h-100v400h300zM500 700v-100h200v100h-200z" />
<glyph unicode="&#xe197;" d="M503 1089q110 0 200.5 -59.5t134.5 -156.5q44 14 90 14q120 0 205 -86.5t85 -207t-85 -207t-205 -86.5h-128v250q0 21 -14.5 35.5t-35.5 14.5h-300q-21 0 -35.5 -14.5t-14.5 -35.5v-250h-222q-80 0 -136 57.5t-56 136.5q0 69 43 122.5t108 67.5q-2 19 -2 37q0 100 49 185 t134 134t185 49zM525 500h150q10 0 17.5 -7.5t7.5 -17.5v-275h137q21 0 26 -11.5t-8 -27.5l-223 -244q-13 -16 -32 -16t-32 16l-223 244q-13 16 -8 27.5t26 11.5h137v275q0 10 7.5 17.5t17.5 7.5z" />
<glyph unicode="&#xe198;" d="M502 1089q110 0 201 -59.5t135 -156.5q43 15 89 15q121 0 206 -86.5t86 -206.5q0 -99 -60 -181t-150 -110l-378 360q-13 16 -31.5 16t-31.5 -16l-381 -365h-9q-79 0 -135.5 57.5t-56.5 136.5q0 69 43 122.5t108 67.5q-2 19 -2 38q0 100 49 184.5t133.5 134t184.5 49.5z M632 467l223 -228q13 -16 8 -27.5t-26 -11.5h-137v-275q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5v275h-137q-21 0 -26 11.5t8 27.5q199 204 223 228q19 19 31.5 19t32.5 -19z" />
<glyph unicode="&#xe199;" d="M700 100v100h400l-270 300h170l-270 300h170l-300 333l-300 -333h170l-270 -300h170l-270 -300h400v-100h-50q-21 0 -35.5 -14.5t-14.5 -35.5v-50h400v50q0 21 -14.5 35.5t-35.5 14.5h-50z" />
<glyph unicode="&#xe200;" d="M600 1179q94 0 167.5 -56.5t99.5 -145.5q89 -6 150.5 -71.5t61.5 -155.5q0 -61 -29.5 -112.5t-79.5 -82.5q9 -29 9 -55q0 -74 -52.5 -126.5t-126.5 -52.5q-55 0 -100 30v-251q21 0 35.5 -14.5t14.5 -35.5v-50h-300v50q0 21 14.5 35.5t35.5 14.5v251q-45 -30 -100 -30 q-74 0 -126.5 52.5t-52.5 126.5q0 18 4 38q-47 21 -75.5 65t-28.5 97q0 74 52.5 126.5t126.5 52.5q5 0 23 -2q0 2 -1 10t-1 13q0 116 81.5 197.5t197.5 81.5z" />
<glyph unicode="&#xe201;" d="M1010 1010q111 -111 150.5 -260.5t0 -299t-150.5 -260.5q-83 -83 -191.5 -126.5t-218.5 -43.5t-218.5 43.5t-191.5 126.5q-111 111 -150.5 260.5t0 299t150.5 260.5q83 83 191.5 126.5t218.5 43.5t218.5 -43.5t191.5 -126.5zM476 1065q-4 0 -8 -1q-121 -34 -209.5 -122.5 t-122.5 -209.5q-4 -12 2.5 -23t18.5 -14l36 -9q3 -1 7 -1q23 0 29 22q27 96 98 166q70 71 166 98q11 3 17.5 13.5t3.5 22.5l-9 35q-3 13 -14 19q-7 4 -15 4zM512 920q-4 0 -9 -2q-80 -24 -138.5 -82.5t-82.5 -138.5q-4 -13 2 -24t19 -14l34 -9q4 -1 8 -1q22 0 28 21 q18 58 58.5 98.5t97.5 58.5q12 3 18 13.5t3 21.5l-9 35q-3 12 -14 19q-7 4 -15 4zM719.5 719.5q-49.5 49.5 -119.5 49.5t-119.5 -49.5t-49.5 -119.5t49.5 -119.5t119.5 -49.5t119.5 49.5t49.5 119.5t-49.5 119.5zM855 551q-22 0 -28 -21q-18 -58 -58.5 -98.5t-98.5 -57.5 q-11 -4 -17 -14.5t-3 -21.5l9 -35q3 -12 14 -19q7 -4 15 -4q4 0 9 2q80 24 138.5 82.5t82.5 138.5q4 13 -2.5 24t-18.5 14l-34 9q-4 1 -8 1zM1000 515q-23 0 -29 -22q-27 -96 -98 -166q-70 -71 -166 -98q-11 -3 -17.5 -13.5t-3.5 -22.5l9 -35q3 -13 14 -19q7 -4 15 -4 q4 0 8 1q121 34 209.5 122.5t122.5 209.5q4 12 -2.5 23t-18.5 14l-36 9q-3 1 -7 1z" />
<glyph unicode="&#xe202;" d="M700 800h300v-380h-180v200h-340v-200h-380v755q0 10 7.5 17.5t17.5 7.5h575v-400zM1000 900h-200v200zM700 300h162l-212 -212l-212 212h162v200h100v-200zM520 0h-395q-10 0 -17.5 7.5t-7.5 17.5v395zM1000 220v-195q0 -10 -7.5 -17.5t-17.5 -7.5h-195z" />
<glyph unicode="&#xe203;" d="M700 800h300v-520l-350 350l-550 -550v1095q0 10 7.5 17.5t17.5 7.5h575v-400zM1000 900h-200v200zM862 200h-162v-200h-100v200h-162l212 212zM480 0h-355q-10 0 -17.5 7.5t-7.5 17.5v55h380v-80zM1000 80v-55q0 -10 -7.5 -17.5t-17.5 -7.5h-155v80h180z" />
<glyph unicode="&#xe204;" d="M1162 800h-162v-200h100l100 -100h-300v300h-162l212 212zM200 800h200q27 0 40 -2t29.5 -10.5t23.5 -30t7 -57.5h300v-100h-600l-200 -350v450h100q0 36 7 57.5t23.5 30t29.5 10.5t40 2zM800 400h240l-240 -400h-800l300 500h500v-100z" />
<glyph unicode="&#xe205;" d="M650 1100h100q21 0 35.5 -14.5t14.5 -35.5v-50h50q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-300q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5h50v50q0 21 14.5 35.5t35.5 14.5zM1000 850v150q41 0 70.5 -29.5t29.5 -70.5v-800 q0 -41 -29.5 -70.5t-70.5 -29.5h-600q-1 0 -20 4l246 246l-326 326v324q0 41 29.5 70.5t70.5 29.5v-150q0 -62 44 -106t106 -44h300q62 0 106 44t44 106zM412 250l-212 -212v162h-200v100h200v162z" />
<glyph unicode="&#xe206;" d="M450 1100h100q21 0 35.5 -14.5t14.5 -35.5v-50h50q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-300q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5h50v50q0 21 14.5 35.5t35.5 14.5zM800 850v150q41 0 70.5 -29.5t29.5 -70.5v-500 h-200v-300h200q0 -36 -7 -57.5t-23.5 -30t-29.5 -10.5t-40 -2h-600q-41 0 -70.5 29.5t-29.5 70.5v800q0 41 29.5 70.5t70.5 29.5v-150q0 -62 44 -106t106 -44h300q62 0 106 44t44 106zM1212 250l-212 -212v162h-200v100h200v162z" />
<glyph unicode="&#xe209;" d="M658 1197l637 -1104q23 -38 7 -65.5t-60 -27.5h-1276q-44 0 -60 27.5t7 65.5l637 1104q22 39 54 39t54 -39zM704 800h-208q-20 0 -32 -14.5t-8 -34.5l58 -302q4 -20 21.5 -34.5t37.5 -14.5h54q20 0 37.5 14.5t21.5 34.5l58 302q4 20 -8 34.5t-32 14.5zM500 300v-100h200 v100h-200z" />
<glyph unicode="&#xe210;" d="M425 1100h250q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5zM425 800h250q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5 t17.5 7.5zM825 800h250q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5zM25 500h250q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5v150 q0 10 7.5 17.5t17.5 7.5zM425 500h250q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5zM825 500h250q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5 v150q0 10 7.5 17.5t17.5 7.5zM25 200h250q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5zM425 200h250q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5 t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5zM825 200h250q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-250q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5z" />
<glyph unicode="&#xe211;" d="M700 1200h100v-200h-100v-100h350q62 0 86.5 -39.5t-3.5 -94.5l-66 -132q-41 -83 -81 -134h-772q-40 51 -81 134l-66 132q-28 55 -3.5 94.5t86.5 39.5h350v100h-100v200h100v100h200v-100zM250 400h700q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-12l137 -100 h-950l138 100h-13q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5zM50 100h1100q21 0 35.5 -14.5t14.5 -35.5v-50h-1200v50q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe212;" d="M600 1300q40 0 68.5 -29.5t28.5 -70.5h-194q0 41 28.5 70.5t68.5 29.5zM443 1100h314q18 -37 18 -75q0 -8 -3 -25h328q41 0 44.5 -16.5t-30.5 -38.5l-175 -145h-678l-178 145q-34 22 -29 38.5t46 16.5h328q-3 17 -3 25q0 38 18 75zM250 700h700q21 0 35.5 -14.5 t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-150v-200l275 -200h-950l275 200v200h-150q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5zM50 100h1100q21 0 35.5 -14.5t14.5 -35.5v-50h-1200v50q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe213;" d="M600 1181q75 0 128 -53t53 -128t-53 -128t-128 -53t-128 53t-53 128t53 128t128 53zM602 798h46q34 0 55.5 -28.5t21.5 -86.5q0 -76 39 -183h-324q39 107 39 183q0 58 21.5 86.5t56.5 28.5h45zM250 400h700q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-13 l138 -100h-950l137 100h-12q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5zM50 100h1100q21 0 35.5 -14.5t14.5 -35.5v-50h-1200v50q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe214;" d="M600 1300q47 0 92.5 -53.5t71 -123t25.5 -123.5q0 -78 -55.5 -133.5t-133.5 -55.5t-133.5 55.5t-55.5 133.5q0 62 34 143l144 -143l111 111l-163 163q34 26 63 26zM602 798h46q34 0 55.5 -28.5t21.5 -86.5q0 -76 39 -183h-324q39 107 39 183q0 58 21.5 86.5t56.5 28.5h45 zM250 400h700q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-13l138 -100h-950l137 100h-12q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5zM50 100h1100q21 0 35.5 -14.5t14.5 -35.5v-50h-1200v50q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe215;" d="M600 1200l300 -161v-139h-300q0 -57 18.5 -108t50 -91.5t63 -72t70 -67.5t57.5 -61h-530q-60 83 -90.5 177.5t-30.5 178.5t33 164.5t87.5 139.5t126 96.5t145.5 41.5v-98zM250 400h700q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-13l138 -100h-950l137 100 h-12q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5zM50 100h1100q21 0 35.5 -14.5t14.5 -35.5v-50h-1200v50q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe216;" d="M600 1300q41 0 70.5 -29.5t29.5 -70.5v-78q46 -26 73 -72t27 -100v-50h-400v50q0 54 27 100t73 72v78q0 41 29.5 70.5t70.5 29.5zM400 800h400q54 0 100 -27t72 -73h-172v-100h200v-100h-200v-100h200v-100h-200v-100h200q0 -83 -58.5 -141.5t-141.5 -58.5h-400 q-83 0 -141.5 58.5t-58.5 141.5v400q0 83 58.5 141.5t141.5 58.5z" />
<glyph unicode="&#xe218;" d="M150 1100h900q21 0 35.5 -14.5t14.5 -35.5v-500q0 -21 -14.5 -35.5t-35.5 -14.5h-900q-21 0 -35.5 14.5t-14.5 35.5v500q0 21 14.5 35.5t35.5 14.5zM125 400h950q10 0 17.5 -7.5t7.5 -17.5v-50q0 -10 -7.5 -17.5t-17.5 -7.5h-283l224 -224q13 -13 13 -31.5t-13 -32 t-31.5 -13.5t-31.5 13l-88 88h-524l-87 -88q-13 -13 -32 -13t-32 13.5t-13 32t13 31.5l224 224h-289q-10 0 -17.5 7.5t-7.5 17.5v50q0 10 7.5 17.5t17.5 7.5zM541 300l-100 -100h324l-100 100h-124z" />
<glyph unicode="&#xe219;" d="M200 1100h800q83 0 141.5 -58.5t58.5 -141.5v-200h-100q0 41 -29.5 70.5t-70.5 29.5h-250q-41 0 -70.5 -29.5t-29.5 -70.5h-100q0 41 -29.5 70.5t-70.5 29.5h-250q-41 0 -70.5 -29.5t-29.5 -70.5h-100v200q0 83 58.5 141.5t141.5 58.5zM100 600h1000q41 0 70.5 -29.5 t29.5 -70.5v-300h-1200v300q0 41 29.5 70.5t70.5 29.5zM300 100v-50q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v50h200zM1100 100v-50q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v50h200z" />
<glyph unicode="&#xe221;" d="M480 1165l682 -683q31 -31 31 -75.5t-31 -75.5l-131 -131h-481l-517 518q-32 31 -32 75.5t32 75.5l295 296q31 31 75.5 31t76.5 -31zM108 794l342 -342l303 304l-341 341zM250 100h800q21 0 35.5 -14.5t14.5 -35.5v-50h-900v50q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe223;" d="M1057 647l-189 506q-8 19 -27.5 33t-40.5 14h-400q-21 0 -40.5 -14t-27.5 -33l-189 -506q-8 -19 1.5 -33t30.5 -14h625v-150q0 -21 14.5 -35.5t35.5 -14.5t35.5 14.5t14.5 35.5v150h125q21 0 30.5 14t1.5 33zM897 0h-595v50q0 21 14.5 35.5t35.5 14.5h50v50 q0 21 14.5 35.5t35.5 14.5h48v300h200v-300h47q21 0 35.5 -14.5t14.5 -35.5v-50h50q21 0 35.5 -14.5t14.5 -35.5v-50z" />
<glyph unicode="&#xe224;" d="M900 800h300v-575q0 -10 -7.5 -17.5t-17.5 -7.5h-375v591l-300 300v84q0 10 7.5 17.5t17.5 7.5h375v-400zM1200 900h-200v200zM400 600h300v-575q0 -10 -7.5 -17.5t-17.5 -7.5h-650q-10 0 -17.5 7.5t-7.5 17.5v950q0 10 7.5 17.5t17.5 7.5h375v-400zM700 700h-200v200z " />
<glyph unicode="&#xe225;" d="M484 1095h195q75 0 146 -32.5t124 -86t89.5 -122.5t48.5 -142q18 -14 35 -20q31 -10 64.5 6.5t43.5 48.5q10 34 -15 71q-19 27 -9 43q5 8 12.5 11t19 -1t23.5 -16q41 -44 39 -105q-3 -63 -46 -106.5t-104 -43.5h-62q-7 -55 -35 -117t-56 -100l-39 -234q-3 -20 -20 -34.5 t-38 -14.5h-100q-21 0 -33 14.5t-9 34.5l12 70q-49 -14 -91 -14h-195q-24 0 -65 8l-11 -64q-3 -20 -20 -34.5t-38 -14.5h-100q-21 0 -33 14.5t-9 34.5l26 157q-84 74 -128 175l-159 53q-19 7 -33 26t-14 40v50q0 21 14.5 35.5t35.5 14.5h124q11 87 56 166l-111 95 q-16 14 -12.5 23.5t24.5 9.5h203q116 101 250 101zM675 1000h-250q-10 0 -17.5 -7.5t-7.5 -17.5v-50q0 -10 7.5 -17.5t17.5 -7.5h250q10 0 17.5 7.5t7.5 17.5v50q0 10 -7.5 17.5t-17.5 7.5z" />
<glyph unicode="&#xe226;" d="M641 900l423 247q19 8 42 2.5t37 -21.5l32 -38q14 -15 12.5 -36t-17.5 -34l-139 -120h-390zM50 1100h106q67 0 103 -17t66 -71l102 -212h823q21 0 35.5 -14.5t14.5 -35.5v-50q0 -21 -14 -40t-33 -26l-737 -132q-23 -4 -40 6t-26 25q-42 67 -100 67h-300q-62 0 -106 44 t-44 106v200q0 62 44 106t106 44zM173 928h-80q-19 0 -28 -14t-9 -35v-56q0 -51 42 -51h134q16 0 21.5 8t5.5 24q0 11 -16 45t-27 51q-18 28 -43 28zM550 727q-32 0 -54.5 -22.5t-22.5 -54.5t22.5 -54.5t54.5 -22.5t54.5 22.5t22.5 54.5t-22.5 54.5t-54.5 22.5zM130 389 l152 130q18 19 34 24t31 -3.5t24.5 -17.5t25.5 -28q28 -35 50.5 -51t48.5 -13l63 5l48 -179q13 -61 -3.5 -97.5t-67.5 -79.5l-80 -69q-47 -40 -109 -35.5t-103 51.5l-130 151q-40 47 -35.5 109.5t51.5 102.5zM380 377l-102 -88q-31 -27 2 -65l37 -43q13 -15 27.5 -19.5 t31.5 6.5l61 53q19 16 14 49q-2 20 -12 56t-17 45q-11 12 -19 14t-23 -8z" />
<glyph unicode="&#xe227;" d="M625 1200h150q10 0 17.5 -7.5t7.5 -17.5v-109q79 -33 131 -87.5t53 -128.5q1 -46 -15 -84.5t-39 -61t-46 -38t-39 -21.5l-17 -6q6 0 15 -1.5t35 -9t50 -17.5t53 -30t50 -45t35.5 -64t14.5 -84q0 -59 -11.5 -105.5t-28.5 -76.5t-44 -51t-49.5 -31.5t-54.5 -16t-49.5 -6.5 t-43.5 -1v-75q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5v75h-100v-75q0 -10 -7.5 -17.5t-17.5 -7.5h-150q-10 0 -17.5 7.5t-7.5 17.5v75h-175q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5h75v600h-75q-10 0 -17.5 7.5t-7.5 17.5v150 q0 10 7.5 17.5t17.5 7.5h175v75q0 10 7.5 17.5t17.5 7.5h150q10 0 17.5 -7.5t7.5 -17.5v-75h100v75q0 10 7.5 17.5t17.5 7.5zM400 900v-200h263q28 0 48.5 10.5t30 25t15 29t5.5 25.5l1 10q0 4 -0.5 11t-6 24t-15 30t-30 24t-48.5 11h-263zM400 500v-200h363q28 0 48.5 10.5 t30 25t15 29t5.5 25.5l1 10q0 4 -0.5 11t-6 24t-15 30t-30 24t-48.5 11h-363z" />
<glyph unicode="&#xe230;" d="M212 1198h780q86 0 147 -61t61 -147v-416q0 -51 -18 -142.5t-36 -157.5l-18 -66q-29 -87 -93.5 -146.5t-146.5 -59.5h-572q-82 0 -147 59t-93 147q-8 28 -20 73t-32 143.5t-20 149.5v416q0 86 61 147t147 61zM600 1045q-70 0 -132.5 -11.5t-105.5 -30.5t-78.5 -41.5 t-57 -45t-36 -41t-20.5 -30.5l-6 -12l156 -243h560l156 243q-2 5 -6 12.5t-20 29.5t-36.5 42t-57 44.5t-79 42t-105 29.5t-132.5 12zM762 703h-157l195 261z" />
<glyph unicode="&#xe231;" d="M475 1300h150q103 0 189 -86t86 -189v-500q0 -41 -42 -83t-83 -42h-450q-41 0 -83 42t-42 83v500q0 103 86 189t189 86zM700 300v-225q0 -21 -27 -48t-48 -27h-150q-21 0 -48 27t-27 48v225h300z" />
<glyph unicode="&#xe232;" d="M475 1300h96q0 -150 89.5 -239.5t239.5 -89.5v-446q0 -41 -42 -83t-83 -42h-450q-41 0 -83 42t-42 83v500q0 103 86 189t189 86zM700 300v-225q0 -21 -27 -48t-48 -27h-150q-21 0 -48 27t-27 48v225h300z" />
<glyph unicode="&#xe233;" d="M1294 767l-638 -283l-378 170l-78 -60v-224l100 -150v-199l-150 148l-150 -149v200l100 150v250q0 4 -0.5 10.5t0 9.5t1 8t3 8t6.5 6l47 40l-147 65l642 283zM1000 380l-350 -166l-350 166v147l350 -165l350 165v-147z" />
<glyph unicode="&#xe234;" d="M250 800q62 0 106 -44t44 -106t-44 -106t-106 -44t-106 44t-44 106t44 106t106 44zM650 800q62 0 106 -44t44 -106t-44 -106t-106 -44t-106 44t-44 106t44 106t106 44zM1050 800q62 0 106 -44t44 -106t-44 -106t-106 -44t-106 44t-44 106t44 106t106 44z" />
<glyph unicode="&#xe235;" d="M550 1100q62 0 106 -44t44 -106t-44 -106t-106 -44t-106 44t-44 106t44 106t106 44zM550 700q62 0 106 -44t44 -106t-44 -106t-106 -44t-106 44t-44 106t44 106t106 44zM550 300q62 0 106 -44t44 -106t-44 -106t-106 -44t-106 44t-44 106t44 106t106 44z" />
<glyph unicode="&#xe236;" d="M125 1100h950q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-950q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5zM125 700h950q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-950q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5 t17.5 7.5zM125 300h950q10 0 17.5 -7.5t7.5 -17.5v-150q0 -10 -7.5 -17.5t-17.5 -7.5h-950q-10 0 -17.5 7.5t-7.5 17.5v150q0 10 7.5 17.5t17.5 7.5z" />
<glyph unicode="&#xe237;" d="M350 1200h500q162 0 256 -93.5t94 -256.5v-500q0 -165 -93.5 -257.5t-256.5 -92.5h-500q-165 0 -257.5 92.5t-92.5 257.5v500q0 165 92.5 257.5t257.5 92.5zM900 1000h-600q-41 0 -70.5 -29.5t-29.5 -70.5v-600q0 -41 29.5 -70.5t70.5 -29.5h600q41 0 70.5 29.5 t29.5 70.5v600q0 41 -29.5 70.5t-70.5 29.5zM350 900h500q21 0 35.5 -14.5t14.5 -35.5v-300q0 -21 -14.5 -35.5t-35.5 -14.5h-500q-21 0 -35.5 14.5t-14.5 35.5v300q0 21 14.5 35.5t35.5 14.5zM400 800v-200h400v200h-400z" />
<glyph unicode="&#xe238;" d="M150 1100h1000q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-50v-200h50q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-50v-200h50q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5t-35.5 -14.5h-50v-200h50q21 0 35.5 -14.5t14.5 -35.5t-14.5 -35.5 t-35.5 -14.5h-1000q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5h50v200h-50q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5h50v200h-50q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5h50v200h-50q-21 0 -35.5 14.5t-14.5 35.5t14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe239;" d="M650 1187q87 -67 118.5 -156t0 -178t-118.5 -155q-87 66 -118.5 155t0 178t118.5 156zM300 800q124 0 212 -88t88 -212q-124 0 -212 88t-88 212zM1000 800q0 -124 -88 -212t-212 -88q0 124 88 212t212 88zM300 500q124 0 212 -88t88 -212q-124 0 -212 88t-88 212z M1000 500q0 -124 -88 -212t-212 -88q0 124 88 212t212 88zM700 199v-144q0 -21 -14.5 -35.5t-35.5 -14.5t-35.5 14.5t-14.5 35.5v142q40 -4 43 -4q17 0 57 6z" />
<glyph unicode="&#xe240;" d="M745 878l69 19q25 6 45 -12l298 -295q11 -11 15 -26.5t-2 -30.5q-5 -14 -18 -23.5t-28 -9.5h-8q1 0 1 -13q0 -29 -2 -56t-8.5 -62t-20 -63t-33 -53t-51 -39t-72.5 -14h-146q-184 0 -184 288q0 24 10 47q-20 4 -62 4t-63 -4q11 -24 11 -47q0 -288 -184 -288h-142 q-48 0 -84.5 21t-56 51t-32 71.5t-16 75t-3.5 68.5q0 13 2 13h-7q-15 0 -27.5 9.5t-18.5 23.5q-6 15 -2 30.5t15 25.5l298 296q20 18 46 11l76 -19q20 -5 30.5 -22.5t5.5 -37.5t-22.5 -31t-37.5 -5l-51 12l-182 -193h891l-182 193l-44 -12q-20 -5 -37.5 6t-22.5 31t6 37.5 t31 22.5z" />
<glyph unicode="&#xe241;" d="M1200 900h-50q0 21 -4 37t-9.5 26.5t-18 17.5t-22 11t-28.5 5.5t-31 2t-37 0.5h-200v-850q0 -22 25 -34.5t50 -13.5l25 -2v-100h-400v100q4 0 11 0.5t24 3t30 7t24 15t11 24.5v850h-200q-25 0 -37 -0.5t-31 -2t-28.5 -5.5t-22 -11t-18 -17.5t-9.5 -26.5t-4 -37h-50v300 h1000v-300zM500 450h-25q0 15 -4 24.5t-9 14.5t-17 7.5t-20 3t-25 0.5h-100v-425q0 -11 12.5 -17.5t25.5 -7.5h12v-50h-200v50q50 0 50 25v425h-100q-17 0 -25 -0.5t-20 -3t-17 -7.5t-9 -14.5t-4 -24.5h-25v150h500v-150z" />
<glyph unicode="&#xe242;" d="M1000 300v50q-25 0 -55 32q-14 14 -25 31t-16 27l-4 11l-289 747h-69l-300 -754q-18 -35 -39 -56q-9 -9 -24.5 -18.5t-26.5 -14.5l-11 -5v-50h273v50q-49 0 -78.5 21.5t-11.5 67.5l69 176h293l61 -166q13 -34 -3.5 -66.5t-55.5 -32.5v-50h312zM412 691l134 342l121 -342 h-255zM1100 150v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1000q-21 0 -35.5 14.5t-14.5 35.5v100q0 21 14.5 35.5t35.5 14.5h1000q21 0 35.5 -14.5t14.5 -35.5z" />
<glyph unicode="&#xe243;" d="M50 1200h1100q21 0 35.5 -14.5t14.5 -35.5v-1100q0 -21 -14.5 -35.5t-35.5 -14.5h-1100q-21 0 -35.5 14.5t-14.5 35.5v1100q0 21 14.5 35.5t35.5 14.5zM611 1118h-70q-13 0 -18 -12l-299 -753q-17 -32 -35 -51q-18 -18 -56 -34q-12 -5 -12 -18v-50q0 -8 5.5 -14t14.5 -6 h273q8 0 14 6t6 14v50q0 8 -6 14t-14 6q-55 0 -71 23q-10 14 0 39l63 163h266l57 -153q11 -31 -6 -55q-12 -17 -36 -17q-8 0 -14 -6t-6 -14v-50q0 -8 6 -14t14 -6h313q8 0 14 6t6 14v50q0 7 -5.5 13t-13.5 7q-17 0 -42 25q-25 27 -40 63h-1l-288 748q-5 12 -19 12zM639 611 h-197l103 264z" />
<glyph unicode="&#xe244;" d="M1200 1100h-1200v100h1200v-100zM50 1000h400q21 0 35.5 -14.5t14.5 -35.5v-900q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5v900q0 21 14.5 35.5t35.5 14.5zM650 1000h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400 q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5zM700 900v-300h300v300h-300z" />
<glyph unicode="&#xe245;" d="M50 1200h400q21 0 35.5 -14.5t14.5 -35.5v-900q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5v900q0 21 14.5 35.5t35.5 14.5zM650 700h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5v400 q0 21 14.5 35.5t35.5 14.5zM700 600v-300h300v300h-300zM1200 0h-1200v100h1200v-100z" />
<glyph unicode="&#xe246;" d="M50 1000h400q21 0 35.5 -14.5t14.5 -35.5v-350h100v150q0 21 14.5 35.5t35.5 14.5h400q21 0 35.5 -14.5t14.5 -35.5v-150h100v-100h-100v-150q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5v150h-100v-350q0 -21 -14.5 -35.5t-35.5 -14.5h-400 q-21 0 -35.5 14.5t-14.5 35.5v800q0 21 14.5 35.5t35.5 14.5zM700 700v-300h300v300h-300z" />
<glyph unicode="&#xe247;" d="M100 0h-100v1200h100v-1200zM250 1100h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5zM300 1000v-300h300v300h-300zM250 500h900q21 0 35.5 -14.5t14.5 -35.5v-400 q0 -21 -14.5 -35.5t-35.5 -14.5h-900q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe248;" d="M600 1100h150q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-150v-100h450q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-900q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5h350v100h-150q-21 0 -35.5 14.5 t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5h150v100h100v-100zM400 1000v-300h300v300h-300z" />
<glyph unicode="&#xe249;" d="M1200 0h-100v1200h100v-1200zM550 1100h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5zM600 1000v-300h300v300h-300zM50 500h900q21 0 35.5 -14.5t14.5 -35.5v-400 q0 -21 -14.5 -35.5t-35.5 -14.5h-900q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5z" />
<glyph unicode="&#xe250;" d="M865 565l-494 -494q-23 -23 -41 -23q-14 0 -22 13.5t-8 38.5v1000q0 25 8 38.5t22 13.5q18 0 41 -23l494 -494q14 -14 14 -35t-14 -35z" />
<glyph unicode="&#xe251;" d="M335 635l494 494q29 29 50 20.5t21 -49.5v-1000q0 -41 -21 -49.5t-50 20.5l-494 494q-14 14 -14 35t14 35z" />
<glyph unicode="&#xe252;" d="M100 900h1000q41 0 49.5 -21t-20.5 -50l-494 -494q-14 -14 -35 -14t-35 14l-494 494q-29 29 -20.5 50t49.5 21z" />
<glyph unicode="&#xe253;" d="M635 865l494 -494q29 -29 20.5 -50t-49.5 -21h-1000q-41 0 -49.5 21t20.5 50l494 494q14 14 35 14t35 -14z" />
<glyph unicode="&#xe254;" d="M700 741v-182l-692 -323v221l413 193l-413 193v221zM1200 0h-800v200h800v-200z" />
<glyph unicode="&#xe255;" d="M1200 900h-200v-100h200v-100h-300v300h200v100h-200v100h300v-300zM0 700h50q0 21 4 37t9.5 26.5t18 17.5t22 11t28.5 5.5t31 2t37 0.5h100v-550q0 -22 -25 -34.5t-50 -13.5l-25 -2v-100h400v100q-4 0 -11 0.5t-24 3t-30 7t-24 15t-11 24.5v550h100q25 0 37 -0.5t31 -2 t28.5 -5.5t22 -11t18 -17.5t9.5 -26.5t4 -37h50v300h-800v-300z" />
<glyph unicode="&#xe256;" d="M800 700h-50q0 21 -4 37t-9.5 26.5t-18 17.5t-22 11t-28.5 5.5t-31 2t-37 0.5h-100v-550q0 -22 25 -34.5t50 -14.5l25 -1v-100h-400v100q4 0 11 0.5t24 3t30 7t24 15t11 24.5v550h-100q-25 0 -37 -0.5t-31 -2t-28.5 -5.5t-22 -11t-18 -17.5t-9.5 -26.5t-4 -37h-50v300 h800v-300zM1100 200h-200v-100h200v-100h-300v300h200v100h-200v100h300v-300z" />
<glyph unicode="&#xe257;" d="M701 1098h160q16 0 21 -11t-7 -23l-464 -464l464 -464q12 -12 7 -23t-21 -11h-160q-13 0 -23 9l-471 471q-7 8 -7 18t7 18l471 471q10 9 23 9z" />
<glyph unicode="&#xe258;" d="M339 1098h160q13 0 23 -9l471 -471q7 -8 7 -18t-7 -18l-471 -471q-10 -9 -23 -9h-160q-16 0 -21 11t7 23l464 464l-464 464q-12 12 -7 23t21 11z" />
<glyph unicode="&#xe259;" d="M1087 882q11 -5 11 -21v-160q0 -13 -9 -23l-471 -471q-8 -7 -18 -7t-18 7l-471 471q-9 10 -9 23v160q0 16 11 21t23 -7l464 -464l464 464q12 12 23 7z" />
<glyph unicode="&#xe260;" d="M618 993l471 -471q9 -10 9 -23v-160q0 -16 -11 -21t-23 7l-464 464l-464 -464q-12 -12 -23 -7t-11 21v160q0 13 9 23l471 471q8 7 18 7t18 -7z" />
<glyph unicode="&#xf8ff;" d="M1000 1200q0 -124 -88 -212t-212 -88q0 124 88 212t212 88zM450 1000h100q21 0 40 -14t26 -33l79 -194q5 1 16 3q34 6 54 9.5t60 7t65.5 1t61 -10t56.5 -23t42.5 -42t29 -64t5 -92t-19.5 -121.5q-1 -7 -3 -19.5t-11 -50t-20.5 -73t-32.5 -81.5t-46.5 -83t-64 -70 t-82.5 -50q-13 -5 -42 -5t-65.5 2.5t-47.5 2.5q-14 0 -49.5 -3.5t-63 -3.5t-43.5 7q-57 25 -104.5 78.5t-75 111.5t-46.5 112t-26 90l-7 35q-15 63 -18 115t4.5 88.5t26 64t39.5 43.5t52 25.5t58.5 13t62.5 2t59.5 -4.5t55.5 -8l-147 192q-12 18 -5.5 30t27.5 12z" />
<glyph unicode="&#x1f511;" d="M250 1200h600q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-150v-500l-255 -178q-19 -9 -32 -1t-13 29v650h-150q-21 0 -35.5 14.5t-14.5 35.5v400q0 21 14.5 35.5t35.5 14.5zM400 1100v-100h300v100h-300z" />
<glyph unicode="&#x1f6aa;" d="M250 1200h750q39 0 69.5 -40.5t30.5 -84.5v-933l-700 -117v950l600 125h-700v-1000h-100v1025q0 23 15.5 49t34.5 26zM500 525v-100l100 20v100z" />
</font>
</defs></svg>

After

Width:  |  Height:  |  Size: 106 KiB

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 22 KiB

88
public/index.php Normal file
View File

@ -0,0 +1,88 @@
<?php
use Carbon\Carbon;
use Incoviba\old\Proyecto\Proyecto;
use App\Contract\Auth;
include_once dirname(__DIR__) . '/bootstrap/autoload.php';
header("Access-Control-Allow-Origin: *");
if (config('app.debug') == true) {
if (config('app.benchmark') == true) {
$benchmark = (object) ['time' => microtime(true)];
}
}
Carbon::setLocale(config('app.locale'));
setlocale(LC_TIME, 'es_ES');
sanitize();
try {
Auth::isIn();
} catch (PDOException $e) {
header('Location: install');
die();
}
if (Auth::isIn()) {
if ((get('p') !== false or get('page') !== false or get('m') !== false or get('module') !== false)) {
if (($route = route()) !== false) {
echo $route;
} else {
echo view('construccion');
}
} else {
$proyectos = model(Proyecto::class)->findMany();
$dias = [];
$cierres = [];
$pendientes = 0;
$hoy = 0;
foreach ($proyectos as $proyecto) {
$pendientes += $proyecto->cuotasPendientes();
$hoy += $proyecto->cuotasHoy();
foreach ($proyecto->cuotasMes() as $cuota) {
$f = $cuota->pago()->fecha();
if ($f->isoWeekday() == 6 or $f->isoWeekDay() == 7) {
$f = $f->copy()->addDays(2)->startOfWeek();
}
$dia = $f->format('Y-m-d');
if (!isset($dias[$dia])) {
$dias[$dia] = [$proyecto->descripcion => 0];
}
if (!isset($dias[$dia][$proyecto->descripcion])) {
$dias[$dia][$proyecto->descripcion] = 0;
}
$dias[$dia][$proyecto->descripcion] ++;
}
if (count($proyecto->cierres()) > 0) {
$cierres[$proyecto->descripcion] = (object) ['total' => count($proyecto->cierres()),'vigentes' => $proyecto->cierres(3), 'rechazados' => $proyecto->cierres(-1), 'pendientes' => $proyecto->cierres(2)];
}
}
uksort($dias, function($a, $b) {
return strcmp($a, $b);
});
uksort($cierres, function($a, $b) {
return strcmp($a, $b);
});
echo view('home', compact('pendientes', 'hoy', 'dias', 'cierres'));
}
} elseif (get('p') == 'auth' or get('page') == 'auth') {
$route = route();
if ($route !== false) {
echo $route;
} else {
echo view('guest');
}
} else {
echo view('guest');
}
if (config('app.debug') == 'true') {
if (config('app.benchmark') == 'true') {
$benchmark->time = microtime(true) - $benchmark->time;
if (get('ajax') != '1' and get('p') != 'ajax' and get('p') != 'informes') {
echo view('benchmark', compact('benchmark'));
}
}
}
?>

View File

@ -0,0 +1,40 @@
<?php
include_once dirname(dirname(__DIR__)) . '/bootstrap/autoload.php';
sanitize();
if (post('name') != null) {
$user = Model::factory(\Incoviba\common\User::class)->where('name', post('name'))->findOne();
if ($user === false) {
$user = Model::factory(\Incoviba\common\User::class)->create();
$user->name = post('name');
$user->password(post('password'));
$user->save();
echo 'Created';
}
$role = Model::factory(\Incoviba\common\Role::class)->where('description', 'administrador')->findOne();
if ($role == false) {
$role = Model::factory(\Incoviba\common\Role::class)->create(['description' => 'administrador']);
$role->save();
}
$usrRl = Model::factory(\Incoviba\common\UserRole::class)->where('user', $user->id)->where('role', $role->id)->findOne();
if ($usrRl == false) {
$usrRl = Model::factory(\Incoviba\common\UserRole::class)->create(['user' => $user->id, 'role' => $role->id]);
$usrRl->save();
}
$perm = Model::factory(\Incoviba\common\Permission::class)->where('type', 2)->where('ext_id', $role->id)->where('all', 1)->where('access', 1)->findOne();
if ($perm == false) {
$perm = Model::factory(\Incoviba\common\Permission::class)->create([
'type' => 2,
'ext_id' => $role->id,
'all' => 1,
'access' => 1
]);
$perm->save();
}
header('Location: next_step.php?step=create_admin');
} else {
echo view('install.admin');
}
?>

View File

@ -0,0 +1,36 @@
<?php
include_once dirname(dirname(__DIR__)) . '/bootstrap/autoload.php';
sanitize();
$user = Model::factory(\Incoviba\common\User::class)->where('name', 'guest')->findOne();
if ($user === false) {
$user = Model::factory(\Incoviba\common\User::class)->create(['name' => 'guest']);
$user->save();
}
$role = Model::factory(\Incoviba\common\Role::class)->where('description', 'guest')->findOne();
if ($role === false) {
$role = Model::factory(\Incoviba\common\Role::class)->create(['description' => 'guest']);
$role->save();
}
$usrRl = Model::factory(\Incoviba\common\UserRole::class)->where('user', $user->id)->where('role', $role->id)->findOne();
if ($usrRl === false) {
$usrRl = Model::factory(\Incoviba\common\UserRole::class)->create(['user' => $user->id, 'role' => $role->id]);
$usrRl->save();
}
$locations = Model::factory(\Incoviba\common\Location::class)->where('controller', 'auth')->findMany();
foreach ($locations as $location) {
$permission = Model::factory(\Incoviba\common\Permission::class)->where('type', 2)->where('ext_id', $role->id)->where('access', 1)->where('location', $location->id)->findOne();
if ($permission === false) {
$permission = Model::factory(\Incoviba\common\Permission::class)->create([
'type' => 2,
'ext_id' => $role->id,
'access' => 1,
'location' => $location->id
]);
$permission->save();
}
}
header('Location: next_step.php?step=create_guest');
?>

View File

@ -0,0 +1,128 @@
<?php
include_once dirname(dirname(__DIR__)) . '/bootstrap/autoload.php';
sanitize();
$models = [
'User',
'Location',
'Role',
'UserRole',
'Permission',
'Auth'
];
$location = realpath(dirname(dirname(__DIR__)) . '/src/common');
function extractColumn($table, $info, &$keys, &$foreigns) {
$column = [];
switch ($info[0]) {
case 'string';
$column['type'] = 'VARCHAR';
break;
default:
$column['type'] = strtoupper($info[0]);
}
$column['name'] = '`' . str_replace('$', '', $info[1]) . '`';
if ($column['name'] == '`id`') {
$column['attr']['unsigned'] = 'UNSIGNED';
$column['attr']['autoincrement'] = 'AUTO_INCREMENT';
$keys []= $column['name'];
}
array_shift($info);
array_shift($info);
foreach ($info as $data) {
if (strpos($data, '=') !== false) {
list($attr, $val) = explode('=', $data);
switch ($attr) {
case 'length':
$column['type'] .= '(' . $val . ')';
break;
case 'foreign':
list($ftable, $fk) = explode('.', $val);
$foreigns []= 'fk_' . $table . '_' . $ftable . ' FOREIGN KEY (' . $column['name'] . ') REFERENCES ' . $ftable . '(' . $fk . ')';
$column['attr']['unsigned'] = 'UNSIGNED';
break;
default:
$column['attr'][$attr] = strtoupper($attr . ' ' . $val);
}
} else {
$column['attr'][$data] = strtoupper($data);
}
}
if ($column['type'] == 'VARCHAR') {
$column['type'] .= '(255)';
}
if (!isset($column['attr']['null'])) {
$column['attr']['null'] = 'NOT NULL';
}
$attrs = ['unsigned', 'zerofill', 'null', 'default', 'autoincrement'];
$reordered = [];
foreach ($attrs as $attr) {
if (isset($column['attr'][$attr])) {
$reordered[$attr] = $column['attr'][$attr];
}
}
$column['attr'] = $reordered;
return $column;
}
function columnQuery($column) {
$q = $column['name'] . ' ' . $column['type'];
foreach ($column['attr'] as $attr) {
$q .= ' ' . $attr;
}
return $q;
}
function tableQuery($table, $columns, $keys, $foreigns) {
$q = 'CREATE TABLE `' . $table . '` (' . implode(', ', $columns);
if (count($keys) > 0) {
$q .= ', PRIMARY KEY (' . implode(', ', $keys) . ')';
}
if (count($foreigns) > 0) {
$q .= ', CONSTRAINT ' . implode(', CONSTRAINT ', $foreigns);
}
$q .= ') ENGINE=InnoDB DEFAULT CHARSET=utf8;';
return $q;
}
$cnt = 0;
$queries = [];
foreach ($models as $model) {
$class = '\\Incoviba\\common\\' . $model;
$ref = new ReflectionClass($class);
$table = $ref->getProperty('_table')->getValue();
$comments = explode(PHP_EOL, $ref->getDocComment());
$columns = [];
$keys = [];
$foreigns = [];
foreach ($comments as $comment) {
if (strpos($comment, '@property') === false) {
continue;
}
$info = explode(' ', substr($comment, strpos($comment, '@property') + strlen('@property ')));
$column = extractColumn($table, $info, $keys, $foreigns);
$columns []= columnQuery($column);
}
$q = tableQuery($table, $columns, $keys, $foreigns);
$queries []= $q;
}
try {
\ORM::getDb()->beginTransaction();
foreach ($queries as $q) {
\ORM::getDb()->query($q);
}
\ORM::getDb()->commit();
header('Location: next_step.php?step=create_user_base');
} catch (Exception $e) {
\ORM::getDb()->rollBack();
throw $e;
}
?>

View File

@ -0,0 +1,7 @@
<?php
include_once dirname(dirname(__DIR__)) . '/bootstrap/autoload.php';
sanitize();
echo view('install.end');
?>

7
public/install/index.php Normal file
View File

@ -0,0 +1,7 @@
<?php
include_once dirname(dirname(__DIR__)) . '/bootstrap/autoload.php';
sanitize();
echo view('install.start');
?>

View File

@ -0,0 +1,39 @@
<?php
include_once dirname(dirname(__DIR__)) . '/bootstrap/autoload.php';
$controllers = glob(config('locations.controllers') . '/*.php');
$cnt = 0;
$errors = 0;
foreach ($controllers as $controller) {
$info = pathinfo($controller);
$name = $info['filename'];
$controller = '' . Stringy\Stringy::create($name)->underscored();
$class = '\\App\\Controller\\' . $name;
$ref = new ReflectionClass($class);
$methods = $ref->getMethods(ReflectionMethod::IS_STATIC);
try {
foreach ($methods as $method) {
$data = [
'controller' => $controller,
'action' => $method->name
];
$location = Model::factory(\Incoviba\common\Location::class)->where('controller', $controller)->where('action', $method->name)->findOne();
if ($location !== false) {
continue;
}
$location = Model::factory(\Incoviba\common\Location::class)->create($data);
$location->save();
$cnt ++;
}
} catch (Exception $e) {
d($e);
$errors ++;
}
}
if ($errors == 0) {
header('Location: next_step.php?step=log_locations');
}
?>

View File

@ -0,0 +1,20 @@
<?php
include_once dirname(dirname(__DIR__)) . '/bootstrap/autoload.php';
sanitize();
$steps = [
'create_user_base',
'log_locations',
'create_guest',
'create_admin',
'end_install'
];
if (get('step') == null) {
$next = $steps[0];
} else {
$next = $steps[array_search(get('step'), $steps) + 1];
}
header('Location: ' . $next . '.php');
?>

81
public/js/admin.js Normal file
View File

@ -0,0 +1,81 @@
$(document).ready(function() {
$('#databases').submit(function(e) {
e.preventDefault();
var db = $("[name='database']").val();
var models = [];
var namespaces = [];
$.post('?p=admin&action=listModels', {"database": db}).done(function(data) {
//console.debug(data);
var info = $.parseJSON(data);
//console.debug(info.models);
models = info.models;
//console.debug(models);
$.post('?p=admin&action=listNamespaces').done(function(data) {
//console.debug(data);
info = $.parseJSON(data);
//console.debug(info.models);
namespaces = info.namespaces;
//console.debug(namespaces);
$.each(models, function(i, elem) {
var div = $('<div></div>').attr('class', 'row');
div.append($('<div></div>').attr('class', 'col-md-2').html(elem.model));
var div2 = $('<div></div>').attr('class', 'row');
$.each(namespaces, function(j, ns) {
div2.append($('<div></div>').attr('class', 'col-md-3').append($('<span></span>').attr('class', 'ns').attr('data-table', elem.table).attr('data-ns', ns).html(ns)));
});
div.append($('<div></div>').attr('class', 'col-md-9').append(div2));
div.append($('<div></div>').attr('class', 'col-md-1 remove').append($('<span></span>').attr('class', 'glyphicon glyphicon-remove')));
$('#results').append(div);
});
$('.ns').css('cursor', 'pointer');
$('.remove').css('cursor', 'pointer');
$('.ns').mouseover(function(e) {
$(this).parent().addClass('bg-success');
$(this).parent().parent().parent().parent().addClass('bg-warning');
}).mouseout(function(e) {
$(this).parent().removeClass('bg-success');
$(this).parent().parent().parent().parent().removeClass('bg-warning');
});
$('.remove').mouseover(function(e) {
$(this).parent().addClass('bg-danger');
}).mouseout(function(e) {
$(this).parent().removeClass('bg-danger');
});
$('.ns').click(function(e) {
var table = $(this).attr('data-table');
var ns = $(this).attr('data-ns');
execute(table, ns);
});
$('.remove').click(function(e) {
$(this).parent().remove();
});
});
});
return false;
});
});
function execute(table, ns) {
console.debug(table, ns);
var db = $("[name='database']").val();
$.post('?p=admin&action=createModel', {"table": table, "namespace": ns, "database": db}).done(function(data) {
console.debug(data);
var info = $.parseJSON(data);
console.debug(info);
if (info.result) {
$(".ns[data-table='" + table + "']").parent().parent().parent().parent().remove();
} else {
alert('Error');
}
});
}

89
public/js/app.js Normal file

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,56 @@
$(document).ready(function(e) {
$('.glyphicon-copy').click(function(ev) {
var name = $(this).attr('data-name');
var n = $(this).attr('data-n');
var total = $("input[name='cuotas']").val();
if (name == 'fecha') {
copyDate(n, total);
return;
}
var value = $("input[name='" + name + n + "']").val();
if (value == '') {
return;
}
if (name == 'numero') {
copyIncrement(name, value, n, total);
return;
}
copyDown(name, value, n, total);
});
});
function copyDate(start, end) {
var d = $("select[name='day" + start + "']").val()
var m = $("select[name='month" + start + "']").val() - 1
var y = $("select[name='year" + start + "']").val()
var f = new Date(y, m, d)
for (i = parseInt(start) + 1; i < end; i ++) {
f = new Date(f.setMonth(f.getMonth() + 1));
if (f.getDate() < d) {
f.setDate(0)
}
$("select[name='day" + i + "']").val(f.getDate())
$("select[name='month" + i + "']").val(f.getMonth() + 1)
$("select[name='year" + i + "']").val(f.getFullYear())
}
}
function copyIncrement(name, value, start, end, type = 'input') {
var val = parseInt(value) + 1;
for (i = parseInt(start) + 1; i < end; i ++) {
$(type + "[name='" + name + i + "']").val(val ++);
}
}
function copyDown(name, value, start, end, type = 'input') {
for (i = parseInt(start) + 1; i < end; i ++) {
$(type + "[name='" + name + i + "']").val(value);
}
}

6
public/links.log Normal file
View File

@ -0,0 +1,6 @@
{
"found": [],
"not_found": [
"/registro/82"
]
}

1
public/precios.csv Normal file
View File

@ -0,0 +1 @@
tipo_unidad;numeracion;valor
1 tipo_unidad numeracion valor

30
resources/js/app.js Normal file
View File

@ -0,0 +1,30 @@
require('./bootstrap');
var autocomplete = require('jquery-ui/ui/widgets/autocomplete');
$(document).ready(function() {
$('form:first').find('*').filter(':input:visible:first').focus();
$('.dropdown-submenu>a').on("click", function(e) {
$(this).next('ul').toggle();
e.stopPropagation();
e.preventDefault();
});
});
require('./jquery.filterTable');
require('./binaryIndexOf');
require('jquery.rut');
String.prototype.ucwords = function() {
str = this.toLowerCase();
return str.replace(/(^([a-zA-Z\p{M}]))|([ -][a-zA-Z\p{M}])/g,
function(s) {
return s.toUpperCase();
});
};
require('./chart');
window.zxcvbn = require('zxcvbn');

View File

@ -0,0 +1,28 @@
function binaryIndexOf(searchElement) {
'use strict';
var minIndex = 0;
var maxIndex = this.length - 1;
var currentIndex;
var currentElement;
var resultIndex;
while (minIndex <= maxIndex) {
resultIndex = currentIndex = (minIndex + maxIndex) / 2 | 0;
currentElement = this[currentIndex];
if (currentElement < searchElement) {
minIndex = currentIndex + 1;
}
else if (currentElement > searchElement) {
maxIndex = currentIndex - 1;
}
else {
return currentIndex;
}
}
return ~maxIndex;
}
Array.prototype.binaryIndexOf = binaryIndexOf;

11
resources/js/bootstrap.js vendored Normal file
View File

@ -0,0 +1,11 @@
/**
* We'll load jQuery and the Bootstrap jQuery plugin which provides support
* for JavaScript based Bootstrap features such as modals and tabs. This
* code may be modified to fit the specific needs of your application.
*/
window.$ = window.jQuery = require('jquery');
require('bootstrap');
require('bootstrap-3-typeahead');

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