barbican-reset 1.5.9 → 1.6.2

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.
@@ -5,7 +5,7 @@
5
5
  <div class="title" v-if="title.length > 0 && !toggle">{{ title }}</div>
6
6
  <slot />
7
7
  </span>
8
- <b-button v-if="toggle" variant="invisible" :class="[`exit`, getStatus]" @click="$emit('close')">
8
+ <b-button v-if="toggle" variant="exit" :class="getStatus" @click="$emit('close')">
9
9
  <close-icon :status="getStatus" />
10
10
  </b-button>
11
11
  </div>
@@ -16,7 +16,7 @@
16
16
  import { BButton } from 'bootstrap-vue'
17
17
  import { CloseIcon } from 'barbican-reset/icons/stream'
18
18
  export default {
19
- name: "Alert",
19
+ name: "BrAlert",
20
20
  components: {
21
21
  BButton,
22
22
  CloseIcon,
@@ -0,0 +1,47 @@
1
+ <template>
2
+ <div class="br-form-group">
3
+ <label v-if="label" :for="id">
4
+ <strong>{{ label }}</strong> <span v-if="label && required">(required)</span><span v-if="label && optional">(optional)</span>
5
+ </label>
6
+ <div :class="[`content`,{ editable },{ label },{ submit }]">
7
+ <b-button v-if="editable" variant="input-edit" @click="$emit('edit')">
8
+ <edit-icon />
9
+ </b-button>
10
+ <slot />
11
+ </div>
12
+ </div>
13
+ </template>
14
+
15
+ <script type="text/javascript">
16
+ import { BButton } from 'bootstrap-vue'
17
+ import { EditIcon } from '../icons/account'
18
+ export default {
19
+ name: 'BrFormGroup',
20
+ components: {
21
+ BButton,
22
+ EditIcon
23
+ },
24
+ props: {
25
+ label: {
26
+ type: String
27
+ },
28
+ required: {
29
+ type: Boolean
30
+ },
31
+ optional: {
32
+ type: Boolean
33
+ },
34
+ submit: {
35
+ type: Boolean
36
+ },
37
+ editable: {
38
+ type: Boolean
39
+ }
40
+ },
41
+ computed: {
42
+ id() {
43
+ return this.label.toLowerCase().split(" ").join("_");
44
+ }
45
+ }
46
+ }
47
+ </script>
@@ -8,7 +8,7 @@
8
8
 
9
9
  <div v-html="data.markup" :class="$style.brightcove"></div>
10
10
 
11
- <alert v-if="data.isExpired" error center inline>Event has passed.</alert>
11
+ <br-alert v-if="data.isExpired" error center inline>Event has passed.</br-alert>
12
12
 
13
13
  </template>
14
14
 
@@ -39,7 +39,7 @@
39
39
  </template>
40
40
 
41
41
  <script>
42
- import { FluidIframe, Alert } from 'barbican-reset'
42
+ import { FluidIframe, BrAlert } from 'barbican-reset'
43
43
  export default {
44
44
  props: {
45
45
  data: {
@@ -58,7 +58,7 @@ export default {
58
58
  this.data.isExpired = this.data.brightcove.isExpired;
59
59
  }
60
60
  },
61
- components: { FluidIframe, Alert },
61
+ components: { FluidIframe, BrAlert },
62
62
  methods: {
63
63
  formatDateTime(date) {
64
64
  return this.$moment(date).format("LT ddd D MMM YYYY");
@@ -136,6 +136,15 @@
136
136
  @include button-outline($c-grey-night);
137
137
  }
138
138
 
139
+ @mixin btn-input-edit {
140
+ @include button-outline($c-grey-steel);
141
+ background-color: $c-grey-pearl;
142
+ border-color: $c-border-strong;
143
+ border-bottom-left-radius: 0;
144
+ border-top-left-radius: 0;
145
+ padding: 0.625rem 0.75rem;
146
+ }
147
+
139
148
  @mixin btn-cinema {
140
149
  @include button-solid($c-brand-cinema);
141
150
  }
@@ -192,15 +201,15 @@
192
201
  @mixin btn-exit {
193
202
  @include button-link;
194
203
  @include focus {
195
- @include single-box($c-grey-night);
196
- background-color: $white;
204
+ outline: 0.1875rem solid $c-grey-night;
197
205
  border-radius: 50%;
206
+ box-shadow: none;
198
207
 
199
- [data-outline], [data-cross] {
208
+ path.cross {
200
209
  fill: $white;
201
210
  }
202
211
 
203
- [data-fill] {
212
+ path.tint {
204
213
  fill: $c-grey-night;
205
214
  }
206
215
  }
@@ -8,11 +8,9 @@
8
8
  height: $size;
9
9
  margin: auto;
10
10
  width: $size;
11
- right: auto;
12
11
  z-index: 3;
13
12
  left: 1rem;
14
- bottom: 0;
15
- top: 0;
13
+ top: 1rem;
16
14
 
17
15
  @if $state != disabled {
18
16
  cursor: pointer;
@@ -9,11 +9,4 @@
9
9
  @include generic-input($state,$type);
10
10
  display: inline-block;
11
11
  margin: 0.25rem;
12
- }
13
-
14
- // margin: 0;
15
- // gap: 1rem;
16
-
17
- // &:not(:first-of-type) {
18
- // margin-top: 1rem;
19
- // }
12
+ }
@@ -3,5 +3,11 @@
3
3
  border: solid $border-width $c-border-strong;
4
4
  padding: 0.875rem 0.875rem 0.75rem;
5
5
  background-color: $c-grey-alpine;
6
- border-radius: $border-radius-lg;
6
+ border-radius: $border-radius-lg;
7
+ color: $c-grey-night;
8
+
9
+ &:disabled, &[readonly] {
10
+ background-color: $c-grey-alpine;
11
+ color: $c-grey-steel;
12
+ }
7
13
  }
@@ -0,0 +1,5 @@
1
+ <template>
2
+ <svg width="28" height="28" viewBox="0 0 24 24">
3
+ <path d="M3,21h3.8L17.8,9.9l-3.8-3.8L3,17.2V21z M5,18.1L14.1,9L15,9.9L5.9,19H5V18.1z M18.4,3.3c-0.4-0.4-1-0.4-1.4,0l-1.8,1.8 l3.8,3.8L20.7,7c0.4-0.4,0.4-1,0-1.4L18.4,3.3z"/>
4
+ </svg>
5
+ </template>
@@ -4,6 +4,7 @@ import VideoIcon from './video'
4
4
  import PaymentIcon from './payment'
5
5
  import OrdersIcon from './orders'
6
6
  import SupportIcon from './support'
7
+ import EditIcon from './edit'
7
8
 
8
9
  export {
9
10
  PersonalIcon,
@@ -11,5 +12,6 @@ export {
11
12
  VideoIcon,
12
13
  PaymentIcon,
13
14
  OrdersIcon,
14
- SupportIcon
15
+ SupportIcon,
16
+ EditIcon
15
17
  }
@@ -1,7 +1,7 @@
1
1
  <template>
2
- <svg width="28" viewBox="0 0 20 20">
3
- <path class="tint" fill="#fefbfa" d="M10,0C4.5,0,0,4.5,0,10s4.5,10,10,10s10-4.5,10-10S15.5,0,10,0z" />
4
- <path class="cross" fill="#353535" d="M10,0C4.5,0,0,4.5,0,10s4.5,10,10,10s10-4.5,10-10S15.5,0,10,0z M10,18c-4.4,0-8-3.6-8-8s3.6-8,8-8s8,3.6,8,8 S14.4,18,10,18z" />
5
- <path class="cross" fill="#353535" d="M12.6,6L10,8.6L7.4,6L6,7.4L8.6,10L6,12.6L7.4,14l2.6-2.6l2.6,2.6l1.4-1.4L11.4,10L14,7.4L12.6,6z" />
2
+ <svg width="28" height="28" viewBox="0 0 20 20">
3
+ <path class="tint" fill="#ffffff" d="M10,1c-4.9,0-9,4.1-9,9s4.1,9,9,9s9-4.1,9-9S14.9,1,10,1z"/>
4
+ <path class="cross" fill="#353535" d="M10,0C4.5,0,0,4.5,0,10s4.5,10,10,10s10-4.5,10-10S15.5,0,10,0z M10,18c-4.4,0-8-3.6-8-8s3.6-8,8-8 s8,3.6,8,8S14.4,18,10,18z M12.6,6L10,8.6L7.4,6L6,7.4L8.6,10L6,12.6L7.4,14l2.6-2.6l2.6,2.6l1.4-1.4L11.4,10L14,7.4L12.6,6z"/>
6
5
  </svg>
7
- </template>
6
+ </template>
7
+
package/index.js CHANGED
@@ -2,7 +2,6 @@ import Container from './components/container'
2
2
  import EventSummary from './components/event_summary'
3
3
  import AccountTitle from './components/account_title'
4
4
  import Wrap from './components/wrap'
5
- import Alert from './components/alert'
6
5
  import Loader from './components/loader'
7
6
  import RelatedTitle from './components/related_title'
8
7
  import RelatedCard from './components/related_card'
@@ -12,7 +11,6 @@ import Placeholder from './components/placeholder'
12
11
  import CardDisplay from './components/card_display'
13
12
  import FormSection from './components/form_section'
14
13
  import FormUpdate from './components/form_update'
15
- import FormGroup from './components/form_group'
16
14
  import RadioGroup from './components/radio_group'
17
15
  import FooterUpper from './components/footer_upper'
18
16
  import FooterLogos from './components/footer_logos'
@@ -22,11 +20,13 @@ import HelpRow from './components/help_row'
22
20
  import VideoContent from './components/video_content'
23
21
  import PaymentLogo from './components/payment_logo'
24
22
  import SkipLink from './components/skip_link'
23
+ import BrAlert from './components/br_alert'
25
24
  import BrButton from './components/br_button'
25
+ import BrFormGroup from './components/br_form_group'
26
26
 
27
27
  export {
28
28
  Loader,
29
- Alert,
29
+ BrAlert,
30
30
  RelatedTitle,
31
31
  RelatedCard,
32
32
  RelatedRow,
@@ -37,7 +37,7 @@ export {
37
37
  Placeholder,
38
38
  FormSection,
39
39
  FormUpdate,
40
- FormGroup,
40
+ BrFormGroup,
41
41
  RadioGroup,
42
42
  EventSummary,
43
43
  FooterUpper,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "barbican-reset",
3
- "version": "1.5.9",
3
+ "version": "1.6.2",
4
4
  "description": "A collection of useful scss imports and js scripts, that provide consistent styling and functionality across barbican projects.",
5
5
  "main": "index.js",
6
6
  "scripts": {
package/scss/_alert.scss CHANGED
@@ -56,10 +56,10 @@ $error_focus: $c-status-error, $c-status-error-fade;
56
56
 
57
57
  .wrap {
58
58
  @include wrap($neutral_wrap...);
59
- border-radius: $border-radius;
59
+ border-radius: $border-radius-lg;
60
60
  border-width: $border-width;
61
+ padding: 0.75rem 0.875rem;
61
62
  border-style: solid;
62
- padding: $space;
63
63
 
64
64
  .btn.btn-link, a {
65
65
  @include status_focus($neutral_focus...);
@@ -115,15 +115,7 @@ $error_focus: $c-status-error, $c-status-error-fade;
115
115
  display: flex;
116
116
  }
117
117
 
118
- .btn.exit {
119
- border-radius: 50%;
120
- border: none;
121
- padding: 0;
122
-
123
- @include focus {
124
- outline: 0.1875rem solid;
125
- box-shadow: none;
126
- }
118
+ .btn.btn-exit {
127
119
 
128
120
  &.error {
129
121
  @include exit($error_focus...);
package/scss/_btn.scss CHANGED
@@ -31,6 +31,10 @@
31
31
  @include btn-outline-secondary;
32
32
  }
33
33
 
34
+ &.btn-input-edit {
35
+ @include btn-input-edit;
36
+ }
37
+
34
38
  &.btn-remove {
35
39
  // solid grey, slim
36
40
  @include btn-remove;
@@ -0,0 +1,59 @@
1
+
2
+ .br-form-group {
3
+
4
+ &:not(:last-of-type) {
5
+ margin-bottom: 1rem;
6
+ }
7
+
8
+ @include media-breakpoint-up(sm) {
9
+ grid-template-columns: 33fr 67fr;
10
+ align-items: center;
11
+ gap: $gap-account;
12
+ display: grid;
13
+ }
14
+
15
+ label {
16
+ font-weight: normal;
17
+
18
+ @include media-breakpoint-down(sm) {
19
+ margin-bottom: 0.5rem;
20
+ }
21
+ }
22
+
23
+ input {
24
+ width: 100%;
25
+ margin: 0;
26
+ }
27
+
28
+ .content {
29
+
30
+ &.editable {
31
+ flex-direction: row-reverse;
32
+ display: flex;
33
+
34
+ input[type=text], input[type=email] {
35
+ border-bottom-right-radius: 0;
36
+ border-top-right-radius: 0;
37
+ border-right: none;
38
+ }
39
+ }
40
+
41
+ &:not(.label) {
42
+ @include media-breakpoint-up(sm) {
43
+ grid-column: 2 / 3;
44
+ }
45
+ }
46
+
47
+ &.submit {
48
+ justify-content: flex-end;
49
+ display: flex;
50
+ gap: 1rem;
51
+
52
+ @include media-breakpoint-down(sm) {
53
+ > button {
54
+ width: 100%;
55
+ }
56
+ }
57
+ }
58
+ }
59
+ }
package/scss/index.scss CHANGED
@@ -15,6 +15,7 @@
15
15
  @import "table/index";
16
16
  @import "promo";
17
17
  @import "alert";
18
+ @import "form-group";
18
19
 
19
20
  // bootstrap component styles
20
21
  @import "btn";
@@ -1,92 +0,0 @@
1
- <template>
2
- <div :class="$style.container">
3
- <label v-if="label" :for="id">
4
- <strong>{{ label }}</strong> <span v-if="label && required">(required)</span><span v-if="label && optional">(optional)</span>
5
- </label>
6
- <div :class="styleContent">
7
- <slot />
8
- </div>
9
- </div>
10
- </template>
11
-
12
- <script type="text/javascript">
13
- export default {
14
- name: 'FormGroup',
15
- props: {
16
- label: {
17
- type: String
18
- },
19
- required: {
20
- type: Boolean
21
- },
22
- optional: {
23
- type: Boolean
24
- },
25
- submit: {
26
- type: Boolean
27
- }
28
- },
29
- computed: {
30
- styleContent() {
31
- const style = this.$style;
32
- let output = [style.content];
33
- if (!this.label) { output.push(style.no_label); }
34
- if (this.submit) { output.push(style.submit); }
35
- return output;
36
- },
37
- id() {
38
- return this.label.toLowerCase().split(" ").join("_");
39
- }
40
- }
41
- }
42
- </script>
43
-
44
- <style lang="scss" module>
45
-
46
- .container {
47
-
48
- &:not(:last-of-type) {
49
- margin-bottom: 1rem;
50
- }
51
-
52
- @include media-breakpoint-up(sm) {
53
- grid-template-columns: 33fr 67fr;
54
- align-items: center;
55
- gap: $gap-account;
56
- display: grid;
57
- }
58
-
59
- label {
60
- font-weight: normal;
61
-
62
- @include media-breakpoint-down(sm) {
63
- margin-bottom: 0.5rem;
64
- }
65
- }
66
-
67
- input {
68
- width: 100%;
69
- margin: 0;
70
- }
71
- }
72
-
73
- .content {
74
-
75
- &.no_label {
76
- @include media-breakpoint-up(sm) {
77
- grid-column: 2 / 3;
78
- }
79
- }
80
-
81
- &.submit {
82
- text-align: right;
83
-
84
- @include media-breakpoint-down(sm) {
85
- > button {
86
- width: 100%;
87
- }
88
- }
89
- }
90
- }
91
-
92
- </style>