├── .config
└── karma.conf.js
├── .editorconfig
├── .github
└── ISSUE_TEMPLATE.md
├── .gitignore
├── .npmignore
├── .sassdocrc
├── CODEOWNERS.md
├── CONTRIBUTING.md
├── LICENSE.md
├── README.md
├── build
├── all.js
├── customization.md.hbs
├── data-uri.template
├── embed-assets.js
├── file-to-sass.js
├── sassdoc-theme.js
├── twbs-compat.js
└── twbs-compat.scss
├── docs
├── _meta.yml
├── customization.md
└── index.md
├── examples
└── react
│ ├── index.html
│ ├── package.json
│ ├── src
│ └── index.js
│ └── webpack.config.js
├── package.json
├── sass-lint.yml
├── scss
├── _mixins.scss
├── _variables.scss
├── action-buttons.scss
├── action-buttons
│ ├── _layout.scss
│ └── _theme.scss
├── all.scss
├── autocomplete.scss
├── autocomplete
│ ├── _layout.scss
│ └── _theme.scss
├── barcode.scss
├── barcode
│ └── _layout.scss
├── button.scss
├── button
│ ├── _layout.scss
│ └── _theme.scss
├── calendar.scss
├── calendar
│ ├── _layout.scss
│ └── _theme.scss
├── colorpicker.scss
├── colorpicker
│ ├── _layout.scss
│ └── _theme.scss
├── combobox.scss
├── combobox
│ ├── _layout.scss
│ └── _theme.scss
├── common
│ ├── _all.scss
│ ├── _animations.scss
│ ├── _base.scss
│ ├── _forms.scss
│ ├── _icons.scss
│ └── font
│ │ ├── WebComponentsIcons.scss
│ │ └── WebComponentsIcons.woff
├── dataviz.scss
├── dataviz
│ ├── _layout.scss
│ └── _theme.scss
├── datetime.scss
├── datetime
│ ├── _layout.scss
│ └── _theme.scss
├── dialog.scss
├── dialog
│ ├── _layout.scss
│ └── _theme.scss
├── dropdownlist.scss
├── dropdownlist
│ ├── _layout.scss
│ └── _theme.scss
├── edit-form.scss
├── edit-form
│ ├── _layout.scss
│ └── _theme.scss
├── editor.scss
├── editor
│ ├── _layout.scss
│ └── _theme.scss
├── gantt.scss
├── gantt
│ ├── _layout.scss
│ └── _theme.scss
├── grid.scss
├── grid
│ ├── _layout.scss
│ └── _theme.scss
├── input.scss
├── input
│ ├── _layout.scss
│ └── _theme.scss
├── listbox.scss
├── listbox
│ ├── _layout.scss
│ └── _theme.scss
├── listview.scss
├── listview
│ ├── _layout.scss
│ └── _theme.scss
├── map.scss
├── map
│ ├── _layout.scss
│ ├── _theme.scss
│ └── images
│ │ ├── markers.png
│ │ └── markers.scss
├── maskedtextbox.scss
├── maskedtextbox
│ ├── _layout.scss
│ └── _theme.scss
├── mediaplayer.scss
├── mediaplayer
│ ├── _layout.scss
│ └── _theme.scss
├── menu.scss
├── menu
│ ├── _layout.scss
│ └── _theme.scss
├── mixins
│ ├── _appearance.scss
│ ├── _blend-modes.scss
│ ├── _border-radius.scss
│ ├── _box-shadow.scss
│ ├── _button-size.scss
│ ├── _button.scss
│ ├── _colors.scss
│ ├── _decoration.scss
│ ├── _disabled.scss
│ ├── _gradients.scss
│ ├── _hide-scrollbar.scss
│ ├── _input.scss
│ ├── _node.scss
│ ├── _widget.scss
│ ├── core
│ │ ├── _data-uri.scss
│ │ ├── _import-once.scss
│ │ ├── _math.scss
│ │ └── _placeholder-selectors.scss
│ └── vendor
│ │ └── color-helpers
│ │ ├── _contrast.scss
│ │ └── _math.scss
├── multiselect.scss
├── multiselect
│ ├── _layout.scss
│ └── _theme.scss
├── no-flexbox.scss
├── notification.scss
├── notification
│ ├── _layout.scss
│ └── _theme.scss
├── numerictextbox.scss
├── numerictextbox
│ ├── _layout.scss
│ └── _theme.scss
├── pager.scss
├── pager
│ ├── _layout.scss
│ └── _theme.scss
├── panelbar.scss
├── panelbar
│ ├── _layout.scss
│ └── _theme.scss
├── pivotgrid.scss
├── pivotgrid
│ ├── _layout.scss
│ └── _theme.scss
├── popup.scss
├── popup
│ ├── _layout.scss
│ └── _theme.scss
├── progressbar.scss
├── progressbar
│ ├── _layout.scss
│ ├── _theme.scss
│ └── images
│ │ ├── indeterminate.gif
│ │ └── indeterminate.scss
├── qrcode.scss
├── qrcode
│ └── _layout.scss
├── responsivepanel.scss
├── responsivepanel
│ ├── _layout.scss
│ └── _theme.scss
├── ripple.scss
├── ripple
│ ├── _layout.scss
│ └── _theme.scss
├── scheduler.scss
├── scheduler
│ ├── _layout.scss
│ └── _theme.scss
├── scroller.scss
├── scroller
│ └── _layout.scss
├── scrollview.scss
├── scrollview
│ ├── _layout.scss
│ └── _theme.scss
├── slider.scss
├── slider
│ ├── _layout.scss
│ ├── _theme.scss
│ └── images
│ │ ├── slider-h.gif
│ │ ├── slider-h.scss
│ │ ├── slider-v.gif
│ │ └── slider-v.scss
├── splitter.scss
├── splitter
│ ├── _layout.scss
│ └── _theme.scss
├── spreadsheet.scss
├── spreadsheet
│ ├── _layout.scss
│ └── _theme.scss
├── switch.scss
├── switch
│ ├── _layout.scss
│ └── _theme.scss
├── tabstrip.scss
├── tabstrip
│ ├── _layout.scss
│ └── _theme.scss
├── toolbar.scss
├── toolbar
│ ├── _layout.scss
│ └── _theme.scss
├── tooltip.scss
├── tooltip
│ ├── _layout.scss
│ └── _theme.scss
├── treelist.scss
├── treelist
│ ├── _layout.scss
│ └── _theme.scss
├── treeview.scss
├── treeview
│ ├── _layout.scss
│ └── _theme.scss
├── upload.scss
├── upload
│ ├── _layout.scss
│ └── _theme.scss
├── validator.scss
├── validator
│ ├── _layout.scss
│ └── _theme.scss
├── window.scss
└── window
│ ├── _layout.scss
│ └── _theme.scss
├── tests
├── button-qunit.js
├── data
│ └── metrics.js
├── fixtures
│ ├── button.html
│ └── icons.html
└── lib
│ └── helpers.js
├── third-party.md
└── webpack.config.js
/.config/karma.conf.js:
--------------------------------------------------------------------------------
1 | module.exports = function(config) {
2 | config.set({
3 |
4 | // base path that will be used to resolve all patterns (eg. files, exclude)
5 | basePath: './../',
6 |
7 |
8 | // frameworks to use
9 | // available frameworks: https://npmjs.org/browse/keyword/karma-adapter
10 | frameworks: ["qunit"],
11 |
12 |
13 | // list of files / patterns to load in the browser
14 | files: [
15 | "node_modules/jquery/dist/jquery.js",
16 | "tests/lib/helpers.js",
17 | "dist/all.css",
18 | "tests/fixtures/**/*.html",
19 | "tests/data/metrics.js",
20 | "tests/**/*-qunit.js"
21 | ],
22 |
23 |
24 | // list of files to exclude
25 | exclude: [
26 | ],
27 |
28 |
29 | // preprocess matching files before serving them to the browser
30 | // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor
31 | preprocessors: {
32 | 'tests/fixtures/**/*.html': []
33 | // 'tests/**/.html': ["html2js"]
34 | },
35 |
36 |
37 | // test results reporter to use
38 | // possible values: 'dots', 'progress'
39 | // available reporters: https://npmjs.org/browse/keyword/karma-reporter
40 | reporters: ['progress'],
41 |
42 |
43 | // web server port
44 | port: 2107,
45 |
46 |
47 | // enable / disable colors in the output (reporters and logs)
48 | colors: true,
49 |
50 |
51 | // level of logging
52 | // possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
53 | logLevel: config.LOG_INFO,
54 |
55 |
56 | // enable / disable watching file and executing tests whenever any file changes
57 | autoWatch: true,
58 |
59 |
60 | // start these browsers
61 | // available browser launchers: https://npmjs.org/browse/keyword/karma-launcher
62 | browsers: ['Chrome'/*, 'PhantomJS'*/],
63 |
64 |
65 | // Continuous Integration mode
66 | // if true, Karma captures browsers, runs the tests and exits
67 | singleRun: false,
68 |
69 | // Concurrency level
70 | // how many browser should be started simultaneous
71 | concurrency: Infinity,
72 |
73 |
74 |
75 |
76 | // client configuration
77 | client: {
78 | clearContext: false,
79 | qunit: {
80 | showUI: false
81 | }
82 | }
83 | })
84 | }
85 |
--------------------------------------------------------------------------------
/.editorconfig:
--------------------------------------------------------------------------------
1 | # what's this?
2 | # - http://editorconfig.org
3 |
4 | root = true
5 |
6 | [*]
7 | end_of_line = lf
8 | insert_final_newline = true
9 | trim_trailing_whitespace = true
10 | max_line_length = off
11 |
12 | [*.scss]
13 | indent_style = space
14 | indent_size = 4
15 |
16 | [{package.json,.travis.yml}]
17 | indent_style = space
18 | indent_size = 2
19 |
--------------------------------------------------------------------------------
/.github/ISSUE_TEMPLATE.md:
--------------------------------------------------------------------------------
1 |
14 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | node_modules/
2 | dist/
3 | /dist.*
4 | npm-debug.log
5 | examples/**/build/
6 | .tmp/
7 | yarn.lock
8 | build/custom.js
9 | .vscode/
10 | tests/**/*.js
11 |
--------------------------------------------------------------------------------
/.npmignore:
--------------------------------------------------------------------------------
1 | *.tgz
2 | .tmp/
3 | .travis.yml
4 | dist/*.*
5 | !dist/all.css
6 | examples
7 | sass-lint.yml
8 | tests
9 |
--------------------------------------------------------------------------------
/.sassdocrc:
--------------------------------------------------------------------------------
1 | {
2 | "dest": ".tmp",
3 | "theme": "build/sassdoc-theme.js",
4 | "meta": {
5 | "name": "default",
6 | "friendlyName": "Default",
7 | },
8 | "groups": {
9 | "charts": "Charts",
10 | "undefined": "Common"
11 | }
12 | }
13 |
--------------------------------------------------------------------------------
/CODEOWNERS.md:
--------------------------------------------------------------------------------
1 | * @gyoshev @joneff
2 | docs/* @dmihaylo
3 |
--------------------------------------------------------------------------------
/CONTRIBUTING.md:
--------------------------------------------------------------------------------
1 | # Guidelines to Contribution
2 |
3 | We accept third-party contributions.
4 |
5 | ## Ways to Contribute
6 |
7 | You can contribute by:
8 |
9 | * Submitting bug-fixes.
10 | * Proposing changes in documentation or updates to existing code.
11 | * Adding features or missing functionalities.
12 |
13 | ## Steps to Contribute
14 |
15 | To submit your suggestions:
16 |
17 | 1. If a first-time contributor, read and sign the [Kendo UI for Angular Contribution License Agreement (CLA)](https://docs.google.com/forms/d/e/1FAIpQLSdSzuLLij8dtytTeiXCzlHcTmHYZIxgrAa7BSaO_fno79ua1A/viewform?c=0&w=1). The Agreement confirms that you acknowledge the legal aspects of your contributions.
18 | 1. Branch out the repo you want to update.
19 | 1. Add your contribution.
20 | 1. Submit a [Pull Request](https://help.github.com/articles/creating-a-pull-request/).
21 |
22 | ## Support-Related Issues
23 |
24 | Refer to our [**Community & Support**](http://www.telerik.com/kendo-angular-ui/support/) page for more information on:
25 |
26 | * How to report a bug
27 | * New upcoming features
28 | * Support-related questions
29 |
--------------------------------------------------------------------------------
/LICENSE.md:
--------------------------------------------------------------------------------
1 | This package is part of the following suites:
2 |
3 | * [Kendo UI for Angular](http://www.telerik.com/kendo-angular-ui/)
4 | * [Kendo UI for jQuery](http://www.telerik.com/kendo-ui)
5 | * [UI for ASP.NET MVC](http://www.telerik.com/aspnet-mvc)
6 | * [UI for ASP.NET Core](http://www.telerik.com/aspnet-core-ui)
7 |
8 | All available Kendo UI commercial licenses may be obtained at http://www.telerik.com/purchase/kendo-ui.
9 |
10 | If you do not own a commercial license, the usage of this software shall be governed by the [Apache License, Version 2.0](http://www.apache.org/licenses/LICENSE-2.0).
11 |
12 | *Copyright © 2018 Telerik AD. All rights reserved.*
13 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | ## This repository is no longer updated. To access the current version, refer to the [`kendo-themes` monorepo](https://github.com/telerik/kendo-themes).
2 |
3 | # Kendo UI Default Theme
4 |
5 | The Kendo UI Default Theme is a SCSS-based theme for the Kendo UI components.
6 |
7 | * [License](#license)
8 | * [Basic Usage](#basic-usage)
9 | * [Customization](#customization)
10 | * [Development](#development)
11 | * [Embedding Resources](#embedding-resources)
12 | * [Documenting Variables](#documenting-variables)
13 |
14 | ## License
15 |
16 | This package is part of the following suites:
17 |
18 | * [Kendo UI for Angular](http://www.telerik.com/kendo-angular-ui/)
19 | * [Kendo UI for jQuery](http://www.telerik.com/kendo-ui)
20 | * [UI for ASP.NET MVC](http://www.telerik.com/aspnet-mvc)
21 | * [UI for ASP.NET Core](http://www.telerik.com/aspnet-core-ui)
22 |
23 | All available Kendo UI commercial licenses may be obtained at http://www.telerik.com/purchase/kendo-ui.
24 |
25 | If you do not own a commercial license, the usage of this software shall be governed by the [Apache License, Version 2.0](http://www.apache.org/licenses/LICENSE-2.0).
26 |
27 | ## Basic Usage
28 |
29 | For more information on how to implement the Default theme in your project, refer to the following articles:
30 |
31 | * [Using the Default Theme in Angular Projects](http://www.telerik.com/kendo-angular-ui/components/styling/)
32 | * [Using the Default Theme in jQuery Projects](http://docs.telerik.com/kendo-ui/styles-and-layout/sass-themes)
33 |
34 | ## Customization
35 |
36 | To customize the Default Theme in one swoop, use the colors which are defined in the [`scss/_variables.scss`](scss/_variables.scss) file. Any change you make to the content of this file is propagated to every component.
37 |
38 | To style a specific component, apply the variables which are used in its specific `.scss` file.
39 |
40 | After you build the theme by running the `npm run build` command, the complete theme that you can use in your project will be available in the `dist/all.css` file.
41 |
42 | ## Development
43 |
44 | The styles are split into components and the dependencies are managed by the [`import-once`](scss/mixins/core/_import-once.scss) mixin. When you configure the styles, define them within an `import-once` block. In this way, when required from multiple files, they are bundled once.
45 |
46 | During development, the SCSS files are linted on every `commit` and built on every `push` command. To test the theme package against a component, link the theme in the components package.
47 |
48 | Browser-specific properties are generated at build-time through the [PostCSS autoprefixer](https://github.com/postcss/autoprefixer).
49 |
50 | ### Embedding Resources
51 |
52 | The embedding of resources, such as images or fonts, avoids hosting-related issues when your project consumes the theme. For more details, refer to [issue #41](https://github.com/telerik/kendo-theme-default/issues/41#issuecomment-258472183).
53 |
54 | To update the embedded resources in your project:
55 |
56 | 1. Run the `npm run embed-assets` task. As a result, the task generates a file with the same name, which registers a Base64-encoded version in the `$data-uris` SCSS map. For example, the `foo.woff` font file will receive a `foo.scss` file, which can later be imported through `@import './font/foo';`.
57 | 1. Inline the Base64 version through `map-get( $data-uris, 'WebComponentsIcons.woff' )`.
58 |
59 | ### Documenting Variables
60 |
61 | The available variables for customizing the Default theme are listed in the article on [Default variables](https://github.com/telerik/kendo-theme-default/blob/develop/docs/customization.md). The file is generated from the SCSS source files by running the `npm run api` command.
62 |
63 | To document a variable, use triple-slash comments (`///`) before its definition.
64 |
65 | /// Variable description
66 | $foo: 42 !default;
67 |
68 | To group variables, use the `@group` directive.
69 |
70 | /// Variable description
71 | /// @group random
72 | $foo: 42 !default;
73 |
74 | /// Another variable description
75 | /// @group random
76 | $bar: 1024 !default;
77 |
78 | To change the layout or the front meter of the generated help topic, change the [`build/customization.md.hbs`](/build/customization.md.hbs) source file.
79 |
80 | *Copyright © 2018 Progress Software Corporation and/or its subsidiaries or affiliates. All Rights Reserved.*
81 |
82 | *Progress, Telerik, and certain product names used herein are trademarks or registered trademarks of Progress Software Corporation and/or one of its subsidiaries or affiliates in the U.S. and/or other countries.*
83 |
--------------------------------------------------------------------------------
/build/all.js:
--------------------------------------------------------------------------------
1 | // entry point for webpack
2 | require("./../scss/all.scss");
--------------------------------------------------------------------------------
/build/customization.md.hbs:
--------------------------------------------------------------------------------
1 | ---
2 | title: Customization
3 | description: "Refer to the list of the Kendo UI {{ meta.friendlyName }} theme variables available for customization."
4 | slug: variables_kendotheme{{ meta.name }}
5 | position: 9
6 | ---
7 |
8 | # Customization
9 |
10 | The following table lists the available variables for customizing the {{ meta.friendlyName }} theme.
11 |
12 |
27 |
28 | ## Variables
29 |
30 | {{#each variable}}
31 |
32 | ### {{ title }}
33 |
34 |
35 |
36 |
37 |
38 |
39 |
40 |
41 | Name |
42 | Default value |
43 | Description |
44 |
45 | {{#each variables}}
46 |
47 | ${{context.name}} |
48 |
49 | {{# if isColor }}{{/if}}
50 | {{ context.value }}
51 | |
52 | {{{ formatText description }}} |
53 |
54 | {{/each}}
55 |
56 |
57 | {{/each}}
58 |
59 | ## Mixins
60 |
61 | {{#each mixin}}
62 | ### `{{ context.name }}`
63 | {{ description }}
64 |
65 | {{#if parameter}}
66 | #### Parameters
67 | {{#each parameter}}
68 | - {{ name }} : `{{ type }}` - {{ description }}
69 | {{/each}}
70 | {{/if}}
71 |
72 | {{/each}}
73 |
74 | ## Suggested Links
75 |
76 | * [Styling Overview]({% slug themesandstyles %})
77 | * [Web Font Icons]({% slug icons %})
78 | * [Preview of the Themed Components](../)
79 |
--------------------------------------------------------------------------------
/build/data-uri.template:
--------------------------------------------------------------------------------
1 | @import '../../mixins';
2 |
3 | @include exports('') {
4 | @include register-data-uri('', 'data:;base64,')
5 | }
6 |
--------------------------------------------------------------------------------
/build/embed-assets.js:
--------------------------------------------------------------------------------
1 | #!/usr/bin/node
2 |
3 | var glob = require('glob');
4 | var exec = require('child_process').exec;
5 | var path = require('path');
6 |
7 | glob('scss/**/*.{png,gif,woff}', function(err, files) {
8 | if (err) {
9 | console.error(err);
10 | } else {
11 | files.forEach(function(filename) {
12 | console.log('converting asset to data URI:', filename);
13 | exec([
14 | 'node',
15 | path.join(__dirname, 'file-to-sass.js'),
16 | filename
17 | ].join(' '), function(err, stdout, stderr) {
18 | if (err) {
19 | console.error(stderr)
20 | process.exit(1);
21 | }
22 | });
23 | });
24 | }
25 | });
--------------------------------------------------------------------------------
/build/file-to-sass.js:
--------------------------------------------------------------------------------
1 | #!/usr/bin/node
2 |
3 | var mime = require('mime');
4 | var fs = require('fs');
5 | var path = require('path');
6 |
7 | var filename = process.argv[2];
8 | var basename = path.basename(filename);
9 | var mimeType = mime.lookup(filename);
10 | var base64 = fs.readFileSync(filename).toString('base64');
11 | var template = fs.readFileSync(path.join(__dirname, 'data-uri.template'), 'utf8');
12 |
13 | var output =
14 | template
15 | .replace(//g, basename)
16 | .replace(//g, mimeType)
17 | .replace(//g, base64);
18 |
19 | var outputFilename =
20 | path.join(
21 | path.dirname(filename),
22 | path.basename(filename, path.extname(filename)) + '.scss'
23 | );
24 |
25 | fs.writeFileSync(outputFilename, output)
--------------------------------------------------------------------------------
/build/sassdoc-theme.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | const fs = require('fs');
4 | const path = require('path');
5 | const hbs = require('handlebars');
6 | const read = (src) =>
7 | fs.readFileSync(path.join(__dirname, src), { encoding: 'utf-8' });
8 |
9 | hbs.registerHelper('formatText', (str) =>
10 | str.replace(/\n(.)/g, '
\n$1'));
11 |
12 | const compile = (src) =>
13 | hbs.compile(read(src), { noEscape: true });
14 | const template = compile('customization.md.hbs');
15 |
16 | module.exports = function(dest, context) {
17 | const capitalize = (str) => str[0].toUpperCase() + str.substring(1);
18 | const isColor = /^#/i;
19 | const data = context.data
20 | .filter((item) => item.access == 'public')
21 | .reduce((acc, item) => {
22 | acc[item.context.type].push(item);
23 | return acc;
24 | }, {
25 | mixin: [],
26 | variable: []
27 | });
28 |
29 | // honor @group annotations
30 | data.variable = data.variable.reduce((acc, item) => {
31 | const groupId = item.group[0];
32 | item.isColor = isColor.test(item.context.value);
33 | acc[groupId] = acc[groupId] || [];
34 | acc[groupId].push(item);
35 | return acc;
36 | }, {});
37 |
38 | // add titles to groups
39 | data.variable = Object.keys(data.variable).map((groupId) => ({
40 | id: groupId === "undefined" ? null : groupId,
41 | title: context.groups[groupId] || capitalize(groupId),
42 | variables: data.variable[groupId]
43 | }));
44 |
45 | // sort groups by title, moving common group to the top
46 | data.variable.sort((a, b) => {
47 | if (!a.id) return -1;
48 | if (!b.id) return 1;
49 |
50 | return a.title === b.title ? 0 :
51 | a.title < b.title ? -1 : 1;
52 | });
53 |
54 | data.meta = context.meta;
55 |
56 | return new Promise(function(done, error) {
57 | let output = template(data);
58 | output = output.replace(/\r?\n/g, '\n');
59 | fs.writeFile(path.join('docs', 'customization.md'), output);
60 | });
61 | };
--------------------------------------------------------------------------------
/build/twbs-compat.js:
--------------------------------------------------------------------------------
1 | // entry point for webpack
2 | require("./twbs-compat.scss");
--------------------------------------------------------------------------------
/build/twbs-compat.scss:
--------------------------------------------------------------------------------
1 | @import "~bootstrap/scss/functions";
2 | @import "~bootstrap/scss/variables";
3 | @import "./../scss/all";
4 |
--------------------------------------------------------------------------------
/docs/_meta.yml:
--------------------------------------------------------------------------------
1 | title: Default Theme
2 | position: 999
3 |
--------------------------------------------------------------------------------
/docs/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | title: Overview
3 | description: "Preview and install the Kendo UI Default theme and style the Kendo UI components in Angular and React projects."
4 | slug: preview_kendothemedefault
5 | position: 1
6 | ---
7 |
8 | # Overview
9 |
10 | The Kendo UI Default theme is available through the @progress/kendo-theme-default NPM module.
11 |
12 | ## Installation
13 |
14 | 1. Download and install the package of the Default theme.
15 |
16 | ```bash
17 | npm install --save @progress/kendo-theme-default
18 | ```
19 |
20 | 1. Apply the Default theme options according to the instructions in the article on [styling]({% slug themesandstyles %}).
21 |
22 | ## Preview
23 |
24 | The following example previews Kendo UI components which are styled with the Default theme.
25 |
26 | {% theme_preview theme:default %}
27 | {% platform_content angular %}
28 |
29 | {% endplatform_content %}
30 | {% platform_content react %}
31 |
32 | {% endplatform_content %}
33 | {% platform_content vue %}
34 |
35 | {% endplatform_content %}
36 |
37 | ## Suggested Links
38 |
39 | * [Styling the Kendo UI Components]({% slug themesandstyles %})
40 | * [Kendo UI Font Icons]({% slug icons %})
41 |
--------------------------------------------------------------------------------
/examples/react/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | Webpack CSS example
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
--------------------------------------------------------------------------------
/examples/react/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "version": "0.1.0",
3 | "description": "A theme test application with Kendo UI for React",
4 | "main": "src/index.js",
5 | "scripts": {
6 | "build": "webpack",
7 | "lint": "standard",
8 | "test": "standard && webpack --bail"
9 | },
10 | "dependencies": {
11 | "@telerik/kendo-common-tasks": "^1.8.0",
12 | "@telerik/kendo-react-inputs": "^0.1.0",
13 | "@telerik/kendo-react-dialog": "^1.0.0",
14 | "@progress/kendo-theme-default": "^1.0.0",
15 | "autoprefixer": "^6.3.6",
16 | "babel-core": "^6.7.6",
17 | "babel-loader": "^6.2.4",
18 | "babel-preset-es2015": "^6.6.0",
19 | "babel-preset-react": "^6.1.4",
20 | "css-loader": "^0.23.0",
21 | "extract-text-webpack-plugin": "^1.0.1",
22 | "node-sass": "^3.4.1",
23 | "postcss-loader": "^0.9.1",
24 | "react": "^15.0.1",
25 | "react-dom": "^15.0.1",
26 | "react-addons-transition-group": "^15.0.1",
27 | "sass-loader": "^3.2.0",
28 | "style-loader": "^0.13.1",
29 | "webpack": "^1.12.14"
30 | },
31 | "eslintConfig": {
32 | "parser": "babel-eslint",
33 | "extends": "airbnb",
34 | "globals": {
35 | "__DEV__": true
36 | },
37 | "env": {
38 | "browser": true
39 | },
40 | "rules": {
41 | "no-confusing-arrow": 0,
42 | "react/jsx-quotes": 0,
43 | "jsx-quotes": [
44 | 2,
45 | "prefer-double"
46 | ]
47 | }
48 | },
49 | "author": "",
50 | "license": "MIT"
51 | }
52 |
--------------------------------------------------------------------------------
/examples/react/src/index.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import ReactDOM from 'react-dom'
3 |
4 | import { Slider } from '@telerik/kendo-react-inputs';
5 | import { Dialog } from '@telerik/kendo-react-dialog';
6 | import { Button } from '@telerik/kendo-react-buttons';
7 | import '@progress/kendo-theme-default/styles/slider/main.scss';
8 | import '@progress/kendo-theme-default/styles/dialog/main.scss';
9 |
10 | class Container extends React.Component {
11 | constructor(props) {
12 | super(props);
13 | this.state = {
14 | dialogVisible: true,
15 | value: 4
16 | };
17 | this.valueChangeHandler = this.onValueChange.bind(this);
18 | this.dialogActionHandler = this.onDialogAction.bind(this);
19 | }
20 |
21 | updateState(newState) {
22 | this.setState(Object.assign({}, this.state, newState));
23 | }
24 |
25 | onValueChange(e) {
26 | this.updateState({ value: e.value });
27 | }
28 |
29 | onDialogAction(e) {
30 | this.updateState({ dialogVisible: false });
31 | }
32 |
33 | render() {
34 | const dialog = (
35 |
44 | );
45 |
46 | return (
47 |
48 | Sample Kendo UI for React Application
49 |
50 |
53 |
54 | { this.state.dialogVisible ? dialog : null }
55 |
56 | );
57 | }
58 | }
59 |
60 | ReactDOM.render(, document.querySelector('#main'))
61 |
--------------------------------------------------------------------------------
/examples/react/webpack.config.js:
--------------------------------------------------------------------------------
1 | const ExtractTextPlugin = require('extract-text-webpack-plugin')
2 | const path = require('path')
3 | const kendoTasks = require('@telerik/kendo-common-tasks');
4 |
5 | const sassLoaders = [
6 | 'css-loader',
7 | 'postcss-loader',
8 | 'sass-loader?indentedSyntax=sass&includePaths[]=' + path.resolve(__dirname, './src')
9 | ]
10 |
11 | const config = kendoTasks.webpackThemeConfig({
12 | entry: {
13 | app: ['./src/index']
14 | },
15 | module: {
16 | loaders: [
17 | {
18 | test: /\.jsx?$/,
19 | exclude: /node_modules/,
20 | loader: 'babel',
21 | query: {
22 | presets: ['es2015', 'react']
23 | }
24 | },
25 | {
26 | test: /\.sass$/,
27 | loader: ExtractTextPlugin.extract('style-loader', sassLoaders.join('!'))
28 | }
29 | ]
30 | },
31 | output: {
32 | filename: '[name].js',
33 | path: path.join(__dirname, './build'),
34 | publicPath: '/build'
35 | },
36 | plugins: [
37 | new ExtractTextPlugin('[name].css')
38 | ],
39 | resolve: {
40 | extensions: ['', '.js', '.sass'],
41 | root: [path.join(__dirname, './src')]
42 | }
43 | })
44 |
45 | module.exports = config
46 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@progress/kendo-theme-default",
3 | "description": "SASS resources for the default Kendo UI theme",
4 | "version": "2.0.0",
5 | "author": "Progress",
6 | "license": "Apache-2.0",
7 | "keywords": [
8 | "Kendo UI",
9 | "Theme"
10 | ],
11 | "main": "dist/all.css",
12 | "sass": "scss/all.scss",
13 | "repository": {
14 | "type": "git",
15 | "url": "https://github.com/telerik/kendo-theme-default.git"
16 | },
17 | "release": {
18 | "debug": false,
19 | "branchTags": {
20 | "develop": "dev"
21 | },
22 | "fallbackTags": {
23 | "dev": "latest"
24 | },
25 | "analyzeCommits": "@telerik/semantic-prerelease/analyzeCommits",
26 | "generateNotes": "@telerik/semantic-prerelease/generateNotes",
27 | "getLastRelease": "@telerik/semantic-prerelease/getLastRelease",
28 | "verifyConditions": "@telerik/semantic-prerelease/verifyConditions",
29 | "verifyRelease": "@telerik/semantic-prerelease/verifyRelease"
30 | },
31 | "scripts": {
32 | "lint": "sass-lint -v -c ./sass-lint.yml",
33 | "api": "sassdoc ./scss/",
34 | "api-check": "npm run api && git diff --exit-code --quiet -- docs/ || (echo -e '\\033[0;31mERROR: API docs are out of date' && exit 1)",
35 | "start": "webpack-dev-server",
36 | "build": "webpack --optimize-minimize --bail",
37 | "watch": "webpack --watch",
38 | "embed-assets": "node build/embed-assets.js",
39 | "test": "npm run lint && npm run build && npm run api-check && npm run twbs-compat && npm run karma-single",
40 | "twbs-compat": "webpack --env.twbs-compat --bail",
41 | "semantic-release": "semantic-release pre && semantic-prerelease publish && semantic-release post",
42 | "watch-test": "npm run karma-watch",
43 | "karma-watch": "karma start --auto-watch --no-single-run",
44 | "karma-single": "karma start --no-auto-watch --single-run --browsers ChromeHeadless"
45 | },
46 | "config": {
47 | "commitizen": {
48 | "path": "./node_modules/cz-conventional-changelog"
49 | },
50 | "ghooks": {
51 | "pre-commit": "npm run lint",
52 | "pre-push": "npm run test",
53 | "commit-msg": "validate-commit-msg"
54 | },
55 | "validate-commit-msg": {
56 | "types": [
57 | "feat",
58 | "fix",
59 | "docs",
60 | "style",
61 | "refactor",
62 | "perf",
63 | "test",
64 | "chore",
65 | "revert"
66 | ],
67 | "warnOnFail": false,
68 | "maxSubjectLength": 100
69 | }
70 | },
71 | "devDependencies": {
72 | "@telerik/kendo-common-tasks": "^3.0.0",
73 | "@telerik/semantic-prerelease": "^1.0.0",
74 | "bootstrap": "4.0.0",
75 | "cz-conventional-changelog": "^1.1.5",
76 | "editorconfig-tools": "^0.1.1",
77 | "ghooks": "^1.0.3",
78 | "glob": "^7.0.5",
79 | "handlebars": "^4.0.10",
80 | "jquery": "^3.3.1",
81 | "karma": "^1.7.1",
82 | "karma-chrome-launcher": "^2.2.0",
83 | "karma-qunit": "^1.2.1",
84 | "mime": "^1.3.4",
85 | "qunitjs": "^2.4.1",
86 | "sass-lint": "^1.7.0",
87 | "sassdoc": "^2.1.20",
88 | "semantic-release": "^6.3.6",
89 | "validate-commit-msg": "^1.1.1",
90 | "webpack": "^1.13.1"
91 | }
92 | }
93 |
--------------------------------------------------------------------------------
/sass-lint.yml:
--------------------------------------------------------------------------------
1 | options:
2 | verbose: true
3 |
4 | files:
5 | include: 'scss/**/*.scss'
6 | ignore:
7 | - 'scss/mixins/**/*.scss'
8 |
9 | rules:
10 | no-ids: 2
11 | property-sort-order: 0
12 | mixins-before-declarations: 0
13 |
14 | nesting-depth:
15 | - 1
16 | - max-depth: 4
17 |
18 | indentation:
19 | - 2
20 | - size: 4
21 |
22 | force-element-nesting: 0
23 | force-attribute-nesting: 0
24 | force-pseudo-nesting: 0
25 |
26 | no-vendor-prefixes: 0
27 |
28 | no-css-comments: 0
29 | no-color-keywords: 0
30 | no-color-literals: 0
31 | hex-length: 0
32 | no-misspelled-properties: 0
33 | no-trailing-whitespace: 2
34 | no-qualifying-elements: 0
35 |
36 | pseudo-element: 2
37 |
38 | final-newline: 0
39 | empty-args: 0
40 | empty-line-between-blocks: 0
41 | placeholder-in-extend: 0
42 | quotes: 0
43 | space-between-parens: 0
44 | shorthand-values: 0
45 | no-empty-rulesets: 0
46 |
--------------------------------------------------------------------------------
/scss/_mixins.scss:
--------------------------------------------------------------------------------
1 | // Core
2 | @import "mixins/core/import-once";
3 | @import "mixins/core/placeholder-selectors";
4 | @import "mixins/core/data-uri";
5 | @import "mixins/core/math";
6 |
7 |
8 | // Utils
9 | @import "mixins/blend-modes";
10 | @import "mixins/border-radius";
11 | @import "mixins/box-shadow";
12 | @import "mixins/button-size";
13 | @import "mixins/colors";
14 | @import "mixins/decoration";
15 | @import "mixins/disabled";
16 | @import "mixins/gradients";
17 | @import "mixins/hide-scrollbar";
18 |
19 |
20 | // Appearance
21 | @import "mixins/appearance";
22 | @import "mixins/widget";
23 | @import "mixins/button";
24 | @import "mixins/input";
25 | @import "mixins/node";
26 |
--------------------------------------------------------------------------------
/scss/action-buttons.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "button";
8 |
9 |
10 | // Component
11 | @import "action-buttons/layout";
12 | @import "action-buttons/theme";
13 |
--------------------------------------------------------------------------------
/scss/action-buttons/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports('action-buttons/layout') {
2 |
3 | .k-action-buttons {
4 | border-width: 1px 0 0;
5 | border-style: solid;
6 | border-color: inherit;
7 | display: flex;
8 | flex-direction: row;
9 | clear: both;
10 |
11 | .k-button {
12 | @include border-radius( 0 );
13 | padding: ($window-inner-padding-x * .75) $window-inner-padding-x;
14 | border-width: 0;
15 | border-color: inherit;
16 | color: inherit;
17 | background: none;
18 | flex: 1;
19 | }
20 | .k-button + .k-button {
21 | border-left-width: 1px;
22 | }
23 |
24 | .k-rtl &,
25 | [dir="rtl"] & {
26 | .k-button + .k-button {
27 | border-left-width: 0;
28 | border-right-width: 1px;
29 | border-right-style: solid;
30 | margin-left: 0;
31 | }
32 | }
33 | }
34 |
35 | }
36 |
--------------------------------------------------------------------------------
/scss/action-buttons/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports('action-buttons/theme') {
2 |
3 | .k-action-buttons {
4 | border-color: $popup-border;
5 |
6 | .k-button {
7 | color: inherit;
8 |
9 | &:hover,
10 | &.k-state-hover {
11 | @include appearance( hovered-button );
12 | border-color: inherit;
13 | }
14 |
15 | &:focus,
16 | &.k-state-focused {
17 | box-shadow: $focused-shadow;
18 | }
19 |
20 | &:active,
21 | &.k-state-active {
22 | @include appearance( pressed-button );
23 | border-color: inherit;
24 | }
25 | }
26 |
27 | .k-primary {
28 | color: $accent;
29 |
30 | &:hover,
31 | &.k-state-hvoer {
32 | @include appearance( hovered-primary-button );
33 | border-color: inherit;
34 |
35 | &:focus,
36 | &.k-state-focused {
37 | box-shadow: $focused-shadow;
38 | }
39 | }
40 |
41 | &:focus,
42 | &.k-state-focused {
43 | box-shadow: inset 0 0 0 2px rgba( $button-hovered-bg, .3);
44 | }
45 |
46 | &:active,
47 | &.k-state-active {
48 | @include appearance( pressed-primary-button );
49 | border-color: inherit;
50 | }
51 | }
52 | }
53 |
54 | }
55 |
--------------------------------------------------------------------------------
/scss/all.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 | // Dependencies
5 | @import "common/all";
6 | @import "ripple";
7 | @import "popup";
8 |
9 |
10 | // Data management
11 | @import "pager";
12 | @import "grid";
13 | @import "spreadsheet";
14 | @import "pivotgrid";
15 | @import "treelist";
16 | @import "scrollview";
17 | @import "listview";
18 |
19 |
20 | // Editors
21 | @import "autocomplete";
22 | @import "colorpicker";
23 | @import "combobox";
24 | @import "datetime";
25 | @import "dropdownlist";
26 | @import "editor";
27 | @import "input";
28 | @import "multiselect";
29 | @import "numerictextbox";
30 | @import "slider";
31 | @import "upload";
32 | @import "validator";
33 | @import "switch";
34 | @import "maskedtextbox";
35 | @import "listbox";
36 |
37 |
38 | // Dataviz
39 | @import "dataviz";
40 | @import "map";
41 |
42 | // Barcodes
43 | @import "barcode";
44 | @import "qrcode";
45 |
46 | // Scheduling
47 | @import "calendar";
48 | @import "gantt";
49 | @import "scheduler";
50 |
51 |
52 | // Media
53 | @import "mediaplayer";
54 |
55 |
56 | // Layout
57 | @import "dialog";
58 | @import "notification";
59 | @import "responsivepanel";
60 | @import "splitter";
61 | @import "tooltip";
62 | @import "window";
63 |
64 |
65 | // Navigation
66 | @import "button";
67 | @import "menu";
68 | @import "panelbar";
69 | @import "tabstrip";
70 | @import "toolbar";
71 | @import "treeview";
72 |
73 |
74 | // Interactivity & UX
75 | @import "progressbar";
76 | @import "scroller";
77 |
--------------------------------------------------------------------------------
/scss/autocomplete.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 | // Dependencies
5 | @import "common/all";
6 | @import 'common/forms';
7 |
8 |
9 | // Component
10 | @import "autocomplete/layout";
11 | @import "autocomplete/theme";
12 |
--------------------------------------------------------------------------------
/scss/autocomplete/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("autocomplete/layout") {
2 |
3 | // Layout
4 | .k-autocomplete {
5 | @include border-radius();
6 |
7 | .k-input {
8 | padding: $input-padding-y $input-padding-x;
9 | height: $form-line-height-em;
10 | box-sizing: content-box;
11 | border: 0;
12 | outline: 0;
13 | color: inherit;
14 | background: none;
15 | font: inherit;
16 | line-height: $form-line-height;
17 | display: inline-block;
18 | flex: 1;
19 | }
20 |
21 | .k-i-close {
22 | display: none;
23 | align-self: center;
24 | }
25 |
26 | &.k-state-hover,
27 | &.k-state-focused {
28 | .k-i-close {
29 | display: flex;
30 | outline: 0;
31 | }
32 | }
33 |
34 | }
35 |
36 | }
37 |
--------------------------------------------------------------------------------
/scss/autocomplete/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("autocomplete/theme") {
2 | .k-autocomplete {
3 | @include appearance( input );
4 | background-clip: padding-box;
5 |
6 | .k-ie11 &,
7 | .k-edge12 &,
8 | .k-edge13 & {
9 | background-clip: border-box;
10 | }
11 |
12 | &.k-state-hover { @include appearance( hovered-input ); }
13 | &.k-state-focused {
14 | @include appearance( focused-input );
15 | }
16 | }
17 | }
18 |
--------------------------------------------------------------------------------
/scss/barcode.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Component
6 | @import "barcode/layout";
7 |
--------------------------------------------------------------------------------
/scss/barcode/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports('barcode/layout') {
2 |
3 | .k-barcode {
4 | display: inline-block;
5 | }
6 |
7 | }
8 |
--------------------------------------------------------------------------------
/scss/button.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import 'button/layout';
11 | @import 'button/theme';
12 |
--------------------------------------------------------------------------------
/scss/calendar.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "common/icons";
8 |
9 |
10 | // Component
11 | @import "calendar/layout";
12 | @import "calendar/theme";
13 |
--------------------------------------------------------------------------------
/scss/calendar/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports('calendar/theme') {
2 | $date-focus-shadow: $list-item-focused-shadow !default;
3 | $header-shadow: 0 1px 3px 1px rgba(black, .1) !default;
4 |
5 | .k-calendar {
6 | background-clip: padding-box;
7 |
8 | .k-ie11 &,
9 | .k-edge12 &,
10 | .k-edge13 & {
11 | background-clip: border-box;
12 | }
13 |
14 |
15 | // Header / footer
16 | .k-header {
17 | @include appearance( header );
18 | }
19 |
20 | .k-nav-prev,
21 | .k-nav-next,
22 | .k-nav-fast {
23 |
24 | // Hover
25 | &:hover,
26 | &.k-state-hover {
27 | @include appearance( hovered-button );
28 | }
29 |
30 | // Pressed
31 | &:active {
32 | @include appearance( pressed-button );
33 | }
34 | }
35 | .k-footer .k-nav-today {
36 | color: $accent;
37 | }
38 |
39 |
40 | // Content
41 | .k-content {}
42 |
43 | .k-content thead {
44 | @include appearance( header );
45 | background-color: transparent;
46 | }
47 |
48 | .k-header {
49 | border-bottom-color: $panel-border;
50 | box-shadow: $header-shadow;
51 | }
52 |
53 | .k-content td {}
54 | .k-content .k-today {
55 | color: $accent;
56 |
57 | &.k-state-selected {
58 | color: $accent-contrast;
59 | }
60 | }
61 |
62 | .k-alt {
63 | background: darken( $widget-bg, 5 );
64 | }
65 |
66 | .k-content .k-alt {
67 | border-right-color: $widget-border;
68 | }
69 |
70 | .k-state-hover {
71 | @include appearance( hovered-node );
72 | }
73 |
74 | .k-state-selected,
75 | .k-weekend.k-state-selected {
76 | @include appearance( selected-node );
77 |
78 | &.k-state-hover {
79 | background-color: blend-multiply( $list-item-selected-bg, $list-item-hovered-bg );
80 | }
81 | }
82 |
83 | .k-state-focused,
84 | .k-state-selected.k-state-focused {
85 | box-shadow: $date-focus-shadow;
86 | }
87 |
88 | // Infinite calendar
89 | .k-calendar-view {
90 | thead {
91 | @include appearance( header );
92 | }
93 | }
94 |
95 | .k-calendar-navigation {
96 | // border underneath highlight
97 | box-shadow: inset -1px 0 $base-border;
98 | background-color: $base-bg;
99 |
100 | .k-content > ul > li:hover {
101 | color: $link-hover-text;
102 | }
103 | }
104 |
105 | .k-calendar-navigation-highlight {
106 | border-color: $base-border;
107 | background-color: $bg-color;
108 | }
109 |
110 | .k-calendar-weekdays thead {
111 | background-color: $bg-color;
112 | }
113 |
114 | &[dir='rtl'],
115 | .k-rtl & {
116 | .k-calendar-navigation {
117 | box-shadow: inset 1px 0 $base-border;
118 | }
119 | }
120 |
121 | &:not(.k-infinite) {
122 | .k-weekend {
123 | background-color: darken($widget-bg, 2.35);
124 | }
125 |
126 | .k-state-hover {
127 | background-color: $node-hovered-bg;
128 | }
129 |
130 | .k-content {
131 | .k-state-selected,
132 | .k-weekend .k-state-selected {
133 | @include appearance( selected-node );
134 |
135 | &.k-state-hover {
136 | background-color: blend-multiply( $list-item-selected-bg, $list-item-hovered-bg );
137 | }
138 | }
139 | }
140 | }
141 | }
142 |
143 | }
144 |
--------------------------------------------------------------------------------
/scss/colorpicker.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "slider";
8 |
9 |
10 | // Component
11 | @import "colorpicker/layout";
12 | @import "colorpicker/theme";
13 |
--------------------------------------------------------------------------------
/scss/colorpicker/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("colorpicker/theme") {
2 |
3 | .k-colorpicker {
4 |
5 | // Normal state
6 | .k-picker-wrap {
7 | @include appearance( button );
8 | background-clip: padding-box;
9 |
10 | .k-ie11 &,
11 | .k-edge12 &,
12 | .k-edge13 & {
13 | background-clip: border-box;
14 | }
15 | }
16 | .k-select {
17 | padding: 0;
18 | width: button-inner-size();
19 | border-width: 0;
20 | }
21 |
22 | // Hovered state
23 | .k-state-hover {
24 | @include appearance( hovered-button );
25 | }
26 |
27 | // Selected state
28 | .k-state-active {
29 | @include appearance( pressed-button );
30 | }
31 |
32 | // Focused state
33 | .k-state-focused {
34 | box-shadow: $button-focused-shadow;
35 | }
36 |
37 | }
38 |
39 | .k-flatcolorpicker {
40 | background-color: $base-bg;
41 | }
42 |
43 | }
44 |
--------------------------------------------------------------------------------
/scss/combobox.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import 'common/forms';
8 |
9 |
10 | // Component
11 | @import "combobox/layout";
12 | @import "combobox/theme";
13 |
--------------------------------------------------------------------------------
/scss/combobox/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("combobox/layout") {
2 |
3 | .k-combobox {
4 | .k-dropdown-wrap {
5 | > .k-i-close {
6 | right: calc(#{$icon-size} + #{$padding-y-lg * 3});
7 | }
8 | }
9 |
10 | .k-input {}
11 |
12 | .k-select {}
13 |
14 | &[dir='rtl'],
15 | .k-rtl & {
16 | > .k-dropdown-wrap {
17 | > .k-i-close {
18 | left: calc(#{$icon-size} + #{$padding-y-lg * 3});
19 | right: auto;
20 | }
21 | }
22 | }
23 | }
24 |
25 | .k-combobox-clearable {
26 | .k-input {
27 | padding-right: add-two($icon-size, $padding-x);
28 | }
29 |
30 | &[dir='rtl'],
31 | .k-rtl & {
32 | .k-input {
33 | padding-left: add-two($icon-size, $padding-x);
34 | padding-right: $input-padding-x;
35 | }
36 | }
37 | }
38 | }
39 |
--------------------------------------------------------------------------------
/scss/combobox/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("combobox/theme") {
2 |
3 | .k-combobox {
4 |
5 | // Normal state
6 | .k-dropdown-wrap {
7 | @include appearance( input );
8 | background-clip: padding-box;
9 |
10 | .k-ie11 &,
11 | .k-edge12 &,
12 | .k-edge13 & {
13 | background-clip: border-box;
14 | }
15 | }
16 |
17 | .k-select {
18 | @include appearance( button );
19 | padding: 0;
20 | width: button-inner-size();
21 | border-width: 0;
22 | }
23 |
24 | // Hovered state
25 | > :hover,
26 | .k-state-hover {
27 | @include appearance( hovered-input );
28 |
29 | .k-select {
30 | @include appearance( hovered-button );
31 | }
32 | }
33 |
34 | // Selected state
35 | > .k-state-focused,
36 | .k-state-active {
37 | @include appearance( focused-input );
38 |
39 | .k-select {}
40 | }
41 | }
42 |
43 | }
44 |
--------------------------------------------------------------------------------
/scss/common/_all.scss:
--------------------------------------------------------------------------------
1 | @import "base";
2 | @import "icons";
3 | @import "animations";
4 | @import "forms";
5 |
--------------------------------------------------------------------------------
/scss/common/font/WebComponentsIcons.woff:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/telerik/kendo-theme-default/77efe2aa5a7bb7fb3d4a30b4cac6b87a4b12c54d/scss/common/font/WebComponentsIcons.woff
--------------------------------------------------------------------------------
/scss/dataviz.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/base";
7 | @import "popup";
8 |
9 |
10 | // Component
11 | @import "dataviz/layout";
12 | @import "dataviz/theme";
13 |
--------------------------------------------------------------------------------
/scss/dataviz/_theme.scss:
--------------------------------------------------------------------------------
1 | // TODO: chart variables
2 |
3 | $chart-crosshair-background: rgba(0, 0, 0, .5) !default;
4 | $chart-crosshair-shared-tooltip-color: $base-text !default;
5 | $chart-crosshair-shared-tooltip-background: $base-bg !default;
6 | $chart-crosshair-shared-tooltip-border: rgba(0, 0, 0, .08) !default;
7 |
8 | $chart-notes-background: rgba(0, 0, 0, .5) !default;
9 | $chart-notes-border: rgba(0, 0, 0, .5) !default;
10 | $chart-notes-lines: rgba(0, 0, 0, .5) !default;
11 |
12 | $error-bars-background: rgba(0, 0, 0, .5) !default;
13 |
14 | $chart-selection-marque-background: $series-a !default;
15 | $selection-border-color: rgba(0, 0, 0, .08) !default;
16 | $selection-shadow: inset 0 1px 7px rgba(0, 0, 0, .15) !default;
17 |
18 | @include exports('dataviz/charts/theme') {
19 | // Exported variables
20 | .k-var--chart-inactive {
21 | background-color: $chart-inactive;
22 | }
23 |
24 | .k-var--chart-major-lines {
25 | background-color: $chart-major-lines;
26 | }
27 |
28 | .k-var--chart-minor-lines {
29 | background-color: $chart-minor-lines;
30 | }
31 |
32 | .k-var--chart-area-opacity {
33 | opacity: $chart-area-opacity;
34 | }
35 |
36 | .k-var--chart-notes-background {
37 | background-color: $chart-notes-background;
38 | }
39 |
40 | .k-var--chart-notes-border {
41 | background-color: $chart-notes-border;
42 | }
43 |
44 | .k-var--chart-notes-lines {
45 | background-color: $chart-notes-lines;
46 | }
47 |
48 | .k-var--chart-crosshair-background {
49 | background-color: $chart-crosshair-background;
50 | }
51 |
52 | .k-var--chart-error-bars-background {
53 | background-color: $error-bars-background;
54 | }
55 |
56 | // Elements
57 | .k-chart,
58 | .k-sparkline,
59 | .k-stockchart {
60 | background-color: transparent;
61 |
62 | .k-popup {
63 | background: transparent;
64 | }
65 | }
66 |
67 | .k-chart-tooltip {
68 | @include border-radius();
69 | color: $widget-bg;
70 | }
71 |
72 | .k-chart-tooltip-inverse {
73 | color: invert($widget-bg);
74 | }
75 |
76 | .k-chart-crosshair-tooltip,
77 | .k-chart-shared-tooltip {
78 | color: $chart-crosshair-shared-tooltip-color;
79 | background-color: $chart-crosshair-shared-tooltip-background;
80 | border-color: $chart-crosshair-shared-tooltip-border;
81 | }
82 |
83 | .k-selection {
84 | border-color: $selection-border-color;
85 | box-shadow: $selection-shadow;
86 | }
87 |
88 | .k-selection-bg {
89 | background-color: transparent;
90 | }
91 |
92 | .k-handle {
93 | cursor: e-resize;
94 | @include appearance( button );
95 |
96 | &:hover {
97 | @include appearance( hovered-button );
98 | }
99 | }
100 |
101 | .k-handle div {
102 | background-color: transparent;
103 | }
104 |
105 | .k-mask {
106 | background-color: $widget-bg;
107 | opacity: .8;
108 | }
109 |
110 | .k-marquee-color {
111 | background-color: $chart-selection-marque-background;
112 | }
113 |
114 | .k-marquee-color {
115 | opacity: .6;
116 | }
117 |
118 | // Navigator hint
119 | .k-navigator-hint .k-scroll {
120 | @include border-radius();
121 | }
122 | }
123 |
124 |
125 |
126 |
127 | @include exports("dataviz/treemap/theme") {
128 |
129 | // Treemap
130 | .k-treemap {
131 |
132 | // Title
133 | .k-treemap-title {
134 | @include appearance( header );
135 | }
136 |
137 | // Leaf
138 | .k-leaf {
139 | color: $panel-bg;
140 | }
141 | .k-leaf.k-inverse {
142 | color: $panel-text;
143 | }
144 | .k-leaf.k-state-hover {
145 | box-shadow: inset 0 0 0 3px $panel-border;
146 | }
147 | }
148 |
149 | }
150 |
--------------------------------------------------------------------------------
/scss/datetime.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "common/forms";
8 | @import "action-buttons";
9 | @import "calendar";
10 | @import "popup";
11 |
12 | // Component
13 | @import "datetime/layout";
14 | @import "datetime/theme";
15 |
--------------------------------------------------------------------------------
/scss/dialog.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "window";
8 |
9 |
10 | // Component
11 | @import "dialog/layout";
12 | @import "dialog/theme";
13 |
--------------------------------------------------------------------------------
/scss/dialog/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("dialog/layout") {
2 |
3 | .k-dialog-wrapper {
4 | display: flex;
5 | align-items: center;
6 | justify-content: center;
7 | flex-direction: column;
8 | position: fixed;
9 | top: 0;
10 | left: 0;
11 | width: 100%;
12 | height: 100%;
13 | z-index: 10001;
14 |
15 | .k-dialog {
16 | position: relative;
17 | }
18 | }
19 |
20 | .k-dialog {
21 | padding: 0;
22 | min-width: 450px;
23 | position: fixed;
24 |
25 | // Centered
26 | &.k-dialog-centered {
27 | transform: translate(-50%, -50%);
28 | top: 50%;
29 | left: 50%;
30 | }
31 | }
32 |
33 |
34 | // Titlebar
35 | .k-dialog-titlebar {}
36 | .k-dialog-title {}
37 |
38 |
39 | // Actions
40 | .k-dialog-actions {}
41 | .k-dialog-action {}
42 |
43 |
44 | // Content
45 | .k-dialog-content {}
46 |
47 |
48 | // Buttons
49 | .k-dialog-buttongroup {
50 | border-width: 1px 0 0;
51 | border-style: solid;
52 | border-color: inherit;
53 | background-color: transparent;
54 | display: flex;
55 | flex: 0 0 auto;
56 |
57 | .k-button {
58 | // sass-lint:disable no-important
59 | padding: ($window-inner-padding-x * .75) $window-inner-padding-x;
60 | width: auto !important;
61 | border-width: 0;
62 | border-color: inherit;
63 | background: none;
64 | white-space: normal;
65 | flex: 1;
66 | // sass-lint:enable no-important
67 |
68 | &::before,
69 | &::after {
70 | // center stretched button content for Safari 10
71 | content: '';
72 | flex: 1 0 auto;
73 | }
74 | }
75 | .k-button,
76 | .k-button:first-child,
77 | .k-button:last-child,
78 | .k-group-start,
79 | .k-group-end {
80 | @include border-radius( 0 );
81 | }
82 | .k-button + .k-button {
83 | margin: 0;
84 | border-left-width: 1px;
85 |
86 | .k-rtl &,
87 | [dir='rtl'] & {
88 | border-left-width: 0;
89 | border-right-width: 1px;
90 | }
91 | }
92 | }
93 | .k-dialog-button-layout-stretched {
94 | flex-direction: row;
95 | align-items: stretch;
96 | }
97 |
98 | }
99 |
--------------------------------------------------------------------------------
/scss/dialog/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("dialog/theme") {
2 |
3 | $dialog-titlebar-border-color: inherit !default;
4 | $dialog-titlebar-bg: $accent !default;
5 | $dialog-titlebar-text: $accent-contrast !default;
6 |
7 | .k-dialog {}
8 |
9 |
10 | // Titlebar
11 | .k-dialog-titlebar {
12 | @include fill( $dialog-titlebar-text, $dialog-titlebar-bg, $dialog-titlebar-border-color );
13 | }
14 |
15 |
16 | .k-dialog-buttongroup {
17 |
18 | .k-button {
19 | color: inherit;
20 |
21 | &:hover,
22 | &.k-state-hover {
23 | @include appearance( hovered-button );
24 | border-color: inherit;
25 | }
26 |
27 | &:focus,
28 | &.k-state-focused {
29 | box-shadow: inset 0 0 0 2px rgba(0, 0, 0, .13);
30 | }
31 |
32 | &:active,
33 | &.k-state-active {
34 | @include appearance( pressed-button );
35 | border-color: inherit;
36 | }
37 | }
38 |
39 |
40 | .k-primary {
41 | color: $accent;
42 |
43 | &:hover,
44 | &.k-state-hvoer {
45 | @include appearance( hovered-primary-button );
46 | border-color: inherit;
47 |
48 | &:focus,
49 | &.k-state-focused {
50 | box-shadow: inset 0 0 0 2px rgba( 0, 0, 0, .13);
51 | }
52 | }
53 |
54 | &:focus,
55 | &.k-state-focused {
56 | box-shadow: inset 0 0 0 2px rgba( $button-hovered-bg, .3);
57 | }
58 |
59 | &:active,
60 | &.k-state-active {
61 | @include appearance( pressed-primary-button );
62 | border-color: inherit;
63 | }
64 | }
65 |
66 | }
67 |
68 | }
69 |
--------------------------------------------------------------------------------
/scss/dropdownlist.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import 'common/forms';
8 |
9 |
10 | // Component
11 | @import "dropdownlist/layout";
12 | @import "dropdownlist/theme";
13 |
--------------------------------------------------------------------------------
/scss/dropdownlist/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("dropdownlist/layout") {
2 |
3 | .k-dropdown {
4 |
5 | .k-select {
6 | border-width: 0;
7 | }
8 |
9 | }
10 |
11 | .k-dropdown-wrap {
12 | outline: 0;
13 |
14 | > .k-input {
15 | flex: 1;
16 | }
17 | }
18 | .k-edge .k-dropdown-wrap > .k-input {
19 | min-width: 0;
20 | }
21 |
22 | .k-dropdown-operator {
23 | width: auto;
24 |
25 | .k-input {
26 | display: none;
27 | }
28 |
29 | .k-select {
30 | width: button-inner-size();
31 | height: button-inner-size();
32 | }
33 | }
34 |
35 | }
36 |
--------------------------------------------------------------------------------
/scss/dropdownlist/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports( "dropdownlist/theme" ) {
2 |
3 | .k-dropdown {
4 |
5 | .k-dropdown-wrap {
6 | @include appearance( button );
7 | background-clip: padding-box;
8 |
9 | .k-ie11 &,
10 | .k-edge12 &,
11 | .k-edge13 & {
12 | background-clip: border-box;
13 | }
14 | }
15 | .k-select {
16 | padding: 0;
17 | width: button-inner-size();
18 | }
19 |
20 | > :hover,
21 | .k-state-hover {
22 | @include appearance( hovered-button );
23 | }
24 |
25 | .k-state-active {}
26 |
27 | .k-state-focused {
28 | @include appearance( focused-input );
29 | }
30 |
31 | }
32 | }
33 |
--------------------------------------------------------------------------------
/scss/edit-form.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "edit-form/layout";
11 | @import "edit-form/theme";
12 |
--------------------------------------------------------------------------------
/scss/edit-form/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("edit-form/layout") {
2 |
3 |
4 | // Edit form
5 | .k-popup-edit-form {}
6 | .k-edit-form-container {
7 | width: 400px;
8 | min-width: 400px;
9 | border-color: inherit;
10 | position: relative;
11 | }
12 |
13 |
14 | // Tabstrip
15 | .k-edit-form-container .k-tabstrip-wrapper {
16 | margin: (-$window-inner-padding-y) (-$window-inner-padding-x);
17 | }
18 | .k-edit-form-container .k-tabstrip.k-root-tabs {
19 | margin-bottom: $window-inner-padding-y;
20 | }
21 | .k-edit-form-container .k-tabstrip .k-tabstrip-items {
22 | padding: $window-inner-padding-y $window-inner-padding-x 0;
23 | }
24 | .k-edit-form-container .k-tabstrip .k-content {
25 | padding: $window-inner-padding-y $window-inner-padding-x;
26 | border-width: 0;
27 | }
28 |
29 |
30 | // Edit buttons
31 | .k-edit-buttons {
32 | padding: $toolbar-padding-y $toolbar-padding-x;
33 | border-width: 1px 0 0;
34 | border-style: solid;
35 | border-color: inherit;
36 | text-align: right;
37 | clear: both;
38 | }
39 | .k-edit-buttons .k-button {}
40 | .k-edit-buttons .k-button + .k-button {
41 | margin-left: ( $spacer-x / 2 );
42 | }
43 | .k-edit-form-container .k-edit-buttons {
44 | margin: $window-inner-padding-y (-$window-inner-padding-x) (-$window-inner-padding-y);
45 | padding: $window-inner-padding-y $window-inner-padding-x;
46 | }
47 |
48 |
49 | // Action buttons
50 | .k-action-buttons {}
51 | .k-popup-edit-form > .k-action-buttons,
52 | .k-edit-form-container .k-action-buttons {
53 | margin: $spacer (-$window-inner-padding-x) (-$window-inner-padding-y);
54 | }
55 |
56 |
57 | .k-edit-label {
58 | margin: 0 0 $spacer-y 0;
59 | padding: add-two($input-padding-y, $input-border-width) 0;
60 | width: 30%;
61 | line-height: $form-line-height;
62 | text-align: right;
63 | float: left;
64 | clear: both;
65 | }
66 | .k-edit-field {
67 | margin: 0 0 $spacer-y 0;
68 | width: 65%;
69 | float: right;
70 | clear: right;
71 | }
72 |
73 | .k-edit-field {
74 |
75 | > .k-widget,
76 | > .k-textbox,
77 | > .k-input.k-textbox {
78 | width: 100%;
79 | box-sizing: border-box;
80 | }
81 | > .k-colorpicker {
82 | width: auto;
83 | }
84 |
85 | input[type="radio"]:not(.k-radio),
86 | input[type="checkbox"]:not(.k-checkbox) {
87 | margin-right: .4ex;
88 | }
89 |
90 | .k-radio-label,
91 | .k-checkbox-label {
92 | margin-right: ($spacer);
93 | }
94 |
95 | .k-checkbox-label {
96 | margin-top: add-two($input-padding-y, $input-border-width);
97 | }
98 |
99 | .k-reset > li + li {
100 | margin-top: ($spacer / 2);
101 | }
102 | .k-reset .k-widget {
103 | margin: 0 .4ex 0 1ex;
104 | }
105 | }
106 |
107 | }
108 |
109 | @include exports("edit-form/rtl") {
110 |
111 | .k-rtl {
112 |
113 | .k-edit-buttons {
114 | text-align: left;
115 |
116 | .k-button + .k-button {
117 | margin-left: 0;
118 | margin-right: .5em;
119 | }
120 | }
121 | }
122 | }
123 |
--------------------------------------------------------------------------------
/scss/edit-form/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("edit-form/theme") {}
2 |
--------------------------------------------------------------------------------
/scss/editor.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "button";
8 | @import "toolbar";
9 | @import "upload";
10 | @import "window";
11 |
12 |
13 | // Component
14 | @import "editor/layout";
15 | @import "editor/theme";
16 |
--------------------------------------------------------------------------------
/scss/editor/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("editor/theme") {
2 |
3 | $editor-overlay-background: #000 !default;
4 |
5 | .k-editor {
6 | @include appearance( panel );
7 | background-clip: padding-box;
8 |
9 | .k-editor-toolbar {}
10 | .k-editable-area {
11 | border-color: $header-border;
12 | }
13 |
14 | .k-ie11 &,
15 | .k-edge12 &,
16 | .k-edge13 & {
17 | background-clip: border-box;
18 | }
19 | }
20 |
21 | .k-overlay {
22 | background-color: $editor-overlay-background;
23 | }
24 |
25 |
26 | // Editor toolbar
27 | .k-editor-toolbar {
28 | @include appearance( toolbar );
29 | padding: 0;
30 |
31 |
32 | // Group
33 | .k-tool-group {
34 | padding: $toolbar-padding-y $toolbar-padding-x;
35 |
36 | .k-tool.k-group-start,
37 | .k-tool.k-group-end {
38 | @include border-radius( 0 );
39 | }
40 | }
41 | .k-tool-group + .k-tool-group {
42 | margin: 0;
43 | border-left-width: 1px;
44 | }
45 |
46 |
47 | // Tools
48 | .k-tool + .k-tool {
49 | margin: 0;
50 | }
51 | }
52 |
53 | // sass-lint:disable class-name-format
54 | .editorToolbarWindow.k-header.k-window-content {
55 | @include appearance( header );
56 | }
57 | // sass-lint:enable class-name-format
58 | // sass-lint:disable class-name-format
59 | .k-editor .k-editor-toolbar-wrap,
60 | .k-ct-popup .k-editor-toolbar,
61 | .editorToolbarWindow.k-header.k-window-content {
62 | a.k-tool {
63 | @include appearance( button );
64 | border-width: 0;
65 | background-image: none;
66 | background-color: transparent;
67 |
68 | &:hover,
69 | &.k-state-hover {
70 | @include appearance( hovered-button );
71 | }
72 |
73 | &:active,
74 | &.k-state-active {
75 | @include appearance( pressed-button );
76 | }
77 |
78 | &.k-state-selected {
79 | @include fill( $selected-text, $selected-bg, $selected-border, none );
80 | }
81 | }
82 | .k-tool-group {
83 | border-color: $border-color;
84 | }
85 | }
86 | // sass-lint:enable class-name-format
87 |
88 |
89 | // Overflow anchor
90 | .k-editor-toolbar .k-overflow-anchor {
91 | padding: $toolbar-padding-y;
92 | width: calc( #{$toolbar-inner-calc-size} );
93 | height: calc( #{$toolbar-inner-calc-size} );
94 | }
95 |
96 |
97 | // Insert table
98 | .k-ct-popup {}
99 |
100 | }
101 |
--------------------------------------------------------------------------------
/scss/gantt.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "button";
8 | @import "treelist";
9 | @import "splitter";
10 | @import "window";
11 |
12 |
13 | // Component
14 | @import "gantt/layout";
15 | @import "gantt/theme";
16 |
--------------------------------------------------------------------------------
/scss/gantt/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("gantt/theme") {
2 |
3 | // Theme
4 | .k-gantt {
5 | background-clip: padding-box;
6 |
7 | .k-ie11 &,
8 | .k-edge12 &,
9 | .k-edge13 & {
10 | background-clip: border-box;
11 | }
12 | }
13 |
14 |
15 | // Header and footer
16 | .k-gantt-toolbar {
17 | @include appearance( header );
18 | }
19 |
20 |
21 | // View switcher
22 | .k-gantt-views {
23 |
24 | li {
25 | @include appearance( button );
26 |
27 | &.k-state-hover { @include appearance( hovered-button ); }
28 | &.k-state-selected { @include fill( $selected-text, $selected-bg, $selected-border, none ); }
29 | }
30 | li:first-child { @include border-radius(); }
31 | li:first-child + li { @include border-left-radius-only(); }
32 | li:last-child { @include border-right-radius-only(); }
33 |
34 |
35 | &.k-state-expanded {
36 | li {
37 | @include border-radius( 0 );
38 | margin: 0;
39 | }
40 | li + li { margin-top: -1px; }
41 | li:first-child { @include border-top-radius-only(); }
42 | li:first-child + li { @include border-radius( 0 ) }
43 | li:last-child { @include border-bottom-radius-only(); }
44 | }
45 | }
46 |
47 |
48 | // Treelist
49 | .k-gantt-treelist {
50 | background-color: darken( $panel-bg, 2 );
51 |
52 | .k-treelist {
53 | background-color: transparent;
54 | }
55 |
56 | tr.k-alt {
57 | background-color: darken( $panel-bg, 6 );
58 | }
59 |
60 | tr.k-state-selected,
61 | td.k-state-selected {
62 | color: inherit;
63 | background-color: rgba($selected-bg, .25);
64 | }
65 |
66 | }
67 |
68 |
69 | // Rows and colls
70 | .k-gantt-rows {}
71 | .k-gantt-columns {}
72 | .k-gantt-columns .k-nonwork-hour {
73 | background-color: rgba( $panel-text, .025 );
74 | }
75 |
76 |
77 | .k-gantt-dependencies {}
78 | .k-line {
79 | color: darken( $panel-text, 40 );
80 | }
81 | .k-line.k-state-selected {
82 | color: $selected-bg;
83 | }
84 |
85 | .k-task-dot {}
86 | .k-task-dot::before {
87 | background-color: $panel-text;
88 | }
89 | .k-task-dot:hover::before,
90 | .k-task-dot.k-state-hover::before {
91 | border-color: $panel-text;
92 | background-color: $panel-bg;
93 | }
94 |
95 |
96 | // Milestone
97 | .k-task-milestone {
98 | border-color: $panel-border;
99 | background-color: $panel-text;
100 | }
101 | .k-task-milestone.k-state-selected {
102 | border-color: $selected-border;
103 | background-color: $selected-bg;
104 | }
105 |
106 |
107 | // Summary
108 | .k-task-summary {
109 | color: mix( $panel-text, $panel-bg, 95 );
110 | }
111 | .k-task-summary-complete {
112 | color: darken( $panel-text, 40 );
113 | }
114 | .k-task-summary.k-state-selected {
115 | color: mix( $selected-bg, $panel-bg, 80 );
116 |
117 | .k-task-summary-complete {
118 | color: shade( $selected-bg );
119 | }
120 | }
121 | .k-task-summary::before,
122 | .k-task-summary::after,
123 | .k-task-summary-complete::before,
124 | .k-task-summary-complete::after {
125 | display: none;
126 | }
127 |
128 |
129 | // Tasks
130 | .k-task-single {
131 | border-width: 0;
132 | border-color: $panel-border;
133 | color: $panel-bg;
134 | background: mix( $panel-text, $panel-bg, 80 );
135 |
136 | .k-task-complete {
137 | background: $panel-text;
138 | }
139 |
140 | .k-task-template {
141 | padding-top: $padding-y;
142 | padding-bottom: $padding-y;
143 | }
144 | }
145 | .k-task-single.k-state-selected {
146 | border-color: $selected-border;
147 | color: $selected-text;
148 | background: mix( $selected-bg, $panel-bg, 70 );
149 |
150 | .k-task-complete {
151 | background: $selected-bg;
152 | }
153 | }
154 |
155 | }
156 |
157 |
158 | @include exports("gantt/theme-rtl") {
159 |
160 | // View switcher
161 | .k-gantt-views {
162 | li:first-child + li { @include border-right-radius-only(); }
163 | li:last-child { @include border-left-radius-only(); }
164 | }
165 | }
166 |
--------------------------------------------------------------------------------
/scss/grid.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "dialog";
8 | @import "pager";
9 |
10 |
11 | // Component
12 | @import "grid/layout";
13 | @import "grid/theme";
--------------------------------------------------------------------------------
/scss/input.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 |
7 |
8 | // Component
9 | @import "input/layout";
10 | @import "input/theme";
11 |
--------------------------------------------------------------------------------
/scss/listbox.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "button";
7 | @import "popup";
8 |
9 |
10 | // Component
11 | @import "listbox/layout";
12 | @import "listbox/theme";
13 |
--------------------------------------------------------------------------------
/scss/listbox/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports( 'listbox/layout' ) {
2 | $listbox-margin: $padding-x !default;
3 | $listbox-width: 12.4em !default;
4 | $listbox-default-height: 200px !default;
5 |
6 | .k-listbox {
7 | width: $listbox-width;
8 | height: $listbox-default-height;
9 | vertical-align: top;
10 | background-color: transparent;
11 | border-width: 0;
12 | display: inline-flex;
13 |
14 | .k-listbox-toolbar ul {
15 | display: flex;
16 | }
17 |
18 | &.k-listbox-toolbar-left,
19 | &.k-listbox-toolbar-right {
20 | .k-listbox-toolbar ul {
21 | flex-direction: column;
22 | }
23 |
24 | .k-listbox-toolbar li + li {
25 | margin-top: $listbox-margin;
26 | }
27 | }
28 |
29 | &.k-listbox-toolbar-left {
30 | flex-direction: row;
31 |
32 | .k-listbox-toolbar {
33 | margin-right: $listbox-margin;
34 | }
35 | }
36 |
37 | &.k-listbox-toolbar-right {
38 | flex-direction: row-reverse;
39 |
40 | .k-listbox-toolbar {
41 | margin-left: $listbox-margin;
42 | }
43 | }
44 |
45 | &.k-listbox-toolbar-top,
46 | &.k-listbox-toolbar-bottom {
47 | flex-direction: column;
48 |
49 | .k-listbox-toolbar ul {
50 | flex-direction: row;
51 | }
52 |
53 | .k-listbox-toolbar li + li {
54 | margin-left: $listbox-margin;
55 | }
56 | }
57 |
58 | &.k-listbox-toolbar-top {
59 | .k-listbox-toolbar {
60 | margin-bottom: $listbox-margin;
61 | }
62 | }
63 |
64 | &.k-listbox-toolbar-bottom {
65 | .k-listbox-toolbar {
66 | margin-top: $listbox-margin;
67 | }
68 | }
69 |
70 | .k-list-scroller {
71 | width: 100%;
72 | border-width: 1px;
73 | border-style: solid;
74 | }
75 |
76 | .k-drop-hint {
77 | border-top-width: 1px;
78 | border-top-style: solid;
79 | }
80 |
81 | .k-ghost {
82 | opacity: .5;
83 | }
84 | }
85 |
86 | .k-item {
87 | cursor: default;
88 | }
89 |
90 | .k-item.k-drag-clue {
91 | @include border-radius( 0 );
92 | padding: $list-item-padding-y $list-item-padding-x;
93 | border-width: 0;
94 | font-size: $font-size;
95 | line-height: $line-height-em;
96 | }
97 | }
98 |
--------------------------------------------------------------------------------
/scss/listbox/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports('listbox/theme') {
2 | .k-listbox {
3 | .k-list-scroller {
4 | background-color: $widget-bg;
5 | border-color: $widget-border;
6 | color: $widget-text;
7 | background-clip: padding-box;
8 |
9 | .k-ie11 &,
10 | .k-edge12 &,
11 | .k-edge13 & {
12 | background-clip: border-box;
13 | }
14 | }
15 | .k-drop-hint {
16 | border-top-color: $accent;
17 | }
18 | }
19 |
20 | .k-item.k-drag-clue {
21 | background-color: $list-item-selected-bg;
22 | color: $list-item-selected-text;
23 | }
24 | }
25 |
--------------------------------------------------------------------------------
/scss/listview.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 | @import "listview/layout";
5 | @import "listview/theme";
6 |
--------------------------------------------------------------------------------
/scss/listview/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports( 'listview/layout' ) {
2 |
3 | }
4 |
--------------------------------------------------------------------------------
/scss/listview/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports( 'listview/theme' ) {
2 | .k-listview > .k-state-focused {
3 | box-shadow: $focused-shadow;
4 | }
5 | }
6 |
--------------------------------------------------------------------------------
/scss/map.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "map/images/markers";
7 |
8 |
9 | // Component
10 | @import "map/layout";
11 | @import "map/theme";
12 |
--------------------------------------------------------------------------------
/scss/map/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("map/layout") {
2 |
3 | $map-navigator-padding: 2px !default;
4 |
5 | // Layout
6 | .k-map {
7 | height: 600px;
8 |
9 | // Scroll wrap
10 | .km-scroll-wrapper {
11 | width: 100%;
12 | height: 100%;
13 | user-select: none;
14 | position: absolute;
15 | }
16 | .k-touch-scrollbar { display: none; }
17 |
18 | // Layers
19 | .k-layer {
20 | position: absolute;
21 | left: 0;
22 | top: 0;
23 | }
24 |
25 | // Marker
26 | .k-marker {
27 | margin: -32px 0 0 -16px;
28 | font-size: $font-size * 2;
29 | cursor: pointer;
30 | position: absolute;
31 | }
32 |
33 |
34 | // TODO: see attribuion
35 | // Attribution
36 | .k-attribution {
37 | padding: $padding-y-sm $padding-x-sm;
38 | font-size: $font-size-sm * .75;
39 | background-color: rgba( $panel-bg, .8);
40 | z-index: 1000;
41 | }
42 |
43 | .km-scroll-container {
44 | height: 100%;
45 | }
46 | }
47 |
48 |
49 | // Controls
50 | .k-map-controls {
51 | position: absolute;
52 | display: flex;
53 | align-items: center;
54 | }
55 | .k-pos-top { top: 0; }
56 | .k-pos-bottom { bottom: 0; }
57 | .k-pos-left { left: 0; }
58 | .k-pos-right { right: 0; }
59 |
60 |
61 | // Navigator
62 | .k-navigator {
63 | margin: $spacer-x;
64 | width: add-two( (3 * $icon-size), $map-navigator-padding );
65 | height: add-two( (3 * $icon-size), $map-navigator-padding );
66 | box-sizing: content-box;
67 | border-radius: 50%;
68 | position: relative;
69 |
70 | .k-pdf-export & { display: none; }
71 |
72 |
73 | // Buttons
74 | .k-button {
75 | margin: 0;
76 | padding: 0;
77 | border-radius: 100%;
78 | line-height: 1;
79 | position: absolute;
80 |
81 | &:not(:hover) {
82 | border-color: transparent;
83 | background: none;
84 | }
85 | }
86 | .k-navigator-up {
87 | transform: translateX(-50%);
88 | top: $map-navigator-padding;
89 | left: 50%;
90 | }
91 | .k-navigator-right {
92 | transform: translateY(-50%);
93 | right: $map-navigator-padding;
94 | top: 50%;
95 | }
96 | .k-navigator-down {
97 | transform: translateX(-50%);
98 | bottom: $map-navigator-padding;
99 | left: 50%;
100 | }
101 | .k-navigator-left {
102 | transform: translateY(-50%);
103 | left: $map-navigator-padding;
104 | top: 50%;
105 | }
106 | }
107 |
108 |
109 | // Zoom control
110 | .k-zoom-control {
111 | margin: $spacer-x;
112 | border: 0;
113 | background: none;
114 | display: flex;
115 |
116 | .k-pdf-export & { display: none; }
117 |
118 |
119 | // Buttons
120 | .k-button {
121 | padding: $button-padding-y;
122 | }
123 | }
124 | .k-buttons-horizontal {}
125 | .k-buttons-vertical {
126 | flex-direction: vertical;
127 | }
128 |
129 | }
130 |
--------------------------------------------------------------------------------
/scss/map/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("map/theme") {
2 | .k-map {
3 | .k-marker {
4 | color: $accent;
5 | }
6 | }
7 | }
8 |
--------------------------------------------------------------------------------
/scss/map/images/markers.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/telerik/kendo-theme-default/77efe2aa5a7bb7fb3d4a30b4cac6b87a4b12c54d/scss/map/images/markers.png
--------------------------------------------------------------------------------
/scss/map/images/markers.scss:
--------------------------------------------------------------------------------
1 | @import '../../mixins';
2 |
3 | @include exports('markers.png') {
4 | @include register-data-uri('markers.png', '')
5 | }
6 |
--------------------------------------------------------------------------------
/scss/maskedtextbox.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "maskedtextbox/layout";
11 | @import "maskedtextbox/theme";
12 |
--------------------------------------------------------------------------------
/scss/maskedtextbox/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("maskedtextbox/layout") {
2 | .k-maskedtextbox {
3 | .k-i-warning {
4 | display: none;
5 | position: absolute;
6 | top: 50%;
7 | transform: translateY(-50%);
8 | right: $padding-x;
9 | }
10 |
11 | .k-rtl &,
12 | &[dir='rtl'] {
13 | .k-i-warning {
14 | right: auto;
15 | left: $padding-x;
16 | }
17 | }
18 |
19 | &.k-state-invalid {
20 | .k-i-warning {
21 | display: inline-block;
22 | }
23 | }
24 | }
25 | }
26 |
--------------------------------------------------------------------------------
/scss/maskedtextbox/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("maskedtextbox/theme") {
2 | .k-maskedtextbox {
3 | .k-i-warning {
4 | color: $error;
5 | }
6 |
7 | &.k-state-invalid {
8 | .k-textbox {
9 | color: $error;
10 | border-color: $error;
11 | }
12 | }
13 | }
14 | }
15 |
--------------------------------------------------------------------------------
/scss/mediaplayer.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "mediaplayer/layout";
11 | @import "mediaplayer/theme";
12 |
--------------------------------------------------------------------------------
/scss/mediaplayer/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("mediaplayer/layout") {
2 |
3 | // Base
4 | .k-mediaplayer {
5 | position: relative;
6 |
7 | > iframe {
8 | width: 100%;
9 | height: 100%;
10 | border: 0;
11 | vertical-align: top;
12 | }
13 | }
14 |
15 |
16 | // Title bar
17 | .k-mediaplayer-titlebar {
18 | padding: $header-padding-y $header-padding-x;
19 | position: absolute;
20 | z-index: 2;
21 | top: 0;
22 | left: 0;
23 | right: 0;
24 | }
25 |
26 |
27 | // Toolbar
28 | .k-mediaplayer-toolbar-wrap {
29 | position: absolute;
30 | z-index: 2;
31 | bottom: 0;
32 | left: 0;
33 | right: 0;
34 | }
35 | .k-mediaplayer-toolbar {
36 | padding: $toolbar-padding-y $toolbar-padding-x;
37 | border-width: 0;
38 | // sass-lint:disable no-important
39 | width: 100% !important;
40 | // sass-lint:enable no-important
41 |
42 |
43 | > * {
44 | align-items: center;
45 | align-content: center;
46 | }
47 |
48 | .k-toolbar-spacer {
49 | margin-top: 0;
50 | margin-bottom: 0;
51 | border-width: 0;
52 | flex: 1;
53 | }
54 |
55 | .k-align-right {
56 | & > * + * { margin-left: $padding-x; }
57 | }
58 |
59 | }
60 | .k-mediaplayer-time-wrap {
61 | flex: 1;
62 | }
63 | .k-mediaplayer-volume-wrap {
64 | align-items: center;
65 | }
66 |
67 |
68 | // Seekbar
69 | .k-slider.k-mediaplayer-seekbar {
70 | width: 100%;
71 | position: absolute;
72 | z-index: 3;
73 | top: -17px;
74 | left: 0;
75 | }
76 | .k-mediaplayer-seekbar .k-slider-track {
77 | // sass-lint:disable no-important
78 | width: 100% !important;
79 | // sass-lint:enable no-important
80 | border-radius: 0;
81 | }
82 |
83 | .k-mediaplayer-fullscreen {
84 | z-index: 10000;
85 | position: fixed;
86 | top: 0;
87 | left: 0;
88 | // sass-lint:disable no-important
89 | width: 100% !important;
90 | height: 100% !important;
91 | // sass-lint:enable no-important
92 | }
93 |
94 | }
95 |
--------------------------------------------------------------------------------
/scss/mediaplayer/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("mediaplayer/theme") {
2 |
3 | // Theme
4 | .k-mediaplayer {
5 | background-clip: padding-box;
6 |
7 | .k-ie11 &,
8 | .k-edge12 &,
9 | .k-edge13 & {
10 | background-clip: border-box;
11 | }
12 | }
13 |
14 |
15 | // Title bar
16 | // TODO: should title bar always appear the same?
17 | .k-mediaplayer-titlebar {
18 | color: $panel-bg;
19 | background-image: linear-gradient( rgba( $panel-text, .7 ), rgba( $panel-text, 0 ) );
20 | // text-shadow: 0 0 1px $panel-text;
21 | }
22 |
23 |
24 | .k-mediaplayer-toolbar {
25 | background-color: rgba($toolbar-bg, .85);
26 | }
27 |
28 | }
29 |
--------------------------------------------------------------------------------
/scss/menu.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "menu/layout";
11 | @import "menu/theme";
12 |
--------------------------------------------------------------------------------
/scss/menu/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("menu/theme") {
2 |
3 | // Theme
4 | .k-menu {
5 | border-width: 0;
6 | color: inherit;
7 | background: none;
8 | background-clip: padding-box;
9 |
10 | .k-ie11 &,
11 | .k-edge12 &,
12 | .k-edge13 & {
13 | background-clip: border-box;
14 | }
15 |
16 | .k-item {
17 | color: $link-text;
18 |
19 | &.k-state-hover {
20 | color: $link-hover-text;
21 | }
22 |
23 | &.k-state-active {
24 | color: inherit;
25 | }
26 |
27 | &.k-state-selected {
28 | color: $list-item-selected-text;
29 | }
30 | }
31 | }
32 | .k-menu.k-context-menu {
33 | @include appearance( popup );
34 | }
35 |
36 | .k-menu-group,
37 | .k-menu.k-context-menu {
38 | .k-item {
39 | color: inherit;
40 |
41 | &.k-state-hover {
42 | @include appearance( hovered-list-item );
43 | }
44 |
45 | &.k-state-active,
46 | &.k-state-selected {
47 | @include appearance( selected-list-item );
48 | }
49 | }
50 | }
51 |
52 |
53 | // Scrolling
54 | .k-menu-scroll-button {
55 | border-color: $widget-border;
56 | color: $link-text;
57 | background: $bg-color;
58 |
59 | &:hover {
60 | border-color: $widget-border;
61 | color: $link-hover-text;
62 | background: $bg-color;
63 | }
64 |
65 | &.k-scroll-left {
66 | width: 16px;
67 | border-right-width: 1px;
68 | }
69 | &.k-scroll-right {
70 | width: 16px;
71 | border-left-width: 1px;
72 | }
73 | &.k-scroll-up {
74 | height: 16px;
75 | border-bottom-width: 1px;
76 | }
77 | &.k-scroll-down {
78 | height: 16px;
79 | border-top-width: 1px;
80 | }
81 | }
82 | }
83 |
--------------------------------------------------------------------------------
/scss/mixins/_appearance.scss:
--------------------------------------------------------------------------------
1 | @mixin appearance( $what ) {
2 |
3 | // Widget
4 | @if ( $what == widget ) {
5 | @include appearance_widget;
6 | }
7 |
8 | // Panels
9 | @if ( $what == panel ) {
10 | @include appearance_panel;
11 | }
12 | @if ( $what == popup ) {
13 | @include appearance_popup;
14 | }
15 |
16 |
17 | // Header
18 | @if ( $what == header ) {
19 | @include appearance_header;
20 | }
21 | @if ( $what == hovered-header ) {
22 | @include appearance_hovered-header;
23 | }
24 | @if ( $what == selected-header ) {
25 | @include appearance_selected-header;
26 | }
27 |
28 |
29 | // Button
30 | @if ( $what == button ) {
31 | @include appearance_button;
32 | }
33 | @if ( $what == hovered-button ) {
34 | @include appearance_hovered-button;
35 | }
36 | @if ( $what == pressed-button ) {
37 | @include appearance_pressed-button;
38 | }
39 | @if ( $what == focused-button ) {
40 | @include appearance_focused-button;
41 | }
42 |
43 |
44 | // Primary button
45 | @if ( $what == primary-button ) {
46 | @include appearance_primary-button;
47 | }
48 | @if ( $what == hovered-primary-button ) {
49 | @include appearance_hovered-primary-button;
50 | }
51 | @if ( $what == pressed-primary-button ) {
52 | @include appearance_pressed-primary-button;
53 | }
54 |
55 |
56 | // Toolbar
57 | @if ( $what == toolbar ) {
58 | @include appearance_toolbar;
59 | }
60 |
61 |
62 | // Input
63 | @if ( $what == input ) {
64 | @include appearance_input;
65 | }
66 | @if ( $what == hovered-input ) {
67 | @include appearance_hovered-input;
68 | }
69 | @if ( $what == focused-input ) {
70 | @include appearance_focused-input;
71 | }
72 |
73 |
74 | // Node
75 | @if ( $what == node ) {
76 | @include appearance_node;
77 | }
78 | @if ( $what == hovered-node ) {
79 | @include appearance_hovered-node;
80 | }
81 | @if ( $what == selected-node ) {
82 | @include appearance_selected-node;
83 | }
84 |
85 |
86 | // List item
87 | @if ( $what == list-item ) {
88 | @include appearance_list-item;
89 | }
90 | @if ( $what == hovered-list-item ) {
91 | @include appearance_hovered-list-item;
92 | }
93 | @if ( $what == selected-list-item ) {
94 | @include appearance_selected-list-item;
95 | }
96 | @if ( $what == focused-list-item ) {
97 | @include appearance_focused-list-item;
98 | }
99 |
100 | }
101 |
--------------------------------------------------------------------------------
/scss/mixins/_border-radius.scss:
--------------------------------------------------------------------------------
1 | // Border radius
2 | @mixin border-radius( $radius: $border-radius ) {
3 | @if $enable-rounded {
4 | border-radius: $radius;
5 | }
6 | }
7 |
8 | @mixin border-top-radius( $radius: $border-radius ) {
9 | @if $enable-rounded {
10 | border-top-left-radius: $radius;
11 | border-top-right-radius: $radius;
12 | }
13 | }
14 |
15 | @mixin border-right-radius( $radius: $border-radius ) {
16 | @if $enable-rounded {
17 | border-top-right-radius: $radius;
18 | border-bottom-right-radius: $radius;
19 | }
20 | }
21 |
22 | @mixin border-bottom-radius( $radius: $border-radius ) {
23 | @if $enable-rounded {
24 | border-bottom-right-radius: $radius;
25 | border-bottom-left-radius: $radius;
26 | }
27 | }
28 |
29 | @mixin border-left-radius( $radius: $border-radius ) {
30 | @if $enable-rounded {
31 | border-top-left-radius: $radius;
32 | border-bottom-left-radius: $radius;
33 | }
34 | }
35 |
36 | @mixin border-top-radius-only( $radius: $border-radius ) {
37 | @if $enable-rounded {
38 | border-radius: $radius $radius 0 0;
39 | }
40 | }
41 |
42 | @mixin border-right-radius-only( $radius: $border-radius ) {
43 | @if $enable-rounded {
44 | border-radius: 0 $radius $radius 0;
45 | }
46 | }
47 |
48 | @mixin border-bottom-radius-only( $radius: $border-radius ) {
49 | @if $enable-rounded {
50 | border-radius: 0 0 $radius $radius;
51 | }
52 | }
53 |
54 | @mixin border-left-radius-only( $radius: $border-radius ) {
55 | @if $enable-rounded {
56 | border-radius: $radius 0 0 $radius;
57 | }
58 | }
59 |
--------------------------------------------------------------------------------
/scss/mixins/_box-shadow.scss:
--------------------------------------------------------------------------------
1 | @mixin box-shadow( $shadow... ) {
2 | @if $enable-shadows {
3 | box-shadow: $shadow;
4 | }
5 | }
6 |
--------------------------------------------------------------------------------
/scss/mixins/_button-size.scss:
--------------------------------------------------------------------------------
1 | @function button-inner-size( $multiplier: 1 ) {
2 | @return add-two( 2 * $button-padding-y, $form-line-height-em, $multiplier );
3 | }
4 |
5 |
6 | @function button-size( $multiplier: 1 ) {
7 | @return add-three( 2 * $button-border-width, 2 * $button-padding-y, $form-line-height-em, $multiplier );
8 | }
9 |
--------------------------------------------------------------------------------
/scss/mixins/_button.scss:
--------------------------------------------------------------------------------
1 | $_button-imported: false !default;
2 |
3 | @if ( $_button-imported == false ) {
4 |
5 | %appearance_button {
6 | color: $button-text;
7 | background-color: $button-bg;
8 | border-color: $button-border;
9 | @include linear-gradient( $button-gradient );
10 | }
11 | %appearance_hovered-button {
12 | color: $button-hovered-text;
13 | background-color: $button-hovered-bg;
14 | border-color: $button-hovered-border;
15 | @include linear-gradient( $button-hovered-gradient );
16 | }
17 | %appearance_pressed-button {
18 | color: $button-pressed-text;
19 | background-color: $button-pressed-bg;
20 | border-color: $button-pressed-border;
21 | @include linear-gradient( $button-pressed-gradient );
22 | @include box-shadow( $button-pressed-shadow );
23 | }
24 | %appearance_focused-button {
25 | @include box-shadow( $button-focused-shadow );
26 | }
27 |
28 | %appearance_primary-button {
29 | color: $primary-button-text;
30 | background-color: $primary-button-bg;
31 | border-color: $primary-button-border;
32 | @include linear-gradient( $primary-button-gradient );
33 | }
34 | %appearance_hovered-primary-button {
35 | color: $primary-button-hovered-text;
36 | background-color: $primary-button-hovered-bg;
37 | border-color: $primary-button-hovered-border;
38 | @include linear-gradient( $primary-button-hovered-gradient );
39 | }
40 | %appearance_pressed-primary-button {
41 | color: $primary-button-pressed-text;
42 | background-color: $primary-button-pressed-bg;
43 | border-color: $primary-button-pressed-border;
44 | @include linear-gradient( $primary-button-pressed-gradient );
45 | }
46 |
47 | %appearance_toolbar {
48 | color: $toolbar-text;
49 | background-color: $toolbar-bg;
50 | border-color: $toolbar-border;
51 | @include linear-gradient( $toolbar-gradient );
52 | }
53 |
54 | $_button-imported: true;
55 |
56 | }
57 |
58 |
59 | @mixin appearance_button { @extend %appearance_button };
60 | @mixin appearance_hovered-button { @extend %appearance_hovered-button };
61 | @mixin appearance_pressed-button { @extend %appearance_pressed-button };
62 | @mixin appearance_focused-button { @extend %appearance_focused-button };
63 |
64 | @mixin appearance_primary-button { @extend %appearance_primary-button };
65 | @mixin appearance_hovered-primary-button { @extend %appearance_hovered-primary-button };
66 | @mixin appearance_pressed-primary-button { @extend %appearance_pressed-primary-button };
67 |
68 | @mixin appearance_toolbar { @extend %appearance_toolbar };
69 |
--------------------------------------------------------------------------------
/scss/mixins/_colors.scss:
--------------------------------------------------------------------------------
1 | @import "vendor/color-helpers/math";
2 | @import "vendor/color-helpers/contrast";
3 |
4 | @function color-level($color, $level: 0) {
5 |
6 | @if ($level == 0) {
7 | @return $color;
8 | }
9 |
10 | $base: if($level > 0, #ffffff, #000000);
11 | $level: abs($level);
12 |
13 | @if ( unit($level) == "%" ) {
14 | @return mix( $base, $color, $level );
15 | }
16 |
17 | @return mix($base, $color, $level * $color-level-step);
18 | }
19 |
20 | @function tint( $color, $level: 1 ) {
21 | @return color-level( $color, $level );
22 | }
23 |
24 | @function shade( $color, $level: 1 ) {
25 | @return color-level( $color, - $level );
26 | }
27 |
28 |
29 | @function try-darken( $color, $amount, $threshold: black ) {
30 | $amount: if(unitless($amount), $amount, ($amount / 1%));
31 |
32 | $result: darken( $color, $amount );
33 | $alt-result: darken( $color, ($amount - 1) );
34 |
35 | @if ($result == $threshold) and ($alt-result == $threshold) {
36 | @return lighten( $color, $amount );
37 | }
38 | @return $result;
39 | }
40 |
41 | @function try-lighten( $color, $amount, $threshold: white ) {
42 | $amount: if(unitless($amount), $amount, ($amount / 1%));
43 |
44 | $result: lighten( $color, $amount );
45 | $alt-result: lighten( $color, ($amount - 1) );
46 |
47 | @if ($result == $threshold) and ($alt-result == $threshold) {
48 | @return darken( $color, $amount );
49 | }
50 | @return $result;
51 | }
52 |
53 |
54 | @function yiq($color) {
55 | $r: red($color);
56 | $g: green($color);
57 | $b: blue($color);
58 |
59 | $yiq: (($r * 299) + ($g * 587) + ($b * 114)) / 1000;
60 |
61 | @return $yiq;
62 | }
63 | @function contrast-yiq($color, $dark: #000000, $light: #ffffff) {
64 | $yiq: yiq($color);
65 | $out: if($yiq >= 150, $dark, $light);
66 | // @debug yiq;
67 | @return $out;
68 | }
69 | @function contrast-wcag($color, $dark: #000000, $light: #ffffff) {
70 | $luma: ch-color-luminance($color);
71 | $out: if($luma < .5, $light, $dark);
72 | // @debug $luma;
73 | @return $out;
74 | }
75 |
--------------------------------------------------------------------------------
/scss/mixins/_decoration.scss:
--------------------------------------------------------------------------------
1 | // Fill and outline
2 | @mixin fill( $color: null, $bg: null, $border: null, $gradient: null ) {
3 | border-color: $border;
4 | color: $color;
5 | background-color: $bg;
6 | @include linear-gradient( $gradient );
7 | }
8 | @mixin outline( $color: null ) {
9 | border-color: $color;
10 | color: $color;
11 | background-color: transparent;
12 | background-image: none;
13 | }
14 |
--------------------------------------------------------------------------------
/scss/mixins/_disabled.scss:
--------------------------------------------------------------------------------
1 | // Disabled
2 | @mixin disabled {
3 | outline: none;
4 | cursor: default;
5 | opacity: $disabled-opacity;
6 | filter: $disabled-filter;
7 | pointer-events: none;
8 | box-shadow: none;
9 | }
10 | @include exports("placeholder/disabled") {
11 | %disabled {
12 | @if ( mixin-exists( disabled ) ) {
13 | @include disabled;
14 | }
15 | }
16 | }
17 |
--------------------------------------------------------------------------------
/scss/mixins/_gradients.scss:
--------------------------------------------------------------------------------
1 | @mixin linear-gradient( $gradient: null ) {
2 | @if $gradient and $enable-gradients {
3 | @if $gradient == none {
4 | background-image: none
5 | }
6 | @else {
7 | background-image: linear-gradient( $gradient );
8 | }
9 | }
10 | }
11 |
12 | @mixin striped-gradient( $color: rgba(255,255,255,.15), $angle: 45deg) {
13 | background-image: linear-gradient($angle, $color 25%, transparent 25%, transparent 50%, $color 50%, $color 75%, transparent 75%, transparent);
14 | }
15 |
--------------------------------------------------------------------------------
/scss/mixins/_hide-scrollbar.scss:
--------------------------------------------------------------------------------
1 | // Infinite calendar and timepicker
2 | @mixin hide-scrollbar($dir: 'right', $max-scrollbar: 100px) {
3 | // anything larger than the scrollbar width will do
4 | $scrollbar-size: 17px;
5 | $margin: -$max-scrollbar - $scrollbar-size;
6 |
7 | padding-right: $max-scrollbar;
8 | padding-left: $max-scrollbar;
9 | margin-left: -$max-scrollbar;
10 | margin-right: -$max-scrollbar;
11 |
12 | @if ($dir == 'right') {
13 | margin-right: $margin;
14 | } @else {
15 | margin-left: $margin;
16 | }
17 | }
18 |
--------------------------------------------------------------------------------
/scss/mixins/_input.scss:
--------------------------------------------------------------------------------
1 | $_input-imported: false !default;
2 |
3 | @if ( $_input-imported == false ) {
4 |
5 | %appearance_input {
6 | color: $input-text;
7 | background-color: $input-bg;
8 | border-color: $input-border;
9 | }
10 | %appearance_hovered-input {
11 | color: $input-hovered-text;
12 | background-color: $input-hovered-bg;
13 | border-color: $input-hovered-border;
14 | }
15 | %appearance_focused-input {
16 | color: $input-focused-text;
17 | background-color: $input-focused-bg;
18 | border-color: $input-focused-border;
19 | box-shadow: $input-focused-shadow;
20 | }
21 |
22 | $_input-imported: true;
23 |
24 | }
25 |
26 |
27 | @mixin appearance_input { @extend %appearance_input; }
28 | @mixin appearance_hovered-input { @extend %appearance_hovered-input; }
29 | @mixin appearance_focused-input { @extend %appearance_focused-input; }
30 |
--------------------------------------------------------------------------------
/scss/mixins/_node.scss:
--------------------------------------------------------------------------------
1 | $_node-imported: false !default;
2 |
3 | @if ( $_node-imported == false ) {
4 |
5 | %appearance_node {
6 | color: $node-text;
7 | background-color: $node-bg;
8 | border-color: $node-border;
9 | @include linear-gradient( $node-gradient );
10 | }
11 | %appearance_hovered-node {
12 | color: $node-hovered-text;
13 | background-color: $node-hovered-bg;
14 | border-color: $node-hovered-border;
15 | @include linear-gradient( $node-hovered-gradient );
16 | }
17 | %appearance_selected-node {
18 | color: $node-selected-text;
19 | background-color: $node-selected-bg;
20 | border-color: $node-selected-border;
21 | @include linear-gradient( $node-selected-gradient );
22 | }
23 |
24 | %appearance_list-item {
25 | color: $list-item-text;
26 | background-color: $list-item-bg;
27 | }
28 | %appearance_focused-list-item {
29 | box-shadow: $list-item-focused-shadow;
30 | }
31 | %appearance_hovered-list-item {
32 | color: $list-item-hovered-text;
33 | background-color: $list-item-hovered-bg;
34 | }
35 | %appearance_selected-list-item {
36 | color: $list-item-selected-text;
37 | background-color: $list-item-selected-bg;
38 | }
39 |
40 | $_node-imported: true;
41 |
42 | }
43 |
44 |
45 | @mixin appearance_node { @extend %appearance_node };
46 | @mixin appearance_hovered-node { @extend %appearance_hovered-node };
47 | @mixin appearance_selected-node { @extend %appearance_selected-node };
48 |
49 | @mixin appearance_list-item { @extend %appearance_list-item };
50 | @mixin appearance_hovered-list-item { @extend %appearance_hovered-list-item };
51 | @mixin appearance_focused-list-item { @extend %appearance_focused-list-item };
52 | @mixin appearance_selected-list-item { @extend %appearance_selected-list-item };
53 |
--------------------------------------------------------------------------------
/scss/mixins/_widget.scss:
--------------------------------------------------------------------------------
1 | $_widget-imported: false !default;
2 |
3 | @if ( $_widget-imported == false ) {
4 |
5 | %appearance_widget {
6 | color: $widget-text;
7 | background-color: $widget-bg;
8 | border-color: $widget-border;
9 | }
10 |
11 | %appearance_panel {
12 | color: $panel-text;
13 | background-color: $panel-bg;
14 | border-color: $panel-border;
15 | }
16 | %appearance_popup {
17 | color: $popup-text;
18 | background-color: $popup-bg;
19 | border-color: $popup-border;
20 | }
21 |
22 | %appearance_header {
23 | color: $header-text;
24 | background-color: $header-bg;
25 | border-color: $header-border;
26 | @include linear-gradient( $header-gradient );
27 | }
28 | %appearance_hovered-header {
29 | color: $header-hovered-text;
30 | background-color: $header-hovered-bg;
31 | border-color: $header-hovered-border;
32 | @include linear-gradient( $header-hovered-gradient );
33 | }
34 | %appearance_selected-header {
35 | color: $header-selected-text;
36 | background-color: $header-selected-bg;
37 | border-color: $header-selected-border;
38 | @include linear-gradient( $header-selected-gradient );
39 | }
40 |
41 | $_widget-imported: true;
42 |
43 | }
44 |
45 | @mixin appearance_widget { @extend %appearance_widget; }
46 |
47 | @mixin appearance_panel { @extend %appearance_panel; }
48 | @mixin appearance_popup { @extend %appearance_popup; }
49 |
50 | @mixin appearance_header { @extend %appearance_header };
51 | @mixin appearance_hovered-header { @extend %appearance_hovered-header };
52 | @mixin appearance_selected-header { @extend %appearance_selected-header };
53 |
--------------------------------------------------------------------------------
/scss/mixins/core/_data-uri.scss:
--------------------------------------------------------------------------------
1 | /// A list of files converted to data URIs
2 | /// @access private
3 | $data-uris: () !default;
4 |
5 | /// Saves a data URI that can be used from the $data-uris map instead of a file reference.
6 | /// @access private
7 | /// @param {String} $name - The name of the resource.
8 | /// @param {String} $content - The data URI of the resource.
9 | /// @require $data-uris
10 | @mixin register-data-uri($name, $content) {
11 | @if (map-has-key($data-uris, $name)) {
12 | @warn "Attempt to redefine data URI of file `#{$name}`.";
13 | }
14 |
15 | $data-uris: map-merge($data-uris, ($name: $content)) !global;
16 | }
17 |
--------------------------------------------------------------------------------
/scss/mixins/core/_import-once.scss:
--------------------------------------------------------------------------------
1 | /// A list of exported modules.
2 | /// @access private
3 | $imported-modules: () !default;
4 |
5 | /// Outputs a module once, no matter how many times it is included.
6 | /// @access public
7 | /// @param {String} $name - The name of the exported module.
8 | /// @require $imported-modules
9 | @mixin exports($name) {
10 | @if (index($imported-modules, $name) == null) {
11 | $imported-modules: append($imported-modules, $name) !global;
12 | @content;
13 | }
14 | }
15 |
--------------------------------------------------------------------------------
/scss/mixins/core/_math.scss:
--------------------------------------------------------------------------------
1 | // Add two
2 | @function add-two( $one, $two, $multiplier: 1 ) {
3 | $_unit-1: unit($one);
4 | $_unit-2: unit($two);
5 |
6 | $_one: $multiplier * $one;
7 | $_two: $multiplier * $two;
8 |
9 | // if either is zero
10 | @if $_one == 0 {
11 | @return $_two;
12 | }
13 |
14 | @if $_two == 0 {
15 | @return $_one;
16 | }
17 |
18 | // if all units are same type
19 | @if $_unit-1 == $_unit-2 {
20 | @return $_one + $_two;
21 | }
22 |
23 | // Fall back to calc
24 | @return calc( #{$_one} + #{$_two} );
25 | }
26 |
27 |
28 | // Add three
29 | @function add-three( $one, $two, $three, $multiplier: 1 ) {
30 | $_unit-1: unit($one);
31 | $_unit-2: unit($two);
32 | $_unit-3: unit($three);
33 |
34 | $_one: $multiplier * $one;
35 | $_two: $multiplier * $two;
36 | $_three: $multiplier * $three;
37 |
38 | // pass to add-two if any component is zero
39 | @if $_one == 0 {
40 | @return add-two($two, $three, $multiplier);
41 | }
42 |
43 | @if $_two == 0 {
44 | @return add-two($one, $three, $multiplier);
45 | }
46 |
47 | @if $_three == 0 {
48 | @return add-two($one, $two, $multiplier);
49 | }
50 |
51 |
52 | // if all units are same type
53 | @if $_unit-1 == $_unit-2 == $_unit-3 {
54 | @return $_one + $_two + $_three;
55 | }
56 |
57 | // if $_unit-1 and $_unit-2 are same type
58 | @if $_unit-1 == $_unit-2 {
59 | @return calc( #{$_one + $_two} + #{$_three} );
60 | }
61 |
62 | // if $_unit-1 and $_unit-3 are same type
63 | @if $_unit-1 == $_unit-3 {
64 | @return calc( #{$_one + $_three} + #{$_two} );
65 | }
66 |
67 | // if $_unit-2 and $_unit-3 are same type
68 | @if $_unit-2 == $_unit-3 {
69 | @return calc( #{$_one} + #{$_two + $_three} );
70 | }
71 |
72 | // Fall back to calc
73 | @return calc( #{$_one} + #{$_two} + #{$_three} );
74 | }
75 |
--------------------------------------------------------------------------------
/scss/mixins/core/_placeholder-selectors.scss:
--------------------------------------------------------------------------------
1 | @include exports( "placeholder-selectors" ) {
2 |
3 | // Box sizing `border-box`
4 | %border-box {
5 | box-sizing: border-box;
6 | }
7 |
8 | // Box sizing `content-box`
9 | %content-box {
10 | box-sizing: content-box;
11 | }
12 |
13 | // Display `none`
14 | %display-none {
15 | display: none;
16 | }
17 |
18 | // Display `block`
19 | %display-block {
20 | display: block;
21 | }
22 |
23 | // Display `inline-block`
24 | %display-inline-block {
25 | display: inline-block;
26 | }
27 |
28 | // Display `inline`
29 | %display-inline {
30 | display: inline;
31 | }
32 |
33 | // Display `flex`
34 | %display-flex {
35 | display: flex;
36 | }
37 |
38 | // Display `inline-flex`
39 | %display-flex {
40 | display: inline-flex;
41 | }
42 |
43 | // Position `static`
44 | %position-static {
45 | position: static;
46 | }
47 |
48 | // Position `relative`
49 | %position-relative {
50 | position: relative;
51 | }
52 |
53 | // Position `absolute`
54 | %position-absolute {
55 | position: absolute;
56 | }
57 |
58 | // Position `fixed`
59 | %position-fixed {
60 | position: fixed;
61 | }
62 |
63 | // Overflow `hidden`
64 | %overflow-hidden {
65 | overflow: hidden;
66 | }
67 |
68 | // Overflow `auto`
69 | %overflow-auto {
70 | overflow: auto;
71 | }
72 |
73 | // Overflow `scroll`
74 | %overflow-scroll {
75 | overflow: scroll;
76 | }
77 |
78 | // Overflow X `auto`
79 | %overflow-x-auto {
80 | @extend %overflow-hidden;
81 | overflow-x: auto;
82 | }
83 |
84 | // Overflow Y `auto`
85 | %overflow-y-auto {
86 | @extend %overflow-hidden;
87 | overflow-y: auto;
88 | }
89 |
90 | // Text align `left`
91 | %text-align-left,
92 | %text-left {
93 | text-align: left;
94 | }
95 |
96 | // Text align `center`
97 | %text-align-center,
98 | %text-center {
99 | text-align: center;
100 | }
101 |
102 | // Text align `right`
103 | %text-align-right,
104 | %text-right {
105 | text-align: right;
106 | }
107 |
108 | // Text align `justify`
109 | %text-align-justify,
110 | %text-justify {
111 | text-align: justify;
112 | }
113 |
114 | // Float `left`
115 | %float-left {
116 | float: left;
117 | }
118 |
119 | // Float `right`
120 | %float-right {
121 | float: right;
122 | }
123 |
124 | // Vertical align `middle`
125 | %vertical-align-middle {
126 | vertical-align: middle;
127 | }
128 |
129 | // Cursor `pointer`
130 | %cursor-pointer {
131 | cursor: pointer;
132 | }
133 |
134 | // Cursor `default`
135 | %cursor-default {
136 | cursor: default;
137 | }
138 |
139 | // Text Decoration
140 | %text-decoration-none {
141 | text-decoration: none;
142 | }
143 | %text-decoration-underline,
144 | %text-underline {
145 | text-decoration: underline;
146 | }
147 |
148 | // Font weight `normal`
149 | %font-weight-normal {
150 | font-weight: normal;
151 | }
152 |
153 | // Font weight `bold`
154 | %font-weight-bold {
155 | font-weight: bold;
156 | }
157 |
158 | // Text overflow
159 | %ellipsis {
160 | overflow: hidden;
161 | text-overflow: ellipsis;
162 | white-space: nowrap;
163 | word-wrap: break-word;
164 | }
165 |
166 | // Poiter events
167 | %pointer-events-none {
168 | pointer-events: none;
169 | }
170 | %pointer-events-all {
171 | pointer-events: all;
172 | }
173 |
174 | }
175 |
--------------------------------------------------------------------------------
/scss/mixins/vendor/color-helpers/_contrast.scss:
--------------------------------------------------------------------------------
1 | // From https://github.com/voxpelli/sass-color-helpers
2 |
3 |
4 | @function ch-color-luminance($color) {
5 | // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js
6 | // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef
7 | $rgba: red($color), green($color), blue($color);
8 | $rgba2: ();
9 |
10 | @for $i from 1 through 3 {
11 | $rgb: nth($rgba, $i);
12 | $rgb: $rgb / 255;
13 |
14 | $rgb: if($rgb < .03928, $rgb / 12.92, ch-pow(($rgb + .055) / 1.055, 2.4, 16));
15 |
16 | $rgba2: append($rgba2, $rgb);
17 | }
18 |
19 | @return .2126 * nth($rgba2, 1) + .7152 * nth($rgba2, 2) + 0.0722 * nth($rgba2, 3);
20 | }
21 |
22 | @function ch-color-contrast($color1, $color2) {
23 | // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js
24 | // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef
25 | $luminance1: ch-color-luminance($color1) + .05;
26 | $luminance2: ch-color-luminance($color2) + .05;
27 | $ratio: $luminance1 / $luminance2;
28 |
29 | @if $luminance2 > $luminance1 {
30 | $ratio: 1 / $ratio;
31 | }
32 |
33 | $ratio: round($ratio * 10) / 10;
34 |
35 | @return $ratio;
36 | }
37 |
38 | @function ch-best-color-contrast($base, $colors: (#fff, #000), $tolerance: 0) {
39 | $best: nth($colors, 1);
40 | $contrast: ch-color-contrast($base, $best);
41 |
42 | @for $i from 2 through length($colors) {
43 | $currentColor: nth($colors, $i);
44 | $currentContrast: ch-color-contrast($base, $currentColor);
45 | @if ($currentContrast - $contrast > $tolerance) {
46 | $best: $currentColor;
47 | $contrast: $currentContrast;
48 | }
49 | }
50 |
51 | @if ($contrast < 3) {
52 | @warn "Contrast ratio of #{$best} on #{$base} is pretty bad, just #{$contrast}";
53 | }
54 |
55 | @return $best;
56 | }
57 |
--------------------------------------------------------------------------------
/scss/mixins/vendor/color-helpers/_math.scss:
--------------------------------------------------------------------------------
1 | // From https://github.com/voxpelli/sass-color-helpers
2 |
3 |
4 | @function ch-max($v1, $v2) {
5 | @return if($v1 > $v2, $v1, $v2);
6 | }
7 |
8 | @function ch-min($v1, $v2) {
9 | @return if($v1 < $v2, $v1, $v2);
10 | }
11 |
12 | @function ch-gcd($a, $b) {
13 | // From: http://rosettacode.org/wiki/Greatest_common_divisor#JavaScript
14 | @if ($b != 0) {
15 | @return ch-gcd($b, $a % $b);
16 | } @else {
17 | @return abs($a);
18 | }
19 | }
20 |
21 | @function ch-pow($base, $exponent, $prec: 12) {
22 | // Handles decimal exponents by trying to convert them into a fraction and then use a nthRoot-algorithm for parts of the calculation
23 | @if (floor($exponent) != $exponent) {
24 | $prec2 : ch-pow(10, $prec);
25 | $exponent: round($exponent * $prec2);
26 | $denominator: ch-gcd($exponent, $prec2);
27 | @return ch-nth-root(ch-pow($base, $exponent / $denominator), $prec2 / $denominator, $prec);
28 | }
29 |
30 | $value: $base;
31 | @if $exponent > 1 {
32 | @for $i from 2 through $exponent {
33 | $value: $value * $base;
34 | }
35 | } @else if $exponent < 1 {
36 | @for $i from 0 through -$exponent {
37 | $value: $value / $base;
38 | }
39 | }
40 |
41 | @return $value;
42 | }
43 |
44 | @function ch-nth-root($num, $n: 2, $prec: 12) {
45 | // From: http://rosettacode.org/wiki/Nth_root#JavaScript
46 | $x: 1;
47 |
48 | @for $i from 0 through $prec {
49 | $x: 1 / $n * (($n - 1) * $x + ($num / ch-pow($x, $n - 1)));
50 | }
51 |
52 | @return $x;
53 | }
54 |
--------------------------------------------------------------------------------
/scss/multiselect.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "common/forms";
8 | @import "button";
9 |
10 |
11 | // Component
12 | @import "multiselect/layout";
13 | @import "multiselect/theme";
14 |
--------------------------------------------------------------------------------
/scss/multiselect/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("multiselect/layout") {
2 |
3 | // Base
4 | .k-multiselect {
5 | @include border-radius();
6 | width: 100%;
7 |
8 | .k-loading-hidden {
9 | visibility: hidden;
10 | }
11 |
12 | .k-clear-value {
13 | top: $input-padding-y;
14 | margin-top: 0;
15 | }
16 |
17 | &[dir='rtl'],
18 | .k-rtl & {
19 | li.k-button {
20 | float: right;
21 | }
22 |
23 | .k-multiselect-wrap {
24 | padding-left: ($padding-x * 3);
25 | padding-right: 0;
26 |
27 | .k-searchbar {
28 | float: right;
29 | }
30 |
31 | .k-button {
32 | width: auto;
33 | margin: $padding-y-sm $padding-y-sm 0 0;
34 |
35 | .k-select {
36 | margin-left: 0;
37 | margin-right: $padding-x;
38 | }
39 | }
40 |
41 | .k-i-loading {
42 | left: $padding-x;
43 | right: auto;
44 | }
45 | }
46 | }
47 | }
48 |
49 | .k-multiselect-wrap {
50 | min-height: calc( #{$input-inner-calc-size} );
51 | padding-right: ($padding-x * 3);
52 | cursor: text;
53 |
54 | // Token list
55 | ul {
56 | vertical-align: top;
57 | }
58 | li.k-button {
59 | float: left;
60 | }
61 |
62 |
63 | // Token
64 | .k-button {
65 | min-height: calc(#{$form-line-height}*1em + #{$button-padding-y-sm} + 2px);
66 | padding: ($button-padding-y-sm / 2) ($button-padding-x / 2);
67 | margin: $padding-y-sm 0 0 $padding-y-sm;
68 | cursor: default;
69 | display: inline-flex;
70 | flex-direction: row;
71 | align-items: center;
72 | line-height: inherit;
73 | white-space: normal;
74 |
75 | .k-select {
76 | display: flex;
77 | cursor: pointer;
78 | margin-left: $padding-x;
79 | }
80 |
81 | &:last-child {
82 | margin-bottom: $padding-y-sm;
83 | }
84 | }
85 |
86 | .k-searchbar {
87 | // search bar must be floated to align after any selected tags
88 | // (or align below them, if space is not available)
89 | float: left;
90 | width: auto;
91 | }
92 | }
93 | }
94 |
--------------------------------------------------------------------------------
/scss/multiselect/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("multiselect/theme") {
2 |
3 | // Appearance
4 | .k-multiselect {
5 | @include appearance( input );
6 | background-clip: padding-box;
7 |
8 | .k-ie11 &,
9 | .k-edge12 &,
10 | .k-edge13 & {
11 | background-clip: border-box;
12 | }
13 |
14 | li {
15 | background-clip: padding-box;
16 |
17 | .k-ie11 &,
18 | .k-edge12 &,
19 | .k-edge13 & {
20 | background-clip: border-box;
21 | }
22 |
23 | .k-icon {
24 | opacity: .6;
25 | cursor: pointer;
26 | }
27 |
28 | .k-icon:hover {
29 | opacity: 1;
30 | }
31 |
32 | &.k-button:active,
33 | &.k-button.k-state-active {
34 | @include appearance( pressed-button );
35 | }
36 |
37 | // Focused state
38 | &:focus,
39 | &.k-state-focused {
40 | .k-icon {
41 | opacity: 1;
42 | }
43 | }
44 | }
45 |
46 | &.k-state-focused {
47 | .k-multiselect-wrap {
48 | @include appearance( focused-input );
49 | }
50 | }
51 | &.k-disabled {
52 | .k-multiselect-wrap {
53 | @include appearance( disabled-input );
54 | }
55 | }
56 |
57 | .k-i-loading {
58 | background-color: $input-bg;
59 | }
60 | }
61 |
62 | .k-multiselect-wrap {
63 | @include appearance( input );
64 |
65 | > .k-readonly {
66 | opacity: .6;
67 | }
68 |
69 | &:hover {
70 | @include appearance( hovered-input );
71 | }
72 | }
73 |
74 | }
75 |
--------------------------------------------------------------------------------
/scss/no-flexbox.scss:
--------------------------------------------------------------------------------
1 | .k-no-flexbox {
2 | .k-calendar-infinite {
3 | height: 330px;
4 |
5 | .k-calendar-navigation,
6 | .k-calendar-monthview {
7 | height: 100%;
8 | float: left;
9 | }
10 |
11 | .k-calendar-header {
12 | display: block;
13 |
14 | .k-today {
15 | float: right;
16 | }
17 | }
18 | }
19 |
20 | .k-dateinput-wrap,
21 | .k-dropdown-wrap,
22 | .k-numeric-wrap,
23 | .k-picker-wrap {
24 | $k-select-width: 2em;
25 | display: block;
26 |
27 | .k-input {
28 | width: calc(100% - #{$k-select-width});
29 | }
30 | .k-input,
31 | .k-select {
32 | display: inline-block;
33 | vertical-align: middle;
34 | }
35 | }
36 |
37 | .k-timepicker,
38 | .k-datepicker {
39 | display: inline-block;
40 |
41 | .k-dateinput-wrap {
42 | display: inline-block;
43 | }
44 |
45 | .k-select {
46 | position: absolute;
47 | top: 0;
48 | right: 0;
49 | bottom: 0;
50 | }
51 | }
52 |
53 | .k-time-list-wrapper,
54 | .k-time-separator {
55 | display: inline-block;
56 | vertical-align: middle;
57 | }
58 |
59 | .k-grid {
60 | $grid-chrome-height: 37px !default;
61 | .k-grid-container {
62 | height: calc( 100% - #{$grid-chrome-height} );
63 | display: block;
64 | }
65 |
66 | .k-grid-content {
67 | height: 100%;
68 | }
69 | }
70 | }
71 |
--------------------------------------------------------------------------------
/scss/notification.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "notification/layout";
11 | @import "notification/theme";
12 |
--------------------------------------------------------------------------------
/scss/notification/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("notification/layout") {
2 |
3 | $alert-padding-y: 1em !default;
4 | $alert-padding-x: 1em !default;
5 |
6 | // Base
7 | .k-notification {
8 | padding: 0;
9 | @include border-radius();
10 | }
11 | .k-notification-wrap {
12 | font-size: $font-size-sm;
13 | padding: $alert-padding-y $alert-padding-x * 2 $alert-padding-y $alert-padding-x;
14 | white-space: nowrap;
15 | cursor: default;
16 | position: relative;
17 | line-height: $line-height-em;
18 |
19 | > .k-icon {
20 | margin-right: $padding-x;
21 | vertical-align: middle;
22 | }
23 |
24 | > .k-i-close {
25 | margin: 0;
26 | position: absolute;
27 | top: $alert-padding-y;
28 | right: $alert-padding-x / 2;
29 | font-size: inherit;
30 | line-height: inherit;
31 |
32 | &::before {
33 | font-size: $icon-size;
34 | }
35 | }
36 | }
37 |
38 | .k-rtl .k-notification-wrap {
39 | padding: $alert-padding-y $alert-padding-x $alert-padding-y $alert-padding-x * 2;
40 |
41 | > .k-icon {
42 | margin-right: 0;
43 | margin-left: $padding-x;
44 | }
45 |
46 | > .k-i-close {
47 | margin: 0;
48 | right: auto;
49 | left: $padding-x-sm;
50 | }
51 | }
52 | }
53 |
--------------------------------------------------------------------------------
/scss/notification/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("notification/theme") {
2 |
3 | // Theme
4 | .k-notification {
5 | @include appearance( panel );
6 | }
7 | .k-notification-info {
8 | border-color: $notification-info-border;
9 | color: $notification-info-text;
10 | background-color: $notification-info-bg;
11 | }
12 | .k-notification-success {
13 | border-color: $notification-success-border;
14 | color: $notification-success-text;
15 | background-color: $notification-success-bg;
16 | }
17 | .k-notification-warning {
18 | border-color: $notification-warning-border;
19 | color: $notification-warning-text;
20 | background-color: $notification-warning-bg;
21 | }
22 | .k-notification-error {
23 | border-color: $notification-error-border;
24 | color: $notification-error-text;
25 | background-color: $notification-error-bg;
26 | }
27 |
28 | }
29 |
--------------------------------------------------------------------------------
/scss/numerictextbox.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "numerictextbox/layout";
11 | @import "numerictextbox/theme";
12 |
--------------------------------------------------------------------------------
/scss/numerictextbox/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("numerictextbox/layout") {
2 |
3 | // Base
4 | .k-numerictextbox {
5 |
6 | .k-rtl &,
7 | &[dir='rtl'] {
8 | .k-numeric-wrap .k-i-warning {
9 | align-self: center;
10 | margin-right: 0;
11 | margin-left: $spacer-x / 2;
12 | }
13 | }
14 | }
15 |
16 | .k-numeric-wrap {
17 | .k-i-warning {
18 | align-self: center;
19 | margin-right: $spacer-x / 2;
20 | }
21 |
22 | > .k-input {
23 | flex: 1 1 0;
24 |
25 | &:invalid {
26 | box-shadow: none;
27 | }
28 | }
29 | }
30 | }
31 |
--------------------------------------------------------------------------------
/scss/numerictextbox/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("numerictextbox/theme") {
2 | $numerictextbox-icon-offset: 2px !default;
3 |
4 | // Numeric
5 | .k-numerictextbox {
6 |
7 | // Normal state
8 | .k-numeric-wrap {
9 | @include appearance( input );
10 | background-clip: padding-box;
11 |
12 | .k-ie11 &,
13 | .k-edge12 &,
14 | .k-edge13 & {
15 | background-clip: border-box;
16 | }
17 | }
18 | .k-select {
19 | @include appearance( button );
20 | padding: 0;
21 | width: button-inner-size();
22 | border-width: 0;
23 |
24 | &:hover {
25 | @include appearance( hovered-button );
26 | }
27 |
28 | > .k-state-selected,
29 | > .k-state-active {
30 | color: darken($text-color, 25%);
31 | @include appearance( hovered-button );
32 | box-shadow: inset $button-focused-shadow;
33 | }
34 | }
35 |
36 | .k-link-increase > .k-icon {
37 | bottom: -$numerictextbox-icon-offset;
38 | }
39 |
40 | .k-link-decrease > .k-icon {
41 | top: -$numerictextbox-icon-offset;
42 | }
43 |
44 | // Hovered state
45 | .k-state-hover {
46 | @include appearance( hovered-input );
47 |
48 | .k-select { @include appearance( hovered-button ); }
49 | }
50 |
51 | // Focused state
52 | .k-state-focused {
53 | @include appearance( focused-input );
54 | }
55 |
56 | .k-numeric-wrap.k-state-invalid {
57 | color: $error;
58 | border-color: $invalid-border;
59 |
60 | .k-select {
61 | color: $error;
62 | }
63 | }
64 | }
65 |
66 | }
67 |
--------------------------------------------------------------------------------
/scss/pager.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "dropdownlist";
8 |
9 |
10 | // Component
11 | @import "pager/layout";
12 | @import "pager/theme";
13 |
--------------------------------------------------------------------------------
/scss/pager/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("pager/layout") {
2 | $pager-buttons-size: calc(#{$form-line-height-em} + 2px) !default; /// icon button size + 2px border (top and bottom)
3 |
4 | .k-pager-wrap {
5 | padding: $pager-padding-y $pager-padding-x;
6 | border-width: 1px;
7 | line-height: $form-line-height;
8 | display: flex;
9 | align-items: center;
10 | overflow: hidden;
11 | cursor: default;
12 | flex: 0 0 auto;
13 |
14 | .k-link,
15 | .k-state-selected {
16 | padding: $button-padding-y;
17 | width: $pager-buttons-size;
18 | height: $pager-buttons-size;
19 | line-height: $pager-buttons-size;
20 | box-sizing: content-box;
21 | display: inline-flex;
22 | align-items: center;
23 | justify-content: center;
24 | position: relative;
25 | text-align: center;
26 | z-index: 1;
27 |
28 | > .k-icon {
29 | vertical-align: middle;
30 | }
31 |
32 | }
33 | .k-link:hover,
34 | .k-state-selected {
35 | z-index: 2;
36 | }
37 | .k-link:focus,
38 | .k-state-selected {
39 | text-decoration: none;
40 | outline: none;
41 | }
42 | .k-link.k-state-disabled {
43 | color: inherit;
44 | }
45 | > .k-pager-nav {}
46 | > .k-pager-nav + .k-pager-nav {}
47 |
48 |
49 | .k-pager-numbers {
50 | display: inline-flex;
51 | flex-direction: row;
52 |
53 | li {
54 | display: inline-block;
55 | }
56 |
57 | .k-current-page {
58 | display: none;
59 | }
60 | .k-current-page + li {
61 | margin-left: 0;
62 | }
63 | }
64 |
65 | .k-label {
66 | margin: 0 $spacer-x;
67 | display: flex;
68 | align-items: center;
69 | }
70 | .k-pager-input {
71 | .k-textbox {
72 | margin: 0 1ex;
73 | width: 3em;
74 | }
75 | }
76 | .k-pager-sizes {
77 | .k-dropdown,
78 | > select {
79 | width: 5.2em;
80 | margin: 0 $padding-x;
81 | }
82 | }
83 | .k-pager-refresh {
84 | order: 10;
85 | }
86 | .k-pager-info {
87 | flex: 1;
88 | text-align: right;
89 | order: 9;
90 | justify-content: flex-end;
91 | }
92 |
93 | [dir = "rtl"] &,
94 | .k-rtl & {
95 | .k-i-arrow-e,
96 | .k-i-arrow-w,
97 | .k-i-seek-e,
98 | .k-i-seek-w {
99 | transform: scaleX(-1);
100 | }
101 | }
102 | }
103 | }
104 |
--------------------------------------------------------------------------------
/scss/pager/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("pager/theme") {
2 | $pager-text: $header-text !default;
3 | $pager-bg: $header-bg !default;
4 | $pager-items-hover-bg: $list-item-hovered-bg !default;
5 | $pager-numbers-text: $accent !default;
6 | $pager-numbers-selected-text: $accent-contrast !default;
7 |
8 | .k-pager-wrap {
9 | color: $pager-text;
10 | background-color: $pager-bg;
11 |
12 | .k-link,
13 | .k-pager-nav {
14 | &:focus {
15 | box-shadow: $list-item-focused-shadow;
16 | }
17 | &:hover {
18 | background-color: $pager-items-hover-bg;
19 | }
20 | }
21 |
22 | .k-state-selected {
23 | &:focus {
24 | box-shadow: none;
25 | }
26 | &:hover {
27 | color: $selected-text;
28 | background-color: $selected-bg;
29 | cursor: default;
30 | }
31 | }
32 | }
33 | .k-pager-numbers {
34 | .k-link,
35 | .k-link:link {
36 | color: $pager-numbers-text;
37 |
38 | &.k-state-selected {
39 | color: $accent-contrast;
40 | }
41 | }
42 | }
43 | }
44 |
--------------------------------------------------------------------------------
/scss/panelbar.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "panelbar/layout";
11 | @import "panelbar/theme";
12 |
--------------------------------------------------------------------------------
/scss/panelbar/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("panelbar/layout") {
2 |
3 | // Base
4 | .k-panelbar {
5 | margin: 0;
6 | padding: 0;
7 | list-style: none;
8 |
9 |
10 | // Root
11 | > .k-item {
12 | // TODO
13 | border-width: 0;
14 | border-style: solid;
15 | border-color: inherit;
16 | display: block;
17 |
18 | > .k-link {
19 | padding: $header-padding-y $header-padding-x;
20 | color: inherit;
21 | background: none;
22 | text-decoration: none;
23 | display: flex;
24 | flex-direction: row;
25 | align-items: center;
26 | align-content: center;
27 | position: relative;
28 | user-select: none;
29 | cursor: default;
30 | transition: $transition;
31 | }
32 | }
33 | > .k-item + .k-item {
34 | border-top-width: 1px;
35 | }
36 |
37 |
38 | // Sub
39 | .k-group {
40 | margin: 0;
41 | padding: 0;
42 | list-style: none;
43 | }
44 | .k-group > .k-item {
45 | display: block;
46 |
47 | > .k-link {
48 | padding: $list-item-padding-y $list-item-padding-x;
49 | color: inherit;
50 | text-decoration: none;
51 | display: flex;
52 | flex-direction: row;
53 | align-items: center;
54 | align-content: center;
55 | position: relative;
56 | user-select: none;
57 | cursor: default;
58 | transition: $transition;
59 | }
60 | }
61 |
62 |
63 | // Expand collapse
64 | .k-panelbar-expand,
65 | .k-panelbar-collapse {
66 | margin-top: -.5em;
67 | position: absolute;
68 | top: 50%;
69 | right: $header-padding-x;
70 | }
71 |
72 | .k-link > .k-image,
73 | .k-link > .k-sprite {
74 | vertical-align: middle;
75 | float: left;
76 | margin-right: 5px;
77 | }
78 |
79 | &[dir='rtl'],
80 | .k-rtl & {
81 | .k-panelbar-expand,
82 | .k-panelbar-collapse {
83 | right: auto;
84 | left: $header-padding-x;
85 | }
86 | }
87 | }
88 |
89 | }
90 |
--------------------------------------------------------------------------------
/scss/panelbar/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports('panelbar/theme') {
2 | $panelbar-root-hover-bg: darken($widget-bg, 5%);
3 |
4 | .k-panelbar {
5 | border-color: $panel-border;
6 | color: $panel-text;
7 | background-color: $panel-bg;
8 | background-clip: padding-box;
9 |
10 | .k-ie11 &,
11 | .k-edge12 &,
12 | .k-edge13 & {
13 | background-clip: border-box;
14 | }
15 |
16 | .k-content {
17 | color: $base-text;
18 | background-color: $base-bg;
19 | }
20 |
21 | // Root
22 | > .k-item {
23 | background-clip: padding-box;
24 |
25 | .k-ie11 &,
26 | .k-edge12 &,
27 | .k-edge13 & {
28 | background-clip: border-box;
29 | }
30 |
31 | > .k-link {
32 | color: $link-text;
33 |
34 | .k-icon {
35 | color: $base-text;
36 | }
37 | }
38 |
39 | > .k-link:hover,
40 | > .k-link.k-state-hover {
41 | color: $link-hover-text;
42 | background-color: $panelbar-root-hover-bg;
43 | }
44 |
45 | > .k-link.k-state-selected:not(.k-state-expanded),
46 | > .k-link.k-state-selected:not(.k-state-active) {
47 | @include appearance( selected-node );
48 |
49 | .k-icon {
50 | color: $selected-text;
51 | }
52 |
53 | &:hover,
54 | &.k-state-hover {
55 | color: $selected-hover-color;
56 | background-color: $selected-hover-bg;
57 | }
58 | }
59 |
60 | &.k-state-expanded > .k-link,
61 | &.k-state-active > .k-link {
62 | @include appearance( node );
63 | font-weight: 500;
64 |
65 | .k-icon {
66 | color: $base-text;
67 | }
68 |
69 | &:hover,
70 | &.k-state-hover {
71 | @include appearance( hovered-node );
72 | }
73 | }
74 |
75 | > .k-link.k-state-focused {
76 | box-shadow: $list-item-focused-shadow;
77 | }
78 | }
79 |
80 | // Sub
81 | .k-group {
82 | color: $base-text;
83 | background-color: $base-bg;
84 |
85 | > .k-item > .k-link:hover,
86 | > .k-item > .k-link.k-state-hover {
87 | @include appearance( hovered-node );
88 |
89 | &.k-state-selected {
90 | color: $selected-hover-color;
91 | background-color: $selected-hover-bg;
92 | }
93 | }
94 |
95 | > .k-item > .k-link.k-state-selected {
96 | @include appearance( selected-node );
97 | }
98 |
99 | > .k-item > .k-link.k-state-focused {
100 | box-shadow: $list-item-focused-shadow;
101 | }
102 |
103 | }
104 |
105 | }
106 |
107 | }
108 |
--------------------------------------------------------------------------------
/scss/pivotgrid.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "dialog";
8 | @import "treeview";
9 |
10 |
11 | // Component
12 | @import "pivotgrid/layout";
13 | @import "pivotgrid/theme";
14 |
--------------------------------------------------------------------------------
/scss/pivotgrid/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports('pivotgrid/theme') {
2 | $pivotgrid-alt-bg: $header-bg !default;
3 | $pivotgrid-chrome-border: $border-color !default;
4 |
5 | $pivotgrid-container-bg: $bg-color !default;
6 | $pivotgrid-row-headers-bg: darken($bg-color, 7%) !default;
7 |
8 | .k-alt,
9 | .k-pivot-toolbar,
10 | .k-pivot-layout > tbody > tr:first-child > td:first-child {
11 | background-color: $pivotgrid-alt-bg;
12 | }
13 |
14 | .k-fieldselector .k-list-container {
15 | background-color: $pivotgrid-container-bg;
16 | }
17 |
18 | .k-pivot-toolbar,
19 | .k-pivot-table,
20 | .k-fieldselector .k-list-container,
21 | .k-fieldselector .k-columns > div,
22 | .k-pivot-rowheaders > .k-grid td:first-child,
23 | .k-pivot-table .k-grid-header .k-header.k-first {
24 | border-color: $pivotgrid-chrome-border;
25 | }
26 |
27 | .k-pivot-rowheaders .k-alt .k-alt,
28 | .k-header.k-alt {
29 | background-color: $pivotgrid-row-headers-bg;
30 | }
31 |
32 | .k-pivot-toolbar .k-button,
33 | .k-fieldselector .k-list li.k-item {
34 | @include appearance( button );
35 | background-clip: padding-box;
36 |
37 | .k-ie11 &,
38 | .k-edge12 &,
39 | .k-edge13 & {
40 | background-clip: border-box;
41 | }
42 |
43 | &:hover,
44 | &.k-state-hover {
45 | @include appearance( hovered-button );
46 | }
47 |
48 | // Pressed state
49 | &:active,
50 | &.k-state-active {
51 | @include fill( $button-text, $button-bg, $button-border, #{to top, $button-gradient} );
52 | box-shadow: $button-pressed-shadow;
53 | }
54 |
55 | // Focused state
56 | &:focus,
57 | &.k-state-focused {
58 | box-shadow: $button-focused-shadow;
59 | }
60 | }
61 |
62 | /* Loading indicator */
63 | .k-fieldselector {
64 | .k-i-loading {
65 | border-color: $header-bg;
66 | }
67 |
68 | .k-i-loading::before,
69 | .k-i-loading::after {
70 | background-color: $header-bg;
71 | }
72 | }
73 | }
74 |
--------------------------------------------------------------------------------
/scss/popup.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "popup/layout";
11 | @import "popup/theme";
12 |
--------------------------------------------------------------------------------
/scss/popup/_theme.scss:
--------------------------------------------------------------------------------
1 | // TODO: list item variables
2 | $list-container-shadow: 0 5px 10px 0 rgba(0, 0, 0, .06) !default;
3 |
4 | $popup-text: $normal-text-color !default;
5 |
6 | $list-container-no-data-text: rgba( $text-color, .5 ) !default;
7 |
8 | @include exports('popup/theme') {
9 |
10 | .k-popup {
11 | @include appearance( popup );
12 | background-clip: padding-box;
13 |
14 | .k-ie11 &,
15 | .k-edge12 &,
16 | .k-edge13 & {
17 | background-clip: border-box;
18 | }
19 | }
20 | .k-popup > .k-group-header,
21 | .k-popup > .k-virtual-wrap > .k-group-header {
22 | border-bottom-color: $border-color;
23 | box-shadow: $list-container-shadow;
24 | }
25 | .k-popup .k-list .k-item > .k-group {
26 | background: $text-color;
27 | color: $bg-color;
28 | }
29 | .k-popup .k-list .k-item > .k-group::before {
30 | border-color: $text-color $text-color transparent transparent;
31 | }
32 | .k-group-header+div > .k-list > .k-item.k-first::before {
33 | border-color: $border-color;
34 | }
35 | }
36 |
37 | @include exports( "list/theme" ) {
38 |
39 | .k-list {}
40 |
41 | .k-list .k-item {
42 | transition: all .2s ease; // sass-lint:disable-block no-transition-all
43 | }
44 |
45 | .k-list .k-item:hover,
46 | .k-list .k-item.k-state-hover,
47 | .k-list-optionlabel:hover {
48 | @include appearance( hovered-list-item );
49 |
50 | &.k-state-selected {
51 | color: $list-item-selected-text;
52 | background-color: blend-multiply( $list-item-selected-bg, $list-item-hovered-bg );
53 | }
54 | }
55 |
56 | .k-list .k-item:focus,
57 | .k-list .k-item.k-state-focused {
58 | @include appearance( focused-list-item );
59 | }
60 |
61 | .k-list .k-item.k-state-selected,
62 | .k-list-optionlabel.k-state-selected {
63 | @include appearance( selected-list-item );
64 | }
65 |
66 | .k-animation-container {
67 | @include border-bottom-radius-only();
68 | }
69 |
70 | .k-animation-container-shown,
71 | .k-animation-container > .k-popup {
72 | box-shadow: $popup-shadow;
73 | }
74 |
75 | .k-animation-container-fixed > .k-popup {
76 | box-shadow: none;
77 | }
78 | }
79 |
80 |
81 |
82 |
83 | @include exports( "listcontainer/theme" ) {
84 |
85 |
86 | .k-list-container {
87 |
88 | // Button normal state
89 | .k-button {
90 | box-shadow: none;
91 | }
92 |
93 |
94 | // Button hover state
95 | .k-button:hover,
96 | .k-button.k-state-hover {
97 | @include appearance( hovered-list-item );
98 | background-image: none;
99 | }
100 |
101 | // Button pressed state
102 | .k-button:active,
103 | .k-button.k-state-active {
104 | @include appearance( selected-list-item );
105 | background-image: none;
106 | }
107 |
108 |
109 | // Button focus state
110 | .k-button:focus,
111 | .k-button.k-state-focused {
112 | box-shadow: $list-item-focused-shadow;
113 | }
114 |
115 | .k-nodata {
116 | color: $list-container-no-data-text;
117 | }
118 |
119 | }
120 |
121 | }
122 |
--------------------------------------------------------------------------------
/scss/progressbar.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "progressbar/images/indeterminate";
8 |
9 |
10 | // Component
11 | @import "progressbar/layout";
12 | @import "progressbar/theme";
13 |
--------------------------------------------------------------------------------
/scss/progressbar/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports('progressbar/layout') {
2 |
3 | // Base
4 | .k-progressbar {
5 | @include border-radius();
6 | border-width: 0;
7 | font-size: $font-size-sm;
8 | line-height: $progressbar-height;
9 | display: inline-flex;
10 | vertical-align: middle;
11 | position: relative;
12 | overflow: hidden;
13 |
14 |
15 | // Status
16 | .k-progress-status-wrap {
17 | width: 100%;
18 | height: 100%;
19 | display: flex;
20 | position: absolute;
21 | top: 0;
22 | left: 0;
23 | }
24 | .k-progress-status {
25 | padding: 0 ($spacer-x / 2);
26 | min-width: 10px;
27 | text-align: center;
28 | display: inline-block;
29 | white-space: nowrap;
30 | }
31 |
32 | > .k-state-selected {
33 | position: absolute;
34 | overflow: hidden;
35 | border-style: solid;
36 | border-width: 0;
37 |
38 | .k-progress-status-wrap {}
39 | }
40 |
41 |
42 | // Chunks
43 | > ul {
44 | border-width: inherit;
45 | border-style: inherit;
46 | white-space: nowrap;
47 | display: flex;
48 | align-items: stretch;
49 | flex: 1;
50 | }
51 | .k-item {
52 | display: block;
53 | border-width: 0;
54 | border-style: solid;
55 | border-color: transparent;
56 | }
57 |
58 | }
59 |
60 |
61 | // Horizontal
62 | .k-progressbar-horizontal {
63 | width: 27em;
64 | height: $progressbar-height;
65 | flex-direction: row;
66 |
67 |
68 | .k-progress-status-wrap {
69 | flex-direction: row;
70 | justify-content: flex-end;
71 | top: 0;
72 | left: 0;
73 | }
74 | > .k-state-selected {
75 | left: 0;
76 | right: auto;
77 | top: 0;
78 | height: 100%;
79 | }
80 |
81 |
82 | // Chunks
83 | > ul {
84 | flex-direction: row;
85 | }
86 | .k-item {}
87 | .k-item + .k-item {
88 | border-left-width: 1px;
89 | }
90 |
91 |
92 | // Horizontal reverse
93 | &.k-progressbar-reverse {
94 | flex-direction: row-reverse;
95 |
96 | .k-progress-status-wrap {
97 | justify-content: flex-start;
98 | left: auto;
99 | right: 0;
100 | }
101 | > .k-state-selected {
102 | left: auto;
103 | right: 0;
104 | }
105 |
106 | }
107 | }
108 |
109 |
110 | // Vertical
111 | .k-progressbar-vertical {
112 | width: $progressbar-height;
113 | height: 27em;
114 | flex-direction: column;
115 | justify-content: flex-end;
116 |
117 |
118 | .k-progress-status-wrap {
119 | flex-direction: column;
120 | justify-content: flex-start;
121 | left: 0;
122 | bottom: 0;
123 | }
124 | .k-progress-status {
125 | transform: rotate(-90deg) translateX(-100%);
126 | transform-origin: 0 0;
127 | }
128 | > .k-state-selected {
129 | left: -1px;
130 | bottom: -1px;
131 | width: 100%;
132 | }
133 |
134 |
135 | // Chunk
136 | > ul {
137 | flex-direction: column;
138 | }
139 | .k-item {}
140 | .k-item + .k-item {
141 | border-top-width: 1px;
142 | }
143 |
144 |
145 | // Vertical reverse
146 | &.k-progressbar-reverse {
147 | flex-direction: column-reverse;
148 |
149 | .k-progress-status-wrap {
150 | justify-content: flex-end;
151 | top: 0;
152 | bottom: auto;
153 | }
154 | .k-progress-status {
155 | transform: rotate(90deg) translateX(-100%);
156 | transform-origin: 0 100%;
157 | position: absolute;
158 | bottom: 0;
159 | left: 0;
160 | }
161 | > .k-state-selected {
162 | left: auto;
163 | right: 0;
164 | bottom: auto;
165 | top: 0;
166 | }
167 |
168 | }
169 | }
170 |
171 | }
172 |
--------------------------------------------------------------------------------
/scss/progressbar/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports('progressbar/theme') {
2 |
3 | $progressbar-bg: $base-bg !default;
4 | $progressbar-border: $base-border !default;
5 | $progressbar-chunk-border: $bg-color !default;
6 | $progressbar-selected-bg: $accent !default;
7 | $progressbar-selected-border: darken( $progressbar-selected-bg, 4%) !default;
8 | $progressbar-selected-gradient: rgba( adjust-hue( $progressbar-selected-bg, 14), 0 ), rgba( adjust-hue( $progressbar-selected-bg, 14), .2 ) !default;
9 |
10 | .k-progressbar {
11 | background-color: $progressbar-bg;
12 | border-color: $progressbar-border;
13 | background-clip: padding-box;
14 |
15 | .k-ie11 &,
16 | .k-edge12 &,
17 | .k-edge13 & {
18 | background-clip: border-box;
19 | }
20 |
21 | .k-state-selected {
22 | border-color: $progressbar-selected-border;
23 | background-color: $progressbar-selected-bg;
24 | @include linear-gradient( $progressbar-selected-gradient );
25 | }
26 |
27 | .k-item {
28 | border-color: $progressbar-chunk-border;
29 | }
30 | }
31 |
32 | .k-progressbar-indeterminate {
33 | background: url(map-get($data-uris, 'indeterminate.gif'));
34 |
35 | .k-progress-status-wrap,
36 | .k-state-selected {
37 | display: none;
38 | }
39 | }
40 | }
41 |
--------------------------------------------------------------------------------
/scss/progressbar/images/indeterminate.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/telerik/kendo-theme-default/77efe2aa5a7bb7fb3d4a30b4cac6b87a4b12c54d/scss/progressbar/images/indeterminate.gif
--------------------------------------------------------------------------------
/scss/progressbar/images/indeterminate.scss:
--------------------------------------------------------------------------------
1 | @import '../../mixins';
2 |
3 | @include exports('indeterminate.gif') {
4 | @include register-data-uri('indeterminate.gif', '')
5 | }
6 |
--------------------------------------------------------------------------------
/scss/qrcode.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 |
7 |
8 | // Component
9 | @import "qrcode/layout";
10 |
--------------------------------------------------------------------------------
/scss/qrcode/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports('qrcode/layout') {
2 |
3 | .k-qrcode {
4 | display: inline-block;
5 | }
6 |
7 | }
8 |
--------------------------------------------------------------------------------
/scss/responsivepanel.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "responsivepanel/layout";
11 | @import "responsivepanel/theme";
12 |
--------------------------------------------------------------------------------
/scss/responsivepanel/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("responsivepanel/layout") {
2 |
3 | .k-rpanel {}
4 |
5 | // Variants
6 | .k-rpanel-left,
7 | .k-rpanel-right {
8 | position: fixed;
9 | display: block;
10 | overflow: auto;
11 | min-width: 320px;
12 | height: 100%;
13 | top: 0;
14 |
15 | & + * {
16 | overflow: auto;
17 | }
18 |
19 | &.k-rpanel-expanded {
20 | transform: translateX(0) translateZ(0);
21 | }
22 | }
23 | .k-rpanel-left {
24 | transform: translateX(-100%) translateZ(0);
25 | left: 0;
26 | }
27 | .k-rpanel-right {
28 | transform: translateX(100%) translateZ(0);
29 | right: 0;
30 | }
31 |
32 | // Top
33 | .k-rpanel-top {
34 | position: static;
35 | max-height: 0;
36 | }
37 | .k-rpanel-top.k-rpanel-expanded {
38 | max-height: 568px;
39 | // sass-lint:disable no-important
40 | overflow: visible !important;
41 | // sass-lint:enable no-important
42 | }
43 |
44 | }
45 |
--------------------------------------------------------------------------------
/scss/responsivepanel/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("responsivepanel/theme") {
2 |
3 | .k-rpanel {}
4 |
5 | }
6 |
--------------------------------------------------------------------------------
/scss/ripple.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 |
7 |
8 | // Component
9 | @import "ripple/layout";
10 | @import "ripple/theme";
11 |
--------------------------------------------------------------------------------
/scss/ripple/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports( 'ripple/layout' ) {
2 | .k-ripple-target {
3 | position: relative;
4 | }
5 |
6 | .k-ripple {
7 | position: absolute;
8 | top: 0;
9 | left: 0;
10 | right: 0;
11 | bottom: 0;
12 | z-index: 1;
13 | overflow: hidden;
14 | pointer-events: none;
15 | }
16 |
17 | .k-ripple-blob {
18 | pointer-events: none;
19 | position: absolute;
20 | border-radius: 50%;
21 | padding: 0;
22 | transform: translate(-50%, -50%) scale(0);
23 | transition: opacity 100ms linear, transform 500ms cubic-bezier(.4, 0, .2, 1);
24 | opacity: .1;
25 | background-color: currentColor;
26 |
27 | .k-primary & {
28 | opacity: .2;
29 | }
30 |
31 | .k-primary.k-flat & {
32 | opacity: 1;
33 | }
34 | }
35 |
36 | }
37 |
--------------------------------------------------------------------------------
/scss/ripple/_theme.scss:
--------------------------------------------------------------------------------
1 |
2 |
--------------------------------------------------------------------------------
/scss/scheduler.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "scheduler/layout";
11 | @import "scheduler/theme";
12 |
--------------------------------------------------------------------------------
/scss/scheduler/_theme.scss:
--------------------------------------------------------------------------------
1 | // TODO: modal header variables
2 | $modal-header-border-color: #cccccc;
3 |
4 |
5 | @include exports("scheduler/theme") {
6 |
7 | // Appearance
8 | .k-scheduler {
9 | background-clip: padding-box;
10 |
11 | .k-ie11 &,
12 | .k-edge12 &,
13 | .k-edge13 & {
14 | background-clip: border-box;
15 | }
16 | }
17 |
18 |
19 | // Header and footer
20 | .k-scheduler-toolbar,
21 | .k-scheduler-footer {
22 | @include appearance( header );
23 | background-clip: padding-box;
24 |
25 | .k-ie11 &,
26 | .k-edge12 &,
27 | .k-edge13 & {
28 | background-clip: border-box;
29 | }
30 | }
31 |
32 |
33 | //Scheduler navigation
34 | .k-scheduler-navigation {
35 |
36 | li {
37 | background-clip: padding-box;
38 |
39 | .k-ie11 &,
40 | .k-edge12 &,
41 | .k-edge13 & {
42 | background-clip: border-box;
43 | }
44 | }
45 |
46 | .k-nav-today,
47 | .k-nav-prev,
48 | .k-nav-next {
49 | @include appearance( button );
50 |
51 | &.k-state-hover { @include appearance( hovered-button ); }
52 | }
53 | }
54 |
55 |
56 | // View switcher
57 | .k-scheduler-views {
58 |
59 | li {
60 | @include appearance( button );
61 | background-clip: padding-box;
62 |
63 | .k-ie11 &,
64 | .k-edge12 &,
65 | .k-edge13 & {
66 | background-clip: border-box;
67 | }
68 |
69 | &.k-state-hover { @include appearance( hovered-button ); }
70 | &.k-state-selected { @include fill( $selected-text, $selected-bg, $selected-border, none ); }
71 | }
72 | }
73 |
74 |
75 | // Scheduler footer
76 | .k-scheduler-footer {
77 |
78 | li {
79 | @include appearance( button );
80 | background-clip: padding-box;
81 |
82 | .k-ie11 &,
83 | .k-edge12 &,
84 | .k-edge13 & {
85 | background-clip: border-box;
86 | }
87 |
88 | &.k-state-hover { @include appearance( hovered-button ); }
89 | }
90 | }
91 |
92 |
93 | // Scheduler content
94 | .k-scheduler-content {}
95 | .k-nonwork-hour {
96 | background-color: mix( $panel-text, $panel-bg, 3% );
97 | }
98 |
99 |
100 | // Appointments
101 | .k-event {
102 | @include appearance( selected-node );
103 | }
104 | .k-event-inverse {
105 | color: $panel-bg;
106 | }
107 |
108 |
109 | // Drag hint
110 | .k-event-drag-hint {}
111 |
112 |
113 | // Resizing
114 | .k-scheduler-marquee {}
115 | .k-scheduler-marquee::before,
116 | .k-scheduler-marquee::after {
117 | border-color: $primary-button-border;
118 | }
119 |
120 | }
121 |
122 |
123 |
124 |
125 | @include exports("scheduler-views/theme") {
126 |
127 | // Day view
128 | .k-scheduler-dayview {}
129 |
130 |
131 | // Workweek view
132 | // sass-lint:disable class-name-format
133 | .k-scheduler-workWeekview {}
134 | // sass-lint:enable class-name-format
135 |
136 |
137 | // Week view
138 | .k-scheduler-weekview {}
139 |
140 |
141 | // Month view
142 | .k-scheduler-monthview {}
143 |
144 |
145 | // Agenda view
146 | .k-scheduler-agendaview {
147 |
148 | tr.k-state-hover {
149 | @include appearance( hovered-node );
150 | }
151 | tr.k-state-hover .k-scheduler-datecolumn {
152 | @include appearance( panel );
153 | }
154 | }
155 |
156 |
157 | // Timeline view
158 | .k-scheduler-timelineview {}
159 |
160 | }
161 |
162 |
163 |
164 |
165 | @include exports("scheduler-edit-form/theme") {
166 |
167 | .k-scheduler-edit-form {}
168 |
169 | }
170 |
--------------------------------------------------------------------------------
/scss/scroller.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 |
7 |
8 | // Component
9 | @import "scroller/layout";
10 |
--------------------------------------------------------------------------------
/scss/scroller/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("scroller/layout") {
2 |
3 | // Layout
4 | .km-scrollview,
5 | .km-scroll-container {
6 | user-select: none;
7 | margin-collapse: separate;
8 | }
9 | .km-scroll-wrapper {
10 | position: relative;
11 | }
12 | .km-scroll-header {
13 | position: absolute;
14 | z-index: 1001;
15 | width: 100%;
16 | top: 0;
17 | left: 0;
18 | }
19 |
20 |
21 | // Pull to refresh
22 | .km-scroller-pull {
23 | width: 100%;
24 | display: block;
25 | position: absolute;
26 | line-height: 3em;
27 | font-size: 1.4em;
28 | text-align: center;
29 | transform: translate3d(0, -3em, 0);
30 | }
31 | .km-scroller-pull .km-template {
32 | display: inline-block;
33 | min-width: 200px;
34 | text-align: left;
35 | }
36 | .km-load-more .km-icon,
37 | .km-widget .km-scroller-pull .km-icon {
38 | display: inline-block;
39 | height: 2rem;
40 | margin-right: 1rem;
41 | vertical-align: middle;
42 | width: 2rem;
43 | font-size: 2rem;
44 | transform: rotate(0deg);
45 | transition: transform 300ms linear;
46 | }
47 | .km-widget .km-scroller-release .km-icon {
48 | transform: rotate(180deg);
49 | }
50 | .km-widget .km-scroller-refresh .km-icon {
51 | transition: none;
52 | }
53 |
54 |
55 | // Scrollbar
56 | .km-touch-scrollbar {
57 | position: absolute;
58 | visibility: hidden;
59 | z-index: 200000;
60 | height: .4em;
61 | width: .4em;
62 | background-color: #333;
63 | opacity: 0;
64 | transform-origin: 0 0;
65 | transition: opacity .3s linear;
66 | }
67 | .km-vertical-scrollbar {
68 | height: 100%;
69 | right: 2px;
70 | top: 0;
71 | }
72 | .km-horizontal-scrollbar {
73 | width: 100%;
74 | left: 0;
75 | bottom: 2px;
76 | }
77 |
78 | }
79 |
--------------------------------------------------------------------------------
/scss/scrollview.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "button";
8 |
9 |
10 | // Component
11 | @import "scrollview/layout";
12 | @import "scrollview/theme";
13 |
--------------------------------------------------------------------------------
/scss/scrollview/_layout.scss:
--------------------------------------------------------------------------------
1 | @import '../common/icons';
2 | @import '../button/layout';
3 |
4 | @include exports('scrollview/layout') {
5 | $scrollview-page-button-size: 8px;
6 | $scrollview-arrow-icon-size: 4.5em;
7 |
8 | .k-scrollview-wrap {
9 | position: relative;
10 | overflow: hidden;
11 | outline: 0;
12 | display: block;
13 | }
14 |
15 | .k-scrollview {
16 | list-style-type: none;
17 | position: absolute;
18 | margin: 0;
19 | padding: 0;
20 | width: 100%;
21 | height: 100%;
22 | cursor: default;
23 |
24 | img,
25 | li {
26 | user-select: none;
27 | }
28 |
29 | & > li {
30 | display: inline-block;
31 | overflow: hidden;
32 | position: absolute;
33 | top: 0;
34 | left: 0;
35 | }
36 |
37 | li > * {
38 | user-select: none;
39 | pointer-events: none;
40 | }
41 | }
42 |
43 | .k-pages,
44 | .k-scrollview-pageable {
45 | margin: 0 auto;
46 | padding: 0;
47 | width: 100%;
48 | display: flex;
49 | justify-content: center;
50 | text-align: center;
51 | list-style: none;
52 | position: absolute;
53 | left: 0;
54 | bottom: 10px;
55 | pointer-events: none;
56 | }
57 | .k-pages > li,
58 | .k-scrollview-pageable > li.k-button {
59 | margin: 10px;
60 | padding: 0;
61 | width: $scrollview-page-button-size;
62 | height: $scrollview-page-button-size;
63 | box-sizing: content-box;
64 | vertical-align: middle;
65 | display: inline-block;
66 | flex: 0 0 $scrollview-page-button-size;
67 | border-radius: 50%;
68 | cursor: pointer;
69 | pointer-events: all;
70 | }
71 |
72 | .k-scrollview-next,
73 | .k-scrollview-prev {
74 | display: table;
75 | position: absolute;
76 | padding: 0;
77 | height: 60%;
78 | top: 20%;
79 | text-decoration: none;
80 | user-select: none;
81 | cursor: pointer;
82 | overflow: hidden;
83 | -webkit-tap-highlight-color: $rgba-transparent;
84 | }
85 |
86 | .k-scrollview-prev {
87 | left: 0;
88 | }
89 |
90 | .k-scrollview-next {
91 | right: 0;
92 | }
93 |
94 | .k-scrollview-next span,
95 | .k-scrollview-prev span {
96 | display: table-cell;
97 | margin: 0;
98 | padding: 0;
99 | vertical-align: middle;
100 | font-size: $scrollview-arrow-icon-size;
101 | font-weight: normal;
102 | }
103 |
104 | .k-scrollview-elements {
105 | width: 100%;
106 | }
107 | }
108 |
109 | @supports (-webkit-user-select: none) {
110 | div.k-scrollview-wrap ul.k-scrollview li > * {
111 | pointer-events: auto;
112 | }
113 | }
114 |
115 | @supports (not (-webkit-user-select: none)) {
116 | div.k-scrollview-wrap ul.k-scrollview li > * {
117 | pointer-events: none;
118 | }
119 | }
120 |
121 | //Mobile version
122 | .km-scrollview {
123 | white-space: nowrap;
124 | overflow: hidden;
125 | position: relative;
126 | width: 100%;
127 |
128 | & > div > * {
129 | -webkit-transform: translatez(0);
130 | }
131 |
132 | & > div > [data-role="page"] {
133 | vertical-align: top;
134 | display: inline-block;
135 | min-height: 1px;
136 | }
137 |
138 | .km-virtual-page {
139 | min-height: 1px;
140 | position: absolute;
141 | top: 0;
142 | left: 0;
143 | display: inline-block;
144 | }
145 | }
146 |
147 | .k-ff18 .km-scrollview > div,
148 | .k-ff19 .km-scrollview > div,
149 | .k-ff20 .km-scrollview > div,
150 | .k-ff21 .km-scrollview > div {
151 | width: 0;
152 | }
153 |
154 | .km-pages {
155 | padding: $padding-y 0 0 0;
156 | position: static;
157 | }
158 |
--------------------------------------------------------------------------------
/scss/scrollview/_theme.scss:
--------------------------------------------------------------------------------
1 | $scrollview-navigation-color: $selected-text !default;
2 | $scrollview-navigation-icon-shadow: rgba(0, 0, 0, .3) 0 0 15px !default;
3 | $scrollview-pagebutton-shadow: 0 0 2px rgba(0, 0, 0, .08) !default;
4 | $scrollview-navigation-background: rgba(0, 0, 0, 0) !default;
5 | $scrollview-navigation-default-opacity: .7 !default;
6 | $scrollview-navigation-hover-opacity: 1 !default;
7 | $webkit-highlight-color: rgba(0, 0, 0, 0) !default;
8 |
9 | @include exports('scrollview/theme') {
10 |
11 | .k-pages > li,
12 | .k-scrollview-pageable > li.k-button {
13 | background-image: none;
14 | box-shadow: $scrollview-pagebutton-shadow;
15 | }
16 | .k-pages > li {
17 | border-color: $button-border;
18 | color: $button-text;
19 | background-color: $button-bg;
20 | }
21 | .k-pages > li.k-current-page {
22 | border-color: $selected-border;
23 | color: $selected-text;
24 | background-color: $selected-bg;
25 | }
26 |
27 | .k-scrollview-elements {
28 | color: $scrollview-navigation-color;
29 | }
30 |
31 | .k-scrollview-next,
32 | .k-scrollview-prev {
33 | color: inherit;
34 | background: $scrollview-navigation-background;
35 | text-shadow: $scrollview-navigation-icon-shadow;
36 | opacity: $scrollview-navigation-default-opacity;
37 | outline-width: 0;
38 |
39 | &:hover {
40 | color: $scrollview-navigation-color;
41 | opacity: $scrollview-navigation-hover-opacity;
42 | }
43 | }
44 |
45 | .k-scrollview-animation {
46 | transition-duration: .3s;
47 | transition-timing-function: ease-out;
48 | }
49 | }
50 |
--------------------------------------------------------------------------------
/scss/slider.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "button";
8 | @import "slider/images/slider-h";
9 | @import "slider/images/slider-v";
10 |
11 |
12 | // Component
13 | @import "slider/layout";
14 | @import "slider/theme";
15 |
--------------------------------------------------------------------------------
/scss/slider/_theme.scss:
--------------------------------------------------------------------------------
1 | $slider-trackbackground-color: darken($widget-bg, 10%) !default;
2 | $slider-selection-background-color: $accent !default;
3 |
4 | @include exports('slider/theme') {
5 |
6 | .k-slider {
7 | .k-slider-track,
8 | .k-slider-selection {
9 | @include border-radius();
10 | }
11 |
12 | .k-slider-track {
13 | background-color: $slider-trackbackground-color;
14 | }
15 |
16 | .k-slider-selection {
17 | background-color: $slider-selection-background-color;
18 | }
19 |
20 | .k-button {
21 | @include border-radius( 50% );
22 | }
23 |
24 | .k-draghandle {
25 | @include appearance( primary-button );
26 | @include border-radius( 50% );
27 |
28 | &:hover {
29 | @include appearance( hovered-primary-button );
30 | }
31 |
32 | &:active,
33 | &.k-pressed {
34 | @include appearance( pressed-primary-button );
35 | box-shadow: inset $primary-button-pressed-shadow;
36 | }
37 |
38 | &:focus {
39 | box-shadow: $primary-button-focused-shadow;
40 | }
41 | }
42 |
43 | &.k-state-focused {
44 | .k-draghandle {
45 | box-shadow: $primary-button-focused-shadow;
46 | }
47 | }
48 |
49 | .k-slider-wrap {
50 | &:focus {
51 | outline: none;
52 | }
53 | }
54 | }
55 |
56 | .k-slider-horizontal .k-tick {
57 | background-image: url(map-get($data-uris, 'slider-h.gif'));
58 | }
59 |
60 | .k-slider-vertical .k-tick {
61 | background-image: url(map-get($data-uris, 'slider-v.gif'));
62 | }
63 | }
64 |
--------------------------------------------------------------------------------
/scss/slider/images/slider-h.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/telerik/kendo-theme-default/77efe2aa5a7bb7fb3d4a30b4cac6b87a4b12c54d/scss/slider/images/slider-h.gif
--------------------------------------------------------------------------------
/scss/slider/images/slider-h.scss:
--------------------------------------------------------------------------------
1 | @import '../../mixins';
2 |
3 | @include exports('slider-h.gif') {
4 | @include register-data-uri('slider-h.gif', '')
5 | }
6 |
--------------------------------------------------------------------------------
/scss/slider/images/slider-v.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/telerik/kendo-theme-default/77efe2aa5a7bb7fb3d4a30b4cac6b87a4b12c54d/scss/slider/images/slider-v.gif
--------------------------------------------------------------------------------
/scss/slider/images/slider-v.scss:
--------------------------------------------------------------------------------
1 | @import '../../mixins';
2 |
3 | @include exports('slider-v.gif') {
4 | @include register-data-uri('slider-v.gif', '')
5 | }
6 |
--------------------------------------------------------------------------------
/scss/splitter.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "splitter/layout";
11 | @import "splitter/theme";
12 |
--------------------------------------------------------------------------------
/scss/splitter/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("splitter/theme") {
2 |
3 | $splitter-bg: rgba( try-darken( $panel-bg, 8 ), .8 );
4 | $splitter-text: $panel-text;
5 | $splitter-hovered-bg: try-darken( $panel-bg, 8 );
6 | $splitter-hovered-text: $panel-text;
7 | $splitter-selected-bg: $selected-bg;
8 | $splitter-selected-text: contrast-wcag( $splitter-selected-bg );
9 |
10 | .k-splitter {
11 | background-clip: padding-box;
12 |
13 | .k-ie11 &,
14 | .k-edge12 &,
15 | .k-edge13 & {
16 | background-clip: border-box;
17 | }
18 | }
19 |
20 | // Splitbar
21 | .k-splitbar {
22 | color: $splitter-text;
23 | background-color: $splitter-bg;
24 |
25 | &:active,
26 | &.k-state-focused {
27 | color: $splitter-selected-text;
28 | background: $splitter-selected-bg;
29 | }
30 | }
31 | .k-splitbar-horizontal-hover,
32 | .k-splitbar-vertical-hover {
33 | color: $splitter-hovered-text;
34 | background-color: $splitter-hovered-bg;
35 | }
36 |
37 | .k-ghost-splitbar {
38 | background-color: $splitter-hovered-bg;
39 | }
40 |
41 | }
42 |
--------------------------------------------------------------------------------
/scss/spreadsheet.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "button";
8 | @import "tabstrip";
9 | @import "toolbar";
10 | @import "window";
11 |
12 |
13 | // Component
14 | @import "spreadsheet/layout";
15 | @import "spreadsheet/theme";
16 |
--------------------------------------------------------------------------------
/scss/spreadsheet/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("sreadsheet/theme") {
2 |
3 | // Spreadsheet
4 | .k-spreadsheet {
5 | background-clip: padding-box;
6 |
7 | .k-ie11 &,
8 | .k-edge12 &,
9 | .k-edge13 & {
10 | background-clip: border-box;
11 | }
12 | }
13 |
14 |
15 | // Header
16 | .k-spreadsheet .k-tabstrip-wrapper {}
17 |
18 |
19 | // Quick access toolbar
20 | .k-spreadsheet-quick-access-toolbar {}
21 |
22 |
23 | // Row / column headers
24 | .k-spreadsheet-top-corner {
25 | @include appearance( header );
26 | }
27 | .k-spreadsheet-row-header,
28 | .k-spreadsheet-column-header {
29 | @include appearance( header );
30 | }
31 |
32 |
33 | // Formula bar
34 | .k-spreadsheet-formula-list {}
35 | .k-syntax-ref { color: #ff8822; }
36 | .k-syntax-num { color: #0099ff; }
37 | .k-syntax-func { font-weight: bold; }
38 | .k-syntax-str { color: #38b714; }
39 | .k-syntax-error { color: red; }
40 | .k-syntax-bool { color: #a9169c; }
41 | .k-syntax-startexp { font-weight: bold; }
42 | .k-syntax-paren-match { background-color: #caf200; }
43 |
44 |
45 | // Cell editor
46 | .k-spreadsheet-cell-editor {
47 | color: $panel-text;
48 | background-color: $panel-bg;
49 | }
50 |
51 |
52 | // Selection
53 | .k-spreadsheet .k-selection-full,
54 | .k-spreadsheet .k-selection-partial {
55 | // TODO: consider extracting variables
56 | border-color: rgba( $header-selected-border, .25 );
57 | background-color: rgba( $header-selected-bg, .25 );
58 | }
59 | .k-spreadsheet-selection {
60 | border-color: $selected-bg;
61 | background-color: rgba( $selected-bg, .25 );
62 | box-shadow: inset 0 0 0 1px $selected-bg;
63 | }
64 | .k-spreadsheet .k-single-selection::after {
65 | border-color: $panel-bg;
66 | background-color: $selected-bg;
67 | }
68 | .k-spreadsheet-active-cell {
69 | box-shadow: inset 0 0 0 1px $selected-bg;
70 | background-color: $panel-bg;
71 |
72 | &.k-right {
73 | box-shadow: inset 0 0 0 1px $selected-bg, inset -1px 0 0 1px $selected-bg;
74 | }
75 |
76 | &.k-bottom {
77 | box-shadow: inset 0 0 0 1px $selected-bg, inset 0 -1px 0 1px $selected-bg;
78 | }
79 |
80 | &.k-bottom.k-right {
81 | box-shadow: inset 0 0 0 1px $selected-bg, inset -1px -1px 0 1px $selected-bg;
82 | }
83 | }
84 |
85 | .k-spreadsheet .k-auto-fill {
86 | border-color: $selected-bg;
87 | background-color: rgba( $selected-bg, .25 );
88 | box-shadow: inset 0 0 0 1px $selected-bg;
89 | }
90 | .k-spreadsheet .k-auto-fill-punch {
91 | background-color: rgba( $panel-bg, .5 );
92 | }
93 |
94 | }
95 |
96 |
97 |
98 |
99 | @include exports( "spreadsheet/filter/theme" ) {
100 |
101 | // Filter button
102 | .k-spreadsheet .k-filter-range {
103 | border-color: $accent;
104 | }
105 | .k-spreadsheet-filter {
106 | @include appearance( button );
107 | box-shadow: inset 0 0 0 1px $button-border;
108 |
109 | &.k-state-active {
110 | @include appearance( pressed-button );
111 | }
112 |
113 | &:hover {
114 | @include appearance( hovered-button );
115 | }
116 | }
117 |
118 |
119 | // Filter menu
120 | .k-spreadsheet-filter-menu {
121 |
122 | > .k-menu {
123 |
124 | .k-item.k-state-hover {
125 | @include appearance( hovered-list-item );
126 | }
127 | }
128 |
129 | .k-spreadsheet-value-treeview-wrapper {
130 | @include appearance( panel );
131 | }
132 | }
133 |
134 | }
135 |
136 |
137 |
138 |
139 | @include exports( "spreadsheet/tools/theme" ) {
140 |
141 | .k-spreadsheet-popup {
142 |
143 | // Buttons
144 | .k-button {}
145 |
146 | .k-button:hover,
147 | .k-button.k-state-hover {
148 | @include appearance( hovered-list-item );
149 | }
150 | .k-button:active,
151 | .k-button.k-state-active,
152 | .k-button.k-state-selected {
153 | @include appearance( selected-list-item );
154 | }
155 |
156 | }
157 |
158 | }
159 |
--------------------------------------------------------------------------------
/scss/switch.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "switch/layout";
11 | @import "switch/theme";
12 |
--------------------------------------------------------------------------------
/scss/switch/_layout.scss:
--------------------------------------------------------------------------------
1 | $switch-size: 3em !default;
2 | $switch-handle-size: (.8 * $switch-size) !default;
3 |
4 | @include exports('switch/layout') {
5 | $switch-border-width: 1px;
6 | $switch-padding: 2 * $switch-border-width;
7 |
8 | .k-switch {
9 | cursor: pointer;
10 | border: 0;
11 | display: inline-block;
12 | font-size: $font-size-xs;
13 | overflow: hidden;
14 | position: relative;
15 | text-align: left;
16 | user-select: none;
17 | vertical-align: middle;
18 | width: (2 * $switch-size);
19 | outline: 0;
20 |
21 | [type='checkbox'] {
22 | display: none;
23 | }
24 | }
25 |
26 | .k-switch,
27 | .k-switch-wrapper,
28 | .k-switch-container,
29 | .k-switch-handle {
30 | box-sizing: border-box;
31 | }
32 |
33 | .k-switch-wrapper {
34 | display: none; // TODO: do not render
35 | }
36 |
37 | .k-switch .k-switch-background {
38 | border-top-right-radius: 0;
39 | border-bottom-right-radius: 0;
40 | }
41 |
42 | .k-switch-container {
43 | padding: $switch-padding 0;
44 | display: block;
45 | width: 100%;
46 | background: transparent;
47 | transform: translateZ(0);
48 | outline: 0;
49 | }
50 |
51 | .k-switch-handle {
52 | position: relative;
53 | width: $switch-handle-size;
54 | height: $switch-handle-size;
55 | display: inline-block;
56 | margin: 0 ($switch-padding * 3) 0 $switch-padding;
57 | border-width: $switch-border-width;
58 | border-style: solid;
59 | vertical-align: middle;
60 | }
61 |
62 | .k-switch-label-off {
63 | left: $switch-size;
64 | }
65 |
66 | .k-switch-label-on {
67 | left: -$switch-handle-size;
68 | }
69 |
70 | .k-switch-label-on,
71 | .k-switch-label-off {
72 | top: -$switch-border-width;
73 | display: block;
74 | text-align: center;
75 | position: absolute;
76 | text-transform: uppercase;
77 | text-shadow: none;
78 | line-height: $switch-handle-size;
79 | vertical-align: middle;
80 | }
81 |
82 | .k-switch-container,
83 | .k-switch-wrapper {
84 | border-width: $switch-border-width;
85 | border-style: solid;
86 | }
87 |
88 |
89 |
90 | .k-switch[dir='rtl'] {
91 | .k-switch-label-off {
92 | left: -$switch-handle-size;
93 | }
94 |
95 | .k-switch-label-on {
96 | left: $switch-size;
97 | }
98 | }
99 | }
100 |
--------------------------------------------------------------------------------
/scss/switch/_theme.scss:
--------------------------------------------------------------------------------
1 | $switch-on-color: $accent !default;
2 | $switch-off-color: $text-color !default;
3 | $switch-border-color: $border-color !default;
4 | $switch-border-radius: ($switch-size / 2) !default;
5 | $switch-hover-border-color: $hovered-border !default;
6 | $switch-handle-shadow: 0 2px 4px 0 rgba(0, 0, 0, .06) !default;
7 | $switch-focus-shadow: inset 0 0 0 3px rgba(0, 0, 0, .06) !default;
8 | $switch-active-shadow: 0 0 0 2px rgba(0, 0, 0, .06) !default;
9 |
10 | @include exports('switch/theme') {
11 | .k-switch,
12 | .k-switch-wrapper,
13 | .k-switch-container {
14 | @include border-radius( $switch-border-radius );
15 | outline: 0;
16 | }
17 |
18 | .k-switch-container,
19 | .k-switch-wrapper {
20 | border-color: $switch-border-color;
21 | background-clip: padding-box;
22 |
23 | .k-ie11 &,
24 | .k-edge12 &,
25 | .k-edge13 & {
26 | background-clip: border-box;
27 | }
28 |
29 | &:hover {
30 | border-color: $switch-hover-border-color;
31 | }
32 | }
33 |
34 | .k-switch-wrapper {
35 | background-color: $widget-bg;
36 | }
37 |
38 | .k-switch-background {
39 | background-position: 4.3em 0;
40 | background-repeat: no-repeat;
41 | }
42 |
43 | .k-switch-handle {
44 | @include appearance( button );
45 | border-radius: 50%;
46 | background-clip: padding-box;
47 | box-shadow: $switch-handle-shadow;
48 |
49 | .k-ie11 &,
50 | .k-edge12 &,
51 | .k-edge13 & {
52 | background-clip: border-box;
53 | }
54 | }
55 |
56 | .k-switch-on {
57 | .k-switch-handle {
58 | @include appearance( primary-button );
59 |
60 | &:active {
61 | @include appearance( active-primary-button );
62 | }
63 | }
64 |
65 | &:hover {
66 | .k-switch-handle {
67 | @include appearance( hovered-primary-button );
68 | }
69 | }
70 | }
71 |
72 | .k-switch-off {
73 | &:hover {
74 | .k-switch-handle {
75 | @include appearance( hovered-button );
76 | }
77 | }
78 |
79 | &:action {
80 | @include fill( $button-text, $button-bg, $button-border, #{to top, $button-gradient} );
81 | }
82 | }
83 |
84 | .k-switch-label-on {
85 | color: $switch-on-color;
86 | background-color: transparent;
87 | }
88 |
89 | .k-switch-label-off {
90 | color: $switch-off-color;
91 | }
92 |
93 | .k-switch {
94 | &:focus,
95 | &.k-state-focused {
96 | outline: none;
97 | box-shadow: $switch-focus-shadow;
98 | }
99 |
100 | &:active {
101 | box-shadow: $switch-active-shadow;
102 | }
103 |
104 | &.k-state-disabled {
105 | cursor: auto;
106 |
107 | .k-switch-container,
108 | .k-switch-wrapper {
109 | border-color: $switch-border-color;
110 | box-shadow: none;
111 | }
112 |
113 | &:focus {
114 | box-shadow: none;
115 | }
116 |
117 | &.k-switch-on {
118 | .k-switch-handle {
119 | background: $accent;
120 | border-color: $accent;
121 | opacity: .5;
122 | }
123 | }
124 | }
125 | }
126 | }
127 |
--------------------------------------------------------------------------------
/scss/tabstrip.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "tabstrip/layout";
11 | @import "tabstrip/theme";
12 |
--------------------------------------------------------------------------------
/scss/tabstrip/_theme.scss:
--------------------------------------------------------------------------------
1 | $tabstrip-border: $panel-border !default;
2 | $tabstrip-item-text: $link-text !default;
3 | $tabstrip-item-bg: transparent !default;
4 | $tabstrip-item-border: transparent !default;
5 | $tabstrip-item-hovered-text: $link-hover-text !default;
6 | $tabstrip-item-hovered-bg: transparent !default;
7 | $tabstrip-item-hovered-border: transparent !default;
8 | $tabstrip-item-selected-text: $base-text !default;
9 | $tabstrip-item-selected-bg: $panel-bg !default;
10 | $tabstrip-item-selected-border: $panel-border !default;
11 | $tabstrip-content-text: $panel-text !default;
12 | $tabstrip-content-bg: $panel-bg !default;
13 | $tabstrip-content-border: $panel-bg !default;
14 |
15 | @include exports('tabstrip/theme') {
16 |
17 | .k-tabstrip {
18 | border-color: $tabstrip-border;
19 |
20 | .k-item {
21 | border-color: $tabstrip-item-border;
22 | color: $tabstrip-item-text;
23 | background-color: $tabstrip-item-bg;
24 | background-clip: padding-box;
25 |
26 | .k-ie11 &,
27 | .k-edge12 &,
28 | .k-edge13 & {
29 | background-clip: border-box;
30 | }
31 |
32 | &:hover,
33 | &.k-state-hover {
34 | border-color: $tabstrip-item-hovered-border;
35 | color: $tabstrip-item-hovered-text;
36 | background-color: $tabstrip-item-hovered-border;
37 | }
38 |
39 | &.k-state-active {
40 | border-color: $tabstrip-item-selected-border;
41 | color: $tabstrip-item-selected-text;
42 | background-color: $tabstrip-item-selected-bg;
43 | }
44 | }
45 |
46 | > .k-content {
47 | border-color: $tabstrip-content-border;
48 | color: $tabstrip-content-text;
49 | background-color: $tabstrip-content-bg;
50 | background-clip: padding-box;
51 |
52 | .k-ie11 &,
53 | .k-edge12 &,
54 | .k-edge13 & {
55 | background-clip: border-box;
56 | }
57 | }
58 | }
59 |
60 |
61 | // Tabstrip variants
62 | .k-tabstrip-top {
63 | > .k-tabstrip-items {
64 | .k-item.k-state-active {
65 | border-bottom-color: $tabstrip-item-selected-bg;
66 | }
67 | }
68 | }
69 | .k-tabstrip-bottom {
70 | > .k-tabstrip-items {
71 | .k-item.k-state-active {
72 | border-top-color: $tabstrip-item-selected-bg;
73 | }
74 | }
75 | }
76 | .k-tabstrip-left {
77 | > .k-tabstrip-items {
78 | .k-item.k-state-active {
79 | border-right-color: $tabstrip-item-selected-bg;
80 | }
81 | }
82 | }
83 | .k-tabstrip-right {
84 | > .k-tabstrip-items {
85 | .k-item.k-state-active {
86 | border-left-color: $tabstrip-item-selected-bg;
87 | }
88 | }
89 | }
90 |
91 | }
92 |
--------------------------------------------------------------------------------
/scss/toolbar.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "button";
8 |
9 |
10 | // Component
11 | @import "toolbar/layout";
12 | @import "toolbar/theme";
13 |
--------------------------------------------------------------------------------
/scss/toolbar/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("toolbar/layout") {
2 |
3 | // Base
4 | .k-toolbar {
5 | padding: $toolbar-padding-y ($toolbar-padding-x / 2);
6 | line-height: $form-line-height;
7 | display: flex;
8 | flex-direction: row;
9 | flex-wrap: wrap;
10 | align-items: center;
11 | justify-content: flex-start;
12 | position: relative;
13 | overflow: hidden;
14 |
15 | &.k-toolbar-resizable {
16 | flex-wrap: nowrap;
17 | }
18 |
19 | > * {
20 | display: inline-flex;
21 | align-items: stretch;
22 | align-content: center;
23 | vertical-align: middle;
24 | margin: 0 ($toolbar-padding-x / 2);
25 | }
26 |
27 | .k-button,
28 | .k-button-group,
29 | .k-separator,
30 | .k-split-button,
31 | .k-textbox,
32 | .k-widget,
33 | label {
34 | vertical-align: middle;
35 | }
36 |
37 |
38 | // Button
39 | .k-button {}
40 |
41 | // Toggle button
42 | .k-toggle-button {}
43 |
44 | // Split button
45 | .k-split-button {
46 | .k-button:hover {
47 | z-index: 2;
48 | }
49 |
50 | &:focus {
51 | outline: none;
52 | }
53 | }
54 |
55 |
56 | // Overflow anchor
57 | .k-overflow-anchor {
58 | @include border-radius( 0 );
59 | padding: $toolbar-padding-y;
60 | width: calc( #{$toolbar-inner-calc-size} );
61 | height: calc( #{$toolbar-inner-calc-size} );
62 | margin: 0;
63 | border-width: 0 0 0 1px;
64 | border-color: inherit;
65 | background-clip: padding-box;
66 | box-sizing: border-box;
67 | justify-content: center;
68 | position: absolute;
69 | top: 0;
70 | right: 0;
71 | }
72 |
73 |
74 | // Separator
75 | .k-separator {
76 | width: 0;
77 | margin-top: -$toolbar-padding-y;
78 | margin-bottom: -$toolbar-padding-y;
79 | border-width: 0 0 0 1px;
80 | border-style: solid;
81 | border-color: inherit;
82 | align-self: stretch;
83 | }
84 | }
85 |
86 |
87 | .k-overflow-container {
88 |
89 | // Group
90 | .k-overflow-tool-group {
91 | display: block;
92 | }
93 |
94 | // Hidden items
95 | .k-tool.k-state-disabled,
96 | .k-overflow-hidden {
97 | display: none;
98 | }
99 | }
100 |
101 | // RTL
102 | .k-rtl .k-toolbar {
103 |
104 | .k-overflow-anchor {
105 | right: auto;
106 | left: 0;
107 | border-width: 0 1px 0 0;
108 | }
109 | }
110 |
111 | }
112 |
--------------------------------------------------------------------------------
/scss/toolbar/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("toolbar/theme") {
2 |
3 | // Theme
4 | .k-toolbar {
5 | @include appearance( toolbar );
6 | background-clip: padding-box;
7 |
8 | .k-ie11 &,
9 | .k-edge12 &,
10 | .k-edge13 & {
11 | background-clip: border-box;
12 | }
13 |
14 |
15 | // Button normal state
16 | .k-button {
17 | border-color: transparent;
18 | color: inherit;
19 | background: none;
20 | background-clip: padding-box;
21 |
22 | .k-ie11 &,
23 | .k-edge12 &,
24 | .k-edge13 & {
25 | background-clip: border-box;
26 | }
27 |
28 | &:not(.k-overflow-anchor) {
29 | position: relative;
30 | }
31 |
32 | &::before,
33 | &::after {
34 | display: block;
35 | opacity: 0;
36 | pointer-events: none;
37 | position: absolute;
38 | z-index: -1;
39 | top: -1px;
40 | left: -1px;
41 | right: -1px;
42 | bottom: -1px;
43 | }
44 |
45 | &::before {
46 | content: "";
47 | background-color: currentColor;
48 | -webkit-transition: opacity .2s ease-in-out;
49 | transition: opacity .2s ease-in-out;
50 | }
51 |
52 | &::after {
53 | content: "";
54 | border: 2px solid currentColor;
55 | }
56 | }
57 |
58 |
59 | // Split button
60 | .k-split-button .k-button {
61 | @include appearance( button );
62 |
63 | &::before,
64 | &::after {
65 | display: none;
66 | }
67 | }
68 |
69 |
70 | // Split button
71 | .k-split-button .k-button {
72 | @include appearance( button );
73 | }
74 |
75 |
76 | // Button hover state
77 | .k-button:hover,
78 | .k-button.k-state-hover {
79 |
80 | &::before {
81 | opacity: .07;
82 | z-index: 1;
83 | }
84 | }
85 | .k-split-button {
86 | .k-button:hover,
87 | .k-button.k-state-hover {
88 | @include appearance( hovered-button );
89 | }
90 | }
91 |
92 |
93 | // Button focus state
94 | .k-button:focus,
95 | .k-button.k-state-focused {
96 | box-shadow: none;
97 |
98 | &::after {
99 | opacity: .08;
100 | z-index: 1;
101 | }
102 | }
103 |
104 | .k-split-button {
105 | .k-button:focus,
106 | .k-button.k-state-focused {
107 | border-color: $button-pressed-border;
108 | box-shadow: inset 0 0 0 1px $button-pressed-border;
109 | }
110 | }
111 | .k-split-button:focus {
112 | box-shadow: $button-focused-shadow;
113 | }
114 |
115 | // Button pressed state
116 | .k-button:active,
117 | .k-button.k-state-active {
118 |
119 | &::before,
120 | &::after {
121 | z-index: 1;
122 | }
123 |
124 | &::before {
125 | opacity: .07;
126 | }
127 | &::after {
128 | opacity: .13;
129 | }
130 | }
131 | .k-split-button {
132 |
133 | .k-button:active,
134 | .k-button.k-state-active {
135 | @include appearance( pressed-button );
136 | box-shadow: none;
137 | }
138 | }
139 | .k-state-border-down .k-split-button-arrow {
140 | box-shadow: inset $button-pressed-shadow;
141 | }
142 |
143 | // Button disabled state
144 | .k-button.k-state-disabled {
145 |
146 | &::after {
147 | opacity: 0;
148 | }
149 | }
150 |
151 |
152 | // Button group
153 | .k-button-group {}
154 | .k-button-group .k-group-start,
155 | .k-button-group .k-button:first-child,
156 | .k-button-group .k-group-end,
157 | .k-button-group .k-button:last-child {
158 | @include border-radius( 0 );
159 | }
160 |
161 |
162 | // Overflow anchor
163 | .k-overflow-anchor {
164 | border-width: 0;
165 | }
166 |
167 | }
168 |
169 | }
170 |
--------------------------------------------------------------------------------
/scss/tooltip.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "tooltip/layout";
11 | @import "tooltip/theme";
12 |
--------------------------------------------------------------------------------
/scss/tooltip/_layout.scss:
--------------------------------------------------------------------------------
1 | // TODO: extract or remove tooltip padding variables
2 | $tooltip-padding-y: $padding-y !default;
3 | $tooltip-padding-x: $padding-x !default;
4 | $tooltip-callout-size: 12px !default;
5 |
6 | @include exports("tooltip/layout") {
7 |
8 | .k-tooltip {
9 | @include border-radius();
10 | padding: $tooltip-padding-y $tooltip-padding-x;
11 | border-width: 0;
12 | background-repeat: repeat-x;
13 | position: absolute;
14 | z-index: 12000;
15 | }
16 |
17 | .k-tooltip-closable {
18 | padding: ($padding-y * 3) ($padding-x * 2);
19 | }
20 |
21 | .k-tooltip-closable .k-tooltip-content {
22 | padding-right: (5 * $icon-size) / 4;
23 | }
24 |
25 | .k-tooltip-button {
26 | height: 0;
27 | text-align: right;
28 | margin-right: -2px;
29 |
30 | .k-icon {
31 | color: inherit;
32 | vertical-align: top;
33 | }
34 | }
35 |
36 | // Callout
37 | .k-callout {
38 | position: absolute;
39 | width: 0;
40 | height: 0;
41 | border-style: solid;
42 | border-width: 6px;
43 | border-color: transparent;
44 | pointer-events: none;
45 | }
46 |
47 | .k-callout-n {
48 | top: -$tooltip-callout-size;
49 | left: 50%;
50 | pointer-events: none;
51 | }
52 |
53 | .k-callout-w {
54 | top: 50%;
55 | left: -$tooltip-callout-size;
56 | pointer-events: none;
57 | }
58 |
59 | .k-callout-s {
60 | left: 50%;
61 | bottom: -$tooltip-callout-size;
62 | pointer-events: none;
63 | }
64 |
65 | .k-callout-e {
66 | top: 50%;
67 | right: -$tooltip-callout-size;
68 | pointer-events: none;
69 | }
70 | }
71 |
--------------------------------------------------------------------------------
/scss/tooltip/_theme.scss:
--------------------------------------------------------------------------------
1 | $tooltip-color: $accent-contrast !default;
2 | $tooltip-bg: $accent !default;
3 |
4 | @include exports("tooltip/theme") {
5 | .k-tooltip {
6 | color: $tooltip-color;
7 | background-color: $tooltip-bg;
8 | }
9 |
10 | .k-callout-n {
11 | border-bottom-color: $tooltip-bg;
12 | }
13 |
14 | .k-callout-e {
15 | border-left-color: $tooltip-bg;
16 | }
17 |
18 | .k-callout-s {
19 | border-top-color: $tooltip-bg;
20 | }
21 |
22 | .k-callout-w {
23 | border-right-color: $tooltip-bg;
24 | }
25 | }
26 |
--------------------------------------------------------------------------------
/scss/treelist.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "grid";
8 |
9 |
10 | // Component
11 | @import "treelist/layout";
12 |
--------------------------------------------------------------------------------
/scss/treelist/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("treelist/layout") {
2 |
3 | // Base
4 | .k-treelist {
5 | &.k-display-block.k-grid-lockedcolumns {
6 | display: block;
7 | }
8 |
9 | .k-status {
10 | padding: .4em .6em;
11 | line-height: 1.6em;
12 |
13 | .k-loading {
14 | vertical-align: baseline;
15 | margin-right: 5px;
16 | }
17 | }
18 |
19 | tr.k-hidden {
20 | display: none;
21 | }
22 |
23 | .k-treelist-dragging,
24 | .k-treelist-dragging .k-state-hover {
25 | cursor: default;
26 | }
27 |
28 | .k-drop-hint {
29 | position: absolute;
30 | z-index: 10000;
31 | visibility: hidden;
32 | width: 80px;
33 | height: 5px;
34 | margin-top: -3px;
35 | background-color: transparent;
36 | background-repeat: no-repeat;
37 | }
38 | }
39 |
40 | .k-drag-separator {
41 | display: inline-block;
42 | border-right: 1px solid;
43 | height: 1em;
44 | vertical-align: top;
45 | margin: 0 .5em;
46 | }
47 |
48 | }
49 |
--------------------------------------------------------------------------------
/scss/treelist/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("treelist/theme") {
2 |
3 | // Theme
4 | .k-treelist {}
5 |
6 | }
7 |
--------------------------------------------------------------------------------
/scss/treeview.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 |
8 |
9 | // Component
10 | @import "treeview/layout";
11 | @import "treeview/theme";
12 |
--------------------------------------------------------------------------------
/scss/treeview/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("treeview/layout") {
2 |
3 | $treeview-indent: 16px;
4 |
5 | // Base
6 | .k-treeview {
7 | border-width: 0;
8 | background: none;
9 | line-height: $form-line-height;
10 | cursor: default;
11 | overflow: auto;
12 | white-space: nowrap;
13 |
14 | .k-content,
15 | > .k-group,
16 | .k-item > .k-group {
17 | margin: 0;
18 | padding: 0;
19 | background: none;
20 | list-style: none;
21 | position: relative;
22 | overflow: hidden;
23 | }
24 |
25 | // Wrappers
26 | .k-top,
27 | .k-mid,
28 | .k-bot {
29 | display: flex;
30 | flex-direction: row;
31 | align-items: center;
32 | align-content: center;
33 | }
34 |
35 | // Items
36 | .k-item {
37 | outline-style: none;
38 | margin: 0;
39 | padding: 0 0 0 $treeview-indent;
40 | border-width: 0;
41 | display: block;
42 | }
43 |
44 | // Link
45 | .k-in {
46 | @include border-radius();
47 | margin: 0;
48 | padding: $button-padding-y $button-padding-x;
49 | border: 1px solid transparent;
50 | text-decoration: none;
51 | display: inline-flex;
52 | align-items: center;
53 | align-content: center;
54 | vertical-align: middle;
55 | position: relative;
56 | }
57 |
58 | // Expand / collapse
59 | .k-i-expand,
60 | .k-i-collapse {
61 | margin-left: -$treeview-indent;
62 | cursor: pointer;
63 | }
64 |
65 | // Other content
66 | .k-checkbox-wrapper {
67 | margin-right: $icon-spacing;
68 | }
69 | .k-in .k-icon,
70 | .k-in .k-image,
71 | .k-in .k-sprite {
72 | margin-right: $icon-spacing;
73 | }
74 | .k-checkbox-label {
75 | padding-left: $icon-size;
76 | }
77 |
78 | }
79 |
80 |
81 |
82 |
83 | // RTL
84 | .k-rtl .k-treeview {
85 |
86 | // Items
87 | .k-item {
88 | padding-left: 0;
89 | padding-right: $treeview-indent;
90 | }
91 |
92 | // Expand / collapse
93 | .k-i-expand,
94 | .k-i-collapse {
95 | margin-left: 0;
96 | margin-right: -$treeview-indent;
97 | }
98 |
99 | // Other content
100 | .k-checkbox-wrapper {
101 | margin-left: $icon-spacing;
102 | margin-right: 0;
103 | }
104 | .k-in .k-icon,
105 | .k-in .k-image,
106 | .k-in .k-sprite {
107 | margin-left: $icon-spacing;
108 | margin-right: 0;
109 | }
110 |
111 | }
112 |
113 | }
114 |
--------------------------------------------------------------------------------
/scss/treeview/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("treeview/theme") {
2 |
3 |
4 | $treeview-item-border-width: 0;
5 | $treeview-item-border-radius: 0;
6 | $treeview-item-focused-shadow: $focused-shadow;
7 |
8 |
9 | // Appearance
10 | .k-treeview {
11 |
12 | // Link
13 | .k-in {
14 | @include border-radius( $treeview-item-border-radius );
15 | border-width: $treeview-item-border-width;
16 | }
17 | .k-in.k-state-hover {
18 | @include appearance( hovered-node );
19 | }
20 | .k-in.k-state-selected {
21 | @include appearance( selected-node );
22 | }
23 | .k-in.k-state-focused {
24 | box-shadow: $treeview-item-focused-shadow;
25 | }
26 | .k-in.k-state-disabled {}
27 | }
28 |
29 | }
30 |
--------------------------------------------------------------------------------
/scss/upload.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "common/icons";
8 | @import "button";
9 | @import "action-buttons";
10 |
11 |
12 | // Component
13 | @import "upload/layout";
14 | @import "upload/theme";
15 |
--------------------------------------------------------------------------------
/scss/validator.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "tooltip";
8 |
9 |
10 | // Component
11 | @import "validator/layout";
12 | @import "validator/theme";
13 |
--------------------------------------------------------------------------------
/scss/validator/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("validator/layout") {
2 |
3 | .k-tooltip-validation {
4 | margin: ($spacer / 2) 0 0;
5 | padding: 0;
6 | position: static;
7 | border-width: 0;
8 | display: inline-flex;
9 | align-items: center;
10 |
11 | &[hidden] {
12 | display: none;
13 | }
14 |
15 | > .k-icon {
16 | margin-right: ($padding-x / 2);
17 | }
18 |
19 | .k-callout {
20 | display: none;
21 | }
22 | }
23 |
24 | }
25 |
--------------------------------------------------------------------------------
/scss/validator/_theme.scss:
--------------------------------------------------------------------------------
1 | $validator-warning-bg: $warning !default;
2 | $validator-warning-text: darken($text-color, 40%) !default;
3 | $validator-warning-border: $validator-warning-bg !default;
4 |
5 | @include exports( "validator/theme" ) {
6 |
7 | .k-tooltip-validation {
8 | border-color: transparent;
9 | color: $error;
10 | background-color: transparent;
11 | }
12 |
13 | }
14 |
--------------------------------------------------------------------------------
/scss/window.scss:
--------------------------------------------------------------------------------
1 | @import "variables";
2 | @import "mixins";
3 |
4 |
5 | // Dependencies
6 | @import "common/all";
7 | @import "button";
8 | @import "action-buttons";
9 | @import "edit-form";
10 |
11 |
12 | // Component
13 | @import "window/layout";
14 | @import "window/theme";
15 |
--------------------------------------------------------------------------------
/scss/window/_layout.scss:
--------------------------------------------------------------------------------
1 | @include exports("window/layout") {
2 |
3 | $window-titlebar-border-width: 0 0 1px !default;
4 | $window-titlebar-border-style: solid !default;
5 |
6 | .k-window {
7 | padding: 0;
8 | max-width: 98vw;
9 | max-height: 98vh;
10 | border-width: 1px;
11 | border-style: solid;
12 | display: inline-flex;
13 | flex-direction: column;
14 | position: absolute;
15 | z-index: 10002;
16 |
17 | // overlay during dragging
18 | .k-overlay {
19 | position: absolute;
20 | opacity: 0;
21 | }
22 | }
23 |
24 | // Title bar
25 | .k-window-titlebar {
26 | padding: $window-titlebar-padding-y $window-titlebar-padding-x;
27 | border-width: $window-titlebar-border-width;
28 | border-style: $window-titlebar-border-style;
29 | white-space: nowrap;
30 | display: flex;
31 | flex-direction: row;
32 | flex-shrink: 0;
33 | align-items: center;
34 | }
35 |
36 | // Title bar title text
37 | .k-window-title {
38 | margin: 0;
39 | font-size: $font-size-lg;
40 | line-height: 1;
41 | text-overflow: ellipsis;
42 | overflow: hidden;
43 | cursor: default;
44 | flex: 1;
45 | }
46 |
47 |
48 | // Actions
49 | .k-window-actions {
50 | margin-top: add-two(-$button-padding-y, -$button-border-width);
51 | margin-bottom: add-two(-$button-padding-y, -$button-border-width);
52 | line-height: 1;
53 | display: flex;
54 | flex-direction: row;
55 | flex-shrink: 0;
56 | align-items: center;
57 | vertical-align: top;
58 | }
59 |
60 |
61 | // Content
62 | .k-window-content,
63 | .k-prompt-container {
64 | padding: $window-inner-padding-y $window-inner-padding-x;
65 | outline: 0;
66 | overflow: auto;
67 | position: relative;
68 | flex: 1 1 auto;
69 | }
70 | .k-window-content + .k-prompt-container {
71 | margin-top: -($window-inner-padding-y / 2);
72 | }
73 |
74 | .k-window-iframecontent {
75 | padding: 0;
76 | overflow: visible;
77 |
78 | .k-content-frame {
79 | vertical-align: top;
80 | border: 0;
81 | width: 100%;
82 | height: 100%;
83 | }
84 | }
85 | }
86 |
--------------------------------------------------------------------------------
/scss/window/_theme.scss:
--------------------------------------------------------------------------------
1 | @include exports("window/theme") {
2 |
3 | $window-border-color: rgba(0, 0, 0, .08) !default;
4 | $window-shadow: 0 3px 3px 0 rgba(0, 0, 0, .06) !default;
5 | $window-focused-shadow: 1px 1px 7px 1px rgba(0, 0, 0, .3) !default;
6 |
7 | $window-titlebar-border-color: inherit !default;
8 | $window-titlebar-bg: $header-bg !default;
9 | $window-titlebar-text: $header-text !default;
10 |
11 | .k-window {
12 | @include appearance( panel );
13 | border-width: 0;
14 | box-shadow: $window-shadow;
15 | }
16 | .k-window.k-state-focused {
17 | box-shadow: $window-focused-shadow;
18 | }
19 |
20 |
21 | // Titlebar
22 | .k-window-titlebar {
23 | @include fill( $window-titlebar-text, $window-titlebar-bg, $window-titlebar-border-color );
24 | background-clip: padding-box;
25 |
26 | .k-ie11 &,
27 | .k-edge12 &,
28 | .k-edge13 & {
29 | background-clip: border-box;
30 | }
31 |
32 | }
33 |
34 | }
35 |
--------------------------------------------------------------------------------
/tests/button-qunit.js:
--------------------------------------------------------------------------------
1 | QUnit.module("Button size", {
2 | before: function() {
3 | TestHelper.loadFixture( "/base/tests/fixtures/button.html" );
4 | },
5 | after: function() {
6 | TestHelper.clearFixture();
7 | }
8 | });
9 |
10 | QUnit.test("Generic button height should be 30", function( assert ) {
11 | var button = $("#button");
12 | var buttonHeight = getHeight( button );
13 |
14 | assert.equal( buttonHeight, metrics.button.height );
15 | });
16 |
--------------------------------------------------------------------------------
/tests/data/metrics.js:
--------------------------------------------------------------------------------
1 | var metrics = {
2 | "button": {
3 | "height": 30
4 | },
5 | "iconButton": {
6 | "width": 30,
7 | "height": 30
8 | }
9 | };
10 |
--------------------------------------------------------------------------------
/tests/fixtures/button.html:
--------------------------------------------------------------------------------
1 |
2 |
3 | Document
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 | Button
12 |
13 |
14 |
15 |
16 |
17 |
--------------------------------------------------------------------------------
/tests/fixtures/icons.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | Document
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
--------------------------------------------------------------------------------
/tests/lib/helpers.js:
--------------------------------------------------------------------------------
1 | ///
2 |
3 |
4 | var TestHelper = (function(){
5 |
6 | function TestHelper() {}
7 |
8 |
9 | // #region Fields
10 | TestHelper.fixture = null;
11 | TestHelper.fixtureID = "fixture_" + Date.now();
12 | var $fixture;
13 | // #endregion
14 |
15 |
16 | // #region Methods
17 | TestHelper.createFixture = function(id) {
18 | var fixture = document.createElement("div");
19 | fixture.id = id || TestHelper.fixtureID;
20 | document.body.appendChild(fixture);
21 |
22 | return fixture;
23 | };
24 | TestHelper.loadFixture = function(url) {
25 |
26 | var $ = window.jQuery;
27 |
28 | if (!TestHelper.fixture) {
29 | TestHelper.fixture = TestHelper.createFixture();
30 | TestHelper.$fixture = $(TestHelper.fixture);
31 | }
32 |
33 | $.ajax(url, {
34 | async: false,
35 | cache: false,
36 | success: function(data, status, $xhr) {
37 | var tmp = document.createElement("_CONTAINER");
38 | tmp.innerHTML = data;
39 | $(tmp).find("title, meta, link, style, script").remove();
40 | tmp.innerHTML = tmp.innerHTML.trim();
41 |
42 | TestHelper.$fixture.append(tmp.innerHTML);
43 |
44 | tmp.innerHTML = "";
45 | tmp = null;
46 | },
47 | error: function() {}
48 | });
49 | };
50 | TestHelper.clearFixture = function() {
51 | TestHelper.fixture.innerHTML = "";
52 | };
53 | TestHelper.removeFixture = function(){
54 | TestHelper.clearFixture();
55 | delete TestHelper.$fixture;
56 | TestHelper.fixture.remove();
57 | TestHelper.fixture = null;
58 | };
59 | // #endregion
60 |
61 |
62 | return TestHelper;
63 |
64 | })();
65 |
66 |
67 | (function() {
68 |
69 | // Qunit settings
70 | QUnit.config.noglobals = true;
71 | QUnit.config.fixture = "";
72 |
73 | QUnit.testStart(function() {
74 | TestHelper.fixture = TestHelper.createFixture();
75 | TestHelper.$fixture = $(TestHelper.fixture);
76 | });
77 |
78 | QUnit.testDone(function() {
79 | TestHelper.removeFixture();
80 | });
81 |
82 | })();
83 |
84 |
85 | // Test methods
86 | function getHeight(element) {
87 | var $ = window.jQuery;
88 |
89 | return $(element).outerHeight();
90 | }
91 | function getWidth(element) {
92 | var $ = window.jQuery;
93 |
94 | return $(element).outerWidth();
95 | }
96 | function getSize(element) {
97 | var $ = window.jQuery;
98 | var $element = $(element);
99 |
100 | return { width: $element.outerWidth(), height: $element.outerHeight() };
101 | }
102 |
--------------------------------------------------------------------------------
/third-party.md:
--------------------------------------------------------------------------------
1 | This Kendo UI theme uses code from the [Sass Color Helpers project](https://github.com/voxpelli/sass-color-helpers).
2 |
3 | The MIT License (MIT)
4 |
5 | Copyright © 2017 Pelle Wessman
6 |
7 | Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
8 |
9 | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
10 |
11 | THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
12 |
--------------------------------------------------------------------------------
/webpack.config.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 | /*
3 | * Build CSS out of SCSS files using webpack, reusing the
4 | * configuration already in place for react / ng2 components.
5 | * This script creates a webpack entry for each of the packages,
6 | * and passes it through the kendo-common-tasks theme config.
7 | */
8 | const glob = require('glob');
9 | const path = require('path');
10 | const fs = require('fs');
11 |
12 | const port = parseInt(process.env.PORT || 3000);
13 | const devServerPort = port + 1;
14 |
15 | /*
16 | * Webpack plug-in that reloads css via browser-sync upon build
17 | */
18 | function BrowserSync() {
19 | this.bs = require("browser-sync").create('bs-refresh');
20 | this.bs.init({
21 | open: false,
22 | proxy: `http://localhost:${devServerPort}/`,
23 | port: port,
24 | host: '0.0.0.0'
25 | });
26 | }
27 | BrowserSync.prototype = {
28 | apply: function(compiler) {
29 | compiler.plugin("emit", (compilation, callback) => {
30 | this.bs.reload("dist.css");
31 | callback();
32 | });
33 | }
34 | };
35 |
36 | let entry = { 'all': './build/all.js' };
37 |
38 | const components = process.env.COMPONENTS || null;
39 | if (components) {
40 | // custom build
41 | const fs = require('fs');
42 | const path = require('path');
43 | const imports = components.split(',')
44 | .map(c => `require("./../scss/${c}.scss");`).join('\n')
45 | fs.writeFileSync(path.join('build', 'custom.js'), imports);
46 | entry = { 'custom': './build/custom.js' };
47 | }
48 |
49 | const compat = process.argv.indexOf('--env.twbs-compat') > -1;
50 |
51 | if (compat) {
52 | entry = { 'twbs-compat': './build/twbs-compat.js' };
53 | }
54 |
55 | const inDevelopment = process.argv.find(v => v.includes('webpack-dev-server'))
56 | module.exports = require('@telerik/kendo-common-tasks')
57 | .webpackThemeConfig({ extract: true }, {
58 | devServer: {
59 | hot: true,
60 | inline: true,
61 | port: devServerPort
62 | },
63 | module: { loaders: [] },
64 | entry: entry,
65 | plugins: inDevelopment ? [ new BrowserSync() ] : [],
66 | output: {
67 | path: 'dist',
68 | publicPath: '/dist/',
69 | filename: '[name].js'
70 | }
71 | });
72 |
--------------------------------------------------------------------------------