toggle-components-library 1.34.0-beta.6 → 1.34.0-beta.7

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 (29) hide show
  1. package/dist/img/airship-feedback-hover.a207c947.svg +10 -0
  2. package/dist/img/airship-feedback.1f7c858c.svg +10 -0
  3. package/dist/toggle-components-library.common.js +238 -201
  4. package/dist/toggle-components-library.common.js.map +1 -1
  5. package/dist/toggle-components-library.css +1 -1
  6. package/dist/toggle-components-library.umd.js +238 -201
  7. package/dist/toggle-components-library.umd.js.map +1 -1
  8. package/dist/toggle-components-library.umd.min.js +1 -1
  9. package/dist/toggle-components-library.umd.min.js.map +1 -1
  10. package/package-lock.json +89 -70
  11. package/package.json +1 -1
  12. package/src/assets/icons/airship-feedback-hover.svg +10 -0
  13. package/src/assets/icons/airship-feedback.svg +10 -0
  14. package/src/components/boosters/ToggleBoosterButton.vue +13 -27
  15. package/src/components/buttons/ToggleButton.vue +9 -39
  16. package/src/components/buttons/ToggleMetricsButton.vue +18 -2
  17. package/src/components/cards/ToggleCommentCard.vue +66 -0
  18. package/src/components/metrics/ToggleMetricSingleMetric.vue +6 -5
  19. package/src/components/metrics/ToggleMetricSparkLine.vue +1 -1
  20. package/src/components/tables/ToggleTableRow.vue +2 -20
  21. package/src/index.js +3 -1
  22. package/src/sass/includes/_as_boosters.scss +0 -34
  23. package/src/sass/includes/_as_buttons.scss +30 -76
  24. package/src/sass/includes/_as_cards.scss +28 -0
  25. package/src/sass/includes/_as_metrics.scss +6 -0
  26. package/src/sass/includes/_as_navs.scss +16 -0
  27. package/src/sass/includes/_as_table.scss +2 -4
  28. package/dist/img/contacts-greyblue.ef6f8a9a.svg +0 -1
  29. package/dist/img/contacts-white.95d07c7a.svg +0 -1
package/package-lock.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "toggle-components-library",
3
- "version": "1.34.0-beta.6",
3
+ "version": "1.34.0-beta.7",
4
4
  "lockfileVersion": 1,
5
5
  "requires": true,
6
6
  "dependencies": {
@@ -3957,6 +3957,16 @@
3957
3957
  "@types/node": "*"
3958
3958
  }
3959
3959
  },
3960
+ "ansi-styles": {
3961
+ "version": "4.3.0",
3962
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
3963
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
3964
+ "dev": true,
3965
+ "optional": true,
3966
+ "requires": {
3967
+ "color-convert": "^2.0.1"
3968
+ }
3969
+ },
3960
3970
  "array-union": {
3961
3971
  "version": "1.0.2",
3962
3972
  "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz",
@@ -3995,6 +4005,34 @@
3995
4005
  }
3996
4006
  }
3997
4007
  },
4008
+ "chalk": {
4009
+ "version": "4.1.2",
4010
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
4011
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
4012
+ "dev": true,
4013
+ "optional": true,
4014
+ "requires": {
4015
+ "ansi-styles": "^4.1.0",
4016
+ "supports-color": "^7.1.0"
4017
+ }
4018
+ },
4019
+ "color-convert": {
4020
+ "version": "2.0.1",
4021
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
4022
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
4023
+ "dev": true,
4024
+ "optional": true,
4025
+ "requires": {
4026
+ "color-name": "~1.1.4"
4027
+ }
4028
+ },
4029
+ "color-name": {
4030
+ "version": "1.1.4",
4031
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
4032
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
4033
+ "dev": true,
4034
+ "optional": true
4035
+ },
3998
4036
  "dir-glob": {
3999
4037
  "version": "2.2.2",
4000
4038
  "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-2.2.2.tgz",
@@ -4078,6 +4116,13 @@
4078
4116
  "slash": "^2.0.0"
4079
4117
  }
4080
4118
  },
4119
+ "has-flag": {
4120
+ "version": "4.0.0",
4121
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
4122
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
4123
+ "dev": true,
4124
+ "optional": true
4125
+ },
4081
4126
  "html-webpack-plugin": {
4082
4127
  "version": "3.2.0",
4083
4128
  "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-3.2.0.tgz",
@@ -4267,6 +4312,16 @@
4267
4312
  "integrity": "sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A==",
4268
4313
  "dev": true
4269
4314
  },
4315
+ "supports-color": {
4316
+ "version": "7.2.0",
4317
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
4318
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
4319
+ "dev": true,
4320
+ "optional": true,
4321
+ "requires": {
4322
+ "has-flag": "^4.0.0"
4323
+ }
4324
+ },
4270
4325
  "terser-webpack-plugin": {
4271
4326
  "version": "1.4.5",
4272
4327
  "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-1.4.5.tgz",
@@ -4323,6 +4378,39 @@
4323
4378
  "mime": "^2.4.4",
4324
4379
  "schema-utils": "^2.5.0"
4325
4380
  }
4381
+ },
4382
+ "vue-loader-v16": {
4383
+ "version": "npm:vue-loader@16.8.3",
4384
+ "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-16.8.3.tgz",
4385
+ "integrity": "sha512-7vKN45IxsKxe5GcVCbc2qFU5aWzyiLrYJyUuMz4BQLKctCj/fmCa0w6fGiiQ2cLFetNcek1ppGJQDCup0c1hpA==",
4386
+ "dev": true,
4387
+ "optional": true,
4388
+ "requires": {
4389
+ "chalk": "^4.1.0",
4390
+ "hash-sum": "^2.0.0",
4391
+ "loader-utils": "^2.0.0"
4392
+ },
4393
+ "dependencies": {
4394
+ "json5": {
4395
+ "version": "2.2.3",
4396
+ "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz",
4397
+ "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
4398
+ "dev": true,
4399
+ "optional": true
4400
+ },
4401
+ "loader-utils": {
4402
+ "version": "2.0.4",
4403
+ "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.4.tgz",
4404
+ "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==",
4405
+ "dev": true,
4406
+ "optional": true,
4407
+ "requires": {
4408
+ "big.js": "^5.2.2",
4409
+ "emojis-list": "^3.0.0",
4410
+ "json5": "^2.1.2"
4411
+ }
4412
+ }
4413
+ }
4326
4414
  }
4327
4415
  }
4328
4416
  },
@@ -18582,75 +18670,6 @@
18582
18670
  }
18583
18671
  }
18584
18672
  },
18585
- "vue-loader-v16": {
18586
- "version": "npm:vue-loader@16.8.3",
18587
- "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-16.8.3.tgz",
18588
- "integrity": "sha512-7vKN45IxsKxe5GcVCbc2qFU5aWzyiLrYJyUuMz4BQLKctCj/fmCa0w6fGiiQ2cLFetNcek1ppGJQDCup0c1hpA==",
18589
- "dev": true,
18590
- "optional": true,
18591
- "requires": {
18592
- "chalk": "^4.1.0",
18593
- "hash-sum": "^2.0.0",
18594
- "loader-utils": "^2.0.0"
18595
- },
18596
- "dependencies": {
18597
- "ansi-styles": {
18598
- "version": "4.3.0",
18599
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
18600
- "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
18601
- "dev": true,
18602
- "optional": true,
18603
- "requires": {
18604
- "color-convert": "^2.0.1"
18605
- }
18606
- },
18607
- "chalk": {
18608
- "version": "4.1.2",
18609
- "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
18610
- "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
18611
- "dev": true,
18612
- "optional": true,
18613
- "requires": {
18614
- "ansi-styles": "^4.1.0",
18615
- "supports-color": "^7.1.0"
18616
- }
18617
- },
18618
- "color-convert": {
18619
- "version": "2.0.1",
18620
- "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
18621
- "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
18622
- "dev": true,
18623
- "optional": true,
18624
- "requires": {
18625
- "color-name": "~1.1.4"
18626
- }
18627
- },
18628
- "color-name": {
18629
- "version": "1.1.4",
18630
- "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
18631
- "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
18632
- "dev": true,
18633
- "optional": true
18634
- },
18635
- "has-flag": {
18636
- "version": "4.0.0",
18637
- "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
18638
- "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
18639
- "dev": true,
18640
- "optional": true
18641
- },
18642
- "supports-color": {
18643
- "version": "7.2.0",
18644
- "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
18645
- "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
18646
- "dev": true,
18647
- "optional": true,
18648
- "requires": {
18649
- "has-flag": "^4.0.0"
18650
- }
18651
- }
18652
- }
18653
- },
18654
18673
  "vue-moment": {
18655
18674
  "version": "4.1.0",
18656
18675
  "resolved": "https://registry.npmjs.org/vue-moment/-/vue-moment-4.1.0.tgz",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "toggle-components-library",
3
- "version": "1.34.0-beta.6",
3
+ "version": "1.34.0-beta.7",
4
4
  "private": false,
5
5
  "scripts": {
6
6
  "serve": "vue-cli-service serve",
@@ -0,0 +1,10 @@
1
+ <svg id="Group_10" data-name="Group 10" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="624.048" height="499" viewBox="0 0 624.048 499">
2
+ <defs>
3
+ <clipPath id="clip-path">
4
+ <rect id="Rectangle_25" data-name="Rectangle 25" width="624.048" height="499" fill="none"/>
5
+ </clipPath>
6
+ </defs>
7
+ <g id="Group_9" data-name="Group 9" clip-path="url(#clip-path)">
8
+ <path id="Path_3" data-name="Path 3" d="M617.3,465.069l-.384-.318c-.385-.317-.9-.738-1.674-1.49-1.419-1.279-3.616-3.309-6.36-6.112a225.664,225.664,0,0,1-20.162-23.534c-.136-.182-.271-.367-.406-.55-22.957-31.214-26.261-72.555-9.486-107.484,16.327-34,23.783-71.208,20.13-109.472C586.148,81.9,441.91-14.07,276.747,1.694S-11.9,138.983.914,273.192,157.963,503.371,323.126,487.608a364.7,364.7,0,0,0,89.545-20,77.522,77.522,0,0,1,58.556,2.224,367.136,367.136,0,0,0,38.334,14.95c29.035,9.42,63.567,16.569,96.922,13.5A19.281,19.281,0,0,0,622.561,486.8a18.785,18.785,0,0,0-5.261-21.731m-446.79-153.1A50.455,50.455,0,1,1,216.243,257.2a50.456,50.456,0,0,1-45.733,54.772m138.931-12.493a50.454,50.454,0,1,1,45.734-54.77,50.454,50.454,0,0,1-45.734,54.77m134.991-12.137a50.455,50.455,0,1,1,45.733-54.769,50.455,50.455,0,0,1-45.733,54.769" transform="translate(0 0)" fill="#477ef6"/>
9
+ </g>
10
+ </svg>
@@ -0,0 +1,10 @@
1
+ <svg id="Group_10" data-name="Group 10" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="624.048" height="499" viewBox="0 0 624.048 499">
2
+ <defs>
3
+ <clipPath id="clip-path">
4
+ <rect id="Rectangle_25" data-name="Rectangle 25" width="624.048" height="499" fill="none"/>
5
+ </clipPath>
6
+ </defs>
7
+ <g id="Group_9" data-name="Group 9" clip-path="url(#clip-path)">
8
+ <path id="Path_3" data-name="Path 3" d="M617.3,465.069l-.384-.318c-.385-.317-.9-.738-1.674-1.49-1.419-1.279-3.616-3.309-6.36-6.112a225.664,225.664,0,0,1-20.162-23.534c-.136-.182-.271-.367-.406-.55-22.957-31.214-26.261-72.555-9.486-107.484,16.327-34,23.783-71.208,20.13-109.472C586.148,81.9,441.91-14.07,276.747,1.694S-11.9,138.983.914,273.192,157.963,503.371,323.126,487.608a364.7,364.7,0,0,0,89.545-20,77.522,77.522,0,0,1,58.556,2.224,367.136,367.136,0,0,0,38.334,14.95c29.035,9.42,63.567,16.569,96.922,13.5A19.281,19.281,0,0,0,622.561,486.8a18.785,18.785,0,0,0-5.261-21.731m-446.79-153.1A50.455,50.455,0,1,1,216.243,257.2a50.456,50.456,0,0,1-45.733,54.772m138.931-12.493a50.454,50.454,0,1,1,45.734-54.77,50.454,50.454,0,0,1-45.734,54.77m134.991-12.137a50.455,50.455,0,1,1,45.733-54.769,50.455,50.455,0,0,1-45.733,54.769" transform="translate(0 0)" fill="#354b64"/>
9
+ </g>
10
+ </svg>
@@ -1,25 +1,19 @@
1
1
  <template>
2
- <div :class="[{'toggle-booster-button-tooltip-container': !!tooltipText }]">
3
- <button :class="['toggle-booster-button-container', boosterType, {'toggle-booster-button-disabled': disabled}]" :disabled="disabled" @click="click">
4
-
5
- <img
6
- :src="logo.src"
7
- :alt="logo.alt"
8
- class="toggle-booster-button-logo"
9
- >
10
-
11
- <div :class="['toggle-booster-button', boosterType]" >
12
- <p class="plus">+</p>
13
- <div v-if="buttonText" class="toggle-booster-button-button-text">
14
- <slot>{{buttonText}}</slot>
15
- </div>
16
- </div>
17
- </button>
2
+ <button :class="['toggle-booster-button-container', boosterType]" @click="click">
3
+
4
+ <img
5
+ :src="logo.src"
6
+ :alt="logo.alt"
7
+ class="toggle-booster-button-logo"
8
+ >
18
9
 
19
- <div class="toggle-booster-button-tooltip-text" v-if="tooltipText">
20
- <div >{{ tooltipText }}</div>
10
+ <div :class="['toggle-booster-button', boosterType]" >
11
+ <p class="plus">+</p>
12
+ <div v-if="buttonText" class="toggle-booster-button-button-text">
13
+ <slot>{{buttonText}}</slot>
14
+ </div>
21
15
  </div>
22
- </div>
16
+ </button>
23
17
  </template>
24
18
 
25
19
  <script>
@@ -42,14 +36,6 @@
42
36
  type: Object,
43
37
  required: true,
44
38
  },
45
- disabled: {
46
- type: Boolean,
47
- default: false,
48
- },
49
- tooltipText: {
50
- type: String,
51
- required: false
52
- }
53
39
  },
54
40
  methods: {
55
41
  click() {
@@ -1,29 +1,22 @@
1
1
  <template>
2
- <div :class="[ 'toggle-button-container', {'toggle-button-container-mini':isMini, 'toggle-button-tooltip-container': !!tooltipText }]">
2
+ <div :class="[ 'toggle-button-container', {'toggle-button-container-mini':isMini}]">
3
3
  <button
4
4
  v-if="!$slots.default"
5
5
  :type="type"
6
- :class="[ 'toggle-button', buttonStyle, {'toggle-button-loading':loading, 'toggle-button-subscribed': !subscribed, 'toggle-button-booster-badge': boosterImageProperties}]"
6
+ :class="[ 'toggle-button', buttonStyle, {'toggle-button-loading':loading, 'toggle-button-subscribed': !subscribed}]"
7
7
  :disabled="(loading || disabled)"
8
8
  @click="click"
9
9
  >
10
10
  <div class="toggle-button-loader" v-if="loading" ></div>
11
11
  <span v-html="buttonText" v-if="!isMini"/>
12
-
13
- <div v-if="boosterImageProperties" :class="['toggle-button-booster-image-badge', {'shimmer': boosterShimmer && !disabled, 'toggle-button-loading': loading, 'toggle-button-disabled': disabled}]" :style="'background-color: ' + boosterImageProperties.bgColor">
14
- <img class="toggle-button-booster-image" :src="boosterImageProperties.src" :alt="boosterImageProperties.alt">
15
- </div>
16
12
  </button>
17
13
  <div v-else :class="[ 'toggle-button-a', buttonStyle, {'toggle-button-a-loading':loading, 'disabled':disabled, 'toggle-button-subscribed': !subscribed}]">
18
- <div class="toggle-button-loader" v-if="loading" ></div>
19
- <div class="toggle-button-a-border" />
20
- <!--
21
- @slot String of button text
22
- -->
23
- <slot>{{buttonText}}</slot>
24
- </div>
25
- <div class="toggle-button-tooltip-text" v-if="tooltipText">
26
- <div >{{ tooltipText }}</div>
14
+ <div class="toggle-button-loader" v-if="loading" ></div>
15
+ <div class="toggle-button-a-border" />
16
+ <!--
17
+ @slot String of button text
18
+ -->
19
+ <slot>{{buttonText}}</slot>
27
20
  </div>
28
21
  </div>
29
22
  </template>
@@ -74,33 +67,10 @@ export default {
74
67
  type:String,
75
68
  default:'confirm'
76
69
  },
77
- /*
78
- * Grey out button if booster not enabled
79
- */
70
+ /* Grey out button if booster not enabled*/
80
71
  subscribed: {
81
72
  type: Boolean,
82
73
  default: true
83
- },
84
- /*
85
- * Booster badge image properties, image, alt text, background colour
86
- */
87
- boosterImageProperties: {
88
- type: Object,
89
- required: false,
90
- },
91
- /*
92
- * Turns the shimmer animation on and off for the booster badge
93
- */
94
- boosterShimmer: {
95
- type: Boolean,
96
- default: true
97
- },
98
- /*
99
- * Text displayed in tooltip
100
- */
101
- tooltipText: {
102
- type: String,
103
- required: false
104
74
  }
105
75
  },
106
76
  computed: {
@@ -1,6 +1,6 @@
1
1
  <template>
2
- <button :class="['toggle-metrics-button', buttonStyle]" @click="click">
3
- <div :class="icon"></div>
2
+ <button :class="['toggle-metrics-button', buttonStyle, 'toggle-metrics-button-' + size]" :style="styles" @click="click">
3
+ <div :class="icon" :style="'background-color:' + styles.color"></div>
4
4
  <slot>{{buttonText}}</slot>
5
5
  </button>
6
6
  </template>
@@ -20,6 +20,22 @@
20
20
  icon: {
21
21
  type: String,
22
22
  required: true,
23
+ validator: function(value) {
24
+ return ["heatmap-icon", "email-icon", "contacts-icon"].indexOf(value) !== -1;
25
+ }
26
+ },
27
+ size: {
28
+ type: String,
29
+ default: "medium",
30
+ required: false,
31
+ validator: function(value) {
32
+ return ["small", "medium", "large"].indexOf(value) !== -1;
33
+ }
34
+ },
35
+ styles: {
36
+ type: Object,
37
+ default: () => ({}),
38
+ required: false,
23
39
  },
24
40
  },
25
41
  methods: {
@@ -0,0 +1,66 @@
1
+ <template>
2
+ <div class="toggle-comment-card">
3
+ <div class="toggle-comment-card-info" :style="{ backgroundColor: cardColor}">
4
+ <div class="toggle-comment-card-text">
5
+ <p>"{{ comment }}"</p>
6
+ </div>
7
+ <div class="toggle-comment-card-name">
8
+ <ToggleMetricsButton
9
+ buttonStyle="mini-contacts"
10
+ :buttonText="name"
11
+ icon="contacts-icon"
12
+ :styles="{ backgroundColor: 'transparent', borderColor: 'white', color: 'white'}"
13
+ />
14
+ </div>
15
+ </div>
16
+ </div>
17
+ </template>
18
+ <script>
19
+ import ToggleMetricsButton from '../buttons/ToggleMetricsButton.vue';
20
+ export default {
21
+ components:{ToggleMetricsButton},
22
+ props: {
23
+ cardIndex: {
24
+ type: Number,
25
+ required: true,
26
+ },
27
+ totalCards: {
28
+ type: Number,
29
+ required: true,
30
+ },
31
+ comment: {
32
+ type: String,
33
+ required: true
34
+ },
35
+ name: {
36
+ type: String,
37
+ required: true
38
+ }
39
+ },
40
+ computed: {
41
+ cardColor() {
42
+ // adjust colour palette below to change the Reward Cards colors
43
+ const colorPalette = [
44
+ '#2c7da0',
45
+ '#f3c570',
46
+ '#8bbcbe',
47
+ '#a0a789',
48
+ '#cbae78',
49
+ '#a284b6',
50
+ '#d39999',
51
+ '#9b7361',
52
+ '#64aaa8',
53
+ '#799194',
54
+ ];
55
+
56
+ // pick random number to return random index of colourPalette
57
+ const paletteIndex = Math.floor(
58
+ (this.cardIndex / this.totalCards) * colorPalette.length
59
+ );
60
+ return colorPalette[paletteIndex];
61
+ }
62
+ },
63
+ };
64
+ </script>
65
+
66
+
@@ -2,7 +2,7 @@
2
2
  <div>
3
3
  <h3 class="toggle-metric metric-label">{{label}}</h3>
4
4
  <div class="single-metric-icon" v-if="metricPending && label.length == 0"></div>
5
- <h1 class="toggle-metric metric-value" v-else>{{metricValue}}</h1>
5
+ <h1 class="toggle-metric metric-value" :class="{ 'toggle-metric-score': score}" v-else>{{metricValue}} {{ symbol }}</h1>
6
6
  </div>
7
7
  </template>
8
8
 
@@ -27,7 +27,7 @@ export default {
27
27
  type : {
28
28
  type: String,
29
29
  validator: function (value) {
30
- return ['text', 'number', 'percentage', 'currency'].indexOf(value) !== -1
30
+ return ['text', 'number', 'percentage', 'currency', 'score'].indexOf(value) !== -1
31
31
  }
32
32
  },
33
33
  /**
@@ -92,9 +92,10 @@ export default {
92
92
  return this.value.toLocaleString();
93
93
 
94
94
  }
95
- }
96
-
97
-
95
+ },
96
+ score() {
97
+ return this.type === 'score';
98
+ },
98
99
  }
99
100
  }
100
101
 
@@ -54,7 +54,7 @@ export default {
54
54
  type : {
55
55
  type: String,
56
56
  validator: function (value) {
57
- return ['text', 'number', 'percentage', 'currency'].indexOf(value) !== -1
57
+ return ['text', 'number', 'percentage', 'currency', 'score'].indexOf(value) !== -1
58
58
  }
59
59
  },
60
60
  /**
@@ -1,23 +1,5 @@
1
1
  <template>
2
- <tr :class="['toggle-tablee-tr',{'tr-disabled':disabled }]" @click="handleClick" >
2
+ <tr class="toggle-tablee-tr" @click="$emit('click')" >
3
3
  <slot></slot>
4
4
  </tr>
5
- </template>
6
-
7
- <script>
8
- export default {
9
- props: {
10
- disabled: {
11
- type: Boolean,
12
- default: false
13
- }
14
- },
15
- methods: {
16
- handleClick() {
17
- if(!this.disabled) {
18
- this.$emit('click')
19
- }
20
- }
21
- }
22
- }
23
- </script>
5
+ </template>
package/src/index.js CHANGED
@@ -88,6 +88,7 @@ import ToggleCarouselSlide from "./components/carousel/ToggleCarouselSlide.vue";
88
88
 
89
89
  import ToggleEmailCard from "./components/cards/ToggleEmailCard.vue";
90
90
  import ToggleRewardsCard from "./components/cards/ToggleRewardsCard.vue";
91
+ import ToggleCommentCard from "./components/cards/ToggleCommentCard.vue";
91
92
 
92
93
 
93
94
  import './sass/main.scss';
@@ -161,7 +162,8 @@ const Components = {
161
162
  ToggleCarousel,
162
163
  ToggleCarouselSlide,
163
164
  ToggleEmailCard,
164
- ToggleRewardsCard
165
+ ToggleRewardsCard,
166
+ ToggleCommentCard
165
167
  }
166
168
 
167
169
  Object.keys(Components).forEach(name => {
@@ -219,37 +219,3 @@ margin:1rem
219
219
 
220
220
  }
221
221
 
222
- .toggle-booster-button-disabled {
223
- opacity: 0.3;
224
- }
225
-
226
- /* Tooltip container */
227
- .toggle-booster-button-tooltip-container {
228
- position: relative;
229
- display: flex;
230
- justify-content: center;
231
- }
232
-
233
- /* Tooltip text */
234
- .toggle-booster-button-tooltip-container .toggle-booster-button-tooltip-text {
235
- visibility: hidden;
236
- width: 120px;
237
- height: fit-content;
238
- background-color: black;
239
- color: #fff;
240
- text-align: center;
241
- padding: 5px;
242
- border-radius: 6px;
243
- position: absolute;
244
- z-index: 999;
245
- top: 100%;
246
- }
247
-
248
- .toggle-booster-button-tooltip-text {
249
- font-family: $toggle-font-family;
250
- padding: 10px;
251
- }
252
-
253
- .toggle-booster-button-tooltip-container:hover .toggle-booster-button-tooltip-text {
254
- visibility: visible;
255
- }