Comments (4)
Wondering if we should not expose these util methods outside the library publically (and just use them internally) since there might be some overlap with other libraries out there.
Or... maybe a select few functions in it should be public?
from pnp-js-core.
I like having some of them exposed for doing things that are clunky. However I think they should be exposed via their own classes instead of through a 'Util' class (most obvious crime against separation of concerns)
from pnp-js-core.
Where possible I want to avoid referencing other libraries since it would force a consumer to also include that lib to use ours. The dateAdd is there because I needed something for the cache expire stuff. I don't really want to handle dates universally. IsFunction is similar, we need that test and it takes up three lines, so I prefer not to take a dep to get three lines of code. Some of the other util methods are there because they are things I have used regularly in the past and were part of the js core from which this was derived. getRansomString forex I often use when creating dynamic DOM elements that need an ID. Always want to keep the conversation going on what makes sense vs. what doesn't, but I am OK with what we have currently.
We do currently expose them through pnp.util on the root object which simulates a class to the consumer.
from pnp-js-core.
Going to close this issue - I think we are in agreement that we need to limit the utility code we write, while keeping a focus on not taking dependencies for a few lines of code in some other library. In other words I think take what we absolutely need to make our library work. Then folks can use whatever they want outside that in their projects.
from pnp-js-core.
Related Issues (20)
- return type for getAll HOT 2
- Handling HTTP 400 Errors via catch HOT 2
- Qustion: The field 'xxxx' is not supported in query. The lookup list is in another web. HOT 1
- [Question]: Retrieve all files within a document library HOT 2
- multiple delete does not work with String Array! HOT 3
- Sharing Site collection to an external user HOT 1
- Uploading package to app catalog HOT 4
- Is it possible to fetch data from client side modern page and show it into a new page SPFX HOT 2
- A call to contextInfo is being made by each spfx webpart. HOT 1
- When I try to upload large file on SharePoint 2013 On-Premise it gives error Resource not found HOT 1
- UserProfile MyProperties with error 500 HOT 2
- Cannot get FileRef from getItemsByCAMLQuery method HOT 1
- how to add field to view? HOT 2
- Trying to update sharepoint library metadata column using pnp js HOT 1
- IncludeGroupsSites doesnt work in the sp.social.my.followed(SocialActorTypes.IncludeGroupsSites) HOT 1
- Using Angular@6 util.js error HOT 3
- Having issues adding User and Lookup fields to List HOT 2
- How to get specific version of item? HOT 3
- Ability to view/add/remove Site Collection Admins? HOT 2
- SPFX and AD Groups Permissions HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from pnp-js-core.