[%# This Source Code Form is subject to the terms of the Mozilla Public # License, v. 2.0. If a copy of the MPL was not distributed with this # file, You can obtain one at http://mozilla.org/MPL/2.0/. # # This Source Code Form is "Incompatible With Secondary Licenses", as # defined by the Mozilla Public License, v. 2.0. #%] [% PROCESS global/variables.none.tmpl %] [% items = [ { id => '' , name => 'Splendidest gear,' }, { id => '#185687' , name => 'Moleskine Notebook (Firefox)' }, { id => '#155749' , name => 'Rickshaw Messenger Bag' }, { id => '#155415S', name => 'Champion Hooded Sweatshirt S' }, { id => '#155415M', name => 'Champion Hooded Sweatshirt M' }, { id => '#155415L', name => 'Champion Hooded Sweatshirt L' }, { id => '#155415X', name => 'Champion Hooded Sweatshirt XL' }, { id => '#1554152', name => 'Champion Hooded Sweatshirt 2XL' }, { id => '#157452S', name => 'Very Splendid Package Ladies S' }, { id => '#157452M', name => 'Very Splendid Package Ladies M' }, { id => '#157452L', name => 'Very Splendid Package Ladies L' }, { id => '#157452X', name => 'Very Splendid Package Ladies XL' }, { id => '#157454S', name => 'Very Splendid Package Men\'s S' }, { id => '#157454M', name => 'Very Splendid Package Men\'s M' }, { id => '#157454L', name => 'Very Splendid Package Men\'s L' }, { id => '#157454X', name => 'Very Splendid Package Men\'s XL' }, { id => '#157451S', name => 'Most Splendid Package' }, { id => '#157451M', name => 'Most Splendid Package' }, { id => '#157451L', name => 'Most Splendid Package' }, { id => '#157451X', name => 'Most Splendid Package' }, { id => '' , name => 'Splendider gear,' }, { id => '#155341X', name => 'Unisex Firefox T-shirt Poppy XL' }, { id => '#1553412', name => 'Unisex Firefox T-shirt Poppy 2XL' }, { id => '#155344S', name => 'Ladies\' Firefox T-shirt Poppy S' }, { id => '#155344M', name => 'Ladies\' Firefox T-shirt Poppy M' }, { id => '#155344L', name => 'Ladies\' Firefox T-shirt Poppy L' }, { id => '#190928S', name => 'Unisex Firefox T-shirt Navy S' }, { id => '#190928M', name => 'Unisex Firefox T-shirt Navy M' }, { id => '#190928L', name => 'Unisex Firefox T-shirt Navy L' }, { id => '#190928X', name => 'Unisex Firefox T-shirt Navy XL' }, { id => '#1553422', name => 'Unisex Firefox T-shirt Navy 2XL*' }, { id => '#1553423', name => 'Unisex Firefox T-shirt Navy 3XL*' }, { id => '#155413S', name => 'Ladies\' Firefox T-shirt Navy S' }, { id => '#155413M', name => 'Ladies\' Firefox T-shirt Navy M' }, { id => '#155413L', name => 'Ladies\' Firefox T-shirt Navy L' }, { id => '#155413X', name => 'Ladies\' Firefox T-shirt Navy XL' }, { id => '#190929S', name => 'Unisex Firefox T-shirt Lapis S' }, { id => '#190929M', name => 'Unisex Firefox T-shirt Lapis M' }, { id => '#190929L', name => 'Unisex Firefox T-shirt Lapis L' }, { id => '#155343X', name => 'Unisex Firefox T-shirt Lapis XL' }, { id => '#155414S', name => 'Ladies\' Firefox T-shirt Lapis S' }, { id => '#155414M', name => 'Ladies\' Firefox T-shirt Lapis M' }, { id => '#155414L', name => 'Ladies\' Firefox T-shirt Lapis L' }, { id => '#155339' , name => 'Black Cap with Tote' }, { id => '#212669' , name => 'Stoneware Ceramic Mug' }, { id => '#155340' , name => 'Beanie' }, { id => '#155751' , name => 'Drawstring Tote' }, { id => '' , name => 'Splendid gear,' }, { id => '#192150' , name => '1.25" Firefox Button-PKG25' }, { id => '#197156' , name => 'Firefox Tattoos- Pkg50' }, { id => '#155754' , name => 'Lanyard with Bulldog Clip (Mozilla)' }, { id => '#197159' , name => 'Firefox Laminated Badge' }, { id => '#155756' , name => 'Silicone Wristband' }, { id => '#197158' , name => 'Firefox Sticker' }, { id => '' , name => 'Firefox OS gear,' }, { id => '#180593' , name => 'Moleskine Notebook (Firefox OS)' }, { id => '#180595' , name => 'Rubber Grip Pens Firefox OS' }, { id => '#187062' , name => 'OS Lanyard w/ Bulldog Clip' }, { id => '#180589' , name => 'Sunglasses Firefox OS' }, { id => '#189674' , name => '3" Firefox Mobilizer Sticker' }, { id => '#180792S', name => 'Firefox OS Tee Blueprint S' }, { id => '#180792M', name => 'Firefox OS Tee Blueprint M' }, { id => '#180792L', name => 'Firefox OS Tee Blueprint L' }, { id => '#180792X', name => 'Firefox OS Tee Blueprint XL' }, { id => '#1807922', name => 'Firefox OS Tee Blueprint 2XL' }, { id => '#182464S', name => 'Firefox OS Ladies Teal Tee S' }, { id => '#182464M', name => 'Firefox OS Ladies Teal Tee M' }, { id => '#182464L', name => 'Firefox OS Ladies Teal Tee L' }, { id => '#182464X', name => 'Firefox OS Ladies Teal Tee XL' }, { id => '#1824642', name => 'Firefox OS Ladies Teal Tee 2XL' }, { id => '#182465S', name => 'Firefox OS Teal Tee S' }, { id => '#182465M', name => 'Firefox OS Teal Tee M' }, { id => '#182465L', name => 'Firefox OS Teal Tee L' }, { id => '#182465X', name => 'Firefox OS Teal Tee XL' }, { id => '#1824652', name => 'Firefox OS Teal Tee 2XL' }, { id => '#1824653', name => 'Firefox OS Teal Tee 3XL' }, { id => '#1824654', name => 'Firefox OS Teal Tee 4XL' }, ]; mozspaces = [ { name => 'Beijing', address1 => 'Mozilla Online Ltd, International Club Office Tower 800A', address2 => '21 Jian Guo Men Wai Avenue', city => 'Beijing', state => 'Chaoyang District', country => 'China', postcode => '100020', }, { name => 'Berlin', address1 => 'MZ Denmark ApS - Germany', address2 => 'Voltastrasse 5 / Building (Haus) 10 / Stair (Treppe) 6 / 2nd floor.', city => 'Berlin', state => 'Germany', country => 'Germany', postcode => '13355', }, { name => 'London', address1 => 'Mozilla London', address2 => '101 St. Martin\'s Lane, 3rd Floor', city => 'London', state => 'Greater London', country => 'UK', postcode => 'WC2N 4AZ', }, { name => 'Mountain View', address1 => 'Mozilla', address2 => '331 E. Evelyn Ave.', city => 'Mountain View', state => 'CA', country => 'USA', postcode => '94041', }, { name => 'Paris', address1 => 'Mozilla', address2 => '16 bis Boulevard Montmartre', city => 'Paris', state => 'Paris', country => 'France', postcode => '75009', }, { name => 'Portland', address1 => 'Mozilla Portland', address2 => 'Brewery Block 2, 1120 NW Couch St. Suite 320', city => 'Portland', state => 'OR', country => 'USA', postcode => '97209', }, { name => 'San Francisco', address1 => 'Mozilla', address2 => '2 Harrison Street, Suite 175', city => 'San Francisco', state => 'CA', country => 'USA', postcode => '94105', }, { name => 'Taipei', address1 => '4F-A1, No. 106, Sec.5, Xinyi Rd', address2 => '', city => 'Taipei City', state => 'Xinyi District', country => 'Taiwan', postcode => '11047', }, { name => 'Tokyo', address1 => '7-5-6 Roppongi', address2 => '', city => 'Minato-ku', state => 'Tokyo', country => 'Japan', postcode => '106-0032', }, { name => 'Toronto', address1 => 'Mozilla Canada', address2 => '366 Adelaide Street W, Suite 500', city => 'Toronto', state => 'Ontario', country => 'Canada', postcode => 'M5V 1R9', }, { name => 'Vancouver', address1 => 'Mozilla Canada', address2 => '163 West Hastings Street, Suite 209', city => 'Vancouver', state => 'BC', country => 'Canada', postcode => 'V6B 1H5', }, ]; PROCESS "bug/create/cost-centers.none.tmpl"; %] [% inline_style = BLOCK %] #gear_form th { text-align: right; font-weight: normal; } #gear_form .heading { text-align: left; font-weight: bold; border-top: 2px dotted #969696; } .mandatory { color: red; } [% END %] [% inline_javascript = BLOCK %] var Dom = YAHOO.util.Dom; var needed = { [% FOREACH item = items %] [% NEXT UNLESS item.id %] '[% item.id FILTER js %]': 0[% ',' UNLESS loop.last %] [% END %] }; var needed_freeform = []; var gear = [ [% FOREACH item = items %] { id: '[% item.id FILTER js %]', name: '[% item.name FILTER js %]' } [% ',' UNLESS loop.last %] [% END %] ]; var mozspaces = { [% FOREACH space = mozspaces %] '[% space.name FILTER js %]': { [% FOREACH key = space.keys.sort %] '[% key FILTER js %]': '[% space.$key FILTER js %]'[% ',' UNLESS loop.last %] [% END %] }[% ',' UNLESS loop.last %] [% END %] }; [%# implemented this way to allow for dynamic updating of mandatory fields #%] var fields = [ { id: 'firstname', mandatory: true }, { id: 'lastname', mandatory: true }, { id: 'email', mandatory: true }, { id: 'mozspace', mandatory: false }, { id: 'teamcode', mandatory: true }, { id: 'purpose', mandatory: true }, { id: 'purpose_other', mandatory: false }, { id: 'date_required', mandatory: false }, { id: 'items', mandatory: true }, { id: 'shiptofirstname', mandatory: true }, { id: 'shiptolastname', mandatory: true }, { id: 'shiptoemail', mandatory: true }, { id: 'shiptoaddress1', mandatory: true }, { id: 'shiptoaddress2', mandatory: false }, { id: 'shiptocity', mandatory: true }, { id: 'shiptostate', mandatory: true }, { id: 'shiptocountry', mandatory: true }, { id: 'shiptopostcode', mandatory: true }, { id: 'shiptophone', mandatory: true }, { id: 'shiptoidrut', mandatory: false }, { id: 'comment', mandatory: false } ]; function initFields() { [%# find fields in the form, and update the fields array #%] var rows = Dom.get('gear_form').getElementsByTagName('TR'); for (var i = 0, l = rows.length; i < l; i++) { var row = rows[i]; var field = firstChild(row, 'INPUT') || firstChild(row, 'SELECT') || firstChild(row, 'TEXTAREA'); if (!field || field.type == 'submit') continue; var id = field.id; var label = firstChild(row, 'TH'); for (var j = 0, m = fields.length; j < m; j++) { if (fields[j].id == id) { fields[j].field = field; fields[j].label = label; fields[j].caption = label.textContent; break; } } } createCalendar('date_required'); } function tagMandatoryFields() { [%# add or remove the "* mandatory" marker from fields #%] for (var i = 0, l = fields.length; i < l; i++) { var f = fields[i]; if (!f.label) continue; var caption = f.caption; if (f.mandatory) caption = caption + ' *'; f.label.innerHTML = caption; } } function validateAndSubmit() { var alert_text = ''; for(var i = 0, l = fields.length; i < l; i++) { var f = fields[i]; if (f.mandatory && !isFilledOut(f.id)) if (f.field.nodeName == 'SELECT') { alert_text += 'Please select the ' + f.caption + ".\n"; } else { alert_text += 'Please enter the ' + f.caption + ".\n"; } } if (isFilledOut('email') && !isValidEmail(Dom.get('email').value)) alert_text += "Please enter a valid Email Address.\n"; if (isFilledOut('shiptoemail') && !isValidEmail(Dom.get('shiptoemail').value)) alert_text += "Please enter a valid Shipping Email Address.\n"; if (alert_text != '') { alert(alert_text); return false; } Dom.get('short_desc').value = 'Mozilla Gear - ' + Dom.get('firstname').value + ' ' + Dom.get('lastname').value; return true; } function onPurposeChange() { var value = Dom.get('purpose').value; var other = Dom.get('purpose_other'); if (value == 'Event') { getField('purpose_other').mandatory = true; other.placeholder = 'link to wiki' Dom.removeClass('purpose_other_row', 'bz_default_hidden'); Dom.addClass('recognition_row', 'bz_default_hidden'); } else if (value == 'Gear Space Stock') { getField('purpose_other').mandatory = true; other.placeholder = 'indicate space' Dom.removeClass('purpose_other_row', 'bz_default_hidden'); Dom.addClass('recognition_row', 'bz_default_hidden'); } else if (value == 'Other') { getField('purpose_other').mandatory = true; other.placeholder = 'more information'; Dom.removeClass('purpose_other_row', 'bz_default_hidden'); Dom.addClass('recognition_row', 'bz_default_hidden'); } else if (value == 'Mozillian Recognition') { getField('purpose_other').mandatory = false; Dom.addClass('purpose_other_row', 'bz_default_hidden'); Dom.removeClass('recognition_row', 'bz_default_hidden'); onRecognitionChange(); } else { getField('purpose_other').mandatory = false; Dom.addClass('purpose_other_row', 'bz_default_hidden'); Dom.addClass('recognition_row', 'bz_default_hidden'); } onRecognitionChange(); } function onRecognitionChange() { var mandatory = Dom.get('purpose').value != 'Mozillian Recognition' || !Dom.get('recognition_shipping').checked; getField('shiptoaddress1').mandatory = mandatory; getField('shiptocity').mandatory = mandatory; getField('shiptostate').mandatory = mandatory; getField('shiptocountry').mandatory = mandatory; getField('shiptopostcode').mandatory = mandatory; getField('shiptophone').mandatory = mandatory; tagMandatoryFields(); } function onMozSpaceChange() { if (Dom.get('mozspace').value) { Dom.removeClass('shipto_mozspace_container', 'bz_default_hidden'); } else { Dom.addClass('shipto_mozspace_container', 'bz_default_hidden'); } onShipToMozSpaceClick(); } function onShipToMozSpaceClick() { var address1 = address2 = city = state = country = postcode = ''; if (Dom.get('shipto_mozspace').checked) { var space = Dom.get('mozspace').value; address1 = mozspaces[space].address1; address2 = mozspaces[space].address2; city = mozspaces[space].city; state = mozspaces[space].state; country = mozspaces[space].country; postcode = mozspaces[space].postcode; } Dom.get('shiptoaddress1').value = address1; Dom.get('shiptoaddress2').value = address2; Dom.get('shiptocity').value = city; Dom.get('shiptostate').value = state; Dom.get('shiptocountry').value = country; Dom.get('shiptopostcode').value = postcode; Dom.get('shiptophone').value = ''; Dom.get('shiptoidrut').value = ''; onRecognitionChange(); } function onAddGearChange(focusInput) { var add_gear = Dom.get('add_gear').value; var isFreeform = add_gear == 'custom' || add_gear == 'other'; if (isFreeform) { Dom.addClass('quantity', 'bz_default_hidden'); resetFreeform(); Dom.get('freeform_quantity').value = Dom.get('quantity').value; Dom.removeClass('freeform_quantity', 'bz_default_hidden'); Dom.removeClass('add_freeform', 'bz_default_hidden'); if (focusInput) Dom.get('freeform_add').focus(); } else { Dom.get('quantity').value = Dom.get('freeform_quantity').value; Dom.removeClass('quantity', 'bz_default_hidden'); Dom.addClass('freeform_quantity', 'bz_default_hidden'); Dom.addClass('add_freeform', 'bz_default_hidden'); } } function firstChild(parent, name) { var a = parent.getElementsByTagName(name); return a.length == 0 ? false : a[0]; } function getField(id) { for(var i = 0, l = fields.length; i < l; i++) { if (fields[i].id == id) return fields[i]; } return false; } function addGear() { var id = Dom.get('add_gear').value; if (id == 'custom' || id == 'other') { var quantity = parseInt(Dom.get('freeform_quantity').value, 10); var name = Dom.get('freeform_add').value; if (!quantity || !name) return; needed_freeform.push({ 'type': id, 'quantity': quantity, 'name': name }); Dom.get('add_gear').value = ''; resetFreeform(); onAddGearChange(); } else { var quantity = parseInt(Dom.get('quantity').value, 10); if (!quantity || !id) return; needed[id] += quantity; } showGear(); } function resetFreeform() { Dom.get('freeform_quantity').value = '1'; Dom.get('freeform_add').value = ''; } function removeGear(id) { if (!id) return; needed[id] = 0; showGear(); } function removeFreeform(index) { needed_freeform.splice(index, 1); showGear(); } function showGear() { var html = '
' + needed[id] + ' x | ' + '' + YAHOO.lang.escapeHTML(item.name) + ' | ' + '' + ' |
' + item.quantity + ' x | ' + '(' + item.type + ') ' + YAHOO.lang.escapeHTML(item.name) + ' | ' + '' + ' |
No gear selected. |
Want gear? Follow the steps below and click Submit Request.
Requests are reviewed and processed on Monday morning (US/Pacific). Any requests received after 9am Monday will be processed the following week.
Check the gear wiki for more information about gear, including approved uses and the list of available gear.
Gear requests for Rep-driven events and campaigns should continue to be submitted through their existing process.
* Required Field
Requests will only be visible to the person who submitted it, authorized members of the Mozilla Engagement team, and our Staples Customer Service rep. We do this to help protect the personal identifying information in this [% terms.bugs %].
[% PROCESS global/footer.html.tmpl %]