Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Submission for Reference Types Lab #212

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
80 changes: 76 additions & 4 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,22 +4,94 @@
* @param {Object} store - An object representing a single store. See the instructions for details on its shape.
* @returns {Object[]} The same `stores` array that was inputted.
*/
function addNewStore(stores, store) {}


/*
WRONG ANSWER WAS {
stores.unshift[store]
return(stores)}
*/

function addNewStore(stores, store) {
stores.push(store); //push adds the input in the paranthesis to the end of the stores array
return stores;
}

/**
* Removes a store object at the given position.
* @param {Object[]]} stores - An array of store objects.
* @param {number} index - A number representing the index of the store to be removed from the array.
* @returns {Object[]} The same `stores` array that was inputted.
*/
function removeStoreAtPosition(stores, index) {}

/carina

*/
function removeStoreAtPosition(stores, index) {
stores.splice(index, 1);
return stores;
}





/**
* Creates a duplicate of the `store` object. No references should be shared between the inputted `store` and the result.
* @param {Object} store - An object representing a single store. See the instructions for details on its shape.
* @returns {Object} The duplicated store object. This should not be the same as the store that was inputted.
*/
function duplicateStore(store) {}
function duplicateStore(store) {
let storeCopy = {}; //objectCopy will store a copy of the store
let key;
for (key in store) { //'in' is an inbuilt operator in JS which is used to check if a particular property exists in an object or not
storeCopy[key] = store[key]; //copies each property to the objectCopy object
}
store.boardGames = ["Monopoly","Parcheesi","Funtimes"]
store.address = {
street: "8675 309th Street",
city: "Lulav",
state: "HI",
zip: "09898",
}
return storeCopy;
}


/**
const store = {
name: "Gamestoria",
boardGames: [
"Terra Mystica",
"Alhambra",
"Scythe",
"Carcassonne",
"Azul",
],
address: {
street: "42-11 Broadway",
city: "Astoria",
state: "NY",
zip: "11103",
},
};

let copyStore = {};
let keys = Object.keys(store);
for (let i = 0; len = keys.length; i < len, i++) {
copyStore[keys] = store[keys];
}
return copyStore
*/

// const sheeps = ['🐑', '🐑'];
// const sheeps2 = sheeps;
// sheeps2.push('🐺');
// console.log(sheeps2);
// // [ '🐑', '🐑', '🐺' ]

// // Ahhh 😱 , our original sheeps have changed?!
// console.log(sheeps);
// // [ '🐑', '🐑', '🐺' ]

module.exports = {
addNewStore,
Expand Down
70 changes: 40 additions & 30 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.