bootstrap-bookingsync-sass 2.0.0 → 3.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (187) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +0 -18
  3. data/CHANGELOG.md +8 -0
  4. data/README.md +0 -112
  5. data/assets/javascripts/bookingsync/form.js +1 -1
  6. data/assets/stylesheets/_bootstrap-bookingsync.scss +0 -3
  7. data/assets/stylesheets/bookingsync/_modals.scss +0 -4
  8. data/docs/Gemfile +3 -2
  9. data/docs/content/assets/stylesheets/_icons.scss +0 -5
  10. data/docs/content/assets/stylesheets/_variables.scss +0 -1
  11. data/docs/content/brand/iconography.md +14 -16
  12. data/docs/layouts/sidebar.html +0 -7
  13. data/lib/bootstrap-bookingsync-sass.rb +9 -10
  14. data/lib/bootstrap/bookingsync/version.rb +1 -1
  15. metadata +3 -175
  16. data/.ember-cli +0 -9
  17. data/.eslintignore +0 -20
  18. data/.eslintrc.js +0 -105
  19. data/.jshintrc +0 -32
  20. data/.npmignore +0 -31
  21. data/.template-lintrc.js +0 -5
  22. data/.travis.yml +0 -84
  23. data/.watchmanconfig +0 -3
  24. data/CONTRIBUTING.md +0 -26
  25. data/LICENSE +0 -21
  26. data/addon/.gitkeep +0 -0
  27. data/addon/components/bsy-alert.js +0 -26
  28. data/addon/components/bsy-annotated-section.js +0 -8
  29. data/addon/components/bsy-annotated-section/annotation.js +0 -8
  30. data/addon/components/bsy-annotated-section/content.js +0 -8
  31. data/addon/components/bsy-button.js +0 -29
  32. data/addon/components/bsy-button/close.js +0 -13
  33. data/addon/components/bsy-checkbox.js +0 -16
  34. data/addon/components/bsy-icon.js +0 -33
  35. data/addon/components/bsy-input-addon.js +0 -16
  36. data/addon/components/bsy-input-addon/addon.js +0 -8
  37. data/addon/components/bsy-input-addon/input.js +0 -17
  38. data/addon/components/bsy-input.js +0 -42
  39. data/addon/components/bsy-modal.js +0 -17
  40. data/addon/components/bsy-modal/body.js +0 -8
  41. data/addon/components/bsy-modal/close.js +0 -7
  42. data/addon/components/bsy-modal/footer.js +0 -8
  43. data/addon/components/bsy-modal/header.js +0 -8
  44. data/addon/components/bsy-nav.js +0 -8
  45. data/addon/components/bsy-nav/item.js +0 -10
  46. data/addon/components/bsy-nav/link.js +0 -10
  47. data/addon/components/bsy-popover.js +0 -5
  48. data/addon/components/bsy-radio-buttons.js +0 -10
  49. data/addon/components/bsy-radio-buttons/button.js +0 -20
  50. data/addon/components/bsy-radio.js +0 -14
  51. data/addon/components/bsy-select-multiple.js +0 -14
  52. data/addon/components/bsy-select.js +0 -14
  53. data/addon/components/bsy-sheet.js +0 -7
  54. data/addon/components/bsy-sheet/header.js +0 -7
  55. data/addon/components/bsy-switch.js +0 -15
  56. data/addon/components/bsy-textarea.js +0 -17
  57. data/addon/templates/components/bsy-alert.hbs +0 -6
  58. data/addon/templates/components/bsy-annotated-section.hbs +0 -1
  59. data/addon/templates/components/bsy-annotated-section/annotation.hbs +0 -1
  60. data/addon/templates/components/bsy-annotated-section/content.hbs +0 -1
  61. data/addon/templates/components/bsy-button.hbs +0 -9
  62. data/addon/templates/components/bsy-button/close.hbs +0 -1
  63. data/addon/templates/components/bsy-checkbox.hbs +0 -8
  64. data/addon/templates/components/bsy-input-addon.hbs +0 -3
  65. data/addon/templates/components/bsy-input-addon/addon.hbs +0 -1
  66. data/addon/templates/components/bsy-input-addon/input.hbs +0 -8
  67. data/addon/templates/components/bsy-input.hbs +0 -14
  68. data/addon/templates/components/bsy-modal.hbs +0 -8
  69. data/addon/templates/components/bsy-modal/body.hbs +0 -1
  70. data/addon/templates/components/bsy-modal/close.hbs +0 -1
  71. data/addon/templates/components/bsy-modal/footer.hbs +0 -1
  72. data/addon/templates/components/bsy-modal/header.hbs +0 -2
  73. data/addon/templates/components/bsy-nav.hbs +0 -1
  74. data/addon/templates/components/bsy-nav/item.hbs +0 -1
  75. data/addon/templates/components/bsy-nav/link.hbs +0 -1
  76. data/addon/templates/components/bsy-radio-buttons.hbs +0 -3
  77. data/addon/templates/components/bsy-radio-buttons/button.hbs +0 -7
  78. data/addon/templates/components/bsy-radio.hbs +0 -9
  79. data/addon/templates/components/bsy-select-multiple.hbs +0 -11
  80. data/addon/templates/components/bsy-select.hbs +0 -13
  81. data/addon/templates/components/bsy-sheet.hbs +0 -1
  82. data/addon/templates/components/bsy-sheet/header.hbs +0 -1
  83. data/addon/templates/components/bsy-switch.hbs +0 -9
  84. data/addon/templates/components/bsy-textarea.hbs +0 -8
  85. data/app/.gitkeep +0 -0
  86. data/app/components/bsy-alert.js +0 -1
  87. data/app/components/bsy-annotated-section.js +0 -1
  88. data/app/components/bsy-annotated-section/annotation.js +0 -1
  89. data/app/components/bsy-annotated-section/content.js +0 -1
  90. data/app/components/bsy-button.js +0 -1
  91. data/app/components/bsy-button/close.js +0 -1
  92. data/app/components/bsy-checkbox.js +0 -1
  93. data/app/components/bsy-icon.js +0 -1
  94. data/app/components/bsy-input-addon.js +0 -1
  95. data/app/components/bsy-input-addon/addon.js +0 -1
  96. data/app/components/bsy-input-addon/input.js +0 -1
  97. data/app/components/bsy-input.js +0 -1
  98. data/app/components/bsy-modal.js +0 -1
  99. data/app/components/bsy-modal/body.js +0 -1
  100. data/app/components/bsy-modal/close.js +0 -1
  101. data/app/components/bsy-modal/footer.js +0 -1
  102. data/app/components/bsy-modal/header.js +0 -1
  103. data/app/components/bsy-nav.js +0 -1
  104. data/app/components/bsy-nav/item.js +0 -1
  105. data/app/components/bsy-nav/link.js +0 -1
  106. data/app/components/bsy-popover.js +0 -1
  107. data/app/components/bsy-radio-buttons.js +0 -1
  108. data/app/components/bsy-radio-buttons/button.js +0 -1
  109. data/app/components/bsy-radio.js +0 -1
  110. data/app/components/bsy-select-multiple.js +0 -1
  111. data/app/components/bsy-select.js +0 -1
  112. data/app/components/bsy-sheet.js +0 -1
  113. data/app/components/bsy-sheet/header.js +0 -1
  114. data/app/components/bsy-switch.js +0 -1
  115. data/app/components/bsy-textarea.js +0 -1
  116. data/assets/stylesheets/bookingsync/_ember-power-select.scss +0 -126
  117. data/assets/stylesheets/bookingsync/_ember-toggle.scss +0 -13
  118. data/assets/stylesheets/bookingsync/_ember-tooltips.scss +0 -15
  119. data/blueprints/ember-cli-bootstrap-bookingsync-sass/files/app/styles/app.scss +0 -3
  120. data/blueprints/ember-cli-bootstrap-bookingsync-sass/files/app/templates/application.hbs +0 -31
  121. data/blueprints/ember-cli-bootstrap-bookingsync-sass/files/ember-cli-build.js +0 -28
  122. data/blueprints/ember-cli-bootstrap-bookingsync-sass/index.js +0 -16
  123. data/config/deploy.js +0 -30
  124. data/config/ember-try.js +0 -83
  125. data/config/environment.js +0 -16
  126. data/docs/public/ember/assets/dummy-605390683726afd79cffdf529eb4531a.css +0 -28
  127. data/docs/public/ember/assets/dummy-daae8f1136db419cd268e84ad4f5c989.js +0 -2
  128. data/docs/public/ember/assets/vendor-226e4280b8b1da91e2e598b6726ea1f4.js +0 -28
  129. data/docs/public/ember/assets/vendor-d41d8cd98f00b204e9800998ecf8427e.css +0 -0
  130. data/docs/public/ember/crossdomain.xml +0 -15
  131. data/docs/public/ember/fonts/bookingsync/bookingsync-icons.eot +0 -0
  132. data/docs/public/ember/fonts/bookingsync/bookingsync-icons.svg +0 -60
  133. data/docs/public/ember/fonts/bookingsync/bookingsync-icons.ttf +0 -0
  134. data/docs/public/ember/fonts/bookingsync/bookingsync-icons.woff +0 -0
  135. data/docs/public/ember/fonts/bookingsync/bookingsync-icons.woff2 +0 -0
  136. data/docs/public/ember/fonts/bookingsync/bookingsync-smiles.eot +0 -0
  137. data/docs/public/ember/fonts/bookingsync/bookingsync-smiles.svg +0 -19
  138. data/docs/public/ember/fonts/bookingsync/bookingsync-smiles.ttf +0 -0
  139. data/docs/public/ember/fonts/bookingsync/bookingsync-smiles.woff +0 -0
  140. data/docs/public/ember/fonts/bookingsync/bookingsync-smiles.woff2 +0 -0
  141. data/docs/public/ember/index.html +0 -27
  142. data/docs/public/ember/robots.txt +0 -3
  143. data/ember-cli-build.js +0 -22
  144. data/index.js +0 -34
  145. data/package-lock.json +0 -20985
  146. data/package.json +0 -83
  147. data/testem.js +0 -25
  148. data/tests/dummy/app/app.js +0 -14
  149. data/tests/dummy/app/components/.gitkeep +0 -0
  150. data/tests/dummy/app/components/navbar/component.js +0 -5
  151. data/tests/dummy/app/components/navbar/template.hbs +0 -19
  152. data/tests/dummy/app/components/sidebar/component.js +0 -5
  153. data/tests/dummy/app/components/sidebar/template.hbs +0 -45
  154. data/tests/dummy/app/controllers/.gitkeep +0 -0
  155. data/tests/dummy/app/controllers/index.js +0 -42
  156. data/tests/dummy/app/helpers/.gitkeep +0 -0
  157. data/tests/dummy/app/index.html +0 -25
  158. data/tests/dummy/app/models/.gitkeep +0 -0
  159. data/tests/dummy/app/resolver.js +0 -3
  160. data/tests/dummy/app/router.js +0 -12
  161. data/tests/dummy/app/routes/.gitkeep +0 -0
  162. data/tests/dummy/app/styles/app.scss +0 -8
  163. data/tests/dummy/app/templates/application.hbs +0 -12
  164. data/tests/dummy/app/templates/components/.gitkeep +0 -0
  165. data/tests/dummy/app/templates/index.hbs +0 -299
  166. data/tests/dummy/config/environment.js +0 -52
  167. data/tests/dummy/config/optional-features.json +0 -3
  168. data/tests/dummy/config/targets.js +0 -18
  169. data/tests/dummy/public/robots.txt +0 -3
  170. data/tests/helpers/.gitkeep +0 -0
  171. data/tests/helpers/resolver.js +0 -11
  172. data/tests/index.html +0 -33
  173. data/tests/integration/.gitkeep +0 -0
  174. data/tests/integration/components/bsy-alert-test.js +0 -26
  175. data/tests/integration/components/bsy-button-test.js +0 -26
  176. data/tests/integration/components/bsy-checkbox-test.js +0 -77
  177. data/tests/integration/components/bsy-input-test.js +0 -120
  178. data/tests/integration/components/bsy-nav-test.js +0 -26
  179. data/tests/integration/components/bsy-nav/item-test.js +0 -26
  180. data/tests/integration/components/bsy-nav/link-test.js +0 -26
  181. data/tests/integration/components/bsy-popover-test.js +0 -28
  182. data/tests/integration/components/bsy-sheet-test.js +0 -26
  183. data/tests/integration/components/bsy-sheet/header-test.js +0 -26
  184. data/tests/integration/components/bsy-switch-test.js +0 -21
  185. data/tests/integration/components/bsy-textarea-test.js +0 -13
  186. data/tests/test-helper.js +0 -8
  187. data/vendor/.gitkeep +0 -0
@@ -1,16 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../templates/components/bsy-checkbox';
3
-
4
- const BsyCheckboxComponent = Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNames: 'checkbox',
8
-
9
- update() {}
10
- });
11
-
12
- BsyCheckboxComponent.reopenClass({
13
- positionalParams: ['checked']
14
- });
15
-
16
- export default BsyCheckboxComponent;
@@ -1,33 +0,0 @@
1
- import Component from '@ember/component';
2
- import { computed } from '@ember/object';
3
-
4
- const BsyIconComponent = Component.extend({
5
- tagName: 'i',
6
- classNameBindings: ['iconClass', 'iconSize', 'iconType', 'fixedWidth:icon-fw'],
7
-
8
- name: '',
9
- size: '',
10
- type: '',
11
- fixedWidth: false,
12
-
13
- iconClass: computed('name', function() {
14
- let name = this.get('name');
15
- return name ? `icon-${name}` : '';
16
- }),
17
-
18
- iconSize: computed('size', function() {
19
- let size = this.get('size');
20
- return size ? `icon-${size}` : '';
21
- }),
22
-
23
- iconType: computed('type', function() {
24
- let type = this.get('type');
25
- return type ? `icon-${type}` : '';
26
- })
27
- });
28
-
29
- BsyIconComponent.reopenClass({
30
- positionalParams: ['name']
31
- });
32
-
33
- export default BsyIconComponent;
@@ -1,16 +0,0 @@
1
- import Ember from 'ember';
2
- import Component from '@ember/component';
3
- import { computed } from '@ember/object';
4
- import layout from '../templates/components/bsy-input-addon';
5
-
6
- const { generateGuid } = Ember;
7
-
8
- export default Component.extend({
9
- layout,
10
- tagName: 'div',
11
- classNames: 'form-group',
12
-
13
- inputId: computed(function() {
14
- return generateGuid();
15
- })
16
- });
@@ -1,8 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../../templates/components/bsy-input-addon/addon';
3
-
4
- export default Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNames: 'input-group-addon'
8
- });
@@ -1,17 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../../templates/components/bsy-input-addon/input';
3
-
4
- const BsyInputAddonInputComponent = Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNameBindings: ['value:filled'],
8
- type: 'text',
9
-
10
- update() {}
11
- });
12
-
13
- BsyInputAddonInputComponent.reopenClass({
14
- positionalParams: ['value']
15
- });
16
-
17
- export default BsyInputAddonInputComponent;
@@ -1,42 +0,0 @@
1
- import Ember from 'ember';
2
- import Component from '@ember/component';
3
- import { computed } from '@ember/object';
4
- import layout from '../templates/components/bsy-input';
5
-
6
- const { generateGuid } = Ember;
7
-
8
- const BsyInputComponent = Component.extend({
9
- layout,
10
- tagName: 'div',
11
- classNames: 'form-group',
12
- type: 'text',
13
- readonly: false,
14
- placeholder: '',
15
- disabled: false,
16
- classNameBindings: ['value:filled', 'icon:has-icon', 'formGroupSize'],
17
- size: null, // sm, lg
18
-
19
- inputClassNames: computed('size', function() {
20
- return this.size ? `form-control input-${this.size}` : 'form-control';
21
- }),
22
-
23
- iconSize: computed('size', function() {
24
- return this.size ? `icon--${this.size}` : '';
25
- }),
26
-
27
- formGroupSize: computed('size', function() {
28
- return this.size ? `form-group--${this.size}` : '';
29
- }),
30
-
31
- inputId: computed(function() {
32
- return generateGuid();
33
- }),
34
-
35
- update() {}
36
- });
37
-
38
- BsyInputComponent.reopenClass({
39
- positionalParams: ['value']
40
- });
41
-
42
- export default BsyInputComponent;
@@ -1,17 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../templates/components/bsy-modal';
3
-
4
- export default Component.extend({
5
- layout,
6
- tagName: 'div',
7
-
8
- didRender() {
9
- this._super(...arguments);
10
- document.body.classList.add('modal-open');
11
- },
12
-
13
- willDestroyElement() {
14
- this._super(...arguments);
15
- document.body.classList.remove('modal-open');
16
- }
17
- });
@@ -1,8 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../../templates/components/bsy-modal/body';
3
-
4
- export default Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNames: 'modal-body'
8
- });
@@ -1,7 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../../templates/components/bsy-modal/close';
3
-
4
- export default Component.extend({
5
- layout,
6
- tagName: 'div'
7
- });
@@ -1,8 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../../templates/components/bsy-modal/footer';
3
-
4
- export default Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNames: 'modal-footer'
8
- });
@@ -1,8 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../../templates/components/bsy-modal/header';
3
-
4
- export default Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNames: 'modal-header'
8
- });
@@ -1,8 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../templates/components/bsy-nav';
3
-
4
- export default Component.extend({
5
- layout,
6
- tagName: 'ul',
7
- classNames: 'nav'
8
- });
@@ -1,10 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../../templates/components/bsy-nav/item';
3
-
4
- export default Component.extend({
5
- layout,
6
- tagName: 'li',
7
- classNames: 'nav-item',
8
- classNameBindings: ['active'],
9
- active: false
10
- });
@@ -1,10 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../../templates/components/bsy-nav/link';
3
-
4
- export default Component.extend({
5
- layout,
6
- tagName: 'a',
7
- classNames: 'nav-link',
8
- classNameBindings: ['active'],
9
- active: false
10
- });
@@ -1,5 +0,0 @@
1
- import EmberPopover from 'ember-tooltips/components/ember-popover';
2
-
3
- export default EmberPopover.extend({
4
- side: 'bottom'
5
- });
@@ -1,10 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../templates/components/bsy-radio-buttons';
3
-
4
- export default Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNames: 'btn-group',
8
- attributeBindings: ['role', 'aria-label'],
9
- role: 'group'
10
- });
@@ -1,20 +0,0 @@
1
- import Component from '@ember/component';
2
- import { computed } from '@ember/object';
3
- import layout from '../../templates/components/bsy-radio-buttons/button';
4
-
5
- const BsyRadioButtonsButtonComponent = Component.extend({
6
- layout,
7
- tagName: 'label',
8
- classNames: 'btn btn-secondary',
9
- classNameBindings: ['active'],
10
-
11
- active: computed('value', 'option', function() {
12
- return this.value === this.option;
13
- }).readOnly()
14
- });
15
-
16
- BsyRadioButtonsButtonComponent.reopenClass({
17
- positionalParams: ['value']
18
- });
19
-
20
- export default BsyRadioButtonsButtonComponent;
@@ -1,14 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../templates/components/bsy-radio';
3
-
4
- const BsyRadioComponent = Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNames: 'radio'
8
- });
9
-
10
- BsyRadioComponent.reopenClass({
11
- positionalParams: ['value']
12
- });
13
-
14
- export default BsyRadioComponent;
@@ -1,14 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../templates/components/bsy-select-multiple';
3
-
4
- const BsySelectMultipleComponent = Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNames: 'select'
8
- });
9
-
10
- BsySelectMultipleComponent.reopenClass({
11
- positionalParams: ['selected']
12
- });
13
-
14
- export default BsySelectMultipleComponent;
@@ -1,14 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../templates/components/bsy-select';
3
-
4
- const BsySelectComponent = Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNames: 'select'
8
- });
9
-
10
- BsySelectComponent.reopenClass({
11
- positionalParams: ['selected']
12
- });
13
-
14
- export default BsySelectComponent;
@@ -1,7 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../templates/components/bsy-sheet';
3
-
4
- export default Component.extend({
5
- layout,
6
- classNames: 'sheet'
7
- });
@@ -1,7 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../../templates/components/bsy-sheet/header';
3
-
4
- export default Component.extend({
5
- layout,
6
- classNames: 'sheet-header'
7
- });
@@ -1,15 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../templates/components/bsy-switch';
3
-
4
- export default Component.extend({
5
- layout,
6
- classNames: ['bsy-switch'],
7
-
8
- theme: 'light',
9
- size: 'medium',
10
- showLabels: false,
11
- onLabel: 'On',
12
- offLabel: 'Off',
13
- value: false,
14
- disabled: false
15
- });
@@ -1,17 +0,0 @@
1
- import Component from '@ember/component';
2
- import layout from '../templates/components/bsy-textarea';
3
-
4
- const BsyTextareaComponent = Component.extend({
5
- layout,
6
- tagName: 'div',
7
- classNames: 'form-group',
8
- classNameBindings: ['value:filled'],
9
-
10
- update() {}
11
- });
12
-
13
- BsyTextareaComponent.reopenClass({
14
- positionalParams: ['value']
15
- });
16
-
17
- export default BsyTextareaComponent;
@@ -1,6 +0,0 @@
1
- {{#if dismissible}}
2
- <button type="button" class="close" aria-label="Close" {{action "dismiss"}}>
3
- <span aria-hidden="true">&times;</span>
4
- </button>
5
- {{/if}}
6
- {{yield}}
@@ -1,9 +0,0 @@
1
- {{#if this.icon}}
2
- <i class="icon-{{icon}}"></i>
3
- {{/if}}
4
-
5
- {{#if this.isLoading}}
6
- {{this.loadingLabel}}
7
- {{else}}
8
- {{yield}}
9
- {{/if}}
@@ -1 +0,0 @@
1
- <span>&times;</span>
@@ -1,8 +0,0 @@
1
- <label>
2
- {{input
3
- type="checkbox"
4
- checked=checked
5
- onclick=update
6
- }}
7
- {{label}}
8
- </label>
@@ -1,3 +0,0 @@
1
- <div class="input-group">
2
- {{yield}}
3
- </div>
@@ -1,8 +0,0 @@
1
- <label class="control-label" for={{inputId}}>{{label}}</label>
2
- {{input
3
- value=value
4
- oninput=update
5
- class="form-control"
6
- type=type
7
- id=inputId
8
- }}
@@ -1,14 +0,0 @@
1
- <label for={{id}}>{{label}}</label>
2
- {{#if icon}}
3
- <i class="icon-{{icon}} {{iconSize}}"></i>
4
- {{/if}}
5
- {{input
6
- value=value
7
- oninput=update
8
- class=inputClassNames
9
- type=type
10
- id=inputId
11
- readonly=readonly
12
- placeholder=placeholder
13
- disabled=disabled
14
- }}