@iamproperty/components 3.1.0 → 3.4.4

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.
Files changed (179) hide show
  1. package/README.md +141 -16
  2. package/assets/css/core.min.css +1 -1
  3. package/assets/css/core.min.css.map +1 -1
  4. package/assets/css/style.min.css +1 -1
  5. package/assets/css/style.min.css.map +1 -1
  6. package/assets/favicons/manifest.json +31 -31
  7. package/assets/js/main.js +57 -57
  8. package/assets/js/modules/accordion.js +33 -32
  9. package/assets/js/modules/alert.js +41 -57
  10. package/assets/js/modules/carousel.js +76 -102
  11. package/assets/js/modules/chart.js +151 -218
  12. package/assets/js/modules/drawer.js +10 -16
  13. package/assets/js/modules/file-upload.js +33 -48
  14. package/assets/js/modules/form.js +122 -168
  15. package/assets/js/modules/helpers.js +90 -119
  16. package/assets/js/modules/modal.js +69 -90
  17. package/assets/js/modules/nav.js +18 -28
  18. package/assets/js/modules/orderablelist.js +91 -122
  19. package/assets/js/modules/table.js +451 -585
  20. package/assets/js/modules/testimonial.js +64 -83
  21. package/assets/js/modules/youtubevideo.js +114 -145
  22. package/assets/js/scripts.bundle.js +895 -955
  23. package/assets/js/scripts.bundle.js.map +1 -1
  24. package/assets/js/scripts.bundle.min.js +3 -3
  25. package/assets/js/scripts.bundle.min.js.map +1 -1
  26. package/assets/sass/_components.scss +14 -14
  27. package/assets/sass/_corefiles.scss +40 -40
  28. package/assets/sass/_fonts.scss +16 -16
  29. package/assets/sass/_forms.scss +10 -10
  30. package/assets/sass/_func.scss +12 -12
  31. package/assets/sass/_functions/functions.scss +141 -141
  32. package/assets/sass/_functions/mixins.scss +170 -170
  33. package/assets/sass/_functions/utilities.scss +143 -143
  34. package/assets/sass/_functions/variables.scss +467 -467
  35. package/assets/sass/_print.scss +61 -61
  36. package/assets/sass/_tests/{sass.spec.js → colours.spec.js} +9 -9
  37. package/assets/sass/_tests/colours.spec.scss +44 -44
  38. package/assets/sass/_tests/func.spec.js +9 -0
  39. package/assets/sass/_tests/func.spec.scss +232 -232
  40. package/assets/sass/_tests/mixins.spec.js +9 -0
  41. package/assets/sass/_tests/mixins.spec.scss +194 -194
  42. package/assets/sass/_tests/typography.spec.js +9 -0
  43. package/assets/sass/_tests/typography.spec.scss +35 -35
  44. package/assets/sass/components/accordion.scss +197 -197
  45. package/assets/sass/components/alert.scss +98 -98
  46. package/assets/sass/{elements → components}/buttons.scss +251 -251
  47. package/assets/sass/{elements → components}/card.scss +288 -288
  48. package/assets/sass/components/cardDeck.scss +107 -107
  49. package/assets/sass/components/carousel.scss +234 -234
  50. package/assets/sass/components/charts.scss +569 -569
  51. package/assets/sass/{elements → components}/container.scss +236 -236
  52. package/assets/sass/components/drawer.scss +46 -46
  53. package/assets/sass/{elements → components}/forms.scss +261 -261
  54. package/assets/sass/components/header.scss +63 -63
  55. package/assets/sass/{elements → components}/links.scss +97 -97
  56. package/assets/sass/{elements → components}/lists.scss +159 -159
  57. package/assets/sass/components/modal.scss +136 -136
  58. package/assets/sass/components/nav.scss +960 -960
  59. package/assets/sass/{elements → components}/panel.scss +161 -161
  60. package/assets/sass/components/property-searchbar.scss +143 -143
  61. package/assets/sass/components/snapshot.scss +70 -70
  62. package/assets/sass/components/stepper.scss +164 -164
  63. package/assets/sass/{elements → components}/tables.scss +290 -290
  64. package/assets/sass/components/tabs.scss +87 -87
  65. package/assets/sass/components/testimonial.scss +132 -132
  66. package/assets/sass/components/timeline.scss +95 -95
  67. package/assets/sass/{elements → components}/tooltips.scss +84 -84
  68. package/assets/sass/core.scss +6 -6
  69. package/assets/sass/email.scss +65 -65
  70. package/assets/sass/error.scss +4 -4
  71. package/assets/sass/foundations/brand.scss +76 -72
  72. package/assets/sass/foundations/circles.scss +74 -74
  73. package/assets/sass/foundations/icons.scss +80 -80
  74. package/assets/sass/foundations/media.scss +50 -50
  75. package/assets/sass/foundations/reboot.scss +130 -130
  76. package/assets/sass/foundations/root.scss +125 -125
  77. package/assets/sass/{elements → foundations}/type.scss +136 -136
  78. package/assets/sass/main.scss +7 -7
  79. package/assets/svg/icons.svg +598 -598
  80. package/assets/svg/logo.svg +49 -43
  81. package/assets/ts/main.ts +68 -68
  82. package/assets/ts/modules/accordion.ts +44 -43
  83. package/assets/ts/modules/alert.ts +58 -0
  84. package/assets/ts/modules/carousel.ts +103 -0
  85. package/assets/ts/modules/chart.ts +219 -0
  86. package/assets/ts/modules/drawer.ts +17 -0
  87. package/assets/ts/modules/file-upload.ts +49 -0
  88. package/assets/ts/modules/form.ts +169 -0
  89. package/assets/ts/modules/helpers.ts +120 -0
  90. package/assets/ts/modules/modal.ts +91 -0
  91. package/assets/ts/modules/nav.ts +29 -0
  92. package/assets/ts/modules/orderablelist.ts +123 -0
  93. package/assets/ts/modules/table.ts +586 -0
  94. package/assets/ts/modules/testimonial.ts +84 -0
  95. package/assets/ts/modules/youtubevideo.ts +146 -0
  96. package/dist/components.es.js +493 -509
  97. package/dist/components.umd.js +15 -15
  98. package/package.json +109 -108
  99. package/src/components/Accordion/Accordion.spec.js +63 -63
  100. package/src/components/Accordion/Accordion.vue +22 -22
  101. package/src/components/Accordion/AccordionItem.vue +52 -52
  102. package/src/components/Accordion/README.md +34 -34
  103. package/src/components/Alert/Alert.spec.js +49 -49
  104. package/src/components/Alert/Alert.vue +39 -39
  105. package/src/components/Alert/README.md +28 -28
  106. package/src/components/Banner/Banner.spec.js +28 -28
  107. package/src/components/Banner/Banner.vue +38 -38
  108. package/src/components/Banner/README.md +23 -23
  109. package/src/{elements → components}/Card/Card.vue +122 -122
  110. package/src/{elements/FileUploads → components/Card}/README.md +24 -24
  111. package/src/components/CardDeck/CardDeck.spec.js +99 -99
  112. package/src/components/CardDeck/CardDeck.vue +77 -77
  113. package/src/components/CardDeck/README.md +24 -24
  114. package/src/components/Carousel/Carousel.spec.js +45 -45
  115. package/src/components/Carousel/Carousel.vue +85 -85
  116. package/src/components/Carousel/README.md +19 -19
  117. package/src/components/Chart/Chart.spec.js +201 -201
  118. package/src/components/Chart/Chart.vue +88 -88
  119. package/src/components/Chart/README.md +17 -17
  120. package/src/components/Drawer/Drawer.vue +53 -53
  121. package/src/components/Drawer/README.md +22 -22
  122. package/src/{elements → components}/FileUploads/FileUploads.vue +48 -48
  123. package/src/{elements/Card → components/FileUploads}/README.md +24 -24
  124. package/src/components/Header/Header.spec.js +33 -33
  125. package/src/components/Header/Header.vue +38 -38
  126. package/src/components/Header/README.md +27 -27
  127. package/src/{elements → components}/Input/Input.vue +272 -272
  128. package/src/{elements → components}/Input/README.md +19 -19
  129. package/src/components/Modal/Modal.spec.js +22 -22
  130. package/src/components/Modal/Modal.vue +43 -43
  131. package/src/components/Modal/README.md +19 -19
  132. package/src/components/Nav/Nav.spec.js +35 -35
  133. package/src/components/Nav/Nav.vue +215 -215
  134. package/src/components/Nav/README.md +22 -22
  135. package/src/components/NoteFeed/NoteFeed.vue +79 -79
  136. package/src/components/NoteFeed/README.md +16 -16
  137. package/src/components/PropertySearchbar/PropertySearchbar.vue +204 -204
  138. package/src/components/PropertySearchbar/README.md +25 -25
  139. package/src/components/Snapshot/README.md +20 -20
  140. package/src/components/Snapshot/Snapshot.vue +32 -32
  141. package/src/components/Stepper/README.md +32 -32
  142. package/src/components/Stepper/Step.vue +28 -28
  143. package/src/components/Stepper/Stepper.spec.js +99 -99
  144. package/src/components/Stepper/Stepper.vue +33 -33
  145. package/src/{elements → components}/Table/README.md +62 -62
  146. package/src/{elements → components}/Table/Table.spec.js +90 -90
  147. package/src/{elements → components}/Table/Table.vue +129 -129
  148. package/src/components/Tabs/README.md +27 -27
  149. package/src/components/Tabs/Tab.vue +32 -32
  150. package/src/components/Tabs/Tabs.vue +77 -77
  151. package/src/components/Testimonial/README.md +25 -25
  152. package/src/components/Testimonial/Testimonial.spec.js +57 -57
  153. package/src/components/Testimonial/Testimonial.vue +60 -60
  154. package/src/components/Timeline/README.md +18 -18
  155. package/src/components/Timeline/Timeline.spec.js +17 -17
  156. package/src/components/Timeline/Timeline.vue +24 -24
  157. package/src/foundations/Icon/Icon.spec.js +24 -24
  158. package/src/foundations/Icon/Icon.vue +24 -24
  159. package/src/foundations/Icon/README.md +11 -11
  160. package/src/foundations/Logo/Logo.spec.js +56 -56
  161. package/src/foundations/Logo/Logo.vue +39 -39
  162. package/src/foundations/Logo/README.md +20 -20
  163. package/src/foundations/YoutubeVideo/README.md +11 -11
  164. package/src/foundations/YoutubeVideo/YoutubeVideo.vue +24 -24
  165. package/src/helpers/strings.js +12 -12
  166. package/src/index.js +27 -27
  167. package/src/vue-shim.d.ts +6 -6
  168. package/assets/css/email.min.css +0 -1
  169. package/assets/css/email.min.css.map +0 -1
  170. package/assets/css/error.min.css +0 -1
  171. package/assets/css/error.min.css.map +0 -1
  172. package/assets/ts/main.js +0 -57
  173. package/assets/ts/main.js.map +0 -1
  174. package/assets/ts/modules/accordion.js +0 -33
  175. package/assets/ts/modules/accordion.js.map +0 -1
  176. package/src/components/Accordion/Accordion.screenshot.vue +0 -57
  177. package/src/components/Accordion/__screenshots__/win32/laptop/Accordion.png +0 -0
  178. package/src/components/Accordion/__screenshots__/win32/mobile/Accordion.png +0 -0
  179. package/src/components/Accordion/__screenshots__/win32/tablet/Accordion.png +0 -0
@@ -1,26 +1,26 @@
1
- ### Usage
2
-
3
- ```
4
- <PropertySearchbar></PropertySearchbar>
5
- ```
6
-
7
- ### Properties
8
-
9
- | Option | Type | Default Value | Description |
10
- | ------ | ---- | ------------- | ----------- |
11
- | formAction | String | - | Set where the property search submit the form to |
12
- | formAction | String | - | Sets how the form is submitted, i.e. post or get |
13
- | distances | Array | See documentation example | Override the default (Not recommened) |
14
- | priceMin | Array | See documentation example | Override the default (Not recommened) |
15
- | priceMax | Array | See documentation example | Override the default (Not recommened) |
16
- | bedsMin | Array | See documentation example | Override the default (Not recommened) |
17
- | bedsMax | Array | See documentation example | Override the default (Not recommened) |
18
- | propertyTypes | Array | See documentation example | Override the default (Not recommened) |
19
-
20
-
21
- ### Slots
22
-
23
- | Option | Default Value | Description |
24
- | ------ | ------------- | ----------- |
25
- | default | - | Will display before the property searchbar |
1
+ ### Usage
2
+
3
+ ```
4
+ <PropertySearchbar></PropertySearchbar>
5
+ ```
6
+
7
+ ### Properties
8
+
9
+ | Option | Type | Default Value | Description |
10
+ | ------ | ---- | ------------- | ----------- |
11
+ | formAction | String | - | Set where the property search submit the form to |
12
+ | formAction | String | - | Sets how the form is submitted, i.e. post or get |
13
+ | distances | Array | See documentation example | Override the default (Not recommened) |
14
+ | priceMin | Array | See documentation example | Override the default (Not recommened) |
15
+ | priceMax | Array | See documentation example | Override the default (Not recommened) |
16
+ | bedsMin | Array | See documentation example | Override the default (Not recommened) |
17
+ | bedsMax | Array | See documentation example | Override the default (Not recommened) |
18
+ | propertyTypes | Array | See documentation example | Override the default (Not recommened) |
19
+
20
+
21
+ ### Slots
22
+
23
+ | Option | Default Value | Description |
24
+ | ------ | ------------- | ----------- |
25
+ | default | - | Will display before the property searchbar |
26
26
  | after | - | Will display after the property searchbar |
@@ -1,21 +1,21 @@
1
- ### Usage
2
-
3
- ```
4
- <Snapshot :items="items"></Snapshot>
5
- ```
6
-
7
- ### Properties
8
-
9
- | Option | Type | Default Value | Description |
10
- | ------ | ---- | ------------- | ----------- |
11
- | items | Array | - | Table row data passed |
12
- | - item.title | String | - | Title of the snapshot figure |
13
- | - item.bg | String | - | Theme colour to highlight the importance of the figure i.e. danger to indicate a high priority. |
14
- | - item.number | String | - | The actual figure, recommended to be a single number but could be more i.e. 10 days.
15
-
16
-
17
- ### Slots
18
-
19
- | Option | Default Value | Description |
20
- | ------ | ------------- | ----------- |
1
+ ### Usage
2
+
3
+ ```
4
+ <Snapshot :items="items"></Snapshot>
5
+ ```
6
+
7
+ ### Properties
8
+
9
+ | Option | Type | Default Value | Description |
10
+ | ------ | ---- | ------------- | ----------- |
11
+ | items | Array | - | Table row data passed |
12
+ | - item.title | String | - | Title of the snapshot figure |
13
+ | - item.bg | String | - | Theme colour to highlight the importance of the figure i.e. danger to indicate a high priority. |
14
+ | - item.number | String | - | The actual figure, recommended to be a single number but could be more i.e. 10 days.
15
+
16
+
17
+ ### Slots
18
+
19
+ | Option | Default Value | Description |
20
+ | ------ | ------------- | ----------- |
21
21
  | default | - | Will display before the snapshot items |
@@ -1,32 +1,32 @@
1
- <template>
2
- <div class="container snapshot" ref="wrapper">
3
- <slot></slot>
4
- <div class="row">
5
- <div class="col" v-for="(value,index) in items" :key="index">
6
-
7
- <a :href="value.link" v-if="value.link">View {{value.title}}</a>
8
- <div :class="`snapshot__item ${value.bg ? 'bg-'+value.bg : ''}`">
9
- <span class="h6 snapshot__title">{{value.title}}</span>
10
- <span class="stat">{{value.number}}</span>
11
- </div>
12
- </div>
13
- </div>
14
- </div>
15
- </template>
16
-
17
- <style lang="scss">
18
- @import "../../../assets/sass/components/snapshot.scss";
19
- </style>
20
-
21
- <script>
22
-
23
- export default {
24
- name: 'Snapshot',
25
- props: {
26
- items: {
27
- type: Array,
28
- required: true
29
- },
30
- }
31
- }
32
- </script>
1
+ <template>
2
+ <div class="container snapshot" ref="wrapper">
3
+ <slot></slot>
4
+ <div class="row">
5
+ <div class="col" v-for="(value,index) in items" :key="index">
6
+
7
+ <a :href="value.link" v-if="value.link">View {{value.title}}</a>
8
+ <div :class="`snapshot__item ${value.bg ? 'bg-'+value.bg : ''}`">
9
+ <span class="h6 snapshot__title">{{value.title}}</span>
10
+ <span class="stat">{{value.number}}</span>
11
+ </div>
12
+ </div>
13
+ </div>
14
+ </div>
15
+ </template>
16
+
17
+ <style lang="scss">
18
+ @import "../../../assets/sass/components/snapshot.scss";
19
+ </style>
20
+
21
+ <script>
22
+
23
+ export default {
24
+ name: 'Snapshot',
25
+ props: {
26
+ items: {
27
+ type: Array,
28
+ required: true
29
+ },
30
+ }
31
+ }
32
+ </script>
@@ -1,33 +1,33 @@
1
- ### Usage
2
-
3
- ```
4
- <Stepper class="visualtest">
5
- <Step status="warning">Warning status</Step>
6
- <Step url="/step" status="danger">Danger status</Step>
7
- <Step url="/step" status="success">Success status</Step>
8
- <Step href="/step" current>Current step</Step>
9
- <Step href="/step">Future step</Step>
10
- </Stepper>
11
- ```
12
-
13
- ### Properties
14
-
15
- | Option | Type | Default Value | Description |
16
- | ------ | ---- | ------------- | ----------- |
17
- | label | String | - | Optional label to title the component |
18
- | endlabel | String | Complete | End label to signify the end of the process |
19
-
20
-
21
- ### Step Properties
22
-
23
- | Option | Type | Default Value | Description |
24
- | ------ | ---- | ------------- | ----------- |
25
- | url | String | - | Add a url to take the user back to or ahead to said step, if a url is not passed the link is disabled. |
26
- | status | String | - | Each step can have a status to highlight to the user whether the step was completed correctly. |
27
- | current | String | - | Indicate whether this is the current step |
28
-
29
- ### Slots
30
-
31
- | Option | Default Value | Description |
32
- | ------ | ------------- | ----------- |
1
+ ### Usage
2
+
3
+ ```
4
+ <Stepper class="visualtest">
5
+ <Step status="warning">Warning status</Step>
6
+ <Step url="/step" status="danger">Danger status</Step>
7
+ <Step url="/step" status="success">Success status</Step>
8
+ <Step href="/step" current>Current step</Step>
9
+ <Step href="/step">Future step</Step>
10
+ </Stepper>
11
+ ```
12
+
13
+ ### Properties
14
+
15
+ | Option | Type | Default Value | Description |
16
+ | ------ | ---- | ------------- | ----------- |
17
+ | label | String | - | Optional label to title the component |
18
+ | endlabel | String | Complete | End label to signify the end of the process |
19
+
20
+
21
+ ### Step Properties
22
+
23
+ | Option | Type | Default Value | Description |
24
+ | ------ | ---- | ------------- | ----------- |
25
+ | url | String | - | Add a url to take the user back to or ahead to said step, if a url is not passed the link is disabled. |
26
+ | status | String | - | Each step can have a status to highlight to the user whether the step was completed correctly. |
27
+ | current | String | - | Indicate whether this is the current step |
28
+
29
+ ### Slots
30
+
31
+ | Option | Default Value | Description |
32
+ | ------ | ------------- | ----------- |
33
33
  | default | - | Container for step components |
@@ -1,28 +1,28 @@
1
- <template>
2
- <li>
3
- <a :href="url" :class="`${status?'bg-'+status:''}${typeof current != 'undefined'?'current':''}`" :aria-current="typeof current != 'undefined'?true:false">
4
- <span><slot></slot></span>
5
- <em class="visually-hidden" v-if="status"> - status: {{status}}</em>
6
- </a>
7
- </li>
8
- </template>
9
-
10
- <script>
11
- export default {
12
- name: 'Stepper',
13
- props: {
14
- url: {
15
- type: String,
16
- required: false
17
- },
18
- status: {
19
- type: String,
20
- required: false
21
- },
22
- current: {
23
- type: String,
24
- required: false
25
- }
26
- }
27
- }
28
- </script>
1
+ <template>
2
+ <li>
3
+ <a :href="url" :class="`${status?'bg-'+status:''}${typeof current != 'undefined'?'current':''}`" :aria-current="typeof current != 'undefined'?true:false">
4
+ <span><slot></slot></span>
5
+ <em class="visually-hidden" v-if="status"> - status: {{status}}</em>
6
+ </a>
7
+ </li>
8
+ </template>
9
+
10
+ <script>
11
+ export default {
12
+ name: 'Stepper',
13
+ props: {
14
+ url: {
15
+ type: String,
16
+ required: false
17
+ },
18
+ status: {
19
+ type: String,
20
+ required: false
21
+ },
22
+ current: {
23
+ type: String,
24
+ required: false
25
+ }
26
+ }
27
+ }
28
+ </script>
@@ -1,99 +1,99 @@
1
- import { mount } from '@vue/test-utils'
2
- import Stepper from './Stepper.vue'
3
- import Step from './Step.vue'
4
-
5
- describe('Stepper component', () => {
6
- it('renders 4 steps', () => {
7
-
8
- const test = mount(Stepper, {
9
- propsData: {
10
- 'label': 'Start',
11
- 'endlabel': 'End'
12
- },
13
- global: {
14
- stubs: {
15
- 'Step': Step
16
- }
17
- },
18
- slots: {
19
- default: `<Step status="success">Customer due diligence</Step>
20
- <Step url="/step" status="success">Legal Preperation</Step>
21
- <Step url="/step" current>Financial Preparation</Step>
22
- <Step url="/step">Surveys</Step>`
23
- }
24
- })
25
-
26
- expect(test.findAll('a').length).toBe(4)
27
- })
28
-
29
- it('renders a label when set', () => {
30
-
31
- const test = mount(Stepper, {
32
- propsData: {
33
- 'label': 'Start',
34
- 'endlabel': 'End'
35
- },
36
- global: {
37
- stubs: {
38
- 'Step': Step
39
- }
40
- },
41
- slots: {
42
- default: `<Step status="success">Customer due diligence</Step>
43
- <Step url="/step" status="success">Legal Preperation</Step>
44
- <Step url="/step" current>Financial Preparation</Step>
45
- <Step url="/step">Surveys</Step>`
46
- }
47
- })
48
-
49
- expect(test.find('.stepper__start').html()).toContain('Start')
50
- })
51
-
52
- it('renders an end label when set', () => {
53
-
54
- const test = mount(Stepper, {
55
- propsData: {
56
- 'label': 'Start',
57
- 'endlabel': 'End'
58
- },
59
- global: {
60
- stubs: {
61
- 'Step': Step
62
- }
63
- },
64
- slots: {
65
- default: `<Step status="success">Customer due diligence</Step>
66
- <Step url="/step" status="success">Legal Preperation</Step>
67
- <Step url="/step" current>Financial Preparation</Step>
68
- <Step url="/step">Surveys</Step>`
69
- }
70
- })
71
-
72
- expect(test.find('.stepper__end').html()).toContain('End')
73
- })
74
-
75
-
76
- it('sets status on steps', () => {
77
-
78
- const test = mount(Stepper, {
79
- propsData: {
80
- 'label': 'Start',
81
- 'endlabel': 'End'
82
- },
83
- global: {
84
- stubs: {
85
- 'Step': Step
86
- }
87
- },
88
- slots: {
89
- default: `<Step status="success">Customer due diligence</Step>
90
- <Step url="/step" status="success">Legal Preperation</Step>
91
- <Step url="/step" current>Financial Preparation</Step>
92
- <Step url="/step">Surveys</Step>`
93
- }
94
- })
95
-
96
- expect(test.find('.bg-success').exists()).toBe(true)
97
- expect(test.find('.current').exists()).toBe(true)
98
- })
99
- })
1
+ import { mount } from '@vue/test-utils'
2
+ import Stepper from './Stepper.vue'
3
+ import Step from './Step.vue'
4
+
5
+ describe('Stepper component', () => {
6
+ it('renders 4 steps', () => {
7
+
8
+ const test = mount(Stepper, {
9
+ propsData: {
10
+ 'label': 'Start',
11
+ 'endlabel': 'End'
12
+ },
13
+ global: {
14
+ stubs: {
15
+ 'Step': Step
16
+ }
17
+ },
18
+ slots: {
19
+ default: `<Step status="success">Customer due diligence</Step>
20
+ <Step url="/step" status="success">Legal Preperation</Step>
21
+ <Step url="/step" current>Financial Preparation</Step>
22
+ <Step url="/step">Surveys</Step>`
23
+ }
24
+ })
25
+
26
+ expect(test.findAll('a').length).toBe(4)
27
+ })
28
+
29
+ it('renders a label when set', () => {
30
+
31
+ const test = mount(Stepper, {
32
+ propsData: {
33
+ 'label': 'Start',
34
+ 'endlabel': 'End'
35
+ },
36
+ global: {
37
+ stubs: {
38
+ 'Step': Step
39
+ }
40
+ },
41
+ slots: {
42
+ default: `<Step status="success">Customer due diligence</Step>
43
+ <Step url="/step" status="success">Legal Preperation</Step>
44
+ <Step url="/step" current>Financial Preparation</Step>
45
+ <Step url="/step">Surveys</Step>`
46
+ }
47
+ })
48
+
49
+ expect(test.find('.stepper__start').html()).toContain('Start')
50
+ })
51
+
52
+ it('renders an end label when set', () => {
53
+
54
+ const test = mount(Stepper, {
55
+ propsData: {
56
+ 'label': 'Start',
57
+ 'endlabel': 'End'
58
+ },
59
+ global: {
60
+ stubs: {
61
+ 'Step': Step
62
+ }
63
+ },
64
+ slots: {
65
+ default: `<Step status="success">Customer due diligence</Step>
66
+ <Step url="/step" status="success">Legal Preperation</Step>
67
+ <Step url="/step" current>Financial Preparation</Step>
68
+ <Step url="/step">Surveys</Step>`
69
+ }
70
+ })
71
+
72
+ expect(test.find('.stepper__end').html()).toContain('End')
73
+ })
74
+
75
+
76
+ it('sets status on steps', () => {
77
+
78
+ const test = mount(Stepper, {
79
+ propsData: {
80
+ 'label': 'Start',
81
+ 'endlabel': 'End'
82
+ },
83
+ global: {
84
+ stubs: {
85
+ 'Step': Step
86
+ }
87
+ },
88
+ slots: {
89
+ default: `<Step status="success">Customer due diligence</Step>
90
+ <Step url="/step" status="success">Legal Preperation</Step>
91
+ <Step url="/step" current>Financial Preparation</Step>
92
+ <Step url="/step">Surveys</Step>`
93
+ }
94
+ })
95
+
96
+ expect(test.find('.bg-success').exists()).toBe(true)
97
+ expect(test.find('.current').exists()).toBe(true)
98
+ })
99
+ })
@@ -1,33 +1,33 @@
1
- <template>
2
- <div class="container">
3
- <nav class="stepper" :aria-label="label?label:'Progress'">
4
- <span class="h6 stepper__start" v-if="label">{{label}}</span>
5
- <ol class="list-unstyled">
6
- <slot><!-- Use for titles etc --></slot>
7
- </ol>
8
- <span class="h6 stepper__end">{{endlabel}}</span>
9
- </nav>
10
- </div>
11
- </template>
12
-
13
-
14
- <style lang="scss">
15
- @import "../../../assets/sass/components/stepper.scss";
16
- </style>
17
-
18
- <script>
19
- export default {
20
- name: 'Stepper',
21
- props: {
22
- label: {
23
- type: String,
24
- required: false
25
- },
26
- endlabel: {
27
- type: String,
28
- required: false,
29
- default: "Complete"
30
- }
31
- }
32
- }
33
- </script>
1
+ <template>
2
+ <div class="container">
3
+ <nav class="stepper" :aria-label="label?label:'Progress'">
4
+ <span class="h6 stepper__start" v-if="label">{{label}}</span>
5
+ <ol class="list-unstyled">
6
+ <slot><!-- Use for titles etc --></slot>
7
+ </ol>
8
+ <span class="h6 stepper__end">{{endlabel}}</span>
9
+ </nav>
10
+ </div>
11
+ </template>
12
+
13
+
14
+ <style lang="scss">
15
+ @import "../../../assets/sass/components/stepper.scss";
16
+ </style>
17
+
18
+ <script>
19
+ export default {
20
+ name: 'Stepper',
21
+ props: {
22
+ label: {
23
+ type: String,
24
+ required: false
25
+ },
26
+ endlabel: {
27
+ type: String,
28
+ required: false,
29
+ default: "Complete"
30
+ }
31
+ }
32
+ }
33
+ </script>