├── .idea ├── .name ├── misc.xml ├── scopes │ └── scope_settings.xml ├── encodings.xml ├── vcs.xml ├── modules.xml └── hotel.iml ├── public ├── favicon.ico ├── robots.txt ├── hotel │ ├── .bowerrc │ ├── app │ │ ├── view1 │ │ │ ├── view1.html │ │ │ ├── view1.js │ │ │ └── view1_test.js │ │ ├── view2 │ │ │ ├── view2.html │ │ │ ├── view2.js │ │ │ └── view2_test.js │ │ ├── components │ │ │ └── version │ │ │ │ ├── version.js │ │ │ │ ├── version-directive.js │ │ │ │ ├── interpolate-filter.js │ │ │ │ ├── version_test.js │ │ │ │ ├── interpolate-filter_test.js │ │ │ │ └── version-directive_test.js │ │ ├── app.js │ │ ├── book │ │ │ ├── book.js │ │ │ ├── finalize.js │ │ │ ├── book.html │ │ │ └── finalize.html │ │ ├── room_admin │ │ │ ├── room_admin.js │ │ │ └── room_admin.html │ │ ├── payment │ │ │ ├── pay.js │ │ │ └── pay.html │ │ ├── index.html │ │ ├── index-async.html │ │ └── app.css │ ├── .gitignore │ ├── .jshintrc │ ├── e2e-tests │ │ ├── protractor.conf.js │ │ └── scenarios.js │ ├── .travis.yml │ ├── bower.json │ ├── karma.conf.js │ ├── LICENSE │ ├── package.json │ └── README.md ├── .htaccess └── index.php ├── app ├── Listeners │ └── .gitkeep ├── Events │ └── Event.php ├── Http │ ├── Requests │ │ └── Request.php │ ├── Controllers │ │ ├── Controller.php │ │ ├── RoomTypeController.php │ │ ├── Auth │ │ │ ├── PasswordController.php │ │ │ └── AuthController.php │ │ ├── PaymentController.php │ │ ├── ReservationController.php │ │ └── RoomCalendarController.php │ ├── Middleware │ │ ├── EncryptCookies.php │ │ ├── VerifyCsrfToken.php │ │ ├── RedirectIfAuthenticated.php │ │ └── Authenticate.php │ ├── Kernel.php │ └── routes.php ├── RoomType.php ├── RoomCalendar.php ├── Customer.php ├── ReservationNight.php ├── Reservation.php ├── Providers │ ├── AppServiceProvider.php │ ├── EventServiceProvider.php │ └── RouteServiceProvider.php ├── Jobs │ └── Job.php ├── Console │ ├── Commands │ │ └── Inspire.php │ └── Kernel.php ├── User.php └── Exceptions │ └── Handler.php ├── database ├── seeds │ ├── .gitkeep │ └── DatabaseSeeder.php ├── migrations │ ├── .gitkeep │ ├── 2015_08_04_170359_create_table_customers.php │ ├── 2015_08_04_170329_create_table_reservation_nights.php │ ├── 2014_10_12_100000_create_password_resets_table.php │ ├── 2015_08_04_170246_create_table_room_type.php │ ├── 2015_08_04_170254_create_table_reservations.php │ ├── 2015_08_04_170250_create_table_room_calendar.php │ └── 2014_10_12_000000_create_users_table.php ├── .gitignore └── factories │ └── ModelFactory.php ├── resources ├── views │ ├── vendor │ │ └── .gitkeep │ ├── welcome.blade.php │ └── errors │ │ └── 503.blade.php ├── assets │ └── sass │ │ └── app.scss └── lang │ └── en │ ├── pagination.php │ ├── passwords.php │ └── validation.php ├── storage ├── app │ └── .gitignore ├── logs │ └── .gitignore └── framework │ ├── cache │ └── .gitignore │ ├── views │ └── .gitignore │ ├── sessions │ └── .gitignore │ └── .gitignore ├── bootstrap ├── cache │ └── .gitignore ├── autoload.php └── app.php ├── .gitattributes ├── phpspec.yml ├── package.json ├── .gitignore ├── .env.example ├── tests ├── ExampleTest.php └── TestCase.php ├── gulpfile.js ├── server.php ├── readme.md ├── phpunit.xml ├── config ├── services.php ├── compile.php ├── view.php ├── broadcasting.php ├── cache.php ├── auth.php ├── filesystems.php ├── queue.php ├── database.php ├── mail.php ├── session.php └── app.php ├── composer.json └── artisan /.idea/.name: -------------------------------------------------------------------------------- 1 | hotel -------------------------------------------------------------------------------- /public/favicon.ico: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /app/Listeners/.gitkeep: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /database/seeds/.gitkeep: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /database/migrations/.gitkeep: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /database/.gitignore: -------------------------------------------------------------------------------- 1 | *.sqlite 2 | -------------------------------------------------------------------------------- /resources/views/vendor/.gitkeep: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /storage/app/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore -------------------------------------------------------------------------------- /bootstrap/cache/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore 3 | -------------------------------------------------------------------------------- /storage/logs/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore 3 | -------------------------------------------------------------------------------- /public/robots.txt: -------------------------------------------------------------------------------- 1 | User-agent: * 2 | Disallow: 3 | -------------------------------------------------------------------------------- /storage/framework/cache/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore -------------------------------------------------------------------------------- /storage/framework/views/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore 3 | -------------------------------------------------------------------------------- /storage/framework/sessions/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore 3 | -------------------------------------------------------------------------------- /public/hotel/.bowerrc: -------------------------------------------------------------------------------- 1 | { 2 | "directory": "app/bower_components" 3 | } -------------------------------------------------------------------------------- /public/hotel/app/view1/view1.html: -------------------------------------------------------------------------------- 1 |

This is the partial for view 1.

2 | -------------------------------------------------------------------------------- /.gitattributes: -------------------------------------------------------------------------------- 1 | * text=auto 2 | *.css linguist-vendored 3 | *.less linguist-vendored 4 | -------------------------------------------------------------------------------- /resources/assets/sass/app.scss: -------------------------------------------------------------------------------- 1 | // @import "node_modules/bootstrap-sass/assets/stylesheets/bootstrap"; 2 | 3 | -------------------------------------------------------------------------------- /app/Events/Event.php: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | -------------------------------------------------------------------------------- /.idea/scopes/scope_settings.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 5 | -------------------------------------------------------------------------------- /public/hotel/app/view2/view2.html: -------------------------------------------------------------------------------- 1 |

This is the partial for view 2.

2 |

3 | Showing of 'interpolate' filter: 4 | {{ 'Current version is v%VERSION%.' | interpolate }} 5 |

6 | -------------------------------------------------------------------------------- /.idea/encodings.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | -------------------------------------------------------------------------------- /.idea/vcs.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | -------------------------------------------------------------------------------- /app/Http/Requests/Request.php: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | -------------------------------------------------------------------------------- /.idea/hotel.iml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | -------------------------------------------------------------------------------- /public/hotel/app/components/version/interpolate-filter.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | angular.module('myApp.version.interpolate-filter', []) 4 | 5 | .filter('interpolate', ['version', function(version) { 6 | return function(text) { 7 | return String(text).replace(/\%VERSION\%/mg, version); 8 | }; 9 | }]); 10 | -------------------------------------------------------------------------------- /app/RoomCalendar.php: -------------------------------------------------------------------------------- 1 | hasOne('App\RoomType'); 13 | } 14 | 15 | 16 | 17 | } 18 | -------------------------------------------------------------------------------- /public/hotel/app/view1/view1.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | angular.module('myApp.view1', ['ngRoute']) 4 | 5 | .config(['$routeProvider', function($routeProvider) { 6 | $routeProvider.when('/view1', { 7 | templateUrl: 'view1/view1.html', 8 | controller: 'View1Ctrl' 9 | }); 10 | }]) 11 | 12 | .controller('View1Ctrl', [function() { 13 | 14 | }]); -------------------------------------------------------------------------------- /public/hotel/app/view2/view2.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | angular.module('myApp.view2', ['ngRoute']) 4 | 5 | .config(['$routeProvider', function($routeProvider) { 6 | $routeProvider.when('/view2', { 7 | templateUrl: 'view2/view2.html', 8 | controller: 'View2Ctrl' 9 | }); 10 | }]) 11 | 12 | .controller('View2Ctrl', [function() { 13 | 14 | }]); -------------------------------------------------------------------------------- /public/hotel/app/components/version/version_test.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | describe('myApp.version module', function() { 4 | beforeEach(module('myApp.version')); 5 | 6 | describe('version service', function() { 7 | it('should return current version', inject(function(version) { 8 | expect(version).toEqual('0.1'); 9 | })); 10 | }); 11 | }); 12 | -------------------------------------------------------------------------------- /app/Customer.php: -------------------------------------------------------------------------------- 1 | hasOne('App\Reservation'); 14 | } 15 | 16 | function RoomType() 17 | { 18 | return $this->hasOne('App\RoomType'); 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /database/seeds/DatabaseSeeder.php: -------------------------------------------------------------------------------- 1 | call(UserTableSeeder::class); 18 | 19 | Model::reguard(); 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /app/Reservation.php: -------------------------------------------------------------------------------- 1 | hasMany('App\ReservationNight'); 14 | } 15 | 16 | function Customer(){ 17 | return $this->belongsTo('App\Customer'); 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /public/hotel/.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - "0.10" 4 | 5 | before_script: 6 | - export DISPLAY=:99.0 7 | - sh -e /etc/init.d/xvfb start 8 | - npm start > /dev/null & 9 | - npm run update-webdriver 10 | - sleep 1 # give server time to start 11 | 12 | script: 13 | - node_modules/.bin/karma start karma.conf.js --no-auto-watch --single-run --reporters=dots --browsers=Firefox 14 | - node_modules/.bin/protractor e2e-tests/protractor.conf.js --browser=firefox 15 | -------------------------------------------------------------------------------- /public/.htaccess: -------------------------------------------------------------------------------- 1 | 2 | 3 | Options -MultiViews 4 | 5 | 6 | RewriteEngine On 7 | 8 | # Redirect Trailing Slashes If Not A Folder... 9 | RewriteCond %{REQUEST_FILENAME} !-d 10 | RewriteRule ^(.*)/$ /$1 [L,R=301] 11 | 12 | # Handle Front Controller... 13 | RewriteCond %{REQUEST_FILENAME} !-d 14 | RewriteCond %{REQUEST_FILENAME} !-f 15 | RewriteRule ^ index.php [L] 16 | 17 | -------------------------------------------------------------------------------- /tests/ExampleTest.php: -------------------------------------------------------------------------------- 1 | visit('/') 17 | ->see('Laravel 5'); 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /public/hotel/bower.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "angular-seed", 3 | "description": "A starter project for AngularJS", 4 | "version": "0.0.0", 5 | "homepage": "https://github.com/angular/angular-seed", 6 | "license": "MIT", 7 | "private": true, 8 | "dependencies": { 9 | "angular": "~1.4.0", 10 | "angular-route": "~1.4.0", 11 | "angular-loader": "~1.4.0", 12 | "angular-mocks": "~1.4.0", 13 | "html5-boilerplate": "~5.2.0", 14 | "angular-materialize": "*", 15 | "angular-payments": "*" 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /public/hotel/app/components/version/interpolate-filter_test.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | describe('myApp.version module', function() { 4 | beforeEach(module('myApp.version')); 5 | 6 | describe('interpolate filter', function() { 7 | beforeEach(module(function($provide) { 8 | $provide.value('version', 'TEST_VER'); 9 | })); 10 | 11 | it('should replace VERSION', inject(function(interpolateFilter) { 12 | expect(interpolateFilter('before %VERSION% after')).toEqual('before TEST_VER after'); 13 | })); 14 | }); 15 | }); 16 | -------------------------------------------------------------------------------- /app/Providers/AppServiceProvider.php: -------------------------------------------------------------------------------- 1 | ')($rootScope); 13 | expect(element.text()).toEqual('TEST_VER'); 14 | }); 15 | }); 16 | }); 17 | }); 18 | -------------------------------------------------------------------------------- /app/Http/Controllers/RoomTypeController.php: -------------------------------------------------------------------------------- 1 | all()); 24 | $room_type->save(); 25 | 26 | return $room_type; 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /app/Jobs/Job.php: -------------------------------------------------------------------------------- 1 | '« Previous', 17 | 'next' => 'Next »', 18 | 19 | ]; 20 | -------------------------------------------------------------------------------- /tests/TestCase.php: -------------------------------------------------------------------------------- 1 | make(Illuminate\Contracts\Console\Kernel::class)->bootstrap(); 22 | 23 | return $app; 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /server.php: -------------------------------------------------------------------------------- 1 | 8 | */ 9 | 10 | $uri = urldecode( 11 | parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH) 12 | ); 13 | 14 | // This file allows us to emulate Apache's "mod_rewrite" functionality from the 15 | // built-in PHP web server. This provides a convenient way to test a Laravel 16 | // application without having installed a "real" web server software here. 17 | if ($uri !== '/' && file_exists(__DIR__.'/public'.$uri)) { 18 | return false; 19 | } 20 | 21 | require_once __DIR__.'/public/index.php'; 22 | -------------------------------------------------------------------------------- /database/factories/ModelFactory.php: -------------------------------------------------------------------------------- 1 | define(App\User::class, function ($faker) { 15 | return [ 16 | 'name' => $faker->name, 17 | 'email' => $faker->email, 18 | 'password' => str_random(10), 19 | 'remember_token' => str_random(10), 20 | ]; 21 | }); 22 | -------------------------------------------------------------------------------- /database/migrations/2015_08_04_170359_create_table_customers.php: -------------------------------------------------------------------------------- 1 | increments('id'); 13 | $table->string('first_name'); 14 | $table->string('last_name'); 15 | $table->string('email'); 16 | $table->date('created_at'); 17 | $table->date('updated_at'); 18 | }); 19 | } 20 | 21 | public function down() 22 | { 23 | Schema::drop('customers'); 24 | 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /app/Console/Commands/Inspire.php: -------------------------------------------------------------------------------- 1 | comment(PHP_EOL.Inspiring::quote().PHP_EOL); 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /public/hotel/app/app.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | // Declare app level module which depends on views, and components 4 | angular.module('myApp', [ 5 | 'ngRoute', 6 | 'myApp.view1', 7 | 'myApp.view2', 8 | 'myApp.version', 9 | 'myApp.roomAdmin', 10 | 'myApp.book', 11 | 'myApp.finalize', 12 | 'myApp.pay','angularPayments' 13 | ]). 14 | config(['$routeProvider', function($routeProvider) { 15 | 16 | $routeProvider.otherwise({redirectTo: '/room_type'}); 17 | 18 | }]) 19 | 20 | 21 | 22 | .service('reservationData', function () { 23 | 24 | var hashtable = {}; 25 | 26 | return { 27 | setValue: function (key, value) { 28 | hashtable[key] = value; 29 | }, 30 | getValue: function (key) { 31 | return hashtable[key]; 32 | } 33 | } 34 | }); -------------------------------------------------------------------------------- /app/Console/Kernel.php: -------------------------------------------------------------------------------- 1 | command('inspire') 28 | ->hourly(); 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /database/migrations/2015_08_04_170329_create_table_reservation_nights.php: -------------------------------------------------------------------------------- 1 | increments('id'); 13 | $table->float('rate'); 14 | $table->date('day'); 15 | $table->integer('room_type_id'); 16 | $table->integer('reservation_id'); 17 | $table->date('created_at'); 18 | $table->date('updated_at'); 19 | }); 20 | } 21 | 22 | 23 | public function down() 24 | { 25 | Schema::drop('reservation_nights'); 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /database/migrations/2014_10_12_100000_create_password_resets_table.php: -------------------------------------------------------------------------------- 1 | string('email')->index(); 17 | $table->string('token')->index(); 18 | $table->timestamp('created_at'); 19 | }); 20 | } 21 | 22 | /** 23 | * Reverse the migrations. 24 | * 25 | * @return void 26 | */ 27 | public function down() 28 | { 29 | Schema::drop('password_resets'); 30 | } 31 | } 32 | -------------------------------------------------------------------------------- /database/migrations/2015_08_04_170246_create_table_room_type.php: -------------------------------------------------------------------------------- 1 | increments('id'); 12 | $table->string('name', 100); 13 | $table->string('short_name',10); 14 | $table->float('base_price'); 15 | $table->integer('base_availability'); 16 | $table->integer('max_occupancy'); 17 | $table->date('created_at'); 18 | $table->date('updated_at'); 19 | }); 20 | 21 | } 22 | 23 | public function down() 24 | { 25 | Schema::drop('room_types'); 26 | 27 | } 28 | } -------------------------------------------------------------------------------- /database/migrations/2015_08_04_170254_create_table_reservations.php: -------------------------------------------------------------------------------- 1 | increments('id'); 13 | $table->float('total_price'); 14 | $table->integer('occupancy'); 15 | $table->date('checkin'); 16 | $table->date('checkout'); 17 | $table->string('customer_id'); 18 | $table->date('created_at'); 19 | $table->date('updated_at'); 20 | }); 21 | } 22 | 23 | public function down() 24 | { 25 | Schema::drop('reservations'); 26 | 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /public/hotel/karma.conf.js: -------------------------------------------------------------------------------- 1 | module.exports = function(config){ 2 | config.set({ 3 | 4 | basePath : './', 5 | 6 | files : [ 7 | 'app/bower_components/angular/angular.js', 8 | 'app/bower_components/angular-route/angular-route.js', 9 | 'app/bower_components/angular-mocks/angular-mocks.js', 10 | 'app/components/**/*.js', 11 | 'app/view*/**/*.js' 12 | ], 13 | 14 | autoWatch : true, 15 | 16 | frameworks: ['jasmine'], 17 | 18 | browsers : ['Chrome'], 19 | 20 | plugins : [ 21 | 'karma-chrome-launcher', 22 | 'karma-firefox-launcher', 23 | 'karma-jasmine', 24 | 'karma-junit-reporter' 25 | ], 26 | 27 | junitReporter : { 28 | outputFile: 'test_out/unit.xml', 29 | suite: 'unit' 30 | } 31 | 32 | }); 33 | }; 34 | -------------------------------------------------------------------------------- /database/migrations/2015_08_04_170250_create_table_room_calendar.php: -------------------------------------------------------------------------------- 1 | increments('id'); 13 | $table->integer('room_type_id'); 14 | $table->integer('availability'); 15 | $table->integer('reservations'); 16 | $table->float('rate'); 17 | $table->date('day'); 18 | $table->date('created_at'); 19 | $table->date('updated_at'); 20 | }); 21 | } 22 | 23 | 24 | public function down() 25 | { 26 | Schema::drop('room_calendars'); 27 | 28 | } 29 | } -------------------------------------------------------------------------------- /resources/lang/en/passwords.php: -------------------------------------------------------------------------------- 1 | 'Passwords must be at least six characters and match the confirmation.', 17 | 'user' => "We can't find a user with that e-mail address.", 18 | 'token' => 'This password reset token is invalid.', 19 | 'sent' => 'We have e-mailed your password reset link!', 20 | 'reset' => 'Your password has been reset!', 21 | 22 | ]; 23 | -------------------------------------------------------------------------------- /app/Providers/EventServiceProvider.php: -------------------------------------------------------------------------------- 1 | [ 17 | 'App\Listeners\EventListener', 18 | ], 19 | ]; 20 | 21 | /** 22 | * Register any other events for your application. 23 | * 24 | * @param \Illuminate\Contracts\Events\Dispatcher $events 25 | * @return void 26 | */ 27 | public function boot(DispatcherContract $events) 28 | { 29 | parent::boot($events); 30 | 31 | // 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /database/migrations/2014_10_12_000000_create_users_table.php: -------------------------------------------------------------------------------- 1 | increments('id'); 17 | $table->string('name'); 18 | $table->string('email')->unique(); 19 | $table->string('password', 60); 20 | $table->rememberToken(); 21 | $table->timestamps(); 22 | }); 23 | } 24 | 25 | /** 26 | * Reverse the migrations. 27 | * 28 | * @return void 29 | */ 30 | public function down() 31 | { 32 | Schema::drop('users'); 33 | } 34 | } 35 | -------------------------------------------------------------------------------- /readme.md: -------------------------------------------------------------------------------- 1 | ## How to build an hotel booking system with Laravel 5.1 and AngularJS 2 | A tutorial series from [CODETutorial.io](http://codetutorial.io) . 3 | 4 | The tutorial will explain how to create an hotel booking system from scratch using Laravel 5.1 and AngularJS. For this booking engine we will use AngularJS to create a single page application, the front end, where the final user can make reservations and the hotel owner can manage rooms, price and reservations. On the backend side we will use Laravel to create all the needed REST API to serve the application. 5 | 6 | ## Tutorial articles 7 | * [Part 1 - Setup Laravel and Datamodel](http://www.codetutorial.io/hotel-booking-with-laravel-5-and-angularjs-p1/) 8 | * [Part 2 - Setup AngularJS](http://www.codetutorial.io/hotel-booking-engine-with-laravel-5-and-angularjs-p2/) 9 | * [Part 3 - Complete the reservation system ](http://www.codetutorial.io/hotel-booking-engine-with-laravel-5-and-angularjs-part-3/) 10 | 11 | -------------------------------------------------------------------------------- /app/Http/Controllers/Auth/PasswordController.php: -------------------------------------------------------------------------------- 1 | middleware('guest'); 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /app/Http/Middleware/RedirectIfAuthenticated.php: -------------------------------------------------------------------------------- 1 | auth = $auth; 26 | } 27 | 28 | /** 29 | * Handle an incoming request. 30 | * 31 | * @param \Illuminate\Http\Request $request 32 | * @param \Closure $next 33 | * @return mixed 34 | */ 35 | public function handle($request, Closure $next) 36 | { 37 | if ($this->auth->check()) { 38 | return redirect('/home'); 39 | } 40 | 41 | return $next($request); 42 | } 43 | } 44 | -------------------------------------------------------------------------------- /app/Http/Controllers/PaymentController.php: -------------------------------------------------------------------------------- 1 | charge($total_price, 23 | [ 24 | 'source' => $token, 25 | 'receipt_email' => $customer->email 26 | ])) 27 | { 28 | $mess = ['status' => "OK","message" =>"Payment ok"]; 29 | return $mess; 30 | }else{ 31 | $mess = ['status' => "ERROR","message" =>"Error submitting payment"]; 32 | return $mess; 33 | } 34 | } 35 | 36 | } 37 | -------------------------------------------------------------------------------- /app/User.php: -------------------------------------------------------------------------------- 1 | 2 | 12 | 13 | 14 | ./tests/ 15 | 16 | 17 | 18 | 19 | app/ 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | -------------------------------------------------------------------------------- /config/services.php: -------------------------------------------------------------------------------- 1 | [ 18 | 'domain' => '', 19 | 'secret' => '', 20 | ], 21 | 22 | 'mandrill' => [ 23 | 'secret' => '', 24 | ], 25 | 26 | 'ses' => [ 27 | 'key' => '', 28 | 'secret' => '', 29 | 'region' => 'us-east-1', 30 | ], 31 | 32 | 'stripe' => [ 33 | 'model' => App\Customer::class, 34 | 'key' => 'pk_test_p0QQDCeJQA7W9X9y0VP7QOz5', 35 | 'secret' => 'sk_test_vkLyPOI6CcWC2xtrSa2r90up', 36 | ], 37 | 38 | ]; 39 | -------------------------------------------------------------------------------- /app/Http/Middleware/Authenticate.php: -------------------------------------------------------------------------------- 1 | auth = $auth; 26 | } 27 | 28 | /** 29 | * Handle an incoming request. 30 | * 31 | * @param \Illuminate\Http\Request $request 32 | * @param \Closure $next 33 | * @return mixed 34 | */ 35 | public function handle($request, Closure $next) 36 | { 37 | if ($this->auth->guest()) { 38 | if ($request->ajax()) { 39 | return response('Unauthorized.', 401); 40 | } else { 41 | return redirect()->guest('auth/login'); 42 | } 43 | } 44 | 45 | return $next($request); 46 | } 47 | } 48 | -------------------------------------------------------------------------------- /app/Http/Kernel.php: -------------------------------------------------------------------------------- 1 | \App\Http\Middleware\Authenticate::class, 30 | 'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class, 31 | 'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class, 32 | ]; 33 | } 34 | -------------------------------------------------------------------------------- /app/Http/routes.php: -------------------------------------------------------------------------------- 1 | 'api'], function() { 19 | Route::post('searchavailabity', 'RoomCalendarController@searchAvailability'); 20 | Route::post('createreservation', 'ReservationController@createReservation'); 21 | Route::get('reservation/{id}', 'ReservationController@show'); 22 | Route::post('payreservation', 'PaymentController@pay'); 23 | 24 | }); 25 | 26 | Route::group(['prefix' => 'adminapi'], function() 27 | { 28 | Route::resource('room_type', 'RoomTypeController'); 29 | Route::post('setpriceinrange', 'RoomCalendarController@setPriceInRangeForRoomType'); 30 | 31 | 32 | }); -------------------------------------------------------------------------------- /config/compile.php: -------------------------------------------------------------------------------- 1 | [ 17 | // 18 | ], 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | Compiled File Providers 23 | |-------------------------------------------------------------------------- 24 | | 25 | | Here you may list service providers which define a "compiles" function 26 | | that returns additional files that should be compiled, providing an 27 | | easy way to get common files from any packages you are utilizing. 28 | | 29 | */ 30 | 31 | 'providers' => [ 32 | // 33 | ], 34 | 35 | ]; 36 | -------------------------------------------------------------------------------- /public/hotel/e2e-tests/scenarios.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | /* https://github.com/angular/protractor/blob/master/docs/toc.md */ 4 | 5 | describe('my app', function() { 6 | 7 | 8 | it('should automatically redirect to /view1 when location hash/fragment is empty', function() { 9 | browser.get('index.html'); 10 | expect(browser.getLocationAbsUrl()).toMatch("/view1"); 11 | }); 12 | 13 | 14 | describe('view1', function() { 15 | 16 | beforeEach(function() { 17 | browser.get('index.html#/view1'); 18 | }); 19 | 20 | 21 | it('should render view1 when user navigates to /view1', function() { 22 | expect(element.all(by.css('[ng-view] p')).first().getText()). 23 | toMatch(/partial for view 1/); 24 | }); 25 | 26 | }); 27 | 28 | 29 | describe('view2', function() { 30 | 31 | beforeEach(function() { 32 | browser.get('index.html#/view2'); 33 | }); 34 | 35 | 36 | it('should render view2 when user navigates to /view2', function() { 37 | expect(element.all(by.css('[ng-view] p')).first().getText()). 38 | toMatch(/partial for view 2/); 39 | }); 40 | 41 | }); 42 | }); 43 | -------------------------------------------------------------------------------- /config/view.php: -------------------------------------------------------------------------------- 1 | [ 17 | realpath(base_path('resources/views')), 18 | ], 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | Compiled View Path 23 | |-------------------------------------------------------------------------- 24 | | 25 | | This option determines where all the compiled Blade templates will be 26 | | stored for your application. Typically, this is within the storage 27 | | directory. However, as usual, you are free to change this value. 28 | | 29 | */ 30 | 31 | 'compiled' => realpath(storage_path('framework/views')), 32 | 33 | ]; 34 | -------------------------------------------------------------------------------- /app/Exceptions/Handler.php: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | Laravel 5 | 6 | 7 | 8 | 37 | 38 | 39 |
40 |
41 |
Laravel 5
42 |
43 |
44 | 45 | 46 | -------------------------------------------------------------------------------- /app/Providers/RouteServiceProvider.php: -------------------------------------------------------------------------------- 1 | group(['namespace' => $this->namespace], function ($router) { 41 | require app_path('Http/routes.php'); 42 | }); 43 | } 44 | } 45 | -------------------------------------------------------------------------------- /resources/views/errors/503.blade.php: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | Be right back. 5 | 6 | 7 | 8 | 39 | 40 | 41 |
42 |
43 |
Be right back.
44 |
45 |
46 | 47 | 48 | -------------------------------------------------------------------------------- /public/hotel/app/book/book.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | angular.module('myApp.book', ['ngRoute','ui.materialize']) 4 | 5 | .config(['$routeProvider', function($routeProvider) { 6 | $routeProvider.when('/book', { 7 | templateUrl: 'book/book.html', 8 | controller: 'BookController' 9 | }); 10 | }]) 11 | 12 | .controller('BookController', function($scope,$http,reservationData,$location) { 13 | 14 | 15 | $scope.select_occupancy = [1,2,3,4,5]; 16 | $scope.available_room_types; 17 | $scope.search_param={}; 18 | 19 | $scope.search = function(){ 20 | 21 | $http.post('/api/searchavailabity',$scope.search_param).success(function(data){ 22 | $scope.available_room_types = data; 23 | }); 24 | 25 | }; 26 | 27 | $scope.book = function (id) { 28 | 29 | console.log($scope.search_param); 30 | 31 | reservationData.setValue('start_dt',$scope.search_param.start_dt); 32 | reservationData.setValue('end_dt',$scope.search_param.end_dt); 33 | reservationData.setValue('occupancy',$scope.search_param.min_occupancy); 34 | reservationData.setValue('room_info', $scope.available_room_types[id]); 35 | 36 | 37 | $location.path( "/finalize" ); 38 | 39 | }; 40 | 41 | } 42 | ); -------------------------------------------------------------------------------- /composer.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "laravel/laravel", 3 | "description": "The Laravel Framework.", 4 | "keywords": ["framework", "laravel"], 5 | "license": "MIT", 6 | "type": "project", 7 | "require": { 8 | "php": ">=5.5.9", 9 | "laravel/framework": "5.1.*" 10 | }, 11 | "require-dev": { 12 | "fzaninotto/faker": "~1.4", 13 | "mockery/mockery": "0.9.*", 14 | "phpunit/phpunit": "~4.0", 15 | "phpspec/phpspec": "~2.1", 16 | "laravel/cashier": "~5.0" 17 | }, 18 | "autoload": { 19 | "classmap": [ 20 | "database" 21 | ], 22 | "psr-4": { 23 | "App\\": "app/" 24 | } 25 | }, 26 | "autoload-dev": { 27 | "classmap": [ 28 | "tests/TestCase.php" 29 | ] 30 | }, 31 | "scripts": { 32 | "post-install-cmd": [ 33 | "php artisan clear-compiled", 34 | "php artisan optimize" 35 | ], 36 | "pre-update-cmd": [ 37 | "php artisan clear-compiled" 38 | ], 39 | "post-update-cmd": [ 40 | "php artisan optimize" 41 | ], 42 | "post-root-package-install": [ 43 | "php -r \"copy('.env.example', '.env');\"" 44 | ], 45 | "post-create-project-cmd": [ 46 | "php artisan key:generate" 47 | ] 48 | }, 49 | "config": { 50 | "preferred-install": "dist" 51 | } 52 | } 53 | -------------------------------------------------------------------------------- /config/broadcasting.php: -------------------------------------------------------------------------------- 1 | env('BROADCAST_DRIVER', 'pusher'), 17 | 18 | /* 19 | |-------------------------------------------------------------------------- 20 | | Broadcast Connections 21 | |-------------------------------------------------------------------------- 22 | | 23 | | Here you may define all of the broadcast connections that will be used 24 | | to broadcast events to other systems or over websockets. Samples of 25 | | each available type of connection are provided inside this array. 26 | | 27 | */ 28 | 29 | 'connections' => [ 30 | 31 | 'pusher' => [ 32 | 'driver' => 'pusher', 33 | 'key' => env('PUSHER_KEY'), 34 | 'secret' => env('PUSHER_SECRET'), 35 | 'app_id' => env('PUSHER_APP_ID'), 36 | ], 37 | 38 | 'redis' => [ 39 | 'driver' => 'redis', 40 | 'connection' => 'default', 41 | ], 42 | 43 | 'log' => [ 44 | 'driver' => 'log', 45 | ], 46 | 47 | ], 48 | 49 | ]; 50 | -------------------------------------------------------------------------------- /public/hotel/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "angular-seed", 3 | "private": true, 4 | "version": "0.0.0", 5 | "description": "A starter project for AngularJS", 6 | "repository": "https://github.com/angular/angular-seed", 7 | "license": "MIT", 8 | "devDependencies": { 9 | "bower": "^1.3.1", 10 | "http-server": "^0.6.1", 11 | "jasmine-core": "^2.3.4", 12 | "karma": "~0.12", 13 | "karma-chrome-launcher": "^0.1.12", 14 | "karma-firefox-launcher": "^0.1.6", 15 | "karma-jasmine": "^0.3.5", 16 | "karma-junit-reporter": "^0.2.2", 17 | "protractor": "^2.1.0", 18 | "shelljs": "^0.2.6" 19 | }, 20 | "scripts": { 21 | "postinstall": "bower install", 22 | 23 | "prestart": "npm install", 24 | "start": "http-server -a localhost -p 8000 -c-1", 25 | 26 | "pretest": "npm install", 27 | "test": "karma start karma.conf.js", 28 | "test-single-run": "karma start karma.conf.js --single-run", 29 | 30 | "preupdate-webdriver": "npm install", 31 | "update-webdriver": "webdriver-manager update", 32 | 33 | "preprotractor": "npm run update-webdriver", 34 | "protractor": "protractor e2e-tests/protractor.conf.js", 35 | 36 | "update-index-async": "node -e \"require('shelljs/global'); sed('-i', /\\/\\/@@NG_LOADER_START@@[\\s\\S]*\\/\\/@@NG_LOADER_END@@/, '//@@NG_LOADER_START@@\\n' + sed(/sourceMappingURL=angular-loader.min.js.map/,'sourceMappingURL=bower_components/angular-loader/angular-loader.min.js.map','app/bower_components/angular-loader/angular-loader.min.js') + '\\n//@@NG_LOADER_END@@', 'app/index-async.html');\"" 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /bootstrap/app.php: -------------------------------------------------------------------------------- 1 | singleton( 30 | Illuminate\Contracts\Http\Kernel::class, 31 | App\Http\Kernel::class 32 | ); 33 | 34 | $app->singleton( 35 | Illuminate\Contracts\Console\Kernel::class, 36 | App\Console\Kernel::class 37 | ); 38 | 39 | $app->singleton( 40 | Illuminate\Contracts\Debug\ExceptionHandler::class, 41 | App\Exceptions\Handler::class 42 | ); 43 | 44 | /* 45 | |-------------------------------------------------------------------------- 46 | | Return The Application 47 | |-------------------------------------------------------------------------- 48 | | 49 | | This script returns the application instance. The instance is given to 50 | | the calling script so we can separate the building of the instances 51 | | from the actual running of the application and sending responses. 52 | | 53 | */ 54 | 55 | return $app; 56 | -------------------------------------------------------------------------------- /artisan: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env php 2 | make(Illuminate\Contracts\Console\Kernel::class); 32 | 33 | $status = $kernel->handle( 34 | $input = new Symfony\Component\Console\Input\ArgvInput, 35 | new Symfony\Component\Console\Output\ConsoleOutput 36 | ); 37 | 38 | /* 39 | |-------------------------------------------------------------------------- 40 | | Shutdown The Application 41 | |-------------------------------------------------------------------------- 42 | | 43 | | Once Artisan has finished running. We will fire off the shutdown events 44 | | so that any final work may be done by the application before we shut 45 | | down the process. This is the last thing to happen to the request. 46 | | 47 | */ 48 | 49 | $kernel->terminate($input, $status); 50 | 51 | exit($status); 52 | -------------------------------------------------------------------------------- /public/hotel/app/room_admin/room_admin.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | angular.module('myApp.roomAdmin', ['ngRoute','ui.materialize']) 4 | 5 | .config(['$routeProvider', function($routeProvider) { 6 | $routeProvider.when('/room_admin', { 7 | templateUrl: 'room_admin/room_admin.html', 8 | controller: 'RoomAdminCtrl' 9 | }); 10 | }]) 11 | 12 | .controller('RoomAdminCtrl', function($scope,$http,$location) { 13 | 14 | $scope.room_types = []; 15 | $scope.new_type = {}; 16 | $scope.selected_idx; 17 | $scope.selected_type= {}; 18 | $scope.message=null; 19 | $scope.update_data= {}; 20 | 21 | $scope.init = function(){ 22 | $http.get('/adminapi/room_type').success(function(data){ 23 | $scope.room_types=data; 24 | }); 25 | } 26 | 27 | $scope.init(); 28 | 29 | $scope.create = function(){ 30 | $http.post('/adminapi/room_type',$scope.new_type).success(function(data){ 31 | 32 | $scope.room_types.push(data); 33 | $scope.new_type.name=""; 34 | $scope.new_type.short_name=""; 35 | $scope.new_type.base_price=""; 36 | $scope.new_type.base_availability=""; 37 | $scope.new_type.max_occupancy=""; 38 | 39 | }); 40 | }; 41 | 42 | $scope.select_type = function(index){ 43 | $scope.selected_idx=index; 44 | $scope.selected_type =$scope.room_types[index]; 45 | $scope.update_data.room_type= $scope.selected_type.id; 46 | $scope.message = null; 47 | 48 | }; 49 | 50 | $scope.setprice = function(){ 51 | 52 | $http.post('/adminapi/setpriceinrange',$scope.update_data).success(function(data){ 53 | $scope.selected_idx=-1; 54 | $scope.selected_type=null; 55 | $scope.update_data={}; 56 | 57 | $scope.message = data; 58 | }); 59 | 60 | } 61 | 62 | } 63 | ); -------------------------------------------------------------------------------- /public/hotel/app/payment/pay.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | angular.module('myApp.pay', ['ngRoute','ui.materialize']) 4 | 5 | .config(['$routeProvider', function($routeProvider) { 6 | $routeProvider.when('/pay/:reserv_id', { 7 | templateUrl: 'payment/pay.html', 8 | controller: 'PayController' 9 | }); 10 | }]) 11 | 12 | .controller('PayController', function($scope,$http,reservationData,$location,$routeParams) { 13 | 14 | $scope.res_id = $routeParams.reserv_id; 15 | $scope.paid = false; 16 | 17 | $scope.handleStripe = function(status, response){ 18 | if(response.error) { 19 | $scope.paid= false; 20 | $scope.message = "Error from Stripe.com" 21 | } else { 22 | console.log(response.id); 23 | var $payInfo = { 24 | 'token' : response.id, 25 | 'customer_id' : $scope.reservation_info.customer_id, 26 | 'total':$scope.reservation_info.total_price 27 | }; 28 | 29 | $http.post('/api/payreservation', $payInfo).success(function(data){ 30 | if(data.status=="OK"){ 31 | $scope.paid= true; 32 | $scope.message = data.message; 33 | }else{ 34 | $scope.paid= false; 35 | $scope.message = data.message; 36 | } 37 | }); 38 | 39 | } 40 | }; 41 | 42 | $scope.init = function(){ 43 | 44 | $scope.loaded = false; 45 | 46 | $http.get('/api/reservation/'+$scope.res_id).success(function(data){ 47 | $scope.reservation_info = data; 48 | console.log(data); 49 | $scope.loaded=true; 50 | }); 51 | }; 52 | 53 | $scope.init(); 54 | 55 | } 56 | ); -------------------------------------------------------------------------------- /public/hotel/app/book/finalize.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Created by andreaterzani on 06/08/15. 3 | */ 4 | 'use strict'; 5 | 6 | angular.module('myApp.finalize', ['ngRoute','ui.materialize']) 7 | 8 | .config(['$routeProvider', function($routeProvider) { 9 | $routeProvider.when('/finalize', { 10 | templateUrl: 'book/finalize.html', 11 | controller: 'FinalizeController' 12 | }); 13 | }]) 14 | 15 | .controller('FinalizeController', function($scope,$http,reservationData,$location) { 16 | 17 | $scope.start_dt; 18 | $scope.end_dt; 19 | $scope.room_info; 20 | $scope.occupancy; 21 | $scope.reservation_info; 22 | $scope.reser_done; 23 | $scope.customer={}; 24 | 25 | $scope.init = function(){ 26 | 27 | 28 | $scope.start_dt = reservationData.getValue('start_dt'); 29 | $scope.end_dt = reservationData.getValue('end_dt'); 30 | $scope.occupancy=reservationData.getValue('occupancy');; 31 | $scope.room_info=reservationData.getValue('room_info'); 32 | 33 | if($scope.room_info==null){ 34 | $location.path('/book'); 35 | } 36 | }; 37 | 38 | $scope.init(); 39 | 40 | $scope.book = function(){ 41 | 42 | var reservationInfo; 43 | console.log($scope.customer); 44 | 45 | reservationInfo = { 46 | 'customer':$scope.customer, 47 | 'room_info':$scope.room_info, 48 | 'start_dt':$scope.start_dt, 49 | 'end_dt':$scope.end_dt, 50 | 'occupancy':$scope.occupancy 51 | }; 52 | 53 | 54 | $http.post('/api/createreservation',reservationInfo).success(function(data){ 55 | 56 | $scope.reser_done=true; 57 | $scope.reservation_info = data; 58 | 59 | 60 | }); 61 | 62 | 63 | } 64 | 65 | 66 | } 67 | ); -------------------------------------------------------------------------------- /public/index.php: -------------------------------------------------------------------------------- 1 | 8 | */ 9 | 10 | /* 11 | |-------------------------------------------------------------------------- 12 | | Register The Auto Loader 13 | |-------------------------------------------------------------------------- 14 | | 15 | | Composer provides a convenient, automatically generated class loader for 16 | | our application. We just need to utilize it! We'll simply require it 17 | | into the script here so that we don't have to worry about manual 18 | | loading any of our classes later on. It feels nice to relax. 19 | | 20 | */ 21 | 22 | require __DIR__.'/../bootstrap/autoload.php'; 23 | 24 | /* 25 | |-------------------------------------------------------------------------- 26 | | Turn On The Lights 27 | |-------------------------------------------------------------------------- 28 | | 29 | | We need to illuminate PHP development, so let us turn on the lights. 30 | | This bootstraps the framework and gets it ready for use, then it 31 | | will load up this application so that we can run it and send 32 | | the responses back to the browser and delight our users. 33 | | 34 | */ 35 | 36 | $app = require_once __DIR__.'/../bootstrap/app.php'; 37 | 38 | /* 39 | |-------------------------------------------------------------------------- 40 | | Run The Application 41 | |-------------------------------------------------------------------------- 42 | | 43 | | Once we have the application, we can handle the incoming request 44 | | through the kernel, and send the associated response back to 45 | | the client's browser allowing them to enjoy the creative 46 | | and wonderful application we have prepared for them. 47 | | 48 | */ 49 | 50 | $kernel = $app->make(Illuminate\Contracts\Http\Kernel::class); 51 | 52 | $response = $kernel->handle( 53 | $request = Illuminate\Http\Request::capture() 54 | ); 55 | 56 | $response->send(); 57 | 58 | $kernel->terminate($request, $response); 59 | -------------------------------------------------------------------------------- /app/Http/Controllers/Auth/AuthController.php: -------------------------------------------------------------------------------- 1 | middleware('guest', ['except' => 'getLogout']); 34 | } 35 | 36 | /** 37 | * Get a validator for an incoming registration request. 38 | * 39 | * @param array $data 40 | * @return \Illuminate\Contracts\Validation\Validator 41 | */ 42 | protected function validator(array $data) 43 | { 44 | return Validator::make($data, [ 45 | 'name' => 'required|max:255', 46 | 'email' => 'required|email|max:255|unique:users', 47 | 'password' => 'required|confirmed|min:6', 48 | ]); 49 | } 50 | 51 | /** 52 | * Create a new user instance after a valid registration. 53 | * 54 | * @param array $data 55 | * @return User 56 | */ 57 | protected function create(array $data) 58 | { 59 | return User::create([ 60 | 'name' => $data['name'], 61 | 'email' => $data['email'], 62 | 'password' => bcrypt($data['password']), 63 | ]); 64 | } 65 | } 66 | -------------------------------------------------------------------------------- /public/hotel/app/book/book.html: -------------------------------------------------------------------------------- 1 |
2 |

Search your room

3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 | 12 | 13 |
14 |
15 |
16 |
17 | 18 | 19 |
20 |
21 |
22 | 23 | 26 |
27 |
28 |
29 |
30 | 31 |
32 |
33 |
34 |
35 |
36 |
37 | 38 |
39 |
40 |
41 |
42 | {{room_type.name}} 43 |

Total price : {{room_type.total_price}}

44 |
45 |
46 | Book this 47 |
48 |
49 |
50 |
-------------------------------------------------------------------------------- /public/hotel/app/payment/pay.html: -------------------------------------------------------------------------------- 1 |
2 |

Pay reservation number {{res_id}}

3 |
4 | 5 | 6 |
7 |
8 |
9 |
10 |
11 |
12 | 13 | 14 |
15 |
16 |
17 | 18 | 19 |
20 |
21 |
22 |
23 | 24 | 25 |
26 |
27 | 28 | 29 |
30 |
31 |
32 |
33 | 34 |
35 |
36 |
37 |
38 |
39 |
40 |
41 |
42 |
43 |

{{message}}

44 |
45 |
46 |
-------------------------------------------------------------------------------- /app/Http/Controllers/ReservationController.php: -------------------------------------------------------------------------------- 1 | toDateString(); 27 | $end_dt= Carbon::createFromFormat('d-m-Y', $request['end_dt'])->toDateString(); 28 | 29 | $customer = Customer::firstOrCreate($request['customer']); 30 | 31 | $reservation = Reservation::create(); 32 | $reservation->total_price=$room_info['total_price']; 33 | $reservation->occupancy=$request['occupancy']; 34 | $reservation->customer_id=$customer->id; 35 | $reservation->checkin=$start_dt; 36 | $reservation->checkout=$end_dt; 37 | 38 | $reservation->save(); 39 | 40 | 41 | $date=$start_dt; 42 | 43 | while (strtotime($date) < strtotime($end_dt)) { 44 | 45 | $room_calendar = RoomCalendar::where('day','=',$date) 46 | ->where('room_type_id','=',$room_info['id'])->first(); 47 | 48 | $night = ReservationNight::create(); 49 | $night->day=$date; 50 | 51 | $night->rate=$room_calendar->rate; 52 | $night->room_type_id=$room_info['id']; 53 | $night->reservation_id=$reservation->id; 54 | 55 | $room_calendar->availability--; 56 | $room_calendar->reservations++; 57 | 58 | $room_calendar->save(); 59 | $night->save(); 60 | 61 | $date = date ("Y-m-d", strtotime("+1 day", strtotime($date))); 62 | 63 | 64 | 65 | } 66 | 67 | $nights = $reservation->nights; 68 | $customer = $reservation->customer; 69 | 70 | 71 | return $reservation; 72 | 73 | } 74 | } 75 | -------------------------------------------------------------------------------- /config/cache.php: -------------------------------------------------------------------------------- 1 | env('CACHE_DRIVER', 'file'), 17 | 18 | /* 19 | |-------------------------------------------------------------------------- 20 | | Cache Stores 21 | |-------------------------------------------------------------------------- 22 | | 23 | | Here you may define all of the cache "stores" for your application as 24 | | well as their drivers. You may even define multiple stores for the 25 | | same cache driver to group types of items stored in your caches. 26 | | 27 | */ 28 | 29 | 'stores' => [ 30 | 31 | 'apc' => [ 32 | 'driver' => 'apc', 33 | ], 34 | 35 | 'array' => [ 36 | 'driver' => 'array', 37 | ], 38 | 39 | 'database' => [ 40 | 'driver' => 'database', 41 | 'table' => 'cache', 42 | 'connection' => null, 43 | ], 44 | 45 | 'file' => [ 46 | 'driver' => 'file', 47 | 'path' => storage_path('framework/cache'), 48 | ], 49 | 50 | 'memcached' => [ 51 | 'driver' => 'memcached', 52 | 'servers' => [ 53 | [ 54 | 'host' => '127.0.0.1', 'port' => 11211, 'weight' => 100, 55 | ], 56 | ], 57 | ], 58 | 59 | 'redis' => [ 60 | 'driver' => 'redis', 61 | 'connection' => 'default', 62 | ], 63 | 64 | ], 65 | 66 | /* 67 | |-------------------------------------------------------------------------- 68 | | Cache Key Prefix 69 | |-------------------------------------------------------------------------- 70 | | 71 | | When utilizing a RAM based store such as APC or Memcached, there might 72 | | be other applications utilizing the same cache. So, we'll specify a 73 | | value to get prefixed to all our keys so we can avoid collisions. 74 | | 75 | */ 76 | 77 | 'prefix' => 'laravel', 78 | 79 | ]; 80 | -------------------------------------------------------------------------------- /config/auth.php: -------------------------------------------------------------------------------- 1 | 'eloquent', 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | Authentication Model 23 | |-------------------------------------------------------------------------- 24 | | 25 | | When using the "Eloquent" authentication driver, we need to know which 26 | | Eloquent model should be used to retrieve your users. Of course, it 27 | | is often just the "User" model but you may use whatever you like. 28 | | 29 | */ 30 | 31 | 'model' => App\User::class, 32 | 33 | /* 34 | |-------------------------------------------------------------------------- 35 | | Authentication Table 36 | |-------------------------------------------------------------------------- 37 | | 38 | | When using the "Database" authentication driver, we need to know which 39 | | table should be used to retrieve your users. We have chosen a basic 40 | | default value but you may easily change it to any table you like. 41 | | 42 | */ 43 | 44 | 'table' => 'users', 45 | 46 | /* 47 | |-------------------------------------------------------------------------- 48 | | Password Reset Settings 49 | |-------------------------------------------------------------------------- 50 | | 51 | | Here you may set the options for resetting passwords including the view 52 | | that is your password reset e-mail. You can also set the name of the 53 | | table that maintains all of the reset tokens for your application. 54 | | 55 | | The expire time is the number of minutes that the reset token should be 56 | | considered valid. This security feature keeps tokens short-lived so 57 | | they have less time to be guessed. You may change this as needed. 58 | | 59 | */ 60 | 61 | 'password' => [ 62 | 'email' => 'emails.password', 63 | 'table' => 'password_resets', 64 | 'expire' => 60, 65 | ], 66 | 67 | ]; 68 | -------------------------------------------------------------------------------- /app/Http/Controllers/RoomCalendarController.php: -------------------------------------------------------------------------------- 1 | $room_type, 'day'=>$date)); 29 | 30 | if(!$room_day->id){ 31 | $room_day->availability = $base_room->base_availability; 32 | } 33 | 34 | $room_day->rate = $price; 35 | $room_day->save(); 36 | $date = date ("Y-m-d", strtotime("+1 day", strtotime($date))); 37 | $i++; 38 | } 39 | 40 | return response("Success updated ".$i." dates",200); 41 | } 42 | 43 | 44 | public function searchAvailability(Request $request){ 45 | 46 | 47 | $start_dt = Carbon::createFromFormat('d-m-Y', $request['start_dt'])->toDateTimeString(); 48 | $end_dt = Carbon::createFromFormat('d-m-Y', $request['end_dt'])->toDateTimeString(); 49 | 50 | $min_occupancy = $request['min_occupancy']; 51 | 52 | $room_types = RoomType::where('max_occupancy','>=',$min_occupancy)->get(); 53 | 54 | $available_room_types=array(); 55 | 56 | foreach( $room_types as $room_type){ 57 | 58 | $count = RoomCalendar::where('day','>=',$start_dt) 59 | ->where('day','<',$end_dt) 60 | ->where('room_type_id','=',$room_type->id) 61 | ->where('availability','<=',0)->count(); 62 | 63 | 64 | if($count==0){ 65 | 66 | $total_price = RoomCalendar::where('day','>=',$start_dt) 67 | ->where('day','<',$end_dt) 68 | ->where('room_type_id','=',$room_type->id) 69 | ->sum('rate'); 70 | 71 | $room_type->total_price = $total_price; 72 | 73 | 74 | array_push($available_room_types,$room_type); 75 | } 76 | 77 | } 78 | 79 | return $available_room_types; 80 | } 81 | } 82 | -------------------------------------------------------------------------------- /public/hotel/app/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | My AngularJS App 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 33 | 34 |
35 | 36 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | -------------------------------------------------------------------------------- /config/filesystems.php: -------------------------------------------------------------------------------- 1 | 'local', 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | Default Cloud Filesystem Disk 23 | |-------------------------------------------------------------------------- 24 | | 25 | | Many applications store files both locally and in the cloud. For this 26 | | reason, you may specify a default "cloud" driver here. This driver 27 | | will be bound as the Cloud disk implementation in the container. 28 | | 29 | */ 30 | 31 | 'cloud' => 's3', 32 | 33 | /* 34 | |-------------------------------------------------------------------------- 35 | | Filesystem Disks 36 | |-------------------------------------------------------------------------- 37 | | 38 | | Here you may configure as many filesystem "disks" as you wish, and you 39 | | may even configure multiple disks of the same driver. Defaults have 40 | | been setup for each driver as an example of the required options. 41 | | 42 | */ 43 | 44 | 'disks' => [ 45 | 46 | 'local' => [ 47 | 'driver' => 'local', 48 | 'root' => storage_path('app'), 49 | ], 50 | 51 | 'ftp' => [ 52 | 'driver' => 'ftp', 53 | 'host' => 'ftp.example.com', 54 | 'username' => 'your-username', 55 | 'password' => 'your-password', 56 | 57 | // Optional FTP Settings... 58 | // 'port' => 21, 59 | // 'root' => '', 60 | // 'passive' => true, 61 | // 'ssl' => true, 62 | // 'timeout' => 30, 63 | ], 64 | 65 | 's3' => [ 66 | 'driver' => 's3', 67 | 'key' => 'your-key', 68 | 'secret' => 'your-secret', 69 | 'region' => 'your-region', 70 | 'bucket' => 'your-bucket', 71 | ], 72 | 73 | 'rackspace' => [ 74 | 'driver' => 'rackspace', 75 | 'username' => 'your-username', 76 | 'key' => 'your-key', 77 | 'container' => 'your-container', 78 | 'endpoint' => 'https://identity.api.rackspacecloud.com/v2.0/', 79 | 'region' => 'IAD', 80 | 'url_type' => 'publicURL', 81 | ], 82 | 83 | ], 84 | 85 | ]; 86 | -------------------------------------------------------------------------------- /public/hotel/app/book/finalize.html: -------------------------------------------------------------------------------- 1 | 2 |
3 |
4 |
5 |
6 | Booking recap 7 |

Check-in : {{start_dt}}

8 |

Check-out : {{end_dt}}

9 |

Passenger : {{occupancy}}

10 |

Room : {{room_info.name}}

11 |

Total price : {{room_info.total_price}}

12 |
13 |
14 |
15 |
16 |
17 |
18 |

Customer info

19 |
20 |
21 | 22 | 23 |
24 |
25 | 26 | 27 |
28 |
29 |
30 |
31 | 32 | 33 |
34 |
35 | 36 |
37 |
38 |
39 |
40 | 41 |
42 |
43 |
44 |
45 |

Reservation

46 |

Customer info

47 |

Name : {{reservation_info.customer.first_name}}

48 |

Last name : {{reservation_info.customer.last_name}}

49 |

Email : {{reservation_info.customer.email}}

50 |

Reservation info

51 |

Check-in : {{reservation_info.checkin}}

52 |

Check-out : {{reservation_info.checkout}}

53 |

Adults : {{reservation_info.occupancy}}

54 |

Total Price : {{reservation_info.total_price}}

55 |

Nights info

56 |

57 | Day {{night.day}} - Rate : {{night.rate}} 58 |

59 | 60 |
61 |
62 |
63 |
64 | 65 | -------------------------------------------------------------------------------- /config/queue.php: -------------------------------------------------------------------------------- 1 | env('QUEUE_DRIVER', 'sync'), 20 | 21 | /* 22 | |-------------------------------------------------------------------------- 23 | | Queue Connections 24 | |-------------------------------------------------------------------------- 25 | | 26 | | Here you may configure the connection information for each server that 27 | | is used by your application. A default configuration has been added 28 | | for each back-end shipped with Laravel. You are free to add more. 29 | | 30 | */ 31 | 32 | 'connections' => [ 33 | 34 | 'sync' => [ 35 | 'driver' => 'sync', 36 | ], 37 | 38 | 'database' => [ 39 | 'driver' => 'database', 40 | 'table' => 'jobs', 41 | 'queue' => 'default', 42 | 'expire' => 60, 43 | ], 44 | 45 | 'beanstalkd' => [ 46 | 'driver' => 'beanstalkd', 47 | 'host' => 'localhost', 48 | 'queue' => 'default', 49 | 'ttr' => 60, 50 | ], 51 | 52 | 'sqs' => [ 53 | 'driver' => 'sqs', 54 | 'key' => 'your-public-key', 55 | 'secret' => 'your-secret-key', 56 | 'queue' => 'your-queue-url', 57 | 'region' => 'us-east-1', 58 | ], 59 | 60 | 'iron' => [ 61 | 'driver' => 'iron', 62 | 'host' => 'mq-aws-us-east-1.iron.io', 63 | 'token' => 'your-token', 64 | 'project' => 'your-project-id', 65 | 'queue' => 'your-queue-name', 66 | 'encrypt' => true, 67 | ], 68 | 69 | 'redis' => [ 70 | 'driver' => 'redis', 71 | 'connection' => 'default', 72 | 'queue' => 'default', 73 | 'expire' => 60, 74 | ], 75 | 76 | ], 77 | 78 | /* 79 | |-------------------------------------------------------------------------- 80 | | Failed Queue Jobs 81 | |-------------------------------------------------------------------------- 82 | | 83 | | These options configure the behavior of failed queue job logging so you 84 | | can control which database and table are used to store the jobs that 85 | | have failed. You may change them to any database / table you wish. 86 | | 87 | */ 88 | 89 | 'failed' => [ 90 | 'database' => 'mysql', 'table' => 'failed_jobs', 91 | ], 92 | 93 | ]; 94 | -------------------------------------------------------------------------------- /public/hotel/app/index-async.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 12 | 13 | 44 | My AngularJS App 45 | 46 | 47 | 48 | 52 | 53 |
54 | 55 |
Angular seed app: v
56 | 57 | 58 | 59 | -------------------------------------------------------------------------------- /public/hotel/app/room_admin/room_admin.html: -------------------------------------------------------------------------------- 1 |
2 |

Room admin

3 |
4 |
5 |
6 |
7 |
Create new room Type
8 |
9 |
10 | 11 | 12 |
13 |
14 | 15 | 16 |
17 |
18 |
19 |
20 | 21 | 22 |
23 |
24 | 25 | 26 |
27 |
28 |
29 |
30 | 31 | 32 |
33 |
34 | 35 |
36 |
37 | 38 |
39 |
40 |
Set price for room Types
41 |
42 | {{room_type.name}} 43 |
44 |
45 | Set price for {{ selected_type.name}} 46 |
47 | 48 | 49 |
50 |
51 | 52 | 53 |
54 |
55 | 56 | 57 |
58 | 59 |
60 |
61 |
62 | {{message}} 63 |
64 |
65 |
66 |
67 |
68 | -------------------------------------------------------------------------------- /config/database.php: -------------------------------------------------------------------------------- 1 | PDO::FETCH_CLASS, 17 | 18 | /* 19 | |-------------------------------------------------------------------------- 20 | | Default Database Connection Name 21 | |-------------------------------------------------------------------------- 22 | | 23 | | Here you may specify which of the database connections below you wish 24 | | to use as your default connection for all database work. Of course 25 | | you may use many connections at once using the Database library. 26 | | 27 | */ 28 | 29 | 'default' => env('DB_CONNECTION', 'mysql'), 30 | 31 | /* 32 | |-------------------------------------------------------------------------- 33 | | Database Connections 34 | |-------------------------------------------------------------------------- 35 | | 36 | | Here are each of the database connections setup for your application. 37 | | Of course, examples of configuring each database platform that is 38 | | supported by Laravel is shown below to make development simple. 39 | | 40 | | 41 | | All database work in Laravel is done through the PHP PDO facilities 42 | | so make sure you have the driver for your particular database of 43 | | choice installed on your machine before you begin development. 44 | | 45 | */ 46 | 47 | 'connections' => [ 48 | 49 | 'sqlite' => [ 50 | 'driver' => 'sqlite', 51 | 'database' => storage_path('database.sqlite'), 52 | 'prefix' => '', 53 | ], 54 | 55 | 'mysql' => [ 56 | 'driver' => 'mysql', 57 | 'host' => env('DB_HOST', 'localhost'), 58 | 'database' => env('DB_DATABASE', 'forge'), 59 | 'username' => env('DB_USERNAME', 'forge'), 60 | 'password' => env('DB_PASSWORD', ''), 61 | 'unix_socket' => '/Applications/MAMP/tmp/mysql/mysql.sock', 62 | 'charset' => 'utf8', 63 | 'collation' => 'utf8_unicode_ci', 64 | 'prefix' => '', 65 | 'strict' => false, 66 | ], 67 | 68 | 'pgsql' => [ 69 | 'driver' => 'pgsql', 70 | 'host' => env('DB_HOST', 'localhost'), 71 | 'database' => env('DB_DATABASE', 'forge'), 72 | 'username' => env('DB_USERNAME', 'forge'), 73 | 'password' => env('DB_PASSWORD', ''), 74 | 'charset' => 'utf8', 75 | 'prefix' => '', 76 | 'schema' => 'public', 77 | ], 78 | 79 | 'sqlsrv' => [ 80 | 'driver' => 'sqlsrv', 81 | 'host' => env('DB_HOST', 'localhost'), 82 | 'database' => env('DB_DATABASE', 'forge'), 83 | 'username' => env('DB_USERNAME', 'forge'), 84 | 'password' => env('DB_PASSWORD', ''), 85 | 'charset' => 'utf8', 86 | 'prefix' => '', 87 | ], 88 | 89 | ], 90 | 91 | /* 92 | |-------------------------------------------------------------------------- 93 | | Migration Repository Table 94 | |-------------------------------------------------------------------------- 95 | | 96 | | This table keeps track of all the migrations that have already run for 97 | | your application. Using this information, we can determine which of 98 | | the migrations on disk haven't actually been run in the database. 99 | | 100 | */ 101 | 102 | 'migrations' => 'migrations', 103 | 104 | /* 105 | |-------------------------------------------------------------------------- 106 | | Redis Databases 107 | |-------------------------------------------------------------------------- 108 | | 109 | | Redis is an open source, fast, and advanced key-value store that also 110 | | provides a richer set of commands than a typical key-value systems 111 | | such as APC or Memcached. Laravel makes it easy to dig right in. 112 | | 113 | */ 114 | 115 | 'redis' => [ 116 | 117 | 'cluster' => false, 118 | 119 | 'default' => [ 120 | 'host' => '127.0.0.1', 121 | 'port' => 6379, 122 | 'database' => 0, 123 | ], 124 | 125 | ], 126 | 127 | ]; 128 | -------------------------------------------------------------------------------- /config/mail.php: -------------------------------------------------------------------------------- 1 | env('MAIL_DRIVER', 'smtp'), 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | SMTP Host Address 23 | |-------------------------------------------------------------------------- 24 | | 25 | | Here you may provide the host address of the SMTP server used by your 26 | | applications. A default option is provided that is compatible with 27 | | the Mailgun mail service which will provide reliable deliveries. 28 | | 29 | */ 30 | 31 | 'host' => env('MAIL_HOST', 'smtp.mailgun.org'), 32 | 33 | /* 34 | |-------------------------------------------------------------------------- 35 | | SMTP Host Port 36 | |-------------------------------------------------------------------------- 37 | | 38 | | This is the SMTP port used by your application to deliver e-mails to 39 | | users of the application. Like the host we have set this value to 40 | | stay compatible with the Mailgun e-mail application by default. 41 | | 42 | */ 43 | 44 | 'port' => env('MAIL_PORT', 587), 45 | 46 | /* 47 | |-------------------------------------------------------------------------- 48 | | Global "From" Address 49 | |-------------------------------------------------------------------------- 50 | | 51 | | You may wish for all e-mails sent by your application to be sent from 52 | | the same address. Here, you may specify a name and address that is 53 | | used globally for all e-mails that are sent by your application. 54 | | 55 | */ 56 | 57 | 'from' => ['address' => null, 'name' => null], 58 | 59 | /* 60 | |-------------------------------------------------------------------------- 61 | | E-Mail Encryption Protocol 62 | |-------------------------------------------------------------------------- 63 | | 64 | | Here you may specify the encryption protocol that should be used when 65 | | the application send e-mail messages. A sensible default using the 66 | | transport layer security protocol should provide great security. 67 | | 68 | */ 69 | 70 | 'encryption' => env('MAIL_ENCRYPTION', 'tls'), 71 | 72 | /* 73 | |-------------------------------------------------------------------------- 74 | | SMTP Server Username 75 | |-------------------------------------------------------------------------- 76 | | 77 | | If your SMTP server requires a username for authentication, you should 78 | | set it here. This will get used to authenticate with your server on 79 | | connection. You may also set the "password" value below this one. 80 | | 81 | */ 82 | 83 | 'username' => env('MAIL_USERNAME'), 84 | 85 | /* 86 | |-------------------------------------------------------------------------- 87 | | SMTP Server Password 88 | |-------------------------------------------------------------------------- 89 | | 90 | | Here you may set the password required by your SMTP server to send out 91 | | messages from your application. This will be given to the server on 92 | | connection so that the application will be able to send messages. 93 | | 94 | */ 95 | 96 | 'password' => env('MAIL_PASSWORD'), 97 | 98 | /* 99 | |-------------------------------------------------------------------------- 100 | | Sendmail System Path 101 | |-------------------------------------------------------------------------- 102 | | 103 | | When using the "sendmail" driver to send e-mails, we will need to know 104 | | the path to where Sendmail lives on this server. A default path has 105 | | been provided here, which will work well on most of your systems. 106 | | 107 | */ 108 | 109 | 'sendmail' => '/usr/sbin/sendmail -bs', 110 | 111 | /* 112 | |-------------------------------------------------------------------------- 113 | | Mail "Pretend" 114 | |-------------------------------------------------------------------------- 115 | | 116 | | When this option is enabled, e-mail will not actually be sent over the 117 | | web and will instead be written to your application's logs files so 118 | | you may inspect the message. This is great for local development. 119 | | 120 | */ 121 | 122 | 'pretend' => false, 123 | 124 | ]; 125 | -------------------------------------------------------------------------------- /config/session.php: -------------------------------------------------------------------------------- 1 | env('SESSION_DRIVER', 'file'), 20 | 21 | /* 22 | |-------------------------------------------------------------------------- 23 | | Session Lifetime 24 | |-------------------------------------------------------------------------- 25 | | 26 | | Here you may specify the number of minutes that you wish the session 27 | | to be allowed to remain idle before it expires. If you want them 28 | | to immediately expire on the browser closing, set that option. 29 | | 30 | */ 31 | 32 | 'lifetime' => 120, 33 | 34 | 'expire_on_close' => false, 35 | 36 | /* 37 | |-------------------------------------------------------------------------- 38 | | Session Encryption 39 | |-------------------------------------------------------------------------- 40 | | 41 | | This option allows you to easily specify that all of your session data 42 | | should be encrypted before it is stored. All encryption will be run 43 | | automatically by Laravel and you can use the Session like normal. 44 | | 45 | */ 46 | 47 | 'encrypt' => false, 48 | 49 | /* 50 | |-------------------------------------------------------------------------- 51 | | Session File Location 52 | |-------------------------------------------------------------------------- 53 | | 54 | | When using the native session driver, we need a location where session 55 | | files may be stored. A default has been set for you but a different 56 | | location may be specified. This is only needed for file sessions. 57 | | 58 | */ 59 | 60 | 'files' => storage_path('framework/sessions'), 61 | 62 | /* 63 | |-------------------------------------------------------------------------- 64 | | Session Database Connection 65 | |-------------------------------------------------------------------------- 66 | | 67 | | When using the "database" or "redis" session drivers, you may specify a 68 | | connection that should be used to manage these sessions. This should 69 | | correspond to a connection in your database configuration options. 70 | | 71 | */ 72 | 73 | 'connection' => null, 74 | 75 | /* 76 | |-------------------------------------------------------------------------- 77 | | Session Database Table 78 | |-------------------------------------------------------------------------- 79 | | 80 | | When using the "database" session driver, you may specify the table we 81 | | should use to manage the sessions. Of course, a sensible default is 82 | | provided for you; however, you are free to change this as needed. 83 | | 84 | */ 85 | 86 | 'table' => 'sessions', 87 | 88 | /* 89 | |-------------------------------------------------------------------------- 90 | | Session Sweeping Lottery 91 | |-------------------------------------------------------------------------- 92 | | 93 | | Some session drivers must manually sweep their storage location to get 94 | | rid of old sessions from storage. Here are the chances that it will 95 | | happen on a given request. By default, the odds are 2 out of 100. 96 | | 97 | */ 98 | 99 | 'lottery' => [2, 100], 100 | 101 | /* 102 | |-------------------------------------------------------------------------- 103 | | Session Cookie Name 104 | |-------------------------------------------------------------------------- 105 | | 106 | | Here you may change the name of the cookie used to identify a session 107 | | instance by ID. The name specified here will get used every time a 108 | | new session cookie is created by the framework for every driver. 109 | | 110 | */ 111 | 112 | 'cookie' => 'laravel_session', 113 | 114 | /* 115 | |-------------------------------------------------------------------------- 116 | | Session Cookie Path 117 | |-------------------------------------------------------------------------- 118 | | 119 | | The session cookie path determines the path for which the cookie will 120 | | be regarded as available. Typically, this will be the root path of 121 | | your application but you are free to change this when necessary. 122 | | 123 | */ 124 | 125 | 'path' => '/', 126 | 127 | /* 128 | |-------------------------------------------------------------------------- 129 | | Session Cookie Domain 130 | |-------------------------------------------------------------------------- 131 | | 132 | | Here you may change the domain of the cookie used to identify a session 133 | | in your application. This will determine which domains the cookie is 134 | | available to in your application. A sensible default has been set. 135 | | 136 | */ 137 | 138 | 'domain' => null, 139 | 140 | /* 141 | |-------------------------------------------------------------------------- 142 | | HTTPS Only Cookies 143 | |-------------------------------------------------------------------------- 144 | | 145 | | By setting this option to true, session cookies will only be sent back 146 | | to the server if the browser has a HTTPS connection. This will keep 147 | | the cookie from being sent to you if it can not be done securely. 148 | | 149 | */ 150 | 151 | 'secure' => false, 152 | 153 | ]; 154 | -------------------------------------------------------------------------------- /resources/lang/en/validation.php: -------------------------------------------------------------------------------- 1 | 'The :attribute must be accepted.', 17 | 'active_url' => 'The :attribute is not a valid URL.', 18 | 'after' => 'The :attribute must be a date after :date.', 19 | 'alpha' => 'The :attribute may only contain letters.', 20 | 'alpha_dash' => 'The :attribute may only contain letters, numbers, and dashes.', 21 | 'alpha_num' => 'The :attribute may only contain letters and numbers.', 22 | 'array' => 'The :attribute must be an array.', 23 | 'before' => 'The :attribute must be a date before :date.', 24 | 'between' => [ 25 | 'numeric' => 'The :attribute must be between :min and :max.', 26 | 'file' => 'The :attribute must be between :min and :max kilobytes.', 27 | 'string' => 'The :attribute must be between :min and :max characters.', 28 | 'array' => 'The :attribute must have between :min and :max items.', 29 | ], 30 | 'boolean' => 'The :attribute field must be true or false.', 31 | 'confirmed' => 'The :attribute confirmation does not match.', 32 | 'date' => 'The :attribute is not a valid date.', 33 | 'date_format' => 'The :attribute does not match the format :format.', 34 | 'different' => 'The :attribute and :other must be different.', 35 | 'digits' => 'The :attribute must be :digits digits.', 36 | 'digits_between' => 'The :attribute must be between :min and :max digits.', 37 | 'email' => 'The :attribute must be a valid email address.', 38 | 'filled' => 'The :attribute field is required.', 39 | 'exists' => 'The selected :attribute is invalid.', 40 | 'image' => 'The :attribute must be an image.', 41 | 'in' => 'The selected :attribute is invalid.', 42 | 'integer' => 'The :attribute must be an integer.', 43 | 'ip' => 'The :attribute must be a valid IP address.', 44 | 'max' => [ 45 | 'numeric' => 'The :attribute may not be greater than :max.', 46 | 'file' => 'The :attribute may not be greater than :max kilobytes.', 47 | 'string' => 'The :attribute may not be greater than :max characters.', 48 | 'array' => 'The :attribute may not have more than :max items.', 49 | ], 50 | 'mimes' => 'The :attribute must be a file of type: :values.', 51 | 'min' => [ 52 | 'numeric' => 'The :attribute must be at least :min.', 53 | 'file' => 'The :attribute must be at least :min kilobytes.', 54 | 'string' => 'The :attribute must be at least :min characters.', 55 | 'array' => 'The :attribute must have at least :min items.', 56 | ], 57 | 'not_in' => 'The selected :attribute is invalid.', 58 | 'numeric' => 'The :attribute must be a number.', 59 | 'regex' => 'The :attribute format is invalid.', 60 | 'required' => 'The :attribute field is required.', 61 | 'required_if' => 'The :attribute field is required when :other is :value.', 62 | 'required_with' => 'The :attribute field is required when :values is present.', 63 | 'required_with_all' => 'The :attribute field is required when :values is present.', 64 | 'required_without' => 'The :attribute field is required when :values is not present.', 65 | 'required_without_all' => 'The :attribute field is required when none of :values are present.', 66 | 'same' => 'The :attribute and :other must match.', 67 | 'size' => [ 68 | 'numeric' => 'The :attribute must be :size.', 69 | 'file' => 'The :attribute must be :size kilobytes.', 70 | 'string' => 'The :attribute must be :size characters.', 71 | 'array' => 'The :attribute must contain :size items.', 72 | ], 73 | 'string' => 'The :attribute must be a string.', 74 | 'timezone' => 'The :attribute must be a valid zone.', 75 | 'unique' => 'The :attribute has already been taken.', 76 | 'url' => 'The :attribute format is invalid.', 77 | 78 | /* 79 | |-------------------------------------------------------------------------- 80 | | Custom Validation Language Lines 81 | |-------------------------------------------------------------------------- 82 | | 83 | | Here you may specify custom validation messages for attributes using the 84 | | convention "attribute.rule" to name the lines. This makes it quick to 85 | | specify a specific custom language line for a given attribute rule. 86 | | 87 | */ 88 | 89 | 'custom' => [ 90 | 'attribute-name' => [ 91 | 'rule-name' => 'custom-message', 92 | ], 93 | ], 94 | 95 | /* 96 | |-------------------------------------------------------------------------- 97 | | Custom Validation Attributes 98 | |-------------------------------------------------------------------------- 99 | | 100 | | The following language lines are used to swap attribute place-holders 101 | | with something more reader friendly such as E-Mail Address instead 102 | | of "email". This simply helps us make messages a little cleaner. 103 | | 104 | */ 105 | 106 | 'attributes' => [], 107 | 108 | ]; 109 | -------------------------------------------------------------------------------- /config/app.php: -------------------------------------------------------------------------------- 1 | env('APP_DEBUG', false), 17 | 18 | /* 19 | |-------------------------------------------------------------------------- 20 | | Application URL 21 | |-------------------------------------------------------------------------- 22 | | 23 | | This URL is used by the console to properly generate URLs when using 24 | | the Artisan command line tool. You should set this to the root of 25 | | your application so that it is used when running Artisan tasks. 26 | | 27 | */ 28 | 29 | 'url' => 'http://localhost', 30 | 31 | /* 32 | |-------------------------------------------------------------------------- 33 | | Application Timezone 34 | |-------------------------------------------------------------------------- 35 | | 36 | | Here you may specify the default timezone for your application, which 37 | | will be used by the PHP date and date-time functions. We have gone 38 | | ahead and set this to a sensible default for you out of the box. 39 | | 40 | */ 41 | 42 | 'timezone' => 'UTC', 43 | 44 | /* 45 | |-------------------------------------------------------------------------- 46 | | Application Locale Configuration 47 | |-------------------------------------------------------------------------- 48 | | 49 | | The application locale determines the default locale that will be used 50 | | by the translation service provider. You are free to set this value 51 | | to any of the locales which will be supported by the application. 52 | | 53 | */ 54 | 55 | 'locale' => 'en', 56 | 57 | /* 58 | |-------------------------------------------------------------------------- 59 | | Application Fallback Locale 60 | |-------------------------------------------------------------------------- 61 | | 62 | | The fallback locale determines the locale to use when the current one 63 | | is not available. You may change the value to correspond to any of 64 | | the language folders that are provided through your application. 65 | | 66 | */ 67 | 68 | 'fallback_locale' => 'en', 69 | 70 | /* 71 | |-------------------------------------------------------------------------- 72 | | Encryption Key 73 | |-------------------------------------------------------------------------- 74 | | 75 | | This key is used by the Illuminate encrypter service and should be set 76 | | to a random, 32 character string, otherwise these encrypted strings 77 | | will not be safe. Please do this before deploying an application! 78 | | 79 | */ 80 | 81 | 'key' => env('APP_KEY', 'SomeRandomString'), 82 | 83 | 'cipher' => 'AES-256-CBC', 84 | 85 | /* 86 | |-------------------------------------------------------------------------- 87 | | Logging Configuration 88 | |-------------------------------------------------------------------------- 89 | | 90 | | Here you may configure the log settings for your application. Out of 91 | | the box, Laravel uses the Monolog PHP logging library. This gives 92 | | you a variety of powerful log handlers / formatters to utilize. 93 | | 94 | | Available Settings: "single", "daily", "syslog", "errorlog" 95 | | 96 | */ 97 | 98 | 'log' => 'single', 99 | 100 | /* 101 | |-------------------------------------------------------------------------- 102 | | Autoloaded Service Providers 103 | |-------------------------------------------------------------------------- 104 | | 105 | | The service providers listed here will be automatically loaded on the 106 | | request to your application. Feel free to add your own services to 107 | | this array to grant expanded functionality to your applications. 108 | | 109 | */ 110 | 111 | 'providers' => [ 112 | 113 | /* 114 | * Laravel Framework Service Providers... 115 | */ 116 | Illuminate\Foundation\Providers\ArtisanServiceProvider::class, 117 | Illuminate\Auth\AuthServiceProvider::class, 118 | Illuminate\Broadcasting\BroadcastServiceProvider::class, 119 | Illuminate\Bus\BusServiceProvider::class, 120 | Illuminate\Cache\CacheServiceProvider::class, 121 | Illuminate\Foundation\Providers\ConsoleSupportServiceProvider::class, 122 | Illuminate\Routing\ControllerServiceProvider::class, 123 | Illuminate\Cookie\CookieServiceProvider::class, 124 | Illuminate\Database\DatabaseServiceProvider::class, 125 | Illuminate\Encryption\EncryptionServiceProvider::class, 126 | Illuminate\Filesystem\FilesystemServiceProvider::class, 127 | Illuminate\Foundation\Providers\FoundationServiceProvider::class, 128 | Illuminate\Hashing\HashServiceProvider::class, 129 | Illuminate\Mail\MailServiceProvider::class, 130 | Illuminate\Pagination\PaginationServiceProvider::class, 131 | Illuminate\Pipeline\PipelineServiceProvider::class, 132 | Illuminate\Queue\QueueServiceProvider::class, 133 | Illuminate\Redis\RedisServiceProvider::class, 134 | Illuminate\Auth\Passwords\PasswordResetServiceProvider::class, 135 | Illuminate\Session\SessionServiceProvider::class, 136 | Illuminate\Translation\TranslationServiceProvider::class, 137 | Illuminate\Validation\ValidationServiceProvider::class, 138 | Illuminate\View\ViewServiceProvider::class, 139 | /* 140 | * Application Service Providers... 141 | */ 142 | App\Providers\AppServiceProvider::class, 143 | App\Providers\EventServiceProvider::class, 144 | App\Providers\RouteServiceProvider::class, 145 | ], 146 | 147 | /* 148 | |-------------------------------------------------------------------------- 149 | | Class Aliases 150 | |-------------------------------------------------------------------------- 151 | | 152 | | This array of class aliases will be registered when this application 153 | | is started. However, feel free to register as many as you wish as 154 | | the aliases are "lazy" loaded so they don't hinder performance. 155 | | 156 | */ 157 | 158 | 'aliases' => [ 159 | 160 | 'App' => Illuminate\Support\Facades\App::class, 161 | 'Artisan' => Illuminate\Support\Facades\Artisan::class, 162 | 'Auth' => Illuminate\Support\Facades\Auth::class, 163 | 'Blade' => Illuminate\Support\Facades\Blade::class, 164 | 'Bus' => Illuminate\Support\Facades\Bus::class, 165 | 'Cache' => Illuminate\Support\Facades\Cache::class, 166 | 'Config' => Illuminate\Support\Facades\Config::class, 167 | 'Cookie' => Illuminate\Support\Facades\Cookie::class, 168 | 'Crypt' => Illuminate\Support\Facades\Crypt::class, 169 | 'DB' => Illuminate\Support\Facades\DB::class, 170 | 'Eloquent' => Illuminate\Database\Eloquent\Model::class, 171 | 'Event' => Illuminate\Support\Facades\Event::class, 172 | 'File' => Illuminate\Support\Facades\File::class, 173 | 'Hash' => Illuminate\Support\Facades\Hash::class, 174 | 'Input' => Illuminate\Support\Facades\Input::class, 175 | 'Inspiring' => Illuminate\Foundation\Inspiring::class, 176 | 'Lang' => Illuminate\Support\Facades\Lang::class, 177 | 'Log' => Illuminate\Support\Facades\Log::class, 178 | 'Mail' => Illuminate\Support\Facades\Mail::class, 179 | 'Password' => Illuminate\Support\Facades\Password::class, 180 | 'Queue' => Illuminate\Support\Facades\Queue::class, 181 | 'Redirect' => Illuminate\Support\Facades\Redirect::class, 182 | 'Redis' => Illuminate\Support\Facades\Redis::class, 183 | 'Request' => Illuminate\Support\Facades\Request::class, 184 | 'Response' => Illuminate\Support\Facades\Response::class, 185 | 'Route' => Illuminate\Support\Facades\Route::class, 186 | 'Schema' => Illuminate\Support\Facades\Schema::class, 187 | 'Session' => Illuminate\Support\Facades\Session::class, 188 | 'Storage' => Illuminate\Support\Facades\Storage::class, 189 | 'URL' => Illuminate\Support\Facades\URL::class, 190 | 'Validator' => Illuminate\Support\Facades\Validator::class, 191 | 'View' => Illuminate\Support\Facades\View::class, 192 | 193 | ], 194 | 195 | ]; 196 | -------------------------------------------------------------------------------- /public/hotel/README.md: -------------------------------------------------------------------------------- 1 | # angular-seed — the seed for AngularJS apps 2 | 3 | This project is an application skeleton for a typical [AngularJS](http://angularjs.org/) web app. 4 | You can use it to quickly bootstrap your angular webapp projects and dev environment for these 5 | projects. 6 | 7 | The seed contains a sample AngularJS application and is preconfigured to install the Angular 8 | framework and a bunch of development and testing tools for instant web development gratification. 9 | 10 | The seed app doesn't do much, just shows how to wire two controllers and views together. 11 | 12 | 13 | ## Getting Started 14 | 15 | To get you started you can simply clone the angular-seed repository and install the dependencies: 16 | 17 | ### Prerequisites 18 | 19 | You need git to clone the angular-seed repository. You can get git from 20 | [http://git-scm.com/](http://git-scm.com/). 21 | 22 | We also use a number of node.js tools to initialize and test angular-seed. You must have node.js and 23 | its package manager (npm) installed. You can get them from [http://nodejs.org/](http://nodejs.org/). 24 | 25 | ### Clone angular-seed 26 | 27 | Clone the angular-seed repository using [git][git]: 28 | 29 | ``` 30 | git clone https://github.com/angular/angular-seed.git 31 | cd angular-seed 32 | ``` 33 | 34 | If you just want to start a new project without the angular-seed commit history then you can do: 35 | 36 | ```bash 37 | git clone --depth=1 https://github.com/angular/angular-seed.git 38 | ``` 39 | 40 | The `depth=1` tells git to only pull down one commit worth of historical data. 41 | 42 | ### Install Dependencies 43 | 44 | We have two kinds of dependencies in this project: tools and angular framework code. The tools help 45 | us manage and test the application. 46 | 47 | * We get the tools we depend upon via `npm`, the [node package manager][npm]. 48 | * We get the angular code via `bower`, a [client-side code package manager][bower]. 49 | 50 | We have preconfigured `npm` to automatically run `bower` so we can simply do: 51 | 52 | ``` 53 | npm install 54 | ``` 55 | 56 | Behind the scenes this will also call `bower install`. You should find that you have two new 57 | folders in your project. 58 | 59 | * `node_modules` - contains the npm packages for the tools we need 60 | * `app/bower_components` - contains the angular framework files 61 | 62 | *Note that the `bower_components` folder would normally be installed in the root folder but 63 | angular-seed changes this location through the `.bowerrc` file. Putting it in the app folder makes 64 | it easier to serve the files by a webserver.* 65 | 66 | ### Run the Application 67 | 68 | We have preconfigured the project with a simple development web server. The simplest way to start 69 | this server is: 70 | 71 | ``` 72 | npm start 73 | ``` 74 | 75 | Now browse to the app at `http://localhost:8000/app/index.html`. 76 | 77 | 78 | 79 | ## Directory Layout 80 | 81 | ``` 82 | app/ --> all of the source files for the application 83 | app.css --> default stylesheet 84 | components/ --> all app specific modules 85 | version/ --> version related components 86 | version.js --> version module declaration and basic "version" value service 87 | version_test.js --> "version" value service tests 88 | version-directive.js --> custom directive that returns the current app version 89 | version-directive_test.js --> version directive tests 90 | interpolate-filter.js --> custom interpolation filter 91 | interpolate-filter_test.js --> interpolate filter tests 92 | view1/ --> the view1 view template and logic 93 | view1.html --> the partial template 94 | room_admin.js --> the controller logic 95 | view1_test.js --> tests of the controller 96 | view2/ --> the view2 view template and logic 97 | view2.html --> the partial template 98 | view2.js --> the controller logic 99 | view2_test.js --> tests of the controller 100 | app.js --> main application module 101 | index.html --> app layout file (the main html template file of the app) 102 | index-async.html --> just like index.html, but loads js files asynchronously 103 | karma.conf.js --> config file for running unit tests with Karma 104 | e2e-tests/ --> end-to-end tests 105 | protractor-conf.js --> Protractor config file 106 | scenarios.js --> end-to-end scenarios to be run by Protractor 107 | ``` 108 | 109 | ## Testing 110 | 111 | There are two kinds of tests in the angular-seed application: Unit tests and End to End tests. 112 | 113 | ### Running Unit Tests 114 | 115 | The angular-seed app comes preconfigured with unit tests. These are written in 116 | [Jasmine][jasmine], which we run with the [Karma Test Runner][karma]. We provide a Karma 117 | configuration file to run them. 118 | 119 | * the configuration is found at `karma.conf.js` 120 | * the unit tests are found next to the code they are testing and are named as `..._test.js`. 121 | 122 | The easiest way to run the unit tests is to use the supplied npm script: 123 | 124 | ``` 125 | npm test 126 | ``` 127 | 128 | This script will start the Karma test runner to execute the unit tests. Moreover, Karma will sit and 129 | watch the source and test files for changes and then re-run the tests whenever any of them change. 130 | This is the recommended strategy; if your unit tests are being run every time you save a file then 131 | you receive instant feedback on any changes that break the expected code functionality. 132 | 133 | You can also ask Karma to do a single run of the tests and then exit. This is useful if you want to 134 | check that a particular version of the code is operating as expected. The project contains a 135 | predefined script to do this: 136 | 137 | ``` 138 | npm run test-single-run 139 | ``` 140 | 141 | 142 | ### End to end testing 143 | 144 | The angular-seed app comes with end-to-end tests, again written in [Jasmine][jasmine]. These tests 145 | are run with the [Protractor][protractor] End-to-End test runner. It uses native events and has 146 | special features for Angular applications. 147 | 148 | * the configuration is found at `e2e-tests/protractor-conf.js` 149 | * the end-to-end tests are found in `e2e-tests/scenarios.js` 150 | 151 | Protractor simulates interaction with our web app and verifies that the application responds 152 | correctly. Therefore, our web server needs to be serving up the application, so that Protractor 153 | can interact with it. 154 | 155 | ``` 156 | npm start 157 | ``` 158 | 159 | In addition, since Protractor is built upon WebDriver we need to install this. The angular-seed 160 | project comes with a predefined script to do this: 161 | 162 | ``` 163 | npm run update-webdriver 164 | ``` 165 | 166 | This will download and install the latest version of the stand-alone WebDriver tool. 167 | 168 | Once you have ensured that the development web server hosting our application is up and running 169 | and WebDriver is updated, you can run the end-to-end tests using the supplied npm script: 170 | 171 | ``` 172 | npm run protractor 173 | ``` 174 | 175 | This script will execute the end-to-end tests against the application being hosted on the 176 | development server. 177 | 178 | 179 | ## Updating Angular 180 | 181 | Previously we recommended that you merge in changes to angular-seed into your own fork of the project. 182 | Now that the angular framework library code and tools are acquired through package managers (npm and 183 | bower) you can use these tools instead to update the dependencies. 184 | 185 | You can update the tool dependencies by running: 186 | 187 | ``` 188 | npm update 189 | ``` 190 | 191 | This will find the latest versions that match the version ranges specified in the `package.json` file. 192 | 193 | You can update the Angular dependencies by running: 194 | 195 | ``` 196 | bower update 197 | ``` 198 | 199 | This will find the latest versions that match the version ranges specified in the `bower.json` file. 200 | 201 | 202 | ## Loading Angular Asynchronously 203 | 204 | The angular-seed project supports loading the framework and application scripts asynchronously. The 205 | special `index-async.html` is designed to support this style of loading. For it to work you must 206 | inject a piece of Angular JavaScript into the HTML page. The project has a predefined script to help 207 | do this. 208 | 209 | ``` 210 | npm run update-index-async 211 | ``` 212 | 213 | This will copy the contents of the `angular-loader.js` library file into the `index-async.html` page. 214 | You can run this every time you update the version of Angular that you are using. 215 | 216 | 217 | ## Serving the Application Files 218 | 219 | While angular is client-side-only technology and it's possible to create angular webapps that 220 | don't require a backend server at all, we recommend serving the project files using a local 221 | webserver during development to avoid issues with security restrictions (sandbox) in browsers. The 222 | sandbox implementation varies between browsers, but quite often prevents things like cookies, xhr, 223 | etc to function properly when an html page is opened via `file://` scheme instead of `http://`. 224 | 225 | 226 | ### Running the App during Development 227 | 228 | The angular-seed project comes preconfigured with a local development webserver. It is a node.js 229 | tool called [http-server][http-server]. You can start this webserver with `npm start` but you may choose to 230 | install the tool globally: 231 | 232 | ``` 233 | sudo npm install -g http-server 234 | ``` 235 | 236 | Then you can start your own development web server to serve static files from a folder by 237 | running: 238 | 239 | ``` 240 | http-server -a localhost -p 8000 241 | ``` 242 | 243 | Alternatively, you can choose to configure your own webserver, such as apache or nginx. Just 244 | configure your server to serve the files under the `app/` directory. 245 | 246 | 247 | ### Running the App in Production 248 | 249 | This really depends on how complex your app is and the overall infrastructure of your system, but 250 | the general rule is that all you need in production are all the files under the `app/` directory. 251 | Everything else should be omitted. 252 | 253 | Angular apps are really just a bunch of static html, css and js files that just need to be hosted 254 | somewhere they can be accessed by browsers. 255 | 256 | If your Angular app is talking to the backend server via xhr or other means, you need to figure 257 | out what is the best way to host the static files to comply with the same origin policy if 258 | applicable. Usually this is done by hosting the files by the backend server or through 259 | reverse-proxying the backend server(s) and webserver(s). 260 | 261 | 262 | ## Continuous Integration 263 | 264 | ### Travis CI 265 | 266 | [Travis CI][travis] is a continuous integration service, which can monitor GitHub for new commits 267 | to your repository and execute scripts such as building the app or running tests. The angular-seed 268 | project contains a Travis configuration file, `.travis.yml`, which will cause Travis to run your 269 | tests when you push to GitHub. 270 | 271 | You will need to enable the integration between Travis and GitHub. See the Travis website for more 272 | instruction on how to do this. 273 | 274 | ### CloudBees 275 | 276 | CloudBees have provided a CI/deployment setup: 277 | 278 | 279 | 280 | 281 | If you run this, you will get a cloned version of this repo to start working on in a private git repo, 282 | along with a CI service (in Jenkins) hosted that will run unit and end to end tests in both Firefox and Chrome. 283 | 284 | 285 | ## Contact 286 | 287 | For more information on AngularJS please check out http://angularjs.org/ 288 | 289 | [git]: http://git-scm.com/ 290 | [bower]: http://bower.io 291 | [npm]: https://www.npmjs.org/ 292 | [node]: http://nodejs.org 293 | [protractor]: https://github.com/angular/protractor 294 | [jasmine]: http://jasmine.github.io 295 | [karma]: http://karma-runner.github.io 296 | [travis]: https://travis-ci.org/ 297 | [http-server]: https://github.com/nodeapps/http-server 298 | -------------------------------------------------------------------------------- /public/hotel/app/app.css: -------------------------------------------------------------------------------- 1 | /* app css stylesheet */ 2 | 3 | .menu { 4 | list-style: none; 5 | border-bottom: 0.1em solid black; 6 | margin-bottom: 2em; 7 | padding: 0 0 0.5em; 8 | } 9 | 10 | .menu:before { 11 | content: "["; 12 | } 13 | 14 | .menu:after { 15 | content: "]"; 16 | } 17 | 18 | .menu > li { 19 | display: inline; 20 | } 21 | 22 | .menu > li:before { 23 | content: "|"; 24 | padding-right: 0.3em; 25 | } 26 | 27 | .menu > li:nth-child(1):before { 28 | content: ""; 29 | padding: 0; 30 | } 31 | 32 | 33 | 34 | .ng-invalid { 35 | border-color: #f00 !important; 36 | } 37 | .visa { 38 | background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gR2VuZXJhdG9yOiBBZG9iZSBJbGx1c3RyYXRvciAxNi4wLjAsIFNWRyBFeHBvcnQgUGx1Zy1JbiAuIFNWRyBWZXJzaW9uOiA2LjAwIEJ1aWxkIDApICAtLT4NCjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+DQo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB3aWR0aD0iNjU5LjA1NXB4IiBoZWlnaHQ9IjIwMi4wNjlweCIgdmlld0JveD0iMCAwIDY1OS4wNTUgMjAyLjA2OSIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNjU5LjA1NSAyMDIuMDY5Ig0KCSB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxnPg0KCQk8cG9seWdvbiBmaWxsPSIjMDAyNDlGIiBwb2ludHM9IjIzMi4xNzgsMTk5LjE2NCAyNjUuNTM5LDMuNDAyIDMxOC44OTgsMy40MDIgMjg1LjUxNCwxOTkuMTY0IAkJIi8+DQoJCTxwYXRoIGZpbGw9IiMwMDI0OUYiIGQ9Ik00NzkuMDQsOC4yMjJDNDY4LjQ2OCw0LjI1Niw0NTEuOTA0LDAsNDMxLjIxNywwYy01Mi43MjQsMC04OS44NjMsMjYuNTUyLTkwLjE4LDY0LjYwNA0KCQkJYy0wLjI5NywyOC4xMjksMjYuNTE0LDQzLjgyLDQ2Ljc1NCw1My4xODVjMjAuNzcsOS41OTUsMjcuNzUyLDE1LjcxNSwyNy42NTIsMjQuMjgzYy0wLjEzMSwxMy4xMjItMTYuNTg2LDE5LjExNy0zMS45MjIsMTkuMTE3DQoJCQljLTIxLjM1NywwLTMyLjcwMy0yLjk2Ny01MC4yMjctMTAuMjc2bC02Ljg3Ni0zLjExMWwtNy40ODksNDMuODIzYzEyLjQ2Miw1LjQ2NCwzNS41MDksMTAuMTk5LDU5LjQzOCwxMC40NDQNCgkJCWM1Ni4wODksMCw5Mi41MDEtMjYuMjQ3LDkyLjkxNS02Ni44ODJjMC4yMDEtMjIuMjctMTQuMDE2LTM5LjIxNy00NC43OTktNTMuMTg4Yy0xOC42NTEtOS4wNTYtMzAuMDczLTE1LjA5OS0yOS45NTItMjQuMjY5DQoJCQljMC04LjEzNyw5LjY2OC0xNi44MzgsMzAuNTU3LTE2LjgzOGMxNy40NDktMC4yNzEsMzAuMDg4LDMuNTM0LDM5LjkzNyw3LjVsNC43ODEsMi4yNTlMNDc5LjA0LDguMjIyIi8+DQoJCTxwYXRoIGZpbGw9IiMwMDI0OUYiIGQ9Ik02MTUuODY3LDMuNTg5aC00MS4yMzFjLTEyLjc3MiwwLTIyLjMzMSwzLjQ4Ni0yNy45NCwxNi4yMzRMNDY3LjQ1LDE5OS4yMjZoNTYuMDMxDQoJCQljMCwwLDkuMTYxLTI0LjEyMiwxMS4yMzMtMjkuNDE4YzYuMTIzLDAsNjAuNTU1LDAuMDg0LDY4LjMzNiwwLjA4NGMxLjU5Nyw2Ljg1Myw2LjQ5MiwyOS4zMzQsNi40OTIsMjkuMzM0aDQ5LjUxMkw2MTUuODY3LDMuNTg5DQoJCQkgTTU1MC4wNywxMjkuNzY3YzQuNDEzLTExLjI3OSwyMS4yNTktNTQuNzI0LDIxLjI1OS01NC43MjRjLTAuMzE1LDAuNTIxLDQuMzgtMTEuMzM0LDcuMDc1LTE4LjY4NGwzLjYwNiwxNi44NzgNCgkJCWMwLDAsMTAuMjE3LDQ2LjcyOSwxMi4zNTMsNTYuNTI4TDU1MC4wNywxMjkuNzY3TDU1MC4wNywxMjkuNzY3eiIvPg0KCQk8cGF0aCBmaWxsPSIjMDAyNDlGIiBkPSJNMTg3LjQyNSwzLjU0NWwtNTIuMjQsMTMzLjQ5NWwtNS41NjYtMjcuMTI5Yy05LjcyNS0zMS4yNzMtNDAuMDI1LTY1LjE1Ni03My44OTktODIuMTE5bDQ3Ljc2NywxNzEuMjAzDQoJCQlsNTYuNDU1LTAuMDY0TDI0My45NDYsMy41NDVIMTg3LjQyNSIvPg0KCQk8cGF0aCBmaWxsPSIjRkZBMDAwIiBkPSJNODYuNzIyLDMuNDI0SDAuNjgxTDAsNy40OTdDNjYuOTM5LDIzLjcwMSwxMTEuMjMyLDYyLjg2LDEyOS42MTgsMTA5LjkxMWwtMTguNzA5LTg5Ljk2DQoJCQlDMTA3LjY3OSw3LjU1NSw5OC4zMTEsMy44NTYsODYuNzIyLDMuNDI0Ii8+DQoJPC9nPg0KPC9nPg0KPC9zdmc+DQo='); 39 | background-size: auto 50%; 40 | background-repeat: no-repeat; 41 | background-position-x: 98%; 42 | background-position-y: 50%; 43 | } 44 | .amex { 45 | background-image: url('data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Created with Inkscape (http://www.inkscape.org/) -->

<svg
   xmlns:dc="http://purl.org/dc/elements/1.1/"
   xmlns:cc="http://creativecommons.org/ns#"
   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
   xmlns:svg="http://www.w3.org/2000/svg"
   xmlns="http://www.w3.org/2000/svg"
   xmlns:xlink="http://www.w3.org/1999/xlink"
   version="1.1"
   width="281.89001"
   height="130.42363"
   viewBox="0 0 281.89001 130.42363"
   id="Layer_1"
   xml:space="preserve"><metadata
   id="metadata38"><rdf:RDF><cc:Work
       rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
         rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs
   id="defs36" />
<radialGradient
   cx="57.388199"
   cy="57.021"
   r="264.57971"
   id="SVGID_1_"
   gradientUnits="userSpaceOnUse"
   gradientTransform="matrix(1.0010754,0,0,0.46091624,-7.6472151,-3.502043)">
	<stop
   id="stop4"
   style="stop-color:#9dd5f6;stop-opacity:1"
   offset="0" />
	<stop
   id="stop6"
   style="stop-color:#98d3f5;stop-opacity:1"
   offset="0.0711" />
	<stop
   id="stop8"
   style="stop-color:#89cef3;stop-opacity:1"
   offset="0.1575" />
	<stop
   id="stop10"
   style="stop-color:#70c6ef;stop-opacity:1"
   offset="0.2516" />
	<stop
   id="stop12"
   style="stop-color:#4ebbea;stop-opacity:1"
   offset="0.35139999" />
	<stop
   id="stop14"
   style="stop-color:#23ade3;stop-opacity:1"
   offset="0.45460001" />
	<stop
   id="stop16"
   style="stop-color:#0da6e0;stop-opacity:1"
   offset="0.5" />
	<stop
   id="stop18"
   style="stop-color:#2e77bc;stop-opacity:1"
   offset="1" />
</radialGradient>
<path
   d="M 282.24821,0 H 0 V 130.42363 H 282.24821 V 87.380507 c 1.1212,-0.74622 1.6748,-1.70078 1.6748,-2.86782 0,-1.33574 -0.5536,-2.16309 -1.6748,-2.86"
   id="path20"
   style="fill:url(#SVGID_1_)" />
<g
   transform="translate(-7.639,-88.953933)"
   id="g22">
	<defs
   id="defs24">
		<path
   d="M 289.584,7.598 H 7.639 v 282.966 h 281.945 v -93.386 c 1.12,-1.619 1.673,-3.69 1.673,-6.222 0,-2.898 -0.553,-4.693 -1.673,-6.205"
   id="SVGID_2_" />
	</defs>
	<clipPath
   id="SVGID_3_">
		<use
   id="use28"
   style="overflow:visible"
   x="0"
   y="0"
   width="300"
   height="300"
   xlink:href="#SVGID_2_" />
	</clipPath>
</g>
<path
   d="m 25.414,41.088067 -5.424,-13.217 -5.393,13.217 m 130.307,-5.263 c -1.089,0.661 -2.377,0.683 -3.92,0.683 h -9.627 v -7.364 h 9.758 c 1.381,0 2.822,0.062 3.758,0.598 1.028,0.483 1.664,1.511 1.664,2.931 0,1.449 -0.605,2.615 -1.633,3.152 z m 68.678,5.263 -5.484,-13.217 -5.454,13.217 h 10.938 z m -128.02,14.306 h -8.124 l -0.03,-25.966 -11.491,25.966 h -6.958 l -11.521,-25.989 v 25.989 H 31.32 l -3.045,-7.395 h -16.5 l -3.076,7.395 H 0.092 l 14.191,-33.154 h 11.774 l 13.478,31.39 v -31.39 h 12.934 l 10.371,22.491 9.527,-22.491 h 13.194 v 33.154 z m 32.379,0 H 91.468 v -33.154 h 26.473 v 6.904 H 99.393 v 5.976 h 18.103 v 6.796 H 99.393 v 6.621 h 18.548 v 6.857 z m 37.326,-24.225 c 0,5.286 -3.528,8.017 -5.584,8.837 1.734,0.66 3.215,1.826 3.92,2.792 1.119,1.649 1.312,3.122 1.312,6.083 v 6.513 h -7.993 l -0.03,-4.181 c 0,-1.995 0.191,-4.864 -1.251,-6.459 -1.158,-1.166 -2.923,-1.419 -5.776,-1.419 h -8.507 v 12.059 h -7.924 v -33.154 h 18.227 c 4.05,0 7.034,0.107 9.596,1.588 2.507,1.481 4.01,3.643 4.01,7.341 z m 12.682,24.225 h -8.086 v -33.154 h 8.086 v 33.154 z m 93.808,0 h -11.23 l -15.021,-24.884 v 24.884 h -16.139 l -3.084,-7.395 h -16.462 l -2.992,7.395 h -9.273 c -3.852,0 -8.729,-0.852 -11.491,-3.667 -2.785,-2.815 -4.234,-6.628 -4.234,-12.657 0,-4.917 0.866,-9.412 4.272,-12.964 2.562,-2.646 6.574,-3.866 12.035,-3.866 h 7.672 v 7.104 h -7.511 c -2.892,0 -4.525,0.43 -6.098,1.964 -1.351,1.396 -2.278,4.035 -2.278,7.51 0,3.552 0.706,6.113 2.179,7.786 1.22,1.312 3.437,1.71 5.523,1.71 h 3.559 l 11.169,-26.073 h 11.874 l 13.417,31.359 v -31.359 h 12.066 l 13.93,23.09 v -23.09 h 8.117 v 33.153 z M 0,61.906067 h 13.54 l 3.053,-7.364 h 6.835 l 3.045,7.364 h 26.641 v -5.63 l 2.378,5.654 h 13.83 l 2.378,-5.738 v 5.714 h 66.208 l -0.031,-12.088 h 1.281 c 0.897,0.031 1.159,0.114 1.159,1.595 v 10.493 h 34.243 v -2.814 c 2.762,1.48 7.058,2.814 12.711,2.814 h 14.406 l 3.083,-7.364 h 6.835 l 3.015,7.364 h 27.761 v -6.995 l 4.204,6.995 h 22.246 v -46.24 h -22.016 v 5.461 l -3.083,-5.461 h -22.591 v 5.461 l -2.831,-5.461 h -30.515 c -5.108,0 -9.598,0.713 -13.225,2.7 v -2.7 h -21.058 v 2.7 c -2.308,-2.048 -5.453,-2.7 -8.95,-2.7 H 67.619 l -5.162,11.943 -5.301,-11.943 H 32.924 v 5.461 l -2.662,-5.461 H 9.596 l -9.597,21.985 v 24.255 z"
   id="path30"
   style="fill:#ffffff" />
<path
   d="m 281.945,86.361067 h -14.443 c -1.442,0 -2.4,0.054 -3.207,0.599 -0.836,0.537 -1.158,1.334 -1.158,2.386 0,1.251 0.706,2.102 1.733,2.47 0.836,0.291 1.734,0.376 3.054,0.376 l 4.295,0.115 c 4.334,0.107 7.227,0.852 8.991,2.669 0.321,0.253 0.514,0.537 0.735,0.821 m 0,12.427003 c -1.925,2.815 -5.676,4.242 -10.754,4.242 h -15.304 v -7.111 h 15.242 c 1.512,0 2.57,-0.199 3.207,-0.821 0.552,-0.513 0.937,-1.258 0.937,-2.163 0,-0.966 -0.385,-1.733 -0.968,-2.193 -0.575,-0.506003 -1.412,-0.736003 -2.792,-0.736003 -7.441,-0.253 -16.724,0.23 -16.724,-10.264 0,-4.81 3.054,-9.873 11.37,-9.873 h 15.785 v -6.598 h -14.666 c -4.426,0 -7.641,1.06 -9.918,2.708 v -2.708 h -21.693 c -3.469,0 -7.541,0.86 -9.467,2.708 v -2.708 h -38.738 v 2.708 c -3.083,-2.224 -8.285,-2.708 -10.686,-2.708 h -25.552 v 2.708 c -2.439,-2.362 -7.863,-2.708 -11.169,-2.708 h -28.597 l -6.544,7.082 -6.129,-7.082 H 56.067 v 46.272003 h 41.914 l 6.743,-7.194 6.352,7.194 25.836,0.023 v -10.885 h 2.54 c 3.428,0.053 7.471,-0.085 11.038,-1.627 v 12.488 h 21.31 v -12.06 h 1.028 c 1.312,0 1.441,0.054 1.441,1.365 v 10.694 h 64.736 c 4.11,0 8.406,-1.052 10.785,-2.961 v 2.961 h 20.534 c 4.273,0 8.446,-0.599 11.621,-2.133 v -8.62 z M 250.334,94.976067 c 1.543,1.597 2.37,3.613 2.37,7.026003 0,7.134 -4.457,10.464 -12.449,10.464 H 224.82 v -7.111 h 15.373 c 1.503,0 2.569,-0.199 3.237,-0.821 0.545,-0.513 0.936,-1.258 0.936,-2.163 0,-0.966 -0.423,-1.733 -0.967,-2.193 -0.606,-0.506003 -1.442,-0.736003 -2.822,-0.736003 -7.411,-0.253 -16.692,0.23 -16.692,-10.264 0,-4.81 3.022,-9.873 11.33,-9.873 h 15.887 v 7.058 h -14.537 c -1.441,0 -2.378,0.054 -3.175,0.599 -0.868,0.537 -1.19,1.334 -1.19,2.386 0,1.251 0.737,2.102 1.734,2.47 0.836,0.291 1.734,0.376 3.084,0.376 l 4.266,0.115 c 4.302,0.105 7.255,0.849 9.05,2.667 z m -71.508,-2.048 c -1.06,0.629 -2.371,0.683 -3.913,0.683 h -9.627 v -7.448 h 9.758 c 1.411,0 2.823,0.03 3.782,0.599 1.027,0.537 1.641,1.564 1.641,2.983 0,1.419 -0.614,2.562 -1.641,3.183 z m 4.786,4.127 c 1.764,0.651 3.206,1.818 3.882,2.784 1.119,1.619003 1.281,3.130003 1.313,6.053003 v 6.574 h -7.956 v -4.149 c 0,-1.995 0.192,-4.949 -1.281,-6.491 -1.158,-1.188 -2.923,-1.472 -5.814,-1.472 h -8.469 v 12.112 h -7.963 V 79.304067 h 18.296 c 4.012,0 6.934,0.177 9.535,1.565 2.501,1.511 4.074,3.581 4.074,7.364 -0.001,5.293 -3.531,7.994 -5.617,8.822 z m 10.011,-17.751 h 26.449 v 6.858 h -18.557 v 6.029 h 18.104 v 6.766 h -18.104 v 6.598003 l 18.557,0.03 v 6.881 H 193.623 V 79.304067 z m -53.467,15.304 h -10.241 v -8.445 h 10.333 c 2.861,0 4.847,1.166 4.847,4.066 0,2.868 -1.894,4.379 -4.939,4.379 z m -18.134,14.842003 -12.167,-13.508003 12.167,-13.079 v 26.587003 z m -31.421,-3.895 H 71.117 v -6.598003 h 17.398 v -6.766 H 71.117 v -6.029 h 19.868 l 8.668,9.664 -9.052,9.729003 z m 63.002,-15.326003 c 0,9.212 -6.873,11.114003 -13.8,11.114003 h -9.888 v 11.123 h -15.403 l -9.758,-10.978 -10.141,10.978 H 63.223 V 79.304067 h 31.873 l 9.75,10.87 10.08,-10.87 h 25.322 c 6.289,0 13.355,1.741 13.355,10.925 z"
   id="path32"
   style="fill:#ffffff" />
</svg>'); 46 | background-size: auto 80%; 47 | background-repeat: no-repeat; 48 | background-position-x: 98%; 49 | background-position-y: 50%; 50 | } 51 | .mastercard { 52 | background-image: url('data:image/svg+xml;base64,<?xml version="1.0" encoding="iso-8859-1"?>
<!-- Generator: Adobe Illustrator 13.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 14948)  -->
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
	 width="300px" height="180px" viewBox="0 0 300 180" style="enable-background:new 0 0 300 180;" xml:space="preserve">
<g id="layer1">
	<g id="g10305">
		<path id="path2268" style="fill:#FF9900;" d="M298.032,90.5c0.014,48.936-39.646,88.614-88.582,88.627
			c-48.937,0.012-88.614-39.646-88.627-88.582c0-0.016,0-0.029,0-0.045c-0.013-48.935,39.647-88.615,88.581-88.628
			c48.937-0.013,88.615,39.647,88.628,88.583C298.032,90.47,298.032,90.484,298.032,90.5z"/>
		<path id="path1350" style="fill:#CC0000;" d="M90.001,1.895C41.355,2.204,1.967,41.781,1.967,90.5
			c0,48.909,39.695,88.604,88.605,88.604c22.955,0,43.879-8.748,59.624-23.086c-0.001,0-0.003-0.002-0.007-0.004h0.019
			c3.224-2.938,6.231-6.108,8.995-9.488H141.05c-2.424-2.928-4.627-5.979-6.606-9.127h31.308c1.904-3.047,3.628-6.211,5.158-9.488
			h-41.635c-1.419-3.042-2.651-6.153-3.703-9.309h49.045c2.956-8.832,4.56-18.281,4.56-28.103c0-6.512-0.706-12.861-2.042-18.974
			h-54.164c0.671-3.146,1.518-6.254,2.528-9.308h49.063c-1.097-3.25-2.371-6.417-3.82-9.487H129.27
			c1.496-3.196,3.191-6.305,5.084-9.307h31.285c-2.082-3.317-4.386-6.486-6.877-9.488h-17.443c2.697-3.174,5.666-6.163,8.889-8.95
			c-15.746-14.34-36.676-23.09-59.636-23.09C90.381,1.895,90.192,1.894,90.001,1.895z"/>
		<path id="use9412" style="fill:#FCB340;" d="M289.143,136.82c0.482,0,0.951,0.125,1.409,0.371c0.46,0.246,0.814,0.601,1.07,1.062
			c0.256,0.456,0.384,0.937,0.384,1.435c0,0.492-0.127,0.968-0.379,1.424c-0.251,0.455-0.605,0.81-1.061,1.063
			c-0.451,0.249-0.928,0.375-1.424,0.375s-0.972-0.126-1.426-0.375c-0.455-0.254-0.807-0.607-1.063-1.063
			c-0.252-0.456-0.377-0.932-0.377-1.424c0-0.498,0.127-0.979,0.384-1.435c0.258-0.461,0.614-0.813,1.071-1.062
			C288.193,136.945,288.662,136.82,289.143,136.82 M289.143,137.295c-0.401,0-0.793,0.104-1.176,0.311
			c-0.38,0.207-0.677,0.5-0.891,0.888c-0.217,0.382-0.325,0.778-0.325,1.194c0,0.412,0.106,0.81,0.315,1.188
			c0.214,0.377,0.51,0.673,0.888,0.885c0.381,0.211,0.776,0.315,1.188,0.315c0.414,0,0.81-0.104,1.189-0.315
			c0.378-0.212,0.673-0.508,0.884-0.885c0.209-0.378,0.313-0.775,0.313-1.188c0-0.416-0.106-0.813-0.321-1.194
			c-0.213-0.388-0.511-0.681-0.894-0.888C289.934,137.398,289.544,137.295,289.143,137.295 M287.887,141.27v-3.082h1.062
			c0.36,0,0.622,0.028,0.784,0.088c0.162,0.057,0.291,0.154,0.388,0.297c0.095,0.141,0.144,0.291,0.144,0.451
			c0,0.226-0.08,0.422-0.242,0.588c-0.158,0.166-0.373,0.261-0.639,0.281c0.109,0.045,0.196,0.102,0.264,0.164
			c0.125,0.12,0.275,0.323,0.455,0.61l0.375,0.603h-0.606l-0.272-0.485c-0.215-0.382-0.388-0.62-0.521-0.718
			c-0.091-0.069-0.224-0.105-0.397-0.105h-0.293v1.311h-0.5 M288.385,139.535h0.604c0.288,0,0.483-0.044,0.588-0.129
			c0.106-0.088,0.159-0.2,0.159-0.342c0-0.092-0.024-0.174-0.075-0.244c-0.052-0.073-0.122-0.125-0.213-0.162
			c-0.089-0.035-0.255-0.055-0.497-0.055h-0.564v0.932"/>
	</g>
	<g id="g16480">
		<g id="g13802" transform="translate(-13.74405,15.9939)">
			<path id="path13804" style="fill:#000066;" d="M133.719,99.926l1.18-8.02c-0.645,0-1.593,0.279-2.431,0.279
				c-3.284,0-3.694-1.755-3.436-3.037l3.236-16.13h4.992l1.029-9.103h-4.705l0.958-5.516H124.7
				c-0.208,0.208-5.568,31.022-5.568,34.776c0,5.555,3.118,8.027,7.516,7.988C130.09,101.134,132.773,100.181,133.719,99.926z"/>
			<path id="path13806" style="fill:#000066;" d="M136.706,84.638c0,13.332,8.799,16.499,16.297,16.499
				c6.921,0,10.55-1.604,10.55-1.604l1.662-9.1c0,0-5.848,2.378-10.601,2.378c-10.131,0-8.355-7.554-8.355-7.554l19.463,0.059
				c0,0,1.239-6.111,1.239-8.602c0-6.217-3.387-13.849-13.745-13.849C143.73,62.867,136.706,73.088,136.706,84.638z M153.252,71.313
				c5.324,0,4.342,5.984,4.342,6.469H147.12C147.12,77.162,148.109,71.313,153.252,71.313z"/>
			<path id="path13808" style="fill:#000066;" d="M212.99,99.923l1.689-10.284c0,0-4.632,2.321-7.807,2.321
				c-6.693,0-9.378-5.11-9.378-10.601c0-11.137,5.758-17.265,12.168-17.265c4.808,0,8.665,2.699,8.665,2.699l1.54-9.993
				c0,0-4.554-3.289-9.456-3.308c-14.745-0.058-23.182,10.208-23.182,27.955c0,11.763,6.248,19.768,17.506,19.768
				C207.918,101.215,212.99,99.923,212.99,99.923z"/>
			<path id="path13810" style="fill:#000066;" d="M81.83,63.012c-6.469,0-11.427,2.079-11.427,2.079l-1.37,8.127
				c0,0,4.093-1.663,10.281-1.663c3.513,0,6.083,0.395,6.083,3.25c0,1.734-0.314,2.374-0.314,2.374s-2.772-0.231-4.056-0.231
				c-9.21,0-16.729,3.482-16.729,13.98c0,8.273,5.623,10.17,9.108,10.17c6.657,0,9.292-4.203,9.444-4.215l-0.077,3.488
				c0,0,8.306,0,8.307,0l3.706-25.98C94.786,63.366,85.17,63.012,81.83,63.012z M83.268,84.108c0.181,1.586-0.41,9.086-6.092,9.086
				c-2.93,0-3.691-2.24-3.691-3.562c0-2.584,1.403-5.683,8.315-5.683C83.41,83.949,82.997,84.065,83.268,84.108z"/>
			<path id="path13812" style="fill:#000066;" d="M103.615,100.906c2.125,0,14.272,0.541,14.272-11.994
				c0-11.721-11.244-9.404-11.244-14.114c0-2.342,1.833-3.08,5.184-3.08c1.329,0,6.447,0.423,6.447,0.423l1.189-8.33
				c0,0.001-3.312-0.741-8.704-0.741c-6.979,0-14.063,2.786-14.063,12.318c0,10.802,11.812,9.717,11.812,14.267
				c0,3.037-3.3,3.287-5.844,3.287c-4.401,0-8.363-1.511-8.377-1.438l-1.259,8.245C93.257,99.819,95.702,100.906,103.615,100.906z"
				/>
			<path id="path13814" style="fill:#000066;" d="M290.807,55.455l-1.705,12.709c0,0-3.553-4.905-9.112-4.905
				c-10.459,0-15.849,10.423-15.849,22.396c0,7.73,3.844,15.307,11.699,15.307c5.651,0,8.784-3.941,8.784-3.941l-0.415,3.365h9.178
				l7.207-44.862L290.807,55.455z M286.755,80.156c0,4.983-2.468,11.64-7.581,11.64c-3.396,0-4.988-2.851-4.988-7.324
				c0-7.315,3.285-12.14,7.432-12.14C285.012,72.332,286.755,74.662,286.755,80.156z"/>
			<path id="path13816" style="fill:#000066;" d="M30.749,100.423l5.743-33.87l0.844,33.87h6.499l12.125-33.87l-5.371,33.87h9.658
				l7.437-44.922l-15.342-0.117l-9.126,27.504l-0.25-27.387h-14.06l-7.544,44.922H30.749L30.749,100.423z"/>
			<path id="path13818" style="fill:#000066;" d="M176.101,100.487c2.746-15.615,3.724-27.947,11.732-25.393
				c1.15-6.044,3.891-11.3,5.143-13.858c0,0-0.396-0.589-2.871-0.589c-4.225,0-9.866,8.574-9.866,8.574l0.843-5.301h-8.786
				l-5.884,36.566H176.101z"/>
			<g id="use14699" transform="translate(845.3001,0)">
				<path id="path13810_1_" style="fill:#000066;" d="M-612.55,63.012c-6.472,0-11.43,2.079-11.43,2.079l-1.369,8.127
					c0,0,4.095-1.663,10.28-1.663c3.514,0,6.083,0.395,6.083,3.25c0,1.734-0.313,2.374-0.313,2.374s-2.771-0.231-4.055-0.231
					c-9.211,0-16.729,3.482-16.729,13.98c0,8.273,5.622,10.17,9.107,10.17c6.655,0,9.292-4.203,9.443-4.215l-0.078,3.488h8.309
					l3.705-25.98C-599.596,63.366-609.212,63.012-612.55,63.012z M-611.114,84.108c0.18,1.586-0.411,9.086-6.092,9.086
					c-2.932,0-3.692-2.24-3.692-3.562c0-2.584,1.402-5.683,8.315-5.683C-610.972,83.949-611.384,84.065-611.114,84.108z"/>
			</g>
			<path id="use14701" style="fill:#000066;" d="M255.266,100.487c1.508-11.488,4.299-27.616,11.731-25.393
				c1.149-6.044,0.041-6.028-2.433-6.028c-4.228,0-5.164,0.154-5.164,0.154l0.844-5.301h-8.785l-5.884,36.567H255.266
				L255.266,100.487z"/>
		</g>
		<g id="g10289">
			<path id="path4157" style="fill:#FFFFFF;" d="M122.434,113.059l1.181-8.019c-0.645,0-1.594,0.276-2.431,0.276
				c-3.284,0-3.646-1.746-3.437-3.037l2.653-16.362h4.991l1.205-8.87h-4.706l0.958-5.516h-9.434
				c-0.208,0.208-5.569,31.023-5.569,34.775c0,5.555,3.119,8.029,7.517,7.989C118.806,114.266,121.488,113.313,122.434,113.059z"/>
			<path id="path4155" style="fill:#FFFFFF;" d="M125.423,97.77c0,13.332,8.8,16.5,16.297,16.5c6.92,0,9.965-1.547,9.965-1.547
				l1.662-9.099c0,0-5.264,2.319-10.018,2.319c-10.13,0-8.356-7.553-8.356-7.553h19.172c0,0,1.238-6.113,1.238-8.604
				c0-6.216-3.094-13.79-13.452-13.79C132.445,75.998,125.423,86.219,125.423,97.77z M141.967,84.445
				c5.324,0,4.342,5.983,4.342,6.467h-10.474C135.835,90.294,136.825,84.445,141.967,84.445z"/>
			<path id="path4151" style="fill:#FFFFFF;" d="M201.707,113.055l1.688-10.285c0,0-4.629,2.321-7.806,2.321
				c-6.692,0-9.376-5.11-9.376-10.6c0-11.137,5.758-17.264,12.168-17.264c4.807,0,8.665,2.699,8.665,2.699l1.54-9.993
				c0,0-5.721-2.315-10.625-2.315c-10.891,0-21.486,9.448-21.486,27.192c0,11.766,5.721,19.537,16.979,19.537
				C196.637,114.348,201.707,113.055,201.707,113.055z"/>
			<path id="path4149" style="fill:#FFFFFF;" d="M70.547,76.143c-6.469,0-11.428,2.079-11.428,2.079l-1.369,8.127
				c0,0,4.093-1.663,10.28-1.663c3.513,0,6.083,0.395,6.083,3.25c0,1.734-0.315,2.374-0.315,2.374s-2.771-0.232-4.054-0.232
				c-8.159,0-16.73,3.482-16.73,13.98c0,8.272,5.623,10.17,9.108,10.17c6.656,0,9.525-4.319,9.678-4.332l-0.311,3.605h8.307
				l3.706-25.981C83.502,76.498,73.887,76.143,70.547,76.143z M72.568,97.297c0.18,1.587-0.995,9.026-6.675,9.026
				c-2.93,0-3.692-2.238-3.692-3.562c0-2.582,1.403-5.682,8.316-5.682C72.125,97.081,72.297,97.253,72.568,97.297z"/>
			<path id="path4145" style="fill:#FFFFFF;" d="M92.331,114.038c2.125,0,14.273,0.54,14.273-11.995
				c0-11.719-11.245-9.404-11.245-14.112c0-2.344,1.833-3.082,5.183-3.082c1.33,0,6.447,0.423,6.447,0.423l1.19-8.33
				c0,0.001-3.312-0.741-8.704-0.741c-6.979,0-14.063,2.786-14.063,12.318c0,10.801,11.812,9.717,11.812,14.267
				c0,3.037-3.3,3.284-5.843,3.284c-4.401,0-8.364-1.51-8.378-1.438l-1.258,8.246C81.973,112.948,84.417,114.038,92.331,114.038z"/>
			<path id="path4139" style="fill:#FFFFFF;" d="M279.852,68.668l-2.035,12.627c0,0-3.551-4.905-9.11-4.905
				c-8.644,0-15.849,10.422-15.849,22.397c0,7.73,3.843,15.304,11.699,15.304c5.651,0,8.784-3.94,8.784-3.94l-0.415,3.365h9.176
				l7.207-44.863L279.852,68.668z M275.471,93.288c0,4.983-2.467,11.639-7.582,11.639c-3.395,0-4.986-2.85-4.986-7.323
				c0-7.314,3.285-12.14,7.43-12.14C273.729,85.463,275.471,87.796,275.471,93.288z"/>
			<path id="path4133" style="fill:#FFFFFF;" d="M19.466,113.555l5.743-33.87l0.843,33.87h6.5l12.125-33.87l-5.371,33.87h9.658
				l7.438-44.923H41.467l-9.301,27.563l-0.484-27.563H17.915l-7.545,44.923H19.466z"/>
			<path id="path4131" style="fill:#FFFFFF;" d="M164.818,113.617c2.746-15.616,3.255-28.296,9.808-25.975
				c1.147-6.044,2.254-8.382,3.506-10.94c0,0-0.587-0.123-1.819-0.123c-4.225,0-7.355,5.772-7.355,5.772l0.841-5.301h-8.784
				l-5.885,36.567H164.818z"/>
			<g id="use8523" transform="translate(847.0062,0)">
				<path id="path4149_1_" style="fill:#FFFFFF;" d="M-623.531,76.143c-6.469,0-11.428,2.079-11.428,2.079l-1.368,8.127
					c0,0,4.093-1.663,10.28-1.663c3.513,0,6.081,0.395,6.081,3.25c0,1.734-0.313,2.374-0.313,2.374s-2.771-0.232-4.055-0.232
					c-8.158,0-16.729,3.482-16.729,13.98c0,8.272,5.622,10.17,9.107,10.17c6.656,0,9.525-4.319,9.677-4.332l-0.309,3.605
					c0,0,8.304,0,8.307,0l3.705-25.981C-610.575,76.498-620.191,76.143-623.531,76.143z M-621.507,97.297
					c0.18,1.587-0.996,9.026-6.678,9.026c-2.93,0-3.69-2.238-3.69-3.562c0-2.582,1.403-5.682,8.315-5.682
					C-621.952,97.081-621.781,97.253-621.507,97.297z"/>
			</g>
			<g id="use8525" transform="translate(442.2857,0)">
				<path id="path4131_1_" style="fill:#FFFFFF;" d="M-198.263,113.617c2.747-15.616,3.256-28.296,9.807-25.975
					c1.149-6.044,2.257-8.382,3.508-10.94c0,0-0.587-0.123-1.819-0.123c-4.225,0-7.355,5.772-7.355,5.772l0.841-5.301h-8.784
					l-5.885,36.567H-198.263z"/>
			</g>
			<path id="text9407" style="fill:#FFFFFF;" d="M289.105,107.975c0.479,0,0.951,0.123,1.406,0.373
				c0.459,0.242,0.816,0.598,1.072,1.059c0.257,0.458,0.383,0.935,0.383,1.434c0,0.493-0.126,0.969-0.379,1.424
				c-0.251,0.455-0.604,0.812-1.059,1.063c-0.454,0.25-0.93,0.376-1.424,0.376c-0.498,0-0.974-0.126-1.429-0.376
				c-0.454-0.253-0.806-0.608-1.058-1.063c-0.256-0.455-0.381-0.931-0.381-1.424c0-0.499,0.127-0.976,0.384-1.434
				c0.258-0.461,0.616-0.815,1.073-1.059C288.154,108.098,288.626,107.975,289.105,107.975 M289.105,108.447
				c-0.401,0-0.793,0.104-1.176,0.313c-0.382,0.204-0.679,0.499-0.894,0.885c-0.214,0.381-0.322,0.78-0.322,1.194
				s0.104,0.81,0.313,1.188c0.213,0.377,0.509,0.673,0.891,0.886c0.378,0.208,0.773,0.313,1.188,0.313
				c0.412,0,0.81-0.105,1.188-0.313c0.378-0.213,0.674-0.509,0.884-0.886c0.211-0.381,0.314-0.774,0.314-1.188
				s-0.107-0.813-0.321-1.194c-0.213-0.386-0.51-0.681-0.894-0.885C289.896,108.552,289.507,108.447,289.105,108.447
				 M287.85,112.423v-3.083h1.061c0.361,0,0.625,0.029,0.785,0.088c0.162,0.055,0.289,0.154,0.388,0.297
				c0.097,0.142,0.146,0.291,0.146,0.451c0,0.225-0.082,0.422-0.244,0.588c-0.158,0.166-0.371,0.262-0.637,0.28
				c0.106,0.046,0.194,0.101,0.262,0.163c0.123,0.122,0.275,0.326,0.455,0.611l0.377,0.604h-0.609l-0.271-0.485
				c-0.216-0.383-0.389-0.621-0.521-0.718c-0.091-0.071-0.224-0.106-0.399-0.106h-0.291v1.311L287.85,112.423 M288.348,110.688
				h0.604c0.289,0,0.484-0.043,0.588-0.129c0.105-0.084,0.16-0.199,0.16-0.342c0-0.091-0.025-0.173-0.075-0.242
				c-0.051-0.074-0.122-0.127-0.213-0.164c-0.091-0.035-0.254-0.053-0.498-0.053h-0.565V110.688"/>
		</g>
	</g>
</g>
</svg>
'); 53 | background-size: auto 80%; 54 | background-repeat: no-repeat; 55 | background-position-x: 98%; 56 | background-position-y: 50%; 57 | } 58 | .discover { 59 | background-image: url('data:image/svg+xml;base64,<?xml version="1.0" standalone="no"?><!-- no kidding around my files... (http://www.dodero.eu) --><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg id="Untitled-Page%201" viewBox="0 0 1430 880" style="background-color:#ffffff00" version="1.1"	xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve"	x="0px" y="0px" width="1430px" height="880px">	<defs>		<radialGradient id="gradient1" cx="50.6977%" cy="50%" r="50%">			<stop stop-color="#ffffff" stop-opacity="1" offset="0%"/>			<stop stop-color="#ff8000" stop-opacity="1" offset="100%"/>		</radialGradient>	</defs>	<g>		<rect x="0" y="-1" width="1430" height="880" fill="#ffffff"/>		<path d="M 1429.98 879.0058 L 357.3838 878.9818 C 507.3335 853.6667 738.6665 804.3334 1014.6665 711.6667 C 1290.6665 619 1415.3335 525.8333 1429.98 517.9085 L 1429.98 879.0058 Z" fill="#ff8000"/>		<g>			<path d="M 150.0288 399.6931 C 178.333 399.6931 200.3457 390.7787 216.0825 372.9343 C 231.8193 355.1056 239.6875 330.0635 239.6875 297.8238 C 239.6875 267.5213 232.2563 244.3376 217.4253 228.2572 C 202.5781 212.1924 181.2056 204.1443 153.3232 204.1443 L 75.8262 204.1443 L 75.8262 399.6931 L 150.0288 399.6931 L 150.0288 399.6931 ZM 113.7939 231.3598 L 136.2437 231.3598 C 150.5601 231.3598 161.457 232.9978 168.9507 236.258 C 176.4287 239.5182 182.8296 245.4244 188.1372 253.9765 C 195.8496 266.4188 199.7212 281.9795 199.7212 300.6587 C 199.7212 324.8188 194.9131 342.8365 185.2959 354.6961 C 175.6792 366.5556 161.0977 372.4775 141.5518 372.4775 L 113.7939 372.4775 L 113.7939 231.3598 L 113.7939 231.3598 Z" fill="#000000"/>			<path d="M 311.627 399.6931 L 311.627 204.1443 L 273.6587 204.1443 L 273.6587 399.6931 L 311.627 399.6931 L 311.627 399.6931 Z" fill="#000000"/>			<path d="M 391.2114 404.733 C 413.1304 404.733 430.3188 399.5829 442.793 389.251 C 455.251 378.9349 461.4956 364.6814 461.4956 346.5062 C 461.4956 333.7174 458.2017 322.8816 451.6138 313.9673 C 445.0254 305.0529 433.0513 295.3195 415.6597 284.7672 L 402.7485 276.9868 C 393.0693 271.0965 386.6216 266.1353 383.4058 262.1034 C 380.1738 258.0714 378.5659 253.378 378.5659 248.0231 C 378.5659 241.5342 381.0171 236.3053 385.9346 232.3048 C 390.8369 228.3202 397.3623 226.3199 405.5117 226.3199 C 416.0498 226.3199 430.3813 230.0211 448.5068 237.4078 L 448.5068 206.1603 C 430.5376 201.4668 414.395 199.1044 400.0791 199.1044 C 382.188 199.1044 367.7939 204.0025 356.9126 213.7989 C 346.0308 223.5952 340.5981 236.5573 340.5981 252.7007 C 340.5981 264.7966 343.9233 275.3489 350.5894 284.3893 C 357.2402 293.4296 368.6523 302.8637 384.8262 312.6758 L 396.894 319.9049 C 406.6357 325.8583 413.1772 331.0242 416.5181 335.3869 C 419.8594 339.7653 421.5298 345.1202 421.5298 351.4516 C 421.5298 359.484 418.7505 365.8469 413.1929 370.5088 C 407.6353 375.1865 400.0166 377.5175 390.3687 377.5175 C 376.5679 377.5175 359.9878 373.1548 340.5981 364.4137 L 340.5981 397.6771 C 359.8315 402.3706 376.6924 404.733 391.2114 404.733 L 391.2114 404.733 Z" fill="#000000"/>			<path d="M 628.5 360.5838 C 608.3164 370.0193 606.1743 376.725 586.3735 376.725 C 564.2754 376.725 547.0322 370.1138 534.6436 356.8914 C 522.2378 343.6691 516.0435 325.2556 516.0435 301.6195 C 516.0435 277.5731 521.7852 259.0018 533.3037 245.9057 C 544.8223 232.8096 561.1782 231.2706 582.3887 231.2706 C 598.9707 231.2706 601.7046 235.3099 626.2729 243.3885 L 626.2729 211.0742 C 604.188 204.579 600.623 201 578.6826 201 C 544.3008 201 517.853 207.9112 499.3047 225.7093 C 480.7568 243.5232 471.5 268.9581 471.5 301.9982 C 471.5 334.4387 480.7222 359.7158 499.1655 377.8295 C 517.6089 395.9431 543.3608 405 576.4204 405 C 603.4946 405 608.9604 400.9607 628.5 392.8821 L 628.5 360.5838 Z" fill="#000000"/>			<path d="M 971.1035 399.6931 L 1036.0176 204.1443 L 1004.8374 204.1443 L 954.583 355.4993 L 903.2515 204.1443 L 865.1602 204.1443 L 931.4795 399.6931 L 971.1035 399.6931 Z" fill="#000000"/>			<path d="M 1177.896 399.6931 L 1177.896 372.4775 L 1097.9634 372.4775 L 1097.9634 313.0065 L 1157.9131 313.0065 L 1157.9131 285.791 L 1097.9634 285.791 L 1097.9634 231.3598 L 1171.9009 231.3598 L 1171.9009 204.1443 L 1059.9956 204.1443 L 1059.9956 399.6931 L 1177.896 399.6931 L 1177.896 399.6931 Z" fill="#000000"/>			<path d="M 1242.8394 399.6931 L 1242.8394 320.0624 L 1263.0098 320.0624 L 1307.9092 399.6931 L 1353.7456 399.6931 L 1294.374 308.2816 C 1305.3804 303.0054 1314.0293 295.4141 1320.3208 285.5232 C 1326.6123 275.6324 1329.7656 264.6548 1329.7656 252.5905 C 1329.7656 220.3035 1311.5313 204.1443 1275.062 204.1443 L 1207.8691 204.1443 L 1207.8691 399.6931 L 1242.8394 399.6931 L 1242.8394 399.6931 ZM 1242.8394 231.3598 L 1255.7349 231.3598 C 1279.7769 231.3598 1291.7979 240.0222 1291.7979 257.3154 C 1291.7979 281.0031 1278.3252 292.8469 1251.3945 292.8469 L 1242.8394 292.8469 L 1242.8394 231.3598 L 1242.8394 231.3598 Z" fill="#000000"/>			<path id="Ellipse" d="M 645.5 302.5 C 645.5 243.1286 693.6284 195 753 195 C 812.3716 195 860.5 243.1286 860.5 302.5 C 860.5 361.8714 812.3716 410 753 410 C 693.6284 410 645.5 361.8714 645.5 302.5 Z" fill="url(#gradient1)"/>		</g>		<g>			<path d="M 437 524 L 437 479.0625 L 469.3438 524 L 481 524 L 481 458 L 470 458 L 470 502.9375 L 437.6563 458 L 426 458 L 426 524 L 437 524 L 437 524 Z" fill="#000000"/>			<path d="M 559.3999 524 L 559.3999 515 L 529.3999 515 L 529.3999 494 L 552.3999 494 L 552.3999 485 L 529.3999 485 L 529.3999 467 L 557.3999 467 L 557.3999 458 L 515.3999 458 L 515.3999 524 L 559.3999 524 L 559.3999 524 Z" fill="#000000"/>			<path d="M 619.7998 524 L 619.7998 467 L 643.7998 467 L 643.7998 458 L 581.7998 458 L 581.7998 467 L 605.7998 467 L 605.7998 524 L 619.7998 524 L 619.7998 524 Z" fill="#000000"/>			<path d="M 693.3408 524 L 703.7002 478.4063 L 713.2158 524 L 726.4971 524 L 744.2002 458 L 734.5439 458 L 721.7002 506.375 L 711.7158 458 L 699.6533 458 L 688.7002 506.6563 L 676.2783 458 L 663.2002 458 L 680.2158 524 L 693.3408 524 L 693.3408 524 Z" fill="#000000"/>			<path d="M 826.3813 514.8594 C 832.522 508.7656 835.6001 500.4375 835.6001 489.875 C 835.6001 479.5469 832.522 471.3125 826.3813 465.1875 C 820.2251 459.0625 811.9751 456 801.6157 456 C 791.1938 456 782.9126 459.0625 776.7876 465.1875 C 770.6626 471.3125 767.6001 479.5938 767.6001 490 C 767.6001 500.3125 770.647 508.5469 776.7407 514.7344 C 782.8345 520.9219 790.9751 524 801.1626 524 C 811.8188 524 820.2251 520.9531 826.3813 514.8594 L 826.3813 514.8594 ZM 787.022 508.1406 C 783.397 503.5625 781.6001 497.5156 781.6001 489.9844 C 781.6001 482.3906 783.4126 476.3281 787.0532 471.7969 C 790.6782 467.2656 795.5376 465 801.6313 465 C 807.6313 465 812.4595 467.2656 816.1157 471.7969 C 819.772 476.3281 821.6001 482.3438 821.6001 489.8438 C 821.6001 497.5781 819.772 503.7031 816.147 508.2188 C 812.5063 512.75 807.5688 515 801.3345 515 C 795.4126 515 790.647 512.7188 787.022 508.1406 L 787.022 508.1406 Z" fill="#000000"/>			<path d="M 880 524 L 880 497 L 886.3906 497 L 903.0938 524 L 920 524 L 898.2344 493.25 C 902.2031 491.4688 905.3125 488.8906 907.5938 485.5469 C 909.8594 482.2031 911 478.4844 911 474.3906 C 911 463.4688 904.2656 458 890.8125 458 L 866 458 L 866 524 L 880 524 L 880 524 ZM 880 467 L 884.4844 467 C 892.8281 467 897 469.9531 897 475.8594 C 897 483.9531 892.3125 488 882.9688 488 L 880 488 L 880 467 L 880 467 Z" fill="#000000"/>			<path d="M 961.3999 524 L 961.3999 491.5313 L 986.6655 524 L 1003.6499 524 L 975.2593 487.5156 L 997.6499 458 L 985.6812 458 L 961.3999 490 L 961.3999 458 L 947.3999 458 L 947.3999 524 L 961.3999 524 L 961.3999 524 Z" fill="#000000"/>		</g>	</g></svg>'); 60 | background-size: auto 80%; 61 | background-repeat: no-repeat; 62 | background-position-x: 98%; 63 | background-position-y: 50%; 64 | } 65 | --------------------------------------------------------------------------------