diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..ebce6d7 --- /dev/null +++ b/.gitignore @@ -0,0 +1,10 @@ +dist +node_modules +bower_components +src/app/config.js +.tmp +.idea +.awspublish* +.DS_Store +/.project +/.settings diff --git a/bower.json b/bower.json new file mode 100755 index 0000000..042a14f --- /dev/null +++ b/bower.json @@ -0,0 +1,38 @@ +{ + "name": "support-admin-app", + "version": "2.3.0", + "dependencies": { + "jquery": "~2.1.1", + "angular-animate": "~1.4.4", + "angular-cookies": "~1.4.4", + "angular-touch": "~1.4.4", + "angular-sanitize": "~1.4.4", + "angular-resource": "~1.4.4", + "angular-ui-router": "~0.2.13", + "bootstrap": "~3.3.5", + "angular-bootstrap": "0.12.x", + "angular": "~1.4.4", + "PACE": "https://github.com/HubSpot/pace.git#~1.0.2", + "metisMenu": "~2.0.2", + "font-awesome": "~4.3.0", + "footable": "~2.0.3", + "icheck": "1.0.2", + "auth0-lock": "~7.6.2", + "auth0.js": "~6.4.2", + "auth0-angular": "~4.0.5", + "a0-angular-storage": "~0.0.11", + "angular-jwt": "~0.0.9", + "angular-footable": "~1.0.3", + "appirio-tech-ng-auth": "3.x.x", + "appirio-tech-ng-login-reg": "0.x.x", + "appirio-tech-ng-api-services": "0.x.x" + }, + "devDependencies": { + "angular-mocks": "~1.4.4" + }, + "resolutions": { + "jquery": "~2.1.1", + "angular": "1.4.x", + "angular-resource": "1.4.x" + } +} diff --git a/config.json b/config.json new file mode 100644 index 0000000..63b7071 --- /dev/null +++ b/config.json @@ -0,0 +1,30 @@ +{ + "local": { + "API_URL" : "http://localhost:8080", + "AUTH0_CLIENT_ID" : "JFDo7HMkf0q2CkVFHojy3zHWafziprhT", + "AUTH0_DOMAIN" : "topcoder-dev.auth0.com", + "AUTH0_TOKEN_NAME" : "userJWTToken", + "AUTH0_REFRESH_TOKEN_NAME" : "userRefreshJWTToken" + }, + "dev": { + "API_URL" : "https://api.topcoder-dev.com", + "AUTH0_CLIENT_ID" : "JFDo7HMkf0q2CkVFHojy3zHWafziprhT", + "AUTH0_DOMAIN" : "topcoder-dev.auth0.com", + "AUTH0_TOKEN_NAME" : "userJWTToken", + "AUTH0_REFRESH_TOKEN_NAME" : "userRefreshJWTToken" + }, + "qa": { + "API_URL" : "https://api.topcoder-qa.com", + "AUTH0_CLIENT_ID" : "EVOgWZlCtIFlbehkq02treuRRoJk12UR", + "AUTH0_DOMAIN" : "topcoder-qa.auth0.com", + "AUTH0_TOKEN_NAME" : "userJWTToken", + "AUTH0_REFRESH_TOKEN_NAME" : "userRefreshJWTToken" + }, + "prod": { + "API_URL" : "https://api.topcoder.com", + "AUTH0_CLIENT_ID" : "6ZwZEUo2ZK4c50aLPpgupeg5v2Ffxp9P", + "AUTH0_DOMAIN" : "topcoder.auth0.com", + "AUTH0_TOKEN_NAME" : "userJWTToken", + "AUTH0_REFRESH_TOKEN_NAME" : "userRefreshJWTToken" + } +} diff --git a/e2e/main.po.js b/e2e/main.po.js new file mode 100755 index 0000000..6b88871 --- /dev/null +++ b/e2e/main.po.js @@ -0,0 +1,15 @@ +/** + * This file uses the Page Object pattern to define the main page for tests + * https://docs.google.com/presentation/d/1B6manhG0zEXkC-H-tPo2vwU06JhL8w9-XCF9oehXzAQ + */ + +'use strict'; + +var MainPage = function() { + this.jumbEl = element(by.css('.jumbotron')); + this.h1El = this.jumbEl.element(by.css('h1')); + this.imgEl = this.jumbEl.element(by.css('img')); + this.thumbnailEls = element(by.css('body')).all(by.repeater('awesomeThing in awesomeThings')); +}; + +module.exports = new MainPage(); diff --git a/e2e/main.spec.js b/e2e/main.spec.js new file mode 100755 index 0000000..da89d22 --- /dev/null +++ b/e2e/main.spec.js @@ -0,0 +1,21 @@ +'use strict'; + +describe('The main view', function () { + var page; + + beforeEach(function () { + browser.get('http://localhost:3000/index.html'); + page = require('./main.po'); + }); + + it('should include jumbotron with correct data', function() { + expect(page.h1El.getText()).toBe('\'Allo, \'Allo!'); + expect(page.imgEl.getAttribute('src')).toMatch(/assets\/images\/yeoman.png$/); + expect(page.imgEl.getAttribute('alt')).toBe('I\'m Yeoman'); + }); + + it('list more than 5 awesome things', function () { + expect(page.thumbnailEls.count()).toBeGreaterThan(5); + }); + +}); diff --git a/gulp/build.js b/gulp/build.js new file mode 100755 index 0000000..870f890 --- /dev/null +++ b/gulp/build.js @@ -0,0 +1,92 @@ +'use strict'; + +var gulp = require('gulp'); + +var paths = gulp.paths; + +var $ = require('gulp-load-plugins')({ + pattern: ['gulp-*', 'main-bower-files', 'uglify-save-license', 'del'] +}); + +gulp.task('partials', function () { + return gulp.src([ + paths.src + '/{app,components}/**/*.html', + paths.tmp + '/{app,components}/**/*.html' + ]) + .pipe($.minifyHtml({ + empty: true, + spare: true, + quotes: true + })) + .pipe($.angularTemplatecache('templateCacheHtml.js', { + module: 'supportAdminApp' + })) + .pipe(gulp.dest(paths.tmp + '/partials/')); +}); + +gulp.task('html', ['inject', 'partials'], function () { + var partialsInjectFile = gulp.src(paths.tmp + '/partials/templateCacheHtml.js', { read: false }); + var partialsInjectOptions = { + starttag: '', + ignorePath: paths.tmp + '/partials', + addRootSlash: false + }; + + var htmlFilter = $.filter('*.html'); + var jsFilter = $.filter('**/*.js'); + var cssFilter = $.filter('**/*.css'); + var assets; + + return gulp.src(paths.tmp + '/serve/*.html') + .pipe($.inject(partialsInjectFile, partialsInjectOptions)) + .pipe(assets = $.useref.assets()) + .pipe($.rev()) + .pipe(jsFilter) + .pipe($.ngAnnotate()) + .pipe($.uglify({preserveComments: $.uglifySaveLicense})) + .pipe(jsFilter.restore()) + .pipe(cssFilter) + .pipe($.replace('../bootstrap/fonts', 'fonts')) + .pipe($.csso()) + .pipe(cssFilter.restore()) + .pipe(assets.restore()) + .pipe($.useref()) + .pipe($.revReplace()) + .pipe(htmlFilter) + .pipe($.minifyHtml({ + empty: true, + spare: true, + quotes: true + })) + .pipe(htmlFilter.restore()) + .pipe(gulp.dest(paths.dist + '/')) + .pipe($.size({ title: paths.dist + '/', showFiles: true })); +}); + +gulp.task('images', function () { + return gulp.src(paths.src + '/assets/images/**/*') + .pipe(gulp.dest(paths.dist + '/assets/images/')); +}); + +gulp.task('fonts', function () { + return gulp.src($.mainBowerFiles()) + .pipe($.filter('**/*.{eot,svg,ttf,woff}')) + .pipe($.flatten()) + .pipe(gulp.dest(paths.dist + '/fonts/')); +}); + +gulp.task('fontawesome', function () { + return gulp.src('bower_components/font-awesome/fonts/*.{eot,svg,ttf,woff}') + .pipe(gulp.dest(paths.dist + '/fonts/')); +}); + +gulp.task('misc', function () { + return gulp.src(paths.src + '/**/*.ico') + .pipe(gulp.dest(paths.dist + '/')); +}); + +gulp.task('clean', function (done) { + $.del([paths.dist + '/', paths.tmp + '/'], done); +}); + +gulp.task('build', ['ng-config', 'html', 'images', 'fonts', 'fontawesome', 'misc']); diff --git a/gulp/e2e-tests.js b/gulp/e2e-tests.js new file mode 100755 index 0000000..99ab2c5 --- /dev/null +++ b/gulp/e2e-tests.js @@ -0,0 +1,35 @@ +'use strict'; + +var gulp = require('gulp'); + +var $ = require('gulp-load-plugins')(); + +var browserSync = require('browser-sync'); + +var paths = gulp.paths; + +// Downloads the selenium webdriver +gulp.task('webdriver-update', $.protractor.webdriver_update); + +gulp.task('webdriver-standalone', $.protractor.webdriver_standalone); + +function runProtractor (done) { + + gulp.src(paths.e2e + '/**/*.js') + .pipe($.protractor.protractor({ + configFile: 'protractor.conf.js', + })) + .on('error', function (err) { + // Make sure failed tests cause gulp to exit non-zero + throw err; + }) + .on('end', function () { + // Close browser sync server + browserSync.exit(); + done(); + }); +} + +gulp.task('protractor', ['protractor:src']); +gulp.task('protractor:src', ['serve:e2e', 'webdriver-update'], runProtractor); +gulp.task('protractor:dist', ['serve:e2e-dist', 'webdriver-update'], runProtractor); diff --git a/gulp/inject.js b/gulp/inject.js new file mode 100755 index 0000000..12fc664 --- /dev/null +++ b/gulp/inject.js @@ -0,0 +1,40 @@ +'use strict'; + +var gulp = require('gulp'); + +var paths = gulp.paths; + +var $ = require('gulp-load-plugins')(); + +var wiredep = require('wiredep').stream; + +gulp.task('inject', ['styles'], function () { + + var injectStyles = gulp.src([ + paths.tmp + '/serve/{app,components}/**/*.css', + '!' + paths.tmp + '/serve/app/vendor.css' + ], { read: false }); + + var injectScripts = gulp.src([ + paths.src + '/{app,components}/**/*.js', + '!' + paths.src + '/{app,components}/**/*.spec.js', + '!' + paths.src + '/{app,components}/**/*.mock.js' + ]).pipe($.angularFilesort()); + + var injectOptions = { + ignorePath: [paths.src, paths.tmp + '/serve'], + addRootSlash: false + }; + + var wiredepOptions = { + directory: 'bower_components', + exclude: [/bootstrap\.js/, /bootstrap\.css/, /bootstrap\.css/, /foundation\.css/] + }; + + return gulp.src(paths.src + '/*.html') + .pipe($.inject(injectStyles, injectOptions)) + .pipe($.inject(injectScripts, injectOptions)) + .pipe(wiredep(wiredepOptions)) + .pipe(gulp.dest(paths.tmp + '/serve')); + +}); diff --git a/gulp/ng-config.js b/gulp/ng-config.js new file mode 100644 index 0000000..b29f478 --- /dev/null +++ b/gulp/ng-config.js @@ -0,0 +1,14 @@ +'use strict'; + +var gulp = require('gulp'); + +var gulpNgConfig = require('gulp-ng-config'); + +gulp.task('ng-config', function () { + gulp.src('config.json') + .pipe( + gulpNgConfig('app.constants', { + environment: process.env.BUILD_ENV || 'dev' + })) + .pipe(gulp.dest('src/app')) +}); diff --git a/gulp/proxy.js b/gulp/proxy.js new file mode 100755 index 0000000..2fcd734 --- /dev/null +++ b/gulp/proxy.js @@ -0,0 +1,65 @@ + /*jshint unused:false */ + +/*************** + + This file allow to configure a proxy system plugged into BrowserSync + in order to redirect backend requests while still serving and watching + files from the web project + + IMPORTANT: The proxy is disabled by default. + + If you want to enable it, watch at the configuration options and finally + change the `module.exports` at the end of the file + +***************/ + +'use strict'; + +var httpProxy = require('http-proxy'); +var chalk = require('chalk'); + +/* + * Location of your backend server + */ +var proxyTarget = 'http://server/context/'; + +var proxy = httpProxy.createProxyServer({ + target: proxyTarget +}); + +proxy.on('error', function(error, req, res) { + res.writeHead(500, { + 'Content-Type': 'text/plain' + }); + + console.error(chalk.red('[Proxy]'), error); +}); + +/* + * The proxy middleware is an Express middleware added to BrowserSync to + * handle backend request and proxy them to your backend. + */ +function proxyMiddleware(req, res, next) { + /* + * This test is the switch of each request to determine if the request is + * for a static file to be handled by BrowserSync or a backend request to proxy. + * + * The existing test is a standard check on the files extensions but it may fail + * for your needs. If you can, you could also check on a context in the url which + * may be more reliable but can't be generic. + */ + if (/\.(html|css|js|png|jpg|jpeg|gif|ico|xml|rss|txt|eot|svg|ttf|woff|cur)(\?((r|v|rel|rev)=[\-\.\w]*)?)?$/.test(req.url)) { + next(); + } else { + proxy.web(req, res); + } +} + +/* + * This is where you activate or not your proxy. + * + * The first line activate if and the second one ignored it + */ + +//module.exports = [proxyMiddleware]; +module.exports = []; diff --git a/gulp/publish.js b/gulp/publish.js new file mode 100644 index 0000000..03a6f25 --- /dev/null +++ b/gulp/publish.js @@ -0,0 +1,43 @@ +'use strict'; + +var gulp = require('gulp'); + +var awspublish = require('gulp-awspublish'); + +gulp.task('publish', function() { + + // create a new publisher using S3 options + // http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/S3.html#constructor-property + var publisher = awspublish.create({ + params: { + //Bucket: "support-admin.topcoder-dev.com" + Bucket: process.env.AWS_BUCKET + } + , + "accessKeyId": process.env.AWS_KEY, + "secretAccessKey": process.env.AWS_SECRET + }); + + // define custom headers + var headers = { + 'Cache-Control': 'max-age=0, no-transform, public' + }; + + return gulp.src(['./dist/**/*','./dist/*']) + // gzip, Set Content-Encoding headers and add .gz extension + // kohata: commented out to avoid the issue (https://github.com/pgherveou/gulp-awspublish/issues/86) + //.pipe(awspublish.gzip()) + + // publisher will add Content-Length, Content-Type and headers specified above + // If not specified it will set x-amz-acl to public-read by default + .pipe(publisher.publish(headers)) + + // create a cache file to speed up consecutive uploads + .pipe(publisher.cache()) + + // remove old files from the destination + .pipe(publisher.sync()) + + // print upload updates to console + .pipe(awspublish.reporter()); +}); diff --git a/gulp/server.js b/gulp/server.js new file mode 100755 index 0000000..5740a54 --- /dev/null +++ b/gulp/server.js @@ -0,0 +1,58 @@ +'use strict'; + +var gulp = require('gulp'); + +var paths = gulp.paths; + +var util = require('util'); + +var browserSync = require('browser-sync'); + +var middleware = require('./proxy'); + +function browserSyncInit(baseDir, files, browser) { + browser = browser === undefined ? 'default' : browser; + + var routes = null; + if(baseDir === paths.src || (util.isArray(baseDir) && baseDir.indexOf(paths.src) !== -1)) { + routes = { + '/bower_components': 'bower_components' + }; + } + + browserSync.instance = browserSync.init(files, { + startPath: '/', + server: { + baseDir: baseDir, + middleware: middleware, + routes: routes + }, + browser: browser + }); +} + +gulp.task('serve', ['watch'], function () { + browserSyncInit([ + paths.tmp + '/serve', + paths.src + ], [ + paths.tmp + '/serve/{app,components}/**/*.css', + paths.src + '/{app,components}/**/*.js', + paths.src + 'src/assets/images/**/*', + paths.tmp + '/serve/*.html', + paths.tmp + '/serve/{app,components}/**/*.html', + paths.src + '/{app,components}/**/*.html' + ]); +}); + +gulp.task('serve:dist', ['build'], function () { + browserSyncInit(paths.dist); +}); + +gulp.task('serve:e2e', ['inject'], function () { + browserSyncInit([paths.tmp + '/serve', paths.src], null, []); +}); + +gulp.task('serve:e2e-dist', ['build'], function () { + browserSyncInit(paths.dist, null, []); +}); diff --git a/gulp/styles.js b/gulp/styles.js new file mode 100755 index 0000000..a033b26 --- /dev/null +++ b/gulp/styles.js @@ -0,0 +1,53 @@ +'use strict'; + +var gulp = require('gulp'); + +var paths = gulp.paths; + +var $ = require('gulp-load-plugins')(); + +gulp.task('styles', function () { + + var lessOptions = { + paths: [ + 'bower_components', + paths.src + '/app', + paths.src + '/components' + ] + }; + + var injectFiles = gulp.src([ + paths.src + '/{app,components}/**/*.less', + '!' + paths.src + '/app/index.less', + '!' + paths.src + '/app/vendor.less' + ], { read: false }); + + var injectOptions = { + transform: function(filePath) { + filePath = filePath.replace(paths.src + '/app/', ''); + filePath = filePath.replace(paths.src + '/components/', '../components/'); + return '@import \'' + filePath + '\';'; + }, + starttag: '// injector', + endtag: '// endinjector', + addRootSlash: false + }; + + var indexFilter = $.filter('index.less'); + + return gulp.src([ + paths.src + '/app/index.less', + paths.src + '/app/vendor.less' + ]) + .pipe(indexFilter) + .pipe($.inject(injectFiles, injectOptions)) + .pipe(indexFilter.restore()) + .pipe($.less()) + + .pipe($.autoprefixer()) + .on('error', function handleError(err) { + console.error(err.toString()); + this.emit('end'); + }) + .pipe(gulp.dest(paths.tmp + '/serve/app/')); +}); diff --git a/gulp/unit-tests.js b/gulp/unit-tests.js new file mode 100755 index 0000000..f13a9c0 --- /dev/null +++ b/gulp/unit-tests.js @@ -0,0 +1,35 @@ +'use strict'; + +var gulp = require('gulp'); + +var $ = require('gulp-load-plugins')(); + +var wiredep = require('wiredep'); + +var paths = gulp.paths; + +function runTests (singleRun, done) { + var bowerDeps = wiredep({ + directory: 'bower_components', + exclude: ['bootstrap-sass-official'], + dependencies: true, + devDependencies: true + }); + + var testFiles = bowerDeps.js.concat([ + paths.src + '/{app,components}/**/*.js' + ]); + + gulp.src(testFiles) + .pipe($.karma({ + configFile: 'karma.conf.js', + action: (singleRun)? 'run': 'watch' + })) + .on('error', function (err) { + // Make sure failed tests cause gulp to exit non-zero + throw err; + }); +} + +gulp.task('test', function (done) { runTests(true /* singleRun */, done) }); +gulp.task('test:auto', function (done) { runTests(false /* singleRun */, done) }); diff --git a/gulp/watch.js b/gulp/watch.js new file mode 100755 index 0000000..61c90a2 --- /dev/null +++ b/gulp/watch.js @@ -0,0 +1,14 @@ +'use strict'; + +var gulp = require('gulp'); + +var paths = gulp.paths; + +gulp.task('watch', ['inject'], function () { + gulp.watch([ + paths.src + '/*.html', + paths.src + '/{app,components}/**/*.less', + paths.src + '/{app,components}/**/*.js', + 'bower.json' + ], ['inject']); +}); diff --git a/gulpfile.js b/gulpfile.js new file mode 100755 index 0000000..19e88c5 --- /dev/null +++ b/gulpfile.js @@ -0,0 +1,16 @@ +'use strict'; + +var gulp = require('gulp'); + +gulp.paths = { + src: 'src', + dist: 'dist', + tmp: '.tmp', + e2e: 'e2e' +}; + +require('require-dir')('./gulp'); + +gulp.task('default', ['clean'], function () { + gulp.start('build'); +}); diff --git a/karma.conf.js b/karma.conf.js new file mode 100755 index 0000000..12e3ff3 --- /dev/null +++ b/karma.conf.js @@ -0,0 +1,17 @@ +'use strict'; + +module.exports = function(config) { + + config.set({ + autoWatch : false, + + frameworks: ['jasmine'], + + browsers : ['PhantomJS'], + + plugins : [ + 'karma-phantomjs-launcher', + 'karma-jasmine' + ] + }); +}; diff --git a/package.json b/package.json new file mode 100755 index 0000000..5628322 --- /dev/null +++ b/package.json @@ -0,0 +1,48 @@ +{ + "name": "support-admin-app", + "version": "2.3.0", + "dependencies": {}, + "devDependencies": { + "bower": "~1.4.1", + "browser-sync": "~1.7.1", + "chalk": "~0.5.1", + "del": "~0.1.3", + "gulp": "~3.8.10", + "gulp-angular-filesort": "~1.0.4", + "gulp-angular-templatecache": "~1.4.2", + "gulp-autoprefixer": "~2.0.0", + "gulp-awspublish": "^3.0.1", + "gulp-consolidate": "~0.1.2", + "gulp-csso": "~0.2.9", + "gulp-filter": "~1.0.2", + "gulp-flatten": "~0.0.4", + "gulp-inject": "~1.0.2", + "gulp-jshint": "~1.9.0", + "gulp-karma": "~0.0.4", + "gulp-less": "~1.3.6", + "gulp-load-plugins": "~0.7.1", + "gulp-minify-html": "~0.1.7", + "gulp-ng-annotate": "~1.0.0", + "gulp-protractor": "~0.0.11", + "gulp-rename": "~1.2.0", + "gulp-replace": "~0.5.0", + "gulp-rev": "~2.0.1", + "gulp-rev-replace": "~0.3.1", + "gulp-size": "~1.1.0", + "gulp-uglify": "~1.0.1", + "gulp-useref": "~1.0.2", + "gulp-ng-config": "~1.2.1", + "http-proxy": "~1.7.0", + "jshint-stylish": "~1.0.0", + "karma-jasmine": "~0.3.1", + "karma-phantomjs-launcher": "~0.1.4", + "main-bower-files": "~2.4.0", + "protractor": "~1.4.0", + "require-dir": "~0.1.0", + "uglify-save-license": "~0.4.1", + "wiredep": "~2.2.0" + }, + "engines": { + "node": ">=0.10.0" + } +} diff --git a/protractor.conf.js b/protractor.conf.js new file mode 100755 index 0000000..0f43a9e --- /dev/null +++ b/protractor.conf.js @@ -0,0 +1,25 @@ +'use strict'; + +var paths = require('./.yo-rc.json')['generator-gulp-angular'].props.paths; + +// An example configuration file. +exports.config = { + // The address of a running selenium server. + //seleniumAddress: 'http://localhost:4444/wd/hub', + //seleniumServerJar: deprecated, this should be set on node_modules/protractor/config.json + + // Capabilities to be passed to the webdriver instance. + capabilities: { + 'browserName': 'chrome' + }, + + // Spec patterns are relative to the current working directly when + // protractor is called. + specs: [paths.e2e + '/**/*.js'], + + // Options to be passed to Jasmine-node. + jasmineNodeOpts: { + showColors: true, + defaultTimeoutInterval: 30000 + } +}; diff --git a/src/app/app.js b/src/app/app.js new file mode 100755 index 0000000..ea2e68a --- /dev/null +++ b/src/app/app.js @@ -0,0 +1,64 @@ +'use strict'; + +/** + * support-admin-app + */ +angular.module('supportAdminApp', [ + 'ngAnimate', + 'ngCookies', + 'ngTouch', + 'ngSanitize', + 'ngResource', + 'ui.router', + 'ui.bootstrap', + 'app.constants', + 'appirio-tech-ng-api-services', + 'appirio-tech-ng-auth', + 'ui.footable']) + // In the run phase of your Angular application + .run(function($rootScope, $location, AuthService, $state, UserV3Service) { + // Listen to '$locationChangeSuccess', not '$stateChangeStart' + $rootScope.$on('$stateChangeStart', function(event, toState, toParams, fromState, fromParams) { + if(toState.name === "login") { + return; + } + console.log('state changed. loggedIn: '+AuthService.isLoggedIn()); // debug + if(!AuthService.isLoggedIn()) { + $state.go('login'); + } else { + UserV3Service.loadUser().then(function(currentUser) { + $rootScope.currentUser = currentUser; + $state.go(toState) + }); + } + }) + }) + .config(function ($stateProvider, $urlRouterProvider, $locationProvider) { + + $stateProvider + .state('login', { + url: "/login", + templateUrl: "app/login/login.html", + data: { pageTitle: 'Login' } + }) + .state('index', { + abstract: true, + url: "/index", + templateUrl: "components/common/content.html", + }) + .state('index.main', { + url: "/main", + templateUrl: "app/main/main.html", + data: { pageTitle: 'Dashboard' } + }) + .state('index.users', { + url: "/users", + templateUrl: "app/users/users.html", + data: { pageTitle: 'User Management' } + }); + + $urlRouterProvider.otherwise('/login'); + + //$locationProvider.html5Mode(true).hashPrefix('!'); + }) +; diff --git a/src/app/directives.js b/src/app/directives.js new file mode 100755 index 0000000..d22b310 --- /dev/null +++ b/src/app/directives.js @@ -0,0 +1,40 @@ +'use strict'; + +//Directive used to set metisMenu and minimalize button +angular.module('supportAdminApp') + .directive('sideNavigation', function ($timeout) { + return { + restrict: 'A', + link: function (scope, element) { + // Call metsi to build when user signup + scope.$watch('authentication.user', function() { + $timeout(function() { + element.metisMenu(); + }); + }); + + } + }; + }) + .directive('minimalizaSidebar', function ($timeout) { + return { + restrict: 'A', + template: '', + controller: function ($scope, $element) { + $scope.minimalize = function () { + angular.element('body').toggleClass('mini-navbar'); + if (!angular.element('body').hasClass('mini-navbar') || angular.element('body').hasClass('body-small')) { + // Hide menu in order to smoothly turn on when maximize menu + angular.element('#side-menu').hide(); + // For smoothly turn on menu + $timeout(function () { + angular.element('#side-menu').fadeIn(500); + }, 100); + } else { + // Remove all inline style from jquery fadeIn function to reset menu state + angular.element('#side-menu').removeAttr('style'); + } + }; + } + }; + }); diff --git a/src/app/index.less b/src/app/index.less new file mode 100755 index 0000000..508b38f --- /dev/null +++ b/src/app/index.less @@ -0,0 +1,2 @@ +@import '/less/style.less'; +@nav-profil-pattern: url("../assets/images/patterns/header-profile.png") no-repeat; \ No newline at end of file diff --git a/src/app/inspinia.js b/src/app/inspinia.js new file mode 100755 index 0000000..5fed843 --- /dev/null +++ b/src/app/inspinia.js @@ -0,0 +1,52 @@ +/** + * INSPINIA - Responsive Admin Theme + * 2.3 + * + * Custom scripts + */ + +$(document).ready(function () { + + + // Full height + function fix_height() { + var heightWithoutNavbar = $("body > #wrapper").height() - 61; + $(".sidebard-panel").css("min-height", heightWithoutNavbar + "px"); + + var navbarHeigh = $('nav.navbar-default').height(); + var wrapperHeigh = $('#page-wrapper').height(); + + if (navbarHeigh > wrapperHeigh) { + $('#page-wrapper').css("min-height", navbarHeigh + "px"); + } + + if (navbarHeigh < wrapperHeigh) { + $('#page-wrapper').css("min-height", $(window).height() + "px"); + } + + if ($('body').hasClass('fixed-nav')) { + $('#page-wrapper').css("min-height", $(window).height() - 60 + "px"); + } + } + + $(window).bind("load resize scroll", function () { + if (!$("body").hasClass('body-small')) { + fix_height(); + } + }) + + setTimeout(function () { + fix_height(); + }) +}); + +// Minimalize menu when screen is less than 768px +$(function () { + $(window).bind("load resize", function () { + if ($(this).width() < 769) { + $('body').addClass('body-small') + } else { + $('body').removeClass('body-small') + } + }) +}); diff --git a/src/app/less/badgets_labels.less b/src/app/less/badgets_labels.less new file mode 100755 index 0000000..b7a729e --- /dev/null +++ b/src/app/less/badgets_labels.less @@ -0,0 +1,67 @@ + +.label { + background-color: @light-gray; + color: @label-badget-color; + font-family: 'Open Sans'; + font-size: 10px; + font-weight: 600; + padding: 3px 8px; + text-shadow: none; +} + +.badge { + background-color: @light-gray; + color: @label-badget-color; + font-family: 'Open Sans'; + font-size: 11px; + font-weight: 600; + padding-bottom: 4px; + padding-left: 6px; + padding-right: 6px; + text-shadow: none; +} + +.label-primary, .badge-primary { + background-color: @navy; + color: #FFFFFF; +} + +.label-success, .badge-success { + background-color: @blue; + color: #FFFFFF; +} + +.label-warning, .badge-warning { + background-color: @yellow; + color: #FFFFFF; +} + +.label-warning-light, .badge-warning-light { + background-color: @yellow; + color: #ffffff; +} + +.label-danger, .badge-danger { + background-color: @red; + color: #FFFFFF; +} + +.label-info, .badge-info { + background-color: @lazur; + color: #FFFFFF; +} + +.label-inverse, .badge-inverse { + background-color: #262626; + color: #FFFFFF; +} + +.label-white, .badge-white { + background-color: #FFFFFF; + color: #5E5E5E; +} + +.label-white, .badge-disable { + background-color: #2A2E36; + color: #8B91A0; +} diff --git a/src/app/less/base.less b/src/app/less/base.less new file mode 100755 index 0000000..1dc85b4 --- /dev/null +++ b/src/app/less/base.less @@ -0,0 +1,1293 @@ +body { + font-family: "open sans", "Helvetica Neue", Helvetica, Arial, sans-serif; + background-color: #2f4050; + font-size: 13px; + color: @text-color; + overflow-x: hidden; + +} + +html,body { + height: 100%; + +} + +body.full-height-layout #wrapper, +body.full-height-layout #page-wrapper { + height: 100%; +} + +#page-wrapper { + min-height: auto; +} + +body.boxed-layout { + background: @boxed-backgound; +} + +body.boxed-layout #wrapper { + background-color: #2f4050; + max-width: @boxed-width; + margin: 0 auto; + -webkit-box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.75); + -moz-box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.75); + box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.75); +} + +.top-navigation.boxed-layout #wrapper, +.boxed-layout #wrapper.top-navigation { + max-width: 1300px !important; +} + +.block { + display: block; +} + +.clear { + display: block; + overflow: hidden; +} + +a { + cursor: pointer; +} + +a:hover, a:focus { + text-decoration: none; +} + +.border-bottom { + border-bottom: 1px solid @border-color !important; +} + +.font-bold { + font-weight: 600; +} + +.font-noraml { + font-weight: 400; +} + + + +.text-uppercase { + text-transform: uppercase; +} + +.b-r { + border-right: 1px solid @border-color; +} + +.hr-line-dashed { + border-top: 1px dashed @border-color; + color: #ffffff; + background-color: #ffffff; + height: 1px; + margin: 20px 0; +} + +.hr-line-solid { + border-bottom: 1px solid @border-color; + background-color: rgba(0, 0, 0, 0); + border-style: solid !important; + margin-top: 15px; + margin-bottom: 15px; +} + +video { + width: 100% !important; + height: auto !important; +} + +/* GALLERY */ +.gallery > .row > div { + margin-bottom: 15px; +} + +.fancybox img { + margin-bottom: 5px; + /* Only for demo */ + width: 24%; +} + +/* Summernote text editor */ +.note-editor { + height: auto !important; + min-height: 300px; +} + +/* MODAL */ +.modal-content { + background-clip: padding-box; + background-color: #FFFFFF; + border: 1px solid rgba(0, 0, 0, 0); + border-radius: 4px; + box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3); + outline: 0 none; + position: relative; +} + +.modal-dialog { + z-index: 2200; +} + +.modal-body { + padding: 20px 30px 30px 30px; +} + + +.inmodal .modal-body { + background: #f8fafb; +} + +.inmodal .modal-header { + padding: 30px 15px; + text-align: center; +} + +.animated.modal.fade .modal-dialog { + -webkit-transform: none; + -ms-transform: none; + -o-transform: none; + transform: none; +} + +.inmodal .modal-title { + font-size: 26px; +} + +.inmodal .modal-icon { + font-size: 84px; + color: #e2e3e3; +} + +.modal-footer { + margin-top: 0; +} + + +/* WRAPPERS */ + +#wrapper { + width: 100%; + overflow-x: hidden; +} + +.wrapper { + padding: 0 20px; +} + +.wrapper-content { + padding: 20px 10px 40px; +} + +#page-wrapper { + padding: 0 15px; + min-height: 568px; + position: relative !important; +} + +@media (min-width: 768px) { + #page-wrapper { + position: inherit; + margin: 0 0 0 240px; + min-height: 1000px; + } +} + +.title-action { + text-align: right; + padding-top: 30px; +} + +.ibox-content h1, .ibox-content h2, .ibox-content h3, .ibox-content h4, .ibox-content h5, +.ibox-title h1, .ibox-title h2, .ibox-title h3, .ibox-title h4, .ibox-title h5 { + margin-top: 5px; +} + +ul.unstyled, ol.unstyled { + list-style: none outside none; + margin-left: 0; +} + +.big-icon { + font-size: 160px !important; + color: #e5e6e7; +} + + +/* FOOTER */ + +.footer { + + background: none repeat scroll 0 0 white; + border-top: 1px solid @border-color; + bottom: 0; + left: 0; + padding: 10px 20px; + position: absolute; + right: 0; +} + +.footer.fixed_full { + position: fixed; + bottom: 0; + left: 0; + right: 0; + z-index: 1000; + padding:10px 20px; + background: white; + border-top: 1px solid @border-color; +} + +.footer.fixed { + position: fixed; + bottom: 0; + left: 0; + right: 0; + z-index: 1000; + padding:10px 20px; + background: white; + border-top: 1px solid @border-color; + margin-left: @sidebar-width; +} + +body.mini-navbar .footer.fixed, +body.body-small.mini-navbar .footer.fixed { + margin: 0 0 0 70px; +} + +body.mini-navbar.canvas-menu .footer.fixed, +body.canvas-menu .footer.fixed { + margin: 0 !important; +} + +body.fixed-sidebar.body-small.mini-navbar .footer.fixed { + margin: 0 0 0 @sidebar-width; +} + +body.body-small .footer.fixed { + margin-left: 0px; +} + +/* PANELS */ + +.page-heading { + border-top: 0; + padding: 0px 10px 20px 10px; +} + +.panel-heading h1, .panel-heading h2 { + margin-bottom: 5px; +} + +/* TABLES */ + +.table-bordered { + border: 1px solid #EBEBEB; +} + +.table-bordered > thead > tr > th, .table-bordered > thead > tr > td { + background-color: #F5F5F6; + border-bottom-width: 1px; +} + +.table-bordered > thead > tr > th, .table-bordered > tbody > tr > th, .table-bordered > tfoot > tr > th, .table-bordered > thead > tr > td, .table-bordered > tbody > tr > td, .table-bordered > tfoot > tr > td { + border: 1px solid #e7e7e7; +} + +.table > thead > tr > th { + border-bottom: 1px solid #DDDDDD; + vertical-align: bottom; +} + +.table > thead > tr > th, .table > tbody > tr > th, .table > tfoot > tr > th, .table > thead > tr > td, .table > tbody > tr > td, .table > tfoot > tr > td { + border-top: 1px solid @border-color; + line-height: 1.42857; + padding: 8px; + vertical-align: top; +} + +/* PANELS */ + +.panel.blank-panel { + background: none; + margin: 0; +} + +.blank-panel .panel-heading { + padding-bottom: 0; +} + +.nav-tabs > li.active > a, .nav-tabs > li.active > a:hover, .nav-tabs > li.active > a:focus { + -moz-border-bottom-colors: none; + -moz-border-left-colors: none; + -moz-border-right-colors: none; + -moz-border-top-colors: none; + background: none; + border-color: #DDDDDD #DDDDDD rgba(0, 0, 0, 0); + border-bottom: @gray; + border-image: none; + border-style: solid; + border-width: 1px; + color: #555555; + cursor: default; +} + +.nav.nav-tabs li { + background: none; + border: none; +} + +.nav-tabs > li > a { + color: #A7B1C2; + font-weight: 600; + padding: 10px 20px 10px 25px; +} + +.nav-tabs > li > a:hover, .nav-tabs > li > a:focus { + background-color: #e6e6e6; + color: @text-color; +} + +.ui-tab .tab-content { + padding: 20px 0px; +} + +/* GLOBAL */ + +.no-padding { + padding: 0 !important; +} + +.no-borders { + border: none !important; +} + +.no-margins { + margin: 0 !important; +} + +.no-top-border { + border-top: 0 !important; +} + +.ibox-content.text-box { + padding-bottom: 0px; + padding-top: 15px; +} + +.border-left-right { + border-left: 1px solid @border-color; + border-right: 1px solid @border-color; + border-top: none; + border-bottom: none; +} + +.border-left{ + border-left: 1px solid @border-color; + border-right: none; + border-top: none; + border-bottom: none; +} + +.border-right { + border-left: none; + border-right: 1px solid @border-color; + border-top: none; + border-bottom: none; +} + +.full-width { + width: 100% !important; +} + +.link-block { + font-size: 12px; + padding: 10px; +} + +.nav.navbar-top-links .link-block a { + font-size: 12px; +} + +.link-block a { + font-size: 10px; + color: inherit; + +} + +body.mini-navbar .branding { + display: none; +} + +img.circle-border { + border: 6px solid #FFFFFF; + border-radius: 50%; +} + +.branding { + float: left; + color: #FFFFFF; + font-size: 18px; + font-weight: 600; + padding: 17px 20px; + text-align: center; + background-color: @navy; +} + +.login-panel { + margin-top: 25%; +} + +.icons-box h3 { + margin-top: 10px; + margin-bottom: 10px; +} + +.icons-box .infont a i { + font-size: 25px; + display: block; + color: @text-color; +} + +.icons-box .infont a { + color: #a6a8a9; +} + +.icons-box .infont a { + padding: 10px; + + margin: 1px; + display: block; +} + +.ui-draggable .ibox-title { + cursor: move; +} + +.breadcrumb { + background-color: #ffffff; + padding: 0; + margin-bottom: 0; +} + +.breadcrumb > li a { + color: inherit; +} + +.breadcrumb > .active { + color: inherit; +} + +code { + background-color: #F9F2F4; + border-radius: 4px; + color: #ca4440; + font-size: 90%; + padding: 2px 4px; + white-space: nowrap; +} + +.ibox { + clear: both; + margin-bottom: 25px; + margin-top: 0; + padding: 0; +} + +.ibox.collapsed .ibox-content{ + display: none; +} +.ibox.collapsed .fa.fa-chevron-up:before { + content: "\f078"; +} +.ibox.collapsed .fa.fa-chevron-down:before { + content: "\f077"; +} + +.ibox:after, .ibox:before { + display: table; +} + +.ibox-title { + -moz-border-bottom-colors: none; + -moz-border-left-colors: none; + -moz-border-right-colors: none; + -moz-border-top-colors: none; + background-color: @ibox-title-bg; + border-color: @border-color; + border-image: none; + border-style: solid solid none; + border-width: 3px 0 0; + color: inherit; + margin-bottom: 0; + padding: 14px 15px 7px; + min-height: 48px; +} + +.ibox-content { + background-color: @ibox-content-bg; + color: inherit; + padding: 15px 20px 20px 20px; + + border-color: @border-color; + border-image: none; + border-style: solid solid none; + border-width: 1px 0px; +} + +.ibox-footer { + color: inherit; + border-top: 1px solid @border-color; + font-size: 90%; + background: #ffffff; + padding: 10px 15px; +} + +table.table-mail tr td { + padding: 12px; +} + +.table-mail .check-mail { + padding-left: 20px; +} + +.table-mail .mail-date { + padding-right: 20px; +} + +.star-mail, .check-mail { + width: 40px; +} + +.unread td a, .unread td { + font-weight: 600; + color: inherit; +} + +.read td a, .read td { + font-weight: normal; + color: inherit; +} + +.unread td { + background-color: #f9f8f8; +} + +.ibox-content { + clear: both; +} + +.ibox-heading { + background-color: #f3f6fb; + border-bottom: none; +} + +.ibox-heading h3 { + font-weight: 200; + font-size: 24px; +} + +.ibox-title h5 { + display: inline-block; + font-size: 14px; + margin: 0 0 7px; + padding: 0; + text-overflow: ellipsis; + float: left; +} + +.ibox-title .label { + float: left; + margin-left: 4px; +} + +.ibox-tools { + display: block; + float: none; + margin-top: 0; + position: relative; + padding: 0; + text-align: right; +} + +.ibox-tools a { + cursor: pointer; + margin-left: 5px; + color: #c4c4c4; +} + +.ibox-tools a.btn-primary { + color: #fff; +} + +.ibox-tools .dropdown-menu > li > a { + padding: 4px 10px; + font-size: 12px; +} + +.ibox .ibox-tools.open > .dropdown-menu { + left: auto; + right: 0; +} + +/* BACKGROUNDS */ + +.gray-bg { + background-color: @gray; +} + +.white-bg { + background-color: #ffffff; +} + +.navy-bg { + background-color: @navy; + color: #ffffff; +} + +.blue-bg { + background-color: @blue; + color: #ffffff; +} + +.lazur-bg { + background-color: @lazur; + color: #ffffff; +} + +.yellow-bg { + background-color: @yellow; + color: #ffffff; +} + +.red-bg { + background-color: @red; + color: #ffffff; +} + +.black-bg { + background-color: #262626; +} + +.panel-primary { + border-color: @navy; +} + +.panel-primary > .panel-heading { + background-color: @navy; + border-color: @navy; +} + +.panel-success { + border-color: @blue; +} + +.panel-success > .panel-heading { + background-color: @blue; + border-color: @blue; + color: #ffffff; +} + +.panel-info { + border-color: @lazur; +} + +.panel-info > .panel-heading { + background-color: @lazur; + border-color: @lazur; + color: #ffffff; +} + +.panel-warning { + border-color: @yellow; +} + +.panel-warning > .panel-heading { + background-color: @yellow; + border-color: @yellow; + color: #ffffff; +} + +.panel-danger { + border-color: @red; +} + +.panel-danger > .panel-heading { + background-color: @red; + border-color: @red; + color: #ffffff; +} + +.progress-bar { + background-color: @navy; +} + +.progress-small, .progress-small .progress-bar { + height: 10px; +} + +.progress-small, .progress-mini { + margin-top: 5px; +} + +.progress-mini, .progress-mini .progress-bar { + height: 5px; + margin-bottom: 0px; +} + +.progress-bar-navy-light { + background-color: #3dc7ab; +} + +.progress-bar-success { + background-color: @blue; +} + +.progress-bar-info { + background-color: @lazur; +} + +.progress-bar-warning { + background-color: @yellow; +} + +.progress-bar-danger { + background-color: @red; +} + +.panel-title { + font-size: inherit; +} + +.jumbotron { + border-radius: 6px; + padding: 40px; +} + +.jumbotron h1 { + margin-top: 0; +} + +/* COLORS */ + +.text-navy { + color: @navy; +} + +.text-primary { + color: inherit; +} + +.text-success { + color: @blue; +} + +.text-info { + color: @lazur; +} + +.text-warning { + color: @yellow; +} + +.text-danger { + color: @red; +} + +.text-muted { + color: #888888; +} + +.text-white { + color: #ffffff; +} + +.simple_tag { + background-color: #f3f3f4; + border: 1px solid #e7eaec; + border-radius: 2px; + color: inherit; + font-size: 10px; + margin-right: 5px; + margin-top: 5px; + padding: 5px 12px; + display: inline-block; +} + +.img-shadow { + -webkit-box-shadow: 0px 0px 3px 0px rgba(145,145,145,1); + -moz-box-shadow: 0px 0px 3px 0px rgba(145,145,145,1); + box-shadow: 0px 0px 3px 0px rgba(145,145,145,1); +} + +/* For handle diferent bg color in AngularJS version */ +.dashboards\.dashboard_2 nav.navbar, +.dashboards\.dashboard_3 nav.navbar, +.mailbox\.inbox nav.navbar, +.mailbox\.email_view nav.navbar, +.mailbox\.email_compose nav.navbar, +.dashboards\.dashboard_4_1 nav.navbar, +.metrics nav.navbar, .metrics\.index nav.navbar, +.dashboards\.dashboard_5 nav.navbar +{ + background: #fff; +} + +/* For handle diferent bg color in MVC version */ +.Dashboard_2 .navbar.navbar-static-top, +.Dashboard_3 .navbar.navbar-static-top, +.Dashboard_4_1 .navbar.navbar-static-top, +.ComposeEmail .navbar.navbar-static-top, +.EmailView .navbar.navbar-static-top, +.Inbox .navbar.navbar-static-top, +.Metrics .navbar.navbar-static-top, +.Dashboard_5 .navbar.navbar-static-top +{ + background: #fff; +} + + +a.close-canvas-menu { + position: absolute; + top:10px; + right: 15px; + z-index: 1011; + color: #a7b1c2; +} + +a.close-canvas-menu:hover { + color: #fff; +} + +/* FULL HEIGHT */ + + +.full-height { + height: 100%; +} + +.fh-breadcrumb { + height: calc(~"100% - 196px"); + margin: 0 -15px; + position: relative +} + +.fh-no-breadcrumb { + height: calc(~"100% - 99px"); + margin: 0 -15px; + position: relative +} + +.fh-column { + background: #fff; + height: 100%; + width: 240px; + float: left +} + +.modal-backdrop { + z-index: 2040 !important; +} + +.modal { + z-index: 2050 !important; +} + +.spiner-example { + height: 200px; + padding-top: 70px; +} + +/* MARGINS & PADDINGS */ + +.p-xxs { + padding: 5px; +} + +.p-xs { + padding: 10px; +} + +.p-sm { + padding: 15px; +} + +.p-m { + padding: 20px; +} + +.p-md { + padding: 25px; +} + +.p-lg { + padding: 30px; +} + +.p-xl { + padding: 40px; +} + +.p-w-xs { + padding: 0 10px; +} + +.p-w-sm { + padding: 0 15px; + +} + +.p-w-m { + padding: 0 20px; + +} + +.p-w-md { + padding: 0 25px; + +} + +.p-w-lg { + padding: 0 30px; + +} + +.p-w-xl { + padding: 0 40px; + +} + +.m-xxs { + margin: 2px 4px; +} + +.m-xs { + margin: 5px; +} + +.m-sm { + margin: 10px; +} + +.m { + margin: 15px; +} + +.m-md { + margin: 20px; +} + +.m-lg { + margin: 30px; +} + +.m-xl { + margin: 50px; +} + +.m-n { + margin: 0 !important; +} + +.m-l-none { + margin-left: 0; +} + +.m-l-xs { + margin-left: 5px; +} + +.m-l-sm { + margin-left: 10px; +} + +.m-l { + margin-left: 15px; +} + +.m-l-md { + margin-left: 20px; +} + +.m-l-lg { + margin-left: 30px; +} + +.m-l-xl { + margin-left: 40px; +} + +.m-l-n-xxs { + margin-left: -1px; +} + +.m-l-n-xs { + margin-left: -5px; +} + +.m-l-n-sm { + margin-left: -10px; +} + +.m-l-n { + margin-left: -15px; +} + +.m-l-n-md { + margin-left: -20px; +} + +.m-l-n-lg { + margin-left: -30px; +} + +.m-l-n-xl { + margin-left: -40px; +} + +.m-t-none { + margin-top: 0; +} + +.m-t-xxs { + margin-top: 1px; +} + +.m-t-xs { + margin-top: 5px; +} + +.m-t-sm { + margin-top: 10px; +} + +.m-t { + margin-top: 15px; +} + +.m-t-md { + margin-top: 20px; +} + +.m-t-lg { + margin-top: 30px; +} + +.m-t-xl { + margin-top: 40px; +} + +.m-t-n-xxs { + margin-top: -1px; +} + +.m-t-n-xs { + margin-top: -5px; +} + +.m-t-n-sm { + margin-top: -10px; +} + +.m-t-n { + margin-top: -15px; +} + +.m-t-n-md { + margin-top: -20px; +} + +.m-t-n-lg { + margin-top: -30px; +} + +.m-t-n-xl { + margin-top: -40px; +} + +.m-r-none { + margin-right: 0; +} + +.m-r-xxs { + margin-right: 1px; +} + +.m-r-xs { + margin-right: 5px; +} + +.m-r-sm { + margin-right: 10px; +} + +.m-r { + margin-right: 15px; +} + +.m-r-md { + margin-right: 20px; +} + +.m-r-lg { + margin-right: 30px; +} + +.m-r-xl { + margin-right: 40px; +} + +.m-r-n-xxs { + margin-right: -1px; +} + +.m-r-n-xs { + margin-right: -5px; +} + +.m-r-n-sm { + margin-right: -10px; +} + +.m-r-n { + margin-right: -15px; +} + +.m-r-n-md { + margin-right: -20px; +} + +.m-r-n-lg { + margin-right: -30px; +} + +.m-r-n-xl { + margin-right: -40px; +} + +.m-b-none { + margin-bottom: 0; +} + +.m-b-xxs { + margin-bottom: 1px; +} + +.m-b-xs { + margin-bottom: 5px; +} + +.m-b-sm { + margin-bottom: 10px; +} + +.m-b { + margin-bottom: 15px; +} + +.m-b-md { + margin-bottom: 20px; +} + +.m-b-lg { + margin-bottom: 30px; +} + +.m-b-xl { + margin-bottom: 40px; +} + +.m-b-n-xxs { + margin-bottom: -1px; +} + +.m-b-n-xs { + margin-bottom: -5px; +} + +.m-b-n-sm { + margin-bottom: -10px; +} + +.m-b-n { + margin-bottom: -15px; +} + +.m-b-n-md { + margin-bottom: -20px; +} + +.m-b-n-lg { + margin-bottom: -30px; +} + +.m-b-n-xl { + margin-bottom: -40px; +} + +.space-15 { + margin: 15px 0; +} + +.space-20 { + margin: 20px 0; +} + +.space-25 { + margin: 25px 0; +} + +.space-30 { + margin: 30px 0; +} + +// Fullscreen functions + +.fullscreen-ibox-mode .animated { + animation: none; +} + +body.fullscreen-ibox-mode { + overflow-y: hidden; +} + +.ibox.fullscreen { + z-index: 2030; + position: fixed; + top: 0; + left: 0; + right: 0; + bottom: 0; + overflow: auto; + margin-bottom: 0; +} + +.ibox.fullscreen .collapse-link { + display: none; +} + +.ibox.fullscreen .ibox-content { + min-height: calc(~"100% - 48px"); +} + +// Bootstrap issue in 3.3.0 with modal https://github.com/twbs/bootstrap/issues/9855 +// Fix +body.modal-open { padding-right:inherit !important; } + +// Fix for modal backdrop with animate.css +body.modal-open .animated { animation-fill-mode: initial; } + +/* Show profile dropdown on fixed sidebar */ +body.mini-navbar.fixed-sidebar .profile-element, .block { + display: block !important; +} + +body.mini-navbar.fixed-sidebar .nav-header { + padding: 33px 25px; +} + +body.mini-navbar.fixed-sidebar .logo-element{ + display: none; +} \ No newline at end of file diff --git a/src/app/less/buttons.less b/src/app/less/buttons.less new file mode 100755 index 0000000..246b24a --- /dev/null +++ b/src/app/less/buttons.less @@ -0,0 +1,308 @@ + +.btn { + border-radius: @btn-border-radius; +} + +.float-e-margins .btn { + margin-bottom: 5px; +} + +.btn-w-m { + min-width: 120px; +} + +.btn-primary.btn-outline { + color: @navy; +} + +.btn-success.btn-outline { + color: @blue; +} + +.btn-info.btn-outline { + color: @lazur; +} + +.btn-warning.btn-outline { + color: @yellow; +} + +.btn-danger.btn-outline { + color: @red; +} + +.btn-primary.btn-outline:hover, +.btn-success.btn-outline:hover, +.btn-info.btn-outline:hover, +.btn-warning.btn-outline:hover, +.btn-danger.btn-outline:hover { + color: #fff; +} + +.btn-primary { + background-color: @navy; + border-color: @navy; + color: #FFFFFF; +} + +.btn-primary:hover, .btn-primary:focus, .btn-primary:active, .btn-primary.active, .open .dropdown-toggle.btn-primary, .btn-primary:active:focus, .btn-primary:active:hover, .btn-primary.active:hover, .btn-primary.active:focus { + background-color: darken(@navy, 3%); + border-color: darken(@navy, 3%); + color: #FFFFFF; +} + +.btn-primary:active, .btn-primary.active, .open .dropdown-toggle.btn-primary { + background-image: none; +} + +.btn-primary.disabled, .btn-primary.disabled:hover, .btn-primary.disabled:focus, .btn-primary.disabled:active, .btn-primary.disabled.active, .btn-primary[disabled], .btn-primary[disabled]:hover, .btn-primary[disabled]:focus, .btn-primary[disabled]:active, .btn-primary.active[disabled], fieldset[disabled] .btn-primary, fieldset[disabled] .btn-primary:hover, fieldset[disabled] .btn-primary:focus, fieldset[disabled] .btn-primary:active, fieldset[disabled] .btn-primary.active { + background-color: lighten(@navy, 4%); + border-color: lighten(@navy, 4%); +} + +.btn-success { + background-color: @blue; + border-color: @blue; + color: #FFFFFF; +} + +.btn-success:hover, .btn-success:focus, .btn-success:active, .btn-success.active, .open .dropdown-toggle.btn-success, .btn-success:active:focus, .btn-success:active:hover, .btn-success.active:hover, .btn-success.active:focus { + background-color: darken(@blue, 3%); + border-color: darken(@blue, 3%); + color: #FFFFFF; +} + +.btn-success:active, .btn-success.active, .open .dropdown-toggle.btn-success { + background-image: none; +} + +.btn-success.disabled, .btn-success.disabled:hover, .btn-success.disabled:focus, .btn-success.disabled:active, .btn-success.disabled.active, .btn-success[disabled], .btn-success[disabled]:hover, .btn-success[disabled]:focus, .btn-success[disabled]:active, .btn-success.active[disabled], fieldset[disabled] .btn-success, fieldset[disabled] .btn-success:hover, fieldset[disabled] .btn-success:focus, fieldset[disabled] .btn-success:active, fieldset[disabled] .btn-success.active { + background-color: lighten(@blue, 4%); + border-color: lighten(@blue, 4%); +} + +.btn-info { + background-color: @lazur; + border-color: @lazur; + color: #FFFFFF; +} + +.btn-info:hover, .btn-info:focus, .btn-info:active, .btn-info.active, .open .dropdown-toggle.btn-info, .btn-info:active:focus, .btn-info:active:hover, .btn-info.active:hover, .btn-info.active:focus { + background-color: darken(@lazur, 3%); + border-color: darken(@lazur, 3%); + color: #FFFFFF; +} + +.btn-info:active, .btn-info.active, .open .dropdown-toggle.btn-info { + background-image: none; +} + +.btn-info.disabled, .btn-info.disabled:hover, .btn-info.disabled:focus, .btn-info.disabled:active, .btn-info.disabled.active, .btn-info[disabled], .btn-info[disabled]:hover, .btn-info[disabled]:focus, .btn-info[disabled]:active, .btn-info.active[disabled], fieldset[disabled] .btn-info, fieldset[disabled] .btn-info:hover, fieldset[disabled] .btn-info:focus, fieldset[disabled] .btn-info:active, fieldset[disabled] .btn-info.active { + background-color: lighten(@lazur, 4%); + border-color: lighten(@lazur, 4%); +} + +.btn-default { + background-color: @dark-gray; + border-color: @dark-gray; + color: #FFFFFF; +} + +.btn-default:hover, .btn-default:focus, .btn-default:active, .btn-default.active, .open .dropdown-toggle.btn-default, .btn-default:active:focus, .btn-default:active:hover, .btn-default.active:hover, .btn-default.active:focus { + background-color: darken(@dark-gray, 3%); + border-color: darken(@dark-gray, 3%); + color: #FFFFFF; +} + +.btn-default:active, .btn-default.active, .open .dropdown-toggle.btn-default { + background-image: none; +} + +.btn-default.disabled, .btn-default.disabled:hover, .btn-default.disabled:focus, .btn-default.disabled:active, .btn-default.disabled.active, .btn-default[disabled], .btn-default[disabled]:hover, .btn-default[disabled]:focus, .btn-default[disabled]:active, .btn-default.active[disabled], fieldset[disabled] .btn-default, fieldset[disabled] .btn-default:hover, fieldset[disabled] .btn-default:focus, fieldset[disabled] .btn-default:active, fieldset[disabled] .btn-default.active { + background-color: lighten(@dark-gray, 4%); + border-color: lighten(@dark-gray, 4%); +} + +.btn-warning { + background-color: @yellow; + border-color: @yellow; + color: #FFFFFF; +} + +.btn-warning:hover, .btn-warning:focus, .btn-warning:active, .btn-warning.active, .open .dropdown-toggle.btn-warning, .btn-warning:active:focus, .btn-warning:active:hover, .btn-warning.active:hover, .btn-warning.active:focus { + background-color: darken(@yellow, 3%); + border-color: darken(@yellow, 3%); + color: #FFFFFF; +} + +.btn-warning:active, .btn-warning.active, .open .dropdown-toggle.btn-warning { + background-image: none; +} + +.btn-warning.disabled, .btn-warning.disabled:hover, .btn-warning.disabled:focus, .btn-warning.disabled:active, .btn-warning.disabled.active, .btn-warning[disabled], .btn-warning[disabled]:hover, .btn-warning[disabled]:focus, .btn-warning[disabled]:active, .btn-warning.active[disabled], fieldset[disabled] .btn-warning, fieldset[disabled] .btn-warning:hover, fieldset[disabled] .btn-warning:focus, fieldset[disabled] .btn-warning:active, fieldset[disabled] .btn-warning.active { + background-color: lighten(@yellow, 4%); + border-color: lighten(@yellow, 4%); +} + +.btn-danger { + background-color: @red; + border-color: @red; + color: #FFFFFF; +} + +.btn-danger:hover, .btn-danger:focus, .btn-danger:active, .btn-danger.active, .open .dropdown-toggle.btn-danger, .btn-danger:active:focus, .btn-danger:active:hover, .btn-danger.active:hover, .btn-danger.active:focus { + background-color: darken(@red, 3%); + border-color: darken(@red, 3%); + color: #FFFFFF; +} + +.btn-danger:active, .btn-danger.active, .open .dropdown-toggle.btn-danger { + background-image: none; +} + +.btn-danger.disabled, .btn-danger.disabled:hover, .btn-danger.disabled:focus, .btn-danger.disabled:active, .btn-danger.disabled.active, .btn-danger[disabled], .btn-danger[disabled]:hover, .btn-danger[disabled]:focus, .btn-danger[disabled]:active, .btn-danger.active[disabled], fieldset[disabled] .btn-danger, fieldset[disabled] .btn-danger:hover, fieldset[disabled] .btn-danger:focus, fieldset[disabled] .btn-danger:active, fieldset[disabled] .btn-danger.active { + background-color: lighten(@red, 4%); + border-color: lighten(@red, 4%); +} + +.btn-link { + color: inherit; +} + +.btn-link:hover, .btn-link:focus, .btn-link:active, .btn-link.active, .open .dropdown-toggle.btn-link { + color: @navy; + text-decoration: none; +} + +.btn-link:active, .btn-link.active, .open .dropdown-toggle.btn-link { + background-image: none; +} + +.btn-link.disabled, .btn-link.disabled:hover, .btn-link.disabled:focus, .btn-link.disabled:active, .btn-link.disabled.active, .btn-link[disabled], .btn-link[disabled]:hover, .btn-link[disabled]:focus, .btn-link[disabled]:active, .btn-link.active[disabled], fieldset[disabled] .btn-link, fieldset[disabled] .btn-link:hover, fieldset[disabled] .btn-link:focus, fieldset[disabled] .btn-link:active, fieldset[disabled] .btn-link.active { + color: #cacaca; +} + +.btn-white { + color: inherit; + background: white; + border: 1px solid @border-color; +} + +.btn-white:hover, .btn-white:focus, .btn-white:active, .btn-white.active, .open .dropdown-toggle.btn-white, .btn-white:active:focus, .btn-white:active:hover, .btn-white.active:hover, .btn-white.active:focus{ + color: inherit; + border: 1px solid #d2d2d2; +} + +.btn-white:active, .btn-white.active { + box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15) inset; +} + +.btn-white:active, .btn-white.active, .open .dropdown-toggle.btn-white { + background-image: none; +} + +.btn-white.disabled, .btn-white.disabled:hover, .btn-white.disabled:focus, .btn-white.disabled:active, .btn-white.disabled.active, .btn-white[disabled], .btn-white[disabled]:hover, .btn-white[disabled]:focus, .btn-white[disabled]:active, .btn-white.active[disabled], fieldset[disabled] .btn-white, fieldset[disabled] .btn-white:hover, fieldset[disabled] .btn-white:focus, fieldset[disabled] .btn-white:active, fieldset[disabled] .btn-white.active { + color: #cacaca; +} + +.form-control, .form-control:focus, .has-error .form-control:focus, .has-success .form-control:focus, .has-warning .form-control:focus, .navbar-collapse, .navbar-form, .navbar-form-custom .form-control:focus, .navbar-form-custom .form-control:hover, .open .btn.dropdown-toggle, .panel, .popover, .progress, .progress-bar { + box-shadow: none; +} + +.btn-outline { + color: inherit; + background-color: transparent; + transition: all .5s; +} + +.btn-rounded { + border-radius: 50px; +} + +.btn-large-dim { + width: 90px; + height: 90px; + font-size: 42px; +} + +button.dim { + display: inline-block; + color: #fff; + text-decoration: none; + text-transform: uppercase; + text-align: center; + padding-top: 6px; + margin-right: 10px; + position: relative; + cursor: pointer; + border-radius: 5px; + font-weight: 600; + margin-bottom: 20px !important; +} + +button.dim:active { + top: 3px; +} + +button.btn-primary.dim { + box-shadow: inset 0px 0px 0px darken(@navy,6%), 0px 5px 0px 0px darken(@navy,6%), 0px 10px 5px #999; +} + +button.btn-primary.dim:active { + box-shadow: inset 0px 0px 0px darken(@navy,6%), 0px 2px 0px 0px darken(@navy,6%), 0px 5px 3px #999; +} + +button.btn-default.dim { + box-shadow: inset 0px 0px 0px darken(@dark-gray,6%), 0px 5px 0px 0px darken(@dark-gray,6%), 0px 10px 5px #999; +} + +button.btn-default.dim:active { + box-shadow: inset 0px 0px 0px darken(@dark-gray,6%), 0px 2px 0px 0px darken(@dark-gray,6%), 0px 5px 3px #999; +} + +button.btn-warning.dim { + box-shadow: inset 0px 0px 0px darken(@yellow,6%), 0px 5px 0px 0px darken(@yellow,6%), 0px 10px 5px #999; +} + +button.btn-warning.dim:active { + box-shadow: inset 0px 0px 0px darken(@yellow,6%), 0px 2px 0px 0px darken(@yellow,6%), 0px 5px 3px #999; +} + +button.btn-info.dim { + box-shadow: inset 0px 0px 0px darken(@lazur,6%), 0px 5px 0px 0px darken(@lazur,6%), 0px 10px 5px #999; +} + +button.btn-info.dim:active { + box-shadow: inset 0px 0px 0px darken(@lazur,6%), 0px 2px 0px 0px darken(@lazur,6%), 0px 5px 3px #999; +} + +button.btn-success.dim { + box-shadow: inset 0px 0px 0px darken(@blue,6%), 0px 5px 0px 0px darken(@blue,6%), 0px 10px 5px #999; +} + +button.btn-success.dim:active { + box-shadow: inset 0px 0px 0px darken(@blue,6%), 0px 2px 0px 0px darken(@blue,6%), 0px 5px 3px #999; +} + +button.btn-danger.dim { + box-shadow: inset 0px 0px 0px darken(@red,6%), 0px 5px 0px 0px darken(@red,6%), 0px 10px 5px #999; +} + +button.btn-danger.dim:active { + box-shadow: inset 0px 0px 0px darken(@red,6%), 0px 2px 0px 0px darken(@red,6%), 0px 5px 3px #999; +} + +button.dim:before { + font-size: 50px; + line-height: 1em; + font-weight: normal; + color: #fff; + display: block; + padding-top: 10px; + +} + +button.dim:active:before { + top: 7px; + font-size: 50px; +} diff --git a/src/app/less/chat.less b/src/app/less/chat.less new file mode 100755 index 0000000..65804c3 --- /dev/null +++ b/src/app/less/chat.less @@ -0,0 +1,126 @@ +#small-chat { + position: fixed; + bottom: 20px; + right: 20px; + z-index: 100; +} + +#small-chat .badge { + position: absolute; + top: -3px; + right: -4px; +} + +.open-small-chat { + height: 38px; + width: 38px; + display: block; + background: #1ab394; + padding: 9px 8px; + text-align: center; + color: #fff; + border-radius: 50%; +} + +.open-small-chat:hover { + color: white; + background: #1ab394; +} + + +.small-chat-box { + display: none; + position: fixed; + bottom: 20px; + right: 75px; + background: #fff; + border: 1px solid @border-color; + width: 230px; + height: 320px; + border-radius: 4px; +} + +.small-chat-box.ng-small-chat { + display: block; +} + +.body-small { + .small-chat-box { + bottom: 70px; + right: 20px; + } +} + +.small-chat-box.active { + display: block; +} + +.small-chat-box { + + .heading { + background: @nav-bg; + padding: 8px 15px; + font-weight: bold; + color: #fff; + } + + .chat-date { + opacity: 0.6; + font-size: 10px; + font-weight: normal; + } + + .content { + padding: 15px 15px; + + .author-name { + font-weight: bold; + margin-bottom: 3px; + font-size: 11px; + } + + > div { + padding-bottom: 20px; + } + + .chat-message { + padding: 5px 10px; + border-radius: 6px; + font-size: 11px; + line-height: 14px; + max-width: 80%; + background: #f3f3f4; + margin-bottom: 10px; + } + + .chat-message.active { + background: #1ab394; + color: #fff; + } + + .left { + text-align: left; + clear: both; + + .chat-message { + float: left; + } + } + + .right { + text-align: right; + clear: both; + + .chat-message { + float: right; + } + + } + + } + + .form-chat { + padding: 10px 10px; + } + +} \ No newline at end of file diff --git a/src/app/less/custom.less b/src/app/less/custom.less new file mode 100755 index 0000000..89f8f14 --- /dev/null +++ b/src/app/less/custom.less @@ -0,0 +1,6 @@ +/* Only demo */ +@media (max-width: 1000px) { + .welcome-message { + display: none; + } +} \ No newline at end of file diff --git a/src/app/less/elements.less b/src/app/less/elements.less new file mode 100755 index 0000000..bb071e5 --- /dev/null +++ b/src/app/less/elements.less @@ -0,0 +1,2284 @@ +/* TOOGLE SWICH */ + +.onoffswitch { + position: relative; + width: 64px; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; +} + +.onoffswitch-checkbox { + display: none; +} + +.onoffswitch-label { + display: block; + overflow: hidden; + cursor: pointer; + border: 2px solid @navy; + border-radius: 2px; +} + +.onoffswitch-inner { + width: 200%; + margin-left: -100%; + -moz-transition: margin 0.3s ease-in 0s; + -webkit-transition: margin 0.3s ease-in 0s; + -o-transition: margin 0.3s ease-in 0s; + transition: margin 0.3s ease-in 0s; +} + +.onoffswitch-inner:before, .onoffswitch-inner:after { + float: left; + width: 50%; + height: 20px; + padding: 0; + line-height: 20px; + font-size: 12px; + color: white; + font-family: Trebuchet, Arial, sans-serif; + font-weight: bold; + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} + +.onoffswitch-inner:before { + content: "ON"; + padding-left: 10px; + background-color: @navy; + color: #FFFFFF; +} + +.onoffswitch-inner:after { + content: "OFF"; + padding-right: 10px; + background-color: #FFFFFF; + color: #999999; + text-align: right; +} + +.onoffswitch-switch { + width: 20px; + margin: 0px; + background: #FFFFFF; + border: 2px solid @navy; + border-radius: 2px; + position: absolute; + top: 0; + bottom: 0; + right: 44px; + -moz-transition: all 0.3s ease-in 0s; + -webkit-transition: all 0.3s ease-in 0s; + -o-transition: all 0.3s ease-in 0s; + transition: all 0.3s ease-in 0s; +} + +.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-inner { + margin-left: 0; +} + +.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-switch { + right: 0px; +} + +/* CHOSEN PLUGIN */ + +.chosen-container-single .chosen-single { + background: #ffffff; + box-shadow: none; + -moz-box-sizing: border-box; + background-color: #FFFFFF; + border: 1px solid #CBD5DD; + border-radius: 2px; + cursor: text; + height: auto !important; + margin: 0; + min-height: 30px; + overflow: hidden; + padding: 4px 12px; + position: relative; + width: 100%; +} + +.chosen-container-multi .chosen-choices li.search-choice { + background: #f1f1f1; + border: 1px solid #ededed; + border-radius: 2px; + box-shadow: none; + color: #333333; + cursor: default; + line-height: 13px; + margin: 3px 0 3px 5px; + padding: 3px 20px 3px 5px; + position: relative; +} + +/* PAGINATIN */ + +.pagination > .active > a, .pagination > .active > span, .pagination > .active > a:hover, .pagination > .active > span:hover, .pagination > .active > a:focus, .pagination > .active > span:focus { + background-color: #f4f4f4; + border-color: #DDDDDD; + color: inherit; + cursor: default; + z-index: 2; +} + +.pagination > li > a, .pagination > li > span { + background-color: #FFFFFF; + border: 1px solid #DDDDDD; + color: inherit; + float: left; + line-height: 1.42857; + margin-left: -1px; + padding: 4px 10px; + position: relative; + text-decoration: none; +} + +/* TOOLTIPS */ + +.tooltip-inner { + background-color: #2F4050; +} + +.tooltip.top .tooltip-arrow { + border-top-color: #2F4050; +} + +.tooltip.right .tooltip-arrow { + border-right-color: #2F4050; +} + +.tooltip.bottom .tooltip-arrow { + border-bottom-color: #2F4050; +} + +.tooltip.left .tooltip-arrow { + border-left-color: #2F4050; +} + +/* EASY PIE CHART*/ + +.easypiechart { + position: relative; + text-align: center; +} + +.easypiechart .h2 { + margin-left: 10px; + margin-top: 10px; + display: inline-block; +} + +.easypiechart canvas { + top: 0; + left: 0; +} + +.easypiechart .easypie-text { + line-height: 1; + position: absolute; + top: 33px; + width: 100%; + z-index: 1; +} + +.easypiechart img { + margin-top: -4px; +} + +.jqstooltip { + -webkit-box-sizing: content-box; + -moz-box-sizing: content-box; + box-sizing: content-box; +} + +/* FULLCALENDAR */ + +.fc-state-default { + background-color: #ffffff; + background-image: none; + background-repeat: repeat-x; + box-shadow: none; + color: #333333; + text-shadow: none; +} + +.fc-state-default { + border: 1px solid; +} + +.fc-button { + color: inherit; + border: 1px solid @border-color; + cursor: pointer; + display: inline-block; + height: 1.9em; + line-height: 1.9em; + overflow: hidden; + padding: 0 0.6em; + position: relative; + white-space: nowrap; +} + +.fc-state-active { + background-color: @navy; + border-color: @navy; + color: #ffffff; +} + +.fc-header-title h2 { + font-size: 16px; + font-weight: 600; + color: inherit; +} + +.fc-content .fc-widget-header, .fc-content .fc-widget-content { + border-color: @border-color; + font-weight: normal; +} + +.fc-border-separate tbody { + background-color: #F8F8F8; +} + +.fc-state-highlight { + background: none repeat scroll 0 0 #FCF8E3; +} + +.external-event { + padding: 5px 10px; + border-radius: 2px; + cursor: pointer; + margin-bottom: 5px; +} + +.fc-ltr .fc-event-hori.fc-event-end, .fc-rtl .fc-event-hori.fc-event-start { + border-radius: 2px; +} + +.fc-event, +.fc-agenda .fc-event-time, +.fc-event a { + padding: 4px 6px; + background-color: @navy; /* background color */ + border-color: @navy; /* border color */ +} + +.fc-event-time, .fc-event-title { + color: #717171; + padding: 0 1px; +} + +.ui-calendar .fc-event-time, .ui-calendar .fc-event-title { + color: #fff; +} + + +/* Chat */ +.chat-activity-list .chat-element { + border-bottom: 1px solid @border-color; +} + +.chat-element:first-child { + margin-top: 0; +} + +.chat-element { + padding-bottom: 15px; +} + +.chat-element, .chat-element .media { + margin-top: 15px; +} + +.chat-element, .media-body { + overflow: hidden; +} + +.media-body { + display: block; + width: auto; +} + +.chat-element > .pull-left { + margin-right: 10px; +} + +.chat-element img.img-circle, .dropdown-messages-box img.img-circle { + width: 38px; + height: 38px; +} + +.chat-element .well { + border: 1px solid @border-color; + box-shadow: none; + margin-top: 10px; + margin-bottom: 5px; + padding: 10px 20px; + font-size: 11px; + line-height: 16px; +} + +.chat-element .actions { + margin-top: 10px; +} + +.chat-element .photos { + margin: 10px 0; + +} + +.right.chat-element > .pull-right { + margin-left: 10px; +} + +.chat-photo { + max-height: 180px; + border-radius: 4px; + overflow: hidden; + margin-right: 10px; + margin-bottom: 10px; +} + +.chat { + margin: 0; + padding: 0; + list-style: none; +} + +.chat li { + margin-bottom: 10px; + padding-bottom: 5px; + border-bottom: 1px dotted #B3A9A9; +} + +.chat li.left .chat-body { + margin-left: 60px; +} + +.chat li.right .chat-body { + margin-right: 60px; +} + +.chat li .chat-body p { + margin: 0; + color: #777777; +} + +.panel .slidedown .glyphicon, +.chat .glyphicon { + margin-right: 5px; +} + +.chat-panel .panel-body { + height: 350px; + overflow-y: scroll; +} + +/* LIST GROUP */ + +a.list-group-item.active, a.list-group-item.active:hover, a.list-group-item.active:focus { + background-color: @navy; + border-color: @navy; + color: #FFFFFF; + z-index: 2; +} + +.list-group-item-heading { + margin-top: 10px; +} + +.list-group-item-text { + margin: 0 0 10px; + color: inherit; + font-size: 12px; + line-height: inherit; +} + +.no-padding .list-group-item { + border-left: none; + border-right: none; + border-bottom: none; +} + +.no-padding .list-group-item:first-child { + border-left: none; + border-right: none; + border-bottom: none; + border-top: none; +} + +.no-padding .list-group { + margin-bottom: 0; +} + +.list-group-item { + background-color: inherit; + border: 1px solid @border-color; + display: block; + margin-bottom: -1px; + padding: 10px 15px; + position: relative; +} + +.elements-list .list-group-item { + border-left: none; + border-right: none; + /*border-top: none;*/ + + padding: 15px 25px; + +} + +.elements-list .list-group-item:first-child { + border-left: none; + border-right: none; + border-top: none !important; +} + +.elements-list .list-group { + margin-bottom: 0; +} + +.elements-list a { + color: inherit; +} + +.elements-list .list-group-item.active, +.elements-list .list-group-item:hover { + background: #f3f3f4; + color: inherit; + border-color: #e7eaec; + /*border-bottom: 1px solid #e7eaec;*/ + /*border-top: 1px solid #e7eaec;*/ + border-radius: 0; +} + +.elements-list li.active { + transition: none; +} + +.element-detail-box { + padding: 25px; +} + +/* FLOT CHART */ + +.flot-chart { + display: block; + height: 200px; +} + +.widget .flot-chart.dashboard-chart { + display: block; + height: 120px; + margin-top: 40px; +} + +.flot-chart.dashboard-chart { + display: block; + height: 180px; + margin-top: 40px; +} + +.flot-chart-content { + width: 100%; + height: 100%; +} + +.flot-chart-pie-content { + width: 200px; + height: 200px; + margin: auto; +} + +.jqstooltip { + position: absolute; + display: block; + left: 0px; + top: 0px; + visibility: hidden; + background: rgb(43, 48, 58); + background-color: rgba(43, 48, 58, 0.8); + color: white; + text-align: left; + white-space: nowrap; + z-index: 10000; + padding: 5px 5px 5px 5px; + min-height: 22px; + border-radius: 3px; +} + +.jqsfield { + color: white; + text-align: left; +} + +.h-200 { + min-height: 200px; +} + +.legendLabel { + padding-left: 5px; +} + +.stat-list li:first-child { + margin-top: 0; +} + +.stat-list { + list-style: none; + padding: 0; + margin: 0; +} + +.stat-percent { + float: right; +} + +.stat-list li { + margin-top: 15px; + position: relative; +} + +/* DATATABLES */ + +table.dataTable thead .sorting, +table.dataTable thead .sorting_asc:after, +table.dataTable thead .sorting_desc, +table.dataTable thead .sorting_asc_disabled, +table.dataTable thead .sorting_desc_disabled { + background: transparent; +} + +.dataTables_wrapper { + padding-bottom: 30px; +} + +.dataTables_length { + float: left; +} + +body.DTTT_Print { + background: #fff; + +} +.DTTT_Print #page-wrapper { + margin: 0; + background:#fff; +} + +button.DTTT_button, div.DTTT_button, a.DTTT_button { + border: 1px solid #e7eaec; + background: #fff; + color: #676a6c; + box-shadow: none; + padding: 6px 8px; +} +button.DTTT_button:hover, div.DTTT_button:hover, a.DTTT_button:hover { + border: 1px solid #d2d2d2; + background: #fff; + color: #676a6c; + box-shadow: none; + padding: 6px 8px; +} + +button.DTTT_button:hover:not(.DTTT_disabled), div.DTTT_button:hover:not(.DTTT_disabled), a.DTTT_button:hover:not(.DTTT_disabled) { + border: 1px solid #d2d2d2; + background: #fff; + box-shadow: none; +} + +.dataTables_filter label { + margin-right: 5px; + +} + +/* CIRCLE */ + +.img-circle { + border-radius: 50%; +} + +.btn-circle { + width: 30px; + height: 30px; + padding: 6px 0; + border-radius: 15px; + text-align: center; + font-size: 12px; + line-height: 1.428571429; +} + +.btn-circle.btn-lg { + width: 50px; + height: 50px; + padding: 10px 16px; + border-radius: 25px; + font-size: 18px; + line-height: 1.33; +} + +.btn-circle.btn-xl { + width: 70px; + height: 70px; + padding: 10px 16px; + border-radius: 35px; + font-size: 24px; + line-height: 1.33; +} + +.show-grid [class^="col-"] { + padding-top: 10px; + padding-bottom: 10px; + border: 1px solid #ddd; + background-color: #eee !important; +} + +.show-grid { + margin: 15px 0; +} + +/* ANIMATION */ + +.css-animation-box h1 { + font-size: 44px; +} + +.animation-efect-links a { + padding: 4px 6px; + font-size: 12px; +} + +#animation_box { + background-color: #f9f8f8; + border-radius: 16px; + width: 80%; + margin: 0 auto; + padding-top: 80px; +} + +.animation-text-box { + position: absolute; + margin-top: 40px; + left: 50%; + margin-left: -100px; + width: 200px; +} + +.animation-text-info { + position: absolute; + margin-top: -60px; + left: 50%; + margin-left: -100px; + width: 200px; + font-size: 10px; +} + +.animation-text-box h2 { + font-size: 54px; + font-weight: 600; + margin-bottom: 5px; +} + +.animation-text-box p { + font-size: 12px; + text-transform: uppercase; +} + +/* PEACE */ + +.pace { + -webkit-pointer-events: none; + pointer-events: none; + + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; +} + +.pace-inactive { + display: none; +} + +.pace .pace-progress { + background: @navy; + position: fixed; + z-index: 2000; + top: 0; + right: 100%; + width: 100%; + height: 2px; +} + +.pace-inactive { + display: none; +} + +/* WIDGETS */ + +.widget { + border-radius: 5px; + padding: 15px 20px; + margin-bottom: 10px; + margin-top: 10px; +} + +.widget.style1 h2 { + font-size: 30px; +} + +.widget h2, .widget h3 { + margin-top: 5px; + margin-bottom: 0; +} + +.widget-text-box { + padding: 20px; + border: 1px solid @border-color; + background: #ffffff; +} + +.widget-head-color-box { + border-radius: 5px 5px 0px 0px; + margin-top: 10px; + +} + +.widget .flot-chart { + height: 100px; +} + +.vertical-align div { + display: inline-block; + vertical-align: middle; +} + +.vertical-align h2, .vertical-align h3 { + margin: 0; +} + +.todo-list { + list-style: none outside none; + margin: 0; + padding: 0; + font-size: 14px; +} + +.todo-list.small-list { + font-size: 12px; +} + +.todo-list.small-list > li { + background: @gray; + border-left: none; + border-right: none; + border-radius: 4px; + color: inherit; + margin-bottom: 2px; + padding: 6px 6px 6px 12px; +} + +.todo-list.small-list .btn-xs, .todo-list.small-list .btn-group-xs > .btn { + border-radius: 5px; + font-size: 10px; + line-height: 1.5; + padding: 1px 2px 1px 5px; +} + +.todo-list > li { + background: @gray; + border-left: 6px solid @border-color; + border-right: 6px solid @border-color; + border-radius: 4px; + color: inherit; + margin-bottom: 2px; + padding: 10px; +} + +.todo-list .handle { + cursor: move; + display: inline-block; + font-size: 16px; + margin: 0 5px; +} + +.todo-list > li .label { + font-size: 9px; + margin-left: 10px; +} + +.check-link { + font-size: 16px; +} + +.todo-completed { + text-decoration: line-through; +} + +.geo-statistic h1 { + font-size: 36px; + margin-bottom: 0; +} + +.glyphicon.fa { + font-family: "FontAwesome"; +} +/* INPUTS */ +.inline { + display: inline-block !important; +} + +.input-s-sm { + width: 120px; +} + +.input-s { + width: 200px; +} + +.input-s-lg { + width: 250px; +} + +.i-checks { + padding-left: 0; +} + +.form-control, .single-line { + background-color: #FFFFFF; + background-image: none; + border: 1px solid #e5e6e7; + border-radius: 1px; + color: inherit; + display: block; + padding: 6px 12px; + transition: border-color 0.15s ease-in-out 0s, box-shadow 0.15s ease-in-out 0s; + width: 100%; + font-size:14px +} + +.form-control:focus, .single-line:focus { + border-color: @navy !important; +} + +.has-success .form-control { + border-color: @navy; +} + +.has-warning .form-control { + border-color: @yellow; +} + +.has-error .form-control { + border-color: @red; +} + +.has-success .control-label { + color: @navy; +} + +.has-warning .control-label { + color: @yellow; +} + +.has-error .control-label { + color: @red; +} + +.input-group-addon { + background-color: #fff; + border: 1px solid #E5E6E7; + border-radius: 1px; + color: inherit; + font-size: 14px; + font-weight: 400; + line-height: 1; + padding: 6px 12px; + text-align: center; +} + +.spinner-buttons.input-group-btn .btn-xs { + line-height: 1.13; +} + +.spinner-buttons.input-group-btn { + width: 20%; +} + +.noUi-connect { + background: none repeat scroll 0 0 @navy; + box-shadow: none; +} + +.slider_red .noUi-connect { + background: none repeat scroll 0 0 @red; + box-shadow: none; +} + +/* UI Sortable */ + +.ui-sortable .ibox-title { + cursor: move; +} + +.ui-sortable-placeholder { + border: 1px dashed #cecece !important; + visibility: visible !important; + background: #e7eaec; +} + +.ibox.ui-sortable-placeholder { + margin: 0px 0px 23px !important; +} + +/* SWITCHES */ +.onoffswitch { + position: relative; width: 54px; + -webkit-user-select:none; -moz-user-select:none; -ms-user-select: none; +} +.onoffswitch-checkbox { + display: none; +} +.onoffswitch-label { + display: block; overflow: hidden; cursor: pointer; + border: 2px solid #1AB394; border-radius: 3px; +} +.onoffswitch-inner { + display: block; width: 200%; margin-left: -100%; + -moz-transition: margin 0.3s ease-in 0s; -webkit-transition: margin 0.3s ease-in 0s; + -o-transition: margin 0.3s ease-in 0s; transition: margin 0.3s ease-in 0s; +} +.onoffswitch-inner:before, .onoffswitch-inner:after { + display: block; float: left; width: 50%; height: 16px; padding: 0; line-height: 16px; + font-size: 10px; color: white; font-family: Trebuchet, Arial, sans-serif; font-weight: bold; + -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; +} +.onoffswitch-inner:before { + content: "ON"; + padding-left: 7px; + background-color: #1AB394; color: #FFFFFF; +} +.onoffswitch-inner:after { + content: "OFF"; + padding-right: 7px; + background-color: #FFFFFF; color: #919191; + text-align: right; +} +.onoffswitch-switch { + display: block; width: 18px; margin: 0px; + background: #FFFFFF; + border: 2px solid #1AB394; border-radius: 3px; + position: absolute; top: 0; bottom: 0; right: 36px; + -moz-transition: all 0.3s ease-in 0s; -webkit-transition: all 0.3s ease-in 0s; + -o-transition: all 0.3s ease-in 0s; transition: all 0.3s ease-in 0s; +} +.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-inner { + margin-left: 0; +} +.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-switch { + right: 0px; +} + +/* jqGrid */ + + +.ui-jqgrid{ + -moz-box-sizing: content-box; +} +.ui-jqgrid-btable{ + border-collapse: separate; +} +.ui-jqgrid-htable{ + border-collapse: separate; +} +.ui-jqgrid-titlebar{ + height: 40px; + line-height: 15px; + color: #676a6c; + background-color: #F9F9F9; + text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); +} +.ui-jqgrid .ui-jqgrid-title { + float: left; + margin: 1.1em 1em 0.2em; +} +.ui-jqgrid .ui-jqgrid-titlebar { + position: relative; + border-left: 0px solid; + border-right: 0px solid; + border-top: 0px solid; +} +.ui-widget-header{ + background: none; + background-image: none; + background-color: #f5f5f6; + text-transform: uppercase; + border-top-left-radius: 0px; + border-top-right-radius: 0px; +} +.ui-jqgrid tr.ui-row-ltr td { + border-right-color: inherit; + border-right-style: solid; + border-right-width: 1px; + text-align: left; + border-color: #DDDDDD; + background-color: inherit; +} +.ui-search-toolbar input[type="text"]{ + font-size: 12px; + height: 15px; + border: 1px solid #CCCCCC; + border-radius: 0px; +} +.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { + background: #F9F9F9; + border: 1px solid #DDDDDD; + line-height: 15px; + font-weight: bold; + color: #676a6c; + text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); +} +.ui-widget-content { + box-sizing: content-box; +} +.ui-icon-triangle-1-n { + background-position: 1px -16px; +} +.ui-jqgrid tr.ui-search-toolbar th { + border-top-width: 0px !important; + border-top-color: inherit !important; + border-top-style: ridge !important +} +.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { + background: #f5f5f5; + border-collapse: separate; +} + +.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight { + background: #f2fbff; +} + +.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { + border: 1px solid #dddddd; + background: #ffffff; + font-weight: normal; + color: #212121; +} +.ui-jqgrid .ui-pg-input { + font-size: inherit; + width: 50px; + border: 1px solid #CCCCCC; + height: 15px; +} +.ui-jqgrid .ui-pg-selbox { + display: block; + font-size: 1em; + height: 25px; + line-height: 18px; + margin: 0; + width: auto; +} +.ui-jqgrid .ui-pager-control { + position: relative; +} +.ui-jqgrid .ui-jqgrid-pager { + height: 32px; + position: relative; +} +.ui-pg-table .navtable .ui-corner-all{ + border-radius: 0px; +} +.ui-jqgrid .ui-pg-button:hover { + padding: 1px; + border: 0px; +} +.ui-jqgrid .loading { + position: absolute; + top: 45%; + left: 45%; + width: auto; + height: auto; + z-index:101; + padding: 6px; + margin: 5px; + text-align: center; + font-weight: bold; + display: none; + border-width: 2px !important; + font-size:11px; +} +.ui-jqgrid .form-control { + height: 10px; + width: auto; + display: inline; + padding: 10px 12px; +} +.ui-jqgrid-pager { + height: 32px; +} + +.ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { + border-top-left-radius: 0; +} + +.ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { + border-top-right-radius: 0; +} + +.ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { + border-bottom-left-radius: 0; +} + +.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { + border-bottom-right-radius: 0; +} + +.ui-widget-content { + border:1px solid #ddd; +} + +.ui-jqgrid .ui-jqgrid-titlebar { + padding: 0; +} + +.ui-jqgrid .ui-jqgrid-titlebar { + border-bottom: 1px solid #ddd; +} + +.ui-jqgrid tr.jqgrow td { + padding: 6px; +} + +.ui-jqdialog .ui-jqdialog-titlebar { + padding: 10px 10px; + +} + +.ui-jqdialog .ui-jqdialog-title { + float: none !important; +} + +.ui-jqdialog > .ui-resizable-se { + position: absolute; +} + + + + +/* Nestable list */ + +.dd { + position: relative; + display: block; + margin: 0; + padding: 0; + list-style: none; + font-size: 13px; + line-height: 20px; +} + +.dd-list { + display: block; + position: relative; + margin: 0; + padding: 0; + list-style: none; +} + +.dd-list .dd-list { + padding-left: 30px; +} + +.dd-collapsed .dd-list { + display: none; +} + +.dd-item, +.dd-empty, +.dd-placeholder { + display: block; + position: relative; + margin: 0; + padding: 0; + min-height: 20px; + font-size: 13px; + line-height: 20px; +} + +.dd-handle { + display: block; + margin: 5px 0; + padding: 5px 10px; + color: #333; + text-decoration: none; + border: 1px solid #e7eaec; + background: #f5f5f5; + -webkit-border-radius: 3px; + border-radius: 3px; + box-sizing: border-box; + -moz-box-sizing: border-box; +} + +.dd-handle span { + font-weight: bold; +} + +.dd-handle:hover { + background: #f0f0f0; + cursor: pointer; + font-weight: bold; +} + +.dd-item > button { + display: block; + position: relative; + cursor: pointer; + float: left; + width: 25px; + height: 20px; + margin: 5px 0; + padding: 0; + text-indent: 100%; + white-space: nowrap; + overflow: hidden; + border: 0; + background: transparent; + font-size: 12px; + line-height: 1; + text-align: center; + font-weight: bold; +} + +.dd-item > button:before { + content: '+'; + display: block; + position: absolute; + width: 100%; + text-align: center; + text-indent: 0; +} + +.dd-item > button[data-action="collapse"]:before { + content: '-'; +} + +#nestable2 .dd-item > button { + font-family: FontAwesome; + height: 34px; + width: 33px; + color: #c1c1c1; + +} + +#nestable2 .dd-item > button:before { + content: "\f067"; +} + +#nestable2 .dd-item > button[data-action="collapse"]:before { + content: "\f068"; +} + +.dd-placeholder, +.dd-empty { + margin: 5px 0; + padding: 0; + min-height: 30px; + background: #f2fbff; + border: 1px dashed #b6bcbf; + box-sizing: border-box; + -moz-box-sizing: border-box; +} + +.dd-empty { + border: 1px dashed #bbb; + min-height: 100px; + background-color: #e5e5e5; + background-image: -webkit-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff), -webkit-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff); + background-image: -moz-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff), -moz-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff); + background-image: linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff), linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff); + background-size: 60px 60px; + background-position: 0 0, 30px 30px; +} + +.dd-dragel { + position: absolute; + z-index: 9999; + pointer-events: none; +} + +.dd-dragel > .dd-item .dd-handle { + margin-top: 0; +} + +.dd-dragel .dd-handle { + -webkit-box-shadow: 2px 4px 6px 0 rgba(0, 0, 0, .1); + box-shadow: 2px 4px 6px 0 rgba(0, 0, 0, .1); +} + +/** +* Nestable Extras +*/ +.nestable-lists { + display: block; + clear: both; + padding: 30px 0; + width: 100%; + border: 0; + border-top: 2px solid #ddd; + border-bottom: 2px solid #ddd; +} + +#nestable-menu { + padding: 0; + margin: 10px 0 20px 0; +} + +#nestable-output, +#nestable2-output { + width: 100%; + font-size: 0.75em; + line-height: 1.333333em; + font-family: open sans, lucida grande, lucida sans unicode, helvetica, arial, sans-serif; + padding: 5px; + box-sizing: border-box; + -moz-box-sizing: border-box; +} + +#nestable2 .dd-handle { + color: inherit; + border: 1px dashed #e7eaec; + background: #f3f3f4; + padding: 10px; +} + +#nestable2 .dd-handle:hover { + /*background: #bbb;*/ +} + + +#nestable2 span.label { + margin-right: 10px; +} + +#nestable-output, +#nestable2-output { + font-size: 12px; + padding: 25px; + box-sizing: border-box; + -moz-box-sizing: border-box; +} + +/* CodeMirror */ +.CodeMirror { + border: 1px solid #eee; + height: auto; +} +.CodeMirror-scroll { + overflow-y: hidden; + overflow-x: auto; +} + +/* Google Maps */ +.google-map { + height: 300px; +} + +/* Validation */ +label.error { + color: #cc5965; + display: inline-block; + margin-left: 5px; +} + +.form-control.error { + border: 1px dotted #cc5965; +} + +/* ngGrid */ +.gridStyle { + border: 1px solid rgb(212, 212, 212); + width: 100%; + height: 400px +} +.gridStyle2 { + border: 1px solid rgb(212,212,212); + width: 500px; + height: 300px; +} +.ngH eaderCell { + border-right: none; + border-bottom: 1px solid #e7eaec; +} +.ngCell { + border-right: none; +} +.ngTopPanel { + background: #F5F5F6; +} +.ngRow.even { + background: #f9f9f9; +} +.ngRow.selected { + background: #EBF2F1; +} +.ngRow { + border-bottom: 1px solid #e7eaec; +} +.ngCell { + background-color: transparent; +} +.ngHeaderCell { + border-right: none; +} + +/* Toastr custom style */ + +#toast-container > .toast { + background-image: none !important; +} + +#toast-container > .toast:before { + position: fixed; + font-family: FontAwesome; + font-size: 24px; + line-height: 24px; + float: left; + color: #FFF; + padding-right: 0.5em; + margin: auto 0.5em auto -1.5em; +} +#toast-container > .toast-warning:before { + content: "\f0e7"; +} +#toast-container > .toast-error:before { + content: "\f071"; +} +#toast-container > .toast-info:before { + content: "\f005"; +} +#toast-container > .toast-success:before { + content: "\f00C"; +} + +#toast-container > div { + -moz-box-shadow: 0 0 3px #999; + -webkit-box-shadow: 0 0 3px #999; + box-shadow: 0 0 3px #999; + opacity: .9; + -ms-filter: alpha(Opacity=90); + filter: alpha(opacity=90) +} + +#toast-container > :hover { + -moz-box-shadow: 0 0 4px #999; + -webkit-box-shadow: 0 0 4px #999; + box-shadow: 0 0 4px #999; + opacity: 1; + -ms-filter: alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer +} + +.toast { + background-color: @navy +} + +.toast-success { + background-color: @navy +} + +.toast-error { + background-color: @red +} + +.toast-info { + background-color: @lazur +} + +.toast-warning { + background-color: @yellow +} + +.toast-top-full-width { + margin-top: 20px; +} + +.toast-bottom-full-width { + margin-bottom: 20px; +} + +/* Notifie */ +.cg-notify-message.inspinia-notify { + background: #fff; + padding: 0; + box-shadow: 0 0 1px rgba(0, 0, 0, 0.1), 0 2px 4px rgba(0, 0, 0, 0.2); + -webkit-box-shadow : 0 0 1 px rgba(0, 0, 0, 0.1), 0 2 px 4 px rgba(0, 0, 0, 0.2); + -moz-box-shadow : 0 0 1 px rgba(0, 0, 0, 0.1), 0 2 px 4 px rgba(0, 0, 0, 0.2); + border:none ; + margin-top: 30px; + color: inherit; +} + +.inspinia-notify.alert-warning { + border-left: 6px solid @yellow; +} +.inspinia-notify.alert-success { + border-left: 6px solid @blue; +} + +.inspinia-notify.alert-danger { + border-left: 6px solid @red; +} + +.inspinia-notify.alert-info { + border-left: 6px solid @navy; +} + +/* Image cropper style */ +.img-container, .img-preview { + overflow: hidden; + text-align: center; + width: 100%; +} +.img-preview-sm { + height: 130px; + width: 200px; +} + +/* Forum styles */ +.forum-post-container .media { + margin: 10px 10px 10px 10px; + padding: 20px 10px 20px 10px; + border-bottom: 1px solid #f1f1f1; +} + +.forum-avatar { + float: left; + margin-right: 20px; + text-align: center; + width: 110px; +} + +.forum-avatar .img-circle { + height: 48px; + width: 48px; +} + +.author-info { + color: #676a6c; + font-size: 11px; + margin-top: 5px; + text-align: center; +} + +.forum-post-info { + padding: 9px 12px 6px 12px; + background:#f9f9f9; + border: 1px solid #f1f1f1; +} + +.media-body > .media { + background: #f9f9f9; + border-radius: 3px; + border: 1px solid #f1f1f1; +} + +.forum-post-container .media-body .photos { + margin: 10px 0; +} + +.forum-photo { + max-width: 140px; + border-radius: 3px; + +} + +.media-body > .media .forum-avatar { + width: 70px; + margin-right: 10px; +} +.media-body > .media .forum-avatar .img-circle { + height: 38px; + width: 38px; +} + +.mid-icon { + font-size: 66px; +} + +.forum-item { + margin: 10px 0; + padding: 10px 0 20px; + border-bottom: 1px solid #f1f1f1; +} + +.views-number { + font-size: 24px; + line-height: 18px; + font-weight: 400; +} + +.forum-container, .forum-post-container { + padding: 30px !important; +} + +.forum-item small { + color: #999; +} + +.forum-item .forum-sub-title{ + color: #999; + margin-left: 50px; +} + +.forum-title { + margin: 15px 0 15px 0; +} + +.forum-info { + text-align: center; +} + +.forum-desc { + color: #999; +} + +.forum-icon { + float: left; + width: 30px; + margin-right: 20px; + text-align: center; +} + +a.forum-item-title { + color: inherit; + display: block; + font-size: 18px; + font-weight: 600; +} + +a.forum-item-title:hover { + color: inherit; +} + +.forum-icon .fa { + + font-size: 30px; + margin-top: 8px; + color: #9b9b9b; +} +.forum-item.active .fa { + color: @navy; +} + +.forum-item.active a.forum-item-title { + color: @navy; +} + +@media (max-width: 992px) { + + .forum-info { + margin: 15px 0 10px 0px; + + /* Comment this is you want to show forum info in small devices */ + display: none; + } + + .forum-desc { + float: none !important; + } + +} + +/* New Timeline style */ + +.vertical-container { + /* this class is used to give a max-width to the element it is applied to, and center it horizontally when it reaches that max-width */ + width: 90%; + max-width: 1170px; + margin: 0 auto; +} +.vertical-container::after { + /* clearfix */ + content: ''; + display: table; + clear: both; +} + +#vertical-timeline { + position: relative; + padding:0; + margin-top: 2em; + margin-bottom: 2em; +} +#vertical-timeline::before { + content: ''; + position: absolute; + top: 0; + left: 18px; + height: 100%; + width: 4px; + background: #f1f1f1; +} + + +.vertical-timeline-content .btn { + float: right; +} + +#vertical-timeline.light-timeline:before { + background: #e7eaec; +} + + +.dark-timeline .vertical-timeline-content:before +{ + border-color: transparent #f5f5f5 transparent transparent ; +} + +.dark-timeline.center-orientation .vertical-timeline-content:before +{ + border-color: transparent transparent transparent #f5f5f5; +} + +.dark-timeline .vertical-timeline-block:nth-child(2n) .vertical-timeline-content:before, +.dark-timeline.center-orientation .vertical-timeline-block:nth-child(2n) .vertical-timeline-content:before +{ + border-color: transparent #f5f5f5 transparent transparent; +} + +.dark-timeline .vertical-timeline-content, +.dark-timeline.center-orientation .vertical-timeline-content +{ + background: #f5f5f5; +} + +@media only screen and (min-width: 1170px) { + #vertical-timeline.center-orientation { + margin-top: 3em; + margin-bottom: 3em; + } + #vertical-timeline.center-orientation:before { + left: 50%; + margin-left: -2px; + } +} + +@media only screen and (max-width: 1170px) { + .center-orientation.dark-timeline .vertical-timeline-content:before { + border-color: transparent #f5f5f5 transparent transparent; + } +} + +.vertical-timeline-block { + position: relative; + margin: 2em 0; +} +.vertical-timeline-block:after { + content: ""; + display: table; + clear: both; +} +.vertical-timeline-block:first-child { + margin-top: 0; +} +.vertical-timeline-block:last-child { + margin-bottom: 0; +} +@media only screen and (min-width: 1170px) { + .center-orientation .vertical-timeline-block { + margin: 4em 0; + } + .center-orientation .vertical-timeline-block:first-child { + margin-top: 0; + } + .center-orientation .vertical-timeline-block:last-child { + margin-bottom: 0; + } +} + +.vertical-timeline-icon { + position: absolute; + top: 0; + left: 0; + width: 40px; + height: 40px; + border-radius: 50%; + font-size: 16px; + border: 3px solid #f1f1f1; + text-align: center; +} +.vertical-timeline-icon i { + display: block; + width: 24px; + height: 24px; + position: relative; + left: 50%; + top: 50%; + margin-left: -12px; + margin-top: -9px; +} + +@media only screen and (min-width: 1170px) { + .center-orientation .vertical-timeline-icon { + width: 50px; + height: 50px; + left: 50%; + margin-left: -25px; + -webkit-transform: translateZ(0); + -webkit-backface-visibility: hidden; + font-size: 19px; + } + .center-orientation .vertical-timeline-icon i { + margin-left: -12px; + margin-top: -10px; + } + .center-orientation .cssanimations .vertical-timeline-icon.is-hidden { + visibility: hidden; + } +} + + +.vertical-timeline-content { + position: relative; + margin-left: 60px; + background: white; + border-radius: 0.25em; + padding: 1em; +} +.vertical-timeline-content:after { + content: ""; + display: table; + clear: both; +} +.vertical-timeline-content h2 { + font-weight: 400; + margin-top: 4px; +} + + +.vertical-timeline-content p { + margin: 1em 0; + line-height: 1.6; +} + + +.vertical-timeline-content .vertical-date { + float: left; + font-weight: 500; +} + +.vertical-date small { + color: @navy; + font-weight: 400; +} + +.vertical-timeline-content::before { + content: ''; + position: absolute; + top: 16px; + right: 100%; + height: 0; + width: 0; + border: 7px solid transparent; + border-right: 7px solid white; +} +@media only screen and (min-width: 768px) { + .vertical-timeline-content h2 { + font-size: 18px; + } + .vertical-timeline-content p { + font-size: 13px; + } + +} +@media only screen and (min-width: 1170px) { + .center-orientation .vertical-timeline-content { + margin-left: 0; + padding: 1.6em; + width: 45%; + } + .center-orientation .vertical-timeline-content::before { + top: 24px; + left: 100%; + border-color: transparent; + border-left-color: white; + } + + .center-orientation .vertical-timeline-content .btn { + float: left; + } + .center-orientation .vertical-timeline-content .vertical-date { + position: absolute; + width: 100%; + left: 122%; + top: 2px; + font-size: 14px; + } + .center-orientation .vertical-timeline-block:nth-child(even) .vertical-timeline-content { + float: right; + } + .center-orientation .vertical-timeline-block:nth-child(even) .vertical-timeline-content::before { + top: 24px; + left: auto; + right: 100%; + border-color: transparent; + border-right-color: white; + } + .center-orientation .vertical-timeline-block:nth-child(even) .vertical-timeline-content .btn { + float: right; + } + .center-orientation .vertical-timeline-block:nth-child(even) .vertical-timeline-content .vertical-date { + left: auto; + right: 122%; + text-align: right; + } + .center-orientation .cssanimations .vertical-timeline-content.is-hidden { + visibility: hidden; + } +} + +/* Tabs */ + +.tabs-container { + + .panel-body { + background: #fff; + border: 1px solid @border-color; + border-radius: 2px; + padding: 20px; + position: relative; + } + + .nav-tabs > li.active > a, + .nav-tabs > li.active > a:hover, + .nav-tabs > li.active > a:focus { + border: 1px solid @border-color; + border-bottom-color: transparent; + background-color: #fff; + } + + .nav-tabs > li { + float: left; + margin-bottom: -1px; + } + + .tab-pane .panel-body { + border-top: none; + } + + .nav-tabs>li.active>a, .nav-tabs>li.active>a:hover, .nav-tabs>li.active>a:focus { + border: 1px solid @border-color; + border-bottom-color: transparent; + } + + .nav-tabs { + border-bottom: 1px solid @border-color; + } + + .tab-pane .panel-body { + border-top: none; + } + + .tabs-left .tab-pane .panel-body, .tabs-right .tab-pane .panel-body { + border-top: 1px solid @border-color; + } + + .nav-tabs > li a:hover { + background: transparent; + border-color: transparent; + } + + .tabs-below > .nav-tabs, + .tabs-right > .nav-tabs, + .tabs-left > .nav-tabs { + border-bottom: 0; + } + + .tabs-left .panel-body { + position: static; + } + + .tabs-left > .nav-tabs, .tabs-right > .nav-tabs { + width: 20%; + } + + .tabs-left .panel-body { + width: 80%; + margin-left: 20%; + } + + .tabs-right .panel-body { + width: 80%; + margin-right: 20%; + } + + .tab-content > .tab-pane, + .pill-content > .pill-pane { + display: none; + } + + .tab-content > .active, + .pill-content > .active { + display: block; + } + + .tabs-below > .nav-tabs { + border-top: 1px solid @border-color; + } + + .tabs-below > .nav-tabs > li { + margin-top: -1px; + margin-bottom: 0; + } + + .tabs-below > .nav-tabs > li > a { + -webkit-border-radius: 0 0 4px 4px; + -moz-border-radius: 0 0 4px 4px; + border-radius: 0 0 4px 4px; + } + + .tabs-below > .nav-tabs > li > a:hover, + .tabs-below > .nav-tabs > li > a:focus { + border-top-color: @border-color; + border-bottom-color: transparent; + } + + + .tabs-left > .nav-tabs > li, + .tabs-right > .nav-tabs > li { + float: none; + } + + .tabs-left > .nav-tabs > li > a, + .tabs-right > .nav-tabs > li > a { + min-width: 74px; + margin-right: 0; + margin-bottom: 3px; + } + + .tabs-left > .nav-tabs { + float: left; + margin-right: 19px; + } + + .tabs-left > .nav-tabs > li > a { + margin-right: -1px; + -webkit-border-radius: 4px 0 0 4px; + -moz-border-radius: 4px 0 0 4px; + border-radius: 4px 0 0 4px; + } + + .tabs-left > .nav-tabs .active > a, + .tabs-left > .nav-tabs .active > a:hover, + .tabs-left > .nav-tabs .active > a:focus { + border-color: @border-color transparent @border-color @border-color; + *border-right-color: #ffffff; + } + + .tabs-right > .nav-tabs { + float: right; + margin-left: 19px; + } + + .tabs-right > .nav-tabs > li > a { + margin-left: -1px; + -webkit-border-radius: 0 4px 4px 0; + -moz-border-radius: 0 4px 4px 0; + border-radius: 0 4px 4px 0; + } + + .tabs-right > .nav-tabs .active > a, + .tabs-right > .nav-tabs .active > a:hover, + .tabs-right > .nav-tabs .active > a:focus { + border-color: @border-color @border-color @border-color transparent; + *border-left-color: #ffffff; + z-index: 1; + } + +} + +/* jsvectormap */ +.jvectormap-container { + width: 100%; + height: 100%; + position: relative; + overflow: hidden; +} + +.jvectormap-tip { + position: absolute; + display: none; + border: solid 1px #CDCDCD; + border-radius: 3px; + background: #292929; + color: white; + font-family: sans-serif, Verdana; + font-size: smaller; + padding: 5px; +} + +.jvectormap-zoomin, .jvectormap-zoomout, .jvectormap-goback { + position: absolute; + left: 10px; + border-radius: 3px; + background: @navy; + padding: 3px; + color: white; + cursor: pointer; + line-height: 10px; + text-align: center; + box-sizing: content-box; +} + +.jvectormap-zoomin, .jvectormap-zoomout { + width: 10px; + height: 10px; +} + +.jvectormap-zoomin { + top: 10px; +} + +.jvectormap-zoomout { + top: 30px; +} + +.jvectormap-goback { + bottom: 10px; + z-index: 1000; + padding: 6px; +} + +.jvectormap-spinner { + position: absolute; + left: 0; + top: 0; + right: 0; + bottom: 0; + background: center no-repeat url(); +} + +.jvectormap-legend-title { + font-weight: bold; + font-size: 14px; + text-align: center; +} + +.jvectormap-legend-cnt { + position: absolute; +} + +.jvectormap-legend-cnt-h { + bottom: 0; + right: 0; +} + +.jvectormap-legend-cnt-v { + top: 0; + right: 0; +} + +.jvectormap-legend { + background: black; + color: white; + border-radius: 3px; +} + +.jvectormap-legend-cnt-h .jvectormap-legend { + float: left; + margin: 0 10px 10px 0; + padding: 3px 3px 1px 3px; +} + +.jvectormap-legend-cnt-h .jvectormap-legend .jvectormap-legend-tick { + float: left; +} + +.jvectormap-legend-cnt-v .jvectormap-legend { + margin: 10px 10px 0 0; + padding: 3px; +} + +.jvectormap-legend-cnt-h .jvectormap-legend-tick { + width: 40px; +} + +.jvectormap-legend-cnt-h .jvectormap-legend-tick-sample { + height: 15px; +} + +.jvectormap-legend-cnt-v .jvectormap-legend-tick-sample { + height: 20px; + width: 20px; + display: inline-block; + vertical-align: middle; +} + +.jvectormap-legend-tick-text { + font-size: 12px; +} + +.jvectormap-legend-cnt-h .jvectormap-legend-tick-text { + text-align: center; +} + +.jvectormap-legend-cnt-v .jvectormap-legend-tick-text { + display: inline-block; + vertical-align: middle; + line-height: 20px; + padding-left: 3px; +} + +/*Slick Carousel */ + +.slick-prev:before, +.slick-next:before +{ + color: @navy !important; +} + +/* Payments */ + +.payment-card { + background: #ffffff; + padding: 20px; + margin-bottom: 25px; + border: 1px solid @border-color; +} + +.payment-icon-big { + font-size: 60px; + color: @light-gray; +} + +.payments-method.panel-group .panel+.panel { + margin-top: -1px; +} + +.payments-method .panel-heading { + padding: 15px; +} + +.payments-method .panel{ + border-radius: 0; +} + +.payments-method .panel-heading h5 { + margin-bottom: 5px; +} + +.payments-method .panel-heading i { + font-size: 26px; +} + +/* Select2 custom styles */ + +.select2-container--default .select2-selection--single, +.select2-container--default .select2-selection--multiple { + border-color: @border-color; +} diff --git a/src/app/less/landing.less b/src/app/less/landing.less new file mode 100755 index 0000000..1a6776e --- /dev/null +++ b/src/app/less/landing.less @@ -0,0 +1,636 @@ +/* + * + * INSPINIA Landing Page - Responsive Admin Theme + * Copyright 2014 Webapplayers.com + * +*/ +/* GLOBAL STYLES +-------------------------------------------------- */ + +/* PACE PLUGIN +-------------------------------------------------- */ +.landing-page.pace .pace-progress { + background: #fff; + position: fixed; + z-index: 2000; + top: 0; + left: 0; + height: 2px; + -webkit-transition: width 1s; + -moz-transition: width 1s; + -o-transition: width 1s; + transition: width 1s; + +} +.pace-inactive { + display: none; +} + +body.landing-page { + color: @text-color; + font-family: 'Open Sans', helvetica, arial, sans-serif; + background-color: #fff; +} + +.landing-page { + + span.navy { + color: @navy; + } + p.text-color { + color: @text-color; + } + a.navy-link { + color: @navy; + text-decoration: none; + } + a.navy-link:hover { + color: darken(@navy, 5%); + } + section p { + color: #aeaeae; + font-size: 13px; + } + address { + font-size: 13px; + } + h1 { + margin-top: 10px; + font-size: 30px; + font-weight: 200; + } + .navy-line { + width: 60px; + height: 1px; + margin: 60px auto 0; + border-bottom: 2px solid @navy; + } + /* CUSTOMIZE THE NAVBAR + -------------------------------------------------- */ + .navbar-wrapper { + position: fixed; + top: 0; + right: 0; + left: 0; + z-index: 200; + } + /* Flip around the padding for proper display in narrow viewports */ + .navbar-wrapper > .container { + padding-right: 0; + padding-left: 0; + } + .navbar-wrapper .navbar { + padding-right: 15px; + padding-left: 15px; + } + .navbar-default.navbar-scroll { + background-color: #fff; + border-color: #fff; + padding: 15px 0; + } + .navbar-default { + background-color: transparent; + border-color: transparent; + transition: all 0.3s ease-in-out 0s; + } + .navbar-default .nav li a { + color: #fff; + font-family: 'Open Sans', helvetica, arial, sans-serif; + font-weight: 700; + letter-spacing: 1px; + text-transform: uppercase; + font-size: 14px; + } + .navbar-nav > li > a { + padding-top: 25px; + border-top: 6px solid transparent; + } + .navbar-default .navbar-nav > .active > a, + .navbar-default .navbar-nav > .active > a:hover { + background: transparent; + color: #fff; + border-top: 6px solid @navy; + } + .navbar-default .navbar-nav > li > a:hover, + .navbar-default .navbar-nav > li > a:focus { + color: @navy; + background: inherit; + } + .navbar-default .navbar-nav > .active > a:focus { + background: transparent; + color: #fff; + } + + .navbar-default .navbar-nav > .active > a:focus { + background: transparent; + color: #ffffff; + } + + .navbar-default.navbar-scroll .navbar-nav > .active > a:focus { + background: transparent; + color: inherit; + } + .navbar-default .navbar-brand:hover, + .navbar-default .navbar-brand:focus { + background: darken(@navy, 5%); + color: #fff; + } + .navbar-default .navbar-brand { + color: #fff; + height: auto; + display: block; + font-size: 14px; + background: @navy; + padding: 15px 20px 15px 20px; + border-radius: 0 0 5px 5px; + font-weight: 700; + transition: all 0.3s ease-in-out 0s; + } + .navbar-scroll.navbar-default .nav li a { + color: @text-color; + } + .navbar-scroll.navbar-default .nav li a:hover { + color: @navy; + } + .navbar-wrapper .navbar.navbar-scroll { + padding-top: 0; + padding-bottom: 0px; + border-bottom: 1px solid @border-color; + border-radius: 0; + } + + .nav > li.active { + border: none; + background: inherit; + } + + .nav > li > a { + padding: 25px 10px 15px 10px; + } + .navbar-scroll .navbar-nav > li > a { + padding: 20px 10px; + } + + .navbar-default .navbar-nav > .active > a, + .navbar-default .navbar-nav > .active > a:hover { + border-top: 6px solid @navy ; + } + + .navbar-fixed-top { + border: none !important; + } + + .navbar-fixed-top.navbar-scroll { + border-bottom: 1px solid @border-color !important; + } + + .navbar.navbar-scroll .navbar-brand { + margin-top: 15px; + border-radius: 5px; + font-size: 12px; + padding: 10px; + height: auto; + } + /* BACKGROUNDS SLIDER + -------------------------------------------------- */ + .header-back { + height: 470px; + width: 100%; + } + .header-back.one { + background: url('../img/landing/header_one.jpg') 50% 0 no-repeat; + } + .header-back.two { + background: url('../img/landing/header_two.jpg') 50% 0 no-repeat; + } + /* CUSTOMIZE THE CAROUSEL + -------------------------------------------------- */ + /* Carousel base class */ + .carousel { + height: 470px; + } + /* Since positioning the image, we need to help out the caption */ + .carousel-caption { + z-index: 10; + } + /* Declare heights because of positioning of img element */ + .carousel .item { + height: 470px; + background-color: #777; + } + .carousel-inner > .item > img { + position: absolute; + top: 0; + left: 0; + min-width: 100%; + height: 470px; + } + .carousel-fade .carousel-inner .item { + opacity: 0; + -webkit-transition-property: opacity; + transition-property: opacity; + } + .carousel-fade .carousel-inner .active { + opacity: 1; + } + .carousel-fade .carousel-inner .active.left, + .carousel-fade .carousel-inner .active.right { + left: 0; + opacity: 0; + z-index: 1; + } + .carousel-fade .carousel-inner .next.left, + .carousel-fade .carousel-inner .prev.right { + opacity: 1; + } + .carousel-fade .carousel-control { + z-index: 2; + } + .carousel-control.left, + .carousel-control.right { + background: none; + } + .carousel-control { + width: 6%; + } + .carousel-inner .container { + position: relative; + } + .carousel-inner { + overflow: visible; + } + .carousel-caption { + position: absolute; + top: 100px; + left: 0; + bottom: auto; + right: auto; + text-align: left; + } + .carousel-caption { + position: absolute; + top: 100px; + left: 0; + bottom: auto; + right: auto; + text-align: left; + } + .carousel-caption.blank { + top: 140px; + } + .carousel-image { + position: absolute; + right: 10px; + top: 150px; + } + .carousel-indicators { + padding-right: 60px; + } + .carousel-caption h1 { + font-weight: 700; + font-size: 38px; + text-transform: uppercase; + text-shadow: none; + letter-spacing: -1.5px; + } + .carousel-caption p { + font-weight: 700; + text-transform: uppercase; + text-shadow: none; + } + .caption-link { + color: #fff; + margin-left: 10px; + text-transform: capitalize; + font-weight: 400; + } + .caption-link:hover { + text-decoration: none; + color: inherit; + } + /* Sections + ------------------------- */ + .services { + padding-top: 60px; + } + .services h2 { + font-size: 20px; + letter-spacing: -1px; + font-weight: 600; + text-transform: uppercase; + } + .features-block { + margin-top: 40px; + } + .features-text { + margin-top: 40px; + } + .features small { + color: @navy; + } + .features h2 { + font-size: 18px; + margin-top: 5px; + } + .features-text-alone { + margin: 40px 0; + } + .features-text-alone h1 { + font-weight: 200; + } + .features-icon { + color: @navy; + font-size: 40px; + } + .navy-section { + margin-top: 60px; + background: @navy; + color: #fff; + padding: 20px 0; + } + .gray-section { + background: #f4f4f4; + margin-top: 60px; + } + .team-member { + text-align: center; + } + .team-member img { + margin: auto; + } + .social-icon a { + background: @navy; + color: #fff; + padding: 4px 8px; + height: 28px; + width: 28px; + display: block; + border-radius: 50px; + } + .social-icon a:hover { + background: darken(@navy, 5%); + } + .img-small { + height: 88px; + width: 88px; + } + .pricing-plan { + margin: 20px 30px 0 30px; + border-radius: 4px; + } + .pricing-plan.selected { + transform: scale(1.1); + background: #f4f4f4 ; + } + .pricing-plan li { + padding: 10px 16px; + border-top: 1px solid @border-color; + text-align: center; + color: #aeaeae; + } + .pricing-plan .pricing-price span { + font-weight: 700; + color: @navy; + } + li.pricing-desc { + font-size: 13px; + border-top: none; + padding: 20px 16px ; + } + li.pricing-title { + background: @navy; + color: #fff; + padding: 10px; + border-radius: 4px 4px 0 0; + font-size: 22px; + font-weight: 600; + } + .testimonials { + padding-top: 80px; + padding-bottom: 90px; + background-color: @navy; + background-image: url('../img/landing/avatar_all.png'); + } + .big-icon { + font-size: 56px !important; + } + .features .big-icon { + color: @navy !important; + } + .contact { + background-image: url('../img/landing/word_map.png'); + background-position: 50% 50%; + background-repeat: no-repeat; + margin-top: 60px; + } + + section.timeline { + padding-bottom: 30px; + } + section.comments { + padding-bottom: 80px; + } + + .comments-avatar { + margin-top: 25px; + margin-left: 22px; + } + + .comments-avatar .commens-name { + font-weight: 600; + font-size: 14px; + } + + .comments-avatar img { + width: 42px; + height: 42px; + border-radius: 50%; + margin-right: 10px; + } + + .bubble { + position: relative; + height: 120px; + padding: 20px; + background: #FFFFFF; + -webkit-border-radius: 10px; + -moz-border-radius: 10px; + border-radius: 10px; + font-style: italic; + font-size: 14px; + } + + .bubble:after { + content: ''; + position: absolute; + border-style: solid; + border-width: 15px 14px 0; + border-color: #FFFFFF transparent; + display: block; + width: 0; + z-index: 1; + bottom: -15px; + left: 30px; + } + + /* Buttons - only primary custom button + ------------------------- */ + .btn-primary.btn-outline:hover, + .btn-success.btn-outline:hover, + .btn-info.btn-outline:hover, + .btn-warning.btn-outline:hover, + .btn-danger.btn-outline:hover { + color: #fff; + } + .btn-primary { + background-color: @navy; + border-color: @navy; + color: #FFFFFF; + font-size: 14px; + padding: 10px 20px; + font-weight: 600; + } + .btn-primary:hover, + .btn-primary:focus, + .btn-primary:active, + .btn-primary.active, + .open .dropdown-toggle.btn-primary { + background-color: darken(@navy, 5%); + border-color: darken(@navy, 5%); + color: #FFFFFF; + } + .btn-primary:active, + .btn-primary.active, + .open .dropdown-toggle.btn-primary { + background-image: none; + } + .btn-primary.disabled, + .btn-primary.disabled:hover, + .btn-primary.disabled:focus, + .btn-primary.disabled:active, + .btn-primary.disabled.active, + .btn-primary[disabled], + .btn-primary[disabled]:hover, + .btn-primary[disabled]:focus, + .btn-primary[disabled]:active, + .btn-primary.active[disabled], + fieldset[disabled] .btn-primary, + fieldset[disabled] .btn-primary:hover, + fieldset[disabled] .btn-primary:focus, + fieldset[disabled] .btn-primary:active, + fieldset[disabled] .btn-primary.active { + background-color: #1dc5a3; + border-color: #1dc5a3; + } + /* RESPONSIVE CSS + -------------------------------------------------- */ + @media (min-width: 768px) { + /* Navbar positioning foo */ + .navbar-wrapper { + margin-top: 20px; + } + .navbar-wrapper .container { + padding-right: 15px; + padding-left: 15px; + } + .navbar-wrapper .navbar { + padding-right: 0; + padding-left: 0; + } + /* The navbar becomes detached from the top, so we round the corners */ + .navbar-wrapper .navbar { + border-radius: 4px; + } + /* Bump up size of carousel content */ + .carousel-caption p { + margin-bottom: 20px; + font-size: 14px; + line-height: 1.4; + } + .featurette-heading { + font-size: 50px; + } + } + @media (max-width: 992px) { + .carousel-image { + display: none; + } + } + @media (max-width: 768px) { + .carousel-caption, + .carousel-caption.blank { + left: 5%; + top: 80px; + } + .carousel-caption h1 { + font-size: 28px; + } + .navbar.navbar-scroll .navbar-brand { + margin-top: 6px; + } + .navbar-default { + background-color: #fff; + border-color: #fff; + padding: 15px 0; + } + .navbar-default .navbar-nav > .active > a:focus { + background: transparent; + color: inherit; + } + .navbar-default .nav li a { + color: @text-color; + } + .navbar-default .nav li a:hover { + color: @navy; + } + .navbar-wrapper .navbar { + padding-top: 0; + padding-bottom: 5px; + border-bottom: 1px solid @border-color; + border-radius: 0; + } + .nav > li > a { + padding: 25px 10px 15px 10px; + } + .navbar-nav > li > a { + padding: 20px 10px; + } + .navbar .navbar-brand { + margin-top: 6px; + border-radius: 5px; + font-size: 12px; + padding: 10px; + height: auto; + } + .navbar-wrapper .navbar { + padding-left: 15px; + padding-right: 5px; + } + .navbar-default .navbar-nav > .active > a, + .navbar-default .navbar-nav > .active > a:hover { + color: inherit; + } + .carousel-control { + display: none; + } + } + @media (min-width: 992px) { + .featurette-heading { + margin-top: 120px; + } + } + + @media (max-width: 768px) { + .navbar .navbar-header { + display: block; + float: none; + } + .navbar .navbar-header .navbar-toggle { + background-color: #ffffff; + padding: 9px 10px; + border: none; + } + } + + +} diff --git a/src/app/less/md-skin.less b/src/app/less/md-skin.less new file mode 100755 index 0000000..da6751d --- /dev/null +++ b/src/app/less/md-skin.less @@ -0,0 +1,388 @@ +@import url("https://fonts.googleapis.com/css?family=Roboto:400,300,500,700"); + +@md-color-primary: #1AB394; +@md-shadow-main: 0 2px 2px 0 rgba(0, 0, 0, .14), 0 3px 1px -2px rgba(0, 0, 0, .2), 0 1px 5px 0 rgba(0, 0, 0, .12); + +body.md-skin { + font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif; + background-color: #ffffff; +} + +.md-skin { + + .nav-header { + background: url("patterns/4.png") no-repeat; + + } + + .label, .badge { + font-family: 'Roboto'; + } + + .font-bold { + font-weight: 500; + } + + .wrapper-content { + padding: 30px 20px 40px; + } + + @media (max-width: 768px) { + .wrapper-content { + padding: 30px 0 40px; + } + } + + .page-heading { + border-bottom: none !important; + border-top: 0; + padding: 0 10px 20px 10px; + box-shadow: 0 1px 1px -1px rgba(0, 0, 0, 0.34), 0 0px 6px 0px rgba(0, 0, 0, 0.14); + } + + .full-height-layout .page-heading { + border-bottom: 1px solid @border-color !important; + } + + .ibox { + clear: both; + margin-bottom: 25px; + margin-top: 0; + padding: 0; + box-shadow: @md-shadow-main; + } + + .ibox.border-bottom { + border-bottom: none !important; + } + + .ibox-title, .ibox-content { + border-style: none; + } + + .ibox-title h5 { + font-size: 16px; + font-weight: 400; + } + + a.close-canvas-menu { + color: #ffffff; + } + + .welcome-message { + color: #ffffff; + font-weight: 300; + } + + #top-search::-moz-placeholder { + color: #ffffff; + } + + #top-search::-webkit-input-placeholder { + color: #ffffff; + } + + #nestable-output, + #nestable2-output { + font-family: 'Roboto', lucida grande, lucida sans unicode, helvetica, arial, sans-serif; + } + + .landing-page { + font-family: 'Roboto', helvetica, arial, sans-serif; + } + + .landing-page.navbar-default.navbar-scroll { + background-color: #fff !important; + } + .landing-page.navbar-default { + background-color: transparent !important; + box-shadow: none; + } + .landing-page.navbar-default .nav li a { + font-family: 'Roboto', helvetica, arial, sans-serif; + } + + .nav > li > a { + color: @text-color; + padding: 14px 20px 14px 25px; + } + + .nav.navbar-right > li > a { + color: #ffffff; + } + + .nav > li.active > a { + color: darken(@text-color, 5%); + font-weight: 700; + } + + .navbar-default .nav > li > a:hover, .navbar-default .nav > li > a:focus { + font-weight: 700; + color: darken(@text-color, 5%); + } + + .nav .open > a, .nav .open > a:hover, .nav .open > a:focus { + background: @navy; + } + + .navbar-top-links li { + display: inline-table; + } + + .navbar-top-links .dropdown-menu li { + display: block; + } + + .pace-done .nav-header { + transition: all 0.4s; + } + + .nav > li.active { + background: lighten(@gray, 2%); + } + + .nav-second-level li a { + padding: 7px 10px 7px 52px; + } + + .navbar-top-links li a { + padding: 20px 10px; + min-height: 50px; + } + + .nav > li > a { + font-weight: 400; + } + + .navbar-static-side .nav > li > a:focus, .navbar-static-side .nav > li > a:hover { + background-color: inherit; + } + + .navbar-top-links .dropdown-menu li a { + padding: 3px 20px; + min-height: inherit; + } + + .nav-header a { + color: #ffffff; + } + + .nav-header .text-muted { + color: #ffffff; + } + + .navbar-form-custom .form-control { + font-weight: 300; + } + + .mini-navbar .nav-second-level { + background-color: inherit; + } + + .mini-navbar li.active .nav-second-level { + left: 65px + } + + .canvas-menu.mini-navbar .nav-second-level { + background: inherit; + } + + .pace-done .navbar-static-side, .pace-done .nav-header, .pace-done li.active, .pace-done #page-wrapper, .pace-done .footer { + -webkit-transition: all 0.4s; + -moz-transition: all 0.4s; + -o-transition: all 0.4s; + transition: all 0.4s; + } + + .navbar-fixed-top { + background: #fff; + transition-duration: 0.4s; + z-index: 2030; + border-bottom: none !important; + } + + .navbar-fixed-top, .navbar-static-top { + background-color: @md-color-primary !important; + box-shadow: @md-shadow-main; + } + + .navbar-static-side { + box-shadow: @md-shadow-main; + } + + // Right sidebar + + #right-sidebar { + box-shadow: @md-shadow-main; + border: none; + z-index: 900; + } + + .white-bg .navbar-fixed-top, .white-bg .navbar-static-top { + background: #fff !important; + } + + .contact-box { + box-shadow: @md-shadow-main; + border: none; + } + + .dashboard-header { + border-bottom: none !important; + border-top: 0; + padding: 20px 20px 20px 20px; + margin: 30px 20px 0 20px; + box-shadow: @md-shadow-main; + } + + @media (max-width: 768px) { + .dashboard-header { + margin: 20px 0 0 0; + } + } + + ul.notes li div { + + box-shadow: @md-shadow-main; + } + + .file { + border: none; + box-shadow: @md-shadow-main; + } + + .mail-box { + background-color: #ffffff; + box-shadow: @md-shadow-main; + padding: 0; + margin-bottom: 20px; + border: none; + } + + .mail-box-header { + border: none; + background-color: #ffffff; + box-shadow: @md-shadow-main; + padding: 30px 20px 20px 20px; + } + + .mailbox-content { + border: none; + padding: 20px; + background: #ffffff; + } + + .social-feed-box { + border: none; + background: #fff; + margin-bottom: 15px; + box-shadow: @md-shadow-main; + } + + &.landing-page .navbar-default { + background-color: transparent !important; + border-color: transparent; + transition: all 0.3s ease-in-out 0s; + box-shadow: none; + } + + &.landing-page .navbar-default.navbar-scroll, + &.landing-page.body-small .navbar-default, + { + background-color: #ffffff !important; + } + + &.landing-page .nav > li.active { + background: inherit; + } + + &.landing-page .navbar-scroll .navbar-nav > li > a { + padding: 20px 10px; + } + + &.landing-page .navbar-default .nav li a { + font-family: 'Roboto', helvetica, arial, sans-serif; + } + + &.landing-page .nav > li > a { + padding: 25px 10px 15px 10px; + } + + &.landing-page .navbar-default .navbar-nav > li > a:hover, + &.landing-page .navbar-default .navbar-nav > li > a:focus { + background: inherit; + color: @navy; + } + + &.landing-page.body-small .nav.navbar-right > li > a { + color: @text-color; + } + + .landing_link a, .special_link a { + color: #ffffff !important; + } + + &.canvas-menu.mini-navbar .nav-second-level { + background: lighten(@gray, 2%); + } + + &.mini-navbar .nav-second-level { + background-color: #ffffff; + box-shadow: @md-shadow-main; + } + + &.mini-navbar .nav-second-level li a { + padding-left: 0px; + } + + &.top-navigation .nav.navbar-right > li > a { + padding: 15px 20px; + color: @text-color; + } + + &.top-navigation .nav > li a:hover, .top-navigation .nav > li a:focus, + &.top-navigation .nav .open > a, + &.top-navigation .nav .open > a:hover, + &.top-navigation .nav .open > a:focus { + color: @navy; + background: #ffffff; + } + + &.top-navigation .nav > li.active a { + color: @navy; + background: #ffffff; + } + + &.fixed-nav #wrapper.top-navigation #page-wrapper { + margin-top: 0; + } + + &.fixed-sidebar.mini-navbar .navbar-static-side { + width: 0; + } + + &.fixed-sidebar.mini-navbar #page-wrapper { + margin: 0 0 0 0; + } + + &.body-small.fixed-sidebar.mini-navbar #page-wrapper { + margin: 0 0 0 0; + } + + &.body-small.fixed-sidebar.mini-navbar .navbar-static-side { + width: @sidebar-width; + background-color: #ffffff; + } + + &.canvas-menu nav.navbar-static-side { + z-index: 2001; + background: #ffffff; + height: 100%; + position: fixed; + display: none; + } + +} + + + diff --git a/src/app/less/media.less b/src/app/less/media.less new file mode 100755 index 0000000..5c27f41 --- /dev/null +++ b/src/app/less/media.less @@ -0,0 +1,122 @@ +@media (min-width: 768px) { + #page-wrapper { + position: inherit; + margin: 0 0 0 @sidebar-width; + min-height: 1200px; + } + + .navbar-static-side { + z-index: 2001; + position: absolute; + width: @sidebar-width; + } + + .navbar-top-links .dropdown-messages, + .navbar-top-links .dropdown-tasks, + .navbar-top-links .dropdown-alerts { + margin-left: auto; + } +} + +@media (max-width: 768px) { + + #page-wrapper { + position: inherit; + margin: 0 0 0 0px; + min-height: 1000px; + } + + .body-small .navbar-static-side { + display: none; + z-index: 2001; + position: absolute; + width: 70px; + } + + .body-small.mini-navbar .navbar-static-side { + display: block; + } + + .lock-word { + display: none; + } + + .navbar-form-custom { + display: none; + } + + .navbar-header { + display: inline; + float: left; + } + + .sidebard-panel { + z-index: 2; + position: relative; + width: auto; + min-height: 100% !important; + } + + .sidebar-content .wrapper { + padding-right: 0px; + z-index: 1; + } + + .fixed-sidebar.body-small .navbar-static-side { + display: none; + z-index: 2001; + position: fixed; + width: @sidebar-width; + } + + .fixed-sidebar.body-small.mini-navbar .navbar-static-side { + display: block; + } + + .ibox-tools { + float: none; + text-align: right; + display: block; + } + +} + +@media (max-width: 350px) { + + .timeline-item .date { + text-align: left; + width: 110px; + position: relative; + padding-top: 30px; + } + + .timeline-item .date i { + position: absolute; + top: 0; + left: 15px; + padding: 5px; + width: 30px; + text-align: center; + border: 1px solid @border-color; + background: #f8f8f8; + } + + .timeline-item .content { + border-left: none; + border-top: 1px solid @border-color; + padding-top: 10px; + min-height: 100px; + } + + .nav.navbar-top-links li.dropdown { + display: none; + } + + .ibox-tools { + float: none; + text-align: left; + display: inline-block; + } + +} + diff --git a/src/app/less/metismenu.less b/src/app/less/metismenu.less new file mode 100755 index 0000000..0c27f5d --- /dev/null +++ b/src/app/less/metismenu.less @@ -0,0 +1,81 @@ +/* + * metismenu - v2.0.2 + * A jQuery menu plugin + * https://github.com/onokumus/metisMenu + * + * Made by Osman Nuri Okumus + * Under MIT License + */ + +.metismenu .plus-minus, .metismenu .plus-times { + float: right +} + +.metismenu .arrow { + float: right; + line-height: 1.42857 +} + +.metismenu .glyphicon.arrow:before { + content: "\e079" +} + +.metismenu .active > a > .glyphicon.arrow:before { + content: "\e114" +} + +.metismenu .fa.arrow:before { + content: "\f104" +} + +.metismenu .active > a > .fa.arrow:before { + content: "\f107" +} + +.metismenu .ion.arrow:before { + content: "\f3d2" +} + +.metismenu .active > a > .ion.arrow:before { + content: "\f3d0" +} + +.metismenu .fa.plus-minus:before, .metismenu .fa.plus-times:before { + content: "\f067" +} + +.metismenu .active > a > .fa.plus-times { + -webkit-transform: rotate(45deg); + -ms-transform: rotate(45deg); + transform: rotate(45deg) +} + +.metismenu .active > a > .fa.plus-minus:before { + content: "\f068" +} + +.metismenu .collapse { + display: none +} + +.metismenu .collapse.in { + display: block +} + +.metismenu .collapsing { + position: relative; + height: 0; + overflow: hidden; + -webkit-transition-timing-function: ease; + transition-timing-function: ease; + -webkit-transition-duration: .35s; + transition-duration: .35s; + -webkit-transition-property: height, visibility; + transition-property: height, visibility +} + + + + + + diff --git a/src/app/less/mixins.less b/src/app/less/mixins.less new file mode 100755 index 0000000..e0ee517 --- /dev/null +++ b/src/app/less/mixins.less @@ -0,0 +1,15 @@ +.border-radius (@radius: 3px) { + -webkit-border-radius: @radius; + -moz-border-radius: @radius; + border-radius: @radius; + + -moz-background-clip: padding; + -webkit-background-clip: padding-box; + background-clip: padding-box; +} + +.opacity (@opacity: 0.5) { + -webkit-opacity: @opacity; + -moz-opacity: @opacity; + opacity: @opacity; +} \ No newline at end of file diff --git a/src/app/less/navigation.less b/src/app/less/navigation.less new file mode 100755 index 0000000..3e4e56f --- /dev/null +++ b/src/app/less/navigation.less @@ -0,0 +1,506 @@ +.nav > li > a { + color: @nav-text-color; + font-weight: 600; + padding: 14px 20px 14px 25px; +} + +.nav.navbar-right > li > a { + color: #999c9e; +} + +.nav > li.active > a { + color: #ffffff; +} + +.navbar-default .nav > li > a:hover, .navbar-default .nav > li > a:focus { + background-color: darken(@nav-bg, 3%); + color: white; +} + +.nav .open > a, .nav .open > a:hover, .nav .open > a:focus { + background: #fff; +} + +.nav.navbar-top-links > li > a:hover, .nav.navbar-top-links > li > a:focus { + background-color: transparent; +} + +.nav > li > a i { + margin-right: 6px; +} + +.navbar { + border: 0; +} + +.navbar-default { + background-color: transparent; + border-color: @nav-bg; +} + +.navbar-top-links li { + display: inline-block; +} + +.navbar-top-links li:last-child { + margin-right: 40px; +} + +.body-small .navbar-top-links li:last-child { + margin-right: 0; +} + +.navbar-top-links li a { + padding: 20px 10px; + min-height: 50px; +} + +.dropdown-menu { + border: medium none; + border-radius: 3px; + box-shadow: 0 0 3px rgba(86, 96, 117, 0.7); + display: none; + float: left; + font-size: 12px; + left: 0; + list-style: none outside none; + padding: 0; + position: absolute; + text-shadow: none; + top: 100%; + z-index: 1000; +} + +.dropdown-menu > li > a { + border-radius: 3px; + color: inherit; + line-height: 25px; + margin: 4px; + text-align: left; + font-weight: normal; +} + +.dropdown-menu > li > a.font-bold { + font-weight: 600; +} + +.navbar-top-links .dropdown-menu li { + display: block; +} + +.navbar-top-links .dropdown-menu li:last-child { + margin-right: 0; +} + +.navbar-top-links .dropdown-menu li a { + padding: 3px 20px; + min-height: 0; +} + +.navbar-top-links .dropdown-menu li a div { + white-space: normal; +} + +.navbar-top-links .dropdown-messages, +.navbar-top-links .dropdown-tasks, +.navbar-top-links .dropdown-alerts { + width: 310px; + min-width: 0; +} + +.navbar-top-links .dropdown-messages { + margin-left: 5px; +} + +.navbar-top-links .dropdown-tasks { + margin-left: -59px; +} + +.navbar-top-links .dropdown-alerts { + margin-left: -123px; +} + +.navbar-top-links .dropdown-user { + right: 0; + left: auto; +} + +.dropdown-messages, .dropdown-alerts { + padding: 10px 10px 10px 10px; +} + +.dropdown-messages li a, .dropdown-alerts li a { + font-size: 12px; +} + +.dropdown-messages li em, .dropdown-alerts li em { + font-size: 10px; +} + +.nav.navbar-top-links .dropdown-alerts a { + font-size: 12px; +} + +.nav-header { + padding: 33px 25px; + background: @nav-profil-pattern; + +} + +.pace-done .nav-header { + transition:all 0.5s; +} + +.nav > li.active { + border-left: 4px solid darken(@navy, 2%); + background: darken(@nav-bg, 3%); +} + + +.nav.nav-second-level > li.active { + border: none; +} + +.nav.nav-second-level.collapse[style] { + height: auto !important; +} + +.nav-header a { + color: #DFE4ED; +} + +.nav-header .text-muted { + color: #8095a8; +} + +.minimalize-styl-2 { + padding: 4px 12px; + margin: 14px 5px 5px 20px; + font-size: 14px; + float: left; +} + +.navbar-form-custom { + float: left; + height: 50px; + padding: 0; + width: 200px; + display: inline-table; +} + +.navbar-form-custom .form-group { + margin-bottom: 0; +} + +.nav.navbar-top-links a { + font-size: 14px; +} + +.navbar-form-custom .form-control { + background: none repeat scroll 0 0 rgba(0, 0, 0, 0); + border: medium none; + font-size: 14px; + height: 60px; + margin: 0; + z-index: 2000; +} + +.count-info .label { + line-height: 12px; + padding: 2px 5px; + position: absolute; + right: 6px; + top: 12px; +} + +.arrow { + float: right; +} + +.fa.arrow:before { + content: "\f104"; +} + +.active > a > .fa.arrow:before { + content: "\f107"; +} + +.nav-second-level li, +.nav-third-level li { + border-bottom: none !important; +} + +.nav-second-level li a { + padding: 7px 10px 7px 10px; + padding-left: 52px; +} + +.nav-third-level li a { + padding-left: 62px; +} + +.nav-second-level li:last-child { + margin-bottom: 10px; +} + +body:not(.fixed-sidebar):not(.canvas-menu).mini-navbar .nav li:hover > .nav-second-level, +.mini-navbar .nav li:focus > .nav-second-level { + display: block; + border-radius: 0 2px 2px 0; + min-width: 140px; + height: auto; +} + +body.mini-navbar .navbar-default .nav > li > .nav-second-level li a { + font-size: 12px; + border-radius: 3px; +} + +.fixed-nav .slimScrollDiv #side-menu { + padding-bottom: 60px; +} + +.mini-navbar .nav-second-level li a { + padding: 10px 10px 10px 15px; +} + +.mini-navbar .nav-second-level { + position: absolute; + left: 70px; + top: 0px; + background-color: @nav-bg; + padding: 10px 10px 10px 10px; + font-size: 12px; +} + +.canvas-menu.mini-navbar .nav-second-level { + background: darken(@nav-bg, 3%); +} + +.mini-navbar li.active .nav-second-level { + left: 65px +} + +.navbar-default .special_link a { + background: @navy; + color: white; +} +.navbar-default .special_link a:hover { + background: #17987e !important; + color: white; +} +.navbar-default .special_link a span.label{ + background: #fff; + color: @navy; +} + +.navbar-default .landing_link a { + background: lighten(@navy, 3%); + color: white; +} +.navbar-default .landing_link a:hover { + background: @navy !important; + color: white; +} +.navbar-default .landing_link a span.label{ + background: #fff; + color: lighten(@navy, 3%); +} + +.logo-element { + text-align: center; + font-size: 18px; + font-weight: 600; + color: white; + display: none; + padding: 18px 0; +} + +.pace-done .navbar-static-side, .pace-done .nav-header, .pace-done li.active, .pace-done #page-wrapper, .pace-done .footer { + -webkit-transition: all 0.5s; + -moz-transition: all 0.5s; + -o-transition: all 0.5s; + transition: all 0.5s; +} + +.navbar-fixed-top { + background: #fff; + transition-duration: 0.5s; + border-bottom: 1px solid #e7eaec !important; + z-index: 2030; +} + +.navbar-fixed-top, .navbar-static-top { + background: @gray; +} + +.fixed-nav #wrapper { + margin-top: 0; +} + +body.fixed-nav #wrapper .navbar-static-side, +body.fixed-nav #wrapper #page-wrapper +{ + margin-top: 60px; +} + +body.top-navigation.fixed-nav #wrapper #page-wrapper { + margin-top: 0; +} + +.fixed-nav .minimalize-styl-2 { + margin: 14px 5px 5px 15px; +} + +.body-small .navbar-fixed-top { + margin-left: 0px; +} + +body.mini-navbar .navbar-static-side { + width: 70px; +} + +body.mini-navbar .profile-element, body.mini-navbar .nav-label, body.mini-navbar .navbar-default .nav li a span { + display: none; +} + +body.canvas-menu .profile-element { + display: block; +} + +body:not(.fixed-sidebar):not(.canvas-menu).mini-navbar .nav-second-level { + display: none; +} + +body.mini-navbar .navbar-default .nav > li > a { + font-size: 16px; +} + +body.mini-navbar .logo-element { + display: block; +} + +body.canvas-menu .logo-element { + display: none; +} + +body.mini-navbar .nav-header { + padding: 0; + background-color: @navy; +} + +body.canvas-menu .nav-header { + padding: 33px 25px; +} + +body.mini-navbar #page-wrapper { + margin: 0 0 0 70px; +} + +body.fixed-sidebar.mini-navbar .footer, +body.canvas-menu.mini-navbar .footer{ + margin: 0 0 0 0 !important; +} + +body.canvas-menu.mini-navbar #page-wrapper, +body.canvas-menu.mini-navbar .footer { + margin: 0 0 0 0; +} + +body.fixed-sidebar .navbar-static-side, +body.canvas-menu .navbar-static-side { + position: fixed; + width: @sidebar-width; + z-index: 2001; + height: 100%; +} + +body.fixed-sidebar.mini-navbar .navbar-static-side { + width: 0px; +} + +body.fixed-sidebar.mini-navbar #page-wrapper { + margin: 0 0 0 0px; +} + +body.body-small.fixed-sidebar.mini-navbar #page-wrapper { + margin: 0 0 0 @sidebar-width; +} + +body.body-small.fixed-sidebar.mini-navbar .navbar-static-side { + width: @sidebar-width; +} + +.fixed-sidebar.mini-navbar .nav li:focus > .nav-second-level, +.canvas-menu.mini-navbar .nav li:focus > .nav-second-level { + display: block; + height: auto; +} + +body.fixed-sidebar.mini-navbar .navbar-default .nav > li > .nav-second-level li a { + font-size: 12px; + border-radius: 3px; +} + +body.canvas-menu.mini-navbar .navbar-default .nav > li > .nav-second-level li a { + font-size: 13px; + border-radius: 3px; +} + +.fixed-sidebar.mini-navbar .nav-second-level li a, +.canvas-menu.mini-navbar .nav-second-level li a { + padding: 10px 10px 10px 15px; +} + +.fixed-sidebar.mini-navbar .nav-second-level, +.canvas-menu.mini-navbar .nav-second-level { + position: relative; + padding: 0; + font-size: 13px; +} + +.fixed-sidebar.mini-navbar li.active .nav-second-level, +.canvas-menu.mini-navbar li.active .nav-second-level { + left: 0px +} + +body.fixed-sidebar.mini-navbar .navbar-default .nav > li > a, +body.canvas-menu.mini-navbar .navbar-default .nav > li > a { + font-size: 13px; +} + +body.fixed-sidebar.mini-navbar .nav-label, +body.fixed-sidebar.mini-navbar .navbar-default .nav li a span, +body.canvas-menu.mini-navbar .nav-label, +body.canvas-menu.mini-navbar .navbar-default .nav li a span { + display: inline; +} + +body.canvas-menu.mini-navbar .navbar-default .nav li .profile-element a span { + display: block; +} + +.canvas-menu.mini-navbar .nav-second-level li a, +.fixed-sidebar.mini-navbar .nav-second-level li a { + padding: 7px 10px 7px 52px +} + +.fixed-sidebar.mini-navbar .nav-second-level, +.canvas-menu.mini-navbar .nav-second-level { + left: 0px +} + + +body.canvas-menu nav.navbar-static-side { + z-index: 2001; + background: #2f4050; + height: 100%; + position: fixed; + display: none; +} + + +body.canvas-menu.mini-navbar nav.navbar-static-side { + display: block; + width: 220px; +} diff --git a/src/app/less/pages.less b/src/app/less/pages.less new file mode 100755 index 0000000..057dc4b --- /dev/null +++ b/src/app/less/pages.less @@ -0,0 +1,1321 @@ +/* SEARCH PAGE */ + +.search-form { + margin-top: 10px; +} + +.search-result h3 { + margin-bottom: 0; + color: #1E0FBE; +} + +.search-result .search-link { + color: #006621; +} + +.search-result p { + font-size: 12px; + margin-top: 5px; +} + +/* CONTACTS */ + +.contact-box { + background-color: #ffffff; + border: 1px solid @border-color; + padding: 20px; + margin-bottom: 20px; +} + +.contact-box > a { + color: inherit; +} + +.contact-box.center-version { + + border: 1px solid @border-color; + padding: 0; +} + +.contact-box.center-version > a { + display: block; + background-color: #ffffff; + padding: 20px; + text-align: center; +} + +.contact-box.center-version > a img { + width: 80px; + height: 80px; + margin-top: 10px; + margin-bottom: 10px; +} + +.contact-box.center-version address { + margin-bottom: 0; +} + +.contact-box .contact-box-footer { + text-align: center; + background-color: #ffffff; + border-top: 1px solid @border-color; + padding: 15px 20px; +} + +/* INVOICE */ + +.invoice-table tbody > tr > td:last-child, .invoice-table tbody > tr > td:nth-child(4), .invoice-table tbody > tr > td:nth-child(3), .invoice-table tbody > tr > td:nth-child(2) { + text-align: right; +} + +.invoice-table thead > tr > th:last-child, .invoice-table thead > tr > th:nth-child(4), .invoice-table thead > tr > th:nth-child(3), .invoice-table thead > tr > th:nth-child(2) { + text-align: right; +} + +.invoice-total > tbody > tr > td:first-child { + text-align: right; +} + +.invoice-total > tbody > tr > td { + border: 0 none; +} + +.invoice-total > tbody > tr > td:last-child { + border-bottom: 1px solid #DDDDDD; + text-align: right; + width: 15%; +} + +/* ERROR & LOGIN & LOCKSCREEN*/ + +.middle-box { + max-width: 400px; + z-index: 100; + margin: 0 auto; + padding-top: 40px; +} + +.lockscreen.middle-box { + width: 200px; + padding-top: 110px; +} + +.loginscreen.middle-box { + width: 300px; +} + +.loginColumns { + max-width: 800px; + margin: 0 auto; + padding: 100px 20px 20px 20px; +} + +.passwordBox { + max-width: 460px; + margin: 0 auto; + padding: 100px 20px 20px 20px; +} + +.logo-name { + color: #e6e6e6; + font-size: 180px; + font-weight: 800; + letter-spacing: -10px; + margin-bottom: 0px; +} + +.middle-box h1 { + font-size: 170px; +} + +.wrapper .middle-box { + margin-top: 140px; +} + +.lock-word { + z-index: 10; + position: absolute; + top: 110px; + left: 50%; + margin-left: -470px; +} + +.lock-word span { + font-size: 100px; + font-weight: 600; + color: #e9e9e9; + display: inline-block; +} + +.lock-word .first-word { + margin-right: 160px; +} + +/* DASBOARD */ + +.dashboard-header { + border-top: 0; + padding: 20px 20px 20px 20px; +} + +.dashboard-header h2 { + margin-top: 10px; + font-size: 26px; +} + +.fist-item { + border-top: none !important; +} + +.statistic-box { + margin-top: 40px; + +} + +.dashboard-header .list-group-item span.label { + margin-right: 10px; +} + +.list-group.clear-list .list-group-item { + border-top: 1px solid @border-color; + border-bottom: 0; + border-right: 0; + border-left: 0; + padding: 10px 0; +} + +ul.clear-list:first-child { + border-top: none !important; +} + +/* Intimeline */ + +.timeline-item .date i { + position: absolute; + top: 0; + right: 0; + padding: 5px; + width: 30px; + text-align: center; + border-top: 1px solid @border-color; + border-bottom: 1px solid @border-color; + border-left: 1px solid @border-color; + background: #f8f8f8; +} + +.timeline-item .date { + text-align: right; + width: 110px; + position: relative; + padding-top: 30px; +} + +.timeline-item .content { + border-left: 1px solid @border-color; + border-top: 1px solid @border-color; + padding-top: 10px; + min-height: 100px; +} + +.timeline-item .content:hover { + background: #f6f6f6; +} + +/* PIN BOARD */ +ul.notes li, ul.tag-list li { + list-style: none; +} + +ul.notes li h4 { + margin-top: 20px; + font-size: 16px; +} + +ul.notes li div { + text-decoration: none; + color: #000; + background: #ffc; + display: block; + height: 140px; + width: 140px; + padding: 1em; + position: relative; +} + +ul.notes li div small { + position: absolute; + top: 5px; + right: 5px; + font-size: 10px +} + +ul.notes li div a { + position: absolute; + right: 10px; + bottom: 10px; + color: inherit; +} + +ul.notes li { + margin: 10px 40px 50px 0px; + float: left; +} + +ul.notes li div p { + font-size: 12px; +} + +ul.notes li div { + text-decoration: none; + color: #000; + background: #ffc; + display: block; + height: 140px; + width: 140px; + padding: 1em; + /* Firefox */ + -moz-box-shadow: 5px 5px 2px rgba(33, 33, 33, 1); + /* Safari+Chrome */ + -webkit-box-shadow: 5px 5px 2px rgba(33, 33, 33, .7); + /* Opera */ + box-shadow: 5px 5px 2px rgba(33, 33, 33, .7); +} + +ul.notes li div { + -webkit-transform: rotate(-6deg); + -o-transform: rotate(-6deg); + -moz-transform: rotate(-6deg); +} + +ul.notes li:nth-child(even) div { + -o-transform: rotate(4deg); + -webkit-transform: rotate(4deg); + -moz-transform: rotate(4deg); + position: relative; + top: 5px; +} + +ul.notes li:nth-child(3n) div { + -o-transform: rotate(-3deg); + -webkit-transform: rotate(-3deg); + -moz-transform: rotate(-3deg); + position: relative; + top: -5px; +} + +ul.notes li:nth-child(5n) div { + -o-transform: rotate(5deg); + -webkit-transform: rotate(5deg); + -moz-transform: rotate(5deg); + position: relative; + top: -10px; +} + +ul.notes li div:hover, ul.notes li div:focus { + + -webkit-transform: scale(1.1); + -moz-transform: scale(1.1); + -o-transform: scale(1.1); + position: relative; + z-index: 5; +} + +ul.notes li div { + text-decoration: none; + color: #000; + background: #ffc; + display: block; + height: 210px; + width: 210px; + padding: 1em; + -moz-box-shadow: 5px 5px 7px rgba(33, 33, 33, 1); + -webkit-box-shadow: 5px 5px 7px rgba(33, 33, 33, .7); + box-shadow: 5px 5px 7px rgba(33, 33, 33, .7); + -moz-transition: -moz-transform .15s linear; + -o-transition: -o-transform .15s linear; + -webkit-transition: -webkit-transform .15s linear; +} + +/* FILE MANAGER */ + +.file-box { + float: left; + width: 220px; +} + +.file-manager h5 { + text-transform: uppercase; +} + +.file-manager { + list-style: none outside none; + margin: 0; + padding: 0; +} + +.folder-list li a { + color: #666666; + display: block; + padding: 5px 0; +} + +.folder-list li { + border-bottom: 1px solid @border-color; + display: block; +} + +.folder-list li i { + margin-right: 8px; + color: #3d4d5d; +} + +.category-list li a { + color: #666666; + display: block; + padding: 5px 0; +} + +.category-list li { + display: block; +} + +.category-list li i { + margin-right: 8px; + color: #3d4d5d; +} + +.category-list li a .text-navy { + color: @navy; +} + +.category-list li a .text-primary { + color: @blue; +} + +.category-list li a .text-info { + color: @lazur; +} + +.category-list li a .text-danger { + color: #EF5352; +} + +.category-list li a .text-warning { + color: #F8AC59; +} + +.file-manager h5.tag-title { + margin-top: 20px; +} + +.tag-list li { + float: left; +} + +.tag-list li a { + font-size: 10px; + background-color: @gray; + padding: 5px 12px; + color: inherit; + border-radius: 2px; + border: 1px solid @border-color; + margin-right: 5px; + margin-top: 5px; + display: block; +} + +.file { + border: 1px solid @border-color; + padding: 0; + background-color: #ffffff; + position: relative; + margin-bottom: 20px; + margin-right: 20px; +} + +.file-manager .hr-line-dashed { + margin: 15px 0; +} + +.file .icon, .file .image { + height: 100px; + overflow: hidden; +} + +.file .icon { + padding: 15px 10px; + text-align: center; +} + +.file-control { + color: inherit; + font-size: 11px; + margin-right: 10px; +} + +.file-control.active { + text-decoration: underline; +} + +.file .icon i { + font-size: 70px; + color: #dadada; +} + +.file .file-name { + padding: 10px; + background-color: #f8f8f8; + border-top: 1px solid @border-color; +} + +.file-name small { + color: @text-color; +} + +.corner { + position: absolute; + display: inline-block; + width: 0; + height: 0; + line-height: 0; + border: 0.6em solid transparent; + border-right: 0.6em solid #f1f1f1; + border-bottom: 0.6em solid #f1f1f1; + right: 0em; + bottom: 0em +} + +a.compose-mail { + padding: 8px 10px; +} + +.mail-search { + max-width: 300px; +} + +/* PROFILE */ + +.profile-content { + border-top: none !important; +} + +.profile-stats { + margin-right: 10px; +} + +.profile-image { + width: 120px; + float: left; +} + +.profile-image img { + width: 96px; + height: 96px; +} + +.profile-info { + margin-left: 120px; +} + +.feed-activity-list .feed-element { + border-bottom: 1px solid @border-color; +} + +.feed-element:first-child { + margin-top: 0; +} + +.feed-element { + padding-bottom: 15px; +} + +.feed-element, .feed-element .media { + margin-top: 15px; +} + +.feed-element, .media-body { + overflow: hidden; +} + +.feed-element > .pull-left { + margin-right: 10px; +} + +.feed-element img.img-circle, .dropdown-messages-box img.img-circle { + width: 38px; + height: 38px; +} + +.feed-element .well { + border: 1px solid @border-color; + box-shadow: none; + margin-top: 10px; + margin-bottom: 5px; + padding: 10px 20px; + font-size: 11px; + line-height: 16px; +} + +.feed-element .actions { + margin-top: 10px; +} + +.feed-element .photos { + margin: 10px 0; + +} + +.feed-photo { + max-height: 180px; + border-radius: 4px; + overflow: hidden; + margin-right: 10px; + margin-bottom: 10px; +} + + +.file-list li { + padding: 5px 10px; + font-size: 11px; + border-radius: 2px; + border: 1px solid @border-color; + margin-bottom: 5px; + +} + +.file-list li a { + color: inherit; +} + +.file-list li a:hover { + color: @navy; +} + +.user-friends img { + width: 42px; + height: 42px; + margin-bottom: 5px; + margin-right: 5px; + +} + + +/* MAILBOX */ + +.mail-box { + background-color: #ffffff; + border: 1px solid @border-color; + border-top: 0; + padding: 0px; + margin-bottom: 20px; +} + +.mail-box-header { + background-color: #ffffff; + border: 1px solid @border-color; + border-bottom: 0; + padding: 30px 20px 20px 20px; +} + +.mail-box-header h2 { + margin-top: 0px; +} + +.mailbox-content .tag-list li a { + background: #ffffff; +} + +.mail-body { + border-top: 1px solid @border-color; + padding: 20px; +} + +.mail-text { + border-top: 1px solid @border-color; +} + +.mail-text .note-toolbar { + padding: 10px 15px; +} + +.mail-body .form-group { + margin-bottom: 5px; +} + +.mail-text .note-editor .note-toolbar { + background-color: #F9F8F8; +} + +.mail-attachment { + border-top: 1px solid @border-color; + padding: 20px; + font-size: 12px; +} + +.mailbox-content { + background: none; + border: none; + padding: 10px; +} + +.mail-ontact { + width: 23%; +} + +/* PROJECTS */ +.project-people, .project-actions { + text-align: right; + vertical-align: middle; +} + +dd.project-people { + text-align: left; + margin-top: 5px; +} + +.project-people img { + width: 32px; + height: 32px; +} + +.project-title a { + font-size: 14px; + color: @text-color; + font-weight: 600; +} + +.project-list table tr td { + border-top: none; + border-bottom: 1px solid @border-color; + padding: 15px 10px; + vertical-align: middle; +} + +.project-manager .tag-list li a { + font-size: 10px; + background-color: white; + padding: 5px 12px; + color: inherit; + border-radius: 2px; + border: 1px solid @border-color; + margin-right: 5px; + margin-top: 5px; + display: block; +} + +.project-files li a { + font-size: 11px; + color: @text-color; + margin-left: 10px; + line-height: 22px; +} + +/* FAQ */ + +.faq-item { + padding: 20px; + margin-bottom: 2px; + background: #fff; +} + +.faq-question { + font-size: 18px; + font-weight: 600; + color: @navy; + display: block; +} + +.faq-question:hover { + color: darken(@navy, 5%); +} + +.faq-answer { + margin-top: 10px; + background: @gray; + border: 1px solid @border-color; + border-radius: 3px; + padding: 15px; +} + +.faq-item .tag-item { + background: @gray; + padding: 2px 6px; + font-size: 10px; + text-transform: uppercase; +} + +/* Chat view */ +.message-input { + height: 90px !important; +} + +.chat-avatar { + white: 36px; + height: 36px; + float: left; + margin-right: 10px; +} + +.chat-user-name { + padding: 10px; +} + +.chat-user { + padding: 8px 10px; + border-bottom: 1px solid #e7eaec; +} + +.chat-user a { + color: inherit; +} + +.chat-view { + z-index: 20012; +} + +.chat-users, .chat-statistic { + margin-left: -30px; +} + +@media (max-width: 992px) { + .chat-users,.chat-statistic { + margin-left: 0px; + } +} +.chat-view .ibox-content { + padding: 0; +} + +.chat-message { + padding: 10px 20px; +} + +.message-avatar { + height: 48px; + width: 48px; + border: 1px solid #e7eaec; + border-radius: 4px; + margin-top: 1px; +} + +.chat-discussion .chat-message.left .message-avatar { + float: left; + margin-right: 10px; +} + +.chat-discussion .chat-message.right .message-avatar { + float: right; + margin-left: 10px; +} + +.message { + background-color: #fff; + border: 1px solid #e7eaec; + text-align: left; + display: block; + padding: 10px 20px; + position: relative; + border-radius: 4px; +} + +.chat-discussion .chat-message.left .message-date { + float: right; +} + +.chat-discussion .chat-message.right .message-date { + float: left; +} + +.chat-discussion .chat-message.left .message { + text-align: left; + margin-left: 55px; +} + +.chat-discussion .chat-message.right .message { + text-align: right; + margin-right: 55px; +} + +.message-date { + font-size: 10px; + color: #888888; +} + +.message-content { + display: block; +} + +.chat-discussion { + background: #eee; + padding: 15px; + height: 400px; + overflow-y: auto; +} + +.chat-users { + overflow-y: auto; + height: 400px; +} + +.chat-message-form .form-group { + margin-bottom: 0; +} + +/* jsTree */ +.jstree-open > .jstree-anchor > .fa-folder:before { + content: "\f07c"; +} + +.jstree-default .jstree-icon.none { + width: 0; +} + +/* CLIENTS */ + +.clients-list { + margin-top: 20px; +} + +.clients-list .tab-pane { + position: relative; + height: 600px; +} + +.client-detail { + position: relative; + height: 620px; +} + +.clients-list table tr td { + height: 46px; + vertical-align: middle; + border: none ; +} + +.client-link { + font-weight: 600; + color: inherit; +} + +.client-link:hover { + color: inherit; +} + +.client-avatar { + width: 42px; +} + +.client-avatar img { + width: 28px; + height: 28px; + border-radius: 50%; +} + +.contact-type { + width: 20px; + color: lighten(@text-color, 35%); +} + +.client-status { + text-align: left; +} + +.client-detail .vertical-timeline-content p { + margin: 0; +} + +.client-detail .vertical-timeline-icon.gray-bg { + color: lighten(@text-color, 25px); +} + +.clients-list { + .nav-tabs > li.active > a, .nav-tabs > li.active > a:hover, .nav-tabs > li.active > a:focus { + border-bottom: 1px solid #fff; + } +} + +/* BLOG ARTICLE */ +.blog h2 { + font-weight: 700; +} + +.blog h5 { + margin: 0 0 5px 0; +} + +.blog .btn{ + margin: 0 0 5px 0; +} + +.article h1 { + font-size: 48px; + font-weight: 700; + color: #2F4050; +} + +.article p { + font-size: 15px; + line-height: 26px; +} + +.article-title { + text-align: center; + margin: 40px 0 100px 0; +} + +.article .ibox-content { + padding: 40px; +} + +/* ISSUE TRACKER */ + +.issue-tracker .btn-link { + color: @navy; +} + +table.issue-tracker tbody tr td { + vertical-align: middle; + height: 50px; +} + +.issue-info { + width: 50%; +} + +.issue-info a { + font-weight: 600; + color: @text-color; +} + +.issue-info small { + display: block; +} + +/* TEAMS */ +.team-members { + margin: 10px 0; +} + +.team-members img.img-circle { + width: 42px; + height: 42px; + margin-bottom: 5px; +} + +/* AGILE BOARD */ + +.sortable-list { + padding: 10px 0; +} +.agile-list { + list-style: none; + margin: 0; +} +.agile-list li { + + background: #FAFAFB; + border: 1px solid #e7eaec; + margin: 0px 0 10px 0; + padding: 10px; + border-radius: 2px; +} +.agile-list li:hover { + cursor: pointer; + background: #fff; +} +.agile-list li.warning-element { + border-left: 3px solid @yellow; +} +.agile-list li.danger-element { + border-left: 3px solid @red; +} +.agile-list li.info-element { + border-left: 3px solid @blue; +} +.agile-list li.success-element { + border-left: 3px solid @navy; +} +.agile-detail { + margin-top: 5px; + font-size: 12px; +} + +/* DIFF */ +ins { + background-color: #c6ffc6; + text-decoration: none; +} + +del { + background-color: #ffc6c6; +} + +/* E-commerce */ +.product-box { + padding: 0; + + border: 1px solid @border-color; +} + + + +.product-box:hover, +.product-box.active { + border: 1px solid transparent; + -webkit-box-shadow: 0px 3px 7px 0px rgba(168,168,168,1); + -moz-box-shadow: 0px 3px 7px 0px rgba(168,168,168,1); + box-shadow: 0px 3px 7px 0px rgba(168,168,168,1); +} + +.product-imitation { + text-align: center; + padding: 90px 0; + background-color: lighten(@gray, 2%); + color: darken(@gray, 20%); + font-weight: 600; +} + +.product-imitation.xl { + padding: 120px 0; +} + +.product-desc { + padding: 20px; + position: relative; +} + +.ecommerce .tag-list { + padding: 0; +} + +.ecommerce .fa-star { + color: @light-gray; +} + +.ecommerce .fa-star.active { + color: @yellow; +} + +.ecommerce .note-editor { + border: 1px solid @border-color; +} + +.product-name { + font-size: 16px; + font-weight: 600; + color: @text-color; + display: block; + margin: 2px 0 5px 0; +} + +.product-name:hover, +.product-name:focus { + color: @navy; +} + +.product-price { + font-size: 14px; + font-weight: 600; + color: #ffffff; + background-color: @navy; + padding: 6px 12px; + + position: absolute; + top: -32px; + right: 0; +} + +.product-detail .ibox-content{ + padding: 30px 30px 50px 30px; +} + +.image-imitation { + background-color: lighten(@gray, 2%); + text-align: center; + padding: 200px 0; + +} + +.product-main-price small { + font-size: 10px; + +} + +.product-images { + margin: 0 20px; +} + +/* Social feed */ +.social-feed-separated .social-feed-box { + margin-left: 62px; +} + +.social-feed-separated .social-avatar { + float: left; + padding: 0; +} + +.social-feed-separated .social-avatar img { + width: 52px; + height: 52px; + border: 1px solid #e7eaec; +} + +.social-feed-separated .social-feed-box .social-avatar { + padding: 15px 15px 0 15px; + float: none; +} + +.social-feed-box { + /*padding: 15px;*/ + border: 1px solid #e7eaec; + background: #fff; + margin-bottom: 15px; +} + +.article .social-feed-box { + margin-bottom: 0; + border-bottom: none; +} + +.article .social-feed-box:last-child{ + margin-bottom: 0; + border-bottom: 1px solid @border-color; +} + +.article .social-feed-box p { + font-size: 13px; + line-height: 18px; +} + +.social-action { + margin: 15px; +} + +.social-avatar { + padding: 15px 15px 0 15px; +} + +.social-comment .social-comment { + margin-left: 45px; +} + +.social-avatar img { + height: 40px; + width: 40px; + margin-right: 10px; +} + +.social-avatar .media-body a { + font-size: 14px; + display: block; +} + +.social-body { + padding: 15px; +} + +.social-body img { + margin-bottom: 10px; +} + +.social-footer { + border-top: 1px solid #e7eaec; + padding: 10px 15px; + background: #f9f9f9; +} + +.social-footer .social-comment img { + width: 32px; + margin-right: 10px; +} + +.social-comment:first-child { + margin-top: 0; +} + +.social-comment { + margin-top: 15px; +} + +.social-comment textarea { + font-size: 12px; +} + +/* Vote list */ + +.vote-item { + padding: 20px 25px; + background: #ffffff; + border-top: 1px solid @border-color; +} + +.vote-item:last-child { + border-bottom: 1px solid @border-color; +} + +.vote-item:hover { + background: lighten(@gray, 3%); +} + +.vote-actions { + float: left; + width: 30px; + margin-right: 15px; + text-align: center; + +} + +.vote-actions a { + color: @navy; + font-weight: 600; +} +.vote-actions { + font-weight: 600; +} + +.vote-title { + display: block; + color: inherit; + font-size: 18px; + font-weight: 600; + margin-top: 5px; + margin-bottom: 2px; +} + +.vote-title:hover,.vote-title:focus{ + color: inherit; +} + +.vote-info, .vote-title { + margin-left: 45px; +} + +.vote-info, .vote-info a { + color: lighten(@text-color, 30%); + font-size: 12px; +} + +.vote-info a { + margin-right: 10px; +} + +.vote-info a:hover { + color: @navy; +} + +.vote-icon { + text-align: right; + font-size: 38px; + display: block; + color: lighten(@text-color, 50%); +} + +.vote-icon.active { + color: @navy; +} + +body.body-small .vote-icon { + display: none; +} + diff --git a/src/app/less/rtl.less b/src/app/less/rtl.less new file mode 100755 index 0000000..3aaf4e8 --- /dev/null +++ b/src/app/less/rtl.less @@ -0,0 +1,267 @@ +//RTL Support +body.rtls { + + #page-wrapper { + margin: 0 220px 0 0; + } + + .nav-second-level li a { + padding: 7px 35px 7px 10px; + } + + .ibox-title h5 { + float: right; + } + + .pull-right { + float: left !important; + } + + .pull-left { + float: right !important; + } + + .ibox-tools { + float: left; + } + + .stat-percent { + float: left; + } + + .navbar-right { + float: left !important; + } + + .navbar-top-links li:last-child { + margin-left: 40px; + margin-right: 0; + } + + .minimalize-styl-2 { + float: right; + margin: 14px 20px 5px 5px; + } + + .feed-element > .pull-left { + margin-left: 10px; + margin-right: 0; + } + + .timeline-item .date { + text-align: left; + } + + .timeline-item .date i { + left: 0; + right: auto; + } + + .timeline-item .content { + border-right: 1px solid #e7eaec; + border-left: none; + } + + .theme-config { + left: 0; + right: auto; + } + + .spin-icon { + border-radius: 0 20px 20px 0; + } + + .toast-close-button { + float: left; + } + + #toast-container > .toast:before { + margin: auto -1.5em auto 0.5em; + } + + #toast-container > div { + padding: 15px 50px 15px 15px; + } + + .center-orientation .vertical-timeline-icon i { + margin-left: 0; + margin-right: -12px; + } + + .vertical-timeline-icon i { + right: 50%; + left: auto; + margin-left: auto; + margin-right: -12px; + } + + .file-box { + float: right; + } + + ul.notes li { + float: right; + } + + .chat-users, .chat-statistic { + margin-right: -30px; + margin-left: auto; + } + + .dropdown-menu > li > a { + text-align: right; + } + + .b-r { + border-left: 1px solid #e7eaec; + border-right: none; + } + + .dd-list .dd-list { + padding-right: 30px; + padding-left: 0; + } + + .dd-item > button { + float: right + } + + /* Theme config */ + .theme-config-box { + margin-left: -220px; + margin-right: 0; + } + + .theme-config-box.show { + margin-left: 0; + margin-right: 0; + } + + .spin-icon { + right: 0; + left: auto; + } + + .skin-setttings { + margin-right: 40px; + margin-left: 0; + } + + .skin-setttings { + direction: ltr; + } + + .footer.fixed { + margin-right: 220px; + margin-left: 0; + } + +} + +@media (max-width: 992px) { + body.rtls { + .chat-users,.chat-statistic { + margin-right: 0px; + } + } +} + +body.rtls.mini-navbar .footer.fixed, body.body-small.mini-navbar .footer.fixed { + margin: 0 70px 0 0; +} + +body.rtls.mini-navbar.fixed-sidebar .footer.fixed, body.body-small.mini-navbar .footer.fixed { + margin: 0 0 0 0; +} + + +body.rtls.top-navigation .navbar-toggle { + float: right; + margin-left: 15px; + margin-right: 15px; +} + +.body-small.rtls.top-navigation .navbar-header { + float: none; +} + +body.rtls.top-navigation #page-wrapper { + margin: 0; +} + +body.rtls.mini-navbar #page-wrapper { + margin: 0 70px 0 0; +} + +body.rtls.mini-navbar.fixed-sidebar #page-wrapper { + margin: 0 0 0 0; +} + +body.rtls.body-small.fixed-sidebar.mini-navbar #page-wrapper { + margin: 0 @sidebar-width 0 0; +} + +body.rtls.body-small.fixed-sidebar.mini-navbar .navbar-static-side { + width: @sidebar-width; +} + +.body-small.rtls .navbar-fixed-top { + margin-right: 0px; +} + +.body-small.rtls .navbar-header { + float: right; +} + +body.rtls .navbar-top-links li:last-child { + margin-left: 20px; +} + +body.rtls .top-navigation #page-wrapper, body.rtls.mini-navbar .top-navigation #page-wrapper, body.rtls.mini-navbar.top-navigation #page-wrapper { + margin: 0; +} + +body.rtls .top-navigation .footer.fixed, body.rtls.top-navigation .footer.fixed { + margin: 0; +} + +@media (max-width: 768px) { + + body.rtls .navbar-top-links li:last-child { + margin-left: 20px; + } + + .body-small.rtls #page-wrapper { + position: inherit; + margin: 0 0 0 0px; + min-height: 1000px; + } + + .body-small.rtls .navbar-static-side { + display: none; + z-index: 2001; + position: absolute; + width: 70px; + } + + .body-small.rtls.mini-navbar .navbar-static-side { + display: block; + } + + .rtls.fixed-sidebar.body-small .navbar-static-side { + display: none; + z-index: 2001; + position: fixed; + width: @sidebar-width; + } + + .rtls.fixed-sidebar.body-small.mini-navbar .navbar-static-side { + display: block; + } + +} + +// For special ltr supporting plugin +.rtls .ltr-support { + direction: ltr; +} diff --git a/src/app/less/sidebar.less b/src/app/less/sidebar.less new file mode 100755 index 0000000..a799da8 --- /dev/null +++ b/src/app/less/sidebar.less @@ -0,0 +1,195 @@ +.sidebard-panel { + width: 220px; + background: darken(@gray, 3%); + padding: 10px 20px; + position: absolute; + right: 0; +} + +.sidebard-panel .feed-element img.img-circle { + width: 32px; + height: 32px; +} + +.sidebard-panel .feed-element, .media-body, .sidebard-panel p { + font-size: 12px; +} + +.sidebard-panel .feed-element { + margin-top: 20px; + padding-bottom: 0; +} +.sidebard-panel .list-group { + margin-bottom: 10px; +} +.sidebard-panel .list-group .list-group-item { + padding: 5px 0; + font-size: 12px; + border: 0; +} + +.sidebar-content .wrapper, .wrapper.sidebar-content { + padding-right: 230px !important; +} + +.body-small .sidebar-content .wrapper, .body-small .wrapper.sidebar-content { + padding-right: 20px !important; +} + +// Right sidebar + +#right-sidebar { + background-color: #fff; + border-left: 1px solid #e7eaec; + border-top: 1px solid #e7eaec; + overflow: hidden; + position: fixed; + top: 60px; + width: 260px !important; + z-index: 1009; + bottom: 0; + right: -260px; +} + + +#right-sidebar.sidebar-open { + right: 0; +} + +#right-sidebar.sidebar-open.sidebar-top { + top: 0; + border-top: none; +} + +.sidebar-container { + + ul.nav-tabs { + border: none; + } + + ul.nav-tabs.navs-4 li { + width: 25%; + } + ul.nav-tabs.navs-3 li { + width: 33.3333%; + } + ul.nav-tabs.navs-2 li { + width: 50%; + } + + ul.nav-tabs li { + border: none; + } + + ul.nav-tabs li a { + border: none; + padding: 12px 10px; + margin: 0; + border-radius: 0; + background: @nav-bg; + color: #fff; + text-align: center; + + border-right:1px solid lighten(@nav-bg, 2%) ; + } + + ul.nav-tabs li.active a { + border: none; + background: #f9f9f9; + color: @text-color; + font-weight: bold; + + } + + .nav-tabs > li.active > a:hover, + .nav-tabs > li.active > a:focus { + + border: none; + + } + + ul.sidebar-list { + margin: 0; + padding: 0; + } + + ul.sidebar-list li { + border-bottom: 1px solid @border-color; + padding: 15px 20px; + list-style: none; + + font-size: 12px; + } + + ul.sidebar-list li:nth-child(2n+2) { +// background: #f9f9f9; + } + + .sidebar-message:nth-child(2n+2) { + background: #f9f9f9; + } + + ul.sidebar-list li a { + text-decoration: none; + color: inherit; + } + + .sidebar-content { + padding: 15px 20px ; + font-size: 12px; + } + + .date-item { + + } + + .sidebar-title { + background: #f9f9f9; + padding: 20px; + border-bottom: 1px solid @border-color; + + + h3 { + margin-bottom: 3px; + padding-left: 2px; + } + } + + .tab-content { + + h4 { + margin-bottom: 5px; + } + + } + + .sidebar-message > a > .pull-left { + margin-right: 10px; + } + + .sidebar-message > a { + text-decoration: none; + color: inherit; + } + + .sidebar-message { + padding: 15px 20px; + } + + .sidebar-message:hover { +// background: #f9f9f9; + } + + .sidebar-message .message-avatar { + height: 38px; + width: 38px; + border-radius: 50%; + } + + .setings-item { + padding: 15px 20px; + border-bottom: 1px solid @border-color; + } + +} + diff --git a/src/app/less/skins.less b/src/app/less/skins.less new file mode 100755 index 0000000..8297d03 --- /dev/null +++ b/src/app/less/skins.less @@ -0,0 +1,465 @@ +/* + * + * SKIN 1 - INSPINIA - Responsive Admin Theme + * NAME - Blue light + * +*/ + +// Main colors +@skin-1-color: #0e9aef; +@skin-1-nav-bg: #3e495f; +@skin-1-a-color: #9ea6b9; +@skin-1-page-bg: #f4f6fa; + +// Custom style +.skin-1 .minimalize-styl-2 { + margin: 14px 5px 5px 30px; +} + +.skin-1 .navbar-top-links li:last-child { + margin-right: 30px; +} + +.skin-1.fixed-nav .minimalize-styl-2 { + margin: 14px 5px 5px 15px; +} + +.skin-1 .spin-icon { + background: @skin-1-color !important; +} + +.skin-1 .nav-header { + background: @skin-1-color; + background: url('patterns/header-profile-skin-1.png'); +} + +.skin-1.mini-navbar .nav-second-level { + background: @skin-1-nav-bg; +} + +.skin-1 .breadcrumb { + background: transparent; +} + +.skin-1 .page-heading { + border: none; +} + +.skin-1 .nav > li.active { + background: darken(@skin-1-nav-bg, 2%); +} + +.skin-1 .nav > li > a { + color: @skin-1-a-color; +} + +.skin-1 .nav > li.active > a { + color: #fff; +} + +.skin-1 .navbar-minimalize { + background: @skin-1-color; + border-color: @skin-1-color; +} + +body.skin-1 { + background: @skin-1-nav-bg; +} + +.skin-1 .navbar-static-top { + background: #ffffff; +} + +.skin-1 .dashboard-header { + background: transparent; + border-bottom: none !important; + border-top: none; + padding: 20px 30px 10px 30px; +} + +.fixed-nav.skin-1 .navbar-fixed-top { + background: #fff; +} + +.skin-1 .wrapper-content { + padding: 30px 15px; +} + +.skin-1 #page-wrapper { + background: @skin-1-page-bg; +} + +.skin-1 .ibox-title, .skin-1 .ibox-content { + border-width: 1px; +} + +.skin-1 .ibox-content:last-child { + border-style: solid solid solid solid; +} + +.skin-1 .nav > li.active { + border: none; +} + +.skin-1 .nav-header { + padding: 35px 25px 25px 25px; +} + +.skin-1 .nav-header a.dropdown-toggle { + color: #fff; + margin-top: 10px; +} + +.skin-1 .nav-header a.dropdown-toggle .text-muted { + color: #fff; + opacity: 0.8; +} + +.skin-1 .profile-element { + text-align: center; +} + +.skin-1 .img-circle { + border-radius: 5px; +} + +.skin-1 .navbar-default .nav > li > a:hover, .skin-1 .navbar-default .nav > li > a:focus { + background: darken(@skin-1-nav-bg, 2%); + color: #fff; +} + +.skin-1 .nav.nav-tabs > li.active > a { + color: #555; +} +.skin-1 .nav.nav-tabs > li.active { + background: transparent; +} + +/* + * + * SKIN 2 - INSPINIA - Responsive Admin Theme + * NAME - Inspinia Ultra + * +*/ + +// Main colors +@skin-2-color: #23c6c8; +@skin-2-nav-bg: #ededed; +@skin-2-nav-top-bg: #213a53; + +// Custom style + +body.skin-2 { + color: #565758 !important; +} + +.skin-2 .minimalize-styl-2 { + margin: 14px 5px 5px 25px; +} + +.skin-2 .navbar-top-links li:last-child { + margin-right: 25px; +} + +.skin-2 .spin-icon { + background: @skin-2-color !important; +} + +.skin-2 .nav-header { + background: @skin-2-color; + background: url('patterns/header-profile-skin-2.png'); +} + +.skin-2.mini-navbar .nav-second-level { + background: @skin-2-nav-bg; +} + +.skin-2 .breadcrumb { + background: transparent; +} + +.skin-2.fixed-nav .minimalize-styl-2 { + margin: 14px 5px 5px 15px; +} + +.skin-2 .page-heading { + border: none; + background: rgba(255, 255, 255, 0.7); +} + +.skin-2 .nav > li.active { + background: #e0e0e0; +} + +.skin-2 .logo-element { + padding: 17px 0; +} + +.skin-2 .nav > li > a, .skin-2 .welcome-message { + color: #edf6ff; +} + +.skin-2 #top-search::-moz-placeholder { + color: #edf6ff; + opacity: 0.5; +} + +.skin-2 #side-menu > li > a, .skin-2 .nav.nav-second-level > li > a { + color: #586b7d; +} + +.skin-2 .nav > li.active > a { + color: @skin-2-nav-top-bg; +} + +.skin-2.mini-navbar .nav-header { + background: @skin-2-nav-top-bg; +} + +.skin-2 .navbar-minimalize { + background: @skin-2-color; + border-color: @skin-2-color; +} + +.skin-2 .border-bottom { + border-bottom: none !important; +} + +.skin-2 #top-search { + color: #fff; +} + +body.skin-2 #wrapper { + background-color: @skin-2-nav-bg; +} + +.skin-2 .navbar-static-top { + background: @skin-2-nav-top-bg; +} + +.fixed-nav.skin-2 .navbar-fixed-top { + background: @skin-2-nav-top-bg; + border-bottom: none !important; +} + +.skin-2 .nav-header { + padding: 30px 25px 30px 25px; +} + +.skin-2 .dashboard-header { + background: rgba(255, 255, 255, 0.4); + border-bottom: none !important; + border-top: none; + padding: 20px 30px 20px 30px; +} + +.skin-2 .wrapper-content { + padding: 30px 15px; +} + +.skin-2 .dashoard-1 .wrapper-content { + padding: 0px 30px 25px 30px; +} + +.skin-2 .ibox-title { + background: rgba(255, 255, 255, 0.7); + border: none; + margin-bottom: 1px; +} + +.skin-2 .ibox-content { + background: rgba(255, 255, 255, 0.4); + border: none !important; +} + +.skin-2 #page-wrapper { + background: rgba(246, 246, 246, 1); + background: -webkit-radial-gradient(center, ellipse cover, rgba(246, 246, 246, 1) 20%, rgba(213, 213, 213, 1) 100%); + background: -o-radial-gradient(center, ellipse cover, rgba(246, 246, 246, 1) 20%, rgba(213, 213, 213, 1) 100%); + background: -ms-radial-gradient(center, ellipse cover, rgba(246, 246, 246, 1) 20%, rgba(213, 213, 213, 1) 100%); + background: radial-gradient(ellipse at center, rgba(246, 246, 246, 1) 20%, rgba(213, 213, 213, 1) 100%); + -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#f6f6f6, endColorstr=#d5d5d5)"; +} + +.skin-2 .ibox-title, .skin-2 .ibox-content { + border-width: 1px; +} + +.skin-2 .ibox-content:last-child { + border-style: solid solid solid solid; +} + +.skin-2 .nav > li.active { + border: none; +} + +.skin-2 .nav-header a.dropdown-toggle { + color: #edf6ff; + margin-top: 10px; +} + +.skin-2 .nav-header a.dropdown-toggle .text-muted { + color: #edf6ff; + opacity: 0.8; +} + +.skin-2 .img-circle { + border-radius: 10px; +} + +.skin-2 .nav.navbar-top-links > li > a:hover, .skin-2 .nav.navbar-top-links > li > a:focus { + background: darken(@skin-2-nav-top-bg, 5%); +} + +.skin-2 .navbar-default .nav > li > a:hover, .skin-2 .navbar-default .nav > li > a:focus { + background: #e0e0e0; + color: #213a53; +} + +.skin-2 .nav.nav-tabs > li.active > a { + color: #555; +} +.skin-2 .nav.nav-tabs > li.active { + background: transparent; +} + +/* + * + * SKIN 3 - INSPINIA - Responsive Admin Theme + * NAME - Yellow/purple + * +*/ + +// Main colors +@skin-3-color: #ecba52; +@skin-3-nav-bg: #3e2c42; +@skin-3-a-color: #948b96; +@skin-3-page-bg: #f4f6fa; + +// Custom style +.skin-3 .minimalize-styl-2 { + margin: 14px 5px 5px 30px; +} + +.skin-3 .navbar-top-links li:last-child { + margin-right: 30px; +} + +.skin-3.fixed-nav .minimalize-styl-2 { + margin: 14px 5px 5px 15px; +} + +.skin-3 .spin-icon { + background: @skin-3-color !important; +} + +body.boxed-layout.skin-3 #wrapper { + background: @skin-3-nav-bg; +} + +.skin-3 .nav-header { + background: @skin-3-color; + background: url('patterns/header-profile-skin-3.png'); +} + +.skin-3.mini-navbar .nav-second-level { + background: @skin-3-nav-bg; +} + +.skin-3 .breadcrumb { + background: transparent; +} + +.skin-3 .page-heading { + border: none; +} + +.skin-3 .nav > li.active { + background: darken(@skin-3-nav-bg, 2%); +} + +.fixed-nav.skin-3 .navbar-fixed-top { + background: #fff; +} + +.skin-3 .nav > li > a { + color: @skin-3-a-color; +} + +.skin-3 .nav > li.active > a { + color: #fff; +} + +.skin-3 .navbar-minimalize { + background: @skin-3-color; + border-color: @skin-3-color; +} + +body.skin-3 { + background: @skin-3-nav-bg; +} + +.skin-3 .navbar-static-top { + background: #ffffff; +} + +.skin-3 .dashboard-header { + background: transparent; + border-bottom: none !important; + border-top: none; + padding: 20px 30px 10px 30px; +} + +.skin-3 .wrapper-content { + padding: 30px 15px; +} + +.skin-3 #page-wrapper { + background: @skin-3-page-bg; +} + +.skin-3 .ibox-title, .skin-3 .ibox-content { + border-width: 1px; +} + +.skin-3 .ibox-content:last-child { + border-style: solid solid solid solid; +} + +.skin-3 .nav > li.active { + border: none; +} + +.skin-3 .nav-header { + padding: 35px 25px 25px 25px; +} + +.skin-3 .nav-header a.dropdown-toggle { + color: #fff; + margin-top: 10px; +} + +.skin-3 .nav-header a.dropdown-toggle .text-muted { + color: #fff; + opacity: 0.8; +} + +.skin-3 .profile-element { + text-align: center; +} + +.skin-3 .img-circle { + border-radius: 5px; +} + +.skin-3 .navbar-default .nav > li > a:hover, .skin-3 .navbar-default .nav > li > a:focus { + background: darken(@skin-3-nav-bg, 2%); + color: #fff; +} + +.skin-3 .nav.nav-tabs > li.active > a { + color: #555; +} +.skin-3 .nav.nav-tabs > li.active { + background: transparent; +} \ No newline at end of file diff --git a/src/app/less/spinners.less b/src/app/less/spinners.less new file mode 100755 index 0000000..e4f0a10 --- /dev/null +++ b/src/app/less/spinners.less @@ -0,0 +1,760 @@ +/* + * Usage: + * + *
+ * + */ + +.sk-spinner-rotating-plane.sk-spinner { + width: 30px; + height: 30px; + background-color: @spin-color; + margin: @spin-margin; + -webkit-animation: sk-rotatePlane 1.2s infinite ease-in-out; + animation: sk-rotatePlane 1.2s infinite ease-in-out; } + +@-webkit-keyframes sk-rotatePlane { + 0% { + -webkit-transform: perspective(120px) rotateX(0deg) rotateY(0deg); + transform: perspective(120px) rotateX(0deg) rotateY(0deg); } + + 50% { + -webkit-transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg); + transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg); } + + 100% { + -webkit-transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg); + transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg); } } + +@keyframes sk-rotatePlane { + 0% { + -webkit-transform: perspective(120px) rotateX(0deg) rotateY(0deg); + transform: perspective(120px) rotateX(0deg) rotateY(0deg); } + + 50% { + -webkit-transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg); + transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg); } + + 100% { + -webkit-transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg); + transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg); } } + +/* + * Usage: + * + *
+ *
+ *
+ *
+ * + */ +.sk-spinner-double-bounce.sk-spinner { + width: 40px; + height: 40px; + position: relative; + margin: @spin-margin; } +.sk-spinner-double-bounce .sk-double-bounce1, .sk-spinner-double-bounce .sk-double-bounce2 { + width: 100%; + height: 100%; + border-radius: 50%; + background-color: @spin-color; + opacity: 0.6; + position: absolute; + top: 0; + left: 0; + -webkit-animation: sk-doubleBounce 2s infinite ease-in-out; + animation: sk-doubleBounce 2s infinite ease-in-out; } +.sk-spinner-double-bounce .sk-double-bounce2 { + -webkit-animation-delay: -1s; + animation-delay: -1s; } + +@-webkit-keyframes sk-doubleBounce { + 0%, 100% { + -webkit-transform: scale(0); + transform: scale(0); } + + 50% { + -webkit-transform: scale(1); + transform: scale(1); } } + +@keyframes sk-doubleBounce { + 0%, 100% { + -webkit-transform: scale(0); + transform: scale(0); } + + 50% { + -webkit-transform: scale(1); + transform: scale(1); } } + +/* + * Usage: + * + *
+ *
+ *
+ *
+ *
+ *
+ *
+ * + */ +.sk-spinner-wave.sk-spinner { + margin: @spin-margin; + width: 50px; + height: 30px; + text-align: center; + font-size: 10px; } +.sk-spinner-wave div { + background-color: @spin-color; + height: 100%; + width: 6px; + display: inline-block; + -webkit-animation: sk-waveStretchDelay 1.2s infinite ease-in-out; + animation: sk-waveStretchDelay 1.2s infinite ease-in-out; } +.sk-spinner-wave .sk-rect2 { + -webkit-animation-delay: -1.1s; + animation-delay: -1.1s; } +.sk-spinner-wave .sk-rect3 { + -webkit-animation-delay: -1s; + animation-delay: -1s; } +.sk-spinner-wave .sk-rect4 { + -webkit-animation-delay: -0.9s; + animation-delay: -0.9s; } +.sk-spinner-wave .sk-rect5 { + -webkit-animation-delay: -0.8s; + animation-delay: -0.8s; } + +@-webkit-keyframes sk-waveStretchDelay { + 0%, 40%, 100% { + -webkit-transform: scaleY(0.4); + transform: scaleY(0.4); } + + 20% { + -webkit-transform: scaleY(1); + transform: scaleY(1); } } + +@keyframes sk-waveStretchDelay { + 0%, 40%, 100% { + -webkit-transform: scaleY(0.4); + transform: scaleY(0.4); } + + 20% { + -webkit-transform: scaleY(1); + transform: scaleY(1); } } + +/* + * Usage: + * + *
+ *
+ *
+ *
+ * + */ +.sk-spinner-wandering-cubes.sk-spinner { + margin: @spin-margin; + width: 32px; + height: 32px; + position: relative; } +.sk-spinner-wandering-cubes .sk-cube1, .sk-spinner-wandering-cubes .sk-cube2 { + background-color: @spin-color; + width: 10px; + height: 10px; + position: absolute; + top: 0; + left: 0; + -webkit-animation: sk-wanderingCubeMove 1.8s infinite ease-in-out; + animation: sk-wanderingCubeMove 1.8s infinite ease-in-out; } +.sk-spinner-wandering-cubes .sk-cube2 { + -webkit-animation-delay: -0.9s; + animation-delay: -0.9s; } + +@-webkit-keyframes sk-wanderingCubeMove { + 25% { + -webkit-transform: translateX(42px) rotate(-90deg) scale(0.5); + transform: translateX(42px) rotate(-90deg) scale(0.5); } + + 50% { + /* Hack to make FF rotate in the right direction */ + -webkit-transform: translateX(42px) translateY(42px) rotate(-179deg); + transform: translateX(42px) translateY(42px) rotate(-179deg); } + + 50.1% { + -webkit-transform: translateX(42px) translateY(42px) rotate(-180deg); + transform: translateX(42px) translateY(42px) rotate(-180deg); } + + 75% { + -webkit-transform: translateX(0px) translateY(42px) rotate(-270deg) scale(0.5); + transform: translateX(0px) translateY(42px) rotate(-270deg) scale(0.5); } + + 100% { + -webkit-transform: rotate(-360deg); + transform: rotate(-360deg); } } + +@keyframes sk-wanderingCubeMove { + 25% { + -webkit-transform: translateX(42px) rotate(-90deg) scale(0.5); + transform: translateX(42px) rotate(-90deg) scale(0.5); } + + 50% { + /* Hack to make FF rotate in the right direction */ + -webkit-transform: translateX(42px) translateY(42px) rotate(-179deg); + transform: translateX(42px) translateY(42px) rotate(-179deg); } + + 50.1% { + -webkit-transform: translateX(42px) translateY(42px) rotate(-180deg); + transform: translateX(42px) translateY(42px) rotate(-180deg); } + + 75% { + -webkit-transform: translateX(0px) translateY(42px) rotate(-270deg) scale(0.5); + transform: translateX(0px) translateY(42px) rotate(-270deg) scale(0.5); } + + 100% { + -webkit-transform: rotate(-360deg); + transform: rotate(-360deg); } } + +/* + * Usage: + * + *
+ * + */ +.sk-spinner-pulse.sk-spinner { + width: 40px; + height: 40px; + margin: @spin-margin; + background-color: @spin-color; + border-radius: 100%; + -webkit-animation: sk-pulseScaleOut 1s infinite ease-in-out; + animation: sk-pulseScaleOut 1s infinite ease-in-out; } + +@-webkit-keyframes sk-pulseScaleOut { + 0% { + -webkit-transform: scale(0); + transform: scale(0); } + + 100% { + -webkit-transform: scale(1); + transform: scale(1); + opacity: 0; } } + +@keyframes sk-pulseScaleOut { + 0% { + -webkit-transform: scale(0); + transform: scale(0); } + + 100% { + -webkit-transform: scale(1); + transform: scale(1); + opacity: 0; } } + +/* + * Usage: + * + *
+ *
+ *
+ *
+ * + */ +.sk-spinner-chasing-dots.sk-spinner { + margin: @spin-margin; + width: 40px; + height: 40px; + position: relative; + text-align: center; + -webkit-animation: sk-chasingDotsRotate 2s infinite linear; + animation: sk-chasingDotsRotate 2s infinite linear; } +.sk-spinner-chasing-dots .sk-dot1, .sk-spinner-chasing-dots .sk-dot2 { + width: 60%; + height: 60%; + display: inline-block; + position: absolute; + top: 0; + background-color: @spin-color; + border-radius: 100%; + -webkit-animation: sk-chasingDotsBounce 2s infinite ease-in-out; + animation: sk-chasingDotsBounce 2s infinite ease-in-out; } +.sk-spinner-chasing-dots .sk-dot2 { + top: auto; + bottom: 0px; + -webkit-animation-delay: -1s; + animation-delay: -1s; } + +@-webkit-keyframes sk-chasingDotsRotate { + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); } } + +@keyframes sk-chasingDotsRotate { + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); } } + +@-webkit-keyframes sk-chasingDotsBounce { + 0%, 100% { + -webkit-transform: scale(0); + transform: scale(0); } + + 50% { + -webkit-transform: scale(1); + transform: scale(1); } } + +@keyframes sk-chasingDotsBounce { + 0%, 100% { + -webkit-transform: scale(0); + transform: scale(0); } + + 50% { + -webkit-transform: scale(1); + transform: scale(1); } } + +/* + * Usage: + * + *
+ *
+ *
+ *
+ *
+ * + */ +.sk-spinner-three-bounce.sk-spinner { + margin: @spin-margin; + width: 70px; + text-align: center; } +.sk-spinner-three-bounce div { + width: 18px; + height: 18px; + background-color: @spin-color; + border-radius: 100%; + display: inline-block; + -webkit-animation: sk-threeBounceDelay 1.4s infinite ease-in-out; + animation: sk-threeBounceDelay 1.4s infinite ease-in-out; + /* Prevent first frame from flickering when animation starts */ + -webkit-animation-fill-mode: both; + animation-fill-mode: both; } +.sk-spinner-three-bounce .sk-bounce1 { + -webkit-animation-delay: -0.32s; + animation-delay: -0.32s; } +.sk-spinner-three-bounce .sk-bounce2 { + -webkit-animation-delay: -0.16s; + animation-delay: -0.16s; } + +@-webkit-keyframes sk-threeBounceDelay { + 0%, 80%, 100% { + -webkit-transform: scale(0); + transform: scale(0); } + + 40% { + -webkit-transform: scale(1); + transform: scale(1); } } + +@keyframes sk-threeBounceDelay { + 0%, 80%, 100% { + -webkit-transform: scale(0); + transform: scale(0); } + + 40% { + -webkit-transform: scale(1); + transform: scale(1); } } + +/* + * Usage: + * + *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ * + */ +.sk-spinner-circle.sk-spinner { + margin: @spin-margin; + width: 22px; + height: 22px; + position: relative; } +.sk-spinner-circle .sk-circle { + width: 100%; + height: 100%; + position: absolute; + left: 0; + top: 0; } +.sk-spinner-circle .sk-circle:before { + content: ''; + display: block; + margin: @spin-margin; + width: 20%; + height: 20%; + background-color: @spin-color; + border-radius: 100%; + -webkit-animation: sk-circleBounceDelay 1.2s infinite ease-in-out; + animation: sk-circleBounceDelay 1.2s infinite ease-in-out; + /* Prevent first frame from flickering when animation starts */ + -webkit-animation-fill-mode: both; + animation-fill-mode: both; } +.sk-spinner-circle .sk-circle2 { + -webkit-transform: rotate(30deg); + -ms-transform: rotate(30deg); + transform: rotate(30deg); } +.sk-spinner-circle .sk-circle3 { + -webkit-transform: rotate(60deg); + -ms-transform: rotate(60deg); + transform: rotate(60deg); } +.sk-spinner-circle .sk-circle4 { + -webkit-transform: rotate(90deg); + -ms-transform: rotate(90deg); + transform: rotate(90deg); } +.sk-spinner-circle .sk-circle5 { + -webkit-transform: rotate(120deg); + -ms-transform: rotate(120deg); + transform: rotate(120deg); } +.sk-spinner-circle .sk-circle6 { + -webkit-transform: rotate(150deg); + -ms-transform: rotate(150deg); + transform: rotate(150deg); } +.sk-spinner-circle .sk-circle7 { + -webkit-transform: rotate(180deg); + -ms-transform: rotate(180deg); + transform: rotate(180deg); } +.sk-spinner-circle .sk-circle8 { + -webkit-transform: rotate(210deg); + -ms-transform: rotate(210deg); + transform: rotate(210deg); } +.sk-spinner-circle .sk-circle9 { + -webkit-transform: rotate(240deg); + -ms-transform: rotate(240deg); + transform: rotate(240deg); } +.sk-spinner-circle .sk-circle10 { + -webkit-transform: rotate(270deg); + -ms-transform: rotate(270deg); + transform: rotate(270deg); } +.sk-spinner-circle .sk-circle11 { + -webkit-transform: rotate(300deg); + -ms-transform: rotate(300deg); + transform: rotate(300deg); } +.sk-spinner-circle .sk-circle12 { + -webkit-transform: rotate(330deg); + -ms-transform: rotate(330deg); + transform: rotate(330deg); } +.sk-spinner-circle .sk-circle2:before { + -webkit-animation-delay: -1.1s; + animation-delay: -1.1s; } +.sk-spinner-circle .sk-circle3:before { + -webkit-animation-delay: -1s; + animation-delay: -1s; } +.sk-spinner-circle .sk-circle4:before { + -webkit-animation-delay: -0.9s; + animation-delay: -0.9s; } +.sk-spinner-circle .sk-circle5:before { + -webkit-animation-delay: -0.8s; + animation-delay: -0.8s; } +.sk-spinner-circle .sk-circle6:before { + -webkit-animation-delay: -0.7s; + animation-delay: -0.7s; } +.sk-spinner-circle .sk-circle7:before { + -webkit-animation-delay: -0.6s; + animation-delay: -0.6s; } +.sk-spinner-circle .sk-circle8:before { + -webkit-animation-delay: -0.5s; + animation-delay: -0.5s; } +.sk-spinner-circle .sk-circle9:before { + -webkit-animation-delay: -0.4s; + animation-delay: -0.4s; } +.sk-spinner-circle .sk-circle10:before { + -webkit-animation-delay: -0.3s; + animation-delay: -0.3s; } +.sk-spinner-circle .sk-circle11:before { + -webkit-animation-delay: -0.2s; + animation-delay: -0.2s; } +.sk-spinner-circle .sk-circle12:before { + -webkit-animation-delay: -0.1s; + animation-delay: -0.1s; } + +@-webkit-keyframes sk-circleBounceDelay { + 0%, 80%, 100% { + -webkit-transform: scale(0); + transform: scale(0); } + + 40% { + -webkit-transform: scale(1); + transform: scale(1); } } + +@keyframes sk-circleBounceDelay { + 0%, 80%, 100% { + -webkit-transform: scale(0); + transform: scale(0); } + + 40% { + -webkit-transform: scale(1); + transform: scale(1); } } + +/* + * Usage: + * + *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ * + */ +.sk-spinner-cube-grid { + /* + * Spinner positions + * 1 2 3 + * 4 5 6 + * 7 8 9 + */ } +.sk-spinner-cube-grid.sk-spinner { + width: 30px; + height: 30px; + margin: @spin-margin; } +.sk-spinner-cube-grid .sk-cube { + width: 33%; + height: 33%; + background-color: @spin-color; + float: left; + -webkit-animation: sk-cubeGridScaleDelay 1.3s infinite ease-in-out; + animation: sk-cubeGridScaleDelay 1.3s infinite ease-in-out; } +.sk-spinner-cube-grid .sk-cube:nth-child(1) { + -webkit-animation-delay: 0.2s; + animation-delay: 0.2s; } +.sk-spinner-cube-grid .sk-cube:nth-child(2) { + -webkit-animation-delay: 0.3s; + animation-delay: 0.3s; } +.sk-spinner-cube-grid .sk-cube:nth-child(3) { + -webkit-animation-delay: 0.4s; + animation-delay: 0.4s; } +.sk-spinner-cube-grid .sk-cube:nth-child(4) { + -webkit-animation-delay: 0.1s; + animation-delay: 0.1s; } +.sk-spinner-cube-grid .sk-cube:nth-child(5) { + -webkit-animation-delay: 0.2s; + animation-delay: 0.2s; } +.sk-spinner-cube-grid .sk-cube:nth-child(6) { + -webkit-animation-delay: 0.3s; + animation-delay: 0.3s; } +.sk-spinner-cube-grid .sk-cube:nth-child(7) { + -webkit-animation-delay: 0s; + animation-delay: 0s; } +.sk-spinner-cube-grid .sk-cube:nth-child(8) { + -webkit-animation-delay: 0.1s; + animation-delay: 0.1s; } +.sk-spinner-cube-grid .sk-cube:nth-child(9) { + -webkit-animation-delay: 0.2s; + animation-delay: 0.2s; } + +@-webkit-keyframes sk-cubeGridScaleDelay { + 0%, 70%, 100% { + -webkit-transform: scale3D(1, 1, 1); + transform: scale3D(1, 1, 1); } + + 35% { + -webkit-transform: scale3D(0, 0, 1); + transform: scale3D(0, 0, 1); } } + +@keyframes sk-cubeGridScaleDelay { + 0%, 70%, 100% { + -webkit-transform: scale3D(1, 1, 1); + transform: scale3D(1, 1, 1); } + + 35% { + -webkit-transform: scale3D(0, 0, 1); + transform: scale3D(0, 0, 1); } } + +/* + * Usage: + * + *
+ * + *
+ * + */ +.sk-spinner-wordpress.sk-spinner { + background-color: @spin-color; + width: 30px; + height: 30px; + border-radius: 30px; + position: relative; + margin: @spin-margin; + -webkit-animation: sk-innerCircle 1s linear infinite; + animation: sk-innerCircle 1s linear infinite; } +.sk-spinner-wordpress .sk-inner-circle { + display: block; + background-color: #fff; + width: 8px; + height: 8px; + position: absolute; + border-radius: 8px; + top: 5px; + left: 5px; } + +@-webkit-keyframes sk-innerCircle { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); } + + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); } } + +@keyframes sk-innerCircle { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); } + + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); } } + +/* + * Usage: + * + *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ * + */ +.sk-spinner-fading-circle.sk-spinner { + margin: @spin-margin; + width: 22px; + height: 22px; + position: relative; } +.sk-spinner-fading-circle .sk-circle { + width: 100%; + height: 100%; + position: absolute; + left: 0; + top: 0; } +.sk-spinner-fading-circle .sk-circle:before { + content: ''; + display: block; + margin: @spin-margin; + width: 18%; + height: 18%; + background-color: @spin-color; + border-radius: 100%; + -webkit-animation: sk-circleFadeDelay 1.2s infinite ease-in-out; + animation: sk-circleFadeDelay 1.2s infinite ease-in-out; + /* Prevent first frame from flickering when animation starts */ + -webkit-animation-fill-mode: both; + animation-fill-mode: both; } +.sk-spinner-fading-circle .sk-circle2 { + -webkit-transform: rotate(30deg); + -ms-transform: rotate(30deg); + transform: rotate(30deg); } +.sk-spinner-fading-circle .sk-circle3 { + -webkit-transform: rotate(60deg); + -ms-transform: rotate(60deg); + transform: rotate(60deg); } +.sk-spinner-fading-circle .sk-circle4 { + -webkit-transform: rotate(90deg); + -ms-transform: rotate(90deg); + transform: rotate(90deg); } +.sk-spinner-fading-circle .sk-circle5 { + -webkit-transform: rotate(120deg); + -ms-transform: rotate(120deg); + transform: rotate(120deg); } +.sk-spinner-fading-circle .sk-circle6 { + -webkit-transform: rotate(150deg); + -ms-transform: rotate(150deg); + transform: rotate(150deg); } +.sk-spinner-fading-circle .sk-circle7 { + -webkit-transform: rotate(180deg); + -ms-transform: rotate(180deg); + transform: rotate(180deg); } +.sk-spinner-fading-circle .sk-circle8 { + -webkit-transform: rotate(210deg); + -ms-transform: rotate(210deg); + transform: rotate(210deg); } +.sk-spinner-fading-circle .sk-circle9 { + -webkit-transform: rotate(240deg); + -ms-transform: rotate(240deg); + transform: rotate(240deg); } +.sk-spinner-fading-circle .sk-circle10 { + -webkit-transform: rotate(270deg); + -ms-transform: rotate(270deg); + transform: rotate(270deg); } +.sk-spinner-fading-circle .sk-circle11 { + -webkit-transform: rotate(300deg); + -ms-transform: rotate(300deg); + transform: rotate(300deg); } +.sk-spinner-fading-circle .sk-circle12 { + -webkit-transform: rotate(330deg); + -ms-transform: rotate(330deg); + transform: rotate(330deg); } +.sk-spinner-fading-circle .sk-circle2:before { + -webkit-animation-delay: -1.1s; + animation-delay: -1.1s; } +.sk-spinner-fading-circle .sk-circle3:before { + -webkit-animation-delay: -1s; + animation-delay: -1s; } +.sk-spinner-fading-circle .sk-circle4:before { + -webkit-animation-delay: -0.9s; + animation-delay: -0.9s; } +.sk-spinner-fading-circle .sk-circle5:before { + -webkit-animation-delay: -0.8s; + animation-delay: -0.8s; } +.sk-spinner-fading-circle .sk-circle6:before { + -webkit-animation-delay: -0.7s; + animation-delay: -0.7s; } +.sk-spinner-fading-circle .sk-circle7:before { + -webkit-animation-delay: -0.6s; + animation-delay: -0.6s; } +.sk-spinner-fading-circle .sk-circle8:before { + -webkit-animation-delay: -0.5s; + animation-delay: -0.5s; } +.sk-spinner-fading-circle .sk-circle9:before { + -webkit-animation-delay: -0.4s; + animation-delay: -0.4s; } +.sk-spinner-fading-circle .sk-circle10:before { + -webkit-animation-delay: -0.3s; + animation-delay: -0.3s; } +.sk-spinner-fading-circle .sk-circle11:before { + -webkit-animation-delay: -0.2s; + animation-delay: -0.2s; } +.sk-spinner-fading-circle .sk-circle12:before { + -webkit-animation-delay: -0.1s; + animation-delay: -0.1s; } + +@-webkit-keyframes sk-circleFadeDelay { + 0%, 39%, 100% { + opacity: 0; } + + 40% { + opacity: 1; } } + +@keyframes sk-circleFadeDelay { + 0%, 39%, 100% { + opacity: 0; } + + 40% { + opacity: 1; } } + diff --git a/src/app/less/style.less b/src/app/less/style.less new file mode 100755 index 0000000..22b42b1 --- /dev/null +++ b/src/app/less/style.less @@ -0,0 +1,60 @@ +/* + * + * INSPINIA - Responsive Admin Theme + * version 2.3 + * +*/ + +// Google Fonts +@import url("https://fonts.googleapis.com/css?family=Open+Sans:300,400,600,700&lang=en"); + +// Variables, Mixins +@import "variables.less"; +@import "mixins.less"; + +// INSPINIA Theme Elements +@import "typography.less"; +@import "navigation.less"; +@import "top_navigation.less"; +@import "buttons.less"; +@import "badgets_labels.less"; +@import "elements.less"; +@import "sidebar.less"; +@import "base.less"; +@import "pages.less"; +@import "chat.less"; +@import "metismenu.less"; +@import "spinners.less"; + +// Landing page styles +@import "landing.less"; + +// RTL Support +@import "rtl.less"; + +// For demo only - config box style +@import "theme-config.less"; + +// INSPINIA Skins +@import "skins.less"; +@import "md-skin.less"; + +// Media query style +@import "media.less"; + +// Custom style +// Your custom style to override base style +@import "custom.less"; + + + + + + + + + + + + + diff --git a/src/app/less/theme-config.less b/src/app/less/theme-config.less new file mode 100755 index 0000000..86905e1 --- /dev/null +++ b/src/app/less/theme-config.less @@ -0,0 +1,113 @@ +/* + * + * This is style for skin config + * Use only in demo theme + * +*/ + +.theme-config { + position: absolute; + top: 90px; + right: 0px; + overflow: hidden; +} + +.theme-config-box { + margin-right: -220px; + position: relative; + z-index: 2000; + transition-duration: 0.8s; +} + +.theme-config-box.show { + margin-right: 0px; +} + +.spin-icon { + background: @navy; + position: absolute; + padding: 7px 10px 7px 13px; + border-radius: 20px 0px 0px 20px; + font-size: 16px; + top: 0; + left: 0px; + width: 40px; + color: #fff; + cursor: pointer; +} + +.skin-setttings { + width: 220px; + margin-left: 40px; + background: @gray; +} + +.skin-setttings .title { + background: #efefef; + text-align: center; + text-transform: uppercase; + font-weight: 600; + display: block; + padding: 10px 15px; + font-size: 12px; +} + +.setings-item { + padding: 10px 30px; +} + +.setings-item.skin { + text-align: center; +} + +.setings-item .switch { + float: right; +} + +.skin-name a { + text-transform: uppercase; +} + +.setings-item a { + color: #fff; +} + +.default-skin, .blue-skin, .ultra-skin, .yellow-skin { + text-align: center; +} + +.default-skin { + font-weight: 600; + background: #1ab394; +} + +.default-skin:hover { + background: #199d82; +} + +.blue-skin { + font-weight: 600; + background: url("patterns/header-profile-skin-1.png") repeat scroll 0 0; +} + +.blue-skin:hover { + background: #0d8ddb; +} + +.yellow-skin { + font-weight: 600; + background: url("patterns/header-profile-skin-3.png") repeat scroll 0 100%; +} + +.yellow-skin:hover { + background: #ce8735; +} + +.ultra-skin { + font-weight: 600; + background: url("patterns/header-profile-skin-2.png") repeat scroll 0 0; +} + +.ultra-skin:hover { + background: #1a2d40; +} \ No newline at end of file diff --git a/src/app/less/top_navigation.less b/src/app/less/top_navigation.less new file mode 100755 index 0000000..bf6f886 --- /dev/null +++ b/src/app/less/top_navigation.less @@ -0,0 +1,127 @@ +.top-navigation #page-wrapper { + margin-left: 0; +} + +.top-navigation .navbar-nav .dropdown-menu > .active > a { + background: white; + color: @navy; + font-weight: bold; +} + +.white-bg .navbar-fixed-top, .white-bg .navbar-static-top { + background: #fff; +} + +.top-navigation .navbar { + margin-bottom: 0; +} + +.top-navigation .nav > li > a { + padding: 15px 20px; + color: #676a6c; +} + +.top-navigation .nav > li a:hover, .top-navigation .nav > li a:focus { + background: #fff; + color: @navy; +} + +.top-navigation .nav > li.active { + background: #fff; + border: none; +} +.top-navigation .nav > li.active > a { + color: @navy; +} +.top-navigation .navbar-right { + margin-right: 10px; +} + +.top-navigation .navbar-nav .dropdown-menu { + box-shadow: none; + border: 1px solid #e7eaec; +} + +.top-navigation .dropdown-menu > li > a { + margin: 0; + padding: 7px 20px; +} + +.navbar .dropdown-menu { + margin-top: 0px; +} + +.top-navigation .navbar-brand { + background: @navy; + color: #fff; + padding: 15px 25px; +} + +.top-navigation .navbar-top-links li:last-child { + margin-right: 0; +} + +.top-navigation.mini-navbar #page-wrapper, +.top-navigation.body-small.fixed-sidebar.mini-navbar #page-wrapper, +.mini-navbar .top-navigation #page-wrapper, +.body-small.fixed-sidebar.mini-navbar .top-navigation #page-wrapper, +.canvas-menu #page-wrapper { + margin: 0; +} + +.top-navigation.fixed-nav #wrapper, .fixed-nav #wrapper.top-navigation { + margin-top: 50px; +} + +.top-navigation .footer.fixed { + margin-left: 0 !important; +} + +.top-navigation .wrapper.wrapper-content { + padding: 40px; +} +.top-navigation.body-small .wrapper.wrapper-content, .body-small .top-navigation .wrapper.wrapper-content { + padding: 40px 0px 40px 0px; +} + +.navbar-toggle { + background-color: @navy; + color: #fff; + padding: 6px 12px; + font-size: 14px; +} + +.top-navigation .navbar-nav .open .dropdown-menu > li > a, .top-navigation .navbar-nav .open .dropdown-menu .dropdown-header { + padding: 10px 15px 10px 20px; +} + +@media (max-width: 768px) { + .top-navigation .navbar-header { + display: block; + float: none; + } +} + +.menu-visible-lg, .menu-visible-md { + display: none !important; +} + +@media (min-width: 1200px) { + .menu-visible-lg { + display: block !important; + } +} +@media (min-width: 992px) { + .menu-visible-md { + display: block !important; + } +} + +@media (max-width: 767px) { + .menu-visible-md { + display: block !important; + } + .menu-visible-lg { + display: block !important; + } +} \ No newline at end of file diff --git a/src/app/less/typography.less b/src/app/less/typography.less new file mode 100755 index 0000000..6110d06 --- /dev/null +++ b/src/app/less/typography.less @@ -0,0 +1,32 @@ +h1, h2, h3, h4, h5, h6 { + font-weight: 100; +} + +h1 { + font-size: 30px; +} + +h2 { + font-size: 24px; +} + +h3 { + font-size: 16px; +} + +h4 { + font-size: 14px; +} + +h5 { + font-size: 12px; +} + +h6 { + font-size: 10px; +} + +h3, h4, h5 { + margin-top: 5px; + font-weight: 600; +} \ No newline at end of file diff --git a/src/app/less/variables.less b/src/app/less/variables.less new file mode 100755 index 0000000..8ac0d0e --- /dev/null +++ b/src/app/less/variables.less @@ -0,0 +1,39 @@ +// Basic Colors +@navy: #1ab394; // Primary color +@dark-gray: #c2c2c2; // Default color +@blue: #1c84c6; // Success color +@lazur: #23c6c8; // Info color +@yellow: #f8ac59; // Warrning color +@red: #ED5565; // Danger color + +// Various colors +@text-color: #676a6c; // Body text +@gray: #f3f3f4; // Background wrapper color +@light-gray: #D1DADE; // Default label, badget +@label-badget-color: #5E5E5E; +@light-blue:#f3f6fb; + +// Spiner color and margin +@spin-color: @navy; +@spin-margin: 0 auto; + + +// IBOX colors ( default panel colors) +@border-color: #e7eaec; // IBox border +@ibox-title-bg:#ffffff; // IBox Background header +@ibox-content-bg:#ffffff; // IBox Background content + +//Sidebar width +@sidebar-width: 220px; + +// Boxed layout width +@boxed-width: 1200px; +@boxed-backgound: url('patterns/shattered.png'); + +//Border radius for buttons +@btn-border-radius: 3px; + +//Navigation +@nav-bg: #2F4050; +@nav-profil-pattern: url("patterns/header-profile.png") no-repeat; +@nav-text-color: #a7b1c2; \ No newline at end of file diff --git a/src/app/login/login.controller.js b/src/app/login/login.controller.js new file mode 100644 index 0000000..49ef027 --- /dev/null +++ b/src/app/login/login.controller.js @@ -0,0 +1,46 @@ +'use strict'; + +angular.module('supportAdminApp') + .controller('LoginController', [ + '$scope', '$rootScope', '$location', '$state', 'AuthService', 'TokenService', 'UserService', + function ($scope, $rootScope, $location, $state, $authService, $tokenService, $userService) { + + $scope.loggingIn = false; + + $scope.isLoggingIn = function() { + return $scope.loggingIn; + }; + + $scope.submit = function() { + + var loginSuccess = function() { + var token = $tokenService.decodeToken(); + console.log(token); + if($.inArray('administrator', token && token.roles) < 0) { + $scope.$broadcast('AlertIssued', {type:'danger', message:'Permission denied.'}); + $scope.loggingIn = false; + return; + } + $userService.findById(token.userId).then(function(currentUser) { + console.log('Login Success'); + $rootScope.currentUser = currentUser; + $state.go('index.main') + }); + }; + + var loginFailure = function() { + console.log('Login Failed') + $scope.loggingIn = false; + }; + + var options = { + username:$scope.username, + password:$scope.password, + success: loginSuccess, + error: loginFailure + }; + + $scope.loggingIn = true; + $authService.login(options); + }; + }]); diff --git a/src/app/login/login.html b/src/app/login/login.html new file mode 100755 index 0000000..9823170 --- /dev/null +++ b/src/app/login/login.html @@ -0,0 +1,14 @@ +
+
+
+

+
+
+
+ +
+
+
diff --git a/src/app/main/main.controller.js b/src/app/main/main.controller.js new file mode 100755 index 0000000..36d6843 --- /dev/null +++ b/src/app/main/main.controller.js @@ -0,0 +1,20 @@ +'use strict'; + +angular.module('supportAdminApp') + .controller('MainController', ['$scope', '$rootScope', '$timeout', '$state', 'AuthService', + function ($scope, $rootScope, $timeout, $state, $authService) { + + $scope.logout = function() { + $authService.logout(); + $state.go('login'); + }; + + $scope.login = function() { + $state.go('login'); + }; + + // auth + $scope.authorized = function() { + return $authService.isLoggedIn(); + } +}]); diff --git a/src/app/main/main.html b/src/app/main/main.html new file mode 100755 index 0000000..ff16238 --- /dev/null +++ b/src/app/main/main.html @@ -0,0 +1,26 @@ +
+
+

Dashboard

+ +
+
+
+
+ +
+
+
+
+
+
+
+
diff --git a/src/app/users/user-edit-dialog.html b/src/app/users/user-edit-dialog.html new file mode 100644 index 0000000..fbdb12f --- /dev/null +++ b/src/app/users/user-edit-dialog.html @@ -0,0 +1,34 @@ +
+ + + +
+ +
+
diff --git a/src/app/users/users.controller.js b/src/app/users/users.controller.js new file mode 100644 index 0000000..e845055 --- /dev/null +++ b/src/app/users/users.controller.js @@ -0,0 +1,165 @@ +'use strict'; + +var module = angular.module('supportAdminApp'); + +module.controller('users.UserSearchController', [ + '$scope', '$rootScope', '$timeout', '$state', '$modal', 'AuthService','UserService', + function ($scope, $rootScope, $timeout, $state, $modal, $authService, $userService) { + + // auth + $scope.authorized = function() { + return $authService.isLoggedIn(); + } + + // search + $scope.formSearch = { + handle : "", + email : "", + status : "", + isLoading: false, + getActive: function() { + return this.status === "active" ? true : + this.status === "inactive" ? false : + null; + }, + setLoading: function(loading) { + this.isLoading = loading; + } + }; + + $scope.search = function() { + + var handle = $scope.formSearch.handle, + email = $scope.formSearch.email, + active = $scope.formSearch.getActive(), + like = false; + + var filter = ''; + if(handle) { + like = handle.indexOf('*')>=0; + filter += "handle="+handle; + } + if(email) { + like = email.indexOf('*')>=0; + if(filter.length>0) + filter += '&'; + filter += "email="+email; + } + if(!(active === null) && !(active === undefined)) { + if(filter.length>0) + filter += '&'; + filter += "active="+active; + } + if(like) { + filter += "&like="+like; + } + + $scope.formSearch.setLoading(true); + $userService.find( + {filter : filter} + ).then( + function(users) { + $scope.users = users; + $scope.formSearch.setLoading(false); + }, + function(error) { + $scope.$broadcast('AlertIssued', {type:'danger', message:error.error}); + $scope.formSearch.setLoading(false); + } + ); + }; + + // list + $scope.users = []; + + $scope.format = function(isoDateText) { + return isoDateText && isoDateText.replace("T"," ").replace(".000Z",""); + }; + + $scope.activate = function(index) { + var user = $scope.users[index]; + if(!user.credential || !user.credential.activationCode) { + $scope.$broadcast('AlertIssued', + {type:'danger', message:'The user \'' + user.handle + '\' is invalid. Unable to activate it.'}); + return; + }; + if(window.confirm('Are you sure you want to activate user \'' + user.handle + '\'?')) { + $scope.formSearch.setLoading(true); + $userService.activate(user.credential.activationCode).then( + function(responseUser) { + user.active = responseUser.active; + $scope.formSearch.setLoading(false); + }, + function(error) { + $scope.$broadcast('AlertIssued', {type:'danger', message:error.error}); + $scope.formSearch.setLoading(false); + } + ); + } + }; + + $scope.deactivate = function(index) { + var user = $scope.users[index]; + + if(window.confirm('Are you sure you want to deactivate user \'' + user.handle + '\'?')) { + // dummy + user.active = false; + } + }; + + $scope.openDialog = function(index) { + var modalInstance = $modal.open({ + size: 'sm', + templateUrl: 'app/users/user-edit-dialog.html', + controller: 'users.UserEditDialogController', + resolve: { + user: function(){ return $scope.users[index]; } + } + }); + }; + } +]); + +module.controller('users.UserEditDialogController', [ + '$scope', '$rootScope', '$timeout', '$state', '$modalInstance', 'AuthService', 'UserService', 'user', + function ($scope, $rootScope, $timeout, $state, $modalInstance, $authService, $userService, user) { + + $scope.form = { + id : user.id, + handle : user.handle, + email : user.email, + active : user.active, + firstName : user.firstName, + lastName : user.lastName, + isLoading : false, + setLoading: function(loading) { + this.isLoading = loading; + } + }; + + $scope.cancel = function() { + $modalInstance.close(); + }; + + $scope.save = function() { + if(window.confirm('Are you sure you want to save changes?')) { + $scope.form.setLoading(true); + // dummy + setTimeout(function() { + $scope.form.setLoading(false); + user.handle = $scope.form.handle; + user.email = $scope.form.email; + user.firstName = $scope.form.firstName; + user.lastName = $scope.form.lastName; + $modalInstance.close(); + }, 1200); + } + } + + $scope.addAlert = function(index) { + //$scope.alerts.push({message: 'Another alert!'}); + $scope.$broadcast('AlertIssued', {type:'danger', message:'TEST!!!'}); + } + + } +]); diff --git a/src/app/users/users.html b/src/app/users/users.html new file mode 100644 index 0000000..9f75941 --- /dev/null +++ b/src/app/users/users.html @@ -0,0 +1,116 @@ + + + + + + + +
+
+

Members

+
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +
+
+ + +
+
+ + +
+
+

+ Tips:
+ - Wildcard(*) is available for partial matching. (e.g. ChrisB*, chris*@appirio.com)
+ - Maximum number of searched results is 500. +

+
+
+ +
+
+ +
+
+
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
User IDHandleEmailRegistred atActivation CodeActiveAction
{{user.id}}{{user.handle}}{{user.email}}{{format(user.createdAt)}}{{user.credential.activationCode}} + + + + EDIT + + + Activate + + + Deactivate + +
+
    +
    +
    +
    +
    +
    +
    diff --git a/src/app/users/users.service.js b/src/app/users/users.service.js new file mode 100644 index 0000000..6f5eb0d --- /dev/null +++ b/src/app/users/users.service.js @@ -0,0 +1,132 @@ +'use strict'; + +angular.module('supportAdminApp') + .factory('UserService', ['$q','$http', 'API_URL', + function ($q, $http, API_URL) { + // local dev + return ({ + + /** find user by ID */ + findById: function(userId) { + if(!userId) { + return $q.reject({error : 'userId must be specified.'}); + } + + var request = $http({ + method: 'GET', + url: API_URL + '/v3/users/' + userId, + headers: { + "Content-Type":"application/json" + } + }); + + return request.then( + function(response) { + console.log(response); + return response.data.result.content; + }, + function(error) { + console.log(error); + var err; + if(error && error.data && error.data.result) { + err = { + status: error.status, + error : error.data.result.content + }; + } + if(!err) { + err = { + status: error.status, + error : error.statusText + }; + } + return $q.reject(err); + } + ); + }, // findById() + + + /** find users */ + find: function(options) { + var opts = options || {}; + var query = ""; + angular.forEach({ + "fields": opts.fields || "id,handle,email,active,credential,firstName,lastName,createdAt,modifiedAt", + "filter": opts.filter + //"limit" : null, + //"offset": null, + //"orderBy": null, + }, function(value, key) { + query += ('&' + key + '=' + encodeURIComponent(value)); + }); + + var request = $http({ + method: 'GET', + url: API_URL + '/v3/users?' + query, + headers: { + "Content-Type":"application/json" + } + }); + + return request.then( + function(response) { + console.log(response); + return response.data.result.content; + }, + function(error) { + console.log(error); + var err; + if(error && error.data && error.data.result) { + err = { + status: error.status, + error : error.data.result.content + }; + } + if(!err) { + err = { + status: error.status, + error : error.statusText + }; + } + return $q.reject(err); + } + ); + }, // find() + + activate: function(activationCode) { + + var request = $http({ + method: 'PUT', + url: API_URL + '/v3/users/activate?code=' + activationCode, + headers: { + "Content-Type":"application/json" + }, + data: {} + }); + + return request.then( + function(response) { + console.log(response); + return response.data.result.content; + }, + function(error) { + console.log(error); + var err; + if(error && error.data && error.data.result) { + err = { + status: error.status, + error : error.data.result.content + }; + } + if(!err) { + err = { + status: error.status, + error : error.statusText + }; + } + return $q.reject(err); + } + ); + } // activate() + }); + }]); diff --git a/src/app/vendor.less b/src/app/vendor.less new file mode 100755 index 0000000..b2745f7 --- /dev/null +++ b/src/app/vendor.less @@ -0,0 +1,10 @@ +@import '../../bower_components/font-awesome/less/font-awesome.less'; +@import '../../bower_components/bootstrap/less/bootstrap.less'; + +// SERVE +@icon-font-path: '/bower_components/bootstrap/fonts/'; +@fa-font-path: '/bower_components/font-awesome/fonts'; + +// SERVE:DIST +//@icon-font-path: '/fonts/'; +//@fa-font-path: '/fonts'; \ No newline at end of file diff --git a/src/assets/images/appirio-logo.png b/src/assets/images/appirio-logo.png new file mode 100644 index 0000000..b55ac75 Binary files /dev/null and b/src/assets/images/appirio-logo.png differ diff --git a/src/assets/images/asp-logo.svg b/src/assets/images/asp-logo.svg new file mode 100644 index 0000000..1b1642b --- /dev/null +++ b/src/assets/images/asp-logo.svg @@ -0,0 +1,47 @@ + + + + ASP-logo-full + Created with Sketch. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/src/assets/images/loading.gif b/src/assets/images/loading.gif new file mode 100644 index 0000000..b9ac809 Binary files /dev/null and b/src/assets/images/loading.gif differ diff --git a/src/assets/images/patterns/1.png b/src/assets/images/patterns/1.png new file mode 100755 index 0000000..ace11c4 Binary files /dev/null and b/src/assets/images/patterns/1.png differ diff --git a/src/assets/images/patterns/2.png b/src/assets/images/patterns/2.png new file mode 100755 index 0000000..ecb1fbe Binary files /dev/null and b/src/assets/images/patterns/2.png differ diff --git a/src/assets/images/patterns/3.png b/src/assets/images/patterns/3.png new file mode 100755 index 0000000..3b8dcdc Binary files /dev/null and b/src/assets/images/patterns/3.png differ diff --git a/src/assets/images/patterns/4.png b/src/assets/images/patterns/4.png new file mode 100755 index 0000000..11fac9a Binary files /dev/null and b/src/assets/images/patterns/4.png differ diff --git a/src/assets/images/patterns/5.png b/src/assets/images/patterns/5.png new file mode 100755 index 0000000..a00521e Binary files /dev/null and b/src/assets/images/patterns/5.png differ diff --git a/src/assets/images/patterns/6.png b/src/assets/images/patterns/6.png new file mode 100755 index 0000000..8fd22a3 Binary files /dev/null and b/src/assets/images/patterns/6.png differ diff --git a/src/assets/images/patterns/7.png b/src/assets/images/patterns/7.png new file mode 100755 index 0000000..3e1f57f Binary files /dev/null and b/src/assets/images/patterns/7.png differ diff --git a/src/assets/images/patterns/congruent_pentagon.png b/src/assets/images/patterns/congruent_pentagon.png new file mode 100755 index 0000000..c712660 Binary files /dev/null and b/src/assets/images/patterns/congruent_pentagon.png differ diff --git a/src/assets/images/patterns/header-profile-skin-1.png b/src/assets/images/patterns/header-profile-skin-1.png new file mode 100755 index 0000000..41c5c08 Binary files /dev/null and b/src/assets/images/patterns/header-profile-skin-1.png differ diff --git a/src/assets/images/patterns/header-profile-skin-2.png b/src/assets/images/patterns/header-profile-skin-2.png new file mode 100755 index 0000000..df46d46 Binary files /dev/null and b/src/assets/images/patterns/header-profile-skin-2.png differ diff --git a/src/assets/images/patterns/header-profile-skin-3.png b/src/assets/images/patterns/header-profile-skin-3.png new file mode 100755 index 0000000..7a80132 Binary files /dev/null and b/src/assets/images/patterns/header-profile-skin-3.png differ diff --git a/src/assets/images/patterns/header-profile.png b/src/assets/images/patterns/header-profile.png new file mode 100755 index 0000000..7dea7f2 Binary files /dev/null and b/src/assets/images/patterns/header-profile.png differ diff --git a/src/assets/images/patterns/otis_redding.png b/src/assets/images/patterns/otis_redding.png new file mode 100755 index 0000000..7fa3533 Binary files /dev/null and b/src/assets/images/patterns/otis_redding.png differ diff --git a/src/assets/images/patterns/shattered.png b/src/assets/images/patterns/shattered.png new file mode 100755 index 0000000..90ed42b Binary files /dev/null and b/src/assets/images/patterns/shattered.png differ diff --git a/src/assets/images/patterns/triangular.png b/src/assets/images/patterns/triangular.png new file mode 100755 index 0000000..7f41795 Binary files /dev/null and b/src/assets/images/patterns/triangular.png differ diff --git a/src/components/alert/alert.controller.js b/src/components/alert/alert.controller.js new file mode 100644 index 0000000..57a0e55 --- /dev/null +++ b/src/components/alert/alert.controller.js @@ -0,0 +1,20 @@ +var module = angular.module('supportAdminApp'); + +module.controller('AlertController', ['$scope', '$rootScope', + function ($scope, $rootScope) { + + $scope.alerts = []; + + $scope.closeAlert = function(index) { + $scope.alerts.splice(index, 1); + } + + $scope.addAlert = function(alert) { + $scope.alerts.push(alert); + } + + $scope.$on('AlertIssued', function(event, alert){ + $scope.addAlert(alert); + }); + } + ]); diff --git a/src/components/alert/alert.html b/src/components/alert/alert.html new file mode 100644 index 0000000..5accbcc --- /dev/null +++ b/src/components/alert/alert.html @@ -0,0 +1,9 @@ +
    + +
    diff --git a/src/components/common/content.html b/src/components/common/content.html new file mode 100755 index 0000000..cf5f827 --- /dev/null +++ b/src/components/common/content.html @@ -0,0 +1,24 @@ + +
    + + +
    + + + +
    + + +
    + + +
    + + +
    + +
    + + +
    + diff --git a/src/components/common/footer.html b/src/components/common/footer.html new file mode 100755 index 0000000..7276167 --- /dev/null +++ b/src/components/common/footer.html @@ -0,0 +1,10 @@ + diff --git a/src/components/common/ibox_tools.html b/src/components/common/ibox_tools.html new file mode 100755 index 0000000..977cbff --- /dev/null +++ b/src/components/common/ibox_tools.html @@ -0,0 +1,13 @@ + \ No newline at end of file diff --git a/src/components/common/navigation.html b/src/components/common/navigation.html new file mode 100755 index 0000000..cdddb07 --- /dev/null +++ b/src/components/common/navigation.html @@ -0,0 +1,16 @@ + diff --git a/src/components/common/topnavbar.html b/src/components/common/topnavbar.html new file mode 100755 index 0000000..8504471 --- /dev/null +++ b/src/components/common/topnavbar.html @@ -0,0 +1,43 @@ +
    + +
    + + diff --git a/src/favicon-tc.ico b/src/favicon-tc.ico new file mode 100644 index 0000000..f71b2c6 Binary files /dev/null and b/src/favicon-tc.ico differ diff --git a/src/favicon.ico b/src/favicon.ico new file mode 100644 index 0000000..517b7d0 Binary files /dev/null and b/src/favicon.ico differ diff --git a/src/index.html b/src/index.html new file mode 100755 index 0000000..055f9c1 --- /dev/null +++ b/src/index.html @@ -0,0 +1,60 @@ + + + + + + Appirio Platform - Support App + + + + + + + + + + + + + + + + + + + + + + +
    + + + + + + + + + + + + + + + + + + + + + +