@hashtagcms/admin-ui-kit 1.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +83 -0
- package/dist/admin-ui-kit.min.css +14 -0
- package/dist/admin-ui-kit.min.js +2 -0
- package/dist/admin-ui-kit.min.js.LICENSE.txt +175 -0
- package/package.json +53 -0
- package/packages/components/README.md +92 -0
- package/packages/components/package.json +28 -0
- package/packages/components/src/action-bar.vue +237 -0
- package/packages/components/src/category-platform.vue +97 -0
- package/packages/components/src/category-settings.vue +815 -0
- package/packages/components/src/cms-module-dropdown.vue +78 -0
- package/packages/components/src/downlods.vue +21 -0
- package/packages/components/src/file-uploader.vue +188 -0
- package/packages/components/src/frontend-module-creator.vue +599 -0
- package/packages/components/src/global-site-button.vue +94 -0
- package/packages/components/src/homepage.vue +1087 -0
- package/packages/components/src/html-slot.vue +23 -0
- package/packages/components/src/image-gallery.vue +144 -0
- package/packages/components/src/index.js +53 -0
- package/packages/components/src/info-boxes.vue +68 -0
- package/packages/components/src/info-popup.vue +121 -0
- package/packages/components/src/language-button.vue +80 -0
- package/packages/components/src/language-copier.vue +177 -0
- package/packages/components/src/left-nav.vue +159 -0
- package/packages/components/src/library/copy-paste.vue +186 -0
- package/packages/components/src/library/info-box.vue +102 -0
- package/packages/components/src/library/left-menu-show-hide.vue +47 -0
- package/packages/components/src/library/loader.vue +141 -0
- package/packages/components/src/library/modal-box.vue +136 -0
- package/packages/components/src/library/split-button.vue +127 -0
- package/packages/components/src/library/timer-button.vue +43 -0
- package/packages/components/src/library/toast-box.vue +53 -0
- package/packages/components/src/menu-sorter.vue +265 -0
- package/packages/components/src/module-creator.vue +650 -0
- package/packages/components/src/module-permission.vue +334 -0
- package/packages/components/src/pagination.vue +125 -0
- package/packages/components/src/platform-button.vue +118 -0
- package/packages/components/src/search-bar.vue +144 -0
- package/packages/components/src/site-button.vue +42 -0
- package/packages/components/src/site-cloner.vue +150 -0
- package/packages/components/src/sitewise-copier.vue +234 -0
- package/packages/components/src/sitewise-data.vue +347 -0
- package/packages/components/src/sorter.vue +239 -0
- package/packages/components/src/tabular-view.vue +824 -0
- package/packages/components/src/title-bar.vue +76 -0
- package/packages/components/src/top-nav.vue +96 -0
- package/packages/helpers/README.md +88 -0
- package/packages/helpers/package.json +20 -0
- package/packages/helpers/src/admin-config.js +9 -0
- package/packages/helpers/src/common.js +89 -0
- package/packages/helpers/src/dashboard.js +16 -0
- package/packages/helpers/src/editor.js +163 -0
- package/packages/helpers/src/error-message-handler.js +50 -0
- package/packages/helpers/src/event-bus.js +4 -0
- package/packages/helpers/src/form.js +4 -0
- package/packages/helpers/src/fx.js +106 -0
- package/packages/helpers/src/humanize.js +14 -0
- package/packages/helpers/src/map.js +3 -0
- package/packages/styles/README.md +37 -0
- package/packages/styles/package.json +15 -0
- package/packages/styles/src/_action-bar.scss +35 -0
- package/packages/styles/src/_admin.scss +22 -0
- package/packages/styles/src/_animate.scss +1579 -0
- package/packages/styles/src/_badges.scss +34 -0
- package/packages/styles/src/_category-list.scss +14 -0
- package/packages/styles/src/_common.scss +163 -0
- package/packages/styles/src/_info-box.scss +96 -0
- package/packages/styles/src/_left-nav.scss +59 -0
- package/packages/styles/src/_loader.scss +82 -0
- package/packages/styles/src/_menu-sorter.scss +39 -0
- package/packages/styles/src/_model-creator.scss +48 -0
- package/packages/styles/src/_module-permission.scss +25 -0
- package/packages/styles/src/_page-manager.scss +63 -0
- package/packages/styles/src/_popover-modal.scss +20 -0
- package/packages/styles/src/_table-grid.scss +39 -0
- package/packages/styles/src/_toast.scss +20 -0
- package/packages/styles/src/_variables.scss +37 -0
- package/packages/styles/src/app.scss +2 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2025 HashtagCMS
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
# HashtagCMS Admin UI Kit
|
|
2
|
+
|
|
3
|
+
Welcome to the official **HashtagCMS Admin UI Kit** monorepo. This repository houses the core modular logic, UI components, and utility libraries that power the HashtagCMS ecosystem.
|
|
4
|
+
|
|
5
|
+
## 📦 Package
|
|
6
|
+
|
|
7
|
+
Everything is bundled into a single NPM package for easier consumption.
|
|
8
|
+
|
|
9
|
+
| Package | Description | Version |
|
|
10
|
+
| :------------------------------------------ | :---------------------------------------------------------- | :------ |
|
|
11
|
+
| **[`@hashtagcms/admin-ui-kit`](./packages)** | Unified Library containing Components, Helpers, and Styles. | `1.0.6` |
|
|
12
|
+
|
|
13
|
+
_Note: The internals are still modular (`packages/components`, `packages/helpers`), but consumers should import from the main package._
|
|
14
|
+
|
|
15
|
+
## 🚀 Getting Started
|
|
16
|
+
|
|
17
|
+
### Installation
|
|
18
|
+
|
|
19
|
+
```bash
|
|
20
|
+
npm install @hashtagcms/admin-ui-kit
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
### Usage
|
|
24
|
+
|
|
25
|
+
**Components & Helpers:**
|
|
26
|
+
|
|
27
|
+
```javascript
|
|
28
|
+
import {
|
|
29
|
+
ActionBar, // Components
|
|
30
|
+
AdminConfig,
|
|
31
|
+
Toast, // Helpers
|
|
32
|
+
} from "@hashtagcms/admin-ui-kit";
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
**Styles:**
|
|
36
|
+
|
|
37
|
+
```scss
|
|
38
|
+
// In your app.scss (Recommended: Use Source for overrides)
|
|
39
|
+
// Your own variables for themes
|
|
40
|
+
@import "./variables";
|
|
41
|
+
|
|
42
|
+
// Bootstrap (if needed by your local overrides, otherwise package might include it or expect it)
|
|
43
|
+
@import "~bootstrap/scss/bootstrap";
|
|
44
|
+
|
|
45
|
+
// Import HashtagCMS Admin UI Kit Styles (Source)
|
|
46
|
+
// Note: Requires Sass loader configuration
|
|
47
|
+
@import "~@hashtagcms/styles/src/app";
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
// Or Pre-compiled CSS (Easiest)
|
|
51
|
+
// Must be imported if you are not using the source SCSS
|
|
52
|
+
@import "~@hashtagcms/admin-ui-kit/dist/admin-ui-kit.min.css";
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
## Documentation
|
|
56
|
+
|
|
57
|
+
Detailed guides for every part of the library:
|
|
58
|
+
|
|
59
|
+
- [**Integration Guide**](./docs/INTEGRATION_GUIDE.md): Setup and framework integration.
|
|
60
|
+
- [**Components Guide**](./docs/COMPONENTS_GUIDE.md): Component API and examples.
|
|
61
|
+
- [**Helpers Guide**](./docs/HELPERS_GUIDE.md): Utilities and helpers documentation.
|
|
62
|
+
- [**Styles Guide**](./docs/STYLES_GUIDE.md): Customization and SCSS variables.
|
|
63
|
+
|
|
64
|
+
## 🛠️ Development
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
This project uses **NPM Workspaces** to manage dependencies.
|
|
68
|
+
|
|
69
|
+
- **Linting**: Ensure code quality standards are met.
|
|
70
|
+
- **Testing**: Run unit tests with `npm run test`.
|
|
71
|
+
- **Playground**: Interactive dev environment. Run `npm run playground` and visit `http://localhost:3000`.
|
|
72
|
+
|
|
73
|
+
## 🤝 Contributing
|
|
74
|
+
|
|
75
|
+
We welcome contributions! Please see our [Contribution Guide](CONTRIBUTING.md) for details.
|
|
76
|
+
|
|
77
|
+
## 📄 License
|
|
78
|
+
|
|
79
|
+
This project is licensed under the [MIT License](LICENSE).
|
|
80
|
+
|
|
81
|
+
---
|
|
82
|
+
|
|
83
|
+
_Built with ❤️ by [HashtagCMS](https://github.com/hashtagcms)._
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* HashtagCMS Admin UI Kit v1.0.7
|
|
3
|
+
* Copyright (c) 2026 Marghoob Suleman
|
|
4
|
+
* Link: https://hashtagcms.org
|
|
5
|
+
* Licensed under MIT
|
|
6
|
+
*/
|
|
7
|
+
.t_left{font-size:.8rem;background:#313131;color:#fff;padding:0;box-shadow:0 5px 15px 1px rgba(0,0,0,.2),0 0 200px 1px hsla(0,0%,100%,.2)}.t_left .fa-icons{padding-right:5px}.t_left a{color:#fff;display:block;text-decoration:none;padding:5px 10px}.t_left a:hover{background:#f5008b}.t_left .adjustMore{font-size:.7rem;padding:8px 15px;position:relative;top:-5px;right:-10px}.t_left a.active{background:#f5008b;color:#fff;border-bottom:0 solid #c3c3c3}.t_left ul ul li a{color:#fff;transition:all .15s;padding-left:25px}.t_left ul ul li a:hover{background:#f5008b}.t_left ul ul li a.active{background:#d50179}.t_left ul ul{display:none}.t_left ul ul.active{display:block;background:#52514f}.info-box{min-width:150px}.info-box:hover{border:1px solid #9d9d9d}.info-box .info-box-icon{display:block;text-align:center;font-size:37px;background:#fff;padding:20px}.info-box .info-box-number{display:block;font-weight:bold;font-size:18px}.info-box .info-box-text{display:block;text-align:center;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase}.color-1{background:#ff1493 !important;color:#fff !important}.color-2{background:#00bfff !important;color:#fff !important}.color-3{background:#006400 !important;color:#fff !important}.color-4{background:coral !important;color:#fff !important}.color-5{background:#8b008b !important;color:#fff !important}.color-6{background:#00008b !important;color:#fff !important}.color-7{background:#008b8b !important;color:#fff !important}.color-8{background:#556b2f !important;color:#fff !important}.color-9{background:#b8860b !important;color:#fff !important}.color-10{background:#483d8b !important;color:#fff !important}.color-1 a,.color-1 a:visited,.color-2 a,.color-2 a:visited,.color-3 a,.color-3 a:visited,.color-4 a,.color-4 a:visited,.color-5 a,.color-5 a:visited,.color-6 a,.color-6 a:visited,.color-7 a,.color-7 a:visited,.color-8 a,.color-8 a:visited,.color-9 a,.color-9 a:visited,.color-10 a,.color-10 a:visited{color:#fff}.table-grid{font-size:.8rem}.table-grid a,.table-grid a:visited{border:none;text-decoration:none}.table-grid td{border:1px solid #c3c3c3;padding:.5rem}.table-grid .header{font-weight:bold}.table-grid th{background-color:#f2f2f2 !important;text-transform:uppercase;border:1px solid #c3c3c3}.table-grid .table-links,.table-grid .table-links:visited{color:inherit}.actions a{color:#636b6f;padding:10px 3px}.actions a:hover{color:maroon}.actions a.approved{color:coral}.actionToolbar *{font-size:12px}.actionToolbar .btn{padding:10px}.actionToolbar .dropdown-menu li:hover{background:#f3f3f3;color:#666}.actionToolbar .dropdown a.lang{border-top-right-radius:0;border-bottom-right-radius:0}.searchForm *{font-size:14px}.searchForm div.space-between{padding:5px 2px;background:#f3f3f3}.searchForm div.space-between:first-child{padding-left:5px}.searchForm .btn-space{margin-right:2px;margin-left:2px}.non-selectable{-webkit-user-select:none;-ms-user-select:none;user-select:none}.js_right_panel{font-size:.8rem}.hook-header{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.hook-header a,.hook-header a:visited{color:#3c763d}.modules-list{padding:0;margin:0}.modules-list li{list-style-type:none;border:1px dotted #c3c3c3;padding:5px;margin:3px 0;border-radius:3px}.modules-list li .delete{display:none}.modules-list li a{color:#666}.modules-list li .fa{margin-top:3px}.modules-list li:hover{background-color:#f2f2f2}.modules-list li:hover .delete{display:inline-block}.all-modules-right li:hover .delete{display:none}.module-drop-eager{background-color:#ffffe0;padding-bottom:30px}.loaderModal{width:100%;height:100%;background:#000;opacity:.2;position:fixed;top:0;left:0;z-index:1999}.loaderPanel{border:1px solid #c3c3c3;display:inline-block;padding:5px;position:fixed;left:50%;top:50%;background:#fff;z-index:2000}.loaderPanel .loaderText{display:inline-block;position:relative;top:-10px;padding-left:10px}.loaderPanel .spinner{width:30px;height:30px;display:inline-block;animation:contanim 2s linear infinite}.loaderPanel .spinner svg{width:100%;height:100%;left:0;top:0;position:absolute;transform:rotate(-90deg)}.loaderPanel .spinner svg:nth-child(1) circle{stroke:#84ebbd;stroke-dasharray:1,300;stroke-dashoffset:0;animation:strokeanim 3s calc(.2s*(1)) ease infinite;transform-origin:center center}.loaderPanel .spinner svg:nth-child(2) circle{stroke:#4977ec;stroke-dasharray:1,300;stroke-dashoffset:0;animation:strokeanim 3s calc(.2s*(2)) ease infinite;transform-origin:center center}.loaderPanel .spinner svg:nth-child(3) circle{stroke:#f6bb67;stroke-dasharray:1,300;stroke-dashoffset:0;animation:strokeanim 3s calc(.2s*(3)) ease infinite;transform-origin:center center}.loaderPanel .spinner svg:nth-child(4) circle{stroke:#333841;stroke-dasharray:1,300;stroke-dashoffset:0;animation:strokeanim 3s calc(.2s*(4)) ease infinite;transform-origin:center center}@keyframes strokeanim{0%{stroke-dasharray:1,300;stroke-dashoffset:0}50%{stroke-dasharray:120,300;stroke-dashoffset:-58.548324585}100%{stroke-dasharray:120,300;stroke-dashoffset:-175.6449737549}}@keyframes contanim{100%{transform:rotate(360deg)}}.list-permission li{border-bottom:1px solid #c3c3c3}.list-permission li:hover{background-color:#f2f2f2}.list-permission li:hover .readonly{display:block}.list-permission li ul{margin-bottom:5px}.list-permission li ul li{border:0px none}.list-permission li .readonly{display:none}.sortable-list{padding:0;margin:0}.sortable-list li{list-style:none none;border:1px solid #c3c3c3;padding:5px;margin:3px 0;border-radius:3px}.sortable-list li .ellipsis{width:12px;text-align:center;padding:3px 0}.sortable-list li:hover{background-color:#f9f9f9}.sortable-list li .child{display:none;background:#f2f2f2}.accordion-control,.accordion-body{display:none}.accordion-control:checked~.accordion-body{display:block !important}.category-items li .icon-btn{display:none}.category-items li:hover{background-color:#f2f2f2}.category-items li:hover .icon-btn{display:inline-block;padding-top:0;padding-bottom:0}.popover .close{background:#666;border-radius:19%;padding:5px;font-size:10px;color:#fff;position:absolute;top:-7px}.modal .select-sm{font-size:.8rem}.fieldset{margin-bottom:20px;border:1px double #c3c3c3;padding:10px}.legendTitle{font-weight:bold;border:none 0;margin-bottom:10px}.fields,.models{background:#f7ecb5;padding:5px;margin-right:15px;border:1px solid #c3c3c3;position:relative;display:inline-block;margin-bottom:10px}.models:hover,.fields:hover{color:#000}.models .glyphicon,.fields .fa{float:right;position:absolute;top:-5px;right:-5px;background-color:#fff;cursor:pointer}.models_row{margin-bottom:10px}.tables_panel{max-height:300px;overflow:auto}.models-box{width:19rem}.toasterHolder{width:auto;min-width:200px;background:#333;padding:10px;text-align:center;float:left;color:#fff;font-size:11px;letter-spacing:1px;-moz-border-radius:5px;border-radius:5px;z-index:9999;position:absolute}.toasterHolder .toasterContent{text-align:center;color:#fff}.badge-primary{background-color:#007bff}.badge-secondary{background-color:#6c757d}.badge-success{background-color:#28a745}.badge-danger{background-color:#dc3545}.badge-warning{background-color:#ffc107;color:#212529}.badge-info{background-color:#17a2b8}.badge-light{background-color:#f8f9fa;color:#212529}.badge-dark{background-color:#343a40}a:hover{color:#f5008b}nav{font-size:.8rem}nav select{font-size:.8rem}nav a img.cms-logo{margin-bottom:3px}.hide{display:none}.pos-absolute{position:absolute}.form-group{margin-bottom:20px}.select-sm{width:auto}.btn-from-submit{min-width:100px}legend{float:none;width:auto;padding:0 10px}.new{font-size:8px;background-color:#ff1493;color:#fff;padding:2px;position:relative;top:-2px}.v-space{margin:20px 0 0 0}.counters{position:relative;top:12px;padding-left:20px}.admin-form{padding:10px 30px}.center-align{float:none;text-align:center}.border-bottom{border-bottom:1px solid #c3c3c3}.hand{cursor:pointer}.select-big{margin-bottom:8px}.pl20{padding-left:20px}.normal{font-weight:normal !important}.pb5{padding-bottom:5px}.ptb5{padding-top:5px;padding-bottom:5px}.p5{padding:5px}.plr5{padding-left:5px;padding-right:5px}.imgHeightFix img{height:100%}.imgWidthFix img{width:100%}.head_action{padding-right:20px !important}.left-zero{padding-left:0 !important}.is-invalid{border-color:maroon}.clearboth{clear:both}.panel .panel-footer{min-height:33px}.strong{font-weight:bold}.form-control.select{width:inherit;display:inline-block}.fixed{position:fixed}.width-auto{width:auto}.inline{display:inline}.width30percent{width:30%}.width40percent{width:40%}/*!
|
|
8
|
+
* animate.css -http://daneden.me/animate
|
|
9
|
+
* Version - 3.5.2
|
|
10
|
+
* Licensed under the MIT license - http://opensource.org/licenses/MIT
|
|
11
|
+
*
|
|
12
|
+
* Copyright (c) 2017 Daniel Eden
|
|
13
|
+
*/.animated{animation-duration:1s;animation-fill-mode:both}.animated.infinite{animation-iteration-count:infinite}.animated.hinge{animation-duration:2s}.animated.flipOutX,.animated.flipOutY,.animated.bounceIn,.animated.bounceOut{animation-duration:.75s}@keyframes bounce{from,20%,53%,80%,to{animation-timing-function:cubic-bezier(0.215, 0.61, 0.355, 1);transform:translate3d(0, 0, 0)}40%,43%{animation-timing-function:cubic-bezier(0.755, 0.05, 0.855, 0.06);transform:translate3d(0, -30px, 0)}70%{animation-timing-function:cubic-bezier(0.755, 0.05, 0.855, 0.06);transform:translate3d(0, -15px, 0)}90%{transform:translate3d(0, -4px, 0)}}.bounce{animation-name:bounce;transform-origin:center bottom}@keyframes flash{from,50%,to{opacity:1}25%,75%{opacity:0}}.flash{animation-name:flash}@keyframes pulse{from{transform:scale3d(1, 1, 1)}50%{transform:scale3d(1.05, 1.05, 1.05)}to{transform:scale3d(1, 1, 1)}}.pulse{animation-name:pulse}@keyframes rubberBand{from{transform:scale3d(1, 1, 1)}30%{transform:scale3d(1.25, 0.75, 1)}40%{transform:scale3d(0.75, 1.25, 1)}50%{transform:scale3d(1.15, 0.85, 1)}65%{transform:scale3d(0.95, 1.05, 1)}75%{transform:scale3d(1.05, 0.95, 1)}to{transform:scale3d(1, 1, 1)}}.rubberBand{animation-name:rubberBand}@keyframes shake{from,to{transform:translate3d(0, 0, 0)}10%,30%,50%,70%,90%{transform:translate3d(-10px, 0, 0)}20%,40%,60%,80%{transform:translate3d(10px, 0, 0)}}.shake{animation-name:shake}@keyframes headShake{0%{transform:translateX(0)}6.5%{transform:translateX(-6px) rotateY(-9deg)}18.5%{transform:translateX(5px) rotateY(7deg)}31.5%{transform:translateX(-3px) rotateY(-5deg)}43.5%{transform:translateX(2px) rotateY(3deg)}50%{transform:translateX(0)}}.headShake{animation-timing-function:ease-in-out;animation-name:headShake}@keyframes swing{20%{transform:rotate3d(0, 0, 1, 15deg)}40%{transform:rotate3d(0, 0, 1, -10deg)}60%{transform:rotate3d(0, 0, 1, 5deg)}80%{transform:rotate3d(0, 0, 1, -5deg)}to{transform:rotate3d(0, 0, 1, 0deg)}}.swing{transform-origin:top center;animation-name:swing}@keyframes tada{from{transform:scale3d(1, 1, 1)}10%,20%{transform:scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg)}30%,50%,70%,90%{transform:scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)}40%,60%,80%{transform:scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg)}to{transform:scale3d(1, 1, 1)}}.tada{animation-name:tada}@keyframes wobble{from{transform:none}15%{transform:translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg)}30%{transform:translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg)}45%{transform:translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg)}60%{transform:translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg)}75%{transform:translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg)}to{transform:none}}.wobble{animation-name:wobble}@keyframes jello{from,11.1%,to{transform:none}22.2%{transform:skewX(-12.5deg) skewY(-12.5deg)}33.3%{transform:skewX(6.25deg) skewY(6.25deg)}44.4%{transform:skewX(-3.125deg) skewY(-3.125deg)}55.5%{transform:skewX(1.5625deg) skewY(1.5625deg)}66.6%{transform:skewX(-0.78125deg) skewY(-0.78125deg)}77.7%{transform:skewX(0.390625deg) skewY(0.390625deg)}88.8%{transform:skewX(-0.1953125deg) skewY(-0.1953125deg)}}.jello{animation-name:jello;transform-origin:center}@keyframes bounceIn{from,20%,40%,60%,80%,to{animation-timing-function:cubic-bezier(0.215, 0.61, 0.355, 1)}0%{opacity:0;transform:scale3d(0.3, 0.3, 0.3)}20%{transform:scale3d(1.1, 1.1, 1.1)}40%{transform:scale3d(0.9, 0.9, 0.9)}60%{opacity:1;transform:scale3d(1.03, 1.03, 1.03)}80%{transform:scale3d(0.97, 0.97, 0.97)}to{opacity:1;transform:scale3d(1, 1, 1)}}.bounceIn{animation-name:bounceIn}@keyframes bounceInDown{from,60%,75%,90%,to{animation-timing-function:cubic-bezier(0.215, 0.61, 0.355, 1)}0%{opacity:0;transform:translate3d(0, -3000px, 0)}60%{opacity:1;transform:translate3d(0, 25px, 0)}75%{transform:translate3d(0, -10px, 0)}90%{transform:translate3d(0, 5px, 0)}to{transform:none}}.bounceInDown{animation-name:bounceInDown}@keyframes bounceInLeft{from,60%,75%,90%,to{animation-timing-function:cubic-bezier(0.215, 0.61, 0.355, 1)}0%{opacity:0;transform:translate3d(-3000px, 0, 0)}60%{opacity:1;transform:translate3d(25px, 0, 0)}75%{transform:translate3d(-10px, 0, 0)}90%{transform:translate3d(5px, 0, 0)}to{transform:none}}.bounceInLeft{animation-name:bounceInLeft}@keyframes bounceInRight{from,60%,75%,90%,to{animation-timing-function:cubic-bezier(0.215, 0.61, 0.355, 1)}from{opacity:0;transform:translate3d(3000px, 0, 0)}60%{opacity:1;transform:translate3d(-25px, 0, 0)}75%{transform:translate3d(10px, 0, 0)}90%{transform:translate3d(-5px, 0, 0)}to{transform:none}}.bounceInRight{animation-name:bounceInRight}@keyframes bounceInUp{from,60%,75%,90%,to{animation-timing-function:cubic-bezier(0.215, 0.61, 0.355, 1)}from{opacity:0;transform:translate3d(0, 3000px, 0)}60%{opacity:1;transform:translate3d(0, -20px, 0)}75%{transform:translate3d(0, 10px, 0)}90%{transform:translate3d(0, -5px, 0)}to{transform:translate3d(0, 0, 0)}}.bounceInUp{animation-name:bounceInUp}@keyframes bounceOut{20%{transform:scale3d(0.9, 0.9, 0.9)}50%,55%{opacity:1;transform:scale3d(1.1, 1.1, 1.1)}to{opacity:0;transform:scale3d(0.3, 0.3, 0.3)}}.bounceOut{animation-name:bounceOut}@keyframes bounceOutDown{20%{transform:translate3d(0, 10px, 0)}40%,45%{opacity:1;transform:translate3d(0, -20px, 0)}to{opacity:0;transform:translate3d(0, 2000px, 0)}}.bounceOutDown{animation-name:bounceOutDown}@keyframes bounceOutLeft{20%{opacity:1;transform:translate3d(20px, 0, 0)}to{opacity:0;transform:translate3d(-2000px, 0, 0)}}.bounceOutLeft{animation-name:bounceOutLeft}@keyframes bounceOutRight{20%{opacity:1;transform:translate3d(-20px, 0, 0)}to{opacity:0;transform:translate3d(2000px, 0, 0)}}.bounceOutRight{animation-name:bounceOutRight}@keyframes bounceOutUp{20%{transform:translate3d(0, -10px, 0)}40%,45%{opacity:1;transform:translate3d(0, 20px, 0)}to{opacity:0;transform:translate3d(0, -2000px, 0)}}.bounceOutUp{animation-name:bounceOutUp}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.fadeIn{animation-name:fadeIn}@keyframes fadeInDown{from{opacity:0;transform:translate3d(0, -100%, 0)}to{opacity:1;transform:none}}.fadeInDown{animation-name:fadeInDown}@keyframes fadeInDownBig{from{opacity:0;transform:translate3d(0, -2000px, 0)}to{opacity:1;transform:none}}.fadeInDownBig{animation-name:fadeInDownBig}@keyframes fadeInLeft{from{opacity:0;transform:translate3d(-100%, 0, 0)}to{opacity:1;transform:none}}.fadeInLeft{animation-name:fadeInLeft}@keyframes fadeInLeftBig{from{opacity:0;transform:translate3d(-2000px, 0, 0)}to{opacity:1;transform:none}}.fadeInLeftBig{animation-name:fadeInLeftBig}@keyframes fadeInRight{from{opacity:0;transform:translate3d(100%, 0, 0)}to{opacity:1;transform:none}}.fadeInRight{animation-name:fadeInRight}@keyframes fadeInRightBig{from{opacity:0;transform:translate3d(2000px, 0, 0)}to{opacity:1;transform:none}}.fadeInRightBig{animation-name:fadeInRightBig}@keyframes fadeInUp{from{opacity:0;transform:translate3d(0, 100%, 0)}to{opacity:1;transform:none}}.fadeInUp{animation-name:fadeInUp}@keyframes fadeInUpBig{from{opacity:0;transform:translate3d(0, 2000px, 0)}to{opacity:1;transform:none}}.fadeInUpBig{animation-name:fadeInUpBig}@keyframes fadeOut{from{opacity:1}to{opacity:0}}.fadeOut{animation-name:fadeOut}@keyframes fadeOutDown{from{opacity:1}to{opacity:0;transform:translate3d(0, 100%, 0)}}.fadeOutDown{animation-name:fadeOutDown}@keyframes fadeOutDownBig{from{opacity:1}to{opacity:0;transform:translate3d(0, 2000px, 0)}}.fadeOutDownBig{animation-name:fadeOutDownBig}@keyframes fadeOutLeft{from{opacity:1}to{opacity:0;transform:translate3d(-100%, 0, 0)}}.fadeOutLeft{animation-name:fadeOutLeft}@keyframes fadeOutLeftBig{from{opacity:1}to{opacity:0;transform:translate3d(-2000px, 0, 0)}}.fadeOutLeftBig{animation-name:fadeOutLeftBig}@keyframes fadeOutRight{from{opacity:1}to{opacity:0;transform:translate3d(100%, 0, 0)}}.fadeOutRight{animation-name:fadeOutRight}@keyframes fadeOutRightBig{from{opacity:1}to{opacity:0;transform:translate3d(2000px, 0, 0)}}.fadeOutRightBig{animation-name:fadeOutRightBig}@keyframes fadeOutUp{from{opacity:1}to{opacity:0;transform:translate3d(0, -100%, 0)}}.fadeOutUp{animation-name:fadeOutUp}@keyframes fadeOutUpBig{from{opacity:1}to{opacity:0;transform:translate3d(0, -2000px, 0)}}.fadeOutUpBig{animation-name:fadeOutUpBig}@keyframes flip{from{transform:perspective(400px) rotate3d(0, 1, 0, -360deg);animation-timing-function:ease-out}40%{transform:perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);animation-timing-function:ease-out}50%{transform:perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);animation-timing-function:ease-in}80%{transform:perspective(400px) scale3d(0.95, 0.95, 0.95);animation-timing-function:ease-in}to{transform:perspective(400px);animation-timing-function:ease-in}}.animated.flip{-webkit-backface-visibility:visible;backface-visibility:visible;animation-name:flip}@keyframes flipInX{from{transform:perspective(400px) rotate3d(1, 0, 0, 90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotate3d(1, 0, 0, -20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotate3d(1, 0, 0, 10deg);opacity:1}80%{transform:perspective(400px) rotate3d(1, 0, 0, -5deg)}to{transform:perspective(400px)}}.flipInX{-webkit-backface-visibility:visible !important;backface-visibility:visible !important;animation-name:flipInX}@keyframes flipInY{from{transform:perspective(400px) rotate3d(0, 1, 0, 90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotate3d(0, 1, 0, -20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotate3d(0, 1, 0, 10deg);opacity:1}80%{transform:perspective(400px) rotate3d(0, 1, 0, -5deg)}to{transform:perspective(400px)}}.flipInY{-webkit-backface-visibility:visible !important;backface-visibility:visible !important;animation-name:flipInY}@keyframes flipOutX{from{transform:perspective(400px)}30%{transform:perspective(400px) rotate3d(1, 0, 0, -20deg);opacity:1}to{transform:perspective(400px) rotate3d(1, 0, 0, 90deg);opacity:0}}.flipOutX{animation-name:flipOutX;-webkit-backface-visibility:visible !important;backface-visibility:visible !important}@keyframes flipOutY{from{transform:perspective(400px)}30%{transform:perspective(400px) rotate3d(0, 1, 0, -15deg);opacity:1}to{transform:perspective(400px) rotate3d(0, 1, 0, 90deg);opacity:0}}.flipOutY{-webkit-backface-visibility:visible !important;backface-visibility:visible !important;animation-name:flipOutY}@keyframes lightSpeedIn{from{transform:translate3d(100%, 0, 0) skewX(-30deg);opacity:0}60%{transform:skewX(20deg);opacity:1}80%{transform:skewX(-5deg);opacity:1}to{transform:none;opacity:1}}.lightSpeedIn{animation-name:lightSpeedIn;animation-timing-function:ease-out}@keyframes lightSpeedOut{from{opacity:1}to{transform:translate3d(100%, 0, 0) skewX(30deg);opacity:0}}.lightSpeedOut{animation-name:lightSpeedOut;animation-timing-function:ease-in}@keyframes rotateIn{from{transform-origin:center;transform:rotate3d(0, 0, 1, -200deg);opacity:0}to{transform-origin:center;transform:none;opacity:1}}.rotateIn{animation-name:rotateIn}@keyframes rotateInDownLeft{from{transform-origin:left bottom;transform:rotate3d(0, 0, 1, -45deg);opacity:0}to{transform-origin:left bottom;transform:none;opacity:1}}.rotateInDownLeft{animation-name:rotateInDownLeft}@keyframes rotateInDownRight{from{transform-origin:right bottom;transform:rotate3d(0, 0, 1, 45deg);opacity:0}to{transform-origin:right bottom;transform:none;opacity:1}}.rotateInDownRight{animation-name:rotateInDownRight}@keyframes rotateInUpLeft{from{transform-origin:left bottom;transform:rotate3d(0, 0, 1, 45deg);opacity:0}to{transform-origin:left bottom;transform:none;opacity:1}}.rotateInUpLeft{animation-name:rotateInUpLeft}@keyframes rotateInUpRight{from{transform-origin:right bottom;transform:rotate3d(0, 0, 1, -90deg);opacity:0}to{transform-origin:right bottom;transform:none;opacity:1}}.rotateInUpRight{animation-name:rotateInUpRight}@keyframes rotateOut{from{transform-origin:center;opacity:1}to{transform-origin:center;transform:rotate3d(0, 0, 1, 200deg);opacity:0}}.rotateOut{animation-name:rotateOut}@keyframes rotateOutDownLeft{from{transform-origin:left bottom;opacity:1}to{transform-origin:left bottom;transform:rotate3d(0, 0, 1, 45deg);opacity:0}}.rotateOutDownLeft{animation-name:rotateOutDownLeft}@keyframes rotateOutDownRight{from{transform-origin:right bottom;opacity:1}to{transform-origin:right bottom;transform:rotate3d(0, 0, 1, -45deg);opacity:0}}.rotateOutDownRight{animation-name:rotateOutDownRight}@keyframes rotateOutUpLeft{from{transform-origin:left bottom;opacity:1}to{transform-origin:left bottom;transform:rotate3d(0, 0, 1, -45deg);opacity:0}}.rotateOutUpLeft{animation-name:rotateOutUpLeft}@keyframes rotateOutUpRight{from{transform-origin:right bottom;opacity:1}to{transform-origin:right bottom;transform:rotate3d(0, 0, 1, 90deg);opacity:0}}.rotateOutUpRight{animation-name:rotateOutUpRight}@keyframes hinge{0%{transform-origin:top left;animation-timing-function:ease-in-out}20%,60%{transform:rotate3d(0, 0, 1, 80deg);transform-origin:top left;animation-timing-function:ease-in-out}40%,80%{transform:rotate3d(0, 0, 1, 60deg);transform-origin:top left;animation-timing-function:ease-in-out;opacity:1}to{transform:translate3d(0, 700px, 0);opacity:0}}.hinge{animation-name:hinge}@keyframes jackInTheBox{from{opacity:0;transform:scale(0.1) rotate(30deg);transform-origin:center bottom}50%{transform:rotate(-10deg)}70%{transform:rotate(3deg)}to{opacity:1;transform:scale(1)}}.jackInTheBox{animation-name:jackInTheBox}@keyframes rollIn{from{opacity:0;transform:translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg)}to{opacity:1;transform:none}}.rollIn{animation-name:rollIn}@keyframes rollOut{from{opacity:1}to{opacity:0;transform:translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg)}}.rollOut{animation-name:rollOut}@keyframes zoomIn{from{opacity:0;transform:scale3d(0.3, 0.3, 0.3)}50%{opacity:1}}.zoomIn{animation-name:zoomIn}@keyframes zoomInDown{from{opacity:0;transform:scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);animation-timing-function:cubic-bezier(0.55, 0.055, 0.675, 0.19)}60%{opacity:1;transform:scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);animation-timing-function:cubic-bezier(0.175, 0.885, 0.32, 1)}}.zoomInDown{animation-name:zoomInDown}@keyframes zoomInLeft{from{opacity:0;transform:scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);animation-timing-function:cubic-bezier(0.55, 0.055, 0.675, 0.19)}60%{opacity:1;transform:scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);animation-timing-function:cubic-bezier(0.175, 0.885, 0.32, 1)}}.zoomInLeft{animation-name:zoomInLeft}@keyframes zoomInRight{from{opacity:0;transform:scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);animation-timing-function:cubic-bezier(0.55, 0.055, 0.675, 0.19)}60%{opacity:1;transform:scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);animation-timing-function:cubic-bezier(0.175, 0.885, 0.32, 1)}}.zoomInRight{animation-name:zoomInRight}@keyframes zoomInUp{from{opacity:0;transform:scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);animation-timing-function:cubic-bezier(0.55, 0.055, 0.675, 0.19)}60%{opacity:1;transform:scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);animation-timing-function:cubic-bezier(0.175, 0.885, 0.32, 1)}}.zoomInUp{animation-name:zoomInUp}@keyframes zoomOut{from{opacity:1}50%{opacity:0;transform:scale3d(0.3, 0.3, 0.3)}to{opacity:0}}.zoomOut{animation-name:zoomOut}@keyframes zoomOutDown{40%{opacity:1;transform:scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);animation-timing-function:cubic-bezier(0.55, 0.055, 0.675, 0.19)}to{opacity:0;transform:scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);transform-origin:center bottom;animation-timing-function:cubic-bezier(0.175, 0.885, 0.32, 1)}}.zoomOutDown{animation-name:zoomOutDown}@keyframes zoomOutLeft{40%{opacity:1;transform:scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0)}to{opacity:0;transform:scale(0.1) translate3d(-2000px, 0, 0);transform-origin:left center}}.zoomOutLeft{animation-name:zoomOutLeft}@keyframes zoomOutRight{40%{opacity:1;transform:scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0)}to{opacity:0;transform:scale(0.1) translate3d(2000px, 0, 0);transform-origin:right center}}.zoomOutRight{animation-name:zoomOutRight}@keyframes zoomOutUp{40%{opacity:1;transform:scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);animation-timing-function:cubic-bezier(0.55, 0.055, 0.675, 0.19)}to{opacity:0;transform:scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);transform-origin:center bottom;animation-timing-function:cubic-bezier(0.175, 0.885, 0.32, 1)}}.zoomOutUp{animation-name:zoomOutUp}@keyframes slideInDown{from{transform:translate3d(0, -100%, 0);visibility:visible}to{transform:translate3d(0, 0, 0)}}.slideInDown{animation-name:slideInDown}@keyframes slideInLeft{from{transform:translate3d(-100%, 0, 0);visibility:visible}to{transform:translate3d(0, 0, 0)}}.slideInLeft{animation-name:slideInLeft}@keyframes slideInRight{from{transform:translate3d(100%, 0, 0);visibility:visible}to{transform:translate3d(0, 0, 0)}}.slideInRight{animation-name:slideInRight}@keyframes slideInUp{from{transform:translate3d(0, 100%, 0);visibility:visible}to{transform:translate3d(0, 0, 0)}}.slideInUp{animation-name:slideInUp}@keyframes slideOutDown{from{transform:translate3d(0, 0, 0)}to{visibility:hidden;transform:translate3d(0, 100%, 0)}}.slideOutDown{animation-name:slideOutDown}@keyframes slideOutLeft{from{transform:translate3d(0, 0, 0)}to{visibility:hidden;transform:translate3d(-100%, 0, 0)}}.slideOutLeft{animation-name:slideOutLeft}@keyframes slideOutRight{from{transform:translate3d(0, 0, 0)}to{visibility:hidden;transform:translate3d(100%, 0, 0)}}.slideOutRight{animation-name:slideOutRight}@keyframes slideOutUp{from{transform:translate3d(0, 0, 0)}to{visibility:hidden;transform:translate3d(0, -100%, 0)}}.slideOutUp{animation-name:slideOutUp}
|
|
14
|
+
.sortElem{margin-top:15px}.sortElem .parent{list-style:none;border:1px solid #cacaca;background:#fff}.sortElem .parent h3{font-size:16px;margin:0}.sortElem ul{padding:0}.sortElem .parent a{padding:10px;color:#666;display:block}.sortElem .parent ul{display:none}.sortElem .parent.active ul{display:block;background:#fff;border-top:1px solid #cacaca}.sortElem .parent.active ul li{list-style:none;margin-left:15px;line-height:normal}.sortElem .parent.active ul li a span{color:#000;font-weight:bold}.sortElem .parent.sortable-chosen{background:#f4f4f4}
|